xref: /freebsd/sys/x86/include/apicreg.h (revision 7c4e76935ea24c7c3d282a4832f9e65975eb497d)
132c3d3b6SJohn Baldwin /*-
232c3d3b6SJohn Baldwin  * Copyright (c) 1996, by Peter Wemm and Steve Passe
332c3d3b6SJohn Baldwin  * All rights reserved.
432c3d3b6SJohn Baldwin  *
532c3d3b6SJohn Baldwin  * Redistribution and use in source and binary forms, with or without
632c3d3b6SJohn Baldwin  * modification, are permitted provided that the following conditions
732c3d3b6SJohn Baldwin  * are met:
832c3d3b6SJohn Baldwin  * 1. Redistributions of source code must retain the above copyright
932c3d3b6SJohn Baldwin  *    notice, this list of conditions and the following disclaimer.
1032c3d3b6SJohn Baldwin  * 2. The name of the developer may NOT be used to endorse or promote products
1132c3d3b6SJohn Baldwin  *    derived from this software without specific prior written permission.
1232c3d3b6SJohn Baldwin  *
1332c3d3b6SJohn Baldwin  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
1432c3d3b6SJohn Baldwin  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
1532c3d3b6SJohn Baldwin  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
1632c3d3b6SJohn Baldwin  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
1732c3d3b6SJohn Baldwin  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
1832c3d3b6SJohn Baldwin  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
1932c3d3b6SJohn Baldwin  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
2032c3d3b6SJohn Baldwin  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
2132c3d3b6SJohn Baldwin  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
2232c3d3b6SJohn Baldwin  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
2332c3d3b6SJohn Baldwin  * SUCH DAMAGE.
2432c3d3b6SJohn Baldwin  *
2532c3d3b6SJohn Baldwin  * $FreeBSD$
2632c3d3b6SJohn Baldwin  */
2732c3d3b6SJohn Baldwin 
2832c3d3b6SJohn Baldwin #ifndef _X86_APICREG_H_
2932c3d3b6SJohn Baldwin #define _X86_APICREG_H_
3032c3d3b6SJohn Baldwin 
3132c3d3b6SJohn Baldwin /*
3232c3d3b6SJohn Baldwin  * Local && I/O APIC definitions.
3332c3d3b6SJohn Baldwin  */
3432c3d3b6SJohn Baldwin 
3532c3d3b6SJohn Baldwin /*
3632c3d3b6SJohn Baldwin  * Pentium P54C+ Built-in APIC
3732c3d3b6SJohn Baldwin  * (Advanced programmable Interrupt Controller)
3832c3d3b6SJohn Baldwin  *
3932c3d3b6SJohn Baldwin  * Base Address of Built-in APIC in memory location
4032c3d3b6SJohn Baldwin  * is 0xfee00000.
4132c3d3b6SJohn Baldwin  *
4232c3d3b6SJohn Baldwin  * Map of APIC Registers:
4332c3d3b6SJohn Baldwin  *
4432c3d3b6SJohn Baldwin  * Offset (hex)    Description                     Read/Write state
4532c3d3b6SJohn Baldwin  * 000             Reserved
4632c3d3b6SJohn Baldwin  * 010             Reserved
4732c3d3b6SJohn Baldwin  * 020 ID          Local APIC ID                   R/W
4832c3d3b6SJohn Baldwin  * 030 VER         Local APIC Version              R
4932c3d3b6SJohn Baldwin  * 040             Reserved
5032c3d3b6SJohn Baldwin  * 050             Reserved
5132c3d3b6SJohn Baldwin  * 060             Reserved
5232c3d3b6SJohn Baldwin  * 070             Reserved
5332c3d3b6SJohn Baldwin  * 080             Task Priority Register          R/W
5432c3d3b6SJohn Baldwin  * 090             Arbitration Priority Register   R
5532c3d3b6SJohn Baldwin  * 0A0             Processor Priority Register     R
5632c3d3b6SJohn Baldwin  * 0B0             EOI Register                    W
5732c3d3b6SJohn Baldwin  * 0C0 RRR         Remote read                     R
5832c3d3b6SJohn Baldwin  * 0D0             Logical Destination             R/W
5932c3d3b6SJohn Baldwin  * 0E0             Destination Format Register     0..27 R;  28..31 R/W
6032c3d3b6SJohn Baldwin  * 0F0 SVR         Spurious Interrupt Vector Reg.  0..3  R;  4..9   R/W
6132c3d3b6SJohn Baldwin  * 100             ISR  000-031                    R
6232c3d3b6SJohn Baldwin  * 110             ISR  032-063                    R
6332c3d3b6SJohn Baldwin  * 120             ISR  064-095                    R
6432c3d3b6SJohn Baldwin  * 130             ISR  095-128                    R
6532c3d3b6SJohn Baldwin  * 140             ISR  128-159                    R
6632c3d3b6SJohn Baldwin  * 150             ISR  160-191                    R
6732c3d3b6SJohn Baldwin  * 160             ISR  192-223                    R
6832c3d3b6SJohn Baldwin  * 170             ISR  224-255                    R
6932c3d3b6SJohn Baldwin  * 180             TMR  000-031                    R
7032c3d3b6SJohn Baldwin  * 190             TMR  032-063                    R
7132c3d3b6SJohn Baldwin  * 1A0             TMR  064-095                    R
7232c3d3b6SJohn Baldwin  * 1B0             TMR  095-128                    R
7332c3d3b6SJohn Baldwin  * 1C0             TMR  128-159                    R
7432c3d3b6SJohn Baldwin  * 1D0             TMR  160-191                    R
7532c3d3b6SJohn Baldwin  * 1E0             TMR  192-223                    R
7632c3d3b6SJohn Baldwin  * 1F0             TMR  224-255                    R
7732c3d3b6SJohn Baldwin  * 200             IRR  000-031                    R
7832c3d3b6SJohn Baldwin  * 210             IRR  032-063                    R
7932c3d3b6SJohn Baldwin  * 220             IRR  064-095                    R
8032c3d3b6SJohn Baldwin  * 230             IRR  095-128                    R
8132c3d3b6SJohn Baldwin  * 240             IRR  128-159                    R
8232c3d3b6SJohn Baldwin  * 250             IRR  160-191                    R
8332c3d3b6SJohn Baldwin  * 260             IRR  192-223                    R
8432c3d3b6SJohn Baldwin  * 270             IRR  224-255                    R
8532c3d3b6SJohn Baldwin  * 280             Error Status Register           R
8632c3d3b6SJohn Baldwin  * 290             Reserved
8732c3d3b6SJohn Baldwin  * 2A0             Reserved
8832c3d3b6SJohn Baldwin  * 2B0             Reserved
8932c3d3b6SJohn Baldwin  * 2C0             Reserved
9032c3d3b6SJohn Baldwin  * 2D0             Reserved
9132c3d3b6SJohn Baldwin  * 2E0             Reserved
9232c3d3b6SJohn Baldwin  * 2F0             Local Vector Table (CMCI)       R/W
9332c3d3b6SJohn Baldwin  * 300 ICR_LOW     Interrupt Command Reg. (0-31)   R/W
9432c3d3b6SJohn Baldwin  * 310 ICR_HI      Interrupt Command Reg. (32-63)  R/W
9532c3d3b6SJohn Baldwin  * 320             Local Vector Table (Timer)      R/W
9632c3d3b6SJohn Baldwin  * 330             Local Vector Table (Thermal)    R/W (PIV+)
9732c3d3b6SJohn Baldwin  * 340             Local Vector Table (Performance) R/W (P6+)
9832c3d3b6SJohn Baldwin  * 350 LVT1        Local Vector Table (LINT0)      R/W
9932c3d3b6SJohn Baldwin  * 360 LVT2        Local Vector Table (LINT1)      R/W
10032c3d3b6SJohn Baldwin  * 370 LVT3        Local Vector Table (ERROR)      R/W
10132c3d3b6SJohn Baldwin  * 380             Initial Count Reg. for Timer    R/W
10232c3d3b6SJohn Baldwin  * 390             Current Count of Timer          R
10332c3d3b6SJohn Baldwin  * 3A0             Reserved
10432c3d3b6SJohn Baldwin  * 3B0             Reserved
10532c3d3b6SJohn Baldwin  * 3C0             Reserved
10632c3d3b6SJohn Baldwin  * 3D0             Reserved
10732c3d3b6SJohn Baldwin  * 3E0             Timer Divide Configuration Reg. R/W
10832c3d3b6SJohn Baldwin  * 3F0             Reserved
10932c3d3b6SJohn Baldwin  */
11032c3d3b6SJohn Baldwin 
11132c3d3b6SJohn Baldwin 
11232c3d3b6SJohn Baldwin /******************************************************************************
11332c3d3b6SJohn Baldwin  * global defines, etc.
11432c3d3b6SJohn Baldwin  */
11532c3d3b6SJohn Baldwin 
11632c3d3b6SJohn Baldwin 
11732c3d3b6SJohn Baldwin /******************************************************************************
11832c3d3b6SJohn Baldwin  * LOCAL APIC structure
11932c3d3b6SJohn Baldwin  */
12032c3d3b6SJohn Baldwin 
12132c3d3b6SJohn Baldwin #ifndef LOCORE
12232c3d3b6SJohn Baldwin #include <sys/types.h>
12332c3d3b6SJohn Baldwin 
12432c3d3b6SJohn Baldwin #define PAD3	int : 32; int : 32; int : 32
12532c3d3b6SJohn Baldwin #define PAD4	int : 32; int : 32; int : 32; int : 32
12632c3d3b6SJohn Baldwin 
12732c3d3b6SJohn Baldwin struct LAPIC {
12832c3d3b6SJohn Baldwin 	/* reserved */		PAD4;
12932c3d3b6SJohn Baldwin 	/* reserved */		PAD4;
13032c3d3b6SJohn Baldwin 	u_int32_t id;		PAD3;
13132c3d3b6SJohn Baldwin 	u_int32_t version;	PAD3;
13232c3d3b6SJohn Baldwin 	/* reserved */		PAD4;
13332c3d3b6SJohn Baldwin 	/* reserved */		PAD4;
13432c3d3b6SJohn Baldwin 	/* reserved */		PAD4;
13532c3d3b6SJohn Baldwin 	/* reserved */		PAD4;
13632c3d3b6SJohn Baldwin 	u_int32_t tpr;		PAD3;
13732c3d3b6SJohn Baldwin 	u_int32_t apr;		PAD3;
13832c3d3b6SJohn Baldwin 	u_int32_t ppr;		PAD3;
13932c3d3b6SJohn Baldwin 	u_int32_t eoi;		PAD3;
14032c3d3b6SJohn Baldwin 	/* reserved */		PAD4;
14132c3d3b6SJohn Baldwin 	u_int32_t ldr;		PAD3;
14232c3d3b6SJohn Baldwin 	u_int32_t dfr;		PAD3;
14332c3d3b6SJohn Baldwin 	u_int32_t svr;		PAD3;
14432c3d3b6SJohn Baldwin 	u_int32_t isr0;		PAD3;
14532c3d3b6SJohn Baldwin 	u_int32_t isr1;		PAD3;
14632c3d3b6SJohn Baldwin 	u_int32_t isr2;		PAD3;
14732c3d3b6SJohn Baldwin 	u_int32_t isr3;		PAD3;
14832c3d3b6SJohn Baldwin 	u_int32_t isr4;		PAD3;
14932c3d3b6SJohn Baldwin 	u_int32_t isr5;		PAD3;
15032c3d3b6SJohn Baldwin 	u_int32_t isr6;		PAD3;
15132c3d3b6SJohn Baldwin 	u_int32_t isr7;		PAD3;
15232c3d3b6SJohn Baldwin 	u_int32_t tmr0;		PAD3;
15332c3d3b6SJohn Baldwin 	u_int32_t tmr1;		PAD3;
15432c3d3b6SJohn Baldwin 	u_int32_t tmr2;		PAD3;
15532c3d3b6SJohn Baldwin 	u_int32_t tmr3;		PAD3;
15632c3d3b6SJohn Baldwin 	u_int32_t tmr4;		PAD3;
15732c3d3b6SJohn Baldwin 	u_int32_t tmr5;		PAD3;
15832c3d3b6SJohn Baldwin 	u_int32_t tmr6;		PAD3;
15932c3d3b6SJohn Baldwin 	u_int32_t tmr7;		PAD3;
16032c3d3b6SJohn Baldwin 	u_int32_t irr0;		PAD3;
16132c3d3b6SJohn Baldwin 	u_int32_t irr1;		PAD3;
16232c3d3b6SJohn Baldwin 	u_int32_t irr2;		PAD3;
16332c3d3b6SJohn Baldwin 	u_int32_t irr3;		PAD3;
16432c3d3b6SJohn Baldwin 	u_int32_t irr4;		PAD3;
16532c3d3b6SJohn Baldwin 	u_int32_t irr5;		PAD3;
16632c3d3b6SJohn Baldwin 	u_int32_t irr6;		PAD3;
16732c3d3b6SJohn Baldwin 	u_int32_t irr7;		PAD3;
16832c3d3b6SJohn Baldwin 	u_int32_t esr;		PAD3;
16932c3d3b6SJohn Baldwin 	/* reserved */		PAD4;
17032c3d3b6SJohn Baldwin 	/* reserved */		PAD4;
17132c3d3b6SJohn Baldwin 	/* reserved */		PAD4;
17232c3d3b6SJohn Baldwin 	/* reserved */		PAD4;
17332c3d3b6SJohn Baldwin 	/* reserved */		PAD4;
17432c3d3b6SJohn Baldwin 	/* reserved */		PAD4;
17532c3d3b6SJohn Baldwin 	u_int32_t lvt_cmci;	PAD3;
17632c3d3b6SJohn Baldwin 	u_int32_t icr_lo;	PAD3;
17732c3d3b6SJohn Baldwin 	u_int32_t icr_hi;	PAD3;
17832c3d3b6SJohn Baldwin 	u_int32_t lvt_timer;	PAD3;
17932c3d3b6SJohn Baldwin 	u_int32_t lvt_thermal;	PAD3;
18032c3d3b6SJohn Baldwin 	u_int32_t lvt_pcint;	PAD3;
18132c3d3b6SJohn Baldwin 	u_int32_t lvt_lint0;	PAD3;
18232c3d3b6SJohn Baldwin 	u_int32_t lvt_lint1;	PAD3;
18332c3d3b6SJohn Baldwin 	u_int32_t lvt_error;	PAD3;
18432c3d3b6SJohn Baldwin 	u_int32_t icr_timer;	PAD3;
18532c3d3b6SJohn Baldwin 	u_int32_t ccr_timer;	PAD3;
18632c3d3b6SJohn Baldwin 	/* reserved */		PAD4;
18732c3d3b6SJohn Baldwin 	/* reserved */		PAD4;
18832c3d3b6SJohn Baldwin 	/* reserved */		PAD4;
18932c3d3b6SJohn Baldwin 	/* reserved */		PAD4;
19032c3d3b6SJohn Baldwin 	u_int32_t dcr_timer;	PAD3;
19132c3d3b6SJohn Baldwin 	/* reserved */		PAD4;
19232c3d3b6SJohn Baldwin };
19332c3d3b6SJohn Baldwin 
19432c3d3b6SJohn Baldwin typedef struct LAPIC lapic_t;
19532c3d3b6SJohn Baldwin 
1964c918926SKonstantin Belousov enum LAPIC_REGISTERS {
1974c918926SKonstantin Belousov 	LAPIC_ID	= 0x2,
1984c918926SKonstantin Belousov 	LAPIC_VERSION	= 0x3,
1994c918926SKonstantin Belousov 	LAPIC_TPR	= 0x8,
2004c918926SKonstantin Belousov 	LAPIC_APR	= 0x9,
2014c918926SKonstantin Belousov 	LAPIC_PPR	= 0xa,
2024c918926SKonstantin Belousov 	LAPIC_EOI	= 0xb,
2034c918926SKonstantin Belousov 	LAPIC_LDR	= 0xd,
2044c918926SKonstantin Belousov 	LAPIC_DFR	= 0xe, /* Not in x2APIC */
2054c918926SKonstantin Belousov 	LAPIC_SVR	= 0xf,
2064c918926SKonstantin Belousov 	LAPIC_ISR0	= 0x10,
2074c918926SKonstantin Belousov 	LAPIC_ISR1	= 0x11,
2084c918926SKonstantin Belousov 	LAPIC_ISR2	= 0x12,
2094c918926SKonstantin Belousov 	LAPIC_ISR3	= 0x13,
2104c918926SKonstantin Belousov 	LAPIC_ISR4	= 0x14,
2114c918926SKonstantin Belousov 	LAPIC_ISR5	= 0x15,
2124c918926SKonstantin Belousov 	LAPIC_ISR6	= 0x16,
2134c918926SKonstantin Belousov 	LAPIC_ISR7	= 0x17,
2144c918926SKonstantin Belousov 	LAPIC_TMR0	= 0x18,
2154c918926SKonstantin Belousov 	LAPIC_TMR1	= 0x19,
2164c918926SKonstantin Belousov 	LAPIC_TMR2	= 0x1a,
2174c918926SKonstantin Belousov 	LAPIC_TMR3	= 0x1b,
2184c918926SKonstantin Belousov 	LAPIC_TMR4	= 0x1c,
2194c918926SKonstantin Belousov 	LAPIC_TMR5	= 0x1d,
2204c918926SKonstantin Belousov 	LAPIC_TMR6	= 0x1e,
2214c918926SKonstantin Belousov 	LAPIC_TMR7	= 0x1f,
2224c918926SKonstantin Belousov 	LAPIC_IRR0	= 0x20,
2234c918926SKonstantin Belousov 	LAPIC_IRR1	= 0x21,
2244c918926SKonstantin Belousov 	LAPIC_IRR2	= 0x22,
2254c918926SKonstantin Belousov 	LAPIC_IRR3	= 0x23,
2264c918926SKonstantin Belousov 	LAPIC_IRR4	= 0x24,
2274c918926SKonstantin Belousov 	LAPIC_IRR5	= 0x25,
2284c918926SKonstantin Belousov 	LAPIC_IRR6	= 0x26,
2294c918926SKonstantin Belousov 	LAPIC_IRR7	= 0x27,
2304c918926SKonstantin Belousov 	LAPIC_ESR	= 0x28,
2314c918926SKonstantin Belousov 	LAPIC_LVT_CMCI	= 0x2f,
2324c918926SKonstantin Belousov 	LAPIC_ICR_LO	= 0x30,
2334c918926SKonstantin Belousov 	LAPIC_ICR_HI	= 0x31, /* Not in x2APIC */
2344c918926SKonstantin Belousov 	LAPIC_LVT_TIMER	= 0x32,
2354c918926SKonstantin Belousov 	LAPIC_LVT_THERMAL = 0x33,
2364c918926SKonstantin Belousov 	LAPIC_LVT_PCINT	= 0x34,
2374c918926SKonstantin Belousov 	LAPIC_LVT_LINT0	= 0x35,
2384c918926SKonstantin Belousov 	LAPIC_LVT_LINT1	= 0x36,
2394c918926SKonstantin Belousov 	LAPIC_LVT_ERROR	= 0x37,
2404c918926SKonstantin Belousov 	LAPIC_ICR_TIMER	= 0x38,
2414c918926SKonstantin Belousov 	LAPIC_CCR_TIMER	= 0x39,
2424c918926SKonstantin Belousov 	LAPIC_DCR_TIMER	= 0x3e,
2434c918926SKonstantin Belousov 	LAPIC_SELF_IPI	= 0x3f, /* Only in x2APIC */
2444c918926SKonstantin Belousov };
2454c918926SKonstantin Belousov 
2464c918926SKonstantin Belousov /*
2474c918926SKonstantin Belousov  * The LAPIC_SELF_IPI register only exists in x2APIC mode.  The
2484c918926SKonstantin Belousov  * formula below is applicable only to reserve the memory region,
2494c918926SKonstantin Belousov  * i.e. for xAPIC mode, where LAPIC_SELF_IPI finely serves as the
2504c918926SKonstantin Belousov  * address past end of the region.
2514c918926SKonstantin Belousov  */
2524c918926SKonstantin Belousov #define	LAPIC_MEM_REGION (LAPIC_SELF_IPI * 0x10)
2534c918926SKonstantin Belousov 
2544c918926SKonstantin Belousov #define	LAPIC_MEM_MUL	0x10
2554c918926SKonstantin Belousov 
25632c3d3b6SJohn Baldwin /******************************************************************************
25732c3d3b6SJohn Baldwin  * I/O APIC structure
25832c3d3b6SJohn Baldwin  */
25932c3d3b6SJohn Baldwin 
26032c3d3b6SJohn Baldwin struct IOAPIC {
26132c3d3b6SJohn Baldwin 	u_int32_t ioregsel;	PAD3;
26232c3d3b6SJohn Baldwin 	u_int32_t iowin;	PAD3;
26332c3d3b6SJohn Baldwin };
26432c3d3b6SJohn Baldwin 
26532c3d3b6SJohn Baldwin typedef struct IOAPIC ioapic_t;
26632c3d3b6SJohn Baldwin 
26732c3d3b6SJohn Baldwin #undef PAD4
26832c3d3b6SJohn Baldwin #undef PAD3
26932c3d3b6SJohn Baldwin 
27032c3d3b6SJohn Baldwin #endif  /* !LOCORE */
27132c3d3b6SJohn Baldwin 
27232c3d3b6SJohn Baldwin 
27332c3d3b6SJohn Baldwin /******************************************************************************
27432c3d3b6SJohn Baldwin  * various code 'logical' values
27532c3d3b6SJohn Baldwin  */
27632c3d3b6SJohn Baldwin 
27732c3d3b6SJohn Baldwin /******************************************************************************
27832c3d3b6SJohn Baldwin  * LOCAL APIC defines
27932c3d3b6SJohn Baldwin  */
28032c3d3b6SJohn Baldwin 
28132c3d3b6SJohn Baldwin /* default physical locations of LOCAL (CPU) APICs */
28232c3d3b6SJohn Baldwin #define DEFAULT_APIC_BASE	0xfee00000
28332c3d3b6SJohn Baldwin 
28432c3d3b6SJohn Baldwin /* constants relating to APIC ID registers */
28532c3d3b6SJohn Baldwin #define APIC_ID_MASK		0xff000000
28632c3d3b6SJohn Baldwin #define	APIC_ID_SHIFT		24
28732c3d3b6SJohn Baldwin #define	APIC_ID_CLUSTER		0xf0
28832c3d3b6SJohn Baldwin #define	APIC_ID_CLUSTER_ID	0x0f
28932c3d3b6SJohn Baldwin #define	APIC_MAX_CLUSTER	0xe
29032c3d3b6SJohn Baldwin #define	APIC_MAX_INTRACLUSTER_ID 3
29132c3d3b6SJohn Baldwin #define	APIC_ID_CLUSTER_SHIFT	4
29232c3d3b6SJohn Baldwin 
29332c3d3b6SJohn Baldwin /* fields in VER */
29432c3d3b6SJohn Baldwin #define APIC_VER_VERSION	0x000000ff
29532c3d3b6SJohn Baldwin #define APIC_VER_MAXLVT		0x00ff0000
29632c3d3b6SJohn Baldwin #define MAXLVTSHIFT		16
29732c3d3b6SJohn Baldwin #define APIC_VER_EOI_SUPPRESSION 0x01000000
29832c3d3b6SJohn Baldwin 
29932c3d3b6SJohn Baldwin /* fields in LDR */
30032c3d3b6SJohn Baldwin #define	APIC_LDR_RESERVED	0x00ffffff
30132c3d3b6SJohn Baldwin 
30232c3d3b6SJohn Baldwin /* fields in DFR */
30332c3d3b6SJohn Baldwin #define	APIC_DFR_RESERVED	0x0fffffff
30432c3d3b6SJohn Baldwin #define	APIC_DFR_MODEL_MASK	0xf0000000
30532c3d3b6SJohn Baldwin #define	APIC_DFR_MODEL_FLAT	0xf0000000
30632c3d3b6SJohn Baldwin #define	APIC_DFR_MODEL_CLUSTER	0x00000000
30732c3d3b6SJohn Baldwin 
30832c3d3b6SJohn Baldwin /* fields in SVR */
30932c3d3b6SJohn Baldwin #define APIC_SVR_VECTOR		0x000000ff
31032c3d3b6SJohn Baldwin #define APIC_SVR_VEC_PROG	0x000000f0
31132c3d3b6SJohn Baldwin #define APIC_SVR_VEC_FIX	0x0000000f
31232c3d3b6SJohn Baldwin #define APIC_SVR_ENABLE		0x00000100
31332c3d3b6SJohn Baldwin # define APIC_SVR_SWDIS		0x00000000
31432c3d3b6SJohn Baldwin # define APIC_SVR_SWEN		0x00000100
31532c3d3b6SJohn Baldwin #define APIC_SVR_FOCUS		0x00000200
31632c3d3b6SJohn Baldwin # define APIC_SVR_FEN		0x00000000
31732c3d3b6SJohn Baldwin # define APIC_SVR_FDIS		0x00000200
31832c3d3b6SJohn Baldwin #define APIC_SVR_EOI_SUPPRESSION 0x00001000
31932c3d3b6SJohn Baldwin 
32032c3d3b6SJohn Baldwin /* fields in TPR */
32132c3d3b6SJohn Baldwin #define APIC_TPR_PRIO		0x000000ff
32232c3d3b6SJohn Baldwin # define APIC_TPR_INT		0x000000f0
32332c3d3b6SJohn Baldwin # define APIC_TPR_SUB		0x0000000f
32432c3d3b6SJohn Baldwin 
32532c3d3b6SJohn Baldwin /* fields in ESR */
32632c3d3b6SJohn Baldwin #define	APIC_ESR_SEND_CS_ERROR		0x00000001
32732c3d3b6SJohn Baldwin #define	APIC_ESR_RECEIVE_CS_ERROR	0x00000002
32832c3d3b6SJohn Baldwin #define	APIC_ESR_SEND_ACCEPT		0x00000004
32932c3d3b6SJohn Baldwin #define	APIC_ESR_RECEIVE_ACCEPT		0x00000008
33032c3d3b6SJohn Baldwin #define	APIC_ESR_SEND_ILLEGAL_VECTOR	0x00000020
33132c3d3b6SJohn Baldwin #define	APIC_ESR_RECEIVE_ILLEGAL_VECTOR	0x00000040
33232c3d3b6SJohn Baldwin #define	APIC_ESR_ILLEGAL_REGISTER	0x00000080
33332c3d3b6SJohn Baldwin 
33432c3d3b6SJohn Baldwin /* fields in ICR_LOW */
33532c3d3b6SJohn Baldwin #define APIC_VECTOR_MASK	0x000000ff
33632c3d3b6SJohn Baldwin 
33732c3d3b6SJohn Baldwin #define APIC_DELMODE_MASK	0x00000700
33832c3d3b6SJohn Baldwin # define APIC_DELMODE_FIXED	0x00000000
33932c3d3b6SJohn Baldwin # define APIC_DELMODE_LOWPRIO	0x00000100
34032c3d3b6SJohn Baldwin # define APIC_DELMODE_SMI	0x00000200
34132c3d3b6SJohn Baldwin # define APIC_DELMODE_RR	0x00000300
34232c3d3b6SJohn Baldwin # define APIC_DELMODE_NMI	0x00000400
34332c3d3b6SJohn Baldwin # define APIC_DELMODE_INIT	0x00000500
34432c3d3b6SJohn Baldwin # define APIC_DELMODE_STARTUP	0x00000600
34532c3d3b6SJohn Baldwin # define APIC_DELMODE_RESV	0x00000700
34632c3d3b6SJohn Baldwin 
34732c3d3b6SJohn Baldwin #define APIC_DESTMODE_MASK	0x00000800
34832c3d3b6SJohn Baldwin # define APIC_DESTMODE_PHY	0x00000000
34932c3d3b6SJohn Baldwin # define APIC_DESTMODE_LOG	0x00000800
35032c3d3b6SJohn Baldwin 
35132c3d3b6SJohn Baldwin #define APIC_DELSTAT_MASK	0x00001000
35232c3d3b6SJohn Baldwin # define APIC_DELSTAT_IDLE	0x00000000
35332c3d3b6SJohn Baldwin # define APIC_DELSTAT_PEND	0x00001000
35432c3d3b6SJohn Baldwin 
35532c3d3b6SJohn Baldwin #define APIC_RESV1_MASK		0x00002000
35632c3d3b6SJohn Baldwin 
35732c3d3b6SJohn Baldwin #define APIC_LEVEL_MASK		0x00004000
35832c3d3b6SJohn Baldwin # define APIC_LEVEL_DEASSERT	0x00000000
35932c3d3b6SJohn Baldwin # define APIC_LEVEL_ASSERT	0x00004000
36032c3d3b6SJohn Baldwin 
36132c3d3b6SJohn Baldwin #define APIC_TRIGMOD_MASK	0x00008000
36232c3d3b6SJohn Baldwin # define APIC_TRIGMOD_EDGE	0x00000000
36332c3d3b6SJohn Baldwin # define APIC_TRIGMOD_LEVEL	0x00008000
36432c3d3b6SJohn Baldwin 
36532c3d3b6SJohn Baldwin #define APIC_RRSTAT_MASK	0x00030000
36632c3d3b6SJohn Baldwin # define APIC_RRSTAT_INVALID	0x00000000
36732c3d3b6SJohn Baldwin # define APIC_RRSTAT_INPROG	0x00010000
36832c3d3b6SJohn Baldwin # define APIC_RRSTAT_VALID	0x00020000
36932c3d3b6SJohn Baldwin # define APIC_RRSTAT_RESV	0x00030000
37032c3d3b6SJohn Baldwin 
37132c3d3b6SJohn Baldwin #define APIC_DEST_MASK		0x000c0000
37232c3d3b6SJohn Baldwin # define APIC_DEST_DESTFLD	0x00000000
37332c3d3b6SJohn Baldwin # define APIC_DEST_SELF		0x00040000
37432c3d3b6SJohn Baldwin # define APIC_DEST_ALLISELF	0x00080000
37532c3d3b6SJohn Baldwin # define APIC_DEST_ALLESELF	0x000c0000
37632c3d3b6SJohn Baldwin 
37732c3d3b6SJohn Baldwin #define APIC_RESV2_MASK		0xfff00000
37832c3d3b6SJohn Baldwin 
37932c3d3b6SJohn Baldwin #define	APIC_ICRLO_RESV_MASK	(APIC_RESV1_MASK | APIC_RESV2_MASK)
38032c3d3b6SJohn Baldwin 
38132c3d3b6SJohn Baldwin /* fields in LVT1/2 */
38232c3d3b6SJohn Baldwin #define APIC_LVT_VECTOR		0x000000ff
38332c3d3b6SJohn Baldwin #define APIC_LVT_DM		0x00000700
38432c3d3b6SJohn Baldwin # define APIC_LVT_DM_FIXED	0x00000000
38532c3d3b6SJohn Baldwin # define APIC_LVT_DM_SMI	0x00000200
38632c3d3b6SJohn Baldwin # define APIC_LVT_DM_NMI	0x00000400
38732c3d3b6SJohn Baldwin # define APIC_LVT_DM_INIT	0x00000500
38832c3d3b6SJohn Baldwin # define APIC_LVT_DM_EXTINT	0x00000700
38932c3d3b6SJohn Baldwin #define APIC_LVT_DS		0x00001000
39032c3d3b6SJohn Baldwin #define APIC_LVT_IIPP		0x00002000
39132c3d3b6SJohn Baldwin #define APIC_LVT_IIPP_INTALO	0x00002000
39232c3d3b6SJohn Baldwin #define APIC_LVT_IIPP_INTAHI	0x00000000
39332c3d3b6SJohn Baldwin #define APIC_LVT_RIRR		0x00004000
39432c3d3b6SJohn Baldwin #define APIC_LVT_TM		0x00008000
39532c3d3b6SJohn Baldwin #define APIC_LVT_M		0x00010000
39632c3d3b6SJohn Baldwin 
39732c3d3b6SJohn Baldwin 
39832c3d3b6SJohn Baldwin /* fields in LVT Timer */
39932c3d3b6SJohn Baldwin #define APIC_LVTT_VECTOR	0x000000ff
40032c3d3b6SJohn Baldwin #define APIC_LVTT_DS		0x00001000
40132c3d3b6SJohn Baldwin #define APIC_LVTT_M		0x00010000
402*7c4e7693SKonstantin Belousov #define APIC_LVTT_TM		0x00060000
40332c3d3b6SJohn Baldwin # define APIC_LVTT_TM_ONE_SHOT	0x00000000
40432c3d3b6SJohn Baldwin # define APIC_LVTT_TM_PERIODIC	0x00020000
405*7c4e7693SKonstantin Belousov # define APIC_LVTT_TM_TSCDLT	0x00040000
406*7c4e7693SKonstantin Belousov # define APIC_LVTT_TM_RSRV	0x00060000
40732c3d3b6SJohn Baldwin 
40832c3d3b6SJohn Baldwin /* APIC timer current count */
40932c3d3b6SJohn Baldwin #define	APIC_TIMER_MAX_COUNT	0xffffffff
41032c3d3b6SJohn Baldwin 
41132c3d3b6SJohn Baldwin /* fields in TDCR */
41232c3d3b6SJohn Baldwin #define APIC_TDCR_2		0x00
41332c3d3b6SJohn Baldwin #define APIC_TDCR_4		0x01
41432c3d3b6SJohn Baldwin #define APIC_TDCR_8		0x02
41532c3d3b6SJohn Baldwin #define APIC_TDCR_16		0x03
41632c3d3b6SJohn Baldwin #define APIC_TDCR_32		0x08
41732c3d3b6SJohn Baldwin #define APIC_TDCR_64		0x09
41832c3d3b6SJohn Baldwin #define APIC_TDCR_128		0x0a
41932c3d3b6SJohn Baldwin #define APIC_TDCR_1		0x0b
42032c3d3b6SJohn Baldwin 
421316032adSJohn Baldwin /* LVT table indices */
422316032adSJohn Baldwin #define	APIC_LVT_LINT0		0
423316032adSJohn Baldwin #define	APIC_LVT_LINT1		1
424316032adSJohn Baldwin #define	APIC_LVT_TIMER		2
425316032adSJohn Baldwin #define	APIC_LVT_ERROR		3
426316032adSJohn Baldwin #define	APIC_LVT_PMC		4
427316032adSJohn Baldwin #define	APIC_LVT_THERMAL	5
428316032adSJohn Baldwin #define	APIC_LVT_CMCI		6
429316032adSJohn Baldwin #define	APIC_LVT_MAX		APIC_LVT_CMCI
430316032adSJohn Baldwin 
43132c3d3b6SJohn Baldwin /******************************************************************************
43232c3d3b6SJohn Baldwin  * I/O APIC defines
43332c3d3b6SJohn Baldwin  */
43432c3d3b6SJohn Baldwin 
43532c3d3b6SJohn Baldwin /* default physical locations of an IO APIC */
43632c3d3b6SJohn Baldwin #define DEFAULT_IO_APIC_BASE	0xfec00000
43732c3d3b6SJohn Baldwin 
43832c3d3b6SJohn Baldwin /* window register offset */
43932c3d3b6SJohn Baldwin #define IOAPIC_WINDOW		0x10
44032c3d3b6SJohn Baldwin #define IOAPIC_EOIR		0x40
44132c3d3b6SJohn Baldwin 
44232c3d3b6SJohn Baldwin /* indexes into IO APIC */
44332c3d3b6SJohn Baldwin #define IOAPIC_ID		0x00
44432c3d3b6SJohn Baldwin #define IOAPIC_VER		0x01
44532c3d3b6SJohn Baldwin #define IOAPIC_ARB		0x02
44632c3d3b6SJohn Baldwin #define IOAPIC_REDTBL		0x10
44732c3d3b6SJohn Baldwin #define IOAPIC_REDTBL0		IOAPIC_REDTBL
44832c3d3b6SJohn Baldwin #define IOAPIC_REDTBL1		(IOAPIC_REDTBL+0x02)
44932c3d3b6SJohn Baldwin #define IOAPIC_REDTBL2		(IOAPIC_REDTBL+0x04)
45032c3d3b6SJohn Baldwin #define IOAPIC_REDTBL3		(IOAPIC_REDTBL+0x06)
45132c3d3b6SJohn Baldwin #define IOAPIC_REDTBL4		(IOAPIC_REDTBL+0x08)
45232c3d3b6SJohn Baldwin #define IOAPIC_REDTBL5		(IOAPIC_REDTBL+0x0a)
45332c3d3b6SJohn Baldwin #define IOAPIC_REDTBL6		(IOAPIC_REDTBL+0x0c)
45432c3d3b6SJohn Baldwin #define IOAPIC_REDTBL7		(IOAPIC_REDTBL+0x0e)
45532c3d3b6SJohn Baldwin #define IOAPIC_REDTBL8		(IOAPIC_REDTBL+0x10)
45632c3d3b6SJohn Baldwin #define IOAPIC_REDTBL9		(IOAPIC_REDTBL+0x12)
45732c3d3b6SJohn Baldwin #define IOAPIC_REDTBL10		(IOAPIC_REDTBL+0x14)
45832c3d3b6SJohn Baldwin #define IOAPIC_REDTBL11		(IOAPIC_REDTBL+0x16)
45932c3d3b6SJohn Baldwin #define IOAPIC_REDTBL12		(IOAPIC_REDTBL+0x18)
46032c3d3b6SJohn Baldwin #define IOAPIC_REDTBL13		(IOAPIC_REDTBL+0x1a)
46132c3d3b6SJohn Baldwin #define IOAPIC_REDTBL14		(IOAPIC_REDTBL+0x1c)
46232c3d3b6SJohn Baldwin #define IOAPIC_REDTBL15		(IOAPIC_REDTBL+0x1e)
46332c3d3b6SJohn Baldwin #define IOAPIC_REDTBL16		(IOAPIC_REDTBL+0x20)
46432c3d3b6SJohn Baldwin #define IOAPIC_REDTBL17		(IOAPIC_REDTBL+0x22)
46532c3d3b6SJohn Baldwin #define IOAPIC_REDTBL18		(IOAPIC_REDTBL+0x24)
46632c3d3b6SJohn Baldwin #define IOAPIC_REDTBL19		(IOAPIC_REDTBL+0x26)
46732c3d3b6SJohn Baldwin #define IOAPIC_REDTBL20		(IOAPIC_REDTBL+0x28)
46832c3d3b6SJohn Baldwin #define IOAPIC_REDTBL21		(IOAPIC_REDTBL+0x2a)
46932c3d3b6SJohn Baldwin #define IOAPIC_REDTBL22		(IOAPIC_REDTBL+0x2c)
47032c3d3b6SJohn Baldwin #define IOAPIC_REDTBL23		(IOAPIC_REDTBL+0x2e)
47132c3d3b6SJohn Baldwin 
47232c3d3b6SJohn Baldwin /* fields in VER */
47332c3d3b6SJohn Baldwin #define IOART_VER_VERSION	0x000000ff
47432c3d3b6SJohn Baldwin #define IOART_VER_MAXREDIR	0x00ff0000
47532c3d3b6SJohn Baldwin #define MAXREDIRSHIFT		16
47632c3d3b6SJohn Baldwin 
47732c3d3b6SJohn Baldwin /*
47832c3d3b6SJohn Baldwin  * fields in the IO APIC's redirection table entries
47932c3d3b6SJohn Baldwin  */
48032c3d3b6SJohn Baldwin #define IOART_DEST	APIC_ID_MASK	/* broadcast addr: all APICs */
48132c3d3b6SJohn Baldwin 
48232c3d3b6SJohn Baldwin #define IOART_RESV	0x00fe0000	/* reserved */
48332c3d3b6SJohn Baldwin 
48432c3d3b6SJohn Baldwin #define IOART_INTMASK	0x00010000	/* R/W: INTerrupt mask */
48532c3d3b6SJohn Baldwin # define IOART_INTMCLR	0x00000000	/*       clear, allow INTs */
48632c3d3b6SJohn Baldwin # define IOART_INTMSET	0x00010000	/*       set, inhibit INTs */
48732c3d3b6SJohn Baldwin 
48832c3d3b6SJohn Baldwin #define IOART_TRGRMOD	0x00008000	/* R/W: trigger mode */
48932c3d3b6SJohn Baldwin # define IOART_TRGREDG	0x00000000	/*       edge */
49032c3d3b6SJohn Baldwin # define IOART_TRGRLVL	0x00008000	/*       level */
49132c3d3b6SJohn Baldwin 
49232c3d3b6SJohn Baldwin #define IOART_REM_IRR	0x00004000	/* RO: remote IRR */
49332c3d3b6SJohn Baldwin 
49432c3d3b6SJohn Baldwin #define IOART_INTPOL	0x00002000	/* R/W: INT input pin polarity */
49532c3d3b6SJohn Baldwin # define IOART_INTAHI	0x00000000	/*      active high */
49632c3d3b6SJohn Baldwin # define IOART_INTALO	0x00002000	/*      active low */
49732c3d3b6SJohn Baldwin 
49832c3d3b6SJohn Baldwin #define IOART_DELIVS	0x00001000	/* RO: delivery status */
49932c3d3b6SJohn Baldwin 
50032c3d3b6SJohn Baldwin #define IOART_DESTMOD	0x00000800	/* R/W: destination mode */
50132c3d3b6SJohn Baldwin # define IOART_DESTPHY	0x00000000	/*      physical */
50232c3d3b6SJohn Baldwin # define IOART_DESTLOG	0x00000800	/*      logical */
50332c3d3b6SJohn Baldwin 
50432c3d3b6SJohn Baldwin #define IOART_DELMOD	0x00000700	/* R/W: delivery mode */
50532c3d3b6SJohn Baldwin # define IOART_DELFIXED	0x00000000	/*       fixed */
50632c3d3b6SJohn Baldwin # define IOART_DELLOPRI	0x00000100	/*       lowest priority */
50732c3d3b6SJohn Baldwin # define IOART_DELSMI	0x00000200	/*       System Management INT */
50832c3d3b6SJohn Baldwin # define IOART_DELRSV1	0x00000300	/*       reserved */
50932c3d3b6SJohn Baldwin # define IOART_DELNMI	0x00000400	/*       NMI signal */
51032c3d3b6SJohn Baldwin # define IOART_DELINIT	0x00000500	/*       INIT signal */
51132c3d3b6SJohn Baldwin # define IOART_DELRSV2	0x00000600	/*       reserved */
51232c3d3b6SJohn Baldwin # define IOART_DELEXINT	0x00000700	/*       External INTerrupt */
51332c3d3b6SJohn Baldwin 
51432c3d3b6SJohn Baldwin #define IOART_INTVEC	0x000000ff	/* R/W: INTerrupt vector field */
51532c3d3b6SJohn Baldwin 
51632c3d3b6SJohn Baldwin #endif /* _X86_APICREG_H_ */
517