avcodec/h264_loopfilter: Fix incorrect function parameter array size

filter_mb_mbaff_edgev() and filter_mb_mbaff_edgecv()
have a function parameter whose expected size depends upon
another parameter: It is 2 * bsi + 1 (with bsi always being 1 or 2).
This array is declared as const int16_t[7], yet some of the callers
with bsi == 1 call it with only an const int16_t[4] available.
This leads to -Wstringop-overread warnings from GCC 12.1.

This commit fixes these by replacing [7] with [/* 2 * bsi + 1 */],
so that the expected range and its dependence on bsi is immediately
visible.

Signed-off-by: Andreas Rheinhardt <andreas.rheinhardt@outlook.com>
This commit is contained in:
Andreas Rheinhardt 2022-07-10 21:25:38 +02:00
parent 708890e78f
commit 890efee2b8

View File

@ -143,7 +143,7 @@ static av_always_inline void filter_mb_edgecv(uint8_t *pix, int stride,
static av_always_inline void filter_mb_mbaff_edgev(const H264Context *h, uint8_t *pix, static av_always_inline void filter_mb_mbaff_edgev(const H264Context *h, uint8_t *pix,
int stride, int stride,
const int16_t bS[7], int bsi, const int16_t bS[ /* 1 + 2 * bsi */ ], int bsi,
int qp, int a, int b, int qp, int a, int b,
int intra) int intra)
{ {
@ -166,7 +166,7 @@ static av_always_inline void filter_mb_mbaff_edgev(const H264Context *h, uint8_t
static av_always_inline void filter_mb_mbaff_edgecv(const H264Context *h, static av_always_inline void filter_mb_mbaff_edgecv(const H264Context *h,
uint8_t *pix, int stride, uint8_t *pix, int stride,
const int16_t bS[7], const int16_t bS[ /* 1 + 2 * bsi */ ],
int bsi, int qp, int a, int bsi, int qp, int a,
int b, int intra) int b, int intra)
{ {