af_amerge.c File Reference

Audio merging filter. More...

#include "libavutil/avstring.h"
#include "libavutil/bprint.h"
#include "libavutil/channel_layout.h"
#include "libavutil/opt.h"
#include "libswresample/swresample.h"
#include "avfilter.h"
#include "audio.h"
#include "bufferqueue.h"
#include "internal.h"
Include dependency graph for af_amerge.c:

Go to the source code of this file.

Data Structures

struct  AMergeContext
 
struct  AMergeContext::amerge_input
 

Macros

#define OFFSET(x)   offsetof(AMergeContext, x)
 
#define FLAGS   AV_OPT_FLAG_AUDIO_PARAM|AV_OPT_FLAG_FILTERING_PARAM
 

Functions

 AVFILTER_DEFINE_CLASS (amerge)
 
static av_cold void uninit (AVFilterContext *ctx)
 
static int query_formats (AVFilterContext *ctx)
 
static int config_output (AVFilterLink *outlink)
 
static int request_frame (AVFilterLink *outlink)
 
static void copy_samples (int nb_inputs, struct amerge_input in[], int *route, uint8_t *ins[], uint8_t **outs, int ns, int bps)
 Copy samples from several input streams to one output stream. More...
 
static int filter_frame (AVFilterLink *inlink, AVFrame *insamples)
 
static av_cold int init (AVFilterContext *ctx)
 

Variables

static const AVOption amerge_options []
 
static const AVFilterPad amerge_outputs []
 
AVFilter avfilter_af_amerge
 

Detailed Description

Audio merging filter.

Definition in file af_amerge.c.

Macro Definition Documentation

Definition at line 50 of file af_amerge.c.

#define OFFSET (   x)    offsetof(AMergeContext, x)

Definition at line 49 of file af_amerge.c.

Function Documentation

AVFILTER_DEFINE_CLASS ( amerge  )
static int config_output ( AVFilterLink outlink)
static

Definition at line 140 of file af_amerge.c.

static void copy_samples ( int  nb_inputs,
struct amerge_input  in[],
int *  route,
uint8_t ins[],
uint8_t **  outs,
int  ns,
int  bps 
)
inlinestatic

Copy samples from several input streams to one output stream.

Parameters
nb_inputsnumber of inputs
ininputs; used only for the nb_ch field;
routerouting values; input channel i goes to output channel route[i]; i < in[0].nb_ch are the channels from the first output; i >= in[0].nb_ch are the channels from the second output
inspointer to the samples of each inputs, in packed format; will be left at the end of the copied samples
outspointer to the samples of the output, in packet format; must point to a buffer big enough; will be left at the end of the copied samples
nsnumber of samples to copy
bpsbytes per sample

Definition at line 201 of file af_amerge.c.

Referenced by filter_frame().

static int filter_frame ( AVFilterLink inlink,
AVFrame insamples 
)
static

Definition at line 222 of file af_amerge.c.

Referenced by init().

static av_cold int init ( AVFilterContext ctx)
static

Definition at line 306 of file af_amerge.c.

static int query_formats ( AVFilterContext ctx)
static

Definition at line 74 of file af_amerge.c.

static int request_frame ( AVFilterLink outlink)
static

Definition at line 172 of file af_amerge.c.

Referenced by ff_request_frame().

static av_cold void uninit ( AVFilterContext ctx)
static

Definition at line 60 of file af_amerge.c.

Variable Documentation

const AVOption amerge_options[]
static
Initial value:
= {
{ "inputs", "specify the number of inputs", OFFSET(nb_inputs),
AV_OPT_TYPE_INT, { .i64 = 2 }, 2, SWR_CH_MAX, FLAGS },
{0}
}
#define FLAGS
Definition: af_amerge.c:50
#define OFFSET(x)
Definition: af_amerge.c:49
#define SWR_CH_MAX
Maximum number of channels.
Definition: swresample.h:102

Definition at line 52 of file af_amerge.c.

const AVFilterPad amerge_outputs[]
static
Initial value:
= {
{
.name = "default",
.config_props = config_output,
.request_frame = request_frame,
},
{ NULL }
}
static int request_frame(AVFilterLink *outlink)
Definition: af_amerge.c:172
static int config_output(AVFilterLink *outlink)
Definition: af_amerge.c:140
NULL
Definition: eval.c:55

Definition at line 328 of file af_amerge.c.

AVFilter avfilter_af_amerge
Initial value:
= {
.name = "amerge",
.description = NULL_IF_CONFIG_SMALL("Merge two or more audio streams into "
"a single multi-channel stream."),
.priv_size = sizeof(AMergeContext),
.init = init,
.priv_class = &amerge_class,
}
static const AVFilterPad outputs[]
Definition: af_ashowinfo.c:117
#define AVFILTER_FLAG_DYNAMIC_INPUTS
The number of the filter inputs is not determined just by AVFilter.inputs.
Definition: avfilter.h:424
static av_cold int init(AVFilterContext *ctx)
Definition: af_amerge.c:306
static av_cold void uninit(AVFilterContext *ctx)
Definition: af_amerge.c:60
static const AVFilterPad amerge_outputs[]
Definition: af_amerge.c:328
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification. ...
NULL
Definition: eval.c:55
static int query_formats(AVFilterContext *ctx)
Definition: af_amerge.c:74
static int flags
Definition: cpu.c:23
these buffered frames must be flushed immediately if a new input produces new the filter must not call request_frame to get more It must just process the frame or queue it The task of requesting more frames is left to the filter s request_frame method or the application If a filter has several inputs

Definition at line 338 of file af_amerge.c.