Commit c44aa7f1 authored by Nick Renieris's avatar Nick Renieris Committed by Paul B Mahol
parent 31acdf43
...@@ -309,12 +309,17 @@ static void av_always_inline horizontal_fill(TiffContext *s, ...@@ -309,12 +309,17 @@ static void av_always_inline horizontal_fill(TiffContext *s,
dst[(width+offset)*2+0] = (usePtr ? src[width] : c) >> 4; dst[(width+offset)*2+0] = (usePtr ? src[width] : c) >> 4;
} }
break; break;
case 12: { case 10:
case 12:
case 14: {
uint16_t *dst16 = (uint16_t *)dst; uint16_t *dst16 = (uint16_t *)dst;
int is_dng = (s->tiff_type == TIFF_TYPE_DNG || s->tiff_type == TIFF_TYPE_CINEMADNG);
uint8_t shift = is_dng ? 0 : 16 - bpp;
GetBitContext gb; GetBitContext gb;
init_get_bits8(&gb, src, width); init_get_bits8(&gb, src, width);
for (int i = 0; i < s->width; i++) { for (int i = 0; i < s->width; i++) {
dst16[i] = get_bits(&gb, 12) << 4; dst16[i] = get_bits(&gb, bpp) << shift;
} }
} }
break; break;
...@@ -1067,7 +1072,9 @@ static int init_image(TiffContext *s, ThreadFrame *frame) ...@@ -1067,7 +1072,9 @@ static int init_image(TiffContext *s, ThreadFrame *frame)
return AVERROR_PATCHWELCOME; return AVERROR_PATCHWELCOME;
} }
break; break;
case 10101:
case 10121: case 10121:
case 10141:
switch (AV_RL32(s->pattern)) { switch (AV_RL32(s->pattern)) {
case 0x02010100: case 0x02010100:
s->avctx->pix_fmt = s->le ? AV_PIX_FMT_BAYER_RGGB16LE : AV_PIX_FMT_BAYER_RGGB16BE; s->avctx->pix_fmt = s->le ? AV_PIX_FMT_BAYER_RGGB16LE : AV_PIX_FMT_BAYER_RGGB16BE;
......
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