[Flac] Bug in bitreader for short reads?
Gilles Boccon-Gibod
bok at bok.net
Sun May 31 22:40:59 PDT 2009
It seems that the bitstream reader is not working as it should
(verified in version 1.2.0 and 1.2.1).
The problem is as follows: if the data read by the read callback is
not a multiple of 4, the bit reader will end up in a very bad state,
where the bits_consumed field will grow without ever being reset to 0,
and that causes everything to fail.
This is not a case that's encountered very often, because in general
(like for example when reading from a file), the read callback will
return as many bytes as were asked for, which happens to be a multiple
of 4. But when reading from a network socket, or some type of
buffering code, it can happen that reads are shorter than requested,
and not always multiples of 4, and that produces decoding problems.
The problem is very easy to reproduce: in the read callback, always
return 1 byte, regardless of how many bytes are asked for.
For example, in a typical read callback routine, one can do the
(simplified) following and see the problem:
static FLAC__StreamDecoderReadStatus
FlacDecoder_ReadCallback(const FLAC__StreamDecoder* flac,
FLAC__byte buffer[],
size_t* bytes,
void* client_data)
{
*bytes=1; /* <--- this was added to always return at most one
byte */
read_only_one_byte_into_buffer(buffer);
return FLAC__STREAM_DECODER_READ_STATUS_CONTINUE;
}
Any hints on how to get this fixed?
-- Gilles
-------------- next part --------------
An HTML attachment was scrubbed...
URL: http://lists.xiph.org/pipermail/flac/attachments/20090531/4dc50eba/attachment.htm
More information about the Flac
mailing list