#1) fix a few potential deadlock conditons in decode.c when crossfading is enabled
#2) fix a deadlock condition when attempting to seek if the decoder quit and returned to playerInit() git-svn-id: https://svn.musicpd.org/mpd/trunk@5325 09075e82-0dd4-0310-85a5-a0d7c8717e4f
This commit is contained in:
parent
c5933a164a
commit
b54c7c64c0
11
src/decode.c
11
src/decode.c
@ -481,10 +481,10 @@ static void advanceOutputBufferTo(OutputBuffer * cb, PlayerControl * pc,
|
|||||||
while (cb->begin != to) {
|
while (cb->begin != to) {
|
||||||
handleMetadata(cb, pc, previous, currentChunkSent,
|
handleMetadata(cb, pc, previous, currentChunkSent,
|
||||||
currentChunk);
|
currentChunk);
|
||||||
cb->begin++;
|
if (cb->begin + 1 >= buffered_chunks) {
|
||||||
if (cb->begin >= buffered_chunks) {
|
|
||||||
cb->begin = 0;
|
cb->begin = 0;
|
||||||
}
|
}
|
||||||
|
else cb->begin++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -517,7 +517,8 @@ static void decodeParent(PlayerControl * pc, DecoderControl * dc, OutputBuffer *
|
|||||||
pc->play = 0;
|
pc->play = 0;
|
||||||
kill(getppid(), SIGUSR1);
|
kill(getppid(), SIGUSR1);
|
||||||
|
|
||||||
while (decode_pid > 0 && cb->end - cb->begin < bbp &&
|
while (decode_pid > 0 &&
|
||||||
|
cb->end - cb->begin < bbp &&
|
||||||
cb->end != buffered_chunks - 1 &&
|
cb->end != buffered_chunks - 1 &&
|
||||||
dc->state != DECODE_STATE_STOP) {
|
dc->state != DECODE_STATE_STOP) {
|
||||||
processDecodeInput();
|
processDecodeInput();
|
||||||
@ -618,10 +619,10 @@ static void decodeParent(PlayerControl * pc, DecoderControl * dc, OutputBuffer *
|
|||||||
cb->begin = 0;
|
cb->begin = 0;
|
||||||
} else
|
} else
|
||||||
cb->begin++;
|
cb->begin++;
|
||||||
} else if (next == cb->begin) {
|
} else if (cb->begin != end && cb->begin == next) {
|
||||||
if (doCrossFade == 1 && nextChunk >= 0) {
|
if (doCrossFade == 1 && nextChunk >= 0) {
|
||||||
nextChunk = cb->begin + crossFadeChunks;
|
nextChunk = cb->begin + crossFadeChunks;
|
||||||
test = cb->end;
|
test = end;
|
||||||
if (end < cb->begin)
|
if (end < cb->begin)
|
||||||
test += buffered_chunks;
|
test += buffered_chunks;
|
||||||
if (nextChunk < test) {
|
if (nextChunk < test) {
|
||||||
|
@ -58,11 +58,10 @@ void clearOutputBuffer(OutputBuffer * cb)
|
|||||||
void flushOutputBuffer(OutputBuffer * cb)
|
void flushOutputBuffer(OutputBuffer * cb)
|
||||||
{
|
{
|
||||||
if (currentChunk == cb->end) {
|
if (currentChunk == cb->end) {
|
||||||
int next = cb->end + 1;
|
if ((cb->end + 1) >= buffered_chunks) {
|
||||||
if (next >= buffered_chunks) {
|
cb->end = 0;
|
||||||
next = 0;
|
|
||||||
}
|
}
|
||||||
cb->end = next;
|
else cb->end++;
|
||||||
currentChunk = -1;
|
currentChunk = -1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -138,6 +138,8 @@ int playerInit(void)
|
|||||||
decode();
|
decode();
|
||||||
else if (pc->stop)
|
else if (pc->stop)
|
||||||
pc->stop = 0;
|
pc->stop = 0;
|
||||||
|
else if (pc->seek)
|
||||||
|
pc->seek = 0;
|
||||||
else if (pc->pause)
|
else if (pc->pause)
|
||||||
pc->pause = 0;
|
pc->pause = 0;
|
||||||
else if (pc->closeAudio) {
|
else if (pc->closeAudio) {
|
||||||
|
Loading…
Reference in New Issue
Block a user