diff options
author | Derek Foreman <derekf@osg.samsung.com> | 2015-05-26 16:21:05 -0500 |
---|---|---|
committer | Bryce Harrington <bryce@osg.samsung.com> | 2015-07-17 19:02:28 -0700 |
commit | d8156e22f6277cf6875c48f566076b61cdb01806 (patch) | |
tree | bf2def58ad17aca5a3f3d65f4928dcab2e11544d /desktop-shell | |
parent | daf846e4ea475ad25ba06e59041ced1b8b9bad49 (diff) |
exposay: Fix use after free when a view is destroyed during animation
Moving the destroy listener setup allows the animation completion handler
to be called before we free any structures it needs.
Signed-off-by: Derek Foreman <derekf@osg.samsung.com>
Diffstat (limited to 'desktop-shell')
-rw-r--r-- | desktop-shell/exposay.c | 12 |
1 files changed, 9 insertions, 3 deletions
diff --git a/desktop-shell/exposay.c b/desktop-shell/exposay.c index 190dd0c0..3d5d0c33 100644 --- a/desktop-shell/exposay.c +++ b/desktop-shell/exposay.c @@ -296,9 +296,6 @@ exposay_layout(struct desktop_shell *shell, struct shell_output *shell_output) esurface->eoutput = eoutput; esurface->view = view; - esurface->view_destroy_listener.notify = handle_view_destroy; - wl_signal_add(&view->destroy_signal, &esurface->view_destroy_listener); - esurface->row = i / eoutput->grid_size; esurface->column = i % eoutput->grid_size; @@ -322,6 +319,15 @@ exposay_layout(struct desktop_shell *shell, struct shell_output *shell_output) exposay_animate_in(esurface); + /* We want our destroy handler to be after the animation + * destroy handler in the list, this way when the view is + * destroyed, the animation can safely call the animation + * completion callback before we free the esurface in our + * destroy handler. + */ + esurface->view_destroy_listener.notify = handle_view_destroy; + wl_signal_add(&view->destroy_signal, &esurface->view_destroy_listener); + i++; } |