summaryrefslogtreecommitdiff
path: root/win32
diff options
context:
space:
mode:
authorGurusamy Sarathy <gsar@cpan.org>1997-12-24 04:21:30 +0000
committerGurusamy Sarathy <gsar@cpan.org>1997-12-24 04:21:30 +0000
commitf998180f71571d04f7a71972eb8eb78805338f5c (patch)
treeb8dfd588a195e6aacb01d3878a7f08d2d94b4153 /win32
parente34ffe5a86599b66240875a414d90fdf19ed7649 (diff)
downloadperl-f998180f71571d04f7a71972eb8eb78805338f5c.tar.gz
[win32] support ioctl() on sockets (does what ioctlsocket() does) to make
non-blocking IO on sockets possible p4raw-id: //depot/win32/perl@387
Diffstat (limited to 'win32')
-rw-r--r--win32/makedef.pl1
-rw-r--r--win32/win32.c9
-rw-r--r--win32/win32iop.h3
-rw-r--r--win32/win32sck.c24
4 files changed, 27 insertions, 10 deletions
diff --git a/win32/makedef.pl b/win32/makedef.pl
index 766a4266f4..27bcf95295 100644
--- a/win32/makedef.pl
+++ b/win32/makedef.pl
@@ -507,6 +507,7 @@ win32_times
win32_alarm
win32_open_osfhandle
win32_get_osfhandle
+win32_ioctl
Perl_win32_init
Perl_init_os_extras
Perl_getTHR
diff --git a/win32/win32.c b/win32/win32.c
index bdfb3e2984..8f96611c5a 100644
--- a/win32/win32.c
+++ b/win32/win32.c
@@ -610,15 +610,6 @@ kill(int pid, int sig)
* File system stuff
*/
-#if 0
-int
-ioctl(int i, unsigned int u, char *data)
-{
- croak("ioctl not implemented!\n");
- return -1;
-}
-#endif
-
DllExport unsigned int
win32_sleep(unsigned int t)
{
diff --git a/win32/win32iop.h b/win32/win32iop.h
index d565cb51e0..5e03f952f2 100644
--- a/win32/win32iop.h
+++ b/win32/win32iop.h
@@ -114,6 +114,7 @@ DllExport int win32_times(struct tms *timebuf);
DllExport unsigned win32_alarm(unsigned int sec);
DllExport int win32_flock(int fd, int oper);
DllExport int win32_stat(const char *path, struct stat *buf);
+DllExport int win32_ioctl(int i, unsigned int u, char *data);
#ifdef HAVE_DES_FCRYPT
DllExport char * win32_crypt(const char *txt, const char *salt);
@@ -138,6 +139,7 @@ END_EXTERN_C
#undef sleep
#undef times
#undef alarm
+#undef ioctl
#ifdef __BORLANDC__
#undef ungetc
@@ -236,6 +238,7 @@ END_EXTERN_C
#define sleep win32_sleep
#define times win32_times
#define alarm win32_alarm
+#define ioctl win32_ioctl
#ifdef HAVE_DES_FCRYPT
#undef crypt
diff --git a/win32/win32sck.c b/win32/win32sck.c
index 64d1a0a65c..a6e7a990b8 100644
--- a/win32/win32sck.c
+++ b/win32/win32sck.c
@@ -223,7 +223,7 @@ win32_getsockopt(SOCKET s, int level, int optname, char *optval, int *optlen)
return r;
}
-int
+DllExport int
win32_ioctlsocket(SOCKET s, long cmd, u_long *argp)
{
int r;
@@ -466,6 +466,28 @@ win32_getservbyport(int port, const char *proto)
return r;
}
+int
+win32_ioctl(int i, unsigned int u, char *data)
+{
+ u_long argp = (u_long)data;
+ int retval;
+
+ if (!wsock_started) {
+ croak("ioctl implemented only on sockets");
+ /* NOTREACHED */
+ }
+
+ retval = ioctlsocket(TO_SOCKET(i), (long)u, &argp);
+ if (retval == SOCKET_ERROR) {
+ if (WSAGetLastError() == WSAENOTSOCK) {
+ croak("ioctl implemented only on sockets");
+ /* NOTREACHED */
+ }
+ errno = WSAGetLastError();
+ }
+ return retval;
+}
+
char FAR *
win32_inet_ntoa(struct in_addr in)
{