mirror of
https://github.com/Rockbox/rockbox.git
synced 2025-10-14 02:27:39 -04:00
r29348 changes can cause certain codecs to jump to code on early track change that assumes initializations have been done. Make sure that track change cleanups are only called if the state is sane to do so. Stops my vorbis data abort issue. Correctness for speex is a guess based on the library calls' source. It appears only speex/vorbis should have been bothered by said revision.
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@29489 a1c6a512-1295-4272-9138-f99709370657
This commit is contained in:
parent
6170ded83d
commit
b3bfc09852
2 changed files with 12 additions and 4 deletions
|
@ -393,6 +393,9 @@ enum codec_status codec_main(void)
|
|||
void *st = NULL;
|
||||
int j = 0;
|
||||
|
||||
memset(&bits, 0, sizeof(bits));
|
||||
memset(&oy, 0, sizeof(oy));
|
||||
|
||||
/* Ogg handling still uses mallocs, so reset the malloc buffer per track */
|
||||
next_track:
|
||||
error = CODEC_OK;
|
||||
|
@ -401,16 +404,16 @@ next_track:
|
|||
error = CODEC_ERROR;
|
||||
goto exit;
|
||||
}
|
||||
|
||||
stereo = speex_stereo_state_init();
|
||||
spx_ogg_sync_init(&oy);
|
||||
spx_ogg_alloc_buffer(&oy,2*CHUNKSIZE);
|
||||
|
||||
if (codec_wait_taginfo() != 0)
|
||||
goto done;
|
||||
|
||||
strtoffset = ci->id3->offset;
|
||||
|
||||
spx_ogg_sync_init(&oy);
|
||||
spx_ogg_alloc_buffer(&oy,2*CHUNKSIZE);
|
||||
|
||||
samplerate = ci->id3->frequency;
|
||||
codec_set_replaygain(ci->id3);
|
||||
|
||||
|
@ -558,6 +561,7 @@ done:
|
|||
|
||||
/* Clean things up for the next track */
|
||||
|
||||
if (st)
|
||||
speex_decoder_destroy(st);
|
||||
|
||||
if (stream_init == 1)
|
||||
|
|
|
@ -110,6 +110,7 @@ enum codec_status codec_main(void)
|
|||
OggVorbis_File vf;
|
||||
ogg_int32_t **pcm;
|
||||
|
||||
bool initialized = false; /* First init done? */
|
||||
int error;
|
||||
long n;
|
||||
int current_section;
|
||||
|
@ -185,6 +186,7 @@ next_track:
|
|||
vf.end = ci->id3->filesize;
|
||||
vf.ready_state = OPENED;
|
||||
vf.links = 1;
|
||||
initialized = true;
|
||||
} else {
|
||||
DEBUGF("Vorbis: ov_open failed: %d\n", error);
|
||||
error = CODEC_ERROR;
|
||||
|
@ -248,6 +250,8 @@ done:
|
|||
ogg_malloc_destroy();
|
||||
|
||||
if (ci->request_next_track()) {
|
||||
if (!initialized)
|
||||
goto next_track;
|
||||
/* Clean things up for the next track */
|
||||
vf.dataoffsets = NULL;
|
||||
vf.offsets = NULL;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue