aboutsummaryrefslogtreecommitdiffstats
path: root/libavformat/matroskadec.c
diff options
context:
space:
mode:
authorAurelien Jacobs <aurel@gnuage.org>2008-08-05 00:41:59 +0000
committerAurelien Jacobs <aurel@gnuage.org>2008-08-05 00:41:59 +0000
commiteb05caccf2e2de346862ade234e17c5b1c242336 (patch)
treef3dd55c6e51fb18d9681b01b4ec4e5d82ac419d0 /libavformat/matroskadec.c
parentc6cd2b3d22a41255225fe76ecfd6543230840749 (diff)
downloadffmpeg-eb05caccf2e2de346862ade234e17c5b1c242336.tar.gz
matroskadec: use an EbmlBin as parameter to ebml_read_binary()
Originally committed as revision 14591 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavformat/matroskadec.c')
-rw-r--r--libavformat/matroskadec.c18
1 files changed, 7 insertions, 11 deletions
diff --git a/libavformat/matroskadec.c b/libavformat/matroskadec.c
index 2bc277129d..9334ce2a15 100644
--- a/libavformat/matroskadec.c
+++ b/libavformat/matroskadec.c
@@ -688,14 +688,15 @@ ebml_read_master (MatroskaDemuxContext *matroska,
static int
ebml_read_binary (ByteIOContext *pb,
int length,
- uint8_t **binary,
- int *size)
+ EbmlBin *bin)
{
- if (!(*binary = av_malloc(length)))
+ av_free(bin->data);
+ if (!(bin->data = av_malloc(length)))
return AVERROR(ENOMEM);
- *size = length;
- if (get_buffer(pb, *binary, length) != length)
+ bin->size = length;
+ bin->pos = url_ftell(pb);
+ if (get_buffer(pb, bin->data, length) != length)
return AVERROR(EIO);
return 0;
@@ -896,7 +897,6 @@ static int ebml_parse_elem(MatroskaDemuxContext *matroska,
ByteIOContext *pb = matroska->ctx->pb;
uint32_t id = syntax->id;
uint64_t length;
- EbmlBin *bin;
int res;
data = (char *)data + syntax->data_offset;
@@ -907,7 +907,6 @@ static int ebml_parse_elem(MatroskaDemuxContext *matroska,
memset(data, 0, syntax->list_elem_size);
list->nb_elem++;
}
- bin = data;
if (syntax->type != EBML_PASS && syntax->type != EBML_STOP)
if ((res = ebml_read_element_id(matroska, &id)) < 0 ||
@@ -919,10 +918,7 @@ static int ebml_parse_elem(MatroskaDemuxContext *matroska,
case EBML_FLOAT: res = ebml_read_float (pb, length, data); break;
case EBML_STR:
case EBML_UTF8: res = ebml_read_ascii (pb, length, data); break;
- case EBML_BIN: av_free(bin->data);
- bin->pos = url_ftell(matroska->ctx->pb);
- res = ebml_read_binary(pb, length, &bin->data,
- &bin->size); break;
+ case EBML_BIN: res = ebml_read_binary(pb, length, data); break;
case EBML_NEST: if ((res=ebml_read_master(matroska, length)) < 0)
return res;
if (id == MATROSKA_ID_SEGMENT)