diff --git a/winsup/cygwin/ChangeLog b/winsup/cygwin/ChangeLog index 0abec830e..0d1e1878b 100644 --- a/winsup/cygwin/ChangeLog +++ b/winsup/cygwin/ChangeLog @@ -1,3 +1,9 @@ +2011-10-10 Christopher Faylor + + * syscalls.cc (open): Add temporary kludge to avoid assigning the + controlling tty on open unless the open is for stdin/stdout/stderr. + * tty.cc (tty_list::connect): Set ENXIO when can't find a tty. + 2011-10-10 Corinna Vinschen * fhandler.h (fhandler_process::closedir): Declare. diff --git a/winsup/cygwin/syscalls.cc b/winsup/cygwin/syscalls.cc index 54d75d0e9..162825442 100644 --- a/winsup/cygwin/syscalls.cc +++ b/winsup/cygwin/syscalls.cc @@ -1130,6 +1130,12 @@ open (const char *unix_path, int flags, ...) if (fd >= 0) { + /* This is a temporary kludge until all utilities can catch up with + a change in behavior that implements linux functionality: opening + a tty should not automatically cause it to become the controlling + tty for the process. */ + if (fd > 2) + flags |= O_NOCTTY; if (!(fh = build_fh_name (unix_path, (flags & (O_NOFOLLOW | O_EXCL)) ? PC_SYM_NOFOLLOW : PC_SYM_FOLLOW, diff --git a/winsup/cygwin/tty.cc b/winsup/cygwin/tty.cc index e751d30c2..30879b0e3 100644 --- a/winsup/cygwin/tty.cc +++ b/winsup/cygwin/tty.cc @@ -103,6 +103,7 @@ tty_list::connect (int ttynum) if (!ttys[ttynum].exists ()) { termios_printf ("tty %d was not allocated", ttynum); + set_errno (ENXIO); return -1; }