aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorZhao Zhili <zhilizhao@tencent.com>2023-06-13 15:37:17 +0800
committerZhao Zhili <zhilizhao@tencent.com>2023-07-04 04:49:48 +0800
commit3eb7968ed98229e3b44a91b89c7cd5512643b182 (patch)
treee316b2705b0f81522b0b70f1efe5cae20cc06c42
parentbdb4b64f16b75c4d4cd88c0755aa6111cadaa602 (diff)
downloadffmpeg-3eb7968ed98229e3b44a91b89c7cd5512643b182.tar.gz
avformat/asfdec_f: support bmp_tags_unofficial
Signed-off-by: Zhao Zhili <zhilizhao@tencent.com>
-rw-r--r--libavformat/asfdec_f.c4
1 files changed, 4 insertions, 0 deletions
diff --git a/libavformat/asfdec_f.c b/libavformat/asfdec_f.c
index bdbd4271c8..1e3eb33fd6 100644
--- a/libavformat/asfdec_f.c
+++ b/libavformat/asfdec_f.c
@@ -445,6 +445,8 @@ static int asf_read_stream_properties(AVFormatContext *s, int64_t size)
st->codecpar->codec_tag = tag1;
st->codecpar->codec_id = ff_codec_get_id(ff_codec_bmp_tags, tag1);
+ if (!st->codecpar->codec_id)
+ st->codecpar->codec_id = ff_codec_get_id(ff_codec_bmp_tags_unofficial, tag1);
if (tag1 == MKTAG('D', 'V', 'R', ' ')) {
sti->need_parsing = AVSTREAM_PARSE_FULL;
/* issue658 contains wrong w/h and MS even puts a fake seq header
@@ -459,6 +461,8 @@ static int asf_read_stream_properties(AVFormatContext *s, int64_t size)
sti->need_parsing = AVSTREAM_PARSE_FULL_ONCE;
if (st->codecpar->codec_id == AV_CODEC_ID_MPEG4)
sti->need_parsing = AVSTREAM_PARSE_FULL_ONCE;
+ if (st->codecpar->codec_id == AV_CODEC_ID_HEVC)
+ sti->need_parsing = AVSTREAM_PARSE_FULL;
}
pos2 = avio_tell(pb);
avio_skip(pb, size - (pos2 - pos1 + 24));