mirror of
https://git.ffmpeg.org/ffmpeg.git
synced 2025-01-14 19:31:24 +00:00
avcodec/msmpeg4enc: Don't use code for static init that can fail
Signed-off-by: Andreas Rheinhardt <andreas.rheinhardt@gmail.com>
This commit is contained in:
parent
afa511ad34
commit
f0042e573e
@ -1008,8 +1008,7 @@ FF_ENABLE_DEPRECATION_WARNINGS
|
|||||||
if (CONFIG_H263_ENCODER && s->out_format == FMT_H263)
|
if (CONFIG_H263_ENCODER && s->out_format == FMT_H263)
|
||||||
ff_h263_encode_init(s);
|
ff_h263_encode_init(s);
|
||||||
if (CONFIG_MSMPEG4_ENCODER && s->msmpeg4_version)
|
if (CONFIG_MSMPEG4_ENCODER && s->msmpeg4_version)
|
||||||
if ((ret = ff_msmpeg4_encode_init(s)) < 0)
|
ff_msmpeg4_encode_init(s);
|
||||||
return ret;
|
|
||||||
if ((CONFIG_MPEG1VIDEO_ENCODER || CONFIG_MPEG2VIDEO_ENCODER)
|
if ((CONFIG_MPEG1VIDEO_ENCODER || CONFIG_MPEG2VIDEO_ENCODER)
|
||||||
&& s->out_format == FMT_MPEG1)
|
&& s->out_format == FMT_MPEG1)
|
||||||
ff_mpeg1_encode_init(s);
|
ff_mpeg1_encode_init(s);
|
||||||
|
@ -50,7 +50,7 @@ void ff_msmpeg4_encode_motion(MpegEncContext * s, int mx, int my);
|
|||||||
int ff_msmpeg4_coded_block_pred(MpegEncContext * s, int n,
|
int ff_msmpeg4_coded_block_pred(MpegEncContext * s, int n,
|
||||||
uint8_t **coded_block_ptr);
|
uint8_t **coded_block_ptr);
|
||||||
|
|
||||||
int ff_msmpeg4_encode_init(MpegEncContext *s);
|
void ff_msmpeg4_encode_init(MpegEncContext *s);
|
||||||
void ff_msmpeg4_encode_picture_header(MpegEncContext *s, int picture_number);
|
void ff_msmpeg4_encode_picture_header(MpegEncContext *s, int picture_number);
|
||||||
void ff_msmpeg4_encode_ext_header(MpegEncContext *s);
|
void ff_msmpeg4_encode_ext_header(MpegEncContext *s);
|
||||||
void ff_msmpeg4_encode_mb(MpegEncContext *s, int16_t block[6][64],
|
void ff_msmpeg4_encode_mb(MpegEncContext *s, int16_t block[6][64],
|
||||||
|
@ -32,7 +32,6 @@
|
|||||||
|
|
||||||
#include "libavutil/attributes.h"
|
#include "libavutil/attributes.h"
|
||||||
#include "libavutil/avutil.h"
|
#include "libavutil/avutil.h"
|
||||||
#include "libavutil/mem.h"
|
|
||||||
#include "mpegvideo.h"
|
#include "mpegvideo.h"
|
||||||
#include "h263.h"
|
#include "h263.h"
|
||||||
#include "internal.h"
|
#include "internal.h"
|
||||||
@ -46,13 +45,11 @@
|
|||||||
static uint8_t rl_length[NB_RL_TABLES][MAX_LEVEL+1][MAX_RUN+1][2];
|
static uint8_t rl_length[NB_RL_TABLES][MAX_LEVEL+1][MAX_RUN+1][2];
|
||||||
|
|
||||||
/* build the table which associate a (x,y) motion vector to a vlc */
|
/* build the table which associate a (x,y) motion vector to a vlc */
|
||||||
static av_cold int init_mv_table(MVTable *tab)
|
static av_cold void init_mv_table(MVTable *tab, uint16_t table_mv_index[4096])
|
||||||
{
|
{
|
||||||
int i, x, y;
|
int i, x, y;
|
||||||
|
|
||||||
tab->table_mv_index = av_malloc(sizeof(uint16_t) * 4096);
|
tab->table_mv_index = table_mv_index;
|
||||||
if (!tab->table_mv_index)
|
|
||||||
return AVERROR(ENOMEM);
|
|
||||||
|
|
||||||
/* mark all entries as not used */
|
/* mark all entries as not used */
|
||||||
for(i=0;i<4096;i++)
|
for(i=0;i<4096;i++)
|
||||||
@ -63,8 +60,6 @@ static av_cold int init_mv_table(MVTable *tab)
|
|||||||
y = tab->table_mvy[i];
|
y = tab->table_mvy[i];
|
||||||
tab->table_mv_index[(x << 6) | y] = i;
|
tab->table_mv_index[(x << 6) | y] = i;
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void ff_msmpeg4_code012(PutBitContext *pb, int n)
|
void ff_msmpeg4_code012(PutBitContext *pb, int n)
|
||||||
@ -118,10 +113,10 @@ static int get_size_of_code(MpegEncContext * s, RLTable *rl, int last, int run,
|
|||||||
return size;
|
return size;
|
||||||
}
|
}
|
||||||
|
|
||||||
av_cold int ff_msmpeg4_encode_init(MpegEncContext *s)
|
av_cold void ff_msmpeg4_encode_init(MpegEncContext *s)
|
||||||
{
|
{
|
||||||
static int init_done=0;
|
static int init_done=0;
|
||||||
int i, ret;
|
int i;
|
||||||
|
|
||||||
ff_msmpeg4_common_init(s);
|
ff_msmpeg4_common_init(s);
|
||||||
if(s->msmpeg4_version>=4){
|
if(s->msmpeg4_version>=4){
|
||||||
@ -130,12 +125,12 @@ av_cold int ff_msmpeg4_encode_init(MpegEncContext *s)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!init_done) {
|
if (!init_done) {
|
||||||
|
static uint16_t mv_index_tables[2][4096];
|
||||||
/* init various encoding tables */
|
/* init various encoding tables */
|
||||||
init_done = 1;
|
init_done = 1;
|
||||||
if ((ret = init_mv_table(&ff_mv_tables[0])) < 0)
|
init_mv_table(&ff_mv_tables[0], mv_index_tables[0]);
|
||||||
return ret;
|
init_mv_table(&ff_mv_tables[1], mv_index_tables[1]);
|
||||||
if ((ret = init_mv_table(&ff_mv_tables[1])) < 0)
|
|
||||||
return ret;
|
|
||||||
for(i=0;i<NB_RL_TABLES;i++)
|
for(i=0;i<NB_RL_TABLES;i++)
|
||||||
ff_rl_init(&ff_rl_table[i], ff_static_rl_table_store[i]);
|
ff_rl_init(&ff_rl_table[i], ff_static_rl_table_store[i]);
|
||||||
|
|
||||||
@ -152,8 +147,6 @@ av_cold int ff_msmpeg4_encode_init(MpegEncContext *s)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void find_best_tables(MpegEncContext * s)
|
static void find_best_tables(MpegEncContext * s)
|
||||||
|
Loading…
Reference in New Issue
Block a user