Source-Changes-HG archive

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

[src/trunk]: src/sys/arch/mips On MIPS use a helper function to work out the ...



details:   https://anonhg.NetBSD.org/src/rev/ec47d6796555
branches:  trunk
changeset: 1018627:ec47d6796555
user:      simonb <simonb%NetBSD.org@localhost>
date:      Wed Feb 10 07:19:54 2021 +0000

description:
On MIPS use a helper function to work out the current PC and then
call stacktrace_subr() directly for displaying a stacktrace with
db_stacktrace() and friends.

diffstat:

 sys/arch/mips/include/db_machdep.h |   7 ++++++-
 sys/arch/mips/mips/db_trace.c      |  26 +++++++++++++++++---------
 2 files changed, 23 insertions(+), 10 deletions(-)

diffs (83 lines):

diff -r e1ea95d68281 -r ec47d6796555 sys/arch/mips/include/db_machdep.h
--- a/sys/arch/mips/include/db_machdep.h        Wed Feb 10 07:17:39 2021 +0000
+++ b/sys/arch/mips/include/db_machdep.h        Wed Feb 10 07:19:54 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: db_machdep.h,v 1.33 2020/08/17 03:19:35 mrg Exp $ */
+/* $NetBSD: db_machdep.h,v 1.34 2021/02/10 07:19:54 simonb Exp $ */
 
 /*
  * Copyright (c) 1997 Jonathan Stone (hereinafter referred to as the author)
@@ -127,6 +127,7 @@
 bool ddb_running_on_this_cpu_p(void);
 bool ddb_running_on_any_cpu_p(void);
 void db_resume_others(void);
+void db_mips_stack_trace(void *, void *, void (*pr)(const char *, ...));
 
 extern void (*cpu_reset_address)(void);
 
@@ -137,4 +138,8 @@
 #define        DB_MACHINE_COMMANDS
 #endif
 
+#define        db_stacktrace_print(prfunc) \
+    db_mips_stack_trace(__builtin_return_address(0), \
+       __builtin_frame_address(0), prfunc)
+
 #endif /* _MIPS_DB_MACHDEP_H_ */
diff -r e1ea95d68281 -r ec47d6796555 sys/arch/mips/mips/db_trace.c
--- a/sys/arch/mips/mips/db_trace.c     Wed Feb 10 07:17:39 2021 +0000
+++ b/sys/arch/mips/mips/db_trace.c     Wed Feb 10 07:19:54 2021 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: db_trace.c,v 1.49 2021/02/09 13:28:47 simonb Exp $     */
+/*     $NetBSD: db_trace.c,v 1.50 2021/02/10 07:19:54 simonb Exp $     */
 
 /*
  * Mach Operating System
@@ -27,7 +27,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: db_trace.c,v 1.49 2021/02/09 13:28:47 simonb Exp $");
+__KERNEL_RCSID(0, "$NetBSD: db_trace.c,v 1.50 2021/02/10 07:19:54 simonb Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_ddb.h"
@@ -74,10 +74,6 @@
  */
 struct mips_saved_state *db_cur_exc_frame = 0;
 
-/*
- * Stack trace helper.
- */
-void db_mips_stack_trace(int, vaddr_t, vaddr_t, vaddr_t, int, vaddr_t);
 int db_mips_variable_func(const struct db_variable *, db_expr_t *, int);
 
 #define DB_SETF_REGS db_mips_variable_func
@@ -289,12 +285,24 @@
 #endif
 }
 
+/*
+ * Helper function for db_stacktrace() and friends, used to get the
+ * pc via the return address.
+ */
 void
-db_mips_stack_trace(int count, vaddr_t stackp, vaddr_t the_pc, vaddr_t the_ra,
-    int flags, vaddr_t kstackp)
+db_mips_stack_trace(void *ra, void *fp, void (*pr)(const char *, ...))
 {
+       vaddr_t pc;
 
-       /* nothing... */
+       /*
+        * The jal instruction for our caller is two insns before the
+        * return address.
+        */
+       pc = (vaddr_t)__builtin_return_address(0) - sizeof(uint32_t) * 2;
+
+       stacktrace_subr(0, 0, 0, 0,     /* no args known */
+           pc, (intptr_t)fp, (intptr_t)fp, (intptr_t)ra,
+           pr);
 }
 
 int



Home | Main Index | Thread Index | Old Index