diff options
author | Christopher Faylor <me@cgf.cx> | 2011-04-21 04:53:55 +0400 |
---|---|---|
committer | Christopher Faylor <me@cgf.cx> | 2011-04-21 04:53:55 +0400 |
commit | 71c17c540231c3b824474431f2be0bd5ce63005f (patch) | |
tree | 29ddf6d9c57e712238eaca5629fb5524ab24c17b /winsup/cygwin/fhandler_termios.cc | |
parent | 2f9c27131fc48d8364e0ef16332cf6e6402c4fdd (diff) |
* cygheap.cc (init_cygheap::close_ctty): Avoid closing console-cttys since they
don't use archetypes and this will just result in double frees.
* dll_init.cc (dll_list::protect): Define.
(dll_list::alloc): Guard list access.
(dll_list::detach): Ditto.
* dll_init.h (dll_list::protect): Declare new muto.
(dll_list::guard): Define/declare function to guard list access.
* fhandler_termios.cc (fhandler_termios::sigflush): Avoid SEGV in pathological
condition of get_ttyp() == NULL.
Diffstat (limited to 'winsup/cygwin/fhandler_termios.cc')
-rw-r--r-- | winsup/cygwin/fhandler_termios.cc | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/winsup/cygwin/fhandler_termios.cc b/winsup/cygwin/fhandler_termios.cc index bdfce4642..80131a796 100644 --- a/winsup/cygwin/fhandler_termios.cc +++ b/winsup/cygwin/fhandler_termios.cc @@ -371,6 +371,9 @@ fhandler_termios::lseek (_off64_t, int) void fhandler_termios::sigflush () { - if (!(get_ttyp ()->ti.c_lflag & NOFLSH)) + /* FIXME: Checking get_ttyp() for NULL is not right since it should not + be NULL while this is alive. However, we can conceivably close a + ctty while exiting and that will zero this. */ + if (get_ttyp () && !(get_ttyp ()->ti.c_lflag & NOFLSH)) tcflush (TCIFLUSH); } |