diff options
author | Christopher Faylor <me@cgf.cx> | 2007-07-07 17:00:33 +0000 |
---|---|---|
committer | Christopher Faylor <me@cgf.cx> | 2007-07-07 17:00:33 +0000 |
commit | d9c0e3ec35b3a087ea68f528967765c2ee6a0dca (patch) | |
tree | dfbb5b49470a1683e12a1579005f99d66feb588a /winsup/cygwin/fhandler.h | |
parent | dee55888399728d1b4652e1a369e0f62a77c1111 (diff) | |
download | newlib-d9c0e3ec35b3a087ea68f528967765c2ee6a0dca.zip newlib-d9c0e3ec35b3a087ea68f528967765c2ee6a0dca.tar.gz newlib-d9c0e3ec35b3a087ea68f528967765c2ee6a0dca.tar.bz2 |
Preliminary change to make fifos/pipes interruptible and fifos reliable.
* dtable.cc (dtable::find_fifo): Eliminate definition.
* dtable.h (dtable::find_fifo): Ditto for declaration.
* fhandler.cc (fhandler_base::raw_read): Remove pipe-specific stuff.
(fhandler_base::fhandler_base): Ditto.
(fhandler_base::close): Handle overlapped I/O structure if appropriate.
(fhandler_base::dup): Ditto.
(fhandler_base::fork_fixup): Ditto.
(fhandler_base::setup_overlapped): Define new function.
(fhandler_base::destroy_overlapped): Ditto.
(fhandler_base::wait_overlapped): Ditto.
(fhandler_base::read_overlapped): Ditto.
(fhandler_base::write_overlapped): Ditto.
* fhandler.h (fhandler_base::get_overlapped): Declare new function.
(fhandler_base::setup_overlapped): Ditto.
(fhandler_base::destroy_overlapped): Ditto.
(fhandler_base::wait_overlapped): Ditto.
(fhandler_base::read_overlapped): Ditto.
(fhandler_base::write_overlapped): Ditto.
(fhandler_base::get_guard): Eliminate.
(fhandler_pipe::*): Rework to eliminate most Win9x related cruft, removing many
variables and defining a new overlapped capability.
(fhandler_fifo::*): Ditto.
(fifo_state): Declare new enum.
* fhandler_fifo.cc (fhandler_fifo::fhandler_fifo): Remove old Win9x stuff.
Initialize overlapped handle to NULL.
(fhandler_fifo::set_use): Eliminate.
(fhandler_fifo::open_nonserver): Define.
(fhandler_fifo::open): Rework to use named pipes and overlapped I/O.
(fhandler_fifo::wait): Define new function to wait for named pipe connection.
(fhandler_fifo::read): Rework to use wait() and new overlapped I/O
functionality.
(fhandler_fifo::write): Ditto.
(fhandler_fifo::dup): Eliminate.
* pinfo.cc (commune_process): Remove fifo handling.
(_pinfo::commune_request): Ditto.
* pinfo.h (picom): Ditto.
* pipe.cc (fhandler_pipe::fhandler_pipe): Remove Win9x stuff. Initialize
overlapped handle to NULL.
(fhandler_pipe::open): Eliminate Win9x stuff.
(fhandler_pipe::set_close_on_exec): Eliminate.
(read_pipe): Eliminate.
(fhandler_pipe::close): Ditto.
(fhandler_pipe::fixup_after_exec): Ditto.
(fhandler_pipe::fixup_in_child): Ditto.
(fhandler_pipe::read): Rework to use overlapped I/O.
(fhandler_pipe::write): New function using overlapped I/O.
(fhandler_pipe::dup): Rework to eliminate Win9x stuff.
(fhandler_pipe::create_selectable): Rework to eliminate Win9x and use
overlapped I/O.
* select.cc (peek_pipe): Rework to eliminate Win9x stuff and use overlapped
I/O.
(fhandler_base::ready_for_read): Ditto.
Diffstat (limited to 'winsup/cygwin/fhandler.h')
-rw-r--r-- | winsup/cygwin/fhandler.h | 62 |
1 files changed, 26 insertions, 36 deletions
diff --git a/winsup/cygwin/fhandler.h b/winsup/cygwin/fhandler.h index b41838c..5a5837e 100644 --- a/winsup/cygwin/fhandler.h +++ b/winsup/cygwin/fhandler.h @@ -141,6 +141,9 @@ class fhandler_base DWORD fs_flags; HANDLE read_state; path_conv pc; + bool wait_overlapped (bool&, bool) __attribute__ ((regparm (2))); + bool setup_overlapped () __attribute__ ((regparm (1))); + void destroy_overlapped () __attribute__ ((regparm (1))); public: class fhandler_base *archetype; @@ -294,7 +297,9 @@ class fhandler_base virtual int fcntl (int cmd, void *); virtual char const *ttyname () { return get_name (); } virtual void __stdcall read (void *ptr, size_t& len) __attribute__ ((regparm (3))); - virtual int write (const void *ptr, size_t len); + virtual void __stdcall read_overlapped (void *ptr, size_t& len) __attribute__ ((regparm (3))); + virtual int __stdcall write (const void *ptr, size_t len); + virtual int __stdcall write_overlapped (const void *ptr, size_t len); virtual ssize_t readv (const struct iovec *, int iovcnt, ssize_t tot = -1); virtual ssize_t writev (const struct iovec *, int iovcnt, ssize_t tot = -1); virtual ssize_t __stdcall pread (void *, size_t, _off64_t) __attribute__ ((regparm (3))); @@ -334,6 +339,7 @@ class fhandler_base virtual void raw_read (void *ptr, size_t& ulen); virtual int raw_write (const void *ptr, size_t ulen); + virtual OVERLAPPED *get_overlapped () {return NULL;} /* Virtual accessor functions to hide the fact that some fd's have two handles. */ @@ -356,7 +362,6 @@ class fhandler_base rabuf = NULL; } void operator delete (void *); - virtual HANDLE get_guard () const {return NULL;} virtual void set_eof () {} virtual int mkdir (mode_t mode); virtual int rmdir (); @@ -372,7 +377,6 @@ class fhandler_base bool issymlink () {return pc.issymlink ();} bool device_access_denied (int) __attribute__ ((regparm (2))); int fhaccess (int flags) __attribute__ ((regparm (2))); - friend class fhandler_fifo; }; class fhandler_mailslot : public fhandler_base @@ -521,13 +525,12 @@ class fhandler_socket: public fhandler_base class fhandler_pipe: public fhandler_base { -protected: - HANDLE guard; - bool broken_pipe; private: pid_t popen_pid; + OVERLAPPED io_status; public: fhandler_pipe (); + OVERLAPPED *get_overlapped () {return &io_status;} void set_popen_pid (pid_t pid) {popen_pid = pid;} pid_t get_popen_pid () const {return popen_pid;} _off64_t lseek (_off64_t offset, int whence); @@ -535,53 +538,40 @@ public: select_record *select_write (select_record *s); select_record *select_except (select_record *s); char *get_proc_fd_name (char *buf); - void set_close_on_exec (bool val); void __stdcall read (void *ptr, size_t& len) __attribute__ ((regparm (3))); + int __stdcall write (const void *, size_t); int open (int flags, mode_t mode = 0); - int close (); - void create_guard (SECURITY_ATTRIBUTES *sa) - { - guard = CreateMutex (sa, FALSE, NULL); - ProtectHandleINH (guard); - } int dup (fhandler_base *child); int ioctl (unsigned int cmd, void *); int __stdcall fstatvfs (struct statvfs *buf) __attribute__ ((regparm (2))); int __stdcall fadvise (_off64_t, _off64_t, int) __attribute__ ((regparm (3))); int __stdcall ftruncate (_off64_t, bool) __attribute__ ((regparm (3))); - void fixup_in_child (); - virtual void fixup_after_fork (HANDLE); - void fixup_after_exec (); - bool hit_eof () {return broken_pipe;} - void set_eof () {broken_pipe = true;} - HANDLE get_guard () const {return guard;} int ready_for_read (int fd, DWORD howlong); static int create (fhandler_pipe *[2], unsigned, int, bool = false); - bool is_slow () {return true;} static int create_selectable (LPSECURITY_ATTRIBUTES, HANDLE&, HANDLE&, DWORD, bool); - friend class fhandler_fifo; }; -class fhandler_fifo: public fhandler_pipe +enum fifo_state { - HANDLE output_handle; - long read_use; - long write_use; - virtual HANDLE& get_io_handle () { return io_handle ?: output_handle; } + fifo_unknown, + fifo_wait_for_client, + fifo_wait_for_server, + fifo_ok +}; +class fhandler_fifo: public fhandler_base +{ + fifo_state wait_state; + HANDLE open_nonserver (const char *, unsigned, LPSECURITY_ATTRIBUTES); + OVERLAPPED io_status; + bool wait (bool) __attribute__ ((regparm (1))); public: fhandler_fifo (); - int open (int flags, mode_t mode = 0); - int open_not_mine (int flags) __attribute__ ((regparm (2))); - int close (); - void set_use (int flags) __attribute__ ((regparm (2))); + void __stdcall read (void *, size_t&) __attribute__ ((regparm (3))); + int __stdcall write (const void *, size_t); + int open (int, mode_t); bool isfifo () { return true; } - HANDLE& get_output_handle () { return output_handle; } - void set_output_handle (HANDLE h) { output_handle = h; } - void set_use (); - int dup (fhandler_base *child); int __stdcall fstatvfs (struct statvfs *buf) __attribute__ ((regparm (2))); - bool is_slow () {return true;} - void close_one_end (); + OVERLAPPED *get_overlapped () {return &io_status;} }; class fhandler_dev_raw: public fhandler_base |