Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/pgoyette-compat]: src/sys Initial implementation of sys/kern/kern_stup.c...
details: https://anonhg.NetBSD.org/src/rev/928495af9dc8
branches: pgoyette-compat
changeset: 360184:928495af9dc8
user: pgoyette <pgoyette%NetBSD.org@localhost>
date: Tue Mar 20 08:11:25 2018 +0000
description:
Initial implementation of sys/kern/kern_stup.c as discussed on tech-kern
For now, we only handle the dev/ccd and NTP needs; more to follow.
diffstat:
sys/compat/common/ccd_60.c | 11 ++---
sys/compat/common/kern_time_50.c | 26 +++++--------
sys/dev/ccd.c | 8 +--
sys/kern/compat_stub.c | 55 +++++++++++++++++++++++++++++
sys/kern/files.kern | 3 +-
sys/rump/librump/rumpkern/Makefile.rumpkern | 3 +-
sys/sys/compat_stub.h | 52 +++++++++++++++++++++++++++
7 files changed, 129 insertions(+), 29 deletions(-)
diffs (truncated from 317 to 300 lines):
diff -r 148840426c49 -r 928495af9dc8 sys/compat/common/ccd_60.c
--- a/sys/compat/common/ccd_60.c Tue Mar 20 06:23:36 2018 +0000
+++ b/sys/compat/common/ccd_60.c Tue Mar 20 08:11:25 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: ccd_60.c,v 1.1.2.5 2018/03/19 21:53:04 pgoyette Exp $ */
+/* $NetBSD: ccd_60.c,v 1.1.2.6 2018/03/20 08:11:25 pgoyette Exp $ */
/*-
* Copyright (c) 2018 The NetBSD Foundation, Inc.
@@ -26,7 +26,7 @@
* POSSIBILITY OF SUCH DAMAGE.
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: ccd_60.c,v 1.1.2.5 2018/03/19 21:53:04 pgoyette Exp $");
+__KERNEL_RCSID(0, "$NetBSD: ccd_60.c,v 1.1.2.6 2018/03/20 08:11:25 pgoyette Exp $");
#ifdef _KERNEL_OPT
#include "opt_compat_netbsd.h"
@@ -36,6 +36,7 @@
#include <sys/systm.h>
#include <sys/disk.h>
#include <sys/lwp.h>
+#include <sys/compat_stub.h>
#include <dev/ccdvar.h>
#include <compat/sys/ccdvar.h>
@@ -45,7 +46,6 @@
* sizeof (size_t) == sizeof (uint64_t) as CCDIOCSET will
* be the same as CCDIOCSET_60
*/
-#if 0
static int
compat_60_ccdioctl(dev_t dev, u_long cmd, void *data, int flag, struct lwp *l,
int (*f)(dev_t, u_long, void *, int, struct lwp *))
@@ -90,18 +90,17 @@
return ENOSYS;
}
}
-#endif /* 0 */
void
ccd_60_init(void)
{
-// compat_ccd_ioctl_60 = compat_60_ccdioctl;
+ compat_ccd_ioctl_60 = compat_60_ccdioctl;
}
void
ccd_60_fini(void)
{
-// compat_ccd_ioctl_60 = (void *)enosys;
+ compat_ccd_ioctl_60 = (void *)enosys;
}
diff -r 148840426c49 -r 928495af9dc8 sys/compat/common/kern_time_50.c
--- a/sys/compat/common/kern_time_50.c Tue Mar 20 06:23:36 2018 +0000
+++ b/sys/compat/common/kern_time_50.c Tue Mar 20 08:11:25 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: kern_time_50.c,v 1.31.16.1 2018/03/19 21:54:43 pgoyette Exp $ */
+/* $NetBSD: kern_time_50.c,v 1.31.16.2 2018/03/20 08:11:25 pgoyette Exp $ */
/*-
* Copyright (c) 2008, 2009 The NetBSD Foundation, Inc.
@@ -29,7 +29,7 @@
* POSSIBILITY OF SUCH DAMAGE.
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: kern_time_50.c,v 1.31.16.1 2018/03/19 21:54:43 pgoyette Exp $");
+__KERNEL_RCSID(0, "$NetBSD: kern_time_50.c,v 1.31.16.2 2018/03/20 08:11:25 pgoyette Exp $");
#ifdef _KERNEL_OPT
#include "opt_aio.h"
@@ -61,6 +61,7 @@
#include <sys/syscallvar.h>
#include <sys/sysctl.h>
#include <sys/resource.h>
+#include <sys/compat_stub.h>
#include <compat/common/compat_util.h>
#include <compat/common/compat_mod.h>
@@ -101,12 +102,9 @@
(sy_call_t *)compat_50_sys_timer_gettime },
{ SYS_compat_50___ntp_gettime30, 0,
(sy_call_t *)compat_50_sys___ntp_gettime30 },
+ { SYS_compat_50___ntp_gettime30, 0,
+ (sy_call_t *)compat_50_sys___ntp_gettime30 },
{ 0, 0, NULL }
-
-
-
-
-
};
int
@@ -556,10 +554,9 @@
compat_50_sys___ntp_gettime30(struct lwp *l,
const struct compat_50_sys___ntp_gettime30_args *uap, register_t *retval)
{
-/* XXX
- * XXX need to detect if kernel has NTP at run-time!
- * XXX */
-#ifdef NTP
+ if (vec_ntp_gettime == NULL)
+ return ENOSYS; /* No NTP available in kernel */
+
/* {
syscallarg(struct ntptimeval *) ntvp;
} */
@@ -568,7 +565,7 @@
int error;
if (SCARG(uap, ntvp)) {
- ntp_gettime(&ntv);
+ (*vec_ntp_gettime)(&ntv);
timespec_to_timespec50(&ntv.time, &ntv50.time);
ntv50.maxerror = ntv.maxerror;
ntv50.esterror = ntv.esterror;
@@ -579,11 +576,8 @@
if (error)
return error;
}
- *retval = ntp_timestatus();
+ *retval = (*vec_ntp_timestatus)();
return 0;
-#else
- return ENOSYS;
-#endif
}
static void
diff -r 148840426c49 -r 928495af9dc8 sys/dev/ccd.c
--- a/sys/dev/ccd.c Tue Mar 20 06:23:36 2018 +0000
+++ b/sys/dev/ccd.c Tue Mar 20 08:11:25 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: ccd.c,v 1.175.2.1 2018/03/18 21:41:31 pgoyette Exp $ */
+/* $NetBSD: ccd.c,v 1.175.2.2 2018/03/20 08:11:25 pgoyette Exp $ */
/*-
* Copyright (c) 1996, 1997, 1998, 1999, 2007, 2009 The NetBSD Foundation, Inc.
@@ -88,7 +88,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: ccd.c,v 1.175.2.1 2018/03/18 21:41:31 pgoyette Exp $");
+__KERNEL_RCSID(0, "$NetBSD: ccd.c,v 1.175.2.2 2018/03/20 08:11:25 pgoyette Exp $");
#if defined(_KERNEL_OPT)
#include "opt_compat_netbsd.h"
@@ -119,6 +119,7 @@
#include <sys/kthread.h>
#include <sys/bufq.h>
#include <sys/sysctl.h>
+#include <sys/compat_stub.h>
#include <uvm/uvm_extern.h>
@@ -1076,9 +1077,6 @@
return (physio(ccdstrategy, NULL, dev, B_WRITE, minphys, uio));
}
-int (*compat_ccd_ioctl_60)(dev_t, u_long, void *, int, struct lwp *,
- int (*)(dev_t, u_long, void *, int, struct lwp *)) = (void *)enosys;
-
static int
ccdioctl(dev_t dev, u_long cmd, void *data, int flag, struct lwp *l)
{
diff -r 148840426c49 -r 928495af9dc8 sys/kern/compat_stub.c
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/sys/kern/compat_stub.c Tue Mar 20 08:11:25 2018 +0000
@@ -0,0 +1,55 @@
+/* $NetBSD: compat_stub.c,v 1.1.2.1 2018/03/20 08:11:25 pgoyette Exp $ */
+
+/*-
+ * Copyright (c) 2018 The NetBSD Foundation, Inc.
+ * All rights reserved.
+ *
+ * This code is derived from software contributed to The NetBSD Foundation
+ * by Paul Goyette
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
+ * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
+ * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+ * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
+ * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+ * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+ * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+ * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+ * POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#include <sys/cdefs.h>
+
+#ifdef _KERNEL_OPT
+#include "opt_ntp.h"
+#endif
+
+#include <sys/systm.h>
+#include <sys/compat_stub.h>
+
+/*
+ * Routine vectors for compat_50___sys_ntp_gettime
+ */
+
+#ifdef NTP
+void (*vec_ntp_gettime)(struct ntptimeval *) = ntp_gettime;
+int (*vec_ntp_timestatus)(void) = ntp_timestatus;
+#else
+void (*vec_ntp_gettime)(struct ntptimeval *) = NULL;
+int (*vec_ntp_timestatus)(void) = NULL;
+#endif
+
+int (*compat_ccd_ioctl_60)(dev_t dev, u_long cmd, void *data, int flag,
+ struct lwp *l, int (*f)(dev_t, u_long, void *, int, struct lwp *)) =
+ (void *)enosys;
diff -r 148840426c49 -r 928495af9dc8 sys/kern/files.kern
--- a/sys/kern/files.kern Tue Mar 20 06:23:36 2018 +0000
+++ b/sys/kern/files.kern Tue Mar 20 08:11:25 2018 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: files.kern,v 1.16.2.4 2018/03/07 09:33:26 pgoyette Exp $
+# $NetBSD: files.kern,v 1.16.2.5 2018/03/20 08:11:25 pgoyette Exp $
#
# kernel sources
@@ -11,6 +11,7 @@
file kern/bufq_fcfs.c bufq_fcfs
file kern/bufq_priocscan.c bufq_priocscan
file kern/bufq_readprio.c bufq_readprio | new_bufq_strategy
+file kern/compat_stub.c kern
file kern/core_elf32.c exec_elf32
file kern/core_elf64.c exec_elf64
file kern/core_netbsd.c exec_aout | exec_coff | exec_ecoff
diff -r 148840426c49 -r 928495af9dc8 sys/rump/librump/rumpkern/Makefile.rumpkern
--- a/sys/rump/librump/rumpkern/Makefile.rumpkern Tue Mar 20 06:23:36 2018 +0000
+++ b/sys/rump/librump/rumpkern/Makefile.rumpkern Tue Mar 20 08:11:25 2018 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: Makefile.rumpkern,v 1.170 2017/07/25 05:01:25 ozaki-r Exp $
+# $NetBSD: Makefile.rumpkern,v 1.170.2.1 2018/03/20 08:11:25 pgoyette Exp $
#
.include "${RUMPTOP}/Makefile.rump"
@@ -67,6 +67,7 @@
#
# sys/kern
SRCS+= init_sysctl_base.c \
+ compat_stub.c \
kern_auth.c \
kern_cfglock.c \
kern_clock.c \
diff -r 148840426c49 -r 928495af9dc8 sys/sys/compat_stub.h
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/sys/sys/compat_stub.h Tue Mar 20 08:11:25 2018 +0000
@@ -0,0 +1,52 @@
+/* $NetBSD: compat_stub.h,v 1.1.2.1 2018/03/20 08:11:26 pgoyette Exp $ */
+
+/*-
+ * Copyright (c) 2018 The NetBSD Foundation, Inc.
+ * All rights reserved.
+ *
+ * This code is derived from software contributed to The NetBSD Foundation
+ * by Paul Goyette
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
+ * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
+ * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+ * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
+ * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+ * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+ * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+ * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+ * POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#ifndef _SYS_COMPAT_STUB_H
+#define _SYS_COMPAT_STUB_H
+
+/*
Home |
Main Index |
Thread Index |
Old Index