summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--winsup/cygwin/ChangeLog19
-rw-r--r--winsup/cygwin/fhandler.cc1
-rw-r--r--winsup/cygwin/fhandler_fifo.cc13
-rw-r--r--winsup/cygwin/include/cygwin/version.h5
-rw-r--r--winsup/cygwin/pipe.cc2
5 files changed, 32 insertions, 8 deletions
diff --git a/winsup/cygwin/ChangeLog b/winsup/cygwin/ChangeLog
index 3154f2904..a807e6040 100644
--- a/winsup/cygwin/ChangeLog
+++ b/winsup/cygwin/ChangeLog
@@ -1,3 +1,22 @@
+2005-04-16 Christopher Faylor <cgf@timesys.com>
+
+ * fhandler.cc (fhandler::dup): Duplicate flags, too.
+ * fhandler.h (fhandler_fifo::owner): Eliminate.
+ * fhandler_disk_file.cc (fhandler_base::fstat_fs): Handle on-disk
+ devices better.
+ (fhandler_base::fstat_helper): Ditto.
+ * fhandler_fifo.cc (fhandler_fifo::fhandler_fifo): Don't initialize
+ obsolete "owner".
+ (fhandler_fifo::open_not_mine): Add some debugging. Duplicate correct
+ handle when we own it.
+ (fhandler_fifo::open): Set flags from input, not from first pipe. Flag
+ that fork fixup is needed.
+ (fhandler_fifo::dup): Set errno correctly when DuplicateHandle fails.
+ * pinfo.cc (commune_send): Add debugging for fifo.
+
+ * cygwin/version.h: Bump API minor version to 127 to reflect exporting
+ of sigrelese.
+
2005-04-14 Kazuhiro Fujieda <fujieda@jaist.ac.jp>
* syscalls.cc (setuid32): Correct debugging output.
diff --git a/winsup/cygwin/fhandler.cc b/winsup/cygwin/fhandler.cc
index b21b973a4..d84aeb55a 100644
--- a/winsup/cygwin/fhandler.cc
+++ b/winsup/cygwin/fhandler.cc
@@ -1284,6 +1284,7 @@ fhandler_base::dup (fhandler_base *child)
VerifyHandle (nh);
child->set_io_handle (nh);
}
+ set_flags (child->get_flags ());
return 0;
}
diff --git a/winsup/cygwin/fhandler_fifo.cc b/winsup/cygwin/fhandler_fifo.cc
index 6026deff8..5431f1005 100644
--- a/winsup/cygwin/fhandler_fifo.cc
+++ b/winsup/cygwin/fhandler_fifo.cc
@@ -1,6 +1,6 @@
-/* fhandler_fifo.cc. See fhandler.h for a description of the fhandler classes.
+/* fhandler_fifo.cc - See fhandler.h for a description of the fhandler classes.
- Copyright 2002, 2003, 2004 Red Hat, Inc.
+ Copyright 2002, 2003, 2004, 2005 Red Hat, Inc.
This file is part of Cygwin.
@@ -23,7 +23,7 @@
#include "pinfo.h"
fhandler_fifo::fhandler_fifo ()
- : fhandler_pipe (), output_handle (NULL), owner (NULL),
+ : fhandler_pipe (), output_handle (NULL),
read_use (0), write_use (0)
{
}
@@ -85,6 +85,8 @@ fhandler_fifo::open_not_mine (int flags)
r = p->commune_send (PICOM_FIFO, get_win32_name ());
if (r.handles[0] == NULL)
continue; // process doesn't own fifo
+ debug_printf ("pid %d, handles[0] %p, handles[1] %p", p->pid,
+ r.handles[0], r.handles[1]);
}
else
{
@@ -162,6 +164,7 @@ fhandler_fifo::open (int flags, mode_t)
delete (fhs[0]);
delete (fhs[1]);
set_use (1);
+ need_fork_fixup (true);
}
out:
@@ -170,17 +173,17 @@ out:
}
int
-fhandler_fifo::dup (fhandler_base * child)
+fhandler_fifo::dup (fhandler_base *child)
{
int res = fhandler_pipe::dup (child);
if (!res)
{
fhandler_fifo *ff = (fhandler_fifo *) child;
-
if (!DuplicateHandle (hMainProc, get_output_handle (), hMainProc,
&ff->get_output_handle (), false, true,
DUPLICATE_SAME_ACCESS))
{
+ __seterrno ();
child->close ();
res = -1;
}
diff --git a/winsup/cygwin/include/cygwin/version.h b/winsup/cygwin/include/cygwin/version.h
index 3bc96286e..680bb0bba 100644
--- a/winsup/cygwin/include/cygwin/version.h
+++ b/winsup/cygwin/include/cygwin/version.h
@@ -252,13 +252,14 @@ details. */
123: Export utmpxname.
124: Add MAP_AUTOGROW flag to mmap.
125: LD_PRELOAD/CW_HOOK available.
- 126: Add lsearch, lfind, timer_gettime.
+ 126: Export lsearch, lfind, timer_gettime.
+ 127: Export sigrelese.
*/
/* Note that we forgot to bump the api for ualarm, strtoll, strtoull */
#define CYGWIN_VERSION_API_MAJOR 0
-#define CYGWIN_VERSION_API_MINOR 126
+#define CYGWIN_VERSION_API_MINOR 127
/* There is also a compatibity version number associated with the
shared memory regions. It is incremented when incompatible
diff --git a/winsup/cygwin/pipe.cc b/winsup/cygwin/pipe.cc
index 4bdb1e8c1..aed84e08d 100644
--- a/winsup/cygwin/pipe.cc
+++ b/winsup/cygwin/pipe.cc
@@ -237,6 +237,7 @@ fhandler_pipe::fixup_after_exec ()
void
fhandler_pipe::fixup_after_fork (HANDLE parent)
{
+debug_printf ("here");
fhandler_base::fixup_after_fork (parent);
if (guard)
fork_fixup (parent, guard, "guard");
@@ -259,7 +260,6 @@ fhandler_pipe::dup (fhandler_base *child)
goto err;
}
- /* FIXME: This leaks handles in the failing condition */
if (guard == NULL)
ftp->guard = NULL;
else if (!DuplicateHandle (hMainProc, guard, hMainProc, &ftp->guard, 0, 1,