diff options
-rw-r--r-- | gst/videoparsers/gsth265parse.c | 26 |
1 files changed, 13 insertions, 13 deletions
diff --git a/gst/videoparsers/gsth265parse.c b/gst/videoparsers/gsth265parse.c index 269726836..9a98dcc76 100644 --- a/gst/videoparsers/gsth265parse.c +++ b/gst/videoparsers/gsth265parse.c @@ -1335,6 +1335,19 @@ gst_h265_parse_update_src_caps (GstH265Parse * h265parse, GstCaps * caps) par_n, par_d, NULL); } + /* set profile and level in caps */ + if (sps) { + GstMapInfo map; + GstBuffer *sps_buf = h265parse->sps_nals[sps->id]; + + if (sps_buf) { + gst_buffer_map (sps_buf, &map, GST_MAP_READ); + gst_codec_utils_h265_caps_set_level_tier_and_profile (caps, + map.data + 1, map.size - 1); + gst_buffer_unmap (sps_buf, &map); + } + } + src_caps = gst_pad_get_current_caps (GST_BASE_PARSE_SRC_PAD (h265parse)); if (src_caps @@ -1361,19 +1374,6 @@ gst_h265_parse_update_src_caps (GstH265Parse * h265parse, GstCaps * caps) gst_buffer_replace (&h265parse->codec_data, NULL); } - /* set profile and level in caps */ - if (sps) { - GstMapInfo map; - GstBuffer *sps_buf = h265parse->sps_nals[sps->id]; - - if (sps_buf) { - gst_buffer_map (sps_buf, &map, GST_MAP_READ); - gst_codec_utils_h265_caps_set_level_tier_and_profile (caps, - map.data + 1, map.size - 1); - gst_buffer_unmap (sps_buf, &map); - } - } - gst_pad_set_caps (GST_BASE_PARSE_SRC_PAD (h265parse), caps); } |