]> git.sesse.net Git - ffmpeg/commitdiff
avformat/mxfenc: Set the component depth from the pixel format if available
authorMichael Niedermayer <michaelni@gmx.at>
Sat, 16 May 2015 17:59:18 +0000 (19:59 +0200)
committerMichael Niedermayer <michaelni@gmx.at>
Mon, 18 May 2015 08:49:28 +0000 (10:49 +0200)
Reviewed-by: tim nicholson <nichot20@yahoo.com>
Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
libavformat/mxfenc.c

index 59667924f0671412d76ec2e8cdcbd02f77cfc6a1..14449c9f19143181bc54d60a1d28b4a621772fff 100644 (file)
@@ -39,6 +39,7 @@
 #include "libavutil/random_seed.h"
 #include "libavutil/timecode.h"
 #include "libavutil/avassert.h"
+#include "libavutil/pixdesc.h"
 #include "libavutil/time_internal.h"
 #include "libavcodec/bytestream.h"
 #include "libavcodec/dnxhddata.h"
@@ -2029,10 +2030,16 @@ static int mxf_write_header(AVFormatContext *s)
         }
 
         if (st->codec->codec_type == AVMEDIA_TYPE_VIDEO) {
+            const AVPixFmtDescriptor *pix_desc = av_pix_fmt_desc_get(st->codec->pix_fmt);
             // TODO: should be avg_frame_rate
             AVRational rate, tbc = st->time_base;
             // Default component depth to 8
             sc->component_depth = 8;
+
+            if (pix_desc) {
+                sc->component_depth = pix_desc->comp[0].depth_minus1 + 1;
+            }
+
             mxf->timecode_base = (tbc.den + tbc.num/2) / tbc.num;
             spf = ff_mxf_get_samples_per_frame(s, tbc);
             if (!spf) {