Source-Changes-HG archive

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

[src/trunk]: src/sys/arch/aarch64/aarch64 instead of reading memory directly,...



details:   https://anonhg.NetBSD.org/src/rev/ea2d6a9f2011
branches:  trunk
changeset: 1010300:ea2d6a9f2011
user:      ryo <ryo%NetBSD.org@localhost>
date:      Fri May 22 04:46:26 2020 +0000

description:
instead of reading memory directly, db_read_bytes() is used to avoid faults in ddb.

diffstat:

 sys/arch/aarch64/aarch64/db_machdep.c |  24 +++++++++++++++++-------
 1 files changed, 17 insertions(+), 7 deletions(-)

diffs (66 lines):

diff -r 3dfe0067438e -r ea2d6a9f2011 sys/arch/aarch64/aarch64/db_machdep.c
--- a/sys/arch/aarch64/aarch64/db_machdep.c     Fri May 22 01:28:44 2020 +0000
+++ b/sys/arch/aarch64/aarch64/db_machdep.c     Fri May 22 04:46:26 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: db_machdep.c,v 1.22 2020/05/13 05:37:16 chs Exp $ */
+/* $NetBSD: db_machdep.c,v 1.23 2020/05/22 04:46:26 ryo Exp $ */
 
 /*-
  * Copyright (c) 2014 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: db_machdep.c,v 1.22 2020/05/13 05:37:16 chs Exp $");
+__KERNEL_RCSID(0, "$NetBSD: db_machdep.c,v 1.23 2020/05/22 04:46:26 ryo Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_compat_netbsd32.h"
@@ -196,6 +196,11 @@
 void
 dump_trapframe(struct trapframe *tf, void (*pr)(const char *, ...))
 {
+       struct trapframe tf_buf;
+
+       db_read_bytes((db_addr_t)tf, sizeof(tf_buf), (char *)&tf_buf);
+       tf = &tf_buf;
+
 #ifdef COMPAT_NETBSD32
        if (tf->tf_spsr & SPSR_A32) {
                (*pr)("    pc=%016"PRIxREGISTER",   spsr=%016"PRIxREGISTER
@@ -342,25 +347,30 @@
 db_md_lwp_cmd(db_expr_t addr, bool have_addr, db_expr_t count,
     const char *modif)
 {
-       lwp_t *l;
-       struct pcb *pcb;
+       lwp_t *l, lwp_buf;
+       struct pcb *pcb, pcb_buf;
 
        if (!have_addr) {
                db_printf("lwp address must be specified\n");
                return;
        }
-       l = (lwp_t *)addr;
+
+       db_read_bytes(addr, sizeof(lwp_buf), (char *)&lwp_buf);
+       l = &lwp_buf;
 
 #define SAFESTRPTR(p)  (((p) == NULL) ? "NULL" : (p))
 
-       db_printf("lwp=%p\n", l);
+       db_printf("lwp=%p\n", (void *)addr);
 
        db_printf("\tlwp_getpcb(l)     =%p\n", lwp_getpcb(l));
 
        db_printf("\tl->l_md.md_onfault=%p\n", l->l_md.md_onfault);
        db_printf("\tl->l_md.md_utf    =%p\n", l->l_md.md_utf);
        dump_trapframe(l->l_md.md_utf, db_printf);
-       pcb = l->l_addr;
+
+       db_read_bytes((db_addr_t)l->l_addr, sizeof(pcb_buf), (char *)&pcb_buf);
+       pcb = &pcb_buf;
+
        db_printf("\tl->l_addr.pcb_tf    =%p\n", pcb->pcb_tf);
        if (pcb->pcb_tf != l->l_md.md_utf)
                dump_trapframe(pcb->pcb_tf, db_printf);



Home | Main Index | Thread Index | Old Index