Source-Changes-HG archive

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

[src/trunk]: src/sys/arch/mips port crash(8) to mips. (most of the kernel si...



details:   https://anonhg.NetBSD.org/src/rev/6e008e89263d
branches:  trunk
changeset: 1012965:6e008e89263d
user:      mrg <mrg%NetBSD.org@localhost>
date:      Mon Aug 17 03:19:35 2020 +0000

description:
port crash(8) to mips.  (most of the kernel side.)

- expose parts of _KERNEL to _KMEMUSER as well
- hide more things for _KERNEL
- avoid DB_MACHINE_COMMANDS in crash(8)
- XXX add mips_label_t for !_KERNEL and use it in the pcb to
  avoid conflicting with the ddb/crash one
- enable dumppcb

some changes to make stack trace fail instead of SEGV and
the userland changes to crash itself not part of this change.

diffstat:

 sys/arch/mips/include/cpu.h          |   8 ++++++--
 sys/arch/mips/include/db_machdep.h   |   8 +++++++-
 sys/arch/mips/include/locore.h       |   6 +++---
 sys/arch/mips/include/mips3_pte.h    |   4 +++-
 sys/arch/mips/include/pcb.h          |   4 ++--
 sys/arch/mips/include/pmap.h         |   3 ++-
 sys/arch/mips/include/types.h        |  10 +++++++++-
 sys/arch/mips/mips/db_interface.c    |  10 ++++++++--
 sys/arch/mips/mips/mips_stacktrace.c |  21 ++++++++++++++-------
 9 files changed, 54 insertions(+), 20 deletions(-)

diffs (truncated from 320 to 300 lines):

diff -r 8a1226791b03 -r 6e008e89263d sys/arch/mips/include/cpu.h
--- a/sys/arch/mips/include/cpu.h       Mon Aug 17 03:14:08 2020 +0000
+++ b/sys/arch/mips/include/cpu.h       Mon Aug 17 03:19:35 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: cpu.h,v 1.130 2020/08/09 06:26:49 skrll Exp $  */
+/*     $NetBSD: cpu.h,v 1.131 2020/08/17 03:19:35 mrg Exp $    */
 
 /*-
  * Copyright (c) 1992, 1993
@@ -45,7 +45,7 @@
 #error Use assym.h to get definitions from <mips/cpu.h>
 #endif
 
-#ifdef _KERNEL
+#if defined(_KERNEL) || defined(_KMEMUSER)
 
 #if defined(_KERNEL_OPT)
 #include "opt_cputype.h"
@@ -57,6 +57,7 @@
 #include <sys/device_if.h>
 #include <sys/evcnt.h>
 #include <sys/kcpuset.h>
+#include <sys/intr.h>
 
 typedef struct cpu_watchpoint {
        register_t      cw_addr;
@@ -158,6 +159,9 @@
 #endif
 
 };
+#endif /* _KERNEL || _KMEMUSER */
+
+#ifdef _KERNEL
 
 #ifdef MULTIPROCESSOR
 #define        CPU_INFO_ITERATOR               int
diff -r 8a1226791b03 -r 6e008e89263d sys/arch/mips/include/db_machdep.h
--- a/sys/arch/mips/include/db_machdep.h        Mon Aug 17 03:14:08 2020 +0000
+++ b/sys/arch/mips/include/db_machdep.h        Mon Aug 17 03:19:35 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: db_machdep.h,v 1.32 2020/07/26 08:08:41 simonb Exp $ */
+/* $NetBSD: db_machdep.h,v 1.33 2020/08/17 03:19:35 mrg Exp $ */
 
 /*
  * Copyright (c) 1997 Jonathan Stone (hereinafter referred to as the author)
@@ -34,7 +34,11 @@
 #ifndef        _MIPS_DB_MACHDEP_H_
 #define        _MIPS_DB_MACHDEP_H_
 
+#include <sys/types.h>
+#include <sys/stdbool.h>
+
 #include <uvm/uvm_param.h>             /* XXX  boolean_t */
+
 #include <mips/trap.h>                 /* T_BREAK */
 #include <mips/reg.h>                  /* register state */
 #include <mips/regnum.h>               /* symbolic register indices */
@@ -126,9 +130,11 @@
 
 extern void (*cpu_reset_address)(void);
 
+#ifdef _KERNEL
 /*
  * We have machine-dependent commands.
  */
 #define        DB_MACHINE_COMMANDS
+#endif
 
 #endif /* _MIPS_DB_MACHDEP_H_ */
diff -r 8a1226791b03 -r 6e008e89263d sys/arch/mips/include/locore.h
--- a/sys/arch/mips/include/locore.h    Mon Aug 17 03:14:08 2020 +0000
+++ b/sys/arch/mips/include/locore.h    Mon Aug 17 03:19:35 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: locore.h,v 1.114 2020/08/15 07:42:07 mrg Exp $ */
+/* $NetBSD: locore.h,v 1.115 2020/08/17 03:19:35 mrg Exp $ */
 
 /*
  * This file should not be included by MI code!!!
@@ -95,6 +95,7 @@
 
 /* XXX some .S files look for MIPS3_PLUS */
 #ifndef __ASSEMBLER__
+#ifdef _KERNEL
 
 /* XXX simonb
  * Should the following be in a cpu_info type structure?
@@ -753,7 +754,6 @@
 #define            MIPS_PRID_CID_INGENIC       0xe1
 #define        MIPS_PRID_COPTS(x)      (((x) >> 24) & 0x00ff)  /* Company Options */
 
-#ifdef _KERNEL
 /*
  * Global variables used to communicate CPU type, and parameters
  * such as cache size, from locore to higher-level code (e.g., pmap).
@@ -917,7 +917,7 @@
 # define MIPS_CIDFL_RMI_L2SZ(cidfl)                                    \
                ((256*1024) << (((cidfl) & MIPS_CIDFL_RMI_L2SZ_MASK)    \
                        >> MIPS_CIDFL_RMI_L2SZ_SHIFT))
+#endif /* _KERNEL */
 #endif /* !__ASSEMBLER__ */
-#endif /* _KERNEL */
 
 #endif /* _MIPS_LOCORE_H */
diff -r 8a1226791b03 -r 6e008e89263d sys/arch/mips/include/mips3_pte.h
--- a/sys/arch/mips/include/mips3_pte.h Mon Aug 17 03:14:08 2020 +0000
+++ b/sys/arch/mips/include/mips3_pte.h Mon Aug 17 03:19:35 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: mips3_pte.h,v 1.30 2020/07/26 08:08:41 simonb Exp $    */
+/*     $NetBSD: mips3_pte.h,v 1.31 2020/08/17 03:19:35 mrg Exp $       */
 
 /*
  * Copyright (c) 1988 University of Utah.
@@ -174,6 +174,7 @@
 #define        MIPS3_PG_SIZE_64M       0x07ffe000
 #define        MIPS3_PG_SIZE_256M      0x1fffe000
 
+#ifdef _KERNEL
 #define        MIPS3_PG_SIZE_MASK_TO_SIZE(pg_mask)     \
     ((((pg_mask) | 0x00001fff) + 1) / 2)
 
@@ -182,6 +183,7 @@
 
 CTASSERT(MIPS3_PG_SIZE_TO_MASK(4096) == MIPS3_PG_SIZE_4K);
 CTASSERT(MIPS3_PG_SIZE_TO_MASK(8192) == MIPS3_PG_SIZE_4K);
+#endif
 
 /* NEC Vr41xx uses different pagemask values. */
 #define        MIPS4100_PG_SIZE_1K     0x00000000
diff -r 8a1226791b03 -r 6e008e89263d sys/arch/mips/include/pcb.h
--- a/sys/arch/mips/include/pcb.h       Mon Aug 17 03:14:08 2020 +0000
+++ b/sys/arch/mips/include/pcb.h       Mon Aug 17 03:19:35 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: pcb.h,v 1.24 2011/08/16 06:58:15 matt Exp $    */
+/*     $NetBSD: pcb.h,v 1.25 2020/08/17 03:19:35 mrg Exp $     */
 
 /*
  * Copyright (c) 1988 University of Utah.
@@ -56,7 +56,7 @@
  * MIPS process control block
  */
 struct pcb {
-       label_t pcb_context;            /* kernel context for resume */
+       mips_label_t pcb_context;       /* kernel context for resume */
        void *  pcb_onfault;            /* for copyin/copyout faults */
        uint32_t pcb_ppl;               /* previous priority level */
        struct fpreg pcb_fpregs;        /* saved floating point registers */
diff -r 8a1226791b03 -r 6e008e89263d sys/arch/mips/include/pmap.h
--- a/sys/arch/mips/include/pmap.h      Mon Aug 17 03:14:08 2020 +0000
+++ b/sys/arch/mips/include/pmap.h      Mon Aug 17 03:19:35 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: pmap.h,v 1.73 2020/08/07 07:19:45 skrll Exp $  */
+/*     $NetBSD: pmap.h,v 1.74 2020/08/17 03:19:35 mrg Exp $    */
 
 /*
  * Copyright (c) 1992, 1993
@@ -175,6 +175,7 @@
 #define        PMAP_SEGTABSIZE         (1 << (31 - SEGSHIFT))
 #endif
 
+#include <uvm/uvm_pmap.h>
 #include <uvm/pmap/vmpagemd.h>
 #include <uvm/pmap/pmap.h>
 #include <uvm/pmap/pmap_tlb.h>
diff -r 8a1226791b03 -r 6e008e89263d sys/arch/mips/include/types.h
--- a/sys/arch/mips/include/types.h     Mon Aug 17 03:14:08 2020 +0000
+++ b/sys/arch/mips/include/types.h     Mon Aug 17 03:19:35 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: types.h,v 1.71 2020/07/30 06:54:07 skrll Exp $ */
+/*     $NetBSD: types.h,v 1.72 2020/08/17 03:19:35 mrg Exp $   */
 
 /*-
  * Copyright (c) 1992, 1993
@@ -115,9 +115,17 @@
 #define        PRIxUREGISTER   PRIx64
 #endif /* __mips_o32 */
 
+#if defined(_KMEMUSER)
+typedef struct mips_label_t {
+       register_t val[14];
+} mips_label_t;
+#else
 typedef struct label_t {
        register_t val[14];
 } label_t;
+typedef label_t mips_label_t;
+#endif
+
 #define        _L_S0           0
 #define        _L_S1           1
 #define        _L_S2           2
diff -r 8a1226791b03 -r 6e008e89263d sys/arch/mips/mips/db_interface.c
--- a/sys/arch/mips/mips/db_interface.c Mon Aug 17 03:14:08 2020 +0000
+++ b/sys/arch/mips/mips/db_interface.c Mon Aug 17 03:19:35 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: db_interface.c,v 1.89 2020/08/15 07:42:07 mrg Exp $    */
+/*     $NetBSD: db_interface.c,v 1.90 2020/08/17 03:19:35 mrg Exp $    */
 
 /*
  * Mach Operating System
@@ -27,12 +27,14 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: db_interface.c,v 1.89 2020/08/15 07:42:07 mrg Exp $");
+__KERNEL_RCSID(0, "$NetBSD: db_interface.c,v 1.90 2020/08/17 03:19:35 mrg Exp $");
 
+#ifdef _KERNEL_OPT
 #include "opt_multiprocessor.h"
 #include "opt_cputype.h"       /* which mips CPUs do we support? */
 #include "opt_ddb.h"
 #include "opt_kgdb.h"
+#endif
 
 #define __PMAP_PRIVATE
 
@@ -57,6 +59,7 @@
 #include <machine/int_fmtio.h>
 #include <machine/db_machdep.h>
 #include <ddb/db_access.h>
+#include <ddb/db_user.h>
 #ifndef KGDB
 #include <ddb/db_command.h>
 #include <ddb/db_output.h>
@@ -92,6 +95,7 @@
 
 paddr_t kvtophys(vaddr_t);
 
+#ifdef _KERNEL
 CTASSERT(sizeof(ddb_regs) == sizeof(struct reg));
 
 #ifndef KGDB
@@ -1041,3 +1045,5 @@
        }
 }
 #endif /* MULTIPROCESSOR */
+
+#endif /* _KERNEL */
diff -r 8a1226791b03 -r 6e008e89263d sys/arch/mips/mips/mips_stacktrace.c
--- a/sys/arch/mips/mips/mips_stacktrace.c      Mon Aug 17 03:14:08 2020 +0000
+++ b/sys/arch/mips/mips/mips_stacktrace.c      Mon Aug 17 03:19:35 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: mips_stacktrace.c,v 1.1 2020/08/15 07:42:07 mrg Exp $  */
+/*     $NetBSD: mips_stacktrace.c,v 1.2 2020/08/17 03:19:35 mrg Exp $  */
 
 /*
  * Copyright (c) 1988 University of Utah.
@@ -40,7 +40,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: mips_stacktrace.c,v 1.1 2020/08/15 07:42:07 mrg Exp $");
+__KERNEL_RCSID(0, "$NetBSD: mips_stacktrace.c,v 1.2 2020/08/17 03:19:35 mrg Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_ddb.h"
@@ -59,6 +59,7 @@
 #include <machine/db_machdep.h>
 #include <ddb/db_sym.h>
 #endif
+#include <ddb/db_user.h>
 
 #ifdef KGDB
 #include <sys/kgdb.h>
@@ -122,7 +123,8 @@
  * Functions ``special'' enough to print by name
  */
 #define Name(_fn)  { (void*)_fn, # _fn }
-const static struct { void *addr; const char *name;} names[] = {
+static const struct { void *addr; const char *name;} names[] = {
+#ifdef _KERNEL
        Name(stacktrace),
        Name(stacktrace_subr),
        Name(main),
@@ -178,12 +180,13 @@
 
        Name(cpu_idle),
        Name(cpu_switchto),
+#endif /* _KERNEL */
        {0, 0}
 };
 
 
-bool
-static kdbpeek(vaddr_t addr, int *valp)
+static bool
+kdbpeek(vaddr_t addr, unsigned *valp)
 {
        if (addr & 3) {
                printf("kdbpeek: unaligned address %#"PRIxVADDR"\n", addr);
@@ -193,7 +196,7 @@
                printf("kdbpeek: NULL\n");
                return false;
        } else {
-               *valp = *(int *)addr;
+               *valp = *(unsigned *)addr;
                return true;
        }
 }
@@ -312,7 +315,7 @@
        sym = db_search_symbol(pc, DB_STGY_ANY, &diff);



Home | Main Index | Thread Index | Old Index