summaryrefslogtreecommitdiff
path: root/apps/codecs/a52_rm.c
diff options
context:
space:
mode:
authorMichael Sevakis <jethead71@rockbox.org>2011-02-20 15:27:10 +0000
committerMichael Sevakis <jethead71@rockbox.org>2011-02-20 15:27:10 +0000
commit85e40257dc65e3542b785898ddf60482e2d1ab0c (patch)
treef7bf9b33decce4296fbea0f437252f40aba6d5de /apps/codecs/a52_rm.c
parent460d54977ae2f9c2c5997c6c4cd5541ab436d718 (diff)
downloadrockbox-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/a52_rm.c')
-rw-r--r--apps/codecs/a52_rm.c13
1 files changed, 8 insertions, 5 deletions
diff --git a/apps/codecs/a52_rm.c b/apps/codecs/a52_rm.c
index bc6c129..f5e4923 100644
--- a/apps/codecs/a52_rm.c
+++ b/apps/codecs/a52_rm.c
@@ -132,20 +132,24 @@ enum codec_status codec_main(void)
uint8_t *filebuf;
int retval, consumed, packet_offset;
int playback_on = -1;
- size_t resume_offset = ci->id3->offset;
+ size_t resume_offset;
/* Generic codec initialisation */
ci->configure(DSP_SET_STEREO_MODE, STEREO_NONINTERLEAVED);
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;
+
+ resume_offset = ci->id3->offset;
ci->configure(DSP_SWITCH_FREQUENCY, ci->id3->frequency);
codec_set_replaygain(ci->id3);
@@ -201,8 +205,7 @@ next_track:
ci->advance_buffer(pkt.length);
}
- retval = CODEC_OK;
-
+request_next_track:
if (ci->request_next_track())
goto next_track;