mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-11 01:45:33 +00:00
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:
parent
351936aeac
commit
6a67ae1bfa
1 changed files with 7 additions and 1 deletions
|
@ -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;
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue