From 3dedcfc454c88d585bc7822509fb254532616eab Mon Sep 17 00:00:00 2001 From: Michael Giacomelli Date: Mon, 22 Sep 2008 01:29:50 +0000 Subject: Hopefully fix glitches when seeking in MP3s on dual core processors. Also, clean up initialization and preprocessor commands. git-svn-id: svn://svn.rockbox.org/rockbox/trunk@18563 a1c6a512-1295-4272-9138-f99709370657 --- apps/codecs/mpa.c | 14 +++++++++++--- 1 file changed, 11 insertions(+), 3 deletions(-) (limited to 'apps') diff --git a/apps/codecs/mpa.c b/apps/codecs/mpa.c index c916aefcaa..e81d8d96c0 100644 --- a/apps/codecs/mpa.c +++ b/apps/codecs/mpa.c @@ -25,8 +25,7 @@ CODEC_HEADER -#if (CONFIG_CPU == PP5024 || CONFIG_CPU == PP5022 || CONFIG_CPU == PP5020 \ - || CONFIG_CPU == PP5002) && !defined(MPEGPLAYER) +#if defined(CPU_PP) && !defined(MPEGPLAYER) #define MPA_SYNTH_ON_COP #endif @@ -64,8 +63,12 @@ void init_mad(void) ci->memset(&frame, 0, sizeof(struct mad_frame)); ci->memset(&synth, 0, sizeof(struct mad_synth)); + ci->memset(&sbsample, 0, sizeof(sbsample)); + #ifdef MPA_SYNTH_ON_COP frame.sbsample_prev = &sbsample_prev; + ci->memset(&sbsample_prev, 0, sizeof(sbsample_prev)); + synth_running=0; #else frame.sbsample_prev = &sbsample; #endif @@ -358,10 +361,15 @@ next_track: ci->yield(); if (ci->stop_codec || ci->new_track) break; - + if (ci->seek_time) { int newpos; +#ifdef MPA_SYNTH_ON_COP + /*make sure the synth thread is idle before seeking*/ + if(synth_running) + mad_synth_thread_wait_pcm(); +#endif samplesdone = ((int64_t)(ci->seek_time-1))*current_frequency/1000; if (ci->seek_time-1 == 0) { -- cgit v1.2.3