mirror of
https://github.com/gnif/LookingGlass.git
synced 2025-01-25 12:58:10 +00:00
[client] overlay/graphs: allow unregistering after shutdown
The Wayland display server has a graph for presentation times, but the backend shuts down after the overlays, so calling overlayGraph_unregister causes memory corruption. We can avoid this problem by making unregister a noop after all graphs have been freed. This is safe because updating the graph doesn't use the graph handle: instead you update the ringbuffer which is owned by the user.
This commit is contained in:
parent
fba7c80b2f
commit
712b1cbc46
1 changed files with 4 additions and 0 deletions
|
@ -89,6 +89,7 @@ static void graphs_free(void * udata)
|
||||||
while(ll_shift(gs.graphs, (void **)&graph))
|
while(ll_shift(gs.graphs, (void **)&graph))
|
||||||
free(graph);
|
free(graph);
|
||||||
ll_free(gs.graphs);
|
ll_free(gs.graphs);
|
||||||
|
gs.graphs = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
struct BufferMetrics
|
struct BufferMetrics
|
||||||
|
@ -239,6 +240,9 @@ GraphHandle overlayGraph_register(const char * name, RingBuffer buffer,
|
||||||
|
|
||||||
void overlayGraph_unregister(GraphHandle handle)
|
void overlayGraph_unregister(GraphHandle handle)
|
||||||
{
|
{
|
||||||
|
if (!gs.graphs)
|
||||||
|
return;
|
||||||
|
|
||||||
ll_removeData(gs.graphs, handle);
|
ll_removeData(gs.graphs, handle);
|
||||||
free(handle);
|
free(handle);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue