Commit ad8158f9 authored by kostya's avatar kostya

Support both LSB and MSB orders for TIFF CCITT G.x compressed data.

This fixes issue 1410.



git-svn-id: file:///var/local/repositories/ffmpeg/trunk@20016 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent b81ff606
...@@ -44,6 +44,7 @@ typedef struct TiffContext { ...@@ -44,6 +44,7 @@ typedef struct TiffContext {
int invert; int invert;
int fax_opts; int fax_opts;
int predictor; int predictor;
int fill_order;
int strips, rps, sstype; int strips, rps, sstype;
int sot; int sot;
...@@ -113,8 +114,12 @@ static int tiff_unpack_strip(TiffContext *s, uint8_t* dst, int stride, const uin ...@@ -113,8 +114,12 @@ static int tiff_unpack_strip(TiffContext *s, uint8_t* dst, int stride, const uin
av_log(s->avctx, AV_LOG_ERROR, "Error allocating temporary buffer\n"); av_log(s->avctx, AV_LOG_ERROR, "Error allocating temporary buffer\n");
return -1; return -1;
} }
if(!s->fill_order){
memcpy(src2, src, size);
}else{
for(i = 0; i < size; i++) for(i = 0; i < size; i++)
src2[i] = ff_reverse[src[i]]; src2[i] = ff_reverse[src[i]];
}
memset(src2+size, 0, FF_INPUT_BUFFER_PADDING_SIZE); memset(src2+size, 0, FF_INPUT_BUFFER_PADDING_SIZE);
if(s->compr == TIFF_G3 && !(s->fax_opts & 1)) if(s->compr == TIFF_G3 && !(s->fax_opts & 1))
s->compr = TIFF_CCITT_RLE; s->compr = TIFF_CCITT_RLE;
...@@ -375,6 +380,13 @@ static int tiff_decode_tag(TiffContext *s, const uint8_t *start, const uint8_t * ...@@ -375,6 +380,13 @@ static int tiff_decode_tag(TiffContext *s, const uint8_t *start, const uint8_t *
return -1; return -1;
} }
break; break;
case TIFF_FILL_ORDER:
if(value < 1 || value > 2){
av_log(s->avctx, AV_LOG_ERROR, "Unknown FillOrder value %d, trying default one\n", value);
value = 1;
}
s->fill_order = value - 1;
break;
case TIFF_PAL: case TIFF_PAL:
if(s->avctx->pix_fmt != PIX_FMT_PAL8){ if(s->avctx->pix_fmt != PIX_FMT_PAL8){
av_log(s->avctx, AV_LOG_ERROR, "Palette met but this is not palettized format\n"); av_log(s->avctx, AV_LOG_ERROR, "Palette met but this is not palettized format\n");
...@@ -433,6 +445,7 @@ static int decode_frame(AVCodecContext *avctx, ...@@ -433,6 +445,7 @@ static int decode_frame(AVCodecContext *avctx,
s->le = le; s->le = le;
s->invert = 0; s->invert = 0;
s->compr = TIFF_RAW; s->compr = TIFF_RAW;
s->fill_order = 0;
// As TIFF 6.0 specification puts it "An arbitrary but carefully chosen number // As TIFF 6.0 specification puts it "An arbitrary but carefully chosen number
// that further identifies the file as a TIFF file" // that further identifies the file as a TIFF file"
if(tget_short(&buf, le) != 42){ if(tget_short(&buf, le) != 42){
......
...@@ -37,6 +37,7 @@ enum TiffTags{ ...@@ -37,6 +37,7 @@ enum TiffTags{
TIFF_BPP, TIFF_BPP,
TIFF_COMPR, TIFF_COMPR,
TIFF_INVERT = 0x106, TIFF_INVERT = 0x106,
TIFF_FILL_ORDER = 0x10A,
TIFF_STRIP_OFFS = 0x111, TIFF_STRIP_OFFS = 0x111,
TIFF_SAMPLES_PER_PIXEL = 0x115, TIFF_SAMPLES_PER_PIXEL = 0x115,
TIFF_ROWSPERSTRIP = 0x116, TIFF_ROWSPERSTRIP = 0x116,
......
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