aboutsummaryrefslogtreecommitdiffstats
path: root/src/PlayerThread.cxx (follow)
Commit message (Collapse)AuthorAgeFilesLines
...
* PlayerControl: add second Cond objectMax Kellermann2013-01-251-1/+1
| | | | | | | | | | | | | This fixes a deadlock bug introduced by 18076ac9. After all, the second Cond was necessary. The problem: two threads can wait for a signal at the same time. The player thread waits for the output thread to finish playback. The main thread waits for the player thread to complete a command. The output thread finishes playback, and sends a signal, which unfortunately does not wake up the player thread, but the main thread. The main thread sees that the command is still not finished, and waits again. The signal is lost forever, and MPD is deadlocked.
* DecoderControl: move functions into the classMax Kellermann2013-01-211-31/+31
|
* PlayerControl: move functions into the classMax Kellermann2013-01-201-61/+61
|
* PlayerControl: switch to the Mutex/Cond classesMax Kellermann2013-01-101-1/+1
|
* PlayerThread: use pc.cond instead of main_condMax Kellermann2013-01-101-1/+1
| | | | | The main_cond variable was completely unnecessary. The pc.cond object can be used for both main->pc and pc->main.
* DecoderControl: take ownership of client_condMax Kellermann2013-01-101-1/+1
| | | | | Don't let the "client" pass its own GCond. This was not used consistently.
* EventPipe: rename to GlobalEventsMax Kellermann2013-01-091-5/+5
|
* event_pipe.h: convert to C++Max Kellermann2013-01-091-4/+1
|
* idle: convert to C++Max Kellermann2013-01-091-1/+1
|
* replay_gain_info, ...: use cmath instead of math.h in C++ modeMax Kellermann2013-01-071-1/+3
| | | | Fixes build problems with mingw32.
* decoder_api.h, ...: add "extern C"Max Kellermann2013-01-071-1/+1
|
* mixer_all: convert to C++Max Kellermann2013-01-071-1/+1
|
* player_control.h: convert header to C++Max Kellermann2013-01-041-1/+1
|
* MusicChunk: move functions to methodsMax Kellermann2013-01-041-2/+2
|
* crossfade: convert to C++Max Kellermann2013-01-041-1/+1
|
* buffer, pipe: convert to C++Max Kellermann2013-01-041-3/+3
|
* decoder_*: convert to C++Max Kellermann2013-01-041-1/+1
|
* {decoder,player}_thread: convert to C++Max Kellermann2013-01-021-0/+1198