Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/pgoyette-compat]: src Create and build a compat_16 module
details: https://anonhg.NetBSD.org/src/rev/8096f1e98742
branches: pgoyette-compat
changeset: 360236:8096f1e98742
user: pgoyette <pgoyette%NetBSD.org@localhost>
date: Fri Mar 30 05:35:47 2018 +0000
description:
Create and build a compat_16 module
diffstat:
distrib/sets/lists/modules/mi | 4 +-
sys/compat/common/compat_16_mod.c | 94 ++++++++++++++++++++++++++++++++++++++
sys/compat/common/compat_mod.c | 78 +------------------------------
sys/compat/common/compat_mod.h | 9 +++-
sys/compat/common/files.common | 3 +-
sys/compat/common/kern_sig_16.c | 96 ++++++++++++++++++++++++++++++++++++++-
sys/modules/Makefile | 4 +-
7 files changed, 207 insertions(+), 81 deletions(-)
diffs (truncated from 447 to 300 lines):
diff -r 85623ba58a6a -r 8096f1e98742 distrib/sets/lists/modules/mi
--- a/distrib/sets/lists/modules/mi Fri Mar 30 02:52:06 2018 +0000
+++ b/distrib/sets/lists/modules/mi Fri Mar 30 05:35:47 2018 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: mi,v 1.114.2.9 2018/03/30 02:28:25 pgoyette Exp $
+# $NetBSD: mi,v 1.114.2.10 2018/03/30 05:35:47 pgoyette Exp $
#
# Note: don't delete entries from here - mark them as "obsolete" instead.
#
@@ -68,6 +68,8 @@
./@MODULEDIR@/coda5/coda5.kmod base-kernel-modules kmod
./@MODULEDIR@/compat base-kernel-modules kmod
./@MODULEDIR@/compat/compat.kmod base-kernel-modules kmod
+./@MODULEDIR@/compat_16 base-kernel-modules kmod
+./@MODULEDIR@/compat_16/compat_16.kmod base-kernel-modules kmod
./@MODULEDIR@/compat_20 base-kernel-modules kmod
./@MODULEDIR@/compat_20/compat_20.kmod base-kernel-modules kmod
./@MODULEDIR@/compat_30 base-kernel-modules kmod
diff -r 85623ba58a6a -r 8096f1e98742 sys/compat/common/compat_16_mod.c
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/sys/compat/common/compat_16_mod.c Fri Mar 30 05:35:47 2018 +0000
@@ -0,0 +1,94 @@
+/* $NetBSD: compat_16_mod.c,v 1.1.2.1 2018/03/30 05:35:47 pgoyette Exp $ */
+
+/*-
+ * Copyright (c) 2018 The NetBSD Foundation, Inc.
+ * All rights reserved.
+ *
+ * This code is derived from software developed for 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.
+ */
+
+/*
+ * Linkage for the compat module: spaghetti.
+ */
+
+#include <sys/cdefs.h>
+__KERNEL_RCSID(0, "$NetBSD: compat_16_mod.c,v 1.1.2.1 2018/03/30 05:35:47 pgoyette Exp $");
+
+#include <sys/systm.h>
+#include <sys/module.h>
+#include <sys/sysctl.h>
+#include <sys/syscall.h>
+#include <sys/syscallvar.h>
+#include <sys/syscallargs.h>
+
+#include <compat/common/compat_util.h>
+#include <compat/common/compat_mod.h>
+
+int
+compat_16_init(void)
+{
+ int error = 0;
+
+ error = kern_sig_16_init();
+ if (error != 0)
+ return error;
+
+ return error;
+}
+
+int
+compat_16_fini(void)
+{
+ int error = 0;
+
+ error = kern_sig_16_fini();
+ if (error != 0) {
+ return error;
+ }
+
+ return error;
+}
+
+#ifdef _MODULE
+
+#define REQD_16_1 "compat_80,compat_70,compat_60,compat_50,"
+#define REQD_16_2 "compat_40,compat_30,compat_20"
+
+MODULE(MODULE_CLASS_EXEC, compat_16, REQD_16_1 REQD_16_2);
+
+static int
+compat_16_modcmd(modcmd_t cmd, void *arg)
+{
+
+ switch (cmd) {
+ case MODULE_CMD_INIT:
+ return compat_16_init();
+ case MODULE_CMD_FINI:
+ return compat_16_init();
+ default:
+ return ENOTTY;
+ }
+}
+#endif
diff -r 85623ba58a6a -r 8096f1e98742 sys/compat/common/compat_mod.c
--- a/sys/compat/common/compat_mod.c Fri Mar 30 02:52:06 2018 +0000
+++ b/sys/compat/common/compat_mod.c Fri Mar 30 05:35:47 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: compat_mod.c,v 1.24.14.25 2018/03/30 02:52:06 pgoyette Exp $ */
+/* $NetBSD: compat_mod.c,v 1.24.14.26 2018/03/30 05:35:47 pgoyette Exp $ */
/*-
* Copyright (c) 2008 The NetBSD Foundation, Inc.
@@ -34,7 +34,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: compat_mod.c,v 1.24.14.25 2018/03/30 02:52:06 pgoyette Exp $");
+__KERNEL_RCSID(0, "$NetBSD: compat_mod.c,v 1.24.14.26 2018/03/30 05:35:47 pgoyette Exp $");
#ifdef _KERNEL_OPT
#include "opt_compat_netbsd.h"
@@ -78,24 +78,13 @@
static const char * const compat_includes[] = {
"compat_80", "compat_70", "compat_60", "compat_50", "compat_40",
- "compat_30","compat_20",
+ "compat_30", "compat_20",
NULL
};
MODULE_WITH_ALIASES(MODULE_CLASS_EXEC, compat, NULL, &compat_includes);
-#ifdef _MODULE
-#ifdef COMPAT_16
-#if !defined(__amd64__) || defined(COMPAT_NETBSD32)
-#define COMPAT_SIGCONTEXT
-extern char sigcode[], esigcode[];
-struct uvm_object *emul_netbsd_object;
-#endif
-#endif
-#endif /* _MODULE */
-
-extern krwlock_t exec_lock;
extern krwlock_t ttcompat_lock;
static const struct syscall_package compat_syscalls[] = {
@@ -160,13 +149,6 @@
{ SYS_compat_13_sigsuspend13, 0, (sy_call_t *)compat_13_sys_sigsuspend },
#endif
-#if defined(COMPAT_16)
-#if defined(COMPAT_SIGCONTEXT)
- { SYS_compat_16___sigaction14, 0, (sy_call_t *)compat_16_sys___sigaction14 },
- { SYS_compat_16___sigreturn14, 0, (sy_call_t *)compat_16_sys___sigreturn14 },
-#endif
-#endif
-
{ 0, 0, NULL },
};
@@ -192,10 +174,10 @@
#ifdef COMPAT_20
{ compat_20_init, compat_20_fini },
#endif
-#if 0 /* NOT YET */
#ifdef COMPAT_16
{ compat_16_init, compat_16_fini },
#endif
+#if 0 /* NOT YET */
#ifdef COMPAT_14
{ compat_14_init, compat_14_fini },
#endif
@@ -220,9 +202,6 @@
static int
compat_modcmd(modcmd_t cmd, void *arg)
{
-#ifdef COMPAT_16
- proc_t *p;
-#endif
int error;
int i, j;
@@ -266,18 +245,6 @@
#ifdef COMPAT_13
uvm_13_init();
#endif
-#ifdef COMPAT_16
-#if defined(COMPAT_SIGCONTEXT)
- KASSERT(emul_netbsd.e_sigobject == NULL);
- rw_enter(&exec_lock, RW_WRITER);
- emul_netbsd.e_sigcode = sigcode;
- emul_netbsd.e_esigcode = esigcode;
- emul_netbsd.e_sigobject = &emul_netbsd_object;
- rw_exit(&exec_lock);
- KASSERT(sendsig_sigcontext_vec == NULL);
- sendsig_sigcontext_vec = sendsig_sigcontext;
-#endif
-#endif
#ifdef COMPAT_10
vfs_syscalls_10_init();
#endif
@@ -291,25 +258,6 @@
#ifdef COMPAT_13
uvm_13_fini();
#endif
-#ifdef COMPAT_16
- /*
- * Ensure sendsig_sigcontext() is not being used.
- * module_lock prevents the flag being set on any
- * further processes while we are here. See
- * sigaction1() for the opposing half.
- */
- mutex_enter(proc_lock);
- PROCLIST_FOREACH(p, &allproc) {
- if ((p->p_lflag & PL_SIGCOMPAT) != 0) {
- break;
- }
- }
- mutex_exit(proc_lock);
- if (p != NULL) {
- return EBUSY;
- }
- sendsig_sigcontext_vec = NULL;
-#endif
/* Unlink the system calls. */
error = syscall_disestablish(NULL, compat_syscalls);
if (error != 0) {
@@ -328,24 +276,6 @@
}
#endif
#endif /* NOTYET XXX */
-#ifdef COMPAT_16
-#if defined(COMPAT_SIGCONTEXT)
- /*
- * The sigobject may persist if still in use, but
- * is reference counted so will die eventually.
- */
- rw_enter(&exec_lock, RW_WRITER);
- if (emul_netbsd_object != NULL) {
- (*emul_netbsd_object->pgops->pgo_detach)
- (emul_netbsd_object);
- }
- emul_netbsd_object = NULL;
- emul_netbsd.e_sigcode = NULL;
- emul_netbsd.e_esigcode = NULL;
- emul_netbsd.e_sigobject = NULL;
- rw_exit(&exec_lock);
-#endif
-#endif /* COMPAT_16 */
/*
* Disable included components in reverse order;
* if any component fails to fini(), re-init those
diff -r 85623ba58a6a -r 8096f1e98742 sys/compat/common/compat_mod.h
--- a/sys/compat/common/compat_mod.h Fri Mar 30 02:52:06 2018 +0000
+++ b/sys/compat/common/compat_mod.h Fri Mar 30 05:35:47 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: compat_mod.h,v 1.1.42.13 2018/03/30 02:28:49 pgoyette Exp $ */
+/* $NetBSD: compat_mod.h,v 1.1.42.14 2018/03/30 05:35:47 pgoyette Exp $ */
/*-
* Copyright (c) 2013 The NetBSD Foundation, Inc.
@@ -116,4 +116,11 @@
void if43_20_fini(void);
#endif
+#ifdef COMPAT_16
+int compat_16_init(void);
+int compat_16_fini(void);
+int kern_sig_16_init(void);
+int kern_sig_16_fini(void);
+#endif
+
#endif /* !_COMPAT_MOD_H_ */
diff -r 85623ba58a6a -r 8096f1e98742 sys/compat/common/files.common
--- a/sys/compat/common/files.common Fri Mar 30 02:52:06 2018 +0000
+++ b/sys/compat/common/files.common Fri Mar 30 05:35:47 2018 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: files.common,v 1.1.2.24 2018/03/30 02:28:49 pgoyette Exp $
+# $NetBSD: files.common,v 1.1.2.25 2018/03/30 05:35:47 pgoyette Exp $
#
# Generic files, used by all compat options.
@@ -41,6 +41,7 @@
file compat/common/rtsock_14.c compat_14
# Compatibility code for NetBSD 1.6
Home |
Main Index |
Thread Index |
Old Index