summaryrefslogtreecommitdiff
path: root/src/main.c
diff options
context:
space:
mode:
authorLars-Dominik Braun <PromyLOPh@lavabit.com>2010-03-16 15:14:51 +0100
committerLars-Dominik Braun <PromyLOPh@lavabit.com>2010-03-16 15:14:51 +0100
commit13bd3c8253a5c2998ce85a084a854f7a3d0ba7f5 (patch)
treec25b8b8e5042de6dc1dae102a5067c3732468fea /src/main.c
parentc7690562ee0963e6cd3af973e34c388347e24190 (diff)
downloadpianobar-13bd3c8253a5c2998ce85a084a854f7a3d0ba7f5.tar.gz
pianobar-13bd3c8253a5c2998ce85a084a854f7a3d0ba7f5.tar.bz2
pianobar-13bd3c8253a5c2998ce85a084a854f7a3d0ba7f5.zip
Fix player race condition
Pressing any key before the player thread set mode to PLAYER_INITIALIZED lead to a song skip and spawning of another player thread. The two player threads were operating on the same variables/memory area, resulting in a crash. Adding a new player state (PLAYER_STARTING) and setting it _before_ invoking pthread_start should resolve this, 'cause the "if PLAYER_FREED-branch" is not taken any more, ergo no second player thread is started.
Diffstat (limited to 'src/main.c')
-rw-r--r--src/main.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/src/main.c b/src/main.c
index 82ed674..5428653 100644
--- a/src/main.c
+++ b/src/main.c
@@ -248,6 +248,9 @@ int main (int argc, char **argv) {
BarUiStartEventCmd (&settings, "songstart", curStation,
playlist, &player, PIANO_RET_OK);
+ /* prevent race condition, mode must _not_ be FREED if
+ * thread has been started */
+ player.mode = PLAYER_STARTING;
/* start player */
pthread_create (&playerThread, NULL, BarPlayerThread,
&player);