mirror of
https://github.com/nyanmisaka/ffmpeg-rockchip.git
synced 2025-10-24 17:32:22 +08:00
avcodec/h264_picture: don't assume Film Grain Params side data will be present
If a decoding error happens before frame side data is allocated, this assert may be triggered. And since applying film grain is not enforced (we just warn it wasn't applied and move on), we can just do that in such scenarios. Fixes: Assertion failure Fixes: clusterfuzz-testcase-minimized-ffmpeg_AV_CODEC_ID_H264_fuzzer-5528650032742400 Signed-off-by: James Almer <jamrial@gmail.com>
This commit is contained in:
@@ -252,7 +252,9 @@ int ff_h264_field_end(H264Context *h, H264SliceContext *sl, int in_setup)
|
|||||||
"hardware accelerator failed to decode picture\n");
|
"hardware accelerator failed to decode picture\n");
|
||||||
} else if (!in_setup && cur->needs_fg && (!FIELD_PICTURE(h) || !h->first_field)) {
|
} else if (!in_setup && cur->needs_fg && (!FIELD_PICTURE(h) || !h->first_field)) {
|
||||||
AVFrameSideData *sd = av_frame_get_side_data(cur->f, AV_FRAME_DATA_FILM_GRAIN_PARAMS);
|
AVFrameSideData *sd = av_frame_get_side_data(cur->f, AV_FRAME_DATA_FILM_GRAIN_PARAMS);
|
||||||
av_assert0(sd); // always present if `cur->needs_fg`
|
|
||||||
|
err = AVERROR_INVALIDDATA;
|
||||||
|
if (sd) // a decoding error may have happened before the side data could be allocated
|
||||||
err = ff_h274_apply_film_grain(cur->f_grain, cur->f, &h->h274db,
|
err = ff_h274_apply_film_grain(cur->f_grain, cur->f, &h->h274db,
|
||||||
(AVFilmGrainParams *) sd->data);
|
(AVFilmGrainParams *) sd->data);
|
||||||
if (err < 0) {
|
if (err < 0) {
|
||||||
|
Reference in New Issue
Block a user