Browse Source

avfilter/formats: free the correct pointer in ADD_FORMAT()

Also only free it when it was not previously allocated to return to the
state prior to the failing function call

Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
tags/n2.5
Michael Niedermayer 11 years ago
parent
commit
75819fafd8
1 changed files with 3 additions and 1 deletions
  1. +3
    -1
      libavfilter/formats.c

+ 3
- 1
libavfilter/formats.c View File

@@ -314,6 +314,7 @@ AVFilterChannelLayouts *avfilter_make_format64_list(const int64_t *fmts)
#define ADD_FORMAT(f, fmt, type, list, nb) \
do { \
type *fmts; \
void *oldf = *f; \
\
if (!(*f) && !(*f = av_mallocz(sizeof(**f)))) \
return AVERROR(ENOMEM); \
@@ -321,7 +322,8 @@ do { \
fmts = av_realloc((*f)->list, \
sizeof(*(*f)->list) * ((*f)->nb + 1));\
if (!fmts) { \
av_freep(&f); \
if (!oldf) \
av_freep(f); \
return AVERROR(ENOMEM); \
} \
\


Loading…
Cancel
Save