]> Zhao Yanbai Git Server - minix.git/commitdiff
Add UDP support to getsockname(2) and getpeername(2). 73/1073/1
authorJan Wieck <janwieck@yahoo.com>
Sat, 26 Oct 2013 11:53:00 +0000 (11:53 +0000)
committerThomas Cort <tcort@minix3.org>
Sat, 26 Oct 2013 19:26:08 +0000 (15:26 -0400)
Change-Id: Ic035b961fb21a6fae75d3af87d714008ecedb874

lib/libc/sys-minix/getpeername.c
lib/libc/sys-minix/getsockname.c

index d0487248a9da6ee0347012274c962061b2f15aa9..38fb54ea1c8bc1e255d61e7945e9083fd8ba3fc3 100644 (file)
@@ -12,6 +12,7 @@
 #include <net/gen/tcp.h>
 #include <net/gen/tcp_io.h>
 #include <net/gen/udp.h>
+#include <net/gen/udp_io.h>
 #include <sys/un.h>
 
 #define DEBUG 0
@@ -19,6 +20,9 @@
 static int _tcp_getpeername(int sock, struct sockaddr *__restrict address,
        socklen_t *__restrict address_len, nwio_tcpconf_t *tcpconfp);
 
+static int _udp_getpeername(int sock, struct sockaddr *__restrict address,
+       socklen_t *__restrict address_len, nwio_udpopt_t *tcpconfp);
+
 static int _uds_getpeername(int sock, struct sockaddr *__restrict address,
        socklen_t *__restrict address_len, struct sockaddr_un *uds_addr);
 
@@ -27,6 +31,7 @@ int getpeername(int sock, struct sockaddr *__restrict address,
 {
        int r;
        nwio_tcpconf_t tcpconf;
+       nwio_udpopt_t udpopt;
        struct sockaddr_un uds_addr;
 
        r= ioctl(sock, NWIOGTCPCONF, &tcpconf);
@@ -41,6 +46,18 @@ int getpeername(int sock, struct sockaddr *__restrict address,
                        &tcpconf);
        }
 
+       r= ioctl(sock, NWIOGUDPOPT, &udpopt);
+       if (r != -1 || (errno != ENOTTY && errno != EBADIOCTL))
+       {
+               if (r == -1)
+               {
+                       /* Bad file descriptor */
+                       return -1;
+               }
+               return _udp_getpeername(sock, address, address_len,
+                       &udpopt);
+       }
+
        r= ioctl(sock, NWIOGUDSPADDR, &uds_addr);
        if (r != -1 || (errno != ENOTTY && errno != EBADIOCTL))
        {
@@ -88,6 +105,33 @@ static int _tcp_getpeername(int sock, struct sockaddr *__restrict address,
        return 0;
 }
 
+static int _udp_getpeername(int sock, struct sockaddr *__restrict address,
+       socklen_t *__restrict address_len, nwio_udpopt_t *udpopt)
+{
+       socklen_t len;
+       struct sockaddr_in sin;
+
+       if (udpopt->nwuo_remaddr == 0 ||
+               udpopt->nwuo_remport == 0)
+       {
+               errno= ENOTCONN;
+               return -1;
+       }
+
+       memset(&sin, '\0', sizeof(sin));
+       sin.sin_family= AF_INET;
+       sin.sin_addr.s_addr= udpopt->nwuo_remaddr;
+       sin.sin_port= udpopt->nwuo_remport;
+
+       len= *address_len;
+       if (len > sizeof(sin))
+               len= sizeof(sin);
+       memcpy(address, &sin, len);
+       *address_len= len;
+
+       return 0;
+}
+
 static int _uds_getpeername(int sock, struct sockaddr *__restrict address,
        socklen_t *__restrict address_len, struct sockaddr_un *uds_addr)
 {
index d6ea057877ca801a8b84051ec0c8ad1a1aaf645f..02e96df970a5f5af61baeef6b7e612ad713d07df 100644 (file)
@@ -19,6 +19,7 @@
 #include <net/gen/tcp.h>
 #include <net/gen/tcp_io.h>
 #include <net/gen/udp.h>
+#include <net/gen/udp_io.h>
 #include <sys/un.h>
 
 /*
@@ -28,6 +29,9 @@
 static int _tcp_getsockname(int fd, struct sockaddr *__restrict address,
    socklen_t *__restrict address_len, nwio_tcpconf_t *tcpconfp);
 
+static int _udp_getsockname(int fd, struct sockaddr *__restrict address,
+   socklen_t *__restrict address_len, nwio_udpopt_t *udpopt);
+
 static int _uds_getsockname(int fd, struct sockaddr *__restrict address,
    socklen_t *__restrict address_len, struct sockaddr_un *uds_addr);
 
@@ -36,6 +40,7 @@ int getsockname(int fd, struct sockaddr *__restrict address,
 {
        int r;
        nwio_tcpconf_t tcpconf;
+       nwio_udpopt_t udpopt;
        struct sockaddr_un uds_addr;
 
 #ifdef DEBUG
@@ -54,6 +59,18 @@ int getsockname(int fd, struct sockaddr *__restrict address,
                return _tcp_getsockname(fd, address, address_len, &tcpconf);
        }
 
+       r= ioctl(fd, NWIOGUDPOPT, &udpopt);
+       if (r != -1 || (errno != ENOTTY && errno != EBADIOCTL))
+       {
+               if (r == -1)
+               {
+                       /* Bad file descriptor */
+                       return -1;
+               }
+
+               return _udp_getsockname(fd, address, address_len, &udpopt);
+       }
+
        r= ioctl(fd, NWIOGUDSADDR, &uds_addr);
        if (r != -1 || (errno != ENOTTY && errno != EBADIOCTL))
        {
@@ -83,11 +100,11 @@ static int _tcp_getsockname(int fd, struct sockaddr *__restrict address,
 
 #ifdef DEBUG1
        fprintf(stderr, "mnx_getsockname: from %s, %u",
-                       inet_ntoa(tcpconf.nwtc_remaddr),
-                       ntohs(tcpconf.nwtc_remport));
+                       inet_ntoa(tcpconf->nwtc_remaddr),
+                       ntohs(tcpconf->nwtc_remport));
        fprintf(stderr," for %s, %u\n",
-                       inet_ntoa(tcpconf.nwtc_locaddr),
-                       ntohs(tcpconf.nwtc_locport));
+                       inet_ntoa(tcpconf->nwtc_locaddr),
+                       ntohs(tcpconf->nwtc_locport));
 #endif
 
        memset(&sin, '\0', sizeof(sin));
@@ -104,6 +121,35 @@ static int _tcp_getsockname(int fd, struct sockaddr *__restrict address,
        return 0;
 }
 
+static int _udp_getsockname(int fd, struct sockaddr *__restrict address,
+   socklen_t *__restrict address_len, nwio_udpopt_t *udpopt)
+{
+       socklen_t len;
+       struct sockaddr_in sin;
+
+#ifdef DEBUG1
+       fprintf(stderr, "mnx_getsockname: from %s, %u",
+                       inet_ntoa(udpopt->nwuo_remaddr),
+                       ntohs(udpopt->nwuo_remport));
+       fprintf(stderr," for %s, %u\n",
+                       inet_ntoa(udpopt->nwuo_locaddr),
+                       ntohs(udpopt->nwuo_locport));
+#endif
+
+       memset(&sin, '\0', sizeof(sin));
+       sin.sin_family= AF_INET;
+       sin.sin_addr.s_addr= udpopt->nwuo_locaddr ;
+       sin.sin_port= udpopt->nwuo_locport;
+
+       len= *address_len;
+       if (len > sizeof(sin))
+               len= sizeof(sin);
+       memcpy(address, &sin, len);
+       *address_len= len;
+
+       return 0;
+}
+
 static int _uds_getsockname(int fd, struct sockaddr *__restrict address,
    socklen_t *__restrict address_len, struct sockaddr_un *uds_addr)
 {