summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPaul B Mahol <onemda@gmail.com>2013-05-28 17:13:26 +0000
committerPaul B Mahol <onemda@gmail.com>2013-05-29 13:42:55 +0000
commit30d7dcce4c3f2af3c99d2ac05a1ecb6caba076fe (patch)
treeafad656378687adc6fbe2786739d999db2ddac6e
parentb257d9a01fcc2fa54a62e46d3d442d3131556055 (diff)
tiff: add helper function for fill_order case
Signed-off-by: Paul B Mahol <onemda@gmail.com>
-rw-r--r--libavcodec/tiff.c43
1 files changed, 21 insertions, 22 deletions
diff --git a/libavcodec/tiff.c b/libavcodec/tiff.c
index 6c2dc233ec..839209b736 100644
--- a/libavcodec/tiff.c
+++ b/libavcodec/tiff.c
@@ -411,6 +411,19 @@ static void av_always_inline horizontal_fill(unsigned int bpp, uint8_t* dst,
}
}
+static int deinvert_buffer(TiffContext *s, const uint8_t *src, int size)
+{
+ int i;
+
+ av_fast_padded_malloc(&s->deinvert_buf, &s->deinvert_buf_size, size);
+ if (!s->deinvert_buf)
+ return AVERROR(ENOMEM);
+ for (i = 0; i < size; i++)
+ s->deinvert_buf[i] = ff_reverse[src[i]];
+
+ return 0;
+}
+
static int tiff_unpack_strip(TiffContext *s, uint8_t *dst, int stride,
const uint8_t *src, int size, int lines)
{
@@ -423,31 +436,23 @@ static int tiff_unpack_strip(TiffContext *s, uint8_t *dst, int stride,
#if CONFIG_ZLIB
if (s->compr == TIFF_DEFLATE || s->compr == TIFF_ADOBE_DEFLATE) {
- uint8_t *src2 = NULL, *zbuf;
+ uint8_t *zbuf;
unsigned long outlen;
- int i, ret;
+ int ret;
outlen = width * lines;
zbuf = av_malloc(outlen);
if (!zbuf)
return AVERROR(ENOMEM);
if (s->fill_order) {
- src2 = av_malloc((unsigned)size + FF_INPUT_BUFFER_PADDING_SIZE);
- if (!src2) {
- av_log(s->avctx, AV_LOG_ERROR, "Error allocating temporary buffer\n");
- av_free(zbuf);
- return AVERROR(ENOMEM);
- }
- for (i = 0; i < size; i++)
- src2[i] = ff_reverse[src[i]];
- memset(src2 + size, 0, FF_INPUT_BUFFER_PADDING_SIZE);
- src = src2;
+ if ((ret = deinvert_buffer(s, src, size)) < 0)
+ return ret;
+ ssrc = src = s->deinvert_buf;
}
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(src2);
av_free(zbuf);
return AVERROR_UNKNOWN;
}
@@ -461,21 +466,15 @@ static int tiff_unpack_strip(TiffContext *s, uint8_t *dst, int stride,
dst += stride;
src += width;
}
- av_free(src2);
av_free(zbuf);
return 0;
}
#endif
if (s->compr == TIFF_LZW) {
if (s->fill_order) {
- int i;
- av_fast_padded_malloc(&s->deinvert_buf, &s->deinvert_buf_size, size);
- if (!s->deinvert_buf)
- return AVERROR(ENOMEM);
- for (i = 0; i < size; i++)
- s->deinvert_buf[i] = ff_reverse[src[i]];
- src = s->deinvert_buf;
- ssrc = src;
+ if ((ret = deinvert_buffer(s, src, size)) < 0)
+ return ret;
+ ssrc = src = s->deinvert_buf;
}
if (size > 1 && !src[0] && (src[1]&1)) {
av_log(s->avctx, AV_LOG_ERROR, "Old style LZW is unsupported\n");