mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-01-24 13:56:33 +02:00
avcodec/svq3: Fix segfault on allocation error, avoid allocations
The very first thing the SVQ3 decoder currently does is allocating several SVQ3Frames, a structure which contains members that need to be freed on their own. If one of these allocations fails, the decoder calls its own close function to not leak the already allocated SVQ3Frames. Yet said function presumes that the SVQ3Frames have been successfully allocated as there is no check before freeing the members that need to be freed. This commit fixes this by making these frames part of the SVQ3Context, thereby avoiding the allocations altogether. Notice that the pointers to the frames have been retained in order to allow to just swap them as the code already does. Signed-off-by: Andreas Rheinhardt <andreas.rheinhardt@gmail.com> (cherry picked from commit 96061c5a4f690c3ab49e4458701bb013fd3dd57f)
This commit is contained in:
parent
2e05113b92
commit
7cfa8e1910
@ -147,6 +147,7 @@ typedef struct SVQ3Context {
|
||||
DECLARE_ALIGNED(8, uint8_t, non_zero_count_cache)[15 * 8];
|
||||
uint32_t dequant4_coeff[QP_MAX_NUM + 1][16];
|
||||
int block_offset[2 * (16 * 3)];
|
||||
SVQ3Frame frames[3];
|
||||
} SVQ3Context;
|
||||
|
||||
#define FULLPEL_MODE 1
|
||||
@ -1135,13 +1136,9 @@ static av_cold int svq3_decode_init(AVCodecContext *avctx)
|
||||
int marker_found = 0;
|
||||
int ret;
|
||||
|
||||
s->cur_pic = av_mallocz(sizeof(*s->cur_pic));
|
||||
s->last_pic = av_mallocz(sizeof(*s->last_pic));
|
||||
s->next_pic = av_mallocz(sizeof(*s->next_pic));
|
||||
if (!s->next_pic || !s->last_pic || !s->cur_pic) {
|
||||
ret = AVERROR(ENOMEM);
|
||||
goto fail;
|
||||
}
|
||||
s->cur_pic = &s->frames[0];
|
||||
s->last_pic = &s->frames[1];
|
||||
s->next_pic = &s->frames[2];
|
||||
|
||||
s->cur_pic->f = av_frame_alloc();
|
||||
s->last_pic->f = av_frame_alloc();
|
||||
@ -1631,9 +1628,6 @@ static av_cold int svq3_decode_end(AVCodecContext *avctx)
|
||||
av_frame_free(&s->cur_pic->f);
|
||||
av_frame_free(&s->next_pic->f);
|
||||
av_frame_free(&s->last_pic->f);
|
||||
av_freep(&s->cur_pic);
|
||||
av_freep(&s->next_pic);
|
||||
av_freep(&s->last_pic);
|
||||
av_freep(&s->slice_buf);
|
||||
av_freep(&s->intra4x4_pred_mode);
|
||||
av_freep(&s->edge_emu_buffer);
|
||||
|
Loading…
x
Reference in New Issue
Block a user