[FFmpeg-devel] [PATCH 1/3] avformat/mxfdec: Read Mastering Display Colour Volume from MXF

Harry Mallon harry.mallon at codex.online
Wed Sep 9 17:50:34 EEST 2020




> On 7 Sep 2020, at 10:40, Tomas Härdin <tjoppen at acc.umu.se> wrote:
> 
> mån 2020-08-31 klockan 20:07 +0100 skrev Harry Mallon:
>> +static const uint8_t mxf_mastering_display_primaries[]                = { 0x06,0x0e,0x2b,0x34,0x01,0x01,0x01,0x0e,0x04,0x20,0x04,0x01,0x01,0x01,0x00,0x00 };
>> +static const uint8_t mxf_mastering_display_white_point_chromaticity[] = { 0x06,0x0e,0x2b,0x34,0x01,0x01,0x01,0x0e,0x04,0x20,0x04,0x01,0x01,0x02,0x00,0x00 };
>> +static const uint8_t mxf_mastering_display_maximum_luminance[]        = { 0x06,0x0e,0x2b,0x34,0x01,0x01,0x01,0x0e,0x04,0x20,0x04,0x01,0x01,0x03,0x00,0x00 };
>> +static const uint8_t mxf_mastering_display_minimum_luminance[]        = { 0x06,0x0e,0x2b,0x34,0x01,0x01,0x01,0x0e,0x04,0x20,0x04,0x01,0x01,0x04,0x00,0x00 };
> 
> I can't find any of these ULs in any of the specs I have on hand. Are
> they all defined in 2067-21? ULs for for example primaries are already
> defined in RP210 (06.0E.2B.34.01.01.01.09.04.01.02.01.01.06.00.00) and
> RP224 (06.0E.2B.34.04.01.01.06.04.01.01.01.03.00.00.00).

SMPTEST 2067-21:2020 (available free atm https://ieeexplore.ieee.org/stamp/stamp.jsp?tp=&arnumber=9097487), Annex B. The UIDs are split over multiple lines, preventing easy grepping. :)

> 
> 
>> @@ -1272,6 +1280,60 @@ static int mxf_read_generic_descriptor(void *arg, AVIOContext *pb, int tag, int
>>                 rsiz == FF_PROFILE_JPEG2000_DCINEMA_4K)
>>                 descriptor->pix_fmt = AV_PIX_FMT_XYZ12;
>>         }
>> +        if (IS_KLV_KEY(uid, mxf_mastering_display_primaries)) {
>> +            const int chroma_den = 50000;
> 
> I see this and luma_den used both here and in the mxfenc patch. Since
> they're the same values, consider defining them as macros in mxf.h
> instead.

Done in v2.

> 
>> +            int i;
>> +            if (!descriptor->mastering) {
>> +                descriptor->mastering = av_mastering_display_metadata_alloc();
>> +                if (!descriptor->mastering)
>> +                    return AVERROR(ENOMEM);
>> +            }
> 
> This exact code appears four times, should be de-duplicated. You could
> for example do IS_KLV_KEY() with a prefix of all four keys
> (0x06,0x0e,0x2b,0x34,0x01,0x01,0x01,0x0e,0x04,0x20,0x04,0x01,0x01)
> before these four IS_KLV_KEY() ifs.

Done in v2.

Best,
Harry


More information about the ffmpeg-devel mailing list