diff options
| author | Michael Sevakis <jethead71@rockbox.org> | 2011-02-20 15:27:10 +0000 |
|---|---|---|
| committer | Michael Sevakis <jethead71@rockbox.org> | 2011-02-20 15:27:10 +0000 |
| commit | 85e40257dc65e3542b785898ddf60482e2d1ab0c (patch) | |
| tree | f7bf9b33decce4296fbea0f437252f40aba6d5de /apps/codecs/ape.c | |
| parent | 460d54977ae2f9c2c5997c6c4cd5541ab436d718 (diff) | |
| download | rockbox-85e40257dc65e3542b785898ddf60482e2d1ab0c.zip rockbox-85e40257dc65e3542b785898ddf60482e2d1ab0c.tar.gz rockbox-85e40257dc65e3542b785898ddf60482e2d1ab0c.tar.bz2 rockbox-85e40257dc65e3542b785898ddf60482e2d1ab0c.tar.xz | |
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
Diffstat (limited to 'apps/codecs/ape.c')
| -rw-r--r-- | apps/codecs/ape.c | 17 |
1 files changed, 7 insertions, 10 deletions
diff --git a/apps/codecs/ape.c b/apps/codecs/ape.c index 06e8842..11d973a 100644 --- a/apps/codecs/ape.c +++ b/apps/codecs/ape.c @@ -149,22 +149,21 @@ enum codec_status codec_main(void) /* Generic codec initialisation */ ci->configure(DSP_SET_SAMPLE_DEPTH, APE_OUTPUT_DEPTH-1); - next_track: - +next_track: retval = CODEC_OK; - /* Remember the resume position - when the codec is opened, the - playback engine will reset it. */ - resume_offset = ci->id3->offset; - if (codec_init()) { LOGF("APE: Error initialising codec\n"); retval = CODEC_ERROR; goto exit; } - while (!*ci->taginfo_ready && !ci->stop_codec) - ci->sleep(1); + if (codec_wait_taginfo() != 0) + goto done; + + /* Remember the resume position - when the codec is opened, the + playback engine will reset it. */ + resume_offset = ci->id3->offset; inbuffer = ci->request_buffer(&bytesleft, INPUT_CHUNKSIZE); @@ -319,8 +318,6 @@ frame_start: currentframe++; } - retval = CODEC_OK; - done: LOGF("APE: Decoded %lu samples\n",(unsigned long)samplesdone); |