aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMichael Niedermayer <michaelni@gmx.at>2012-01-02 19:06:46 +0100
committerMichael Niedermayer <michaelni@gmx.at>2012-01-03 22:51:48 +0100
commit80695c9d1f0dcfc96f7c2d4a469d0ecc5939fb2f (patch)
treead047d60a48f0739dcd96f96f043b734269a4a36
parent17c3ec77c2d1c4304054d7ad005aacfb3b78bdef (diff)
downloadffmpeg-80695c9d1f0dcfc96f7c2d4a469d0ecc5939fb2f.tar.gz
jpegdec: non interleaved rgb ljpeg support.
Fixes Ticket856 Signed-off-by: Michael Niedermayer <michaelni@gmx.at> (cherry picked from commit 45552371e3434fb7aa4d0bc566fd4ef954f9af14) Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
-rw-r--r--libavcodec/mjpegdec.c15
1 files changed, 8 insertions, 7 deletions
diff --git a/libavcodec/mjpegdec.c b/libavcodec/mjpegdec.c
index 5018edb4ba..41722c425a 100644
--- a/libavcodec/mjpegdec.c
+++ b/libavcodec/mjpegdec.c
@@ -648,7 +648,7 @@ static int decode_block_refinement(MJpegDecodeContext *s, DCTELEM *block, uint8_
#undef REFINE_BIT
#undef ZERO_RUN
-static int ljpeg_decode_rgb_scan(MJpegDecodeContext *s, int predictor, int point_transform){
+static int ljpeg_decode_rgb_scan(MJpegDecodeContext *s, int nb_components, int predictor, int point_transform){
int i, mb_x, mb_y;
uint16_t (*buffer)[4];
int left[3], top[3], topleft[3];
@@ -675,7 +675,7 @@ static int ljpeg_decode_rgb_scan(MJpegDecodeContext *s, int predictor, int point
if (s->restart_interval && !s->restart_count)
s->restart_count = s->restart_interval;
- for(i=0;i<3;i++) {
+ for(i=0;i<nb_components;i++) {
int pred, dc;
topleft[i]= top[i];
@@ -710,10 +710,11 @@ static int ljpeg_decode_rgb_scan(MJpegDecodeContext *s, int predictor, int point
ptr[3*mb_x+2] = buffer[mb_x][2] + ptr[3*mb_x+1];
}
}else{
- for(mb_x = 0; mb_x < s->mb_width; mb_x++) {
- ptr[3*mb_x+0] = buffer[mb_x][2];
- ptr[3*mb_x+1] = buffer[mb_x][1];
- ptr[3*mb_x+2] = buffer[mb_x][0];
+ for(i=0;i<nb_components;i++) {
+ int c= s->comp_index[i];
+ for(mb_x = 0; mb_x < s->mb_width; mb_x++) {
+ ptr[3*mb_x+2-c] = buffer[mb_x][i];
+ }
}
}
}
@@ -1117,7 +1118,7 @@ int ff_mjpeg_decode_sos(MJpegDecodeContext *s,
return -1;
}else{
if(s->rgb){
- if(ljpeg_decode_rgb_scan(s, predictor, point_transform) < 0)
+ if(ljpeg_decode_rgb_scan(s, nb_components, predictor, point_transform) < 0)
return -1;
}else{
if(ljpeg_decode_yuv_scan(s, predictor, point_transform) < 0)