diff options
-rw-r--r-- | demux/demux_mkv.c | 105 |
1 files changed, 52 insertions, 53 deletions
diff --git a/demux/demux_mkv.c b/demux/demux_mkv.c index 52f5a6634c..7169f2c32a 100644 --- a/demux/demux_mkv.c +++ b/demux/demux_mkv.c @@ -1227,6 +1227,8 @@ static int demux_mkv_open_video(demuxer_t *demuxer, mkv_track_t *track) sh->demuxer_id = track->tnum; sh->title = talloc_strdup(sh_v, track->name); + sh_v->bits_per_coded_sample = 24; + if (!strcmp(track->codec_id, MKV_V_MSCOMP)) { /* AVI compatibility mode */ // The private_data contains a BITMAPINFOHEADER struct if (track->private_data == NULL || track->private_size < 40) @@ -1244,62 +1246,59 @@ static int demux_mkv_open_video(demuxer_t *demuxer, mkv_track_t *track) extradata_size = track->private_size - 40; mp_set_codec_from_tag(sh); sh_v->avi_dts = true; - } else { - sh_v->bits_per_coded_sample = 24; - - if (track->private_size >= RVPROPERTIES_SIZE - && (!strcmp(track->codec_id, MKV_V_REALV10) + } else if (track->private_size >= RVPROPERTIES_SIZE + && (!strcmp(track->codec_id, MKV_V_REALV10) || !strcmp(track->codec_id, MKV_V_REALV20) || !strcmp(track->codec_id, MKV_V_REALV30) - || !strcmp(track->codec_id, MKV_V_REALV40))) { - unsigned char *src; - uint32_t type2; - unsigned int cnt; - - src = (uint8_t *) track->private_data + RVPROPERTIES_SIZE; - - cnt = track->private_size - RVPROPERTIES_SIZE; - type2 = AV_RB32(src - 4); - if (type2 == 0x10003000 || type2 == 0x10003001) - sh->format = MP_FOURCC('R', 'V', '1', '3'); - else - sh->format = MP_FOURCC('R', 'V', track->codec_id[9], '0'); - // copy type1 and type2 info from rv properties - extradata_size = cnt + 8; - extradata = src - 8; - track->parse = true; - track->parse_timebase = 1e3; + || !strcmp(track->codec_id, MKV_V_REALV40))) + { + unsigned char *src; + uint32_t type2; + unsigned int cnt; + + src = (uint8_t *) track->private_data + RVPROPERTIES_SIZE; + + cnt = track->private_size - RVPROPERTIES_SIZE; + type2 = AV_RB32(src - 4); + if (type2 == 0x10003000 || type2 == 0x10003001) + sh->format = MP_FOURCC('R', 'V', '1', '3'); + else + sh->format = MP_FOURCC('R', 'V', track->codec_id[9], '0'); + // copy type1 and type2 info from rv properties + extradata_size = cnt + 8; + extradata = src - 8; + track->parse = true; + track->parse_timebase = 1e3; + mp_set_codec_from_tag(sh); + } else if (strcmp(track->codec_id, MKV_V_UNCOMPRESSED) == 0) { + // raw video, "like AVI" - this is a FourCC + sh->format = track->colorspace; + sh->codec = "rawvideo"; + } else if (strcmp(track->codec_id, MKV_V_QUICKTIME) == 0) { + uint32_t fourcc1 = 0, fourcc2 = 0; + if (track->private_size >= 8) { + fourcc1 = AV_RL32(track->private_data + 0); + fourcc2 = AV_RL32(track->private_data + 4); + } + if (fourcc1 == MP_FOURCC('S', 'V', 'Q', '3') || + fourcc2 == MP_FOURCC('S', 'V', 'Q', '3')) + { + sh->codec = "svq3"; + extradata = track->private_data; + extradata_size = track->private_size; + } + } else { + const videocodec_info_t *vi = vinfo; + while (vi->id && strcmp(vi->id, track->codec_id)) + vi++; + if (vi->id) { + sh->format = vi->fourcc; mp_set_codec_from_tag(sh); - } else if (strcmp(track->codec_id, MKV_V_UNCOMPRESSED) == 0) { - // raw video, "like AVI" - this is a FourCC - sh->format = track->colorspace; - sh->codec = "rawvideo"; - } else if (strcmp(track->codec_id, MKV_V_QUICKTIME) == 0) { - uint32_t fourcc1 = 0, fourcc2 = 0; - if (track->private_size >= 8) { - fourcc1 = AV_RL32(track->private_data + 0); - fourcc2 = AV_RL32(track->private_data + 4); - } - if (fourcc1 == MP_FOURCC('S', 'V', 'Q', '3') || - fourcc2 == MP_FOURCC('S', 'V', 'Q', '3')) - { - sh->codec = "svq3"; - extradata = track->private_data; - extradata_size = track->private_size; - } - } else { - const videocodec_info_t *vi = vinfo; - while (vi->id && strcmp(vi->id, track->codec_id)) - vi++; - if (vi->id) { - sh->format = vi->fourcc; - mp_set_codec_from_tag(sh); - } - if (vi->extradata && track->private_data && track->private_size > 0) - { - extradata = track->private_data; - extradata_size = track->private_size; - } + } + if (vi->extradata && track->private_data && track->private_size > 0) + { + extradata = track->private_data; + extradata_size = track->private_size; } } |