diff options
| author | Furkan Sahin <furkan-dev@proton.me> | 2020-12-28 21:36:12 +0000 |
|---|---|---|
| committer | Furkan Sahin <furkan-dev@proton.me> | 2020-12-28 21:36:12 +0000 |
| commit | 7b2aadfdb3ca75a77c45a8cc819e3c1e6819b73b (patch) | |
| tree | 392e7d3d11761e62bd82bd66da898e56160f345f | |
| parent | 07fc2a78fd7ab5a09eb8e5d0b285c5b2928c5635 (diff) | |
input/seat: Reset command handler context in seat_destroy()
This fixes a dangling reference which causes a use-after-free.
| -rw-r--r-- | sway/input/seat.c | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/sway/input/seat.c b/sway/input/seat.c index dbb69ba0..1f5865ee 100644 --- a/sway/input/seat.c +++ b/sway/input/seat.c @@ -15,6 +15,7 @@ #include "config.h" #include "list.h" #include "log.h" +#include "sway/config.h" #include "sway/desktop.h" #include "sway/input/cursor.h" #include "sway/input/input-manager.h" @@ -53,6 +54,9 @@ static void seat_node_destroy(struct sway_seat_node *seat_node) { } void seat_destroy(struct sway_seat *seat) { + if (seat == config->handler_context.seat) { + config->handler_context.seat = input_manager_get_default_seat(); + } struct sway_seat_device *seat_device, *next; wl_list_for_each_safe(seat_device, next, &seat->devices, link) { seat_device_destroy(seat_device); |
