diff options
author | Patrick Palka <patrick@parcs.ath.cx> | 2015-04-27 21:37:48 -0400 |
---|---|---|
committer | Patrick Palka <patrick@parcs.ath.cx> | 2015-05-13 11:53:28 -0400 |
commit | 1e04046d0b7e0f87bc6e2fefd966c9dd89d2ce13 (patch) | |
tree | fec0ac237bd87cc93603dc18cad9fac8704fcd7e | |
parent | 558e5469679897ee57ad6706074f55ff4952cf43 (diff) | |
download | gdb-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.c | 2 | ||||
-rw-r--r-- | gdb/tui/tui.c | 2 |
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 ()) |