#ifndef _KVM_H
#define _KVM_H
#include <mdb/mdb_modapi.h>
#include <mdb/mdb_target.h>
#include <kmdb/kmdb_dpi.h>
#include <kmdb/kvm_isadep.h>
#include <sys/kobj.h>
#ifdef __cplusplus
extern "C" {
#endif
#define KM_F_PRIMARY 1
#define KMT_TRAP_NOTENUM -1
#define KMT_TRAP_ALL -2
typedef struct kmt_module {
mdb_list_t km_list;
char *km_name;
char km_seen;
GElf_Ehdr km_ehdr;
mdb_gelf_symtab_t *km_symtab;
Shdr km_symtab_hdr;
Shdr km_strtab_hdr;
const void *km_symtab_va;
const void *km_strtab_va;
uintptr_t km_text_va;
size_t km_text_size;
uintptr_t km_data_va;
size_t km_data_size;
uintptr_t km_bss_va;
size_t km_bss_size;
const void *km_ctf_va;
size_t km_ctf_size;
ctf_file_t *km_ctfp;
struct modctl km_modctl;
struct module km_module;
int km_flags;
} kmt_module_t;
typedef struct kmt_data {
const mdb_tgt_regdesc_t *kmt_rds;
mdb_nv_t kmt_modules;
mdb_list_t kmt_modlist;
const char *kmt_rtld_name;
caddr_t kmt_writemap;
size_t kmt_writemapsz;
mdb_map_t kmt_map;
ulong_t *kmt_trapmap;
size_t kmt_trapmax;
int kmt_symavail;
uint_t kmt_narmedbpts;
#if defined(__i386) || defined(__amd64)
struct {
GElf_Sym _kmt_cmnint;
GElf_Sym _kmt_cmntrap;
GElf_Sym _kmt_sysenter;
GElf_Sym _kmt_brand_sysenter;
#if defined(__amd64)
GElf_Sym _kmt_syscall;
GElf_Sym _kmt_brand_syscall;
#endif
} kmt_intrsyms;
#endif
} kmt_data_t;
#if defined(__i386) || defined(__amd64)
#define kmt_cmnint kmt_intrsyms._kmt_cmnint
#define kmt_cmntrap kmt_intrsyms._kmt_cmntrap
#endif
typedef struct kmt_defbp {
mdb_list_t dbp_bplist;
char *dbp_objname;
char *dbp_symname;
int dbp_ref;
} kmt_defbp_t;
typedef struct kmt_brkpt {
uintptr_t kb_addr;
mdb_instr_t kb_oinstr;
} kmt_brkpt_t;
typedef struct kmt_bparg {
uintptr_t ka_addr;
char *ka_symbol;
kmt_defbp_t *ka_defbp;
} kmt_bparg_t;
extern void kmt_printregs(const mdb_tgt_gregset_t *gregs);
extern const char *kmt_def_dismode(void);
extern void kmt_init_isadep(mdb_tgt_t *);
extern void kmt_startup_isadep(mdb_tgt_t *);
extern ssize_t kmt_write(mdb_tgt_t *, const void *, size_t, uintptr_t);
extern ssize_t kmt_pwrite(mdb_tgt_t *, const void *, size_t, physaddr_t);
extern ssize_t kmt_rw(mdb_tgt_t *, void *, size_t, uint64_t,
ssize_t (*)(void *, size_t, uint64_t));
extern ssize_t kmt_writer(void *, size_t, uint64_t);
extern ssize_t kmt_ioread(mdb_tgt_t *, void *, size_t, uintptr_t);
extern ssize_t kmt_iowrite(mdb_tgt_t *, const void *, size_t, uintptr_t);
extern int kmt_step_out(mdb_tgt_t *, uintptr_t *);
extern int kmt_next(mdb_tgt_t *, uintptr_t *);
extern int kmt_stack(uintptr_t, uint_t, int, const mdb_arg_t *);
extern int kmt_stackv(uintptr_t, uint_t, int, const mdb_arg_t *);
extern int kmt_stackr(uintptr_t, uint_t, int, const mdb_arg_t *);
extern int kmt_cpustack(uintptr_t, uint_t, int, const mdb_arg_t *, int, uint_t);
extern const char *kmt_trapname(int);
#ifdef __cplusplus
}
#endif
#endif