Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys put the code that returns the sizeof the socket by famil...



details:   https://anonhg.NetBSD.org/src/rev/b9f5e1af9c0f
branches:  trunk
changeset: 354849:b9f5e1af9c0f
user:      christos <christos%NetBSD.org@localhost>
date:      Sat Jul 01 16:59:12 2017 +0000

description:
put the code that returns the sizeof the socket by family in one place.

diffstat:

 sys/kern/uipc_domain.c |  66 ++++++++++++++++++++++++-------------------------
 sys/net/rtsock.c       |  28 ++++----------------
 sys/sys/socket.h       |   5 ++-
 3 files changed, 41 insertions(+), 58 deletions(-)

diffs (181 lines):

diff -r b204c141ca28 -r b9f5e1af9c0f sys/kern/uipc_domain.c
--- a/sys/kern/uipc_domain.c    Sat Jul 01 16:34:17 2017 +0000
+++ b/sys/kern/uipc_domain.c    Sat Jul 01 16:59:12 2017 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: uipc_domain.c,v 1.96 2014/12/02 19:45:58 christos Exp $        */
+/*     $NetBSD: uipc_domain.c,v 1.97 2017/07/01 16:59:12 christos Exp $        */
 
 /*
  * Copyright (c) 1982, 1986, 1993
@@ -32,7 +32,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: uipc_domain.c,v 1.96 2014/12/02 19:45:58 christos Exp $");
+__KERNEL_RCSID(0, "$NetBSD: uipc_domain.c,v 1.97 2017/07/01 16:59:12 christos Exp $");
 
 #include <sys/param.h>
 #include <sys/socket.h>
@@ -228,7 +228,7 @@
 }
 
 const struct sockaddr *
-sockaddr_any_by_family(int family)
+sockaddr_any_by_family(sa_family_t family)
 {
        const struct domain *dom;
 
@@ -255,42 +255,40 @@
        return sockaddr_const_addr(any, slenp);
 }
 
+socklen_t
+sockaddr_getsize_by_family(sa_family_t af)
+{
+       switch (af) {
+       case AF_INET:
+               return sizeof(struct sockaddr_in);
+       case AF_INET6:
+               return sizeof(struct sockaddr_in6);
+       case AF_UNIX:
+               return sizeof(struct sockaddr_un);
+       case AF_LINK:
+               return sizeof(struct sockaddr_dl);
+       case AF_APPLETALK:
+               return sizeof(struct sockaddr_at);
+       default:
+#ifdef DIAGNOSTIC
+               printf("%s: Unhandled address family=%hhu\n", __func__, af);
+#endif
+               return 0;
+       }
+}
+
 #ifdef DIAGNOSTIC
 static void
 sockaddr_checklen(const struct sockaddr *sa)
 {
-       socklen_t len = 0;
-       switch (sa->sa_family) {
-       case AF_INET:
-               len = sizeof(struct sockaddr_in);
-               break;
-       case AF_INET6:
-               len = sizeof(struct sockaddr_in6);
-               break;
-       case AF_UNIX:
-               len = sizeof(struct sockaddr_un);
-               break;
-       case AF_LINK:
-               len = sizeof(struct sockaddr_dl);
-               // As long as it is not 0...
-               if (sa->sa_len != 0)
-                       return;
-               break;
-       case AF_APPLETALK:
-               len = sizeof(struct sockaddr_at);
-               break;
-       default:
-               printf("%s: Unhandled af=%hhu socklen=%hhu\n", __func__,
-                   sa->sa_family, sa->sa_len);
+       socklen_t len = sockaddr_getsize_by_family(sa->sa_family);
+       if (len == 0 || len == sa->sa_len)
                return;
-       }
-       if (len != sa->sa_len) {
-               char buf[512];
-               sockaddr_format(sa, buf, sizeof(buf));
-               printf("%s: %p bad len af=%hhu socklen=%hhu len=%u [%s]\n",
-                   __func__, sa, sa->sa_family, sa->sa_len,
-                   (unsigned)len, buf);
-       }
+
+       char buf[512];
+       sockaddr_format(sa, buf, sizeof(buf));
+       printf("%s: %p bad len af=%hhu socklen=%hhu len=%u [%s]\n",
+           __func__, sa, sa->sa_family, sa->sa_len, (unsigned)len, buf);
 }
 #else
 #define sockaddr_checklen(sa) ((void)0)
diff -r b204c141ca28 -r b9f5e1af9c0f sys/net/rtsock.c
--- a/sys/net/rtsock.c  Sat Jul 01 16:34:17 2017 +0000
+++ b/sys/net/rtsock.c  Sat Jul 01 16:59:12 2017 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: rtsock.c,v 1.226 2017/06/30 18:28:31 christos Exp $    */
+/*     $NetBSD: rtsock.c,v 1.227 2017/07/01 16:59:12 christos Exp $    */
 
 /*
  * Copyright (C) 1995, 1996, 1997, and 1998 WIDE Project.
@@ -61,7 +61,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: rtsock.c,v 1.226 2017/06/30 18:28:31 christos Exp $");
+__KERNEL_RCSID(0, "$NetBSD: rtsock.c,v 1.227 2017/07/01 16:59:12 christos Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_inet.h"
@@ -721,24 +721,6 @@
        return error;
 }
 
-static socklen_t
-sa_addrlen(const struct sockaddr *sa)
-{
-
-       switch (sa->sa_family) {
-#ifdef INET
-       case AF_INET:
-               return sizeof(struct sockaddr_in);
-#endif
-#ifdef INET6
-       case AF_INET6:
-               return sizeof(struct sockaddr_in6);
-#endif
-       default:
-               return 0;
-       }
-}
-
 /*ARGSUSED*/
 int
 COMPATNAME(route_output)(struct mbuf *m, struct socket *so)
@@ -819,8 +801,10 @@
         * (padded with 0's). We keep the original length of the sockaddr.
         */
        if (info.rti_info[RTAX_NETMASK]) {
-               socklen_t sa_len = sa_addrlen(info.rti_info[RTAX_NETMASK]);
-               socklen_t masklen = info.rti_info[RTAX_NETMASK]->sa_len;
+               socklen_t sa_len = sockaddr_getsize_by_family(
+                   info.rti_info[RTAX_NETMASK]->sa_family);
+               socklen_t masklen = sockaddr_getlen(
+                   info.rti_info[RTAX_NETMASK]);
                if (sa_len != 0 && sa_len > masklen) {
                        KASSERT(sa_len <= sizeof(netmask));
                        memcpy(&netmask, info.rti_info[RTAX_NETMASK], masklen);
diff -r b204c141ca28 -r b9f5e1af9c0f sys/sys/socket.h
--- a/sys/sys/socket.h  Sat Jul 01 16:34:17 2017 +0000
+++ b/sys/sys/socket.h  Sat Jul 01 16:59:12 2017 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: socket.h,v 1.122 2017/05/27 21:02:56 bouyer Exp $      */
+/*     $NetBSD: socket.h,v 1.123 2017/07/01 16:59:12 christos Exp $    */
 
 /*
  * Copyright (C) 1995, 1996, 1997, and 1998 WIDE Project.
@@ -625,6 +625,7 @@
 }
 
 __BEGIN_DECLS
+socklen_t sockaddr_getsize_by_family(sa_family_t);
 struct sockaddr *sockaddr_copy(struct sockaddr *, socklen_t,
     const struct sockaddr *);
 struct sockaddr *sockaddr_externalize(struct sockaddr *, socklen_t,
@@ -633,7 +634,7 @@
 const void *sockaddr_const_addr(const struct sockaddr *, socklen_t *);
 void *sockaddr_addr(struct sockaddr *, socklen_t *);
 const struct sockaddr *sockaddr_any(const struct sockaddr *);
-const struct sockaddr *sockaddr_any_by_family(int);
+const struct sockaddr *sockaddr_any_by_family(sa_family_t);
 const void *sockaddr_anyaddr(const struct sockaddr *, socklen_t *);
 int sockaddr_cmp(const struct sockaddr *, const struct sockaddr *);
 struct sockaddr *sockaddr_dup(const struct sockaddr *, int);



Home | Main Index | Thread Index | Old Index