aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPatrick Palka <patrick@parcs.ath.cx>2015-04-27 21:37:48 -0400
committerPatrick Palka <patrick@parcs.ath.cx>2015-05-13 11:53:28 -0400
commit1e04046d0b7e0f87bc6e2fefd966c9dd89d2ce13 (patch)
treefec0ac237bd87cc93603dc18cad9fac8704fcd7e
parent558e5469679897ee57ad6706074f55ff4952cf43 (diff)
downloadgdb-1e04046d0b7e0f87bc6e2fefd966c9dd89d2ce13.zip
gdb-1e04046d0b7e0f87bc6e2fefd966c9dd89d2ce13.tar.gz
gdb-1e04046d0b7e0f87bc6e2fefd966c9dd89d2ce13.tar.bz2
Avoid race condition when handling a SIGWINCH signal
The control variable win_resized must be cleared before responding to it. Otherwise there is a small window where another SIGWINCH might occur in between the handling of an earlier SIGWINCH and the clearing of win_resized, at which point win_resized would be set (again) by the signal handler. Shortly thereafter we would clear win_resized even though we only handled the earlier SIGWINCH but not the latest one. This chain of events is all avoided if we clear win_resized first. gdb/ChangeLog: * tui/tui-win.c (tui_async_resize_screen): Clear win_resized first before resizing the window. * tui.c (tui_enable): Likewise.
-rw-r--r--gdb/tui/tui-win.c2
-rw-r--r--gdb/tui/tui.c2
2 files changed, 2 insertions, 2 deletions
diff --git a/gdb/tui/tui-win.c b/gdb/tui/tui-win.c
index 683c0ed..8c0685b 100644
--- a/gdb/tui/tui-win.c
+++ b/gdb/tui/tui-win.c
@@ -858,10 +858,10 @@ tui_async_resize_screen (gdb_client_data arg)
}
else
{
+ tui_set_win_resized_to (FALSE);
tui_resize_all ();
tui_refresh_all_win ();
tui_update_gdb_sizes ();
- tui_set_win_resized_to (FALSE);
tui_redisplay_readline ();
}
}
diff --git a/gdb/tui/tui.c b/gdb/tui/tui.c
index 9fac06e..b04e106 100644
--- a/gdb/tui/tui.c
+++ b/gdb/tui/tui.c
@@ -492,8 +492,8 @@ tui_enable (void)
window. */
if (tui_win_resized ())
{
- tui_resize_all ();
tui_set_win_resized_to (FALSE);
+ tui_resize_all ();
}
if (deprecated_safe_get_selected_frame ())