Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/compat/netbsd32 Restore netbsd32 compat code for new NPF...
details: https://anonhg.NetBSD.org/src/rev/49756283834f
branches: trunk
changeset: 446167:49756283834f
user: mlelstv <mlelstv%NetBSD.org@localhost>
date: Sun Nov 25 17:58:29 2018 +0000
description:
Restore netbsd32 compat code for new NPF ABI.
diffstat:
sys/compat/netbsd32/netbsd32.h | 9 +++-
sys/compat/netbsd32/netbsd32_conv.h | 32 +++++++++++++-
sys/compat/netbsd32/netbsd32_ioctl.c | 83 +++++++++++++++++++++++++++++++++--
sys/compat/netbsd32/netbsd32_ioctl.h | 25 ++++++++++-
4 files changed, 140 insertions(+), 9 deletions(-)
diffs (272 lines):
diff -r 276a77f81b9d -r 49756283834f sys/compat/netbsd32/netbsd32.h
--- a/sys/compat/netbsd32/netbsd32.h Sun Nov 25 16:21:04 2018 +0000
+++ b/sys/compat/netbsd32/netbsd32.h Sun Nov 25 17:58:29 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: netbsd32.h,v 1.119 2018/08/11 03:41:06 mrg Exp $ */
+/* $NetBSD: netbsd32.h,v 1.120 2018/11/25 17:58:29 mlelstv Exp $ */
/*
* Copyright (c) 1998, 2001, 2008, 2015 Matthew R. Green
@@ -912,6 +912,13 @@
netbsd32_size_t pref_len;
};
+/* <nv.h> */
+typedef struct {
+ netbsd32_pointer_t buf;
+ netbsd32_size_t len;
+ int flags;
+} netbsd32_nvlist_ref_t;
+
/* from <ufs/lfs/lfs.h> */
typedef netbsd32_pointer_t netbsd32_block_infop_t; /* XXX broken */
diff -r 276a77f81b9d -r 49756283834f sys/compat/netbsd32/netbsd32_conv.h
--- a/sys/compat/netbsd32/netbsd32_conv.h Sun Nov 25 16:21:04 2018 +0000
+++ b/sys/compat/netbsd32/netbsd32_conv.h Sun Nov 25 17:58:29 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: netbsd32_conv.h,v 1.35 2018/05/10 02:36:07 christos Exp $ */
+/* $NetBSD: netbsd32_conv.h,v 1.36 2018/11/25 17:58:29 mlelstv Exp $ */
/*
* Copyright (c) 1998, 2001 Matthew R. Green
@@ -48,6 +48,8 @@
#include <prop/plistref.h>
+#include <nv.h>
+
#include <compat/netbsd32/netbsd32.h>
/* converters for structures that we need */
@@ -796,6 +798,34 @@
sizeof(struct netbsd32_plistref));
}
+static __inline int
+netbsd32_copyin_nvlist_ref_t(netbsd32_pointer_t n32p, nvlist_ref_t *p)
+{
+ netbsd32_nvlist_ref_t n32nv;
+ int error;
+
+ error = copyin(NETBSD32PTR64(n32p), &n32nv,
+ sizeof(netbsd32_nvlist_ref_t));
+ if (error)
+ return error;
+ p->buf = NETBSD32PTR64(n32nv.buf);
+ p->len = n32nv.len;
+ p->flags = n32nv.flags;
+ return 0;
+}
+
+static __inline int
+netbsd32_copyout_nvlist_ref_t(netbsd32_pointer_t n32p, nvlist_ref_t *p)
+{
+ netbsd32_nvlist_ref_t n32nv;
+
+ NETBSD32PTR32(n32nv.buf, p->buf);
+ n32nv.len = p->len;
+ n32nv.flags = p->flags;
+ return copyout(&n32nv, NETBSD32PTR64(n32p),
+ sizeof(netbsd32_nvlist_ref_t));
+}
+
static __inline void
netbsd32_to_mq_attr(const struct netbsd32_mq_attr *a32,
struct mq_attr *attr)
diff -r 276a77f81b9d -r 49756283834f sys/compat/netbsd32/netbsd32_ioctl.c
--- a/sys/compat/netbsd32/netbsd32_ioctl.c Sun Nov 25 16:21:04 2018 +0000
+++ b/sys/compat/netbsd32/netbsd32_ioctl.c Sun Nov 25 17:58:29 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: netbsd32_ioctl.c,v 1.99 2018/10/12 05:06:05 rin Exp $ */
+/* $NetBSD: netbsd32_ioctl.c,v 1.100 2018/11/25 17:58:29 mlelstv 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.99 2018/10/12 05:06:05 rin Exp $");
+__KERNEL_RCSID(0, "$NetBSD: netbsd32_ioctl.c,v 1.100 2018/11/25 17:58:29 mlelstv Exp $");
#if defined(_KERNEL_OPT)
#include "opt_ntp.h"
@@ -287,20 +287,27 @@
}
static inline void
+netbsd32_to_nvlist_ref_t(netbsd32_nvlist_ref_t *s32p, nvlist_ref_t *p, u_long cmd)
+{
+
+ p->buf = NETBSD32PTR64(s32p->buf);
+ p->len = s32p->len;
+ p->flags = s32p->flags;
+}
+
+static inline void
netbsd32_to_u_long(netbsd32_u_long *s32p, u_long *p, u_long cmd)
{
*p = (u_long)*s32p;
}
-#ifdef notdef
static inline void
netbsd32_to_voidp(netbsd32_voidp *s32p, voidp *p, u_long cmd)
{
*p = (void *)NETBSD32PTR64(*s32p);
}
-#endif
static inline void
netbsd32_to_wdog_conf(struct netbsd32_wdog_conf *s32p, struct wdog_conf *p, u_long cmd)
@@ -311,6 +318,28 @@
}
static inline void
+netbsd32_to_npf_ioctl_table(
+ const struct netbsd32_npf_ioctl_table *s32p,
+ struct npf_ioctl_table *p,
+ u_long cmd)
+{
+
+ p->nct_cmd = s32p->nct_cmd;
+ p->nct_name = NETBSD32PTR64(s32p->nct_name);
+ switch (s32p->nct_cmd) {
+ case NPF_CMD_TABLE_LOOKUP:
+ case NPF_CMD_TABLE_ADD:
+ case NPF_CMD_TABLE_REMOVE:
+ p->nct_data.ent = s32p->nct_data.ent;
+ break;
+ case NPF_CMD_TABLE_LIST:
+ p->nct_data.buf.buf = NETBSD32PTR64(s32p->nct_data.buf.buf);
+ p->nct_data.buf.len = s32p->nct_data.buf.len;
+ break;
+ }
+}
+
+static inline void
netbsd32_to_bpf_program(struct netbsd32_bpf_program *s32p, struct bpf_program *p, u_long cmd)
{
@@ -740,6 +769,15 @@
}
static inline void
+netbsd32_from_nvlist_ref_t(nvlist_ref_t *p, netbsd32_nvlist_ref_t *s32p, u_long cmd)
+{
+
+ NETBSD32PTR32(s32p->buf, p->buf);
+ s32p->len = p->len;
+ s32p->flags = p->flags;
+}
+
+static inline void
netbsd32_from_wdog_conf(struct wdog_conf *p, struct netbsd32_wdog_conf *s32p, u_long cmd)
{
@@ -857,14 +895,12 @@
*s32p = (netbsd32_u_long)*p;
}
-#ifdef notdef
static inline void
netbsd32_from_voidp(voidp *p, netbsd32_voidp *s32p, u_long cmd)
{
NETBSD32PTR32(*s32p, *p);
}
-#endif
static inline void
netbsd32_from_clockctl_settimeofday(
@@ -935,6 +971,28 @@
}
static inline void
+netbsd32_from_npf_ioctl_table(
+ const struct npf_ioctl_table *p,
+ struct netbsd32_npf_ioctl_table *s32p,
+ u_long cmd)
+{
+
+ s32p->nct_cmd = p->nct_cmd;
+ NETBSD32PTR32(s32p->nct_name, p->nct_name);
+ switch (p->nct_cmd) {
+ case NPF_CMD_TABLE_LOOKUP:
+ case NPF_CMD_TABLE_ADD:
+ case NPF_CMD_TABLE_REMOVE:
+ s32p->nct_data.ent = p->nct_data.ent;
+ break;
+ case NPF_CMD_TABLE_LIST:
+ NETBSD32PTR32(s32p->nct_data.buf.buf, p->nct_data.buf.buf);
+ s32p->nct_data.buf.len = p->nct_data.buf.len;
+ break;
+ }
+}
+
+static inline void
netbsd32_from_devlistargs(
const struct devlistargs *p,
struct netbsd32_devlistargs *s32p,
@@ -1422,6 +1480,19 @@
case KIOCGVALUE32:
IOCTL_STRUCT_CONV_TO(KIOCGVALUE, ksyms_gvalue);
+ case IOC_NPF_LOAD32:
+ IOCTL_CONV_TO(IOC_NPF_LOAD, nvlist_ref_t);
+ case IOC_NPF_TABLE32:
+ IOCTL_STRUCT_CONV_TO(IOC_NPF_TABLE, npf_ioctl_table);
+ case IOC_NPF_STATS32:
+ IOCTL_CONV_TO(IOC_NPF_STATS, voidp);
+ case IOC_NPF_SAVE32:
+ IOCTL_CONV_TO(IOC_NPF_SAVE, nvlist_ref_t);
+ case IOC_NPF_RULE32:
+ IOCTL_CONV_TO(IOC_NPF_RULE, nvlist_ref_t);
+ case IOC_NPF_CONN_LOOKUP32:
+ IOCTL_CONV_TO(IOC_NPF_CONN_LOOKUP, nvlist_ref_t);
+
case DRVRESCANBUS32:
IOCTL_STRUCT_CONV_TO(DRVRESCANBUS, devrescanargs);
case DRVLISTDEV32:
diff -r 276a77f81b9d -r 49756283834f sys/compat/netbsd32/netbsd32_ioctl.h
--- a/sys/compat/netbsd32/netbsd32_ioctl.h Sun Nov 25 16:21:04 2018 +0000
+++ b/sys/compat/netbsd32/netbsd32_ioctl.h Sun Nov 25 17:58:29 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: netbsd32_ioctl.h,v 1.65 2018/10/11 15:23:22 christos Exp $ */
+/* $NetBSD: netbsd32_ioctl.h,v 1.66 2018/11/25 17:58:29 mlelstv Exp $ */
/*
* Copyright (c) 1998, 2001 Matthew R. Green
@@ -561,6 +561,29 @@
#define KIOCGSYMBOL32 _IOWR('l', 5, struct netbsd32_ksyms_gsymbol)
#endif /* KIOCGSYMBOL */
+#include <net/npf/npf.h>
+
+typedef struct netbsd32_npf_ioctl_buf {
+ netbsd32_voidp buf;
+ netbsd32_size_t len;
+} netbsd32_npf_ioctl_buf_t;
+
+typedef struct netbsd32_npf_ioctl_table {
+ int nct_cmd;
+ netbsd32_charp nct_name;
+ union {
+ npf_ioctl_ent_t ent;
+ netbsd32_npf_ioctl_buf_t buf;
+ } nct_data;
+} netbsd32_npf_ioctl_table_t;
+
+#define IOC_NPF_LOAD32 _IOWR('N', 102, netbsd32_nvlist_ref_t)
+#define IOC_NPF_TABLE32 _IOW('N', 103, struct netbsd32_npf_ioctl_table)
+#define IOC_NPF_STATS32 _IOW('N', 104, netbsd32_voidp)
+#define IOC_NPF_SAVE32 _IOR('N', 105, netbsd32_nvlist_ref_t)
+#define IOC_NPF_RULE32 _IOWR('N', 107, netbsd32_nvlist_ref_t)
+#define IOC_NPF_CONN_LOOKUP32 _IOWR('N', 108, netbsd32_nvlist_ref_t)
+
/* From sys/drvctlio.h */
struct netbsd32_devlistargs {
char l_devname[16];
Home |
Main Index |
Thread Index |
Old Index