Commit 3a776037 authored by aurel's avatar aurel

matroskadec: implement matroska_ebmlnum_uint() using ebml_read_num()

git-svn-id: file:///var/local/repositories/ffmpeg/trunk@14608 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent b0ffb6b1
...@@ -478,10 +478,9 @@ static int ebml_level_end(MatroskaDemuxContext *matroska) ...@@ -478,10 +478,9 @@ static int ebml_level_end(MatroskaDemuxContext *matroska)
* number. * number.
* Returns: num. of bytes read. < 0 on error. * Returns: num. of bytes read. < 0 on error.
*/ */
static int ebml_read_num(MatroskaDemuxContext *matroska, static int ebml_read_num(MatroskaDemuxContext *matroska, ByteIOContext *pb,
int max_size, uint64_t *number) int max_size, uint64_t *number)
{ {
ByteIOContext *pb = matroska->ctx->pb;
int len_mask = 0x80, read = 1, n = 1; int len_mask = 0x80, read = 1, n = 1;
int64_t total = 0; int64_t total = 0;
...@@ -532,7 +531,7 @@ static int ebml_read_element_id(MatroskaDemuxContext *matroska, uint32_t *id) ...@@ -532,7 +531,7 @@ static int ebml_read_element_id(MatroskaDemuxContext *matroska, uint32_t *id)
uint64_t total; uint64_t total;
/* read out the "EBML number", include tag in ID */ /* read out the "EBML number", include tag in ID */
if ((read = ebml_read_num(matroska, 4, &total)) < 0) if ((read = ebml_read_num(matroska, matroska->ctx->pb, 4, &total)) < 0)
return read; return read;
*id = total | (1 << (read * 7)); *id = total | (1 << (read * 7));
...@@ -638,53 +637,26 @@ static int ebml_read_master(MatroskaDemuxContext *matroska, int length) ...@@ -638,53 +637,26 @@ static int ebml_read_master(MatroskaDemuxContext *matroska, int length)
/* /*
* Read signed/unsigned "EBML" numbers. * Read signed/unsigned "EBML" numbers.
* Return: number of bytes processed, < 0 on error. * Return: number of bytes processed, < 0 on error.
* XXX: use ebml_read_num().
*/ */
static int matroska_ebmlnum_uint(uint8_t *data, uint32_t size, uint64_t *num) static int matroska_ebmlnum_uint(MatroskaDemuxContext *matroska,
uint8_t *data, uint32_t size, uint64_t *num)
{ {
int len_mask = 0x80, read = 1, n = 1, num_ffs = 0; ByteIOContext pb;
uint64_t total; init_put_byte(&pb, data, size, 0, NULL, NULL, NULL, NULL);
return ebml_read_num(matroska, &pb, 8, num);
if (size <= 0)
return AVERROR_INVALIDDATA;
total = data[0];
while (read <= 8 && !(total & len_mask)) {
read++;
len_mask >>= 1;
}
if (read > 8)
return AVERROR_INVALIDDATA;
if ((total &= (len_mask - 1)) == len_mask - 1)
num_ffs++;
if (size < read)
return AVERROR_INVALIDDATA;
while (n < read) {
if (data[n] == 0xff)
num_ffs++;
total = (total << 8) | data[n];
n++;
}
if (read == num_ffs)
*num = (uint64_t)-1;
else
*num = total;
return read;
} }
/* /*
* Same as above, but signed. * Same as above, but signed.
*/ */
static int matroska_ebmlnum_sint(uint8_t *data, uint32_t size, int64_t *num) static int matroska_ebmlnum_sint(MatroskaDemuxContext *matroska,
uint8_t *data, uint32_t size, int64_t *num)
{ {
uint64_t unum; uint64_t unum;
int res; int res;
/* read as unsigned number first */ /* read as unsigned number first */
if ((res = matroska_ebmlnum_uint(data, size, &unum)) < 0) if ((res = matroska_ebmlnum_uint(matroska, data, size, &unum)) < 0)
return res; return res;
/* make signed (weird way) */ /* make signed (weird way) */
...@@ -762,7 +734,7 @@ static int ebml_parse_elem(MatroskaDemuxContext *matroska, ...@@ -762,7 +734,7 @@ static int ebml_parse_elem(MatroskaDemuxContext *matroska,
} }
if (syntax->type != EBML_PASS && syntax->type != EBML_STOP) if (syntax->type != EBML_PASS && syntax->type != EBML_STOP)
if ((res = ebml_read_num(matroska, 8, &length)) < 0) if ((res = ebml_read_num(matroska, pb, 8, &length)) < 0)
return res; return res;
switch (syntax->type) { switch (syntax->type) {
...@@ -1387,7 +1359,7 @@ static int matroska_parse_block(MatroskaDemuxContext *matroska, uint8_t *data, ...@@ -1387,7 +1359,7 @@ static int matroska_parse_block(MatroskaDemuxContext *matroska, uint8_t *data,
int n, flags, laces = 0; int n, flags, laces = 0;
uint64_t num; uint64_t num;
if ((n = matroska_ebmlnum_uint(data, size, &num)) < 0) { if ((n = matroska_ebmlnum_uint(matroska, data, size, &num)) < 0) {
av_log(matroska->ctx, AV_LOG_ERROR, "EBML block data error\n"); av_log(matroska->ctx, AV_LOG_ERROR, "EBML block data error\n");
return res; return res;
} }
...@@ -1465,7 +1437,7 @@ static int matroska_parse_block(MatroskaDemuxContext *matroska, uint8_t *data, ...@@ -1465,7 +1437,7 @@ static int matroska_parse_block(MatroskaDemuxContext *matroska, uint8_t *data,
case 0x3: /* EBML lacing */ { case 0x3: /* EBML lacing */ {
uint32_t total; uint32_t total;
n = matroska_ebmlnum_uint(data, size, &num); n = matroska_ebmlnum_uint(matroska, data, size, &num);
if (n < 0) { if (n < 0) {
av_log(matroska->ctx, AV_LOG_INFO, av_log(matroska->ctx, AV_LOG_INFO,
"EBML block data error\n"); "EBML block data error\n");
...@@ -1477,7 +1449,7 @@ static int matroska_parse_block(MatroskaDemuxContext *matroska, uint8_t *data, ...@@ -1477,7 +1449,7 @@ static int matroska_parse_block(MatroskaDemuxContext *matroska, uint8_t *data,
for (n = 1; res == 0 && n < laces - 1; n++) { for (n = 1; res == 0 && n < laces - 1; n++) {
int64_t snum; int64_t snum;
int r; int r;
r = matroska_ebmlnum_sint (data, size, &snum); r = matroska_ebmlnum_sint(matroska, data, size, &snum);
if (r < 0) { if (r < 0) {
av_log(matroska->ctx, AV_LOG_INFO, av_log(matroska->ctx, AV_LOG_INFO,
"EBML block data error\n"); "EBML block data error\n");
......
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