66 #define OFFSET(x) offsetof(JoinContext, x) 
   67 #define A AV_OPT_FLAG_AUDIO_PARAM 
   68 #define F AV_OPT_FLAG_FILTERING_PARAM 
   71     { 
"channel_layout", 
"Channel layout of the " 
   73     { 
"map",            
"A comma-separated list of channels maps in the format " 
   74                         "'input_stream.input_channel-output_channel.",
 
   90         if (link == ctx->
inputs[i])
 
  102         for (j = 1; !i && j < ctx->
nb_inputs; j++)
 
  112     char separator = 
'|';
 
  115 #if FF_API_OLD_FILTER_OPTS 
  116     if (cur && strchr(cur, 
',')) {
 
  118                "separate the mappings.\n");
 
  123     while (cur && *cur) {
 
  124         char *sep, *next, *p;
 
  125         uint64_t in_channel = 0, out_channel = 0;
 
  126         int input_idx, out_ch_idx, in_ch_idx;
 
  128         next = strchr(cur, separator);
 
  133         if (!(sep = strchr(cur, 
'-'))) {
 
  140 #define PARSE_CHANNEL(str, var, inout)                                         \ 
  141         if (!(var = av_get_channel_layout(str))) {                             \ 
  142             av_log(ctx, AV_LOG_ERROR, "Invalid " inout " channel: %s.\n", str);\ 
  143             return AVERROR(EINVAL);                                            \ 
  145         if (av_get_channel_layout_nb_channels(var) != 1) {                     \ 
  146             av_log(ctx, AV_LOG_ERROR, "Channel map describes more than one "   \ 
  147                    inout " channel.\n");                                       \ 
  148             return AVERROR(EINVAL);                                            \ 
  155                    "requested channel layout.\n", sep);
 
  168         input_idx = strtol(cur, &cur, 0);
 
  169         if (input_idx < 0 || input_idx >= s->
inputs) {
 
  178         in_ch_idx = strtol(cur, &p, 0);
 
  222     for (i = 0; i < s->
inputs; i++) {
 
  226         snprintf(name, 
sizeof(name), 
"input%d", i);
 
  368                    "output channel '%s'.\n",
 
  418     int linesize   = INT_MAX;
 
  419     int nb_samples = INT_MAX;
 
  458         for (j = 0; j < nb_buffers; j++)
 
  478         if (!frame->
buf[i]) {
 
  529                                            "multi-channel output."),
 
  531     .priv_class     = &join_class,
 
  536     .
outputs        = avfilter_af_join_outputs,
 
void av_frame_set_channels(AVFrame *frame, int val)
uint64_t in_channel
layout describing the input channel 
This structure describes decoded (raw) audio or video data. 
#define AV_LOG_WARNING
Something somehow does not look correct. 
Main libavfilter public API header. 
AVBufferRef * buf[AV_NUM_DATA_POINTERS]
AVBuffer references backing the data for this frame. 
static av_cold int init(AVCodecContext *avctx)
#define AVFILTER_FLAG_DYNAMIC_INPUTS
The number of the filter inputs is not determined just by AVFilter.inputs. 
int nb_extended_buf
Number of elements in extended_buf. 
int request_samples
Audio only, the destination filter sets this to a non-zero value to request that buffers with the giv...
enum AVMediaType type
AVFilterPad type. 
struct AVFilterChannelLayouts * in_channel_layouts
AVBufferRef ** buffers
Temporary storage for buffer references, for assembling the output frame. 
int av_get_channel_layout_nb_channels(uint64_t channel_layout)
Return the number of channels in the channel layout. 
const char * name
Pad name. 
uint64_t av_get_channel_layout(const char *name)
Return a channel layout id that matches name, or 0 if no match is found. 
AVFilterLink ** inputs
array of pointers to input links 
#define av_assert0(cond)
assert() equivalent, that is always enabled. 
int ff_filter_frame(AVFilterLink *link, AVFrame *frame)
Send a frame of data to the next filter. 
static av_cold void join_uninit(AVFilterContext *ctx)
AVFrame * av_frame_alloc(void)
Allocate an AVFrame and set its fields to default values. 
static av_cold int uninit(AVCodecContext *avctx)
int64_t pts
Presentation timestamp in time_base units (time when frame should be shown to user). 
static av_cold int join_init(AVFilterContext *ctx)
static void guess_map_matching(AVFilterContext *ctx, ChannelMap *ch, uint64_t *inputs)
int input
input stream index 
#define AV_LOG_VERBOSE
Detailed information. 
static int join_query_formats(AVFilterContext *ctx)
A filter pad used for either input or output. 
A link between two filters. 
AVFilterPad * input_pads
array of input pads 
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered. 
int sample_rate
samples per second 
void av_frame_free(AVFrame **frame)
Free the frame and any dynamically allocated objects in it, e.g. 
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification. ...
void * priv
private data for use by the filter 
int(* filter_frame)(AVFilterLink *link, AVFrame *frame)
Filtering callback. 
simple assert() macros that are a bit more flexible than ISO C assert(). 
struct AVFilterChannelLayouts * out_channel_layouts
uint64_t channel_layout
Channel layout of the audio data. 
static const AVOption join_options[]
audio channel layout utility functions 
unsigned nb_inputs
number of input pads 
AVBufferRef ** extended_buf
For planar audio which requires more than AV_NUM_DATA_POINTERS AVBufferRef pointers, this array will hold all the references which cannot fit into AVFrame.buf. 
AVBufferRef * av_frame_get_plane_buffer(AVFrame *frame, int plane)
Get the buffer reference a given data plane is stored in. 
AVFilterContext * src
source filter 
static const AVFilterPad outputs[]
static const AVFilterPad avfilter_af_join_outputs[]
int format
agreed upon media format 
#define FF_ARRAY_ELEMS(a)
int in_channel_idx
index of in_channel in the input stream data 
A list of supported channel layouts. 
int format
format of the frame, -1 if unknown or unset Values correspond to enum AVPixelFormat for video frames...
static const AVFilterPad inputs[]
AVFILTER_DEFINE_CLASS(join)
char * av_strdup(const char *s)
Duplicate the string s. 
int linesize[AV_NUM_DATA_POINTERS]
For video, size in bytes of each picture line. 
Describe the class of an AVClass context structure. 
int sample_rate
Sample rate of the audio data. 
#define PARSE_CHANNEL(str, var, inout)
uint64_t out_channel
layout describing the output channel 
const char * name
Filter name. 
AVFilterLink ** outputs
array of pointers to output links 
enum MovChannelLayoutTag * layouts
int av_get_channel_layout_channel_index(uint64_t channel_layout, uint64_t channel)
Get the index of a channel in channel_layout. 
uint8_t * data[AV_NUM_DATA_POINTERS]
pointer to the picture/channel planes. 
AVFrame ** input_frames
Temporary storage for input frames, until we get one on each input. 
A reference to a data buffer. 
static int query_formats(AVFilterContext *ctx)
static void guess_map_any(AVFilterContext *ctx, ChannelMap *ch, uint64_t *inputs)
common internal and external API header 
uint64_t av_channel_layout_extract_channel(uint64_t channel_layout, int index)
Get the channel with the given index in channel_layout. 
AVBufferRef * av_buffer_ref(AVBufferRef *buf)
Create a new reference to an AVBuffer. 
static int parse_maps(AVFilterContext *ctx)
uint64_t channel_layout
channel layout of current buffer (see libavutil/channel_layout.h) 
int channels
Number of channels. 
static int join_request_frame(AVFilterLink *outlink)
char * channel_layout_str
const char * av_get_channel_name(uint64_t channel)
Get the name of a given channel. 
static int try_push_frame(AVFilterContext *ctx)
AVFilterContext * dst
dest filter 
static void * av_mallocz_array(size_t nmemb, size_t size)
static int join_config_output(AVFilterLink *outlink)
int needs_fifo
The filter expects a fifo to be inserted on its input link, typically because it has a delay...
int ff_request_frame(AVFilterLink *link)
Request an input frame from the filter at the other end of the link. 
static int filter_frame(AVFilterLink *link, AVFrame *frame)
uint8_t ** extended_data
pointers to the data planes/channels. 
int nb_samples
number of audio samples (per channel) described by this frame 
static int ff_insert_inpad(AVFilterContext *f, unsigned index, AVFilterPad *p)
Insert a new input pad for the filter.