aboutsummaryrefslogtreecommitdiffstats
path: root/libavcodec
diff options
context:
space:
mode:
authorMichael Niedermayer <michaelni@gmx.at>2014-10-03 17:54:21 +0200
committerMichael Niedermayer <michaelni@gmx.at>2014-10-05 14:20:32 +0200
commitd1e71ecbb01717a636ebcaf927109f75b7e895ec (patch)
tree7302df6a819f49f22215dd47fa0381bd57a2fa52 /libavcodec
parent64be1a45eb2604deca259319780ce02bd921859b (diff)
downloadffmpeg-d1e71ecbb01717a636ebcaf927109f75b7e895ec.tar.gz
avcodec/pngdec: Calculate MPNG bytewidth more defensively
Signed-off-by: Michael Niedermayer <michaelni@gmx.at> (cherry picked from commit e830902934a29df05c7af65aef2a480b15f572c4) Conflicts: libavcodec/pngdec.c
Diffstat (limited to 'libavcodec')
-rw-r--r--libavcodec/pngdec.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/libavcodec/pngdec.c b/libavcodec/pngdec.c
index d3b1df21a8..d4f633ac70 100644
--- a/libavcodec/pngdec.c
+++ b/libavcodec/pngdec.c
@@ -841,10 +841,11 @@ static int decode_frame(AVCodecContext *avctx,
int i, j;
uint8_t *pd = p->data[0];
uint8_t *pd_last = s->last_picture.f->data[0];
+ int ls = FFMIN(av_image_get_linesize(p->format, s->width, 0), s->width * s->bpp);
ff_thread_await_progress(&s->last_picture, INT_MAX, 0);
for (j = 0; j < s->height; j++) {
- for (i = 0; i < s->width * s->bpp; i++) {
+ for (i = 0; i < ls; i++) {
pd[i] += pd_last[i];
}
pd += s->image_linesize;