summaryrefslogtreecommitdiff
path: root/libavfilter/af_superequalizer.c
diff options
context:
space:
mode:
authorPaul B Mahol <onemda@gmail.com>2019-05-27 17:24:22 +0200
committerPaul B Mahol <onemda@gmail.com>2019-05-27 17:36:30 +0200
commit293489d8355a3c6e3485eb7d621cd64af80b7bf5 (patch)
tree73261e340efc80229ccb3e69bfed1e6457b54817 /libavfilter/af_superequalizer.c
parent3da8d04c18fedcedc6c52137ed310a2a0fe27577 (diff)
avfilter/af_superequalizer: switch to activate
Diffstat (limited to 'libavfilter/af_superequalizer.c')
-rw-r--r--libavfilter/af_superequalizer.c31
1 files changed, 25 insertions, 6 deletions
diff --git a/libavfilter/af_superequalizer.c b/libavfilter/af_superequalizer.c
index f38cca5c8b..f11ec9e6d1 100644
--- a/libavfilter/af_superequalizer.c
+++ b/libavfilter/af_superequalizer.c
@@ -25,6 +25,7 @@
#include "audio.h"
#include "avfilter.h"
+#include "filters.h"
#include "internal.h"
#define NBANDS 17
@@ -203,7 +204,7 @@ static int filter_frame(AVFilterLink *inlink, AVFrame *in)
dst = (float *)s->out->extended_data[ch];
src = (float *)in->extended_data[ch];
- for (i = 0; i < s->winlen; i++)
+ for (i = 0; i < in->nb_samples; i++)
fsamples[i] = src[i];
for (; i < s->tabsize; i++)
fsamples[i] = 0;
@@ -240,6 +241,28 @@ static int filter_frame(AVFilterLink *inlink, AVFrame *in)
return ff_filter_frame(outlink, out);
}
+static int activate(AVFilterContext *ctx)
+{
+ AVFilterLink *inlink = ctx->inputs[0];
+ AVFilterLink *outlink = ctx->outputs[0];
+ SuperEqualizerContext *s = ctx->priv;
+ AVFrame *in = NULL;
+ int ret;
+
+ FF_FILTER_FORWARD_STATUS_BACK(outlink, inlink);
+
+ ret = ff_inlink_consume_samples(inlink, s->winlen, s->winlen, &in);
+ if (ret < 0)
+ return ret;
+ if (ret > 0)
+ return filter_frame(inlink, in);
+
+ FF_FILTER_FORWARD_STATUS(inlink, outlink);
+ FF_FILTER_FORWARD_WANTED(outlink, inlink);
+
+ return FFERROR_NOT_READY;
+}
+
static av_cold int init(AVFilterContext *ctx)
{
SuperEqualizerContext *s = ctx->priv;
@@ -277,10 +300,6 @@ static int config_input(AVFilterLink *inlink)
AVFilterContext *ctx = inlink->dst;
SuperEqualizerContext *s = ctx->priv;
- inlink->partial_buf_size =
- inlink->min_samples =
- inlink->max_samples = s->winlen;
-
s->out = ff_get_audio_buffer(inlink, s->tabsize);
if (!s->out)
return AVERROR(ENOMEM);
@@ -314,7 +333,6 @@ static const AVFilterPad superequalizer_inputs[] = {
{
.name = "default",
.type = AVMEDIA_TYPE_AUDIO,
- .filter_frame = filter_frame,
.config_props = config_input,
},
{ NULL }
@@ -363,6 +381,7 @@ AVFilter ff_af_superequalizer = {
.priv_class = &superequalizer_class,
.query_formats = query_formats,
.init = init,
+ .activate = activate,
.uninit = uninit,
.inputs = superequalizer_inputs,
.outputs = superequalizer_outputs,