kaif.h revision 9acbbeaf2a1ffe5c14b244867d427714fab43c5c
da2e3ebdc1edfbc5028edf1354e7dd2fa69a7968chin/*
da2e3ebdc1edfbc5028edf1354e7dd2fa69a7968chin * CDDL HEADER START
da2e3ebdc1edfbc5028edf1354e7dd2fa69a7968chin *
3e14f97f673e8a630f076077de35afdd43dc1587Roger A. Faulkner * The contents of this file are subject to the terms of the
da2e3ebdc1edfbc5028edf1354e7dd2fa69a7968chin * Common Development and Distribution License (the "License").
da2e3ebdc1edfbc5028edf1354e7dd2fa69a7968chin * You may not use this file except in compliance with the License.
7c2fbfb345896881c631598ee3852ce9ce33fb07April Chin *
da2e3ebdc1edfbc5028edf1354e7dd2fa69a7968chin * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
da2e3ebdc1edfbc5028edf1354e7dd2fa69a7968chin * or http://www.opensolaris.org/os/licensing.
da2e3ebdc1edfbc5028edf1354e7dd2fa69a7968chin * See the License for the specific language governing permissions
da2e3ebdc1edfbc5028edf1354e7dd2fa69a7968chin * and limitations under the License.
da2e3ebdc1edfbc5028edf1354e7dd2fa69a7968chin *
da2e3ebdc1edfbc5028edf1354e7dd2fa69a7968chin * When distributing Covered Code, include this CDDL HEADER in each
da2e3ebdc1edfbc5028edf1354e7dd2fa69a7968chin * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
da2e3ebdc1edfbc5028edf1354e7dd2fa69a7968chin * If applicable, add the following below this CDDL HEADER, with the
da2e3ebdc1edfbc5028edf1354e7dd2fa69a7968chin * fields enclosed by brackets "[]" replaced with your own identifying
da2e3ebdc1edfbc5028edf1354e7dd2fa69a7968chin * information: Portions Copyright [yyyy] [name of copyright owner]
da2e3ebdc1edfbc5028edf1354e7dd2fa69a7968chin *
da2e3ebdc1edfbc5028edf1354e7dd2fa69a7968chin * CDDL HEADER END
da2e3ebdc1edfbc5028edf1354e7dd2fa69a7968chin */
da2e3ebdc1edfbc5028edf1354e7dd2fa69a7968chin/*
da2e3ebdc1edfbc5028edf1354e7dd2fa69a7968chin * Copyright 2006 Sun Microsystems, Inc. All rights reserved.
da2e3ebdc1edfbc5028edf1354e7dd2fa69a7968chin * Use is subject to license terms.
da2e3ebdc1edfbc5028edf1354e7dd2fa69a7968chin */
da2e3ebdc1edfbc5028edf1354e7dd2fa69a7968chin
da2e3ebdc1edfbc5028edf1354e7dd2fa69a7968chin#ifndef _KAIF_H
da2e3ebdc1edfbc5028edf1354e7dd2fa69a7968chin#define _KAIF_H
da2e3ebdc1edfbc5028edf1354e7dd2fa69a7968chin
da2e3ebdc1edfbc5028edf1354e7dd2fa69a7968chin#pragma ident "%Z%%M% %I% %E% SMI"
da2e3ebdc1edfbc5028edf1354e7dd2fa69a7968chin
da2e3ebdc1edfbc5028edf1354e7dd2fa69a7968chin#ifndef _ASM
da2e3ebdc1edfbc5028edf1354e7dd2fa69a7968chin#include <sys/kdi.h>
da2e3ebdc1edfbc5028edf1354e7dd2fa69a7968chin#include <sys/types.h>
da2e3ebdc1edfbc5028edf1354e7dd2fa69a7968chin#include <sys/segments.h>
da2e3ebdc1edfbc5028edf1354e7dd2fa69a7968chin#include <kmdb/kaif_regs.h>
da2e3ebdc1edfbc5028edf1354e7dd2fa69a7968chin#endif
da2e3ebdc1edfbc5028edf1354e7dd2fa69a7968chin
da2e3ebdc1edfbc5028edf1354e7dd2fa69a7968chin#ifdef __cplusplus
da2e3ebdc1edfbc5028edf1354e7dd2fa69a7968chinextern "C" {
da2e3ebdc1edfbc5028edf1354e7dd2fa69a7968chin#endif
da2e3ebdc1edfbc5028edf1354e7dd2fa69a7968chin
da2e3ebdc1edfbc5028edf1354e7dd2fa69a7968chin#define KAIF_MASTER_CPUID_UNSET -1
#define KAIF_CPU_CMD_RESUME 0
#define KAIF_CPU_CMD_RESUME_MASTER 1
#define KAIF_CPU_CMD_SWITCH 2
#define KAIF_CPU_CMD_PASS_TO_KERNEL 3
#define KAIF_CPU_CMD_REBOOT 4
#define KAIF_CPU_STATE_NONE 0
#define KAIF_CPU_STATE_MASTER 1
#define KAIF_CPU_STATE_SLAVE 2
#ifndef _ASM
typedef struct kaif_memrange {
caddr_t mr_base;
caddr_t mr_lim;
} kaif_memrange_t;
extern kaif_memrange_t kaif_memranges[];
extern int kaif_nmemranges;
extern kaif_cpusave_t *kaif_cpusave;
extern int kaif_ncpusave;
extern int kaif_master_cpuid;
extern uint32_t kaif_cs;
extern uint32_t kaif_ds;
extern uint32_t kaif_fs;
extern uint32_t kaif_gs;
extern char kaif_slave_entry_patch;
extern struct gate_desc kaif_idt[];
extern desctbr_t kaif_idtr;
extern size_t kaif_ivct_size;
extern int kaif_trap_switch;
extern uintptr_t kaif_kernel_handler;
extern uintptr_t kaif_sys_sysenter;
extern uintptr_t kaif_brand_sys_sysenter;
extern void kaif_trap_set_debugger(void);
extern void kaif_trap_set_saved(kaif_cpusave_t *);
extern uintptr_t kaif_invoke(uintptr_t, uint_t, const uintptr_t[]);
extern void kaif_nmiint(void);
extern void kaif_cmnint(void);
extern void kaif_enter(void);
extern void kaif_slave_entry(void);
extern int kaif_debugger_entry(kaif_cpusave_t *);
extern void kaif_mod_loaded(struct modctl *);
extern void kaif_mod_unloading(struct modctl *);
extern void kaif_cpu_debug_init(kaif_cpusave_t *);
extern void kaif_idt_init(void);
extern void kaif_idt_write(gate_desc_t *, uint_t);
extern void kaif_idt_patch(caddr_t, size_t);
extern uintptr_t kaif_kernel_trap2hdlr(int);
extern void kaif_activate(kdi_debugvec_t **, uint_t);
extern void kaif_deactivate(void);
extern int kaif_memrange_add(caddr_t, size_t);
extern void get_idt(desctbr_t *);
extern void set_idt(desctbr_t *);
#endif
#ifdef __cplusplus
}
#endif
#endif /* _KAIF_H */