32 #define KNOWN(l) (!FF_LAYOUT2COUNT(l))
37 #define MERGE_REF(ret, a, fmts, type, fail) \
42 if (!(tmp = av_realloc_array(ret->refs, ret->refcount + a->refcount, \
47 for (i = 0; i < a->refcount; i ++) { \
48 ret->refs[ret->refcount] = a->refs[i]; \
49 *ret->refs[ret->refcount++] = ret; \
61 #define MERGE_FORMATS(ret, a, b, fmts, nb, type, fail) \
63 int i, j, k = 0, count = FFMIN(a->nb, b->nb); \
65 if (!(ret = av_mallocz(sizeof(*ret)))) \
69 if (!(ret->fmts = av_malloc_array(count, sizeof(*ret->fmts)))) \
71 for (i = 0; i < a->nb; i++) \
72 for (j = 0; j < b->nb; j++) \
73 if (a->fmts[i] == b->fmts[j]) { \
74 if(k >= FFMIN(a->nb, b->nb)){ \
75 av_log(NULL, AV_LOG_ERROR, "Duplicate formats in %s detected\n", __FUNCTION__); \
80 ret->fmts[k++] = a->fmts[i]; \
88 MERGE_REF(ret, a, fmts, type, fail); \
89 MERGE_REF(ret, b, fmts, type, fail); \
97 int alpha1=0, alpha2=0;
98 int chroma1=0, chroma2=0;
124 if (alpha2 > alpha1 || chroma2 > chroma1)
144 if (a == b)
return a;
172 int ret_max, ret_nb = 0, i, j,
round;
174 if (a == b)
return a;
179 FFSWAP(
unsigned, a_all, b_all);
182 if (a_all == 1 && !b_all) {
216 for (round = 0; round < 2; round++) {
219 if (!fmt || !
KNOWN(fmt))
258 for (p = fmts; *p != -1; p++) {
265 #define MAKE_FORMAT_LIST(type, field, count_field) \
269 for (count = 0; fmts[count] != -1; count++) \
271 formats = av_mallocz(sizeof(*formats)); \
274 formats->count_field = count; \
276 formats->field = av_malloc_array(count, sizeof(*formats->field)); \
277 if (!formats->field) { \
278 av_freep(&formats); \
297 memcpy(
formats->channel_layouts, fmts,
308 memcpy(
formats->channel_layouts, fmts,
314 #define ADD_FORMAT(f, fmt, unref_fn, type, list, nb) \
319 if (!(*f) && !(*f = av_mallocz(sizeof(**f)))) { \
321 return AVERROR(ENOMEM); \
324 fmts = av_realloc_array((*f)->list, (*f)->nb + 1, \
325 sizeof(*(*f)->list)); \
330 return AVERROR(ENOMEM); \
334 (*f)->list[(*f)->nb++] = fmt; \
419 #define FORMATS_REF(f, ref, unref_fn) \
423 return AVERROR(ENOMEM); \
425 tmp = av_realloc_array(f->refs, sizeof(*f->refs), f->refcount + 1); \
428 return AVERROR(ENOMEM); \
431 f->refs[f->refcount++] = ref; \
445 #define FIND_REF_INDEX(ref, idx) \
448 for (i = 0; i < (*ref)->refcount; i ++) \
449 if((*ref)->refs[i] == ref) { \
455 #define FORMATS_UNREF(ref, list) \
459 if (!*ref || !(*ref)->refs) \
462 FIND_REF_INDEX(ref, idx); \
465 memmove((*ref)->refs + idx, (*ref)->refs + idx + 1, \
466 sizeof(*(*ref)->refs) * ((*ref)->refcount - idx - 1)); \
468 if(!--(*ref)->refcount) { \
469 av_free((*ref)->list); \
470 av_free((*ref)->refs); \
486 #define FORMATS_CHANGEREF(oldref, newref) \
490 FIND_REF_INDEX(oldref, idx); \
493 (*oldref)->refs[idx] = newref; \
510 #define SET_COMMON_FORMATS(ctx, fmts, in_fmts, out_fmts, ref_fn, unref_fn, list) \
514 return AVERROR(ENOMEM); \
516 for (i = 0; i < ctx->nb_inputs; i++) { \
517 if (ctx->inputs[i] && !ctx->inputs[i]->out_fmts) { \
518 int ret = ref_fn(fmts, &ctx->inputs[i]->out_fmts); \
521 av_freep(&fmts->list); \
528 for (i = 0; i < ctx->nb_outputs; i++) { \
529 if (ctx->outputs[i] && !ctx->outputs[i]->in_fmts) { \
530 int ret = ref_fn(fmts, &ctx->outputs[i]->in_fmts); \
533 av_freep(&fmts->list); \
542 av_freep(&fmts->list); \
543 av_freep(&fmts->refs); \
614 pix_fmt = strtol(arg, &tail, 0);
629 sfmt = strtol(arg, &tail, 0);
654 if (*tail || srate < 1 || (
int)srate != srate || srate > INT_MAX) {
672 if (!chlayout && !nret) {
673 av_log(log_ctx,
AV_LOG_ERROR,
"Unknown channel layout '%s' is not supported.\n", arg);
int av_parse_ratio(AVRational *q, const char *str, int max, int log_offset, void *log_ctx)
Parse str and store the parsed ratio in q.
static enum AVPixelFormat pix_fmt
const AVPixFmtDescriptor * av_pix_fmt_desc_get(enum AVPixelFormat pix_fmt)
Main libavfilter public API header.
void * av_mallocz(size_t size)
Allocate a memory block with alignment suitable for all memory accesses (including vectors if availab...
struct AVFilterChannelLayouts *** refs
references to this list
int av_get_channel_layout_nb_channels(uint64_t channel_layout)
Return the number of channels in the channel layout.
AVFilterLink ** inputs
array of pointers to input links
#define AV_PIX_FMT_FLAG_ALPHA
The pixel format has an alpha channel.
int av_sample_fmt_is_planar(enum AVSampleFormat sample_fmt)
Check if the sample format is planar.
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
uint64_t * channel_layouts
list of channel layouts
simple assert() macros that are a bit more flexible than ISO C assert().
static av_always_inline av_const double round(double x)
const char * av_get_sample_fmt_name(enum AVSampleFormat sample_fmt)
Return the name of sample_fmt, or NULL if sample_fmt is not recognized.
char all_counts
accept any channel layout or count
uint64_t flags
Combination of AV_PIX_FMT_FLAG_...
enum AVPixelFormat av_pix_fmt_desc_get_id(const AVPixFmtDescriptor *desc)
uint8_t nb_components
The number of components each pixel has, (1-4)
audio channel layout utility functions
#define av_assert1(cond)
assert() equivalent, that does not lie in speed critical code.
A list of supported channel layouts.
double av_strtod(const char *numstr, char **tail)
Parse the string in numstr and return its value as a double.
AVSampleFormat
Audio sample formats.
char all_layouts
accept any known channel layout
Descriptor that unambiguously describes how the bits of a pixel are stored in the up to 4 data planes...
static const uint16_t channel_layouts[7]
Rational number (pair of numerator and denominator).
enum AVSampleFormat av_get_sample_fmt(const char *name)
Return a sample format corresponding to name, or AV_SAMPLE_FMT_NONE on error.
AVFilterLink ** outputs
array of pointers to output links
enum MovChannelLayoutTag * layouts
enum AVMediaType type
filter media type
int av_get_bytes_per_sample(enum AVSampleFormat sample_fmt)
Return number of bytes per sample.
common internal and external API header
static int ref[MAX_W *MAX_W]
int nb_channel_layouts
number of channel layouts
#define av_malloc_array(a, b)
#define FFSWAP(type, a, b)
enum AVPixelFormat av_get_pix_fmt(const char *name)
Return the pixel format corresponding to name.
AVPixelFormat
Pixel format.
int av_get_extended_channel_layout(const char *name, uint64_t *channel_layout, int *nb_channels)
Return a channel layout and the number of channels based on the specified name.
simple arithmetic expression evaluator
const AVPixFmtDescriptor * av_pix_fmt_desc_next(const AVPixFmtDescriptor *prev)
Iterate over all pixel format descriptors known to libavutil.