10Sstevel@tonic-gate /* 20Sstevel@tonic-gate * CDDL HEADER START 30Sstevel@tonic-gate * 40Sstevel@tonic-gate * The contents of this file are subject to the terms of the 53446Smrj * Common Development and Distribution License (the "License"). 63446Smrj * You may not use this file except in compliance with the License. 70Sstevel@tonic-gate * 80Sstevel@tonic-gate * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 90Sstevel@tonic-gate * or http://www.opensolaris.org/os/licensing. 100Sstevel@tonic-gate * See the License for the specific language governing permissions 110Sstevel@tonic-gate * and limitations under the License. 120Sstevel@tonic-gate * 130Sstevel@tonic-gate * When distributing Covered Code, include this CDDL HEADER in each 140Sstevel@tonic-gate * file and include the License file at usr/src/OPENSOLARIS.LICENSE. 150Sstevel@tonic-gate * If applicable, add the following below this CDDL HEADER, with the 160Sstevel@tonic-gate * fields enclosed by brackets "[]" replaced with your own identifying 170Sstevel@tonic-gate * information: Portions Copyright [yyyy] [name of copyright owner] 180Sstevel@tonic-gate * 190Sstevel@tonic-gate * CDDL HEADER END 200Sstevel@tonic-gate */ 210Sstevel@tonic-gate /* 223446Smrj * Copyright 2007 Sun Microsystems, Inc. All rights reserved. 230Sstevel@tonic-gate * Use is subject to license terms. 240Sstevel@tonic-gate */ 250Sstevel@tonic-gate 260Sstevel@tonic-gate #ifndef _SYS_KDI_MACHIMPL_H 270Sstevel@tonic-gate #define _SYS_KDI_MACHIMPL_H 280Sstevel@tonic-gate 290Sstevel@tonic-gate #pragma ident "%Z%%M% %I% %E% SMI" 300Sstevel@tonic-gate 310Sstevel@tonic-gate /* 320Sstevel@tonic-gate * The Kernel/Debugger interface. The operations provided by the kdi_t, 330Sstevel@tonic-gate * defined below, comprise the Debugger -> Kernel portion of the interface, 340Sstevel@tonic-gate * and are to be used only when the system has been stopped. 350Sstevel@tonic-gate */ 360Sstevel@tonic-gate 370Sstevel@tonic-gate #include <sys/modctl.h> 380Sstevel@tonic-gate #include <sys/types.h> 393446Smrj #include <sys/cpuvar.h> 403446Smrj #include <sys/kdi_regs.h> 410Sstevel@tonic-gate 420Sstevel@tonic-gate #ifdef __cplusplus 430Sstevel@tonic-gate extern "C" { 440Sstevel@tonic-gate #endif 450Sstevel@tonic-gate 463446Smrj typedef void (*kdi_main_t)(kdi_cpusave_t *); 473446Smrj 483446Smrj typedef struct kdi_memrange { 493446Smrj caddr_t mr_base; 503446Smrj caddr_t mr_lim; 513446Smrj } kdi_memrange_t; 523446Smrj 533446Smrj #define KDI_MEMRANGES_MAX 2 540Sstevel@tonic-gate 553446Smrj typedef struct kdi_mach { 563446Smrj void (*mkdi_activate)(kdi_main_t, kdi_cpusave_t *, uint_t); 573446Smrj void (*mkdi_deactivate)(void); 583446Smrj 593446Smrj void (*mkdi_idt_switch)(kdi_cpusave_t *); 603446Smrj 613446Smrj void (*mkdi_update_drreg)(kdi_drreg_t *); 623446Smrj void (*mkdi_set_debug_msrs)(kdi_msr_t *); 630Sstevel@tonic-gate 640Sstevel@tonic-gate uintptr_t (*mkdi_get_userlimit)(void); 650Sstevel@tonic-gate 663446Smrj int (*mkdi_get_cpuinfo)(uint_t *, uint_t *, uint_t *); 670Sstevel@tonic-gate 683446Smrj void (*mkdi_stop_slaves)(int, int); 693446Smrj 703446Smrj void (*mkdi_start_slaves)(void); 710Sstevel@tonic-gate 723446Smrj void (*mkdi_slave_wait)(void); 730Sstevel@tonic-gate 743446Smrj void (*mkdi_memrange_add)(caddr_t, size_t); 753446Smrj 763446Smrj void (*mkdi_reboot)(void); 770Sstevel@tonic-gate } kdi_mach_t; 780Sstevel@tonic-gate 793446Smrj #define mkdi_activate kdi_mach.mkdi_activate 803446Smrj #define mkdi_deactivate kdi_mach.mkdi_deactivate 813446Smrj #define mkdi_idt_switch kdi_mach.mkdi_idt_switch 823446Smrj #define mkdi_update_drreg kdi_mach.mkdi_update_drreg 833446Smrj #define mkdi_set_debug_msrs kdi_mach.mkdi_set_debug_msrs 840Sstevel@tonic-gate #define mkdi_get_userlimit kdi_mach.mkdi_get_userlimit 853446Smrj #define mkdi_get_cpuinfo kdi_mach.mkdi_get_cpuinfo 863446Smrj #define mkdi_stop_slaves kdi_mach.mkdi_stop_slaves 873446Smrj #define mkdi_start_slaves kdi_mach.mkdi_start_slaves 883446Smrj #define mkdi_slave_wait kdi_mach.mkdi_slave_wait 893446Smrj #define mkdi_memrange_add kdi_mach.mkdi_memrange_add 903446Smrj #define mkdi_reboot kdi_mach.mkdi_reboot 910Sstevel@tonic-gate 920Sstevel@tonic-gate extern void hat_kdi_init(void); 933446Smrj 943446Smrj extern ulong_t kdi_getdr0(void), kdi_getdr1(void), kdi_getdr2(void); 953446Smrj extern ulong_t kdi_getdr3(void), kdi_getdr6(void), kdi_getdr7(void); 963446Smrj extern void kdi_setdr0(ulong_t), kdi_setdr1(ulong_t), kdi_setdr2(ulong_t); 973446Smrj extern void kdi_setdr3(ulong_t), kdi_setdr6(ulong_t), kdi_setdr7(ulong_t); 983446Smrj extern ulong_t kdi_dreg_get(int); 993446Smrj extern void kdi_dreg_set(int, ulong_t); 1003446Smrj extern void kdi_update_drreg(kdi_drreg_t *); 1013446Smrj extern void kdi_set_debug_msrs(kdi_msr_t *); 1023446Smrj extern void kdi_cpu_debug_init(kdi_cpusave_t *); 1030Sstevel@tonic-gate 1043446Smrj extern void kdi_cpu_init(void); 1053446Smrj extern void kdi_xc_others(int, void (*)(void)); 1063446Smrj extern void kdi_start_slaves(void); 1073446Smrj extern void kdi_slave_wait(void); 1083446Smrj 1093446Smrj extern void kdi_idtr_set(gate_desc_t *, size_t); 1103446Smrj extern void kdi_idt_write(struct gate_desc *, uint_t); 1113446Smrj extern void kdi_idt_sync(void); 1123446Smrj extern void kdi_idt_switch(kdi_cpusave_t *); 113*5084Sjohnlev #ifdef __xpv 114*5084Sjohnlev extern void kdi_idtr_write(desctbr_t *); 115*5084Sjohnlev #else 1163446Smrj #define kdi_idtr_write(idtr) wr_idtr(idtr) 117*5084Sjohnlev #endif 1183446Smrj 1193446Smrj extern void kdi_activate(kdi_main_t, kdi_cpusave_t *, uint_t); 1203446Smrj extern void kdi_deactivate(void); 1213446Smrj extern void kdi_stop_slaves(int, int); 1223446Smrj extern void kdi_memrange_add(caddr_t, size_t); 1233446Smrj extern void kdi_reboot(void); 1240Sstevel@tonic-gate 1250Sstevel@tonic-gate #ifdef __cplusplus 1260Sstevel@tonic-gate } 1270Sstevel@tonic-gate #endif 1280Sstevel@tonic-gate 1290Sstevel@tonic-gate #endif /* _SYS_KDI_MACHIMPL_H */ 130