From 9c70b1b562ce9e5047f814f8613f5cda4f436d14 Mon Sep 17 00:00:00 2001 From: Miika Pekkarinen Date: Sat, 2 Jul 2005 17:03:19 +0000 Subject: Make sure we stop the playback the right way. git-svn-id: svn://svn.rockbox.org/rockbox/trunk@6987 a1c6a512-1295-4272-9138-f99709370657 --- apps/playback.c | 50 ++++++++++++++++++++++---------------------------- 1 file changed, 22 insertions(+), 28 deletions(-) (limited to 'apps') diff --git a/apps/playback.c b/apps/playback.c index 3a5eeb328f..291f45eea3 100644 --- a/apps/playback.c +++ b/apps/playback.c @@ -1121,6 +1121,23 @@ void audio_update_trackinfo(void) audiobuffer_add_event(codec_track_changed); } +static void audio_stop_playback(void) +{ + paused = false; + playing = false; + ci.stop_codec = true; + if (current_fd >= 0) { + close(current_fd); + current_fd = -1; + } + pcm_play_stop(); + pcm_play_pause(true); + track_count = 0; + filling = true; + audio_clear_track_entries(); + filling = false; +} + void audio_change_track(void) { logf("change track"); @@ -1128,9 +1145,7 @@ void audio_change_track(void) logf("No more tracks"); while (pcm_is_playing()) yield(); - track_count = 0; - audio_clear_track_entries(); - playing = false; + audio_stop_playback(); return ; } @@ -1257,18 +1272,7 @@ void audio_thread(void) break ; case AUDIO_STOP: - paused = false; - filling = false; - playing = false; - ci.stop_codec = true; - if (current_fd >= 0) { - close(current_fd); - current_fd = -1; - } - pcm_play_stop(); - pcm_play_pause(true); - track_count = 0; - audio_clear_track_entries(); + audio_stop_playback(); break ; case AUDIO_PAUSE: @@ -1296,14 +1300,8 @@ void audio_thread(void) #ifndef SIMULATOR case SYS_USB_CONNECTED: - track_count = 0; - audio_clear_track_entries(); - playing = false; - filling = false; - ci.stop_codec = true; logf("USB Connection"); - pcm_play_stop(); - pcm_play_pause(true); + audio_stop_playback(); usb_acknowledge(SYS_USB_CONNECTED_ACK); usb_wait_for_disconnect(&audio_queue); break ; @@ -1334,9 +1332,7 @@ void codec_thread(void) codecsize = cur_ti->codecsize; if (codecsize == 0) { logf("Codec slot is empty!"); - track_count = 0; - audio_clear_track_entries(); - playing = false; + audio_stop_playback(); break ; } @@ -1363,9 +1359,7 @@ void codec_thread(void) if (status != CODEC_OK) { logf("Codec failure"); splash(HZ*2, true, "Codec failure"); - track_count = 0; - audio_clear_track_entries(); - playing = false; + audio_stop_playback(); } else { logf("Codec finished"); } -- cgit v1.2.3