1*7c478bd9Sstevel@tonic-gate /* 2*7c478bd9Sstevel@tonic-gate * CDDL HEADER START 3*7c478bd9Sstevel@tonic-gate * 4*7c478bd9Sstevel@tonic-gate * The contents of this file are subject to the terms of the 5*7c478bd9Sstevel@tonic-gate * Common Development and Distribution License, Version 1.0 only 6*7c478bd9Sstevel@tonic-gate * (the "License"). You may not use this file except in compliance 7*7c478bd9Sstevel@tonic-gate * with the License. 8*7c478bd9Sstevel@tonic-gate * 9*7c478bd9Sstevel@tonic-gate * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 10*7c478bd9Sstevel@tonic-gate * or http://www.opensolaris.org/os/licensing. 11*7c478bd9Sstevel@tonic-gate * See the License for the specific language governing permissions 12*7c478bd9Sstevel@tonic-gate * and limitations under the License. 13*7c478bd9Sstevel@tonic-gate * 14*7c478bd9Sstevel@tonic-gate * When distributing Covered Code, include this CDDL HEADER in each 15*7c478bd9Sstevel@tonic-gate * file and include the License file at usr/src/OPENSOLARIS.LICENSE. 16*7c478bd9Sstevel@tonic-gate * If applicable, add the following below this CDDL HEADER, with the 17*7c478bd9Sstevel@tonic-gate * fields enclosed by brackets "[]" replaced with your own identifying 18*7c478bd9Sstevel@tonic-gate * information: Portions Copyright [yyyy] [name of copyright owner] 19*7c478bd9Sstevel@tonic-gate * 20*7c478bd9Sstevel@tonic-gate * CDDL HEADER END 21*7c478bd9Sstevel@tonic-gate */ 22*7c478bd9Sstevel@tonic-gate /* 23*7c478bd9Sstevel@tonic-gate * Copyright 2005 Sun Microsystems, Inc. All rights reserved. 24*7c478bd9Sstevel@tonic-gate * Use is subject to license terms. 25*7c478bd9Sstevel@tonic-gate */ 26*7c478bd9Sstevel@tonic-gate 27*7c478bd9Sstevel@tonic-gate #ifndef _SYS_MACHINTREG_H 28*7c478bd9Sstevel@tonic-gate #define _SYS_MACHINTREG_H 29*7c478bd9Sstevel@tonic-gate 30*7c478bd9Sstevel@tonic-gate #pragma ident "%Z%%M% %I% %E% SMI" 31*7c478bd9Sstevel@tonic-gate 32*7c478bd9Sstevel@tonic-gate #ifdef __cplusplus 33*7c478bd9Sstevel@tonic-gate extern "C" { 34*7c478bd9Sstevel@tonic-gate #endif 35*7c478bd9Sstevel@tonic-gate 36*7c478bd9Sstevel@tonic-gate /* 37*7c478bd9Sstevel@tonic-gate * Interrupt Receive Data Registers 38*7c478bd9Sstevel@tonic-gate * ASI_SDB_INTR_R or ASI_INTR_RECEIVE; ASI 0x7F; VA 0x40, 0x50, 0x60 39*7c478bd9Sstevel@tonic-gate */ 40*7c478bd9Sstevel@tonic-gate #define IRDR_0 0x40 41*7c478bd9Sstevel@tonic-gate #define IRDR_1 0x50 42*7c478bd9Sstevel@tonic-gate #define IRDR_2 0x60 43*7c478bd9Sstevel@tonic-gate 44*7c478bd9Sstevel@tonic-gate #define UIII_IRDR_0 0x40 45*7c478bd9Sstevel@tonic-gate #define UIII_IRDR_1 0x48 46*7c478bd9Sstevel@tonic-gate #define UIII_IRDR_2 0x50 47*7c478bd9Sstevel@tonic-gate #define UIII_IRDR_3 0x58 48*7c478bd9Sstevel@tonic-gate #define UIII_IRDR_4 0x60 49*7c478bd9Sstevel@tonic-gate #define UIII_IRDR_5 0x68 50*7c478bd9Sstevel@tonic-gate #define UIII_IRDR_6 0x80 51*7c478bd9Sstevel@tonic-gate #define UIII_IRDR_7 0x88 52*7c478bd9Sstevel@tonic-gate 53*7c478bd9Sstevel@tonic-gate /* 54*7c478bd9Sstevel@tonic-gate * Interrupt Receive Status Register 55*7c478bd9Sstevel@tonic-gate * ASI_INTR_RECEIVE_STATUS; ASI 0x49; VA 0x0 56*7c478bd9Sstevel@tonic-gate * 57*7c478bd9Sstevel@tonic-gate * |---------------------------------------------------| 58*7c478bd9Sstevel@tonic-gate * | RESERVED (Read as 0) | BUSY | PORTID | 59*7c478bd9Sstevel@tonic-gate * |--------------------------------|------|-----------| 60*7c478bd9Sstevel@tonic-gate * 63 6 5 4 0 61*7c478bd9Sstevel@tonic-gate * 62*7c478bd9Sstevel@tonic-gate */ 63*7c478bd9Sstevel@tonic-gate #define IRSR_BUSY 0x20 /* set when there's a vector received */ 64*7c478bd9Sstevel@tonic-gate #define IRSR_PID_MASK 0x1F /* PORTID bit mask <4:0> */ 65*7c478bd9Sstevel@tonic-gate 66*7c478bd9Sstevel@tonic-gate /* 67*7c478bd9Sstevel@tonic-gate * Interrupt Dispatch Data Register 68*7c478bd9Sstevel@tonic-gate * ASI_SDB_INTR_W or ASI_INTR_DISPATCH; ASI 0x77; VA 0x40, 0x50, 0x60 69*7c478bd9Sstevel@tonic-gate */ 70*7c478bd9Sstevel@tonic-gate #define IDDR_0 0x40 71*7c478bd9Sstevel@tonic-gate #define IDDR_1 0x50 72*7c478bd9Sstevel@tonic-gate #define IDDR_2 0x60 73*7c478bd9Sstevel@tonic-gate 74*7c478bd9Sstevel@tonic-gate #define UIII_IDDR_0 0x40 75*7c478bd9Sstevel@tonic-gate #define UIII_IDDR_1 0x48 76*7c478bd9Sstevel@tonic-gate #define UIII_IDDR_2 0x50 77*7c478bd9Sstevel@tonic-gate #define UIII_IDDR_3 0x58 78*7c478bd9Sstevel@tonic-gate #define UIII_IDDR_4 0x60 79*7c478bd9Sstevel@tonic-gate #define UIII_IDDR_5 0x68 80*7c478bd9Sstevel@tonic-gate #define UIII_IDDR_6 0x80 81*7c478bd9Sstevel@tonic-gate #define UIII_IDDR_7 0x88 82*7c478bd9Sstevel@tonic-gate 83*7c478bd9Sstevel@tonic-gate #if defined(JALAPENO) || defined(SERRANO) 84*7c478bd9Sstevel@tonic-gate /* 85*7c478bd9Sstevel@tonic-gate * Interrupt Dispatch Command Register 86*7c478bd9Sstevel@tonic-gate * ASI_INTR_DISPATCH or ASI_SDB_INTR_W; ASI 0x77; VA = PORTID<<14|0x70 87*7c478bd9Sstevel@tonic-gate * 88*7c478bd9Sstevel@tonic-gate * |------------------------------------------------| 89*7c478bd9Sstevel@tonic-gate * | 0 | PORTID & BUSY/NACK | 0x70 | 90*7c478bd9Sstevel@tonic-gate * |---------|-----------------------|--------------| 91*7c478bd9Sstevel@tonic-gate * 63 19 18 14 13 0 92*7c478bd9Sstevel@tonic-gate */ 93*7c478bd9Sstevel@tonic-gate #define IDCR_OFFSET 0x70 /* IDCR VA<13:0> */ 94*7c478bd9Sstevel@tonic-gate #define IDCR_PID_SHIFT 14 95*7c478bd9Sstevel@tonic-gate #define IDCR_BN_SHIFT 14 /* JBUS only */ 96*7c478bd9Sstevel@tonic-gate #define IDCR_BN_MASK 0x3 /* JBUS only */ 97*7c478bd9Sstevel@tonic-gate #else /* (JALAPENO || SERRANO) */ 98*7c478bd9Sstevel@tonic-gate /* 99*7c478bd9Sstevel@tonic-gate * Interrupt Dispatch Command Register 100*7c478bd9Sstevel@tonic-gate * ASI_INTR_DISPATCH or ASI_SDB_INTR_W; ASI 0x77; VA = PORTID<<14|0x70 101*7c478bd9Sstevel@tonic-gate * 102*7c478bd9Sstevel@tonic-gate * |------------------------------------------------| 103*7c478bd9Sstevel@tonic-gate * | 0 | BUSY/NACK | PORTID | 0x70 | 104*7c478bd9Sstevel@tonic-gate * |---------|-----------|-----------|--------------| 105*7c478bd9Sstevel@tonic-gate * 63 29 28 24 23 14 13 0 106*7c478bd9Sstevel@tonic-gate */ 107*7c478bd9Sstevel@tonic-gate #define IDCR_OFFSET 0x70 /* IDCR VA<13:0> */ 108*7c478bd9Sstevel@tonic-gate #define IDCR_PID_SHIFT 14 109*7c478bd9Sstevel@tonic-gate #define IDCR_BN_SHIFT 24 /* safari only */ 110*7c478bd9Sstevel@tonic-gate #endif /* (JALAPENO || SERRANO) */ 111*7c478bd9Sstevel@tonic-gate 112*7c478bd9Sstevel@tonic-gate /* 113*7c478bd9Sstevel@tonic-gate * Interrupt Dispatch Status Register 114*7c478bd9Sstevel@tonic-gate * ASI_INTR_DISPATCH_STATUS; ASI 0x48; VA 0x0 115*7c478bd9Sstevel@tonic-gate * 116*7c478bd9Sstevel@tonic-gate * |---------------------------------------------------| 117*7c478bd9Sstevel@tonic-gate * | RESERVED (Read as 0) | NACK | BUSY | 118*7c478bd9Sstevel@tonic-gate * |-----------------------------------|-------|-------| 119*7c478bd9Sstevel@tonic-gate * 63 2 1 0 | 120*7c478bd9Sstevel@tonic-gate */ 121*7c478bd9Sstevel@tonic-gate #define IDSR_NACK 0x2 /* set if interrupt dispatch failed */ 122*7c478bd9Sstevel@tonic-gate #define IDSR_BUSY 0x1 /* set when there's a dispatch */ 123*7c478bd9Sstevel@tonic-gate 124*7c478bd9Sstevel@tonic-gate /* 125*7c478bd9Sstevel@tonic-gate * Safari systems define IDSR as 32 busy/nack pairs 126*7c478bd9Sstevel@tonic-gate */ 127*7c478bd9Sstevel@tonic-gate #if defined(JALAPENO) || defined(SERRANO) 128*7c478bd9Sstevel@tonic-gate #define IDSR_BN_SETS 4 129*7c478bd9Sstevel@tonic-gate #define CPUID_TO_BN_PAIR(x) ((x) & (IDSR_BN_SETS-1)) 130*7c478bd9Sstevel@tonic-gate #else /* (JALAPENO || SERRANO) */ 131*7c478bd9Sstevel@tonic-gate #define IDSR_BN_SETS 32 132*7c478bd9Sstevel@tonic-gate #endif /* (JALAPENO || SERRANO) */ 133*7c478bd9Sstevel@tonic-gate #define IDSR_NACK_BIT(i) ((uint64_t)IDSR_NACK << (2 * (i))) 134*7c478bd9Sstevel@tonic-gate #define IDSR_BUSY_BIT(i) ((uint64_t)IDSR_BUSY << (2 * (i))) 135*7c478bd9Sstevel@tonic-gate #define IDSR_NACK_TO_BUSY(n) ((n) >> 1) 136*7c478bd9Sstevel@tonic-gate #define IDSR_BUSY_TO_NACK(n) ((n) << 1) 137*7c478bd9Sstevel@tonic-gate #define IDSR_NACK_IDX(bit) (((bit) - 1) / 2) 138*7c478bd9Sstevel@tonic-gate #define IDSR_BUSY_IDX(bit) ((bit) / 2) 139*7c478bd9Sstevel@tonic-gate 140*7c478bd9Sstevel@tonic-gate /* 141*7c478bd9Sstevel@tonic-gate * Interrupt Number Register 142*7c478bd9Sstevel@tonic-gate * Every interrupt source has a register associated with it 143*7c478bd9Sstevel@tonic-gate * 144*7c478bd9Sstevel@tonic-gate * |---------------------------------------------------| 145*7c478bd9Sstevel@tonic-gate * |INT_EN | PORTID |RESERVED (Read as 0)| INT_NUMBER| 146*7c478bd9Sstevel@tonic-gate * | | | | IGN | INO | 147*7c478bd9Sstevel@tonic-gate * |-------|----------|--------------------|-----|-----| 148*7c478bd9Sstevel@tonic-gate * | 31 30 26 25 11 10 6 5 0 149*7c478bd9Sstevel@tonic-gate */ 150*7c478bd9Sstevel@tonic-gate #define INR_EN_SHIFT 31 151*7c478bd9Sstevel@tonic-gate #define INR_PID_SHIFT 26 152*7c478bd9Sstevel@tonic-gate #define INR_PID_MASK (IRSR_PID_MASK << (INR_PID_SHIFT)) 153*7c478bd9Sstevel@tonic-gate #ifdef _STARFIRE 154*7c478bd9Sstevel@tonic-gate /* 155*7c478bd9Sstevel@tonic-gate * Starfire interrupt group number is 7 bits 156*7c478bd9Sstevel@tonic-gate * Starfire's IGN (inter group #) is not the same as upaid 157*7c478bd9Sstevel@tonic-gate */ 158*7c478bd9Sstevel@tonic-gate #define IGN_SIZE 7 /* Interrupt Group Number bit size */ 159*7c478bd9Sstevel@tonic-gate #define UPAID_TO_IGN(upaid) ((((upaid & 0x3C) >> 1) | (upaid & 0x1)) | \ 160*7c478bd9Sstevel@tonic-gate (((upaid & 0x2) << 4) | \ 161*7c478bd9Sstevel@tonic-gate ((upaid & 0x40) ^ 0x40))) 162*7c478bd9Sstevel@tonic-gate #else 163*7c478bd9Sstevel@tonic-gate /* 164*7c478bd9Sstevel@tonic-gate * IGN_SIZE can be defined in a platform's makefile. If it is not defined, 165*7c478bd9Sstevel@tonic-gate * use a default of 5. 166*7c478bd9Sstevel@tonic-gate */ 167*7c478bd9Sstevel@tonic-gate #ifndef IGN_SIZE 168*7c478bd9Sstevel@tonic-gate #define IGN_SIZE 5 /* Interrupt Group Number bit size */ 169*7c478bd9Sstevel@tonic-gate #endif 170*7c478bd9Sstevel@tonic-gate #define UPAID_TO_IGN(upaid) (upaid) 171*7c478bd9Sstevel@tonic-gate #endif /* _STARFIRE */ 172*7c478bd9Sstevel@tonic-gate 173*7c478bd9Sstevel@tonic-gate #define IR_CPU_CLEAR 0x4 /* clear pending register for cpu */ 174*7c478bd9Sstevel@tonic-gate #define IR_MASK_OFFSET 0x4 175*7c478bd9Sstevel@tonic-gate #define IR_SET_ITR 0x10 176*7c478bd9Sstevel@tonic-gate #define IR_SOFT_INT(n) (0x000010000 << (n)) 177*7c478bd9Sstevel@tonic-gate #define IR_SOFT_INT4 IR_SOFT_INT(4) /* r/w - software level 4 interrupt */ 178*7c478bd9Sstevel@tonic-gate #define IR_CPU_SOFTINT 0x8 /* set soft interrupt for cpu */ 179*7c478bd9Sstevel@tonic-gate #define IR_CLEAR_OFFSET 0x8 180*7c478bd9Sstevel@tonic-gate 181*7c478bd9Sstevel@tonic-gate 182*7c478bd9Sstevel@tonic-gate #ifdef __cplusplus 183*7c478bd9Sstevel@tonic-gate } 184*7c478bd9Sstevel@tonic-gate #endif 185*7c478bd9Sstevel@tonic-gate 186*7c478bd9Sstevel@tonic-gate #endif /* _SYS_MACHINTREG_H */ 187