diff --git a/res/res_musiconhold.c b/res/res_musiconhold.c index 137f83bac79bfa91c5e26c3379e4d8eb47d51b00..5c739ab8fdc95b6fb873bf523c4e7b3e736197b9 100644 --- a/res/res_musiconhold.c +++ b/res/res_musiconhold.c @@ -402,11 +402,28 @@ static int ast_moh_files_next(struct ast_channel *chan) static struct ast_frame *moh_files_readframe(struct ast_channel *chan) { - struct ast_frame *f = NULL; - - if (!(ast_channel_stream(chan) && (f = ast_readframe(ast_channel_stream(chan))))) { - if (!ast_moh_files_next(chan)) + struct ast_frame *f; + + f = ast_readframe(ast_channel_stream(chan)); + if (!f) { + /* Either there was no file stream setup or we reached EOF. */ + if (!ast_moh_files_next(chan)) { + /* + * Either we resetup the previously saved file stream position + * or we started a new file stream. + */ f = ast_readframe(ast_channel_stream(chan)); + if (!f) { + /* + * We can get here if we were very unlucky because the + * resetup file stream was saved at EOF when MOH was + * previously stopped. + */ + if (!ast_moh_files_next(chan)) { + f = ast_readframe(ast_channel_stream(chan)); + } + } + } } return f;