* 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().
This commit is contained in:
Corinna Vinschen 2001-09-20 11:29:48 +00:00
parent f4e6b76a05
commit 8e54fb88f3
4 changed files with 37 additions and 2 deletions

View File

@ -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,

View File

@ -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

View File

@ -467,6 +467,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];

View File

@ -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);
}