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