aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMichael Niedermayer <michaelni@gmx.at>2015-03-22 20:31:03 +0100
committerMichael Niedermayer <michaelni@gmx.at>2015-03-22 20:31:03 +0100
commita089d567f10e45ac3501f1f9741077a5df401859 (patch)
tree8c64f245512f44225c26a724f66f5fba09ec688a
parent74097e09023c2ebea3570dbc7a21ea493fdd7ebe (diff)
downloadffmpeg-a089d567f10e45ac3501f1f9741077a5df401859.tar.gz
avcodec/jpeglsdec: support PAL1-PAL7
Fixes Ticket3933 Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
-rw-r--r--libavcodec/jpeglsdec.c12
1 files changed, 10 insertions, 2 deletions
diff --git a/libavcodec/jpeglsdec.c b/libavcodec/jpeglsdec.c
index e85f511d71..e6fa01fe45 100644
--- a/libavcodec/jpeglsdec.c
+++ b/libavcodec/jpeglsdec.c
@@ -111,12 +111,20 @@ int ff_jpegls_decode_lse(MJpegDecodeContext *s)
if ((s->avctx->pix_fmt == AV_PIX_FMT_GRAY8 || s->avctx->pix_fmt == AV_PIX_FMT_PAL8) &&
(s->picture_ptr->format == AV_PIX_FMT_GRAY8 || s->picture_ptr->format == AV_PIX_FMT_PAL8)) {
uint32_t *pal = (uint32_t *)s->picture_ptr->data[1];
+ int shift = 0;
+
+ if (s->avctx->bits_per_raw_sample > 0 && s->avctx->bits_per_raw_sample < 8) {
+ maxtab = FFMIN(maxtab, (1<<s->avctx->bits_per_raw_sample)-1);
+ shift = 8 - s->avctx->bits_per_raw_sample;
+ }
+
s->picture_ptr->format =
s->avctx->pix_fmt = AV_PIX_FMT_PAL8;
for (i=s->palette_index; i<=maxtab; i++) {
- pal[i] = 0;
+ uint8_t k = i << shift;
+ pal[k] = 0;
for (j=0; j<wt; j++) {
- pal[i] |= get_bits(&s->gb, 8) << (8*(wt-j-1));
+ pal[k] |= get_bits(&s->gb, 8) << (8*(wt-j-1));
}
}
s->palette_index = i;