diff options
author | Corinna Vinschen <corinna@vinschen.de> | 2002-01-06 09:28:13 +0000 |
---|---|---|
committer | Corinna Vinschen <corinna@vinschen.de> | 2002-01-06 09:28:13 +0000 |
commit | d6154fb758bddfc22abf303f5cb015b2c9fb4eeb (patch) | |
tree | 0d9496ce75979c99eb9ff34e1053b215d2be9f45 /winsup/cygwin/ioctl.cc | |
parent | 9125cbd7cf47b848390294897561c556a8d8b572 (diff) | |
download | cygnal-d6154fb758bddfc22abf303f5cb015b2c9fb4eeb.tar.gz cygnal-d6154fb758bddfc22abf303f5cb015b2c9fb4eeb.tar.bz2 cygnal-d6154fb758bddfc22abf303f5cb015b2c9fb4eeb.zip |
* ioctl.cc (ioctl): Make third argument optional.
* include/sys/ioctl.h: Ditto in declaration.
* dtable.cc (dtable::init_std_file_from_handle): Revert previous
bogus patch.
* window.cc (WndProc): Raise SIGURG instead of SIGIO in case of FD_OOB
message.
Diffstat (limited to 'winsup/cygwin/ioctl.cc')
-rw-r--r-- | winsup/cygwin/ioctl.cc | 18 |
1 files changed, 12 insertions, 6 deletions
diff --git a/winsup/cygwin/ioctl.cc b/winsup/cygwin/ioctl.cc index 98c157800..95986a6c0 100644 --- a/winsup/cygwin/ioctl.cc +++ b/winsup/cygwin/ioctl.cc @@ -23,25 +23,31 @@ details. */ #include <sys/termios.h> extern "C" int -ioctl (int fd, int cmd, void *buf) +ioctl (int fd, int cmd, ...) { cygheap_fdget cfd (fd); if (cfd < 0) return -1; + /* check for optional mode argument */ + va_list ap; + va_start (ap, cmd); + char *argp = va_arg (ap, char *); + va_end (ap); + debug_printf ("fd %d, cmd %x\n", fd, cmd); if (cfd->is_tty () && cfd->get_device () != FH_PTYM) switch (cmd) { case TCGETA: - return tcgetattr (fd, (struct termios *) buf); + return tcgetattr (fd, (struct termios *) argp); case TCSETA: - return tcsetattr (fd, TCSANOW, (struct termios *) buf); + return tcsetattr (fd, TCSANOW, (struct termios *) argp); case TCSETAW: - return tcsetattr (fd, TCSADRAIN, (struct termios *) buf); + return tcsetattr (fd, TCSADRAIN, (struct termios *) argp); case TCSETAF: - return tcsetattr (fd, TCSAFLUSH, (struct termios *) buf); + return tcsetattr (fd, TCSAFLUSH, (struct termios *) argp); } - return cfd->ioctl (cmd, buf); + return cfd->ioctl (cmd, argp); } |