diff options
author | Corinna Vinschen <corinna@vinschen.de> | 2001-09-20 11:29:48 +0000 |
---|---|---|
committer | Corinna Vinschen <corinna@vinschen.de> | 2001-09-20 11:29:48 +0000 |
commit | 8e54fb88f368b4f582d2f40b42056d730dd229bc (patch) | |
tree | 6e22b77d8a61dfd723c61adf3d9fa233bccc8f01 /winsup | |
parent | f4e6b76a05b9e0a0c851b0473eb51285028e3e41 (diff) | |
download | newlib-8e54fb88f368b4f582d2f40b42056d730dd229bc.zip newlib-8e54fb88f368b4f582d2f40b42056d730dd229bc.tar.gz newlib-8e54fb88f368b4f582d2f40b42056d730dd229bc.tar.bz2 |
* fhandler.h (fhandler_socket::fixup_after_exec): Remove inline
implementation.
(fhandler_dev_raw::fixup_after_exec): Ditto.
* fhandler_raw.cc (fhandler_dev_raw::fixup_after_fork): Don't
duplicate buffer on fork to avoid memory leak.
(fhandler_dev_raw::fixup_after_exec): New implementation equal to
former fixup_after_fork() implementation.
* fhandler_socket.cc (fhandler_socket::fixup_after_fork): Do
nothing when not using Winsock2.
(fhandler_socket::fixup_after_exec): New implementation.
(fhandler_socket::set_close_on_exec): Never call set_inheritance().
Diffstat (limited to 'winsup')
-rw-r--r-- | winsup/cygwin/ChangeLog | 14 | ||||
-rw-r--r-- | winsup/cygwin/fhandler.h | 4 | ||||
-rw-r--r-- | winsup/cygwin/fhandler_raw.cc | 8 | ||||
-rw-r--r-- | winsup/cygwin/fhandler_socket.cc | 13 |
4 files changed, 37 insertions, 2 deletions
diff --git a/winsup/cygwin/ChangeLog b/winsup/cygwin/ChangeLog index 342b152..0c09beb 100644 --- a/winsup/cygwin/ChangeLog +++ b/winsup/cygwin/ChangeLog @@ -1,3 +1,17 @@ +Thu Sep 20 13:20:00 2001 Corinna Vinschen <corinna@vinschen.de> + + * fhandler.h (fhandler_socket::fixup_after_exec): Remove inline + implementation. + (fhandler_dev_raw::fixup_after_exec): Ditto. + * fhandler_raw.cc (fhandler_dev_raw::fixup_after_fork): Don't + duplicate buffer on fork to avoid memory leak. + (fhandler_dev_raw::fixup_after_exec): New implementation equal to + former fixup_after_fork() implementation. + * fhandler_socket.cc (fhandler_socket::fixup_after_fork): Do + nothing when not using Winsock2. + (fhandler_socket::fixup_after_exec): New implementation. + (fhandler_socket::set_close_on_exec): Never call set_inheritance(). + Thu Sep 20 9:55:00 2001 Corinna Vinschen <corinna@vinschen.de> * fhandler.cc (fhandler_base::set_inheritance): If available, diff --git a/winsup/cygwin/fhandler.h b/winsup/cygwin/fhandler.h index 1f6f839..1ab1557 100644 --- a/winsup/cygwin/fhandler.h +++ b/winsup/cygwin/fhandler.h @@ -418,7 +418,7 @@ public: void set_close_on_exec (int val); virtual void fixup_before_fork_exec (DWORD); void fixup_after_fork (HANDLE); - void fixup_after_exec (HANDLE parent) { fixup_after_fork (parent); } + void fixup_after_exec (HANDLE); select_record *select_read (select_record *s); select_record *select_write (select_record *s); @@ -490,7 +490,7 @@ public: int ioctl (unsigned int cmd, void *buf); void fixup_after_fork (HANDLE); - void fixup_after_exec (HANDLE parent) { fixup_after_fork (parent); } + void fixup_after_exec (HANDLE); }; class fhandler_dev_floppy: public fhandler_dev_raw diff --git a/winsup/cygwin/fhandler_raw.cc b/winsup/cygwin/fhandler_raw.cc index a5befb6..7ed439b 100644 --- a/winsup/cygwin/fhandler_raw.cc +++ b/winsup/cygwin/fhandler_raw.cc @@ -468,6 +468,14 @@ fhandler_dev_raw::dup (fhandler_base *child) void fhandler_dev_raw::fixup_after_fork (HANDLE) { + devbufstart = 0; + devbufend = 0; + lastblk_to_read = 0; +} + +void +fhandler_dev_raw::fixup_after_exec (HANDLE) +{ if (devbufsiz > 1L) devbuf = new char [devbufsiz]; devbufstart = 0; diff --git a/winsup/cygwin/fhandler_socket.cc b/winsup/cygwin/fhandler_socket.cc index 9e019f9..dc76d0e 100644 --- a/winsup/cygwin/fhandler_socket.cc +++ b/winsup/cygwin/fhandler_socket.cc @@ -202,13 +202,24 @@ fhandler_socket::fixup_after_fork (HANDLE parent) } else { +#if 0 fhandler_base::fixup_after_fork (parent); +#endif debug_printf ("Without Winsock 2.0"); } if (secret_event) fork_fixup (parent, secret_event, "secret_event"); } +void +fhandler_socket::fixup_after_exec (HANDLE parent) +{ + if (!get_close_on_exec ()) + fixup_after_fork (parent); + else + closesocket (get_socket ()); +} + int fhandler_socket::dup (fhandler_base *child) { @@ -447,9 +458,11 @@ fhandler_socket::fcntl (int cmd, void *arg) void fhandler_socket::set_close_on_exec (int val) { +#if 0 extern WSADATA wsadata; if (wsadata.wVersion < 512) /* < Winsock 2.0 */ set_inheritance (get_handle (), val); +#endif set_close_on_exec_flag (val); debug_printf ("set close_on_exec for %s to %d", get_name (), val); } |