diff options
author | Michael Niedermayer <michaelni@gmx.at> | 2014-01-06 02:51:20 +0100 |
---|---|---|
committer | Michael Niedermayer <michaelni@gmx.at> | 2014-01-06 04:32:37 +0100 |
commit | 4ced5d7780fea2ea49444d6686d26f26b3a2160f (patch) | |
tree | 62e1e3d0927c79dd6506de1c4aba4b6f45a6b030 /libavcodec/hevc.c | |
parent | d66bab0a69ac1860e78dd951ad8db1a507e75642 (diff) | |
download | ffmpeg-4ced5d7780fea2ea49444d6686d26f26b3a2160f.tar.gz |
avcodec/hevc: Fix modulo operations
Fixes qp fields becoming out of range
Fixes: asan_static-oob_e393a3_6998_WPP_A_ericsson_MAIN10_2.bit
Found-by: Mateusz "j00ru" Jurczyk and Gynvael Coldwind
Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
Diffstat (limited to 'libavcodec/hevc.c')
-rw-r--r-- | libavcodec/hevc.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/libavcodec/hevc.c b/libavcodec/hevc.c index 2f33d1d8a0..f001a6c627 100644 --- a/libavcodec/hevc.c +++ b/libavcodec/hevc.c @@ -688,8 +688,8 @@ static int hls_slice_header(HEVCContext *s) s->HEVClc->first_qp_group = !s->sh.dependent_slice_segment_flag; if (!s->pps->cu_qp_delta_enabled_flag) - s->HEVClc->qp_y = ((s->sh.slice_qp + 52 + 2 * s->sps->qp_bd_offset) % - (52 + s->sps->qp_bd_offset)) - s->sps->qp_bd_offset; + s->HEVClc->qp_y = FFUMOD(s->sh.slice_qp + 52 + 2 * s->sps->qp_bd_offset, + 52 + s->sps->qp_bd_offset) - s->sps->qp_bd_offset; s->slice_initialized = 1; |