diff --git a/transcode.c b/transcode.c index f5b9f672eb21eb3a7f0ea2de201ba2eb6a80e249..1f33526f954c147e48dfc601e3b10acbedebb802 100644 --- a/transcode.c +++ b/transcode.c @@ -66,17 +66,20 @@ static void setup_input_stream(char *stream, AVFormatContext *demux, else if (type == AVMEDIA_TYPE_AUDIO) { // Set channel layout to default if not set - if(decs[idx]->ch_layout.order == AV_CHANNEL_ORDER_UNSPEC) + if(!decs[idx]->channel_layout) + decs[idx]->channel_layout = av_get_default_channel_layout(decs[idx]->channels); + /*if(decs[idx]->ch_layout.order == AV_CHANNEL_ORDER_UNSPEC) av_channel_layout_default(&decs[idx]->ch_layout, decs[idx]->ch_layout.nb_channels); char ch_layout[64]; err = av_channel_layout_describe(&decs[idx]->ch_layout, ch_layout, sizeof(ch_layout)); if (err < 0) - job_failed("Could not describe channel layout: %s", av_err2str(err)); + job_failed("Could not describe channel layout: %s", av_err2str(err));*/ + p = mprintf("time_base=%d/%d:sample_rate=%d:sample_fmt=%d:channel_layout=%s:channels=%d", demux->streams[idx]->time_base.num, demux->streams[idx]->time_base.den, - decs[idx]->sample_rate, decs[idx]->sample_fmt, ch_layout, + decs[idx]->sample_rate, decs[idx]->sample_fmt, decs[idx]->channel_layout, decs[idx]->channels); err = avfilter_graph_create_filter(&srcs[idx], avfilter_get_by_name("abuffer"), 0, p, 0, fg);