v4l2codecs: Don't unref allocation query caps

The caps obtained from parsing the allocation query is borrowed and
should not be unreffed. This fixes criticals assertion introduced in
1.24.1.

(gst-launch-1.0:242): GStreamer-CRITICAL **: 19:48:02.667:
    gst_mini_object_unref: assertion 'GST_MINI_OBJECT_REFCOUNT_VALUE (mini_object) > 0' failed

Fixes: 5189e8b956 ("v4l2codecs: decoders: Add DMA_DRM caps support")
Closes #3462

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6679>
This commit is contained in:
Nicolas Dufresne 2024-04-17 16:55:31 -04:00 committed by GStreamer Marge Bot
parent a342d14ba9
commit e34f765a7e
6 changed files with 0 additions and 6 deletions

View file

@ -409,7 +409,6 @@ gst_v4l2_codec_av1_dec_decide_allocation (GstVideoDecoder * decoder,
"DMABuf caps negotiated without the mandatory support of VideoMeta"); "DMABuf caps negotiated without the mandatory support of VideoMeta");
return FALSE; return FALSE;
} }
gst_caps_unref (caps);
if (gst_query_get_n_allocation_pools (query) > 0) if (gst_query_get_n_allocation_pools (query) > 0)
gst_query_parse_nth_allocation_pool (query, 0, NULL, NULL, &min, NULL); gst_query_parse_nth_allocation_pool (query, 0, NULL, NULL, &min, NULL);

View file

@ -454,7 +454,6 @@ gst_v4l2_codec_h264_dec_decide_allocation (GstVideoDecoder * decoder,
"DMABuf caps negotiated without the mandatory support of VideoMeta"); "DMABuf caps negotiated without the mandatory support of VideoMeta");
return FALSE; return FALSE;
} }
gst_caps_unref (caps);
if (gst_query_get_n_allocation_pools (query) > 0) if (gst_query_get_n_allocation_pools (query) > 0)
gst_query_parse_nth_allocation_pool (query, 0, NULL, NULL, &min, NULL); gst_query_parse_nth_allocation_pool (query, 0, NULL, NULL, &min, NULL);

View file

@ -483,7 +483,6 @@ gst_v4l2_codec_h265_dec_decide_allocation (GstVideoDecoder * decoder,
"DMABuf caps negotiated without the mandatory support of VideoMeta"); "DMABuf caps negotiated without the mandatory support of VideoMeta");
return FALSE; return FALSE;
} }
gst_caps_unref (caps);
if (gst_query_get_n_allocation_pools (query) > 0) if (gst_query_get_n_allocation_pools (query) > 0)
gst_query_parse_nth_allocation_pool (query, 0, NULL, NULL, &min, NULL); gst_query_parse_nth_allocation_pool (query, 0, NULL, NULL, &min, NULL);

View file

@ -376,7 +376,6 @@ gst_v4l2_codec_mpeg2_dec_decide_allocation (GstVideoDecoder * decoder,
"DMABuf caps negotiated without the mandatory support of VideoMeta"); "DMABuf caps negotiated without the mandatory support of VideoMeta");
return FALSE; return FALSE;
} }
gst_caps_unref (caps);
if (gst_query_get_n_allocation_pools (query) > 0) if (gst_query_get_n_allocation_pools (query) > 0)
gst_query_parse_nth_allocation_pool (query, 0, NULL, NULL, &min, NULL); gst_query_parse_nth_allocation_pool (query, 0, NULL, NULL, &min, NULL);

View file

@ -320,7 +320,6 @@ gst_v4l2_codec_vp8_dec_decide_allocation (GstVideoDecoder * decoder,
"DMABuf caps negotiated without the mandatory support of VideoMeta"); "DMABuf caps negotiated without the mandatory support of VideoMeta");
return FALSE; return FALSE;
} }
gst_caps_unref (caps);
if (gst_query_get_n_allocation_pools (query) > 0) if (gst_query_get_n_allocation_pools (query) > 0)
gst_query_parse_nth_allocation_pool (query, 0, NULL, NULL, &min, NULL); gst_query_parse_nth_allocation_pool (query, 0, NULL, NULL, &min, NULL);

View file

@ -593,7 +593,6 @@ gst_v4l2_codec_vp9_dec_decide_allocation (GstVideoDecoder * decoder,
"DMABuf caps negotiated without the mandatory support of VideoMeta"); "DMABuf caps negotiated without the mandatory support of VideoMeta");
return FALSE; return FALSE;
} }
gst_caps_unref (caps);
if (gst_query_get_n_allocation_pools (query) > 0) if (gst_query_get_n_allocation_pools (query) > 0)
gst_query_parse_nth_allocation_pool (query, 0, NULL, NULL, &min, NULL); gst_query_parse_nth_allocation_pool (query, 0, NULL, NULL, &min, NULL);