aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMichael Niedermayer <michaelni@gmx.at>2014-10-29 14:15:29 +0100
committerMichael Niedermayer <michaelni@gmx.at>2014-11-01 13:28:14 +0100
commit24d725f455742378048e6a7e41dd21ec8df893e2 (patch)
tree261f10d7e528b08a33b380125634ce70d151e67a
parent66fcf1fa404ea4b32ed02f6cd9ca1b057ae4fc6c (diff)
downloadffmpeg-24d725f455742378048e6a7e41dd21ec8df893e2.tar.gz
avcodec/utils: Align dimensions by at least their chroma sub-sampling factors.
Fixes: out of array accesses Fixes: asan_heap-oob_112c6b3_13_012.avi Found-by: Mateusz "j00ru" Jurczyk and Gynvael Coldwind Signed-off-by: Michael Niedermayer <michaelni@gmx.at> (cherry picked from commit df74811cd53e45fcbbd3b77a1c42416816687c5c) Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
-rw-r--r--libavcodec/utils.c8
1 files changed, 6 insertions, 2 deletions
diff --git a/libavcodec/utils.c b/libavcodec/utils.c
index 07874c238f..4931444583 100644
--- a/libavcodec/utils.c
+++ b/libavcodec/utils.c
@@ -279,6 +279,12 @@ void avcodec_align_dimensions2(AVCodecContext *s, int *width, int *height,
int i;
int w_align = 1;
int h_align = 1;
+ AVPixFmtDescriptor *desc = av_pix_fmt_desc_get(s->pix_fmt);
+
+ if (desc) {
+ w_align = 1 << desc->log2_chroma_w;
+ h_align = 1 << desc->log2_chroma_h;
+ }
switch (s->pix_fmt) {
case AV_PIX_FMT_YUV420P:
@@ -406,8 +412,6 @@ void avcodec_align_dimensions2(AVCodecContext *s, int *width, int *height,
}
break;
default:
- w_align = 1;
- h_align = 1;
break;
}