forked from len0rd/rockbox
Enforce that codecs wait for their metadata in a proper-ish and consistent manner. Sort of a halfway patch; best would be to give them an internal copy of the current track information which lasts unaltered by playback until a track switch or unload.
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@29348 a1c6a512-1295-4272-9138-f99709370657
This commit is contained in:
parent
460d54977a
commit
85e40257dc
34 changed files with 171 additions and 125 deletions
|
@ -128,13 +128,15 @@ enum codec_status codec_main(void)
|
|||
ci->configure(DSP_SET_SAMPLE_DEPTH, 28);
|
||||
|
||||
next_track:
|
||||
retval = CODEC_OK;
|
||||
|
||||
if (codec_init()) {
|
||||
retval = CODEC_ERROR;
|
||||
goto exit;
|
||||
}
|
||||
|
||||
while (!ci->taginfo_ready)
|
||||
ci->yield();
|
||||
if (codec_wait_taginfo() != 0)
|
||||
goto request_next_track;
|
||||
|
||||
ci->configure(DSP_SWITCH_FREQUENCY, ci->id3->frequency);
|
||||
codec_set_replaygain(ci->id3);
|
||||
|
@ -176,8 +178,8 @@ next_track:
|
|||
a52_decode_data(filebuf, filebuf + n);
|
||||
ci->advance_buffer(n);
|
||||
}
|
||||
retval = CODEC_OK;
|
||||
|
||||
request_next_track:
|
||||
if (ci->request_next_track())
|
||||
goto next_track;
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue