aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMichael Niedermayer <michaelni@gmx.at>2015-06-12 18:56:02 +0200
committerMichael Niedermayer <michaelni@gmx.at>2015-06-12 19:40:48 +0200
commitd0061e77cde56dc26caaec804384b1c58f22f3ea (patch)
tree12c1f25474e85432326511ec3d9447ef97b04ed4
parentce3bcb9479a4b28bd6ea69ef01f06d5964d130ad (diff)
downloadffmpeg-d0061e77cde56dc26caaec804384b1c58f22f3ea.tar.gz
avformat/mxfdec: Detect jpeg2000 through codec_ul too
Fixes Ticket2345 Reviewed-by: Paul B Mahol <onemda@gmail.com> Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
-rw-r--r--libavformat/mxfdec.c14
1 files changed, 14 insertions, 0 deletions
diff --git a/libavformat/mxfdec.c b/libavformat/mxfdec.c
index 78e2393c18..7389555cbe 100644
--- a/libavformat/mxfdec.c
+++ b/libavformat/mxfdec.c
@@ -166,6 +166,7 @@ typedef struct MXFDescriptor {
enum MXFMetadataSetType type;
UID essence_container_ul;
UID essence_codec_ul;
+ UID codec_ul;
AVRational sample_rate;
AVRational aspect_ratio;
int width;
@@ -974,6 +975,9 @@ static int mxf_read_generic_descriptor(void *arg, AVIOContext *pb, int tag, int
case 0x3004:
avio_read(pb, descriptor->essence_container_ul, 16);
break;
+ case 0x3005:
+ avio_read(pb, descriptor->codec_ul, 16);
+ break;
case 0x3006:
descriptor->linked_track_id = avio_rb32(pb);
break;
@@ -1151,6 +1155,11 @@ static const MXFCodecUL mxf_data_essence_container_uls[] = {
{ { 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00 }, 0, AV_CODEC_ID_NONE },
};
+static const MXFCodecUL mxf_codec_uls[] = {
+ { { 0x06,0x0E,0x2B,0x34,0x04,0x01,0x01,0x09,0x04,0x01,0x02,0x02,0x03,0x01,0x01,0x00 }, 14, AV_CODEC_ID_JPEG2000 },
+ { { 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00 }, 0, AV_CODEC_ID_NONE },
+};
+
static const char* const mxf_data_essence_descriptor[] = {
"vbi_vanc_smpte_436M",
};
@@ -1950,6 +1959,11 @@ static int mxf_parse_structural_metadata(MXFContext *mxf)
/* TODO: drop PictureEssenceCoding and SoundEssenceCompression, only check EssenceContainer */
codec_ul = mxf_get_codec_ul(ff_mxf_codec_uls, &descriptor->essence_codec_ul);
st->codec->codec_id = (enum AVCodecID)codec_ul->id;
+ if (st->codec->codec_id == AV_CODEC_ID_NONE) {
+ codec_ul = mxf_get_codec_ul(mxf_codec_uls, &descriptor->codec_ul);
+ st->codec->codec_id = (enum AVCodecID)codec_ul->id;
+ }
+
av_log(mxf->fc, AV_LOG_VERBOSE, "%s: Universal Label: ",
avcodec_get_name(st->codec->codec_id));
for (k = 0; k < 16; k++) {