Skip to content

Commit 99ee7a9

Browse files
committed
lavfi: move AVFilterLink.m{ax,in}_samples to FilterLink
Also, document who sets these fields and when.
1 parent 54754ee commit 99ee7a9

File tree

7 files changed

+40
-27
lines changed

7 files changed

+40
-27
lines changed

libavfilter/af_firequalizer.c

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -26,6 +26,7 @@
2626
#include "libavutil/avassert.h"
2727
#include "libavutil/tx.h"
2828
#include "avfilter.h"
29+
#include "filters.h"
2930
#include "internal.h"
3031
#include "audio.h"
3132

@@ -725,6 +726,7 @@ static int generate_kernel(AVFilterContext *ctx, const char *gain, const char *g
725726

726727
static int config_input(AVFilterLink *inlink)
727728
{
729+
FilterLink *l = ff_filter_link(inlink);
728730
AVFilterContext *ctx = inlink->dst;
729731
FIREqualizerContext *s = ctx->priv;
730732
float iscale, scale = 1.f;
@@ -824,7 +826,7 @@ static int config_input(AVFilterLink *inlink)
824826
inlink->sample_rate, inlink->ch_layout.nb_channels, s->analysis_rdft_len, s->rdft_len, s->fir_len, s->nsamples_max);
825827

826828
if (s->fixed)
827-
inlink->min_samples = inlink->max_samples = s->nsamples_max;
829+
l->min_samples = l->max_samples = s->nsamples_max;
828830

829831
return generate_kernel(ctx, SELECT_GAIN(s), SELECT_GAIN_ENTRY(s));
830832
}

libavfilter/af_lv2.c

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -34,6 +34,7 @@
3434
#include "libavutil/opt.h"
3535
#include "audio.h"
3636
#include "avfilter.h"
37+
#include "filters.h"
3738
#include "formats.h"
3839
#include "internal.h"
3940

@@ -381,7 +382,7 @@ static int config_output(AVFilterLink *outlink)
381382
(lilv_plugin_has_feature(s->plugin, s->powerOf2BlockLength) ||
382383
lilv_plugin_has_feature(s->plugin, s->fixedBlockLength) ||
383384
lilv_plugin_has_feature(s->plugin, s->boundedBlockLength))) {
384-
AVFilterLink *inlink = ctx->inputs[0];
385+
FilterLink *inlink = ff_filter_link(ctx->inputs[0]);
385386

386387
inlink->min_samples = inlink->max_samples = 4096;
387388
}

libavfilter/af_replaygain.c

Lines changed: 4 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -30,6 +30,7 @@
3030
#include "libavutil/opt.h"
3131
#include "audio.h"
3232
#include "avfilter.h"
33+
#include "filters.h"
3334
#include "formats.h"
3435
#include "internal.h"
3536

@@ -349,6 +350,7 @@ static int query_formats(AVFilterContext *ctx)
349350

350351
static int config_input(AVFilterLink *inlink)
351352
{
353+
FilterLink *l = ff_filter_link(inlink);
352354
AVFilterContext *ctx = inlink->dst;
353355
ReplayGainContext *s = ctx->priv;
354356
int i;
@@ -366,8 +368,8 @@ static int config_input(AVFilterLink *inlink)
366368

367369
s->yule_hist_i = 20;
368370
s->butter_hist_i = 4;
369-
inlink->min_samples =
370-
inlink->max_samples = inlink->sample_rate / 20;
371+
l->min_samples =
372+
l->max_samples = inlink->sample_rate / 20;
371373

372374
return 0;
373375
}

libavfilter/avfilter.c

Lines changed: 7 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -1077,14 +1077,15 @@ static int samples_ready(FilterLinkInternal *link, unsigned min)
10771077
static int take_samples(FilterLinkInternal *li, unsigned min, unsigned max,
10781078
AVFrame **rframe)
10791079
{
1080-
AVFilterLink *link = &li->l.pub;
1080+
FilterLink *l = &li->l;
1081+
AVFilterLink *link = &l->pub;
10811082
AVFrame *frame0, *frame, *buf;
10821083
unsigned nb_samples, nb_frames, i, p;
10831084
int ret;
10841085

10851086
/* Note: this function relies on no format changes and must only be
10861087
called with enough samples. */
1087-
av_assert1(samples_ready(li, link->min_samples));
1088+
av_assert1(samples_ready(li, l->min_samples));
10881089
frame0 = frame = ff_framequeue_peek(&li->fifo, 0);
10891090
if (!li->fifo.samples_skipped && frame->nb_samples >= min && frame->nb_samples <= max) {
10901091
*rframe = ff_framequeue_take(&li->fifo);
@@ -1142,8 +1143,8 @@ static int ff_filter_frame_to_filter(AVFilterLink *link)
11421143
int ret;
11431144

11441145
av_assert1(ff_framequeue_queued_frames(&li->fifo));
1145-
ret = link->min_samples ?
1146-
ff_inlink_consume_samples(link, link->min_samples, link->max_samples, &frame) :
1146+
ret = li->l.min_samples ?
1147+
ff_inlink_consume_samples(link, li->l.min_samples, li->l.max_samples, &frame) :
11471148
ff_inlink_consume_frame(link, &frame);
11481149
av_assert1(ret);
11491150
if (ret < 0) {
@@ -1218,8 +1219,8 @@ static int ff_filter_activate_default(AVFilterContext *filter)
12181219
}
12191220

12201221
for (i = 0; i < filter->nb_inputs; i++) {
1221-
if (samples_ready(ff_link_internal(filter->inputs[i]),
1222-
filter->inputs[i]->min_samples)) {
1222+
FilterLinkInternal *li = ff_link_internal(filter->inputs[i]);
1223+
if (samples_ready(li, li->l.min_samples)) {
12231224
return ff_filter_frame_to_filter(filter->inputs[i]);
12241225
}
12251226
}

libavfilter/avfilter.h

Lines changed: 0 additions & 15 deletions
Original file line numberDiff line numberDiff line change
@@ -625,21 +625,6 @@ struct AVFilterLink {
625625
*/
626626
AVRational frame_rate;
627627

628-
/**
629-
* Minimum number of samples to filter at once. If filter_frame() is
630-
* called with fewer samples, it will accumulate them in fifo.
631-
* This field and the related ones must not be changed after filtering
632-
* has started.
633-
* If 0, all related fields are ignored.
634-
*/
635-
int min_samples;
636-
637-
/**
638-
* Maximum number of samples to filter at once. If filter_frame() is
639-
* called with more samples, it will split them.
640-
*/
641-
int max_samples;
642-
643628
/**
644629
* Number of past frames sent through the link.
645630
*/

libavfilter/buffersink.c

Lines changed: 3 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -119,7 +119,8 @@ static int get_frame_internal(AVFilterContext *ctx, AVFrame *frame, int flags, i
119119

120120
int attribute_align_arg av_buffersink_get_frame_flags(AVFilterContext *ctx, AVFrame *frame, int flags)
121121
{
122-
return get_frame_internal(ctx, frame, flags, ctx->inputs[0]->min_samples);
122+
return get_frame_internal(ctx, frame, flags,
123+
ff_filter_link(ctx->inputs[0])->min_samples);
123124
}
124125

125126
int attribute_align_arg av_buffersink_get_samples(AVFilterContext *ctx,
@@ -163,7 +164,7 @@ static int activate(AVFilterContext *ctx)
163164

164165
void av_buffersink_set_frame_size(AVFilterContext *ctx, unsigned frame_size)
165166
{
166-
AVFilterLink *inlink = ctx->inputs[0];
167+
FilterLink *inlink = ff_filter_link(ctx->inputs[0]);
167168

168169
inlink->min_samples = inlink->max_samples = frame_size;
169170
}

libavfilter/filters.h

Lines changed: 21 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -41,8 +41,29 @@
4141
*/
4242
typedef struct FilterLink {
4343
AVFilterLink pub;
44+
45+
/**
46+
* Minimum number of samples to filter at once.
47+
*
48+
* May be set by the link destination filter in its config_props().
49+
* If 0, all related fields are ignored.
50+
*/
51+
int min_samples;
52+
53+
/**
54+
* Maximum number of samples to filter at once. If filter_frame() is
55+
* called with more samples, it will split them.
56+
*
57+
* May be set by the link destination filter in its config_props().
58+
*/
59+
int max_samples;
4460
} FilterLink;
4561

62+
static inline FilterLink* ff_filter_link(AVFilterLink *link)
63+
{
64+
return (FilterLink*)link;
65+
}
66+
4667
/**
4768
* Mark a filter ready and schedule it for activation.
4869
*

0 commit comments

Comments
 (0)