1 1.35 tsutsui /* $NetBSD: db_machdep.h,v 1.35 2023/09/26 14:33:55 tsutsui Exp $ */ 2 1.12 cgd 3 1.34 tsutsui /* 4 1.1 glass * Mach Operating System 5 1.1 glass * Copyright (c) 1992 Carnegie Mellon University 6 1.1 glass * All Rights Reserved. 7 1.34 tsutsui * 8 1.1 glass * Permission to use, copy, modify and distribute this software and its 9 1.1 glass * documentation is hereby granted, provided that both the copyright 10 1.1 glass * notice and this permission notice appear in all copies of the 11 1.1 glass * software, derivative works or modified versions, and any portions 12 1.1 glass * thereof, and that both notices appear in supporting documentation. 13 1.34 tsutsui * 14 1.1 glass * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS" 15 1.1 glass * CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR 16 1.1 glass * ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE. 17 1.34 tsutsui * 18 1.1 glass * Carnegie Mellon requests users of this software to return to 19 1.34 tsutsui * 20 1.1 glass * Software Distribution Coordinator or Software.Distribution (at) CS.CMU.EDU 21 1.1 glass * School of Computer Science 22 1.1 glass * Carnegie Mellon University 23 1.1 glass * Pittsburgh PA 15213-3890 24 1.34 tsutsui * 25 1.34 tsutsui * any improvements or extensions that they make and grant Carnegie Mellon 26 1.1 glass * the rights to redistribute these changes. 27 1.1 glass */ 28 1.1 glass 29 1.1 glass /* 30 1.1 glass * Machine-dependent defines for new kernel debugger. 31 1.1 glass */ 32 1.3 cgd #ifndef _M68K_DB_MACHDEP_H_ 33 1.3 cgd #define _M68K_DB_MACHDEP_H_ 34 1.1 glass 35 1.31 mlelstv #if !defined(_KERNEL) && !defined(_STANDALONE) 36 1.31 mlelstv #include <stddef.h> 37 1.31 mlelstv #include <stdbool.h> 38 1.31 mlelstv #include <string.h> 39 1.31 mlelstv #endif /* _KERNEL || _STANDALONE */ 40 1.31 mlelstv 41 1.19 gwr #include <sys/types.h> 42 1.19 gwr 43 1.32 christos #include <uvm/uvm_extern.h> 44 1.15 gwr 45 1.15 gwr #include <machine/frame.h> 46 1.28 rmind #include <machine/pcb.h> 47 1.1 glass #include <machine/psl.h> 48 1.1 glass #include <machine/trap.h> 49 1.1 glass 50 1.21 leo typedef vaddr_t db_addr_t; /* address - unsigned */ 51 1.30 joerg #define DDB_EXPR_FMT "l" /* expression is long */ 52 1.16 scottr typedef long db_expr_t; /* expression - signed */ 53 1.15 gwr typedef struct trapframe db_regs_t; 54 1.15 gwr 55 1.19 gwr extern db_regs_t ddb_regs; /* register state */ 56 1.1 glass #define DDB_REGS (&ddb_regs) 57 1.1 glass 58 1.23 kristerw #define PC_REGS(regs) ((regs)->tf_pc) 59 1.1 glass 60 1.24 scw #define BKPT_ADDR(addr) (addr) /* breakpoint address */ 61 1.1 glass #define BKPT_INST 0x4e4f /* breakpoint instruction */ 62 1.1 glass #define BKPT_SIZE (2) /* size of breakpoint inst */ 63 1.27 cherry #define BKPT_SET(inst, addr) (BKPT_INST) 64 1.1 glass 65 1.17 gwr #define FIXUP_PC_AFTER_BREAK(regs) ((regs)->tf_pc -= BKPT_SIZE) 66 1.1 glass 67 1.19 gwr #define db_clear_single_step(regs) ((regs)->tf_sr &= ~PSL_T) 68 1.19 gwr #define db_set_single_step(regs) ((regs)->tf_sr |= PSL_T) 69 1.1 glass 70 1.4 mycroft #define IS_BREAKPOINT_TRAP(type, code) ((type) == T_BREAKPOINT) 71 1.5 mycroft #ifdef T_WATCHPOINT 72 1.1 glass #define IS_WATCHPOINT_TRAP(type, code) ((type) == T_WATCHPOINT) 73 1.5 mycroft #else 74 1.5 mycroft #define IS_WATCHPOINT_TRAP(type, code) 0 75 1.5 mycroft #endif 76 1.1 glass 77 1.1 glass #define M_RTS 0xffff0000 78 1.1 glass #define I_RTS 0x4e750000 79 1.1 glass #define M_JSR 0xffc00000 80 1.1 glass #define I_JSR 0x4e800000 81 1.1 glass #define M_BSR 0xff000000 82 1.1 glass #define I_BSR 0x61000000 83 1.1 glass #define M_RTE 0xffff0000 84 1.1 glass #define I_RTE 0x4e730000 85 1.1 glass 86 1.1 glass #define inst_trap_return(ins) (((ins)&M_RTE) == I_RTE) 87 1.1 glass #define inst_return(ins) (((ins)&M_RTS) == I_RTS) 88 1.1 glass #define inst_call(ins) (((ins)&M_JSR) == I_JSR || \ 89 1.1 glass ((ins)&M_BSR) == I_BSR) 90 1.1 glass #define inst_load(ins) 0 91 1.1 glass #define inst_store(ins) 0 92 1.13 leo 93 1.18 gwr /* 94 1.18 gwr * Things needed by kgdb: 95 1.18 gwr */ 96 1.18 gwr typedef long kgdb_reg_t; 97 1.18 gwr #define KGDB_NUMREGS (16+2) 98 1.18 gwr #define KGDB_BUFLEN 512 99 1.18 gwr 100 1.18 gwr 101 1.13 leo #ifdef _KERNEL 102 1.13 leo 103 1.25 thorpej void Debugger(void); /* XXX */ 104 1.25 thorpej void kdb_kintr(db_regs_t *); 105 1.35 tsutsui int kdb_trap(int, db_regs_t *); 106 1.13 leo 107 1.13 leo #endif /* _KERNEL */ 108 1.20 thorpej 109 1.20 thorpej /* 110 1.29 mrg * We use Elf32 symbols in DDB. 111 1.20 thorpej */ 112 1.25 thorpej #define DB_ELF_SYMBOLS 113 1.1 glass 114 1.7 mycroft #endif /* _M68K_DB_MACHDEP_H_ */ 115