Commit f39ab207 authored by Loren Merritt's avatar Loren Merritt

change a variable-length array to a malloc.

Originally committed as revision 23103 to svn://svn.ffmpeg.org/ffmpeg/trunk
parent 7693b93e
...@@ -275,8 +275,8 @@ int init_vlc_sparse(VLC *vlc, int nb_bits, int nb_codes, ...@@ -275,8 +275,8 @@ int init_vlc_sparse(VLC *vlc, int nb_bits, int nb_codes,
const void *symbols, int symbols_wrap, int symbols_size, const void *symbols, int symbols_wrap, int symbols_size,
int flags) int flags)
{ {
VLCcode buf[nb_codes]; VLCcode *buf;
int i, j; int i, j, ret;
vlc->bits = nb_bits; vlc->bits = nb_bits;
if(flags & INIT_VLC_USE_NEW_STATIC){ if(flags & INIT_VLC_USE_NEW_STATIC){
...@@ -295,6 +295,8 @@ int init_vlc_sparse(VLC *vlc, int nb_bits, int nb_codes, ...@@ -295,6 +295,8 @@ int init_vlc_sparse(VLC *vlc, int nb_bits, int nb_codes,
av_log(NULL,AV_LOG_DEBUG,"build table nb_codes=%d\n", nb_codes); av_log(NULL,AV_LOG_DEBUG,"build table nb_codes=%d\n", nb_codes);
#endif #endif
buf = av_malloc((nb_codes+1)*sizeof(VLCcode));
assert(symbols_size <= 2 || !symbols); assert(symbols_size <= 2 || !symbols);
j = 0; j = 0;
#define COPY(condition)\ #define COPY(condition)\
...@@ -319,7 +321,10 @@ int init_vlc_sparse(VLC *vlc, int nb_bits, int nb_codes, ...@@ -319,7 +321,10 @@ int init_vlc_sparse(VLC *vlc, int nb_bits, int nb_codes,
COPY(buf[j].bits && buf[j].bits <= nb_bits); COPY(buf[j].bits && buf[j].bits <= nb_bits);
nb_codes = j; nb_codes = j;
if (build_table(vlc, nb_bits, nb_codes, buf, flags) < 0) { ret = build_table(vlc, nb_bits, nb_codes, buf, flags);
av_free(buf);
if (ret < 0) {
av_freep(&vlc->table); av_freep(&vlc->table);
return -1; return -1;
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment