summaryrefslogtreecommitdiff
path: root/libavcodec
diff options
context:
space:
mode:
authorMichael Niedermayer <michaelni@gmx.at>2015-06-08 23:36:59 +0200
committerMichael Niedermayer <michaelni@gmx.at>2015-06-09 01:01:01 +0200
commit028c59c17b14751e049a05abbdac52f885ad96a2 (patch)
treed4df9c608d84046c103b39607a37fd55a9f0dfcd /libavcodec
parent6fdbaa2b7fb56623ab2163f861952bc1408c39b3 (diff)
avcodec/jpeg2000dec: Fix high bit depth branch sample shift
Fix part of Ticket3619 Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
Diffstat (limited to 'libavcodec')
-rw-r--r--libavcodec/jpeg2000dec.c6
1 files changed, 4 insertions, 2 deletions
diff --git a/libavcodec/jpeg2000dec.c b/libavcodec/jpeg2000dec.c
index 1b441a5b0c..6587e7d90b 100644
--- a/libavcodec/jpeg2000dec.c
+++ b/libavcodec/jpeg2000dec.c
@@ -1284,6 +1284,8 @@ static int jpeg2000_decode_tile(Jpeg2000DecoderContext *s, Jpeg2000Tile *tile,
}
}
} else {
+ int precision = picture->format == AV_PIX_FMT_XYZ12 ? 16 : s->precision;
+
for (compno = 0; compno < s->ncomponents; compno++) {
Jpeg2000Component *comp = tile->comp + compno;
Jpeg2000CodingStyle *codsty = tile->codsty + compno;
@@ -1310,7 +1312,7 @@ static int jpeg2000_decode_tile(Jpeg2000DecoderContext *s, Jpeg2000Tile *tile,
/* DC level shift and clip see ISO 15444-1:2002 G.1.2 */
val = av_clip(val, 0, (1 << cbps) - 1);
/* align 12 bit values in little-endian mode */
- *dst = val << (16 - cbps);
+ *dst = val << (precision - cbps);
datap++;
dst += pixelsize;
}
@@ -1320,7 +1322,7 @@ static int jpeg2000_decode_tile(Jpeg2000DecoderContext *s, Jpeg2000Tile *tile,
/* DC level shift and clip see ISO 15444-1:2002 G.1.2 */
val = av_clip(val, 0, (1 << cbps) - 1);
/* align 12 bit values in little-endian mode */
- *dst = val << (16 - cbps);
+ *dst = val << (precision - cbps);
i_datap++;
dst += pixelsize;
}