diff options
author | Tom Butterworth <bangnoise@gmail.com> | 2015-07-16 13:23:22 +0100 |
---|---|---|
committer | Michael Niedermayer <michael@niedermayer.cc> | 2015-07-16 20:41:07 +0200 |
commit | 17ee24af7e5f7112fe25c734236d521f9e35d80d (patch) | |
tree | 272bb8fb9c8f1792fccf287a138e09e064425e71 /libavcodec/snappy.c | |
parent | c4dfb76fa7e4d51fd4ca686a63499245c0687a84 (diff) | |
download | ffmpeg-17ee24af7e5f7112fe25c734236d521f9e35d80d.tar.gz |
avcodec/snappy: refactor so ff_snappy_uncompress uses an existing buffer
Some uses of Snappy require uncompressing to positions within an existing buffer. Also adds a function to get the uncompressed length of Snappy data.
Signed-off-by: Michael Niedermayer <michael@niedermayer.cc>
Diffstat (limited to 'libavcodec/snappy.c')
-rw-r--r-- | libavcodec/snappy.c | 24 |
1 files changed, 17 insertions, 7 deletions
diff --git a/libavcodec/snappy.c b/libavcodec/snappy.c index 553d713281..7900b0f978 100644 --- a/libavcodec/snappy.c +++ b/libavcodec/snappy.c @@ -128,7 +128,17 @@ static int64_t decode_len(GetByteContext *gb) return len; } -int ff_snappy_uncompress(GetByteContext *gb, uint8_t **buf, int64_t *size) +int64_t ff_snappy_peek_uncompressed_length(GetByteContext *gb) +{ + int pos = bytestream2_get_bytes_left(gb); + int64_t len = decode_len(gb); + + bytestream2_seek(gb, -pos, SEEK_END); + + return len; +} + +int ff_snappy_uncompress(GetByteContext *gb, uint8_t *buf, int64_t *size) { int64_t len = decode_len(gb); int ret = 0; @@ -137,11 +147,11 @@ int ff_snappy_uncompress(GetByteContext *gb, uint8_t **buf, int64_t *size) if (len < 0) return len; - if ((ret = av_reallocp(buf, len)) < 0) - return AVERROR(ENOMEM); + if (len > *size) + return AVERROR_BUFFER_TOO_SMALL; *size = len; - p = *buf; + p = buf; while (bytestream2_get_bytes_left(gb) > 0) { uint8_t s = bytestream2_get_byte(gb); @@ -152,13 +162,13 @@ int ff_snappy_uncompress(GetByteContext *gb, uint8_t **buf, int64_t *size) ret = snappy_literal(gb, p, len, val); break; case SNAPPY_COPY_1: - ret = snappy_copy1(gb, *buf, p, len, val); + ret = snappy_copy1(gb, buf, p, len, val); break; case SNAPPY_COPY_2: - ret = snappy_copy2(gb, *buf, p, len, val); + ret = snappy_copy2(gb, buf, p, len, val); break; case SNAPPY_COPY_4: - ret = snappy_copy4(gb, *buf, p, len, val); + ret = snappy_copy4(gb, buf, p, len, val); break; } |