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.
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().
void * av_mallocz(size_t size)
Allocate a memory block with alignment suitable for all memory accesses (including vectors if availab...
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.