Source-Changes-HG archive

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

[src/trunk]: src/sys/compat/netbsd32 Add support for SIOCGIFGENERIC and SIOCS...



details:   https://anonhg.NetBSD.org/src/rev/420b5bea74f7
branches:  trunk
changeset: 357773:420b5bea74f7
user:      jmcneill <jmcneill%NetBSD.org@localhost>
date:      Sun Nov 26 17:46:13 2017 +0000

description:
Add support for SIOCGIFGENERIC and SIOCSIFGENERIC ioctls.

diffstat:

 sys/compat/netbsd32/netbsd32_ioctl.c |  25 +++++++++++++++++++++----
 sys/compat/netbsd32/netbsd32_ioctl.h |   5 ++++-
 2 files changed, 25 insertions(+), 5 deletions(-)

diffs (81 lines):

diff -r bae3638b51f4 -r 420b5bea74f7 sys/compat/netbsd32/netbsd32_ioctl.c
--- a/sys/compat/netbsd32/netbsd32_ioctl.c      Sun Nov 26 16:32:10 2017 +0000
+++ b/sys/compat/netbsd32/netbsd32_ioctl.c      Sun Nov 26 17:46:13 2017 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: netbsd32_ioctl.c,v 1.89 2017/01/14 16:34:44 maya Exp $ */
+/*     $NetBSD: netbsd32_ioctl.c,v 1.90 2017/11/26 17:46:13 jmcneill Exp $     */
 
 /*
  * Copyright (c) 1998, 2001 Matthew R. Green
@@ -31,7 +31,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: netbsd32_ioctl.c,v 1.89 2017/01/14 16:34:44 maya Exp $");
+__KERNEL_RCSID(0, "$NetBSD: netbsd32_ioctl.c,v 1.90 2017/11/26 17:46:13 jmcneill Exp $");
 
 #if defined(_KERNEL_OPT)
 #include "opt_ntp.h"
@@ -116,8 +116,14 @@
         * union member needs to be converted to 64 bits... this
         * is very driver specific and so we ignore it for now..
         */
-       if (cmd == SIOCGIFDATA || cmd == SIOCZIFDATA)
+       switch (cmd) {
+       case SIOCGIFDATA:
+       case SIOCZIFDATA:
+       case SIOCGIFGENERIC:
+       case SIOCSIFGENERIC:
                p->ifr_data = (void *)NETBSD32PTR64(s32p->ifr_data);
+               break;
+       }
 }
 
 static inline void
@@ -534,8 +540,14 @@
         * is very driver specific and so we ignore it for now..
         */
        memcpy(s32p, p, sizeof *s32p);
-       if (cmd == SIOCGIFDATA || cmd == SIOCZIFDATA)
+       switch (cmd) {
+       case SIOCGIFDATA:
+       case SIOCZIFDATA:
+       case SIOCGIFGENERIC:
+       case SIOCSIFGENERIC:
                NETBSD32PTR32(s32p->ifr_data, p->ifr_data);
+               break;
+       }
 }
 
 static inline void
@@ -1233,6 +1245,11 @@
        case SIOCGIFMEDIA32:
                IOCTL_STRUCT_CONV_TO(SIOCGIFMEDIA, ifmediareq);
 
+       case SIOCGIFGENERIC32:
+               IOCTL_STRUCT_CONV_TO(SIOCGIFGENERIC, ifreq);
+       case SIOCSIFGENERIC32:
+               IOCTL_STRUCT_CONV_TO(SIOCSIFGENERIC, ifreq);
+
        case PPPOESETPARMS32:
                IOCTL_STRUCT_CONV_TO(PPPOESETPARMS, pppoediscparms);
        case PPPOEGETPARMS32:
diff -r bae3638b51f4 -r 420b5bea74f7 sys/compat/netbsd32/netbsd32_ioctl.h
--- a/sys/compat/netbsd32/netbsd32_ioctl.h      Sun Nov 26 16:32:10 2017 +0000
+++ b/sys/compat/netbsd32/netbsd32_ioctl.h      Sun Nov 26 17:46:13 2017 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: netbsd32_ioctl.h,v 1.56 2016/12/26 23:05:06 christos Exp $     */
+/*     $NetBSD: netbsd32_ioctl.h,v 1.57 2017/11/26 17:46:13 jmcneill Exp $     */
 
 /*
  * Copyright (c) 1998, 2001 Matthew R. Green
@@ -374,6 +374,9 @@
 #define        SIOCSIFMEDIA32  _IOWR('i', 53, struct netbsd32_ifreq)   /* set net media */
 #define        OSIOCSIFMEDIA32 _IOWR('i', 53, struct netbsd32_oifreq)  /* set net media */
 
+#define        SIOCSIFGENERIC32 _IOW('i', 57, struct netbsd32_ifreq)   /* generic IF set op */
+#define        SIOCGIFGENERIC32 _IOWR('i', 58, struct netbsd32_ifreq)  /* generic IF get op */
+
 #define        SIOCIFGCLONERS32 _IOWR('i', 120, struct netbsd32_if_clonereq) /* get cloners */
 
 #define        SIOCSIFMTU32     _IOW('i', 127, struct netbsd32_ifreq)  /* set ifnet mtu */



Home | Main Index | Thread Index | Old Index