mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-07 07:55:41 +00:00
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/6682>
This commit is contained in:
parent
ac835db179
commit
3efcfef4b5
6 changed files with 0 additions and 6 deletions
|
@ -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);
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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);
|
||||||
|
|
Loading…
Reference in a new issue