Git Inbox Mirror of the ffmpeg-devel mailing list - see https://ffmpeg.org/mailman/listinfo/ffmpeg-devel
 help / color / mirror / Atom feed
From: James Almer <jamrial@gmail.com>
To: ffmpeg-devel@ffmpeg.org
Subject: [FFmpeg-devel] [PATCH 277/281] ffmpeg: convert to new channel layout-API
Date: Wed, 12 Jan 2022 23:09:09 -0300
Message-ID: <20220113020913.870-8-jamrial@gmail.com> (raw)
In-Reply-To: <20220113015101.4-1-jamrial@gmail.com>

Signed-off-by: James Almer <jamrial@gmail.com>
---
 fftools/cmdutils.c            | 42 +++++++++++++++---------
 fftools/cmdutils.h            |  8 -----
 fftools/ffmpeg.c              | 47 ++++++++++++++++----------
 fftools/ffmpeg.h              |  7 ++--
 fftools/ffmpeg_filter.c       | 52 ++++++++++++++++++++++-------
 fftools/ffmpeg_opt.c          | 62 ++++++++++++++++++++++++++++++-----
 tests/fate/aac.mak            |  2 +-
 tests/fate/lavf-container.mak |  2 +-
 8 files changed, 155 insertions(+), 67 deletions(-)

diff --git a/fftools/cmdutils.c b/fftools/cmdutils.c
index 4b50e15eef..55cdbfb7a7 100644
--- a/fftools/cmdutils.c
+++ b/fftools/cmdutils.c
@@ -1470,8 +1470,19 @@ static void print_codec(const AVCodec *c)
                           GET_SAMPLE_RATE_NAME);
     PRINT_CODEC_SUPPORTED(c, sample_fmts, enum AVSampleFormat, "sample formats",
                           AV_SAMPLE_FMT_NONE, GET_SAMPLE_FMT_NAME);
-    PRINT_CODEC_SUPPORTED(c, channel_layouts, uint64_t, "channel layouts",
-                          0, GET_CH_LAYOUT_DESC);
+
+    if (c->ch_layouts) {
+        const AVChannelLayout *p = c->ch_layouts;
+
+        printf("    Supported channel layouts:");
+        while (p->nb_channels) {
+            char name[128];
+            av_channel_layout_describe(p, name, sizeof(name));
+            printf(" %s", name);
+            p++;
+        }
+        printf("\n");
+    }
 
     if (c->priv_class) {
         show_help_children(c->priv_class,
@@ -1784,29 +1795,30 @@ int show_pix_fmts(void *optctx, const char *opt, const char *arg)
 
 int show_layouts(void *optctx, const char *opt, const char *arg)
 {
+    const AVChannelLayout *ch_layout;
+    void *iter = NULL;
+    char buf[128], buf2[128];
     int i = 0;
-    uint64_t layout, j;
-    const char *name, *descr;
 
     printf("Individual channels:\n"
            "NAME           DESCRIPTION\n");
     for (i = 0; i < 63; i++) {
-        name = av_get_channel_name((uint64_t)1 << i);
-        if (!name)
+        av_channel_name(buf, sizeof(buf), i);
+        if (!strcmp(buf, "?"))
             continue;
-        descr = av_get_channel_description((uint64_t)1 << i);
-        printf("%-14s %s\n", name, descr);
+        av_channel_description(buf2, sizeof(buf2), i);
+        printf("%-14s %s\n", buf, buf2);
     }
     printf("\nStandard channel layouts:\n"
            "NAME           DECOMPOSITION\n");
-    for (i = 0; !av_get_standard_channel_layout(i, &layout, &name); i++) {
-        if (name) {
-            printf("%-14s ", name);
-            for (j = 1; j; j <<= 1)
-                if ((layout & j))
-                    printf("%s%s", (layout & (j - 1)) ? "+" : "", av_get_channel_name(j));
+    while (ch_layout = av_channel_layout_standard(&iter)) {
+            av_channel_layout_describe(ch_layout, buf, sizeof(buf));
+            av_channel_name(buf2, sizeof(buf2), i);
+            printf("%-14s ", buf);
+            for (i = 0; i < 63; i++)
+                if (av_channel_layout_index_from_channel(ch_layout, i) >= 0)
+                    printf("%s%s", i ? "+" : "", buf2);
             printf("\n");
-        }
     }
     return 0;
 }
diff --git a/fftools/cmdutils.h b/fftools/cmdutils.h
index 50eed9b13a..274d2e5b14 100644
--- a/fftools/cmdutils.h
+++ b/fftools/cmdutils.h
@@ -663,14 +663,6 @@ void *allocate_array_elem(void *array, size_t elem_size, int *nb_elems);
     char name[16];\
     snprintf(name, sizeof(name), "%d", rate);
 
-#define GET_CH_LAYOUT_NAME(ch_layout)\
-    char name[16];\
-    snprintf(name, sizeof(name), "0x%"PRIx64, ch_layout);
-
-#define GET_CH_LAYOUT_DESC(ch_layout)\
-    char name[128];\
-    av_get_channel_layout_string(name, sizeof(name), 0, ch_layout);
-
 double get_rotation(int32_t *displaymatrix);
 
 #endif /* FFTOOLS_CMDUTILS_H */
diff --git a/fftools/ffmpeg.c b/fftools/ffmpeg.c
index 5d134b025f..22d6309f2a 100644
--- a/fftools/ffmpeg.c
+++ b/fftools/ffmpeg.c
@@ -555,6 +555,7 @@ static void ffmpeg_cleanup(int ret)
 
             avfilter_inout_free(&ofilter->out_tmp);
             av_freep(&ofilter->name);
+            av_channel_layout_uninit(&ofilter->ch_layout);
             av_freep(&fg->outputs[j]);
         }
         av_freep(&fg->outputs);
@@ -1537,7 +1538,7 @@ static int reap_filters(int flush)
                 break;
             case AVMEDIA_TYPE_AUDIO:
                 if (!(enc->codec->capabilities & AV_CODEC_CAP_PARAM_CHANGE) &&
-                    enc->channels != filtered_frame->channels) {
+                    enc->ch_layout.nb_channels != filtered_frame->ch_layout.nb_channels) {
                     av_log(NULL, AV_LOG_ERROR,
                            "Audio filter graph output is not normalized and encoder does not support parameter changes\n");
                     break;
@@ -1883,17 +1884,22 @@ static void print_report(int is_last_report, int64_t timer_start, int64_t cur_ti
         print_final_stats(total_size);
 }
 
-static void ifilter_parameters_from_codecpar(InputFilter *ifilter, AVCodecParameters *par)
+static int ifilter_parameters_from_codecpar(InputFilter *ifilter, AVCodecParameters *par)
 {
+    int ret;
+
     // We never got any input. Set a fake format, which will
     // come from libavformat.
     ifilter->format                 = par->format;
     ifilter->sample_rate            = par->sample_rate;
-    ifilter->channels               = par->channels;
-    ifilter->channel_layout         = par->channel_layout;
     ifilter->width                  = par->width;
     ifilter->height                 = par->height;
     ifilter->sample_aspect_ratio    = par->sample_aspect_ratio;
+    ret = av_channel_layout_copy(&ifilter->ch_layout, &par->ch_layout);
+    if (ret < 0)
+        return ret;
+
+    return 0;
 }
 
 static void flush_encoders(void)
@@ -1921,8 +1927,11 @@ static void flush_encoders(void)
                 int x;
                 for (x = 0; x < fg->nb_inputs; x++) {
                     InputFilter *ifilter = fg->inputs[x];
-                    if (ifilter->format < 0)
-                        ifilter_parameters_from_codecpar(ifilter, ifilter->ist->st->codecpar);
+                    if (ifilter->format < 0 &&
+                        ifilter_parameters_from_codecpar(ifilter, ifilter->ist->st->codecpar) < 0) {
+                        av_log(NULL, AV_LOG_ERROR, "Error copying paramerets from input stream\n");
+                        exit_program(1);
+                    }
                 }
 
                 if (!ifilter_has_all_input_formats(fg))
@@ -2098,16 +2107,15 @@ int guess_input_channel_layout(InputStream *ist)
 {
     AVCodecContext *dec = ist->dec_ctx;
 
-    if (!dec->channel_layout) {
+    if (dec->ch_layout.order == AV_CHANNEL_ORDER_UNSPEC) {
         char layout_name[256];
 
-        if (dec->channels > ist->guess_layout_max)
+        if (dec->ch_layout.nb_channels > ist->guess_layout_max)
             return 0;
-        dec->channel_layout = av_get_default_channel_layout(dec->channels);
-        if (!dec->channel_layout)
+        av_channel_layout_default(&dec->ch_layout, dec->ch_layout.nb_channels);
+        if (dec->ch_layout.order == AV_CHANNEL_ORDER_UNSPEC)
             return 0;
-        av_get_channel_layout_string(layout_name, sizeof(layout_name),
-                                     dec->channels, dec->channel_layout);
+        av_channel_layout_describe(&dec->ch_layout, layout_name, sizeof(layout_name));
         av_log(NULL, AV_LOG_WARNING, "Guessed Channel Layout for Input Stream "
                "#%d.%d : %s\n", ist->file_index, ist->st->index, layout_name);
     }
@@ -2160,8 +2168,7 @@ static int ifilter_send_frame(InputFilter *ifilter, AVFrame *frame, int keep_ref
     switch (ifilter->ist->st->codecpar->codec_type) {
     case AVMEDIA_TYPE_AUDIO:
         need_reinit |= ifilter->sample_rate    != frame->sample_rate ||
-                       ifilter->channels       != frame->channels ||
-                       ifilter->channel_layout != frame->channel_layout;
+                       av_channel_layout_compare(&ifilter->ch_layout, &frame->ch_layout);
         break;
     case AVMEDIA_TYPE_VIDEO:
         need_reinit |= ifilter->width  != frame->width ||
@@ -2241,8 +2248,11 @@ static int ifilter_send_eof(InputFilter *ifilter, int64_t pts)
             return ret;
     } else {
         // the filtergraph was never configured
-        if (ifilter->format < 0)
-            ifilter_parameters_from_codecpar(ifilter, ifilter->ist->st->codecpar);
+        if (ifilter->format < 0) {
+            ret = ifilter_parameters_from_codecpar(ifilter, ifilter->ist->st->codecpar);
+            if (ret < 0)
+                return ret;
+        }
         if (ifilter->format < 0 && (ifilter->type == AVMEDIA_TYPE_AUDIO || ifilter->type == AVMEDIA_TYPE_VIDEO)) {
             av_log(NULL, AV_LOG_ERROR, "Cannot determine format of input stream %d:%d after EOF\n", ifilter->ist->file_index, ifilter->ist->st->index);
             return AVERROR_INVALIDDATA;
@@ -3316,8 +3326,9 @@ static int init_output_stream_encode(OutputStream *ost, AVFrame *frame)
     case AVMEDIA_TYPE_AUDIO:
         enc_ctx->sample_fmt     = av_buffersink_get_format(ost->filter->filter);
         enc_ctx->sample_rate    = av_buffersink_get_sample_rate(ost->filter->filter);
-        enc_ctx->channel_layout = av_buffersink_get_channel_layout(ost->filter->filter);
-        enc_ctx->channels       = av_buffersink_get_channels(ost->filter->filter);
+        ret = av_buffersink_get_ch_layout(ost->filter->filter, &enc_ctx->ch_layout);
+        if (ret < 0)
+            return ret;
 
         if (ost->bits_per_raw_sample)
             enc_ctx->bits_per_raw_sample = ost->bits_per_raw_sample;
diff --git a/fftools/ffmpeg.h b/fftools/ffmpeg.h
index 9b200b806a..75f6f9ef72 100644
--- a/fftools/ffmpeg.h
+++ b/fftools/ffmpeg.h
@@ -250,8 +250,7 @@ typedef struct InputFilter {
     AVRational sample_aspect_ratio;
 
     int sample_rate;
-    int channels;
-    uint64_t channel_layout;
+    AVChannelLayout ch_layout;
 
     AVBufferRef *hw_frames_ctx;
     int32_t *displaymatrix;
@@ -274,12 +273,12 @@ typedef struct OutputFilter {
     AVRational frame_rate;
     int format;
     int sample_rate;
-    uint64_t channel_layout;
+    AVChannelLayout ch_layout;
 
     // those are only set if no format is specified and the encoder gives us multiple options
     // They point directly to the relevant lists of the encoder.
     const int *formats;
-    const uint64_t *channel_layouts;
+    const AVChannelLayout *ch_layouts;
     const int *sample_rates;
 } OutputFilter;
 
diff --git a/fftools/ffmpeg_filter.c b/fftools/ffmpeg_filter.c
index 1f6cba2c04..b096196135 100644
--- a/fftools/ffmpeg_filter.c
+++ b/fftools/ffmpeg_filter.c
@@ -153,8 +153,29 @@ DEF_CHOOSE_FORMAT(sample_fmts, enum AVSampleFormat, format, formats,
 DEF_CHOOSE_FORMAT(sample_rates, int, sample_rate, sample_rates, 0,
                   "%d", )
 
-DEF_CHOOSE_FORMAT(channel_layouts, uint64_t, channel_layout, channel_layouts, 0,
-                  "0x%"PRIx64, )
+static void choose_channel_layouts(OutputFilter *ofilter, AVBPrint *bprint)
+{
+    AVBPrint bp;
+
+    av_bprint_init(&bp, 0, AV_BPRINT_SIZE_UNLIMITED);
+    if (av_channel_layout_check(&ofilter->ch_layout)) {
+        av_channel_layout_describe_bprint(&ofilter->ch_layout, &bp);
+        av_bprintf(bprint, "channel_layouts=%s", bp.str);
+    } else if (ofilter->ch_layouts) {
+        const AVChannelLayout *p;
+
+        av_bprintf(bprint, "channel_layouts=");
+        for (p = ofilter->ch_layouts; p->nb_channels; p++) {
+            av_channel_layout_describe_bprint(p, &bp);
+            av_bprintf(bprint, "%s|", bp.str);
+        }
+        if (bprint->len > 0)
+            bprint->str[--bprint->len] = '\0';
+    } else
+        return;
+    av_bprint_finalize(&bp, NULL);
+    av_bprint_chars(bprint, ':', 1);
+}
 
 int init_simple_filtergraph(InputStream *ist, OutputStream *ost)
 {
@@ -541,9 +562,11 @@ static int configure_output_audio_filter(FilterGraph *fg, OutputFilter *ofilter,
 } while (0)
     av_bprint_init(&args, 0, AV_BPRINT_SIZE_UNLIMITED);
     if (ost->audio_channels_mapped) {
+        AVChannelLayout mapped_layout = { 0 };
         int i;
-        av_bprintf(&args, "0x%"PRIx64,
-                   av_get_default_channel_layout(ost->audio_channels_mapped));
+        av_channel_layout_default(&mapped_layout, ost->audio_channels_mapped);
+        av_bprintf(&args, "0x%"PRIx64, mapped_layout.order == AV_CHANNEL_ORDER_NATIVE ?
+                                       mapped_layout.u.mask : 0);
         for (i = 0; i < ost->audio_channels_mapped; i++)
             if (ost->audio_channels_map[i] != -1)
                 av_bprintf(&args, "|c%d=c%d", i, ost->audio_channels_map[i]);
@@ -552,8 +575,8 @@ static int configure_output_audio_filter(FilterGraph *fg, OutputFilter *ofilter,
         av_bprint_clear(&args);
     }
 
-    if (codec->channels && !codec->channel_layout)
-        codec->channel_layout = av_get_default_channel_layout(codec->channels);
+    if (codec->ch_layout.order == AV_CHANNEL_ORDER_UNSPEC)
+        av_channel_layout_default(&codec->ch_layout, codec->ch_layout.nb_channels);
 
     choose_sample_fmts(ofilter,     &args);
     choose_sample_rates(ofilter,    &args);
@@ -832,11 +855,11 @@ static int configure_input_audio_filter(FilterGraph *fg, InputFilter *ifilter,
              1, ifilter->sample_rate,
              ifilter->sample_rate,
              av_get_sample_fmt_name(ifilter->format));
-    if (ifilter->channel_layout)
+    if (av_channel_layout_check(&ifilter->ch_layout) && ifilter->ch_layout.order == AV_CHANNEL_ORDER_NATIVE)
         av_bprintf(&args, ":channel_layout=0x%"PRIx64,
-                   ifilter->channel_layout);
+                   ifilter->ch_layout.u.mask);
     else
-        av_bprintf(&args, ":channels=%d", ifilter->channels);
+        av_bprintf(&args, ":channels=%d", ifilter->ch_layout.nb_channels);
     snprintf(name, sizeof(name), "graph_%d_in_%d_%d", fg->index,
              ist->file_index, ist->st->index);
 
@@ -1084,7 +1107,10 @@ int configure_filtergraph(FilterGraph *fg)
         ofilter->height = av_buffersink_get_h(sink);
 
         ofilter->sample_rate    = av_buffersink_get_sample_rate(sink);
-        ofilter->channel_layout = av_buffersink_get_channel_layout(sink);
+        av_channel_layout_uninit(&ofilter->ch_layout);
+        ret = av_buffersink_get_ch_layout(sink, &ofilter->ch_layout);
+        if (ret < 0)
+            goto fail;
     }
 
     fg->reconfiguration = 1;
@@ -1148,6 +1174,7 @@ fail:
 int ifilter_parameters_from_frame(InputFilter *ifilter, const AVFrame *frame)
 {
     AVFrameSideData *sd;
+    int ret;
 
     av_buffer_unref(&ifilter->hw_frames_ctx);
 
@@ -1158,8 +1185,9 @@ int ifilter_parameters_from_frame(InputFilter *ifilter, const AVFrame *frame)
     ifilter->sample_aspect_ratio = frame->sample_aspect_ratio;
 
     ifilter->sample_rate         = frame->sample_rate;
-    ifilter->channels            = frame->channels;
-    ifilter->channel_layout      = frame->channel_layout;
+    ret = av_channel_layout_copy(&ifilter->ch_layout, &frame->ch_layout);
+    if (ret < 0)
+        return ret;
 
     av_freep(&ifilter->displaymatrix);
     sd = av_frame_get_side_data(frame, AV_FRAME_DATA_DISPLAYMATRIX);
diff --git a/fftools/ffmpeg_opt.c b/fftools/ffmpeg_opt.c
index 9c820ab73f..0eb2c779f2 100644
--- a/fftools/ffmpeg_opt.c
+++ b/fftools/ffmpeg_opt.c
@@ -507,7 +507,7 @@ static int opt_map_channel(void *optctx, const char *opt, const char *arg)
     /* allow trailing ? to map_channel */
     if (allow_unused = strchr(mapchan, '?'))
         *allow_unused = 0;
-    if (m->channel_idx < 0 || m->channel_idx >= st->codecpar->channels ||
+    if (m->channel_idx < 0 || m->channel_idx >= st->codecpar->ch_layout.nb_channels ||
         input_streams[input_files[m->file_idx]->ist_index + m->stream_idx]->user_set_discard == AVDISCARD_ALL) {
         if (allow_unused) {
             av_log(NULL, AV_LOG_VERBOSE, "mapchan: invalid audio channel #%d.%d.%d\n",
@@ -1954,9 +1954,14 @@ static OutputStream *new_audio_stream(OptionsContext *o, AVFormatContext *oc, in
     MATCH_PER_STREAM_OPT(filters,        str, ost->filters,        oc, st);
 
     if (!ost->stream_copy) {
+        int channels = 0;
         char *sample_fmt = NULL;
 
-        MATCH_PER_STREAM_OPT(audio_channels, i, audio_enc->channels, oc, st);
+        MATCH_PER_STREAM_OPT(audio_channels, i, channels, oc, st);
+        if (channels) {
+            audio_enc->ch_layout.order       = AV_CHANNEL_ORDER_UNSPEC;
+            audio_enc->ch_layout.nb_channels = channels;
+        }
 
         MATCH_PER_STREAM_OPT(sample_fmts, str, sample_fmt, oc, st);
         if (sample_fmt &&
@@ -2378,7 +2383,7 @@ static int open_output_file(OptionsContext *o, const char *filename)
                 for (i = 0; i < ifile->nb_streams; i++) {
                     int score;
                     ist = input_streams[ifile->ist_index + i];
-                    score = ist->st->codecpar->channels
+                    score = ist->st->codecpar->ch_layout.nb_channels
                             + 100000000 * !!(ist->st->event_flags & AVSTREAM_EVENT_FLAG_NEW_PACKETS)
                             + 5000000*!!(ist->st->disposition & AV_DISPOSITION_DEFAULT);
                     if (ist->user_set_discard == AVDISCARD_ALL)
@@ -2651,10 +2656,10 @@ loop_end:
                 } else {
                     f->sample_rates = ost->enc->supported_samplerates;
                 }
-                if (ost->enc_ctx->channels) {
-                    f->channel_layout = av_get_default_channel_layout(ost->enc_ctx->channels);
-                } else {
-                    f->channel_layouts = ost->enc->channel_layouts;
+                if (ost->enc_ctx->ch_layout.nb_channels) {
+                    av_channel_layout_default(&f->ch_layout, ost->enc_ctx->ch_layout.nb_channels);
+                } else if (ost->enc->ch_layouts) {
+                    f->ch_layouts = ost->enc->ch_layouts;
                 }
                 break;
             }
@@ -3237,6 +3242,41 @@ static int opt_timecode(void *optctx, const char *opt, const char *arg)
     return ret;
 }
 
+static int opt_ch_layout(void *optctx, const char *opt, const char *arg)
+{
+    OptionsContext *o = optctx;
+    char layout_str[32];
+    char *stream_str;
+    char *ac_str;
+    int ret, ac_str_size;
+    AVChannelLayout layout = { 0 };
+
+    ret = av_channel_layout_from_string(&layout, arg);
+    if (ret < 0) {
+        av_log(NULL, AV_LOG_ERROR, "Unknown channel layout: %s\n", arg);
+        return AVERROR(EINVAL);
+    }
+    ret = opt_default_new(o, opt, arg);
+    if (ret < 0)
+        return ret;
+
+    /* set 'ac' option based on channel layout */
+    snprintf(layout_str, sizeof(layout_str), "%d", layout.nb_channels);
+    stream_str = strchr(opt, ':');
+    ac_str_size = 3 + (stream_str ? strlen(stream_str) : 0);
+    ac_str = av_mallocz(ac_str_size);
+    if (!ac_str)
+        return AVERROR(ENOMEM);
+    av_strlcpy(ac_str, "ac", 3);
+    if (stream_str)
+        av_strlcat(ac_str, stream_str, ac_str_size);
+    ret = parse_option(o, ac_str, layout_str, options);
+    av_free(ac_str);
+
+    return ret;
+}
+
+#if FF_API_OLD_CHANNEL_LAYOUT
 static int opt_channel_layout(void *optctx, const char *opt, const char *arg)
 {
     OptionsContext *o = optctx;
@@ -3272,6 +3312,7 @@ static int opt_channel_layout(void *optctx, const char *opt, const char *arg)
 
     return ret;
 }
+#endif
 
 static int opt_audio_qscale(void *optctx, const char *opt, const char *arg)
 {
@@ -3818,9 +3859,14 @@ const OptionDef options[] = {
     { "sample_fmt",     OPT_AUDIO | HAS_ARG  | OPT_EXPERT | OPT_SPEC |
                         OPT_STRING | OPT_INPUT | OPT_OUTPUT,                       { .off = OFFSET(sample_fmts) },
         "set sample format", "format" },
+    { "ch_layout",      OPT_AUDIO | HAS_ARG  | OPT_EXPERT | OPT_PERFILE |
+                        OPT_INPUT | OPT_OUTPUT,                                    { .func_arg = opt_ch_layout },
+        "set channel layout", "layout" },
+#if FF_API_OLD_CHANNEL_LAYOUT
     { "channel_layout", OPT_AUDIO | HAS_ARG  | OPT_EXPERT | OPT_PERFILE |
                         OPT_INPUT | OPT_OUTPUT,                                    { .func_arg = opt_channel_layout },
-        "set channel layout", "layout" },
+        "deprecated, use -ch_layout", "layout" },
+#endif
     { "af",             OPT_AUDIO | HAS_ARG  | OPT_PERFILE | OPT_OUTPUT,           { .func_arg = opt_audio_filters },
         "set audio filters", "filter_graph" },
     { "guess_layout_max", OPT_AUDIO | HAS_ARG | OPT_INT | OPT_SPEC | OPT_EXPERT | OPT_INPUT, { .off = OFFSET(guess_layout_max) },
diff --git a/tests/fate/aac.mak b/tests/fate/aac.mak
index 1743428f54..d8750b093a 100644
--- a/tests/fate/aac.mak
+++ b/tests/fate/aac.mak
@@ -237,7 +237,7 @@ fate-aac-latm_000000001180bc60: CMD = pcm -i $(TARGET_SAMPLES)/aac/latm_00000000
 fate-aac-latm_000000001180bc60: REF = $(SAMPLES)/aac/latm_000000001180bc60.s16
 
 FATE_AAC_LATM += fate-aac-latm_stereo_to_51
-fate-aac-latm_stereo_to_51: CMD = pcm -i $(TARGET_SAMPLES)/aac/latm_stereo_to_51.ts -channel_layout 5.1
+fate-aac-latm_stereo_to_51: CMD = pcm -i $(TARGET_SAMPLES)/aac/latm_stereo_to_51.ts -ch_layout 5.1
 fate-aac-latm_stereo_to_51: REF = $(SAMPLES)/aac/latm_stereo_to_51_ref.s16
 
 fate-aac-autobsf-adtstoasc: CMD = transcode "aac" $(TARGET_SAMPLES)/audiomatch/tones_afconvert_16000_mono_aac_lc.adts \
diff --git a/tests/fate/lavf-container.mak b/tests/fate/lavf-container.mak
index 9e0eed4851..446a0cfbe2 100644
--- a/tests/fate/lavf-container.mak
+++ b/tests/fate/lavf-container.mak
@@ -26,7 +26,7 @@ $(FATE_LAVF_CONTAINER): $(AREF) $(VREF)
 
 fate-lavf-asf: CMD = lavf_container "" "-c:a mp2 -ar 44100" "-r 25"
 fate-lavf-avi fate-lavf-nut: CMD = lavf_container "" "-c:a mp2 -ar 44100 -threads 1"
-fate-lavf-dv:  CMD = lavf_container "-ar 48000 -channel_layout stereo" "-r 25 -s pal"
+fate-lavf-dv:  CMD = lavf_container "-ar 48000 -ch_layout stereo" "-r 25 -s pal"
 fate-lavf-dv_pal:  CMD = lavf_container_timecode_nodrop "-ar 48000 -r 25 -s pal -ac 2 -f dv"
 fate-lavf-dv_ntsc:  CMD = lavf_container_timecode_drop "-ar 48000 -pix_fmt yuv411p -s ntsc -ac 2 -f dv"
 fate-lavf-flv fate-lavf-swf: CMD = lavf_container "" "-an"
-- 
2.34.1

_______________________________________________
ffmpeg-devel mailing list
ffmpeg-devel@ffmpeg.org
https://ffmpeg.org/mailman/listinfo/ffmpeg-devel

To unsubscribe, visit link above, or email
ffmpeg-devel-request@ffmpeg.org with subject "unsubscribe".

  parent reply	other threads:[~2022-01-13  2:53 UTC|newest]

Thread overview: 337+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2022-01-13  1:49 [FFmpeg-devel] [PATCH 000/281 v3] New channel layout API James Almer
2022-01-13  1:49 ` [FFmpeg-devel] [PATCH 001/281] Add a new " James Almer
2022-01-13 14:08   ` Lynne
2022-01-16 11:27   ` Nicolas George
2022-01-16 22:54     ` Marton Balint
2022-01-17 13:22       ` James Almer
2022-01-17 20:18         ` Marton Balint
2022-01-17 20:27           ` James Almer
2022-01-17 13:53       ` Nicolas George
2022-01-17 13:54         ` James Almer
2022-01-17 13:56           ` Nicolas George
2022-01-17 14:02             ` James Almer
2022-01-17 16:50               ` Nicolas George
2022-01-17 16:52                 ` James Almer
2022-01-17 16:54                   ` Nicolas George
2022-01-17 16:57                     ` James Almer
2022-01-17 17:55                       ` Nicolas George
2022-01-17 13:32     ` James Almer
2022-01-17 13:51       ` Nicolas George
2022-01-17 14:12         ` James Almer
2022-01-17 16:48           ` Nicolas George
2022-01-17 16:50             ` James Almer
2022-01-13  1:49 ` [FFmpeg-devel] [PATCH 002/281] fate: add a channel_layout API test James Almer
2022-01-13  1:49 ` [FFmpeg-devel] [PATCH 003/281] lavu: support AVChannelLayout AVOptions James Almer
2022-01-13  1:49 ` [FFmpeg-devel] [PATCH 004/281] lavc: deprecate channel count/layout changing side data James Almer
2022-01-13  1:49 ` [FFmpeg-devel] [PATCH 005/281] avframe: switch to the new channel layout API James Almer
2022-01-13  1:49 ` [FFmpeg-devel] [PATCH 006/281] avcodecpar: " James Almer
2022-01-13  1:49 ` [FFmpeg-devel] [PATCH 007/281] lavf: add a temporary compat layer for the channel layout API change James Almer
2022-01-13  1:49 ` [FFmpeg-devel] [PATCH 008/281] lavf: convert the generic layer to the new channel layout James Almer
2022-01-13  1:49 ` [FFmpeg-devel] [PATCH 009/281] 3dostr: convert to new channel layout API James Almer
2022-01-13  1:49 ` [FFmpeg-devel] [PATCH 010/281] 4xm: " James Almer
2022-01-13  1:49 ` [FFmpeg-devel] [PATCH 011/281] aa: " James Almer
2022-01-13  1:49 ` [FFmpeg-devel] [PATCH 012/281] aax: " James Almer
2022-01-13  1:49 ` [FFmpeg-devel] [PATCH 013/281] ace: " James Almer
2022-01-13  1:49 ` [FFmpeg-devel] [PATCH 014/281] acm: " James Almer
2022-01-13  1:49 ` [FFmpeg-devel] [PATCH 015/281] act: " James Almer
2022-01-13  1:49 ` [FFmpeg-devel] [PATCH 016/281] adp: " James Almer
2022-01-13  1:49 ` [FFmpeg-devel] [PATCH 017/281] ads: " James Almer
2022-01-13  1:49 ` [FFmpeg-devel] [PATCH 018/281] adxdec: " James Almer
2022-01-13  1:49 ` [FFmpeg-devel] [PATCH 019/281] aea: " James Almer
2022-01-13  1:49 ` [FFmpeg-devel] [PATCH 020/281] afc: " James Almer
2022-01-13  1:49 ` [FFmpeg-devel] [PATCH 021/281] aiff: " James Almer
2022-01-13  1:49 ` [FFmpeg-devel] [PATCH 022/281] aixdec: " James Almer
2022-01-13  1:49 ` [FFmpeg-devel] [PATCH 023/281] alsa: " James Almer
2022-01-13  1:49 ` [FFmpeg-devel] [PATCH 024/281] alp: " James Almer
2022-01-13  1:49 ` [FFmpeg-devel] [PATCH 025/281] amr: " James Almer
2022-01-13  1:49 ` [FFmpeg-devel] [PATCH 026/281] amv: " James Almer
2022-01-13  1:49 ` [FFmpeg-devel] [PATCH 027/281] apc: " James Almer
2022-01-26 13:41   ` Anton Khirnov
2022-01-13  1:49 ` [FFmpeg-devel] [PATCH 028/281] ape: " James Almer
2022-01-13  1:49 ` [FFmpeg-devel] [PATCH 029/281] apm: " James Almer
2022-01-13  1:49 ` [FFmpeg-devel] [PATCH 030/281] aptxdec: " James Almer
2022-01-13  1:49 ` [FFmpeg-devel] [PATCH 031/281] argo: " James Almer
2022-01-13  1:49 ` [FFmpeg-devel] [PATCH 032/281] ast: " James Almer
2022-01-13  1:49 ` [FFmpeg-devel] [PATCH 033/281] au: " James Almer
2022-01-13  1:49 ` [FFmpeg-devel] [PATCH 034/281] avr: " James Almer
2022-01-13  1:49 ` [FFmpeg-devel] [PATCH 035/281] bethsoftvid: " James Almer
2022-01-13  1:49 ` [FFmpeg-devel] [PATCH 036/281] bfi: " James Almer
2022-01-13  1:49 ` [FFmpeg-devel] [PATCH 037/281] bink: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 038/281] bit: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 039/281] bmv: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 040/281] boa: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 041/281] brstm: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 042/281] caf: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 043/281] cdxl: " James Almer
2022-01-26 13:53   ` Anton Khirnov
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 044/281] codec2: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 045/281] dash: " James Almer
2022-01-26 13:56   ` Anton Khirnov
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 046/281] dcstr: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 047/281] derf: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 048/281] dhav: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 049/281] dtshddec: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 050/281] dsicin: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 051/281] dshow: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 052/281] dss: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 053/281] dsfdec: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 054/281] dv: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 055/281] eac: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 056/281] electronicarts: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 057/281] epafdec: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 058/281] flac: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 059/281] flic: " James Almer
2022-01-27  7:46   ` Anton Khirnov
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 060/281] flv: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 061/281] framehash: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 062/281] fsb: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 063/281] fwse: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 064/281] g722: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 065/281] g723_1: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 066/281] g726: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 067/281] g729: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 068/281] gdv: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 069/281] genh: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 070/281] gsm: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 071/281] gxf: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 072/281] hca: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 073/281] hcom: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 074/281] hls_sample_encryption: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 075/281] idcin: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 076/281] idroq: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 077/281] iff: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 078/281] ifv: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 079/281] ilbc: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 080/281] imx: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 081/281] ircam: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 082/281] ipmovie: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 083/281] iss: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 084/281] jack: port " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 085/281] jvdec: convert " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 086/281] kvag: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 087/281] avdevice/lavfi: " James Almer
2022-01-13  1:50 ` [FFmpeg-devel] [PATCH 088/281] libcdio: port " James Almer
2022-01-13  1:55 ` [FFmpeg-devel] [PATCH 089/281] lvf: convert " James Almer
2022-01-13  1:55 ` [FFmpeg-devel] [PATCH 090/281] lxfdec: " James Almer
2022-01-27 15:19   ` Tomas Härdin
2022-01-13  1:55 ` [FFmpeg-devel] [PATCH 091/281] matroska: " James Almer
2022-01-21 19:52   ` Andreas Rheinhardt
2022-01-21 20:20     ` James Almer
2022-01-13  1:55 ` [FFmpeg-devel] [PATCH 092/281] mca: " James Almer
2022-01-13  1:55 ` [FFmpeg-devel] [PATCH 093/281] mm: " James Almer
2022-01-13  1:55 ` [FFmpeg-devel] [PATCH 094/281] mmf: " James Almer
2022-01-13  1:55 ` [FFmpeg-devel] [PATCH 095/281] moflex: " James Almer
2022-01-13  1:55 ` [FFmpeg-devel] [PATCH 096/281] mov: " James Almer
2022-01-28 10:08   ` Anton Khirnov
2022-01-13  1:55 ` [FFmpeg-devel] [PATCH 097/281] movenc-test: " James Almer
2022-01-13  1:55 ` [FFmpeg-devel] [PATCH 098/281] mp3: " James Almer
2022-01-13  1:55 ` [FFmpeg-devel] [PATCH 099/281] mpc: " James Almer
2022-01-13  1:55 ` [FFmpeg-devel] [PATCH 100/281] mpc8: " James Almer
2022-01-13  1:55 ` [FFmpeg-devel] [PATCH 101/281] mpeg: " James Almer
2022-01-13  1:55 ` [FFmpeg-devel] [PATCH 102/281] mpegenc: " James Almer
2022-01-13  1:55 ` [FFmpeg-devel] [PATCH 103/281] mpegtsenc: " James Almer
2022-01-13  1:55 ` [FFmpeg-devel] [PATCH 104/281] msf: " James Almer
2022-01-13  1:55 ` [FFmpeg-devel] [PATCH 105/281] mtaf: " James Almer
2022-01-13  1:55 ` [FFmpeg-devel] [PATCH 106/281] musx: " James Almer
2022-01-13  1:56 ` [FFmpeg-devel] [PATCH 107/281] mvdec: " James Almer
2022-01-13  1:56 ` [FFmpeg-devel] [PATCH 108/281] mvi: " James Almer
2022-01-13  1:56 ` [FFmpeg-devel] [PATCH 109/281] mxf: " James Almer
2022-01-19 19:06   ` Tomas Härdin
2022-01-13  1:56 ` [FFmpeg-devel] [PATCH 110/281] mxg: " James Almer
2022-01-13  1:56 ` [FFmpeg-devel] [PATCH 111/281] nistspheredec: " James Almer
2022-01-13  1:56 ` [FFmpeg-devel] [PATCH 112/281] nspdec: " James Almer
2022-01-13  1:56 ` [FFmpeg-devel] [PATCH 113/281] nsvdec: " James Almer
2022-01-13  1:56 ` [FFmpeg-devel] [PATCH 114/281] nutdec: " James Almer
2022-01-13  1:56 ` [FFmpeg-devel] [PATCH 115/281] nuv: " James Almer
2022-01-13  1:56 ` [FFmpeg-devel] [PATCH 116/281] ogg: " James Almer
2022-01-13  1:56 ` [FFmpeg-devel] [PATCH 117/281] oma: " James Almer
2022-01-13  1:56 ` [FFmpeg-devel] [PATCH 118/281] oss: port " James Almer
2022-01-13  1:56 ` [FFmpeg-devel] [PATCH 119/281] paf: convert " James Almer
2022-01-13  1:57 ` [FFmpeg-devel] [PATCH 089/281] lvf: " James Almer
2022-01-13  1:57 ` [FFmpeg-devel] [PATCH 120/281] pcm: " James Almer
2022-01-13  1:57 ` [FFmpeg-devel] [PATCH 121/281] pmp: " James Almer
2022-01-13  1:57 ` [FFmpeg-devel] [PATCH 122/281] pp_bnk: " James Almer
2022-01-13  1:57 ` [FFmpeg-devel] [PATCH 123/281] psxstr: " James Almer
2022-01-13  1:57 ` [FFmpeg-devel] [PATCH 124/281] pvf: " James Almer
2022-01-13  1:57 ` [FFmpeg-devel] [PATCH 125/281] qcp: " James Almer
2022-01-13  1:57 ` [FFmpeg-devel] [PATCH 126/281] r3d: " James Almer
2022-01-13  1:57 ` [FFmpeg-devel] [PATCH 127/281] rawenc: " James Almer
2022-01-13  1:57 ` [FFmpeg-devel] [PATCH 128/281] redspark: " James Almer
2022-01-13  1:57 ` [FFmpeg-devel] [PATCH 129/281] riff: " James Almer
2022-01-13  1:57 ` [FFmpeg-devel] [PATCH 130/281] rl2: " James Almer
2022-01-13  1:57 ` [FFmpeg-devel] [PATCH 131/281] rm: " James Almer
2022-01-13  1:57 ` [FFmpeg-devel] [PATCH 132/281] rpl: " James Almer
2022-01-13  1:57 ` [FFmpeg-devel] [PATCH 133/281] rsd: " James Almer
2022-01-13  1:57 ` [FFmpeg-devel] [PATCH 134/281] rso: " James Almer
2022-01-13  1:57 ` [FFmpeg-devel] [PATCH 135/281] rtp: " James Almer
2022-01-28 14:15   ` Anton Khirnov
2022-01-13  1:57 ` [FFmpeg-devel] [PATCH 136/281] sbg: " James Almer
2022-01-13  1:57 ` [FFmpeg-devel] [PATCH 137/281] scd: " James Almer
2022-01-13  1:57 ` [FFmpeg-devel] [PATCH 138/281] sdp: " James Almer
2022-01-13  1:57 ` [FFmpeg-devel] [PATCH 139/281] sdr2: " James Almer
2022-01-13  1:57 ` [FFmpeg-devel] [PATCH 140/281] sds: " James Almer
2022-01-13  1:57 ` [FFmpeg-devel] [PATCH 141/281] sdx: " James Almer
2022-01-13  1:57 ` [FFmpeg-devel] [PATCH 142/281] segafilm: " James Almer
2022-01-13  1:58 ` [FFmpeg-devel] [PATCH 143/281] sga: " James Almer
2022-01-13  1:58 ` [FFmpeg-devel] [PATCH 144/281] sierravmd: " James Almer
2022-01-13  1:58 ` [FFmpeg-devel] [PATCH 145/281] siff: " James Almer
2022-01-13  1:58 ` [FFmpeg-devel] [PATCH 146/281] smacker: " James Almer
2022-01-13  1:58 ` [FFmpeg-devel] [PATCH 147/281] smjpegenc: " James Almer
2022-01-13  1:58 ` [FFmpeg-devel] [PATCH 148/281] smoothstreaming: " James Almer
2022-01-13  1:58 ` [FFmpeg-devel] [PATCH 149/281] smush: " James Almer
2022-01-13  1:59 ` [FFmpeg-devel] [PATCH 089/281] lvf: " James Almer
2022-01-13  1:59 ` [FFmpeg-devel] [PATCH 150/281] sol: " James Almer
2022-01-13  1:59 ` [FFmpeg-devel] [PATCH 151/281] sox: " James Almer
2022-01-13  1:59 ` [FFmpeg-devel] [PATCH 152/281] svag: " James Almer
2022-01-13  2:00 ` [FFmpeg-devel] [PATCH 153/281] svs: " James Almer
2022-01-13  2:00 ` [FFmpeg-devel] [PATCH 154/281] swf: " James Almer
2022-01-13  2:00 ` [FFmpeg-devel] [PATCH 155/281] tak: " James Almer
2022-01-13  2:00 ` [FFmpeg-devel] [PATCH 156/281] thp: " James Almer
2022-01-13  2:00 ` [FFmpeg-devel] [PATCH 157/281] tiertexseq: " James Almer
2022-01-13  2:00 ` [FFmpeg-devel] [PATCH 158/281] tmv: " James Almer
2022-01-13  2:00 ` [FFmpeg-devel] [PATCH 159/281] tta: " James Almer
2022-01-13  2:00 ` [FFmpeg-devel] [PATCH 160/281] uncodedframecrcenc: " James Almer
2022-01-13  2:00 ` [FFmpeg-devel] [PATCH 161/281] vag: " James Almer
2022-01-13  2:00 ` [FFmpeg-devel] [PATCH 162/281] vividas: " James Almer
2022-01-13  2:00 ` [FFmpeg-devel] [PATCH 163/281] vivo: " James Almer
2022-01-13  2:00 ` [FFmpeg-devel] [PATCH 164/281] voc: " James Almer
2022-01-13  2:00 ` [FFmpeg-devel] [PATCH 165/281] vpk: " James Almer
2022-01-13  2:00 ` [FFmpeg-devel] [PATCH 166/281] vqf: " James Almer
2022-01-13  2:00 ` [FFmpeg-devel] [PATCH 167/281] wav: " James Almer
2022-01-13  2:00 ` [FFmpeg-devel] [PATCH 168/281] wc3movie: " James Almer
2022-01-13  2:00 ` [FFmpeg-devel] [PATCH 169/281] westwood: " James Almer
2022-01-13  2:00 ` [FFmpeg-devel] [PATCH 170/281] wtv: " James Almer
2022-01-13  2:00 ` [FFmpeg-devel] [PATCH 171/281] wv: " James Almer
2022-01-13  2:00 ` [FFmpeg-devel] [PATCH 172/281] xa: " James Almer
2022-01-13  2:00 ` [FFmpeg-devel] [PATCH 173/281] xmv: " James Almer
2022-01-13  2:00 ` [FFmpeg-devel] [PATCH 174/281] xwma: " James Almer
2022-01-13  2:00 ` [FFmpeg-devel] [PATCH 175/281] yop: " James Almer
2022-01-13  2:00 ` [FFmpeg-devel] [PATCH 176/281] wsd: " James Almer
2022-01-13  2:00 ` [FFmpeg-devel] [PATCH 177/281] wve: " James Almer
2022-01-13  2:00 ` [FFmpeg-devel] [PATCH 178/281] xvag: " James Almer
2022-01-13  2:00 ` [FFmpeg-devel] [PATCH 179/281] lavf: drop the channel layout compat layer for old-style (de)muxers James Almer
2022-01-13  2:02 ` [FFmpeg-devel] [PATCH 180/281] lavc: switch to the new channel layout API James Almer
2022-01-13  2:02 ` [FFmpeg-devel] [PATCH 181/281] 8svx: convert to " James Almer
2022-01-13  2:02 ` [FFmpeg-devel] [PATCH 182/281] aac: " James Almer
2022-01-13  2:02 ` [FFmpeg-devel] [PATCH 183/281] ac3: " James Almer
2022-01-13  2:02 ` [FFmpeg-devel] [PATCH 184/281] adpcm: " James Almer
2022-01-13  2:02 ` [FFmpeg-devel] [PATCH 185/281] adx: " James Almer
2022-01-13  2:02 ` [FFmpeg-devel] [PATCH 186/281] alac: " James Almer
2022-02-09  9:40   ` Anton Khirnov
2022-01-13  2:02 ` [FFmpeg-devel] [PATCH 187/281] als: " James Almer
2022-01-13  2:02 ` [FFmpeg-devel] [PATCH 188/281] amr: " James Almer
2022-01-13  2:02 ` [FFmpeg-devel] [PATCH 189/281] aptx: " James Almer
2022-01-13  2:02 ` [FFmpeg-devel] [PATCH 190/281] atrac1: " James Almer
2022-01-13  2:02 ` [FFmpeg-devel] [PATCH 191/281] atrac3: " James Almer
2022-01-13  2:02 ` [FFmpeg-devel] [PATCH 192/281] atrac3plus: " James Almer
2022-01-13  2:02 ` [FFmpeg-devel] [PATCH 193/281] atrac9: " James Almer
2022-01-13  2:02 ` [FFmpeg-devel] [PATCH 194/281] apedec: " James Almer
2022-01-13  2:02 ` [FFmpeg-devel] [PATCH 195/281] audiotoolbox: " James Almer
2022-02-21 14:22   ` Anton Khirnov
2022-01-13  2:02 ` [FFmpeg-devel] [PATCH 196/281] binkaudio: " James Almer
2022-01-13  2:02 ` [FFmpeg-devel] [PATCH 197/281] bmvaudio: " James Almer
2022-01-13  2:02 ` [FFmpeg-devel] [PATCH 198/281] cng: " James Almer
2022-01-13  2:02 ` [FFmpeg-devel] [PATCH 199/281] cook: " James Almer
2022-01-13  2:02 ` [FFmpeg-devel] [PATCH 200/281] dca: " James Almer
2022-01-13  2:02 ` [FFmpeg-devel] [PATCH 201/281] dolby_e: " James Almer
2022-01-13  2:02 ` [FFmpeg-devel] [PATCH 202/281] dpcm: " James Almer
2022-01-13  2:02 ` [FFmpeg-devel] [PATCH 203/281] dsd: " James Almer
2022-01-13  2:02 ` [FFmpeg-devel] [PATCH 204/281] dsicinav: " James Almer
2022-01-13  2:02 ` [FFmpeg-devel] [PATCH 205/281] dss_sp: " James Almer
2022-01-13  2:02 ` [FFmpeg-devel] [PATCH 206/281] dst: " James Almer
2022-01-13  2:02 ` [FFmpeg-devel] [PATCH 207/281] dvaudio: " James Almer
2022-01-13  2:02 ` [FFmpeg-devel] [PATCH 208/281] evrc: " James Almer
2022-01-13  2:02 ` [FFmpeg-devel] [PATCH 209/281] fastaudio: " James Almer
2022-01-13  2:04 ` [FFmpeg-devel] [PATCH 210/281] ffwavesynth: " James Almer
2022-01-13  2:04 ` [FFmpeg-devel] [PATCH 211/281] flac: " James Almer
2022-02-23 10:24   ` Anton Khirnov
2022-02-23 11:51     ` James Almer
2022-01-13  2:04 ` [FFmpeg-devel] [PATCH 212/281] g722: " James Almer
2022-01-13  2:04 ` [FFmpeg-devel] [PATCH 213/281] g723_1: " James Almer
2022-01-13  2:04 ` [FFmpeg-devel] [PATCH 214/281] g726: " James Almer
2022-01-13  2:04 ` [FFmpeg-devel] [PATCH 215/281] g729: " James Almer
2022-01-13  2:04 ` [FFmpeg-devel] [PATCH 216/281] gsmdec: " James Almer
2022-01-13  2:04 ` [FFmpeg-devel] [PATCH 217/281] hca: " James Almer
2022-01-13  2:04 ` [FFmpeg-devel] [PATCH 218/281] hcom: " James Almer
2022-01-13  2:04 ` [FFmpeg-devel] [PATCH 219/281] ilbc: " James Almer
2022-01-13  2:04 ` [FFmpeg-devel] [PATCH 220/281] imc: " James Almer
2022-01-13  2:05 ` [FFmpeg-devel] [PATCH 221/281] interplayacm: " James Almer
2022-01-13  2:05 ` [FFmpeg-devel] [PATCH 222/281] libcelt: " James Almer
2022-01-13  2:05 ` [FFmpeg-devel] [PATCH 223/281] libcodec2: " James Almer
2022-01-13  2:05 ` [FFmpeg-devel] [PATCH 224/281] libfdk-aac: " James Almer
2022-02-25 11:18   ` Anton Khirnov
2022-01-13  2:05 ` [FFmpeg-devel] [PATCH 225/281] libilbc: " James Almer
2022-01-13  2:05 ` [FFmpeg-devel] [PATCH 226/281] libgsm: " James Almer
2022-02-25 11:20   ` Anton Khirnov
2022-01-13  2:05 ` [FFmpeg-devel] [PATCH 227/281] libmp3lame: " James Almer
2022-01-13  2:05 ` [FFmpeg-devel] [PATCH 228/281] libopencore-amr: " James Almer
2022-01-13  2:05 ` [FFmpeg-devel] [PATCH 229/281] libopus: " James Almer
2022-02-25 11:46   ` Anton Khirnov
2022-01-13  2:05 ` [FFmpeg-devel] [PATCH 230/281] libshine: " James Almer
2022-01-13  2:05 ` [FFmpeg-devel] [PATCH 231/281] libspeexdec: " James Almer
2022-01-13  2:05 ` [FFmpeg-devel] [PATCH 232/281] libtwolame: " James Almer
2022-01-13  2:05 ` [FFmpeg-devel] [PATCH 233/281] libvo-amrwbenc: " James Almer
2022-01-13  2:05 ` [FFmpeg-devel] [PATCH 234/281] libvorbis: " James Almer
2022-01-13  2:05 ` [FFmpeg-devel] [PATCH 235/281] mace: " James Almer
2022-01-13  2:05 ` [FFmpeg-devel] [PATCH 236/281] metasound: " James Almer
2022-01-13  2:05 ` [FFmpeg-devel] [PATCH 237/281] mf: " James Almer
2022-01-13  2:05 ` [FFmpeg-devel] [PATCH 238/281] mlp: " James Almer
2022-01-13  2:05 ` [FFmpeg-devel] [PATCH 239/281] mpc7: " James Almer
2022-01-13  2:06 ` [FFmpeg-devel] [PATCH 240/281] mpc8: " James Almer
2022-01-13  2:06 ` [FFmpeg-devel] [PATCH 241/281] mpegaudio: " James Almer
2022-01-13  2:06 ` [FFmpeg-devel] [PATCH 242/281] nellymoser: " James Almer
2022-01-13  2:06 ` [FFmpeg-devel] [PATCH 243/281] on2avc: " James Almer
2022-01-13  2:06 ` [FFmpeg-devel] [PATCH 244/281] opus: " James Almer
2022-01-13  2:06 ` [FFmpeg-devel] [PATCH 245/281] pafaudio: " James Almer
2022-01-13  2:06 ` [FFmpeg-devel] [PATCH 246/281] pcm: " James Almer
2022-01-13  2:06 ` [FFmpeg-devel] [PATCH 247/281] qcelpdec: " James Almer
2022-01-13  2:06 ` [FFmpeg-devel] [PATCH 248/281] qdmc: " James Almer
2022-01-13  2:06 ` [FFmpeg-devel] [PATCH 249/281] qdm2: " James Almer
2022-01-13  2:06 ` [FFmpeg-devel] [PATCH 250/281] ra144: " James Almer
2022-01-13  2:06 ` [FFmpeg-devel] [PATCH 251/281] ra288: " James Almer
2022-01-13  2:06 ` [FFmpeg-devel] [PATCH 252/281] ralf: " James Almer
2022-01-13  2:06 ` [FFmpeg-devel] [PATCH 253/281] roqaudioenc: " James Almer
2022-01-13  2:06 ` [FFmpeg-devel] [PATCH 254/281] s302m: " James Almer
2022-01-13  2:06 ` [FFmpeg-devel] [PATCH 255/281] sbc: " James Almer
2022-01-13  2:07 ` [FFmpeg-devel] [PATCH 256/281] shorten: " James Almer
2022-01-13  2:07 ` [FFmpeg-devel] [PATCH 257/281] sipr: " James Almer
2022-01-13  2:07 ` [FFmpeg-devel] [PATCH 258/281] siren: " James Almer
2022-01-13  2:07 ` [FFmpeg-devel] [PATCH 259/281] smacker: " James Almer
2022-01-13  2:07 ` [FFmpeg-devel] [PATCH 260/281] sonic: " James Almer
2022-01-13  2:07 ` [FFmpeg-devel] [PATCH 261/281] speex: " James Almer
2022-01-13  2:07 ` [FFmpeg-devel] [PATCH 262/281] tak: " James Almer
2022-01-13  2:07 ` [FFmpeg-devel] [PATCH 263/281] truespeech: " James Almer
2022-01-13  2:07 ` [FFmpeg-devel] [PATCH 264/281] tta: " James Almer
2022-01-13  2:07 ` [FFmpeg-devel] [PATCH 265/281] twinvq: " James Almer
2022-01-13  2:07 ` [FFmpeg-devel] [PATCH 266/281] vima: " James Almer
2022-01-13  2:07 ` [FFmpeg-devel] [PATCH 267/281] vmdaudio: " James Almer
2022-01-13  2:07 ` [FFmpeg-devel] [PATCH 268/281] vorbis: " James Almer
2022-01-13  2:07 ` [FFmpeg-devel] [PATCH 269/281] wavpack: " James Almer
2022-03-07 10:42   ` Anton Khirnov
2022-01-13  2:09 ` [FFmpeg-devel] [PATCH 270/281] wma: " James Almer
2022-03-07 10:26   ` Anton Khirnov
2022-01-13  2:09 ` [FFmpeg-devel] [PATCH 271/281] ws-snd1: " James Almer
2022-01-13  2:09 ` [FFmpeg-devel] [PATCH 272/281] lavc: drop temporary compat wrappers for channel layout API change James Almer
2022-01-13  2:09 ` [FFmpeg-devel] [PATCH 273/281] lavf: Add non diegetic stream disposition flag James Almer
2022-01-13  2:09 ` [FFmpeg-devel] [PATCH 274/281] swresample: convert to new channel layout API James Almer
2022-01-19 17:20   ` Andreas Rheinhardt
2022-01-19 17:29     ` James Almer
2022-01-13  2:09 ` [FFmpeg-devel] [PATCH 275/281] avfilter: " James Almer
2022-02-14 15:49   ` Anton Khirnov
2022-02-15 11:50   ` Anton Khirnov
2022-02-15 12:27     ` James Almer
2022-02-15 12:34       ` Anton Khirnov
2022-02-15 18:52     ` James Almer
2022-02-16 18:15   ` Anton Khirnov
2022-02-18 13:07     ` James Almer
2022-01-13  2:09 ` [FFmpeg-devel] [PATCH 276/281] avdevice/lavfi: remove call to deprecated function av_buffersink_get_channel_layout() James Almer
2022-01-13  2:09 ` James Almer [this message]
2022-01-13 18:29   ` [FFmpeg-devel] [PATCH 277/281] ffmpeg: convert to new channel layout-API Michael Niedermayer
2022-01-13 18:40     ` James Almer
2022-01-13 19:44       ` James Almer
2022-01-15 13:47         ` Michael Niedermayer
2022-01-15 16:04           ` James Almer
2022-01-13  2:09 ` [FFmpeg-devel] [PATCH 278/281] ffprobe: " James Almer
2022-01-13  2:09 ` [FFmpeg-devel] [PATCH 279/281] channel_layout: add support for Ambisonic James Almer
2022-01-13  2:09 ` [FFmpeg-devel] [PATCH 280/281] opus: export mapping family 2 (Ambisonic) as Ambisonic layout James Almer
2022-01-13  2:09 ` [FFmpeg-devel] [PATCH 281/281] mov: Implement spatial audio support James Almer

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20220113020913.870-8-jamrial@gmail.com \
    --to=jamrial@gmail.com \
    --cc=ffmpeg-devel@ffmpeg.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link

Git Inbox Mirror of the ffmpeg-devel mailing list - see https://ffmpeg.org/mailman/listinfo/ffmpeg-devel

This inbox may be cloned and mirrored by anyone:

	git clone --mirror https://master.gitmailbox.com/ffmpegdev/0 ffmpegdev/git/0.git

	# If you have public-inbox 1.1+ installed, you may
	# initialize and index your mirror using the following commands:
	public-inbox-init -V2 ffmpegdev ffmpegdev/ https://master.gitmailbox.com/ffmpegdev \
		ffmpegdev@gitmailbox.com
	public-inbox-index ffmpegdev

Example config snippet for mirrors.


AGPL code for this site: git clone https://public-inbox.org/public-inbox.git