diff options
author | scop <scop> | 2005-08-26 18:11:40 +0000 |
---|---|---|
committer | scop <scop> | 2005-08-26 18:11:40 +0000 |
commit | 4a33fe954fa713be10b0efdecbecd4e1b1f9caa7 (patch) | |
tree | 4be77febb67b0967ff604fac9782acb181c30417 /dxr3audiodecoder.c | |
parent | ef401208952d25f33972d1ab8b3bf3788113e52c (diff) | |
download | vdr-plugin-dxr3-4a33fe954fa713be10b0efdecbecd4e1b1f9caa7.tar.gz vdr-plugin-dxr3-4a33fe954fa713be10b0efdecbecd4e1b1f9caa7.tar.bz2 |
Don't abort with lpcm frames containing an odd number of bytes, drop instead.
Diffstat (limited to 'dxr3audiodecoder.c')
-rw-r--r-- | dxr3audiodecoder.c | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/dxr3audiodecoder.c b/dxr3audiodecoder.c index 67238d2..f742375 100644 --- a/dxr3audiodecoder.c +++ b/dxr3audiodecoder.c @@ -202,10 +202,14 @@ void cDxr3AudioDecoder::DecodeLpcm(const uint8_t* buf, int length, { if (length > (LPCM_HEADER_LENGTH + 2)) { - uint8_t* pFrame = new uint8_t[length - LPCM_HEADER_LENGTH]; // only even number of bytes are allowed - assert(!((length - LPCM_HEADER_LENGTH) % 2)); + if ((length - LPCM_HEADER_LENGTH) % 2 != 0) + { + esyslog("dxr3: audiodecoder: skipping %d lpcm bytes", length); + return; + } + uint8_t* pFrame = new uint8_t[length - LPCM_HEADER_LENGTH]; for (int i = LPCM_HEADER_LENGTH; i < length; i += 2) { pFrame[i - LPCM_HEADER_LENGTH] = buf[i + 1]; |