Commit 002b0499 authored by Paul B Mahol's avatar Paul B Mahol

avfilter/af_ladspa: check functions return value in query_formats

Signed-off-by: 's avatarPaul B Mahol <onemda@gmail.com>
parent 62144b22
...@@ -597,22 +597,29 @@ static int query_formats(AVFilterContext *ctx) ...@@ -597,22 +597,29 @@ static int query_formats(AVFilterContext *ctx)
AVFilterChannelLayouts *layouts; AVFilterChannelLayouts *layouts;
static const enum AVSampleFormat sample_fmts[] = { static const enum AVSampleFormat sample_fmts[] = {
AV_SAMPLE_FMT_FLTP, AV_SAMPLE_FMT_NONE }; AV_SAMPLE_FMT_FLTP, AV_SAMPLE_FMT_NONE };
int ret;
formats = ff_make_format_list(sample_fmts); formats = ff_make_format_list(sample_fmts);
if (!formats) if (!formats)
return AVERROR(ENOMEM); return AVERROR(ENOMEM);
ff_set_common_formats(ctx, formats); ret = ff_set_common_formats(ctx, formats);
if (ret < 0)
return ret;
if (s->nb_inputs) { if (s->nb_inputs) {
formats = ff_all_samplerates(); formats = ff_all_samplerates();
if (!formats) if (!formats)
return AVERROR(ENOMEM); return AVERROR(ENOMEM);
ff_set_common_samplerates(ctx, formats); ret = ff_set_common_samplerates(ctx, formats);
if (ret < 0)
return ret;
} else { } else {
int sample_rates[] = { s->sample_rate, -1 }; int sample_rates[] = { s->sample_rate, -1 };
ff_set_common_samplerates(ctx, ff_make_format_list(sample_rates)); ret = ff_set_common_samplerates(ctx, ff_make_format_list(sample_rates));
if (ret < 0)
return ret;
} }
if (s->nb_inputs == 1 && s->nb_outputs == 1) { if (s->nb_inputs == 1 && s->nb_outputs == 1) {
...@@ -621,11 +628,17 @@ static int query_formats(AVFilterContext *ctx) ...@@ -621,11 +628,17 @@ static int query_formats(AVFilterContext *ctx)
if (!layouts) if (!layouts)
return AVERROR(ENOMEM); return AVERROR(ENOMEM);
ff_set_common_channel_layouts(ctx, layouts); ret = ff_set_common_channel_layouts(ctx, layouts);
if (ret < 0)
return ret;
} else if (s->nb_inputs == 2 && s->nb_outputs == 2) { } else if (s->nb_inputs == 2 && s->nb_outputs == 2) {
layouts = NULL; layouts = NULL;
ff_add_channel_layout(&layouts, AV_CH_LAYOUT_STEREO); ret = ff_add_channel_layout(&layouts, AV_CH_LAYOUT_STEREO);
ff_set_common_channel_layouts(ctx, layouts); if (ret < 0)
return ret;
ret = ff_set_common_channel_layouts(ctx, layouts);
if (ret < 0)
return ret;
} else { } else {
AVFilterLink *outlink = ctx->outputs[0]; AVFilterLink *outlink = ctx->outputs[0];
...@@ -634,19 +647,30 @@ static int query_formats(AVFilterContext *ctx) ...@@ -634,19 +647,30 @@ static int query_formats(AVFilterContext *ctx)
int64_t inlayout = FF_COUNT2LAYOUT(s->nb_inputs); int64_t inlayout = FF_COUNT2LAYOUT(s->nb_inputs);
layouts = NULL; layouts = NULL;
ff_add_channel_layout(&layouts, inlayout); ret = ff_add_channel_layout(&layouts, inlayout);
ff_channel_layouts_ref(layouts, &inlink->out_channel_layouts); if (ret < 0)
return ret;
if (!s->nb_outputs) ret = ff_channel_layouts_ref(layouts, &inlink->out_channel_layouts);
ff_channel_layouts_ref(layouts, &outlink->in_channel_layouts); if (ret < 0)
return ret;
if (!s->nb_outputs) {
ret = ff_channel_layouts_ref(layouts, &outlink->in_channel_layouts);
if (ret < 0)
return ret;
}
} }
if (s->nb_outputs >= 1) { if (s->nb_outputs >= 1) {
int64_t outlayout = FF_COUNT2LAYOUT(s->nb_outputs); int64_t outlayout = FF_COUNT2LAYOUT(s->nb_outputs);
layouts = NULL; layouts = NULL;
ff_add_channel_layout(&layouts, outlayout); ret = ff_add_channel_layout(&layouts, outlayout);
ff_channel_layouts_ref(layouts, &outlink->in_channel_layouts); if (ret < 0)
return ret;
ret = ff_channel_layouts_ref(layouts, &outlink->in_channel_layouts);
if (ret < 0)
return ret;
} }
} }
......
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