diff options
author | Luca Barbato <lu_zero@gentoo.org> | 2013-06-03 03:51:05 +0200 |
---|---|---|
committer | Luca Barbato <lu_zero@gentoo.org> | 2013-06-07 17:23:53 +0200 |
commit | 103937681d7e6afd3e8caf8937272575e450fb55 (patch) | |
tree | eaeda3f14c1c37389d0b59e270ad993b7a7fa4f2 /libavcodec | |
parent | f8a4d5e970f32f8cc747f9fa7bd975ee4a060ea1 (diff) | |
download | ffmpeg-103937681d7e6afd3e8caf8937272575e450fb55.tar.gz |
tiff: refactor deflate support in a separate function
Report when zlib support is missing.
Diffstat (limited to 'libavcodec')
-rw-r--r-- | libavcodec/tiff.c | 62 |
1 files changed, 37 insertions, 25 deletions
diff --git a/libavcodec/tiff.c b/libavcodec/tiff.c index a2fae32590..e4ea0ba7ce 100644 --- a/libavcodec/tiff.c +++ b/libavcodec/tiff.c @@ -111,6 +111,35 @@ static int tiff_uncompress(uint8_t *dst, unsigned long *len, const uint8_t *src, *len = zstream.total_out; return zret == Z_STREAM_END ? Z_OK : zret; } + +static int tiff_unpack_zlib(TiffContext *s, uint8_t *dst, int stride, + const uint8_t *src, int size, + int width, int lines) +{ + uint8_t *zbuf; + unsigned long outlen; + int ret, line; + outlen = width * lines; + zbuf = av_malloc(outlen); + if (!zbuf) + return AVERROR(ENOMEM); + ret = tiff_uncompress(zbuf, &outlen, src, size); + if (ret != Z_OK) { + av_log(s->avctx, AV_LOG_ERROR, + "Uncompressing failed (%lu of %lu) with error %d\n", outlen, + (unsigned long)width * lines, ret); + av_free(zbuf); + return AVERROR_UNKNOWN; + } + src = zbuf; + for (line = 0; line < lines; line++) { + memcpy(dst, src, width); + dst += stride; + src += width; + } + av_free(zbuf); + return 0; +} #endif static int tiff_unpack_strip(TiffContext *s, uint8_t *dst, int stride, @@ -123,33 +152,16 @@ static int tiff_unpack_strip(TiffContext *s, uint8_t *dst, int stride, if (size <= 0) return AVERROR_INVALIDDATA; -#if CONFIG_ZLIB if (s->compr == TIFF_DEFLATE || s->compr == TIFF_ADOBE_DEFLATE) { - uint8_t *zbuf; - unsigned long outlen; - int ret; - outlen = width * lines; - zbuf = av_malloc(outlen); - if (!zbuf) - return AVERROR(ENOMEM); - ret = tiff_uncompress(zbuf, &outlen, src, size); - if (ret != Z_OK) { - av_log(s->avctx, AV_LOG_ERROR, - "Uncompressing failed (%lu of %lu) with error %d\n", outlen, - (unsigned long)width * lines, ret); - av_free(zbuf); - return AVERROR_UNKNOWN; - } - src = zbuf; - for (line = 0; line < lines; line++) { - memcpy(dst, src, width); - dst += stride; - src += width; - } - av_free(zbuf); - return 0; - } +#if CONFIG_ZLIB + return tiff_unpack_zlib(s, dst, stride, src, size, width, lines); +#else + av_log(s->avctx, AV_LOG_ERROR, + "zlib support not enabled, " + "deflate compression not supported\n"); + return AVERROR(ENOSYS); #endif + } if (s->compr == TIFF_LZW) { if ((ret = ff_lzw_decode_init(s->lzw, 8, src, size, FF_LZW_TIFF)) < 0) { av_log(s->avctx, AV_LOG_ERROR, "Error initializing LZW decoder\n"); |