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
|
|
@ -56,7 +56,7 @@ enum codec_status codec_main(void)
|
|||
uint32_t s = 0; /* sample rate */
|
||||
unsigned char c = 0; /* channels */
|
||||
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);
|
||||
|
|
@ -70,8 +70,10 @@ next_track:
|
|||
return CODEC_ERROR;
|
||||
}
|
||||
|
||||
while (!*ci->taginfo_ready && !ci->stop_codec)
|
||||
ci->sleep(1);
|
||||
if (codec_wait_taginfo() != 0)
|
||||
goto done;
|
||||
|
||||
resume_offset = ci->id3->offset;
|
||||
|
||||
ci->memset(&rmctx,0,sizeof(RMContext));
|
||||
ci->memset(&pkt,0,sizeof(RMPacket));
|
||||
|
|
@ -224,8 +226,6 @@ seek_start:
|
|||
ci->advance_buffer(pkt.length);
|
||||
}
|
||||
|
||||
err = CODEC_OK;
|
||||
|
||||
done:
|
||||
if (ci->request_next_track())
|
||||
goto next_track;
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue