Commit 35858dfe authored by Max Kellermann's avatar Max Kellermann

aac: don't depend on consumed data in fillAacBuffer()

Fill the AacBuffer even when nothing has been consumed yet. The function should not check for consumed data, but for free space at the end of the buffer.
parent 2a141411
...@@ -41,28 +41,32 @@ static void fillAacBuffer(AacBuffer * b) ...@@ -41,28 +41,32 @@ static void fillAacBuffer(AacBuffer * b)
{ {
size_t bread; size_t bread;
if (b->bytesConsumed == 0) if (b->bytesIntoBuffer >= FAAD_MIN_STREAMSIZE * AAC_MAX_CHANNELS)
/* buffer already full */
return; return;
if (b->bytesIntoBuffer) { if (b->bytesConsumed > 0 && b->bytesIntoBuffer > 0) {
memmove((void *)b->buffer, (void *)(b->buffer + memmove((void *)b->buffer, (void *)(b->buffer +
b->bytesConsumed), b->bytesConsumed),
b->bytesIntoBuffer); b->bytesIntoBuffer);
} }
b->bytesConsumed = 0;
if (!b->atEof) { if (!b->atEof) {
size_t rest = FAAD_MIN_STREAMSIZE * AAC_MAX_CHANNELS -
b->bytesIntoBuffer;
bread = readFromInputStream(b->inStream, bread = readFromInputStream(b->inStream,
(void *)(b->buffer + (void *)(b->buffer +
b-> b->
bytesIntoBuffer), bytesIntoBuffer),
1, b->bytesConsumed); 1, rest);
if (bread != b->bytesConsumed) if (bread != rest)
b->atEof = 1; b->atEof = 1;
b->bytesIntoBuffer += bread; b->bytesIntoBuffer += bread;
} }
b->bytesConsumed = 0;
if ((b->bytesIntoBuffer > 3 && memcmp(b->buffer, "TAG", 3) == 0) || if ((b->bytesIntoBuffer > 3 && memcmp(b->buffer, "TAG", 3) == 0) ||
(b->bytesIntoBuffer > 11 && (b->bytesIntoBuffer > 11 &&
memcmp(b->buffer, "LYRICSBEGIN", 11) == 0) || memcmp(b->buffer, "LYRICSBEGIN", 11) == 0) ||
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment