4 * The contents of this file are subject to the terms of the
5 * Common Development and Distribution License (the "License").
6 * You may not use this file except in compliance with the License.
8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 * or http://www.opensolaris.org/os/licensing.
10 * See the License for the specific language governing permissions
11 * and limitations under the License.
13 * When distributing Covered Code, include this CDDL HEADER in each
14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 * If applicable, add the following below this CDDL HEADER, with the
16 * fields enclosed by brackets "[]" replaced with your own identifying
17 * information: Portions Copyright [yyyy] [name of copyright owner]
22 * Copyright 2007 Sun Microsystems, Inc. All rights reserved.
23 * Use is subject to license terms.
25 * Copyright 2018 Joyent, Inc.
35 #include <mdb/mdb_modapi.h>
36 #include <mdb/mdb_target.h>
37 #include <kmdb/kmdb_dpi.h>
38 #include <kmdb/kvm_isadep.h>
46 #define KM_F_PRIMARY 1
48 #define KMT_TRAP_NOTENUM -1 /* Glob for unnamed traps */
49 #define KMT_TRAP_ALL -2 /* Glob for all traps */
51 typedef struct kmt_module
{
52 mdb_list_t km_list
; /* List forward/back pointers */
53 char *km_name
; /* Module name */
57 mdb_gelf_symtab_t
*km_symtab
;
60 const void *km_symtab_va
;
61 const void *km_strtab_va
;
69 const void *km_ctf_va
;
73 struct modctl km_modctl
;
74 struct module km_module
;
78 typedef struct kmt_data
{
79 const mdb_tgt_regdesc_t
*kmt_rds
; /* Register description table */
80 mdb_nv_t kmt_modules
; /* Hash table of modules */
81 mdb_list_t kmt_modlist
; /* List of mods in load order */
82 const char *kmt_rtld_name
; /* Module containing krtld */
83 caddr_t kmt_writemap
; /* Used to map PAs for writes */
84 size_t kmt_writemapsz
; /* Size of same */
85 mdb_map_t kmt_map
; /* Persistant map for callers */
88 int kmt_symavail
; /* Symbol resolution allowed */
89 uint_t kmt_narmedbpts
; /* Number of armed brkpts */
90 #if defined(__i386) || defined(__amd64)
93 GElf_Sym _kmt_cmntrap
;
94 GElf_Sym _kmt_sysenter
;
95 GElf_Sym _kmt_brand_sysenter
;
97 GElf_Sym _kmt_syscall
;
98 GElf_Sym _kmt_brand_syscall
;
104 #if defined(__i386) || defined(__amd64)
105 #define kmt_cmnint kmt_intrsyms._kmt_cmnint
106 #define kmt_cmntrap kmt_intrsyms._kmt_cmntrap
109 typedef struct kmt_defbp
{
110 mdb_list_t dbp_bplist
;
116 typedef struct kmt_brkpt
{
117 uintptr_t kb_addr
; /* Breakpoint address */
118 mdb_instr_t kb_oinstr
; /* Replaced instruction */
121 typedef struct kmt_bparg
{
122 uintptr_t ka_addr
; /* Explicit address */
123 char *ka_symbol
; /* Symbolic name */
124 kmt_defbp_t
*ka_defbp
;
127 extern void kmt_printregs(const mdb_tgt_gregset_t
*gregs
);
129 extern const char *kmt_def_dismode(void);
131 extern void kmt_init_isadep(mdb_tgt_t
*);
132 extern void kmt_startup_isadep(mdb_tgt_t
*);
134 extern ssize_t
kmt_write(mdb_tgt_t
*, const void *, size_t, uintptr_t);
135 extern ssize_t
kmt_pwrite(mdb_tgt_t
*, const void *, size_t, physaddr_t
);
136 extern ssize_t
kmt_rw(mdb_tgt_t
*, void *, size_t, uint64_t,
137 ssize_t (*)(void *, size_t, uint64_t));
138 extern ssize_t
kmt_writer(void *, size_t, uint64_t);
139 extern ssize_t
kmt_ioread(mdb_tgt_t
*, void *, size_t, uintptr_t);
140 extern ssize_t
kmt_iowrite(mdb_tgt_t
*, const void *, size_t, uintptr_t);
142 extern int kmt_step_out(mdb_tgt_t
*, uintptr_t *);
143 extern int kmt_next(mdb_tgt_t
*, uintptr_t *);
145 extern int kmt_stack(uintptr_t, uint_t
, int, const mdb_arg_t
*);
146 extern int kmt_stackv(uintptr_t, uint_t
, int, const mdb_arg_t
*);
147 extern int kmt_stackr(uintptr_t, uint_t
, int, const mdb_arg_t
*);
148 extern int kmt_cpustack(uintptr_t, uint_t
, int, const mdb_arg_t
*, int, int);
150 extern const char *kmt_trapname(int);