scenechange: fix memory leak

A reference to the last buffer(oldbuf) was kept
leading to a memory leak on stop.

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/7666>
This commit is contained in:
Stéphane Cerveau 2024-10-14 15:31:54 +02:00 committed by GStreamer Marge Bot
parent d71dd64717
commit b736ac5bb4

View file

@ -60,7 +60,7 @@
* terms of accuracy, schro's implementation has about 2-3 false positives
* or false negatives per 100 scene changes. This implementation has
* about 5 per 100. The threshold is tuned for minimum total false
* positives or negatives, on the assumption that the badness of a
* positives or negatives, on the assumption that the badness of a
* false negative is the same as a false positive.
*
* This algorithm is pretty much at its limit for error rate. I
@ -92,6 +92,7 @@ GST_DEBUG_CATEGORY_STATIC (gst_scene_change_debug_category);
static GstFlowReturn gst_scene_change_transform_frame_ip (GstVideoFilter *
filter, GstVideoFrame * frame);
static gboolean gst_scenechange_stop (GstBaseTransform * base);
#undef TESTING
#ifdef TESTING
@ -119,6 +120,7 @@ static void
gst_scene_change_class_init (GstSceneChangeClass * klass)
{
GstVideoFilterClass *video_filter_class = GST_VIDEO_FILTER_CLASS (klass);
GstBaseTransformClass *trans_class = GST_BASE_TRANSFORM_CLASS (klass);
gst_element_class_add_pad_template (GST_ELEMENT_CLASS (klass),
gst_pad_template_new ("src", GST_PAD_SRC, GST_PAD_ALWAYS,
@ -135,6 +137,7 @@ gst_scene_change_class_init (GstSceneChangeClass * klass)
video_filter_class->transform_frame_ip =
GST_DEBUG_FUNCPTR (gst_scene_change_transform_frame_ip);
trans_class->stop = GST_DEBUG_FUNCPTR (gst_scenechange_stop);
}
static void
@ -142,7 +145,6 @@ gst_scene_change_init (GstSceneChange * scenechange)
{
}
static double
get_frame_score (GstVideoFrame * f1, GstVideoFrame * f2)
{
@ -259,10 +261,15 @@ gst_scene_change_transform_frame_ip (GstVideoFilter * filter,
return GST_FLOW_OK;
}
static gboolean
gst_scenechange_stop (GstBaseTransform * base)
{
GstSceneChange *scenechange = GST_SCENE_CHANGE (base);
gst_clear_buffer (&scenechange->oldbuf);
return TRUE;
}
#ifdef TESTING
/* This is from ds's personal collection. No, you can't have it. */