Source-Changes-HG archive

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

[src/trunk]: src/sys/sys Arrange so that no options COREDUMP and no options P...



details:   https://anonhg.NetBSD.org/src/rev/43355226ab9e
branches:  trunk
changeset: 977270:43355226ab9e
user:      christos <christos%NetBSD.org@localhost>
date:      Mon Oct 19 19:33:01 2020 +0000

description:
Arrange so that no options COREDUMP and no options PTRACE work together.
Thanks to Paul Goyette for testing.

diffstat:

 sys/arch/amd64/conf/MODULAR          |   7 ++++---
 sys/arch/amd64/conf/files.amd64      |   4 ++--
 sys/kern/compat_stub.c               |   4 +++-
 sys/kern/core_elf32.c                |   6 +++---
 sys/kern/files.kern                  |   6 +++---
 sys/kern/kern_core.c                 |  25 ++++++++++++++++++++++---
 sys/kern/kern_sig.c                  |  32 +++++++++++++++++++++++++-------
 sys/modules/coredump/Makefile        |  21 ++++++++++-----------
 sys/modules/exec_elf32/Makefile      |   4 ++--
 sys/modules/exec_elf64/Makefile      |   4 ++--
 sys/modules/ptrace_common/Makefile   |   6 ++++--
 sys/modules/ptrace_common/machdep.mk |  13 +++++++++++++
 sys/sys/compat_stub.h                |   6 +++++-
 sys/sys/exec_elf.h                   |  14 +++++++++-----
 14 files changed, 107 insertions(+), 45 deletions(-)

diffs (truncated from 414 to 300 lines):

diff -r 343fe0330855 -r 43355226ab9e sys/arch/amd64/conf/MODULAR
--- a/sys/arch/amd64/conf/MODULAR       Mon Oct 19 19:14:11 2020 +0000
+++ b/sys/arch/amd64/conf/MODULAR       Mon Oct 19 19:33:01 2020 +0000
@@ -1,11 +1,9 @@
-# $NetBSD: MODULAR,v 1.17 2020/09/27 13:48:49 roy Exp $
+# $NetBSD: MODULAR,v 1.18 2020/10/19 19:33:01 christos Exp $
 #
 # Try to exclude all the drivers in GENERIC that have been modularized
 # XXX: incomplete
 
 include "arch/amd64/conf/GENERIC"
-options        MODULAR         # new style module(7) framework
-options        MODULAR_DEFAULT_AUTOLOAD
 
 -no acpicpu*   at cpu?
 -no est0               at cpu0
@@ -85,6 +83,9 @@
 
 -no options    AIO
 
+-no options    PTRACE
+-no options    COREDUMP
+
 -no acpiacad*  at acpi?                # ACPI AC Adapter
 -no acpibat*   at acpi?                # ACPI Battery
 -no acpibut*   at acpi?                # ACPI Button
diff -r 343fe0330855 -r 43355226ab9e sys/arch/amd64/conf/files.amd64
--- a/sys/arch/amd64/conf/files.amd64   Mon Oct 19 19:14:11 2020 +0000
+++ b/sys/arch/amd64/conf/files.amd64   Mon Oct 19 19:33:01 2020 +0000
@@ -1,4 +1,4 @@
-#      $NetBSD: files.amd64,v 1.117 2020/10/15 17:40:13 mgorny Exp $
+#      $NetBSD: files.amd64,v 1.118 2020/10/19 19:33:01 christos Exp $
 #
 # new style config file for amd64 architecture
 #
@@ -47,7 +47,7 @@
 file   arch/amd64/amd64/gdt.c                  machdep
 file   arch/amd64/amd64/machdep.c              machdep
 file   arch/amd64/amd64/prekern.c              kaslr
-file   arch/amd64/amd64/process_machdep.c      machdep
+file   arch/amd64/amd64/process_machdep.c      machdep & ptrace
 file   arch/amd64/amd64/trap.c                 machdep
 file   arch/x86/x86/fpu.c                      machdep
 file   arch/x86/x86/dbregs.c                   machdep
diff -r 343fe0330855 -r 43355226ab9e sys/kern/compat_stub.c
--- a/sys/kern/compat_stub.c    Mon Oct 19 19:14:11 2020 +0000
+++ b/sys/kern/compat_stub.c    Mon Oct 19 19:33:01 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: compat_stub.c,v 1.19 2019/11/20 19:37:53 pgoyette Exp $    */
+/* $NetBSD: compat_stub.c,v 1.20 2020/10/19 19:33:02 christos Exp $    */
 
 /*-
  * Copyright (c) 2018 The NetBSD Foundation, Inc.
@@ -280,6 +280,8 @@
 struct coredump_offset_hook_t coredump_offset_hook;
 struct coredump_write_hook_t coredump_write_hook;
 struct coredump_netbsd_hook_t coredump_netbsd_hook;
+struct coredump_elf32_hook_t coredump_elf32_hook;
+struct coredump_elf64_hook_t coredump_elf64_hook;
 struct uvm_coredump_walkmap_hook_t uvm_coredump_walkmap_hook;
 struct uvm_coredump_count_segs_hook_t uvm_coredump_count_segs_hook;
 
diff -r 343fe0330855 -r 43355226ab9e sys/kern/core_elf32.c
--- a/sys/kern/core_elf32.c     Mon Oct 19 19:14:11 2020 +0000
+++ b/sys/kern/core_elf32.c     Mon Oct 19 19:33:01 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: core_elf32.c,v 1.65 2020/10/10 00:10:06 rin Exp $      */
+/*     $NetBSD: core_elf32.c,v 1.66 2020/10/19 19:33:02 christos Exp $ */
 
 /*
  * Copyright (c) 2001 Wasabi Systems, Inc.
@@ -40,7 +40,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(1, "$NetBSD: core_elf32.c,v 1.65 2020/10/10 00:10:06 rin Exp $");
+__KERNEL_RCSID(1, "$NetBSD: core_elf32.c,v 1.66 2020/10/19 19:33:02 christos Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_compat_netbsd32.h"
@@ -109,7 +109,7 @@
 #define elf_fpreg              CONCAT(process_fpreg, ELFSIZE)
 
 int
-ELFNAMEEND(coredump)(struct lwp *l, struct coredump_iostate *cookie)
+ELFNAMEEND(real_coredump)(struct lwp *l, struct coredump_iostate *cookie)
 {
        Elf_Ehdr ehdr;
        Elf_Shdr shdr;
diff -r 343fe0330855 -r 43355226ab9e sys/kern/files.kern
--- a/sys/kern/files.kern       Mon Oct 19 19:14:11 2020 +0000
+++ b/sys/kern/files.kern       Mon Oct 19 19:33:01 2020 +0000
@@ -1,4 +1,4 @@
-#      $NetBSD: files.kern,v 1.52 2020/09/07 03:50:41 thorpej Exp $
+#      $NetBSD: files.kern,v 1.53 2020/10/19 19:33:02 christos Exp $
 
 #
 # kernel sources
@@ -16,8 +16,8 @@
 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_elf32.c               exec_elf32 & coredump
+file   kern/core_elf64.c               exec_elf64 & coredump
 file   kern/core_netbsd.c              coredump
 file   kern/cnmagic.c                  kern
 file   kern/exec_aout.c                exec_aout
diff -r 343fe0330855 -r 43355226ab9e sys/kern/kern_core.c
--- a/sys/kern/kern_core.c      Mon Oct 19 19:14:11 2020 +0000
+++ b/sys/kern/kern_core.c      Mon Oct 19 19:33:01 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: kern_core.c,v 1.30 2020/05/23 23:42:43 ad Exp $        */
+/*     $NetBSD: kern_core.c,v 1.31 2020/10/19 19:33:02 christos Exp $  */
 
 /*
  * Copyright (c) 1982, 1986, 1989, 1991, 1993
@@ -37,7 +37,11 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: kern_core.c,v 1.30 2020/05/23 23:42:43 ad Exp $");
+__KERNEL_RCSID(0, "$NetBSD: kern_core.c,v 1.31 2020/10/19 19:33:02 christos Exp $");
+
+#ifdef _KERNEL_OPT
+#include "opt_compat_netbsd32.h"
+#endif
 
 #include <sys/param.h>
 #include <sys/vnode.h>
@@ -51,8 +55,15 @@
 #include <sys/kauth.h>
 #include <sys/module.h>
 #include <sys/compat_stub.h>
+#include <sys/exec_elf.h>
 
-MODULE(MODULE_CLASS_MISC, coredump, NULL);
+#ifdef COMPAT_NETBSD32
+#define COREDUMP_MODULE_DEP    "compat_netbsd32_ptrace"
+#else
+#define COREDUMP_MODULE_DEP    NULL
+#endif
+
+MODULE(MODULE_CLASS_MISC, coredump, COREDUMP_MODULE_DEP);
 
 struct coredump_iostate {
        struct lwp *io_lwp;
@@ -77,6 +88,10 @@
                MODULE_HOOK_SET(coredump_write_hook, coredump_write);
                MODULE_HOOK_SET(coredump_offset_hook, coredump_offset);
                MODULE_HOOK_SET(coredump_netbsd_hook, real_coredump_netbsd);
+               MODULE_HOOK_SET(coredump_elf32_hook, real_coredump_elf32);
+#ifdef _LP64
+               MODULE_HOOK_SET(coredump_elf64_hook, real_coredump_elf64);
+#endif
                MODULE_HOOK_SET(uvm_coredump_walkmap_hook,
                    uvm_coredump_walkmap);
                MODULE_HOOK_SET(uvm_coredump_count_segs_hook,
@@ -85,6 +100,10 @@
        case MODULE_CMD_FINI:
                MODULE_HOOK_UNSET(uvm_coredump_count_segs_hook);
                MODULE_HOOK_UNSET(uvm_coredump_walkmap_hook);
+#ifdef _LP64
+               MODULE_HOOK_UNSET(coredump_elf64_hook);
+#endif
+               MODULE_HOOK_UNSET(coredump_elf32_hook);
                MODULE_HOOK_UNSET(coredump_netbsd_hook);
                MODULE_HOOK_UNSET(coredump_offset_hook);
                MODULE_HOOK_UNSET(coredump_write_hook);
diff -r 343fe0330855 -r 43355226ab9e sys/kern/kern_sig.c
--- a/sys/kern/kern_sig.c       Mon Oct 19 19:14:11 2020 +0000
+++ b/sys/kern/kern_sig.c       Mon Oct 19 19:33:01 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: kern_sig.c,v 1.390 2020/05/23 23:42:43 ad Exp $        */
+/*     $NetBSD: kern_sig.c,v 1.391 2020/10/19 19:33:02 christos Exp $  */
 
 /*-
  * Copyright (c) 2006, 2007, 2008, 2019 The NetBSD Foundation, Inc.
@@ -70,7 +70,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: kern_sig.c,v 1.390 2020/05/23 23:42:43 ad Exp $");
+__KERNEL_RCSID(0, "$NetBSD: kern_sig.c,v 1.391 2020/10/19 19:33:02 christos Exp $");
 
 #include "opt_ptrace.h"
 #include "opt_dtrace.h"
@@ -100,6 +100,7 @@
 #include <sys/cpu.h>
 #include <sys/module.h>
 #include <sys/sdt.h>
+#include <sys/exec_elf.h>
 #include <sys/compat_stub.h>
 
 #ifdef PAX_SEGVGUARD
@@ -2343,12 +2344,9 @@
 }
 
 /*
- * Many emulations have a common coredump_netbsd() established as their
- * dump routine.  Since the "real" code may (or may not) be present in
- * loadable module, we provide a routine here which calls the module
- * hook.
+ * Since the "real" code may (or may not) be present in loadable module,
+ * we provide routines here which calls the module hooks.
  */
-
 int
 coredump_netbsd(struct lwp *l, struct coredump_iostate *iocookie)
 {
@@ -2358,6 +2356,26 @@
        return retval;
 }
 
+int
+coredump_elf32(struct lwp *l, struct coredump_iostate *iocookie)
+{
+       int retval;
+
+       MODULE_HOOK_CALL(coredump_elf32_hook, (l, iocookie), ENOSYS, retval);
+       return retval;
+}
+
+#ifdef _LP64
+int
+coredump_elf64(struct lwp *l, struct coredump_iostate *iocookie)
+{
+       int retval;
+
+       MODULE_HOOK_CALL(coredump_elf64_hook, (l, iocookie), ENOSYS, retval);
+       return retval;
+}
+#endif
+
 /*
  * Put process 'p' into the stopped state and optionally, notify the parent.
  */
diff -r 343fe0330855 -r 43355226ab9e sys/modules/coredump/Makefile
--- a/sys/modules/coredump/Makefile     Mon Oct 19 19:14:11 2020 +0000
+++ b/sys/modules/coredump/Makefile     Mon Oct 19 19:33:01 2020 +0000
@@ -1,25 +1,24 @@
-#      $NetBSD: Makefile,v 1.6 2019/11/20 19:37:54 pgoyette Exp $
+#      $NetBSD: Makefile,v 1.7 2020/10/19 19:33:02 christos Exp $
 
 .include "../Makefile.inc"
 
 KMOD=  coredump
 
 .PATH: ${S}/kern
-SRCS=  kern_core.c core_netbsd.c 
+SRCS=  kern_core.c core_netbsd.c
+SRCS+= ${OBJECT_FMTS:S/^/core_/:S/$/.c/}
 
 .PATH: ${S}/uvm
 SRCS+= uvm_coredump.c
 
-.PATH: ${S}/arch/${MACHINE}/${MACHINE}
-.PATH: ${S}/arch/${MACHINE_ARCH}/${MACHINE_ARCH}
-.PATH: ${S}/arch/${MACHINE_CPU}/${MACHINE_CPU}
-.if ${MACHINE_ARCH} == "i386" || ${MACHINE_ARCH} == "x86_64"
-.PATH: ${S}/arch/x86/x86
+.include "../ptrace_common/machdep.mk"
+SRCS+= core_machdep.c
+
+.include "${.CURDIR}/../../compat/netbsd32/netbsd32.mk"
+.if ${COMPAT_USE_NETBSD32} != "no"
+CPPFLAGS.core_elf32.c+=     -DCOMPAT_NETBSD32
+CPPFLAGS.kern_core.c+=     -DCOMPAT_NETBSD32
 .endif
-.if ${MACHINE_ARCH} == "powerpc64"
-.PATH: ${S}/arch/powerpc/powerpc
-.endif
-SRCS+= core_machdep.c
 
 WARNS= 3
 
diff -r 343fe0330855 -r 43355226ab9e sys/modules/exec_elf32/Makefile
--- a/sys/modules/exec_elf32/Makefile   Mon Oct 19 19:14:11 2020 +0000
+++ b/sys/modules/exec_elf32/Makefile   Mon Oct 19 19:33:01 2020 +0000
@@ -1,4 +1,4 @@
-#      $NetBSD: Makefile,v 1.5 2019/11/20 19:37:54 pgoyette Exp $
+#      $NetBSD: Makefile,v 1.6 2020/10/19 19:33:02 christos Exp $
 
 .include "../Makefile.inc"
 
@@ -19,7 +19,7 @@
 .endif
 
 .PATH: ${S}/kern
-SRCS=  exec_elf32.c core_elf32.c
+SRCS=  exec_elf32.c
 
 WARNS= 3
 
diff -r 343fe0330855 -r 43355226ab9e sys/modules/exec_elf64/Makefile
--- a/sys/modules/exec_elf64/Makefile   Mon Oct 19 19:14:11 2020 +0000
+++ b/sys/modules/exec_elf64/Makefile   Mon Oct 19 19:33:01 2020 +0000
@@ -1,4 +1,4 @@
-#      $NetBSD: Makefile,v 1.4 2019/11/20 19:37:54 pgoyette Exp $



Home | Main Index | Thread Index | Old Index