diff options
author | Carl Eugen Hoyos <cehoyos@ag.or.at> | 2016-09-28 17:49:39 +0200 |
---|---|---|
committer | Carl Eugen Hoyos <cehoyos@ag.or.at> | 2016-09-28 17:49:39 +0200 |
commit | 83bf40f3cfcf4b7545e41836b37f21806004f136 (patch) | |
tree | 45da019b69aabaf47bc6ca7fc2efaceca65db3bb /libavcodec | |
parent | 58776ccbdb4d2e5f07d1d0fe12a1529cffe949c0 (diff) | |
download | ffmpeg-83bf40f3cfcf4b7545e41836b37f21806004f136.tar.gz |
lavc/8bps: Fix 32bit output of 24bit video.
Regression since / partial revert of ba3bb53b
Diffstat (limited to 'libavcodec')
-rw-r--r-- | libavcodec/8bps.c | 13 | ||||
-rw-r--r-- | libavcodec/version.h | 2 |
2 files changed, 9 insertions, 6 deletions
diff --git a/libavcodec/8bps.c b/libavcodec/8bps.c index 46344e0e43..49fd445494 100644 --- a/libavcodec/8bps.c +++ b/libavcodec/8bps.c @@ -41,7 +41,7 @@ static const enum AVPixelFormat pixfmt_rgb24[] = { - AV_PIX_FMT_BGR24, AV_PIX_FMT_RGB32, AV_PIX_FMT_NONE }; + AV_PIX_FMT_BGR24, AV_PIX_FMT_0RGB32, AV_PIX_FMT_NONE }; typedef struct EightBpsContext { AVCodecContext *avctx; @@ -65,6 +65,7 @@ static int decode_frame(AVCodecContext *avctx, void *data, unsigned int dlen, p, row; const unsigned char *lp, *dp, *ep; unsigned char count; + unsigned int px_inc; unsigned int planes = c->planes; unsigned char *planemap = c->planemap; int ret; @@ -77,6 +78,8 @@ static int decode_frame(AVCodecContext *avctx, void *data, /* Set data pointer after line lengths */ dp = encoded + planes * (height << 1); + px_inc = planes + (avctx->pix_fmt == AV_PIX_FMT_0RGB32); + for (p = 0; p < planes; p++) { /* Lines length pointer for this plane */ lp = encoded + p * (height << 1); @@ -95,21 +98,21 @@ static int decode_frame(AVCodecContext *avctx, void *data, if ((count = *dp++) <= 127) { count++; dlen -= count + 1; - if (pixptr_end - pixptr < count * planes) + if (pixptr_end - pixptr < count * px_inc) break; if (ep - dp < count) return AVERROR_INVALIDDATA; while (count--) { *pixptr = *dp++; - pixptr += planes; + pixptr += px_inc; } } else { count = 257 - count; - if (pixptr_end - pixptr < count * planes) + if (pixptr_end - pixptr < count * px_inc) break; while (count--) { *pixptr = *dp; - pixptr += planes; + pixptr += px_inc; } dp++; dlen -= 2; diff --git a/libavcodec/version.h b/libavcodec/version.h index 636c9d64fe..e7778e9bc0 100644 --- a/libavcodec/version.h +++ b/libavcodec/version.h @@ -29,7 +29,7 @@ #define LIBAVCODEC_VERSION_MAJOR 57 #define LIBAVCODEC_VERSION_MINOR 58 -#define LIBAVCODEC_VERSION_MICRO 101 +#define LIBAVCODEC_VERSION_MICRO 102 #define LIBAVCODEC_VERSION_INT AV_VERSION_INT(LIBAVCODEC_VERSION_MAJOR, \ LIBAVCODEC_VERSION_MINOR, \ |