decoder/DsdLib: fix integer overflow in ID3 size calculation
This commit is contained in:
parent
3ecb19d0f1
commit
e2e66404d5
@ -117,13 +117,15 @@ dsdlib_tag_id3(InputStream &is,
|
|||||||
if (tagoffset >= size)
|
if (tagoffset >= size)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
const id3_length_t count = size - tagoffset;
|
const auto count64 = size - tagoffset;
|
||||||
if (count < 10 || count > 1024 * 1024)
|
if (count64 < 10 || count64 > 1024 * 1024)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (!dsdlib_skip_to(nullptr, is, tagoffset))
|
if (!dsdlib_skip_to(nullptr, is, tagoffset))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
const id3_length_t count = count64;
|
||||||
|
|
||||||
id3_byte_t *const id3_buf = new id3_byte_t[count];
|
id3_byte_t *const id3_buf = new id3_byte_t[count];
|
||||||
if (id3_buf == nullptr)
|
if (id3_buf == nullptr)
|
||||||
return;
|
return;
|
||||||
|
Loading…
Reference in New Issue
Block a user