1 /* $NetBSD: db_machdep.c,v 1.7 2002/01/05 22:41:47 chris Exp $ */ 2 3 /* 4 * Copyright (c) 1996 Mark Brinicombe 5 * 6 * Mach Operating System 7 * Copyright (c) 1991,1990 Carnegie Mellon University 8 * All Rights Reserved. 9 * 10 * Permission to use, copy, modify and distribute this software and its 11 * documentation is hereby granted, provided that both the copyright 12 * notice and this permission notice appear in all copies of the 13 * software, derivative works or modified versions, and any portions 14 * thereof, and that both notices appear in supporting documentation. 15 * 16 * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS" 17 * CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR 18 * ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE. 19 * 20 * Carnegie Mellon requests users of this software to return to 21 * 22 * Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU 23 * School of Computer Science 24 * Carnegie Mellon University 25 * Pittsburgh PA 15213-3890 26 * 27 * any improvements or extensions that they make and grant Carnegie the 28 * rights to redistribute these changes. 29 */ 30 31 #include <sys/param.h> 32 #include <sys/proc.h> 33 #include <sys/vnode.h> 34 #include <sys/systm.h> 35 36 #include <arm/arm32/db_machdep.h> 37 38 #include <ddb/db_access.h> 39 #include <ddb/db_sym.h> 40 #include <ddb/db_output.h> 41 42 43 void 44 db_show_panic_cmd(addr, have_addr, count, modif) 45 db_expr_t addr; 46 int have_addr; 47 db_expr_t count; 48 char *modif; 49 { 50 int s; 51 52 s = splhigh(); 53 54 db_printf("Panic string: %s\n", panicstr); 55 56 (void)splx(s); 57 } 58 59 60 void 61 db_show_frame_cmd(addr, have_addr, count, modif) 62 db_expr_t addr; 63 int have_addr; 64 db_expr_t count; 65 char *modif; 66 { 67 struct trapframe *frame; 68 69 if (!have_addr) { 70 db_printf("frame address must be specified\n"); 71 return; 72 } 73 74 frame = (struct trapframe *)addr; 75 76 db_printf("frame address = %08x ", (u_int)frame); 77 db_printf("spsr=%08x\n", frame->tf_spsr); 78 db_printf("r0 =%08x r1 =%08x r2 =%08x r3 =%08x\n", 79 frame->tf_r0, frame->tf_r1, frame->tf_r2, frame->tf_r3); 80 db_printf("r4 =%08x r5 =%08x r6 =%08x r7 =%08x\n", 81 frame->tf_r4, frame->tf_r5, frame->tf_r6, frame->tf_r7); 82 db_printf("r8 =%08x r9 =%08x r10=%08x r11=%08x\n", 83 frame->tf_r8, frame->tf_r9, frame->tf_r10, frame->tf_r11); 84 db_printf("r12=%08x r13=%08x r14=%08x r15=%08x\n", 85 frame->tf_r12, frame->tf_usr_sp, frame->tf_usr_lr, frame->tf_pc); 86 db_printf("slr=%08x\n", frame->tf_svc_lr); 87 } 88