68 #define OFFSET(x) offsetof(ChannelMapContext, x) 69 #define A AV_OPT_FLAG_AUDIO_PARAM 71 {
"map",
"A comma-separated list of input channel numbers in output order.",
73 {
"channel_layout",
"Output channel layout.",
85 static char*
split(
char *message,
char delim) {
86 char *next = strchr(message, delim);
94 char *next =
split(*map, delim);
97 if (!next && delim ==
'-')
100 sscanf(*map,
"%d%n", ch, &n);
103 if (*ch < 0 || *ch > max_ch)
111 char *next =
split(*map, delim);
112 if (!next && delim ==
'-')
124 char *mapping, separator =
'|';
128 uint64_t out_ch_mask = 0;
136 char *dash = strchr(mapping,
'-');
153 #if FF_API_OLD_FILTER_OPTS 154 if (strchr(mapping,
',')) {
156 "'|' to separate the mappings.\n");
165 while ((sep = strchr(sep, separator))) {
171 if (map_entries >
MAX_CH) {
176 for (i = 0; i < map_entries; i++) {
177 int in_ch_idx = -1, out_ch_idx = -1;
178 uint64_t in_ch = 0, out_ch = 0;
179 static const char err[] =
"Failed to parse channel map\n";
190 if (
get_channel(&mapping, &in_ch, separator) < 0) {
209 out_ch & out_ch_mask) {
215 out_ch_mask |= out_ch;
229 out_ch & out_ch_mask) {
235 out_ch_mask |= out_ch;
240 s->
nch = map_entries;
254 for (i = 0; i < s->
nch; i++) {
258 }
else if (out_ch_mask && out_ch_mask != fmt) {
261 "Output channel layout '%s' does not match the list of channel mapped: '%s'.\n",
266 "Output channel layout %s does not match the number of channels mapped %d.\n",
274 "cannot be guessed from the maps.\n");
279 for (i = 0; i < s->
nch; i++) {
309 const int nch_out = s->
nch;
314 nch_in *
sizeof(source_planes[0]));
316 if (nch_out > nch_in) {
320 if (!new_extended_data) {
336 for (ch = 0; ch < nch_out; ch++) {
356 const char *channel_name;
357 char layout_name[256];
359 for (i = 0; i < s->
nch; i++) {
373 "input channel '%s' not available from input layout '%s'\n",
374 channel_name, layout_name);
377 "input channel #%d not available from input layout '%s'\n",
406 .
name =
"channelmap",
411 .priv_class = &channelmap_class,
uint64_t av_get_default_channel_layout(int nb_channels)
Return default channel layout for a given number of channels.
static const AVOption options[]
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.
static const AVFilterPad outputs[]
Main libavfilter public API header.
AVFilter ff_af_channelmap
int av_isdigit(int c)
Locale-independent conversion of ASCII isdigit.
#define FF_ARRAY_ELEMS(a)
struct AVFilterChannelLayouts * in_channel_layouts
const char * class_name
The name of the class; usually it is the same name as the context structure type to which the AVClass...
AVFilterLink ** inputs
array of pointers to input links
int ff_filter_frame(AVFilterLink *link, AVFrame *frame)
Send a frame of data to the next filter.
static int channelmap_filter_frame(AVFilterLink *inlink, AVFrame *buf)
char * channel_layout_str
static int channelmap_query_formats(AVFilterContext *ctx)
int av_get_channel_layout_channel_index(uint64_t channel_layout, uint64_t channel)
Get the index of a channel in channel_layout.
A link between two filters.
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
void av_free(void *ptr)
Free a memory block which has been allocated with av_malloc(z)() or av_realloc(). ...
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 av_get_channel_layout_nb_channels(uint64_t channel_layout)
Return the number of channels in the channel layout.
struct AVFilterChannelLayouts * out_channel_layouts
void av_log(void *avcl, int level, const char *fmt,...)
const char * av_get_channel_name(uint64_t channel)
Get the name of a given channel.
static char * split(char *message, char delim)
uint64_t channel_layout
Channel layout of the audio data.
audio channel layout utility functions
int in_channel_idx
index of in_channel in the input stream data
static const AVClass channelmap_class
struct ChannelMap map[MAX_CH]
Describe the class of an AVClass context structure.
static const AVFilterPad inputs[]
uint64_t out_channel
layout describing the output channel
const char * name
Filter name.
AVFilterLink ** outputs
array of pointers to output links
static int channelmap_config_input(AVFilterLink *inlink)
uint8_t * data[AV_NUM_DATA_POINTERS]
pointer to the picture/channel planes.
static const AVFilterPad avfilter_af_channelmap_inputs[]
static int get_channel_idx(char **map, int *ch, char delim, int max_ch)
common internal and external API header
uint64_t channel_layout
channel layout of current buffer (see libavutil/channel_layout.h)
struct AVFilterPad AVFilterPad
AVFilterContext * dst
dest filter
uint64_t av_get_channel_layout(const char *name)
Return a channel layout id that matches name, or 0 if no match is found.
static int get_channel(char **map, uint64_t *ch, char delim)
static av_cold int channelmap_init(AVFilterContext *ctx)
static const AVFilterPad avfilter_af_channelmap_outputs[]
uint8_t ** extended_data
pointers to the data planes/channels.
void * av_mallocz(size_t size)
Allocate a block of size bytes with alignment suitable for all memory accesses (including vectors if ...
void av_get_channel_layout_string(char *buf, int buf_size, int nb_channels, uint64_t channel_layout)
Return a description of a channel layout.