]> git.sesse.net Git - ffmpeg/blobdiff - libavfilter/avcodec.c
Merge commit '072be3e8969f24113d599444be4d6a0ed04a6602'
[ffmpeg] / libavfilter / avcodec.c
index 705cf80ca51382ab29c1d5721fbf99250749710d..2533bd8f678719f6e809ec6afa30b15732972566 100644 (file)
@@ -93,10 +93,16 @@ AVFilterBufferRef *avfilter_get_audio_buffer_ref_from_frame(const AVFrame *frame
                                                             int perms)
 {
     AVFilterBufferRef *samplesref;
+    int64_t layout = av_frame_get_channel_layout(frame);
 
     if(av_frame_get_channels(frame) > 8) // libavfilter does not suport more than 8 channels FIXME, remove once libavfilter is fixed
         return NULL;
 
+    if (layout && av_get_channel_layout_nb_channels(layout) != av_frame_get_channels(frame)) {
+        av_log(0, AV_LOG_ERROR, "Layout indicates a differnt number of channels than actually present\n");
+        return NULL;
+    }
+
     samplesref = avfilter_get_audio_buffer_ref_from_arrays((uint8_t **)frame->data, frame->linesize[0], perms,
                                                   frame->nb_samples, frame->format,
                                                   av_frame_get_channel_layout(frame));