net/gstptpclock: fix double free of domain data during deinit

The attempt to free the domain data is happeing twice during the ptp deinit.
Once while iterating through the list domain_data and second while iterating
through the list domain_clocks, so this is crashing the application
trying to gst_ptp_deinit

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6443>
This commit is contained in:
Taruntej Kanakamalla 2024-03-26 19:40:04 +05:30
parent 351936aeac
commit 6a67ae1bfa

View file

@ -382,6 +382,11 @@ typedef struct
GstClock *domain_clock; GstClock *domain_clock;
} PtpDomainData; } PtpDomainData;
// The lists domain_clocks and domain_data are same but the former is protected
// by the domain_clocks_lock.
// It is needed because sometimes other threads than the PTP thread will need
// to access the list, and without a mutex it might happen that the original
// list (domain_data) is modified at the same time (prepending a new domain).
static GList *domain_data; static GList *domain_data;
static GMutex domain_clocks_lock; static GMutex domain_clocks_lock;
static GList *domain_clocks; static GList *domain_clocks;
@ -3050,7 +3055,8 @@ gst_ptp_deinit (void)
} }
g_list_free (domain_data); g_list_free (domain_data);
domain_data = NULL; domain_data = NULL;
g_list_foreach (domain_clocks, (GFunc) g_free, NULL); // The domain_clocks list is same as domain_data
// and the elements are freed above already
g_list_free (domain_clocks); g_list_free (domain_clocks);
domain_clocks = NULL; domain_clocks = NULL;