Commit e5ec1318 authored by Andreas Rheinhardt's avatar Andreas Rheinhardt Committed by James Almer

avformat/matroskadec: Use generic size check for signed integers

and drop the redundant checks contained in ebml_read_uint and
ebml_read_sint.
Signed-off-by: 's avatarAndreas Rheinhardt <andreas.rheinhardt@gmail.com>
parent 07d40560
...@@ -882,9 +882,6 @@ static int ebml_read_uint(AVIOContext *pb, int size, uint64_t *num) ...@@ -882,9 +882,6 @@ static int ebml_read_uint(AVIOContext *pb, int size, uint64_t *num)
{ {
int n = 0; int n = 0;
if (size > 8)
return AVERROR_INVALIDDATA;
/* big-endian ordering; build up number */ /* big-endian ordering; build up number */
*num = 0; *num = 0;
while (n++ < size) while (n++ < size)
...@@ -901,9 +898,6 @@ static int ebml_read_sint(AVIOContext *pb, int size, int64_t *num) ...@@ -901,9 +898,6 @@ static int ebml_read_sint(AVIOContext *pb, int size, int64_t *num)
{ {
int n = 1; int n = 1;
if (size > 8)
return AVERROR_INVALIDDATA;
if (size == 0) { if (size == 0) {
*num = 0; *num = 0;
} else { } else {
...@@ -1161,6 +1155,7 @@ static int ebml_parse_elem(MatroskaDemuxContext *matroska, ...@@ -1161,6 +1155,7 @@ static int ebml_parse_elem(MatroskaDemuxContext *matroska,
{ {
static const uint64_t max_lengths[EBML_TYPE_COUNT] = { static const uint64_t max_lengths[EBML_TYPE_COUNT] = {
[EBML_UINT] = 8, [EBML_UINT] = 8,
[EBML_SINT] = 8,
[EBML_FLOAT] = 8, [EBML_FLOAT] = 8,
// max. 16 MB for strings // max. 16 MB for strings
[EBML_STR] = 0x1000000, [EBML_STR] = 0x1000000,
......
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