xref: /freebsd/sys/x86/include/apicreg.h (revision 95ee2897e98f5d444f26ed2334cc7c439f9c16c6)
132c3d3b6SJohn Baldwin /*-
2*4d846d26SWarner Losh  * SPDX-License-Identifier: BSD-2-Clause
3ebf5747bSPedro 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 
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  * global defines, etc.
11332c3d3b6SJohn Baldwin  */
11432c3d3b6SJohn Baldwin 
11532c3d3b6SJohn Baldwin /******************************************************************************
11632c3d3b6SJohn Baldwin  * LOCAL APIC structure
11732c3d3b6SJohn Baldwin  */
11832c3d3b6SJohn Baldwin 
11932c3d3b6SJohn Baldwin #ifndef LOCORE
12032c3d3b6SJohn Baldwin #include <sys/types.h>
12132c3d3b6SJohn Baldwin 
12232c3d3b6SJohn Baldwin #define PAD3	int : 32; int : 32; int : 32
12332c3d3b6SJohn Baldwin #define PAD4	int : 32; int : 32; int : 32; int : 32
12432c3d3b6SJohn Baldwin 
12532c3d3b6SJohn Baldwin struct LAPIC {
12632c3d3b6SJohn Baldwin 	/* reserved */		PAD4;
12732c3d3b6SJohn Baldwin 	/* reserved */		PAD4;
12832c3d3b6SJohn Baldwin 	u_int32_t id;		PAD3;
12932c3d3b6SJohn Baldwin 	u_int32_t version;	PAD3;
13032c3d3b6SJohn Baldwin 	/* reserved */		PAD4;
13132c3d3b6SJohn Baldwin 	/* reserved */		PAD4;
13232c3d3b6SJohn Baldwin 	/* reserved */		PAD4;
13332c3d3b6SJohn Baldwin 	/* reserved */		PAD4;
13432c3d3b6SJohn Baldwin 	u_int32_t tpr;		PAD3;
13532c3d3b6SJohn Baldwin 	u_int32_t apr;		PAD3;
13632c3d3b6SJohn Baldwin 	u_int32_t ppr;		PAD3;
13732c3d3b6SJohn Baldwin 	u_int32_t eoi;		PAD3;
13832c3d3b6SJohn Baldwin 	/* reserved */		PAD4;
13932c3d3b6SJohn Baldwin 	u_int32_t ldr;		PAD3;
14032c3d3b6SJohn Baldwin 	u_int32_t dfr;		PAD3;
14132c3d3b6SJohn Baldwin 	u_int32_t svr;		PAD3;
14232c3d3b6SJohn Baldwin 	u_int32_t isr0;		PAD3;
14332c3d3b6SJohn Baldwin 	u_int32_t isr1;		PAD3;
14432c3d3b6SJohn Baldwin 	u_int32_t isr2;		PAD3;
14532c3d3b6SJohn Baldwin 	u_int32_t isr3;		PAD3;
14632c3d3b6SJohn Baldwin 	u_int32_t isr4;		PAD3;
14732c3d3b6SJohn Baldwin 	u_int32_t isr5;		PAD3;
14832c3d3b6SJohn Baldwin 	u_int32_t isr6;		PAD3;
14932c3d3b6SJohn Baldwin 	u_int32_t isr7;		PAD3;
15032c3d3b6SJohn Baldwin 	u_int32_t tmr0;		PAD3;
15132c3d3b6SJohn Baldwin 	u_int32_t tmr1;		PAD3;
15232c3d3b6SJohn Baldwin 	u_int32_t tmr2;		PAD3;
15332c3d3b6SJohn Baldwin 	u_int32_t tmr3;		PAD3;
15432c3d3b6SJohn Baldwin 	u_int32_t tmr4;		PAD3;
15532c3d3b6SJohn Baldwin 	u_int32_t tmr5;		PAD3;
15632c3d3b6SJohn Baldwin 	u_int32_t tmr6;		PAD3;
15732c3d3b6SJohn Baldwin 	u_int32_t tmr7;		PAD3;
15832c3d3b6SJohn Baldwin 	u_int32_t irr0;		PAD3;
15932c3d3b6SJohn Baldwin 	u_int32_t irr1;		PAD3;
16032c3d3b6SJohn Baldwin 	u_int32_t irr2;		PAD3;
16132c3d3b6SJohn Baldwin 	u_int32_t irr3;		PAD3;
16232c3d3b6SJohn Baldwin 	u_int32_t irr4;		PAD3;
16332c3d3b6SJohn Baldwin 	u_int32_t irr5;		PAD3;
16432c3d3b6SJohn Baldwin 	u_int32_t irr6;		PAD3;
16532c3d3b6SJohn Baldwin 	u_int32_t irr7;		PAD3;
16632c3d3b6SJohn Baldwin 	u_int32_t esr;		PAD3;
16732c3d3b6SJohn Baldwin 	/* reserved */		PAD4;
16832c3d3b6SJohn Baldwin 	/* reserved */		PAD4;
16932c3d3b6SJohn Baldwin 	/* reserved */		PAD4;
17032c3d3b6SJohn Baldwin 	/* reserved */		PAD4;
17132c3d3b6SJohn Baldwin 	/* reserved */		PAD4;
17232c3d3b6SJohn Baldwin 	/* reserved */		PAD4;
17332c3d3b6SJohn Baldwin 	u_int32_t lvt_cmci;	PAD3;
17432c3d3b6SJohn Baldwin 	u_int32_t icr_lo;	PAD3;
17532c3d3b6SJohn Baldwin 	u_int32_t icr_hi;	PAD3;
17632c3d3b6SJohn Baldwin 	u_int32_t lvt_timer;	PAD3;
17732c3d3b6SJohn Baldwin 	u_int32_t lvt_thermal;	PAD3;
17832c3d3b6SJohn Baldwin 	u_int32_t lvt_pcint;	PAD3;
17932c3d3b6SJohn Baldwin 	u_int32_t lvt_lint0;	PAD3;
18032c3d3b6SJohn Baldwin 	u_int32_t lvt_lint1;	PAD3;
18132c3d3b6SJohn Baldwin 	u_int32_t lvt_error;	PAD3;
18232c3d3b6SJohn Baldwin 	u_int32_t icr_timer;	PAD3;
18332c3d3b6SJohn Baldwin 	u_int32_t ccr_timer;	PAD3;
18432c3d3b6SJohn Baldwin 	/* reserved */		PAD4;
18532c3d3b6SJohn Baldwin 	/* reserved */		PAD4;
18632c3d3b6SJohn Baldwin 	/* reserved */		PAD4;
18732c3d3b6SJohn Baldwin 	/* reserved */		PAD4;
18832c3d3b6SJohn Baldwin 	u_int32_t dcr_timer;	PAD3;
18932c3d3b6SJohn Baldwin 	/* reserved */		PAD4;
19032c3d3b6SJohn Baldwin };
19132c3d3b6SJohn Baldwin 
19232c3d3b6SJohn Baldwin typedef struct LAPIC lapic_t;
19332c3d3b6SJohn Baldwin 
1944c918926SKonstantin Belousov enum LAPIC_REGISTERS {
1954c918926SKonstantin Belousov 	LAPIC_ID	= 0x2,
1964c918926SKonstantin Belousov 	LAPIC_VERSION	= 0x3,
1974c918926SKonstantin Belousov 	LAPIC_TPR	= 0x8,
1984c918926SKonstantin Belousov 	LAPIC_APR	= 0x9,
1994c918926SKonstantin Belousov 	LAPIC_PPR	= 0xa,
2004c918926SKonstantin Belousov 	LAPIC_EOI	= 0xb,
2014c918926SKonstantin Belousov 	LAPIC_LDR	= 0xd,
2024c918926SKonstantin Belousov 	LAPIC_DFR	= 0xe, /* Not in x2APIC */
2034c918926SKonstantin Belousov 	LAPIC_SVR	= 0xf,
2044c918926SKonstantin Belousov 	LAPIC_ISR0	= 0x10,
2054c918926SKonstantin Belousov 	LAPIC_ISR1	= 0x11,
2064c918926SKonstantin Belousov 	LAPIC_ISR2	= 0x12,
2074c918926SKonstantin Belousov 	LAPIC_ISR3	= 0x13,
2084c918926SKonstantin Belousov 	LAPIC_ISR4	= 0x14,
2094c918926SKonstantin Belousov 	LAPIC_ISR5	= 0x15,
2104c918926SKonstantin Belousov 	LAPIC_ISR6	= 0x16,
2114c918926SKonstantin Belousov 	LAPIC_ISR7	= 0x17,
2124c918926SKonstantin Belousov 	LAPIC_TMR0	= 0x18,
2134c918926SKonstantin Belousov 	LAPIC_TMR1	= 0x19,
2144c918926SKonstantin Belousov 	LAPIC_TMR2	= 0x1a,
2154c918926SKonstantin Belousov 	LAPIC_TMR3	= 0x1b,
2164c918926SKonstantin Belousov 	LAPIC_TMR4	= 0x1c,
2174c918926SKonstantin Belousov 	LAPIC_TMR5	= 0x1d,
2184c918926SKonstantin Belousov 	LAPIC_TMR6	= 0x1e,
2194c918926SKonstantin Belousov 	LAPIC_TMR7	= 0x1f,
2204c918926SKonstantin Belousov 	LAPIC_IRR0	= 0x20,
2214c918926SKonstantin Belousov 	LAPIC_IRR1	= 0x21,
2224c918926SKonstantin Belousov 	LAPIC_IRR2	= 0x22,
2234c918926SKonstantin Belousov 	LAPIC_IRR3	= 0x23,
2244c918926SKonstantin Belousov 	LAPIC_IRR4	= 0x24,
2254c918926SKonstantin Belousov 	LAPIC_IRR5	= 0x25,
2264c918926SKonstantin Belousov 	LAPIC_IRR6	= 0x26,
2274c918926SKonstantin Belousov 	LAPIC_IRR7	= 0x27,
2284c918926SKonstantin Belousov 	LAPIC_ESR	= 0x28,
2294c918926SKonstantin Belousov 	LAPIC_LVT_CMCI	= 0x2f,
2304c918926SKonstantin Belousov 	LAPIC_ICR_LO	= 0x30,
2314c918926SKonstantin Belousov 	LAPIC_ICR_HI	= 0x31, /* Not in x2APIC */
2324c918926SKonstantin Belousov 	LAPIC_LVT_TIMER	= 0x32,
2334c918926SKonstantin Belousov 	LAPIC_LVT_THERMAL = 0x33,
2344c918926SKonstantin Belousov 	LAPIC_LVT_PCINT	= 0x34,
2354c918926SKonstantin Belousov 	LAPIC_LVT_LINT0	= 0x35,
2364c918926SKonstantin Belousov 	LAPIC_LVT_LINT1	= 0x36,
2374c918926SKonstantin Belousov 	LAPIC_LVT_ERROR	= 0x37,
2384c918926SKonstantin Belousov 	LAPIC_ICR_TIMER	= 0x38,
2394c918926SKonstantin Belousov 	LAPIC_CCR_TIMER	= 0x39,
2404c918926SKonstantin Belousov 	LAPIC_DCR_TIMER	= 0x3e,
2414c918926SKonstantin Belousov 	LAPIC_SELF_IPI	= 0x3f, /* Only in x2APIC */
242bc1e6499SAndriy Gapon 	LAPIC_EXT_FEATURES = 0x40, /* AMD */
243bc1e6499SAndriy Gapon 	LAPIC_EXT_CTRL	= 0x41, /* AMD */
244bc1e6499SAndriy Gapon 	LAPIC_EXT_SEOI	= 0x42, /* AMD */
245bc1e6499SAndriy Gapon 	LAPIC_EXT_IER0	= 0x48, /* AMD */
246bc1e6499SAndriy Gapon 	LAPIC_EXT_IER1	= 0x49, /* AMD */
247bc1e6499SAndriy Gapon 	LAPIC_EXT_IER2	= 0x4a, /* AMD */
248bc1e6499SAndriy Gapon 	LAPIC_EXT_IER3	= 0x4b, /* AMD */
249bc1e6499SAndriy Gapon 	LAPIC_EXT_IER4	= 0x4c, /* AMD */
250bc1e6499SAndriy Gapon 	LAPIC_EXT_IER5	= 0x4d, /* AMD */
251bc1e6499SAndriy Gapon 	LAPIC_EXT_IER6	= 0x4e, /* AMD */
252bc1e6499SAndriy Gapon 	LAPIC_EXT_IER7	= 0x4f, /* AMD */
253bc1e6499SAndriy Gapon 	LAPIC_EXT_LVT0	= 0x50, /* AMD */
254bc1e6499SAndriy Gapon 	LAPIC_EXT_LVT1	= 0x51, /* AMD */
255bc1e6499SAndriy Gapon 	LAPIC_EXT_LVT2	= 0x52, /* AMD */
256bc1e6499SAndriy Gapon 	LAPIC_EXT_LVT3	= 0x53, /* AMD */
2574c918926SKonstantin Belousov };
2584c918926SKonstantin Belousov 
2594c918926SKonstantin Belousov #define	LAPIC_MEM_MUL	0x10
2604c918926SKonstantin Belousov 
261bc1e6499SAndriy Gapon /*
262bc1e6499SAndriy Gapon  * Although some registers are available on AMD processors only,
263bc1e6499SAndriy Gapon  * it's not a big waste to reserve them on all platforms.
264bc1e6499SAndriy Gapon  * However, we need to watch out for this space being assigned for
265bc1e6499SAndriy Gapon  * non-APIC purposes in the future processor models.
266bc1e6499SAndriy Gapon  */
267bc1e6499SAndriy Gapon #define	LAPIC_MEM_REGION ((LAPIC_EXT_LVT3 + 1) * LAPIC_MEM_MUL)
268bc1e6499SAndriy Gapon 
26932c3d3b6SJohn Baldwin /******************************************************************************
27032c3d3b6SJohn Baldwin  * I/O APIC structure
27132c3d3b6SJohn Baldwin  */
27232c3d3b6SJohn Baldwin 
27332c3d3b6SJohn Baldwin struct IOAPIC {
27432c3d3b6SJohn Baldwin 	u_int32_t ioregsel;	PAD3;
27532c3d3b6SJohn Baldwin 	u_int32_t iowin;	PAD3;
27632c3d3b6SJohn Baldwin };
27732c3d3b6SJohn Baldwin 
27832c3d3b6SJohn Baldwin typedef struct IOAPIC ioapic_t;
27932c3d3b6SJohn Baldwin 
28032c3d3b6SJohn Baldwin #undef PAD4
28132c3d3b6SJohn Baldwin #undef PAD3
28232c3d3b6SJohn Baldwin 
28332c3d3b6SJohn Baldwin #endif  /* !LOCORE */
28432c3d3b6SJohn Baldwin 
28532c3d3b6SJohn Baldwin /******************************************************************************
28632c3d3b6SJohn Baldwin  * various code 'logical' values
28732c3d3b6SJohn Baldwin  */
28832c3d3b6SJohn Baldwin 
28932c3d3b6SJohn Baldwin /******************************************************************************
29032c3d3b6SJohn Baldwin  * LOCAL APIC defines
29132c3d3b6SJohn Baldwin  */
29232c3d3b6SJohn Baldwin 
29332c3d3b6SJohn Baldwin /* default physical locations of LOCAL (CPU) APICs */
29432c3d3b6SJohn Baldwin #define DEFAULT_APIC_BASE	0xfee00000
29532c3d3b6SJohn Baldwin 
29632c3d3b6SJohn Baldwin /* constants relating to APIC ID registers */
29732c3d3b6SJohn Baldwin #define APIC_ID_MASK		0xff000000
29832c3d3b6SJohn Baldwin #define	APIC_ID_SHIFT		24
29932c3d3b6SJohn Baldwin #define	APIC_ID_CLUSTER		0xf0
30032c3d3b6SJohn Baldwin #define	APIC_ID_CLUSTER_ID	0x0f
30132c3d3b6SJohn Baldwin #define	APIC_MAX_CLUSTER	0xe
30232c3d3b6SJohn Baldwin #define	APIC_MAX_INTRACLUSTER_ID 3
30332c3d3b6SJohn Baldwin #define	APIC_ID_CLUSTER_SHIFT	4
30432c3d3b6SJohn Baldwin 
30532c3d3b6SJohn Baldwin /* fields in VER */
30632c3d3b6SJohn Baldwin #define APIC_VER_VERSION	0x000000ff
30732c3d3b6SJohn Baldwin #define APIC_VER_MAXLVT		0x00ff0000
30832c3d3b6SJohn Baldwin #define MAXLVTSHIFT		16
30932c3d3b6SJohn Baldwin #define APIC_VER_EOI_SUPPRESSION 0x01000000
310bc1e6499SAndriy Gapon #define APIC_VER_AMD_EXT_SPACE	0x80000000
31132c3d3b6SJohn Baldwin 
31232c3d3b6SJohn Baldwin /* fields in LDR */
31332c3d3b6SJohn Baldwin #define	APIC_LDR_RESERVED	0x00ffffff
31432c3d3b6SJohn Baldwin 
31532c3d3b6SJohn Baldwin /* fields in DFR */
31632c3d3b6SJohn Baldwin #define	APIC_DFR_RESERVED	0x0fffffff
31732c3d3b6SJohn Baldwin #define	APIC_DFR_MODEL_MASK	0xf0000000
31832c3d3b6SJohn Baldwin #define	APIC_DFR_MODEL_FLAT	0xf0000000
31932c3d3b6SJohn Baldwin #define	APIC_DFR_MODEL_CLUSTER	0x00000000
32032c3d3b6SJohn Baldwin 
32132c3d3b6SJohn Baldwin /* fields in SVR */
32232c3d3b6SJohn Baldwin #define APIC_SVR_VECTOR		0x000000ff
32332c3d3b6SJohn Baldwin #define APIC_SVR_VEC_PROG	0x000000f0
32432c3d3b6SJohn Baldwin #define APIC_SVR_VEC_FIX	0x0000000f
32532c3d3b6SJohn Baldwin #define APIC_SVR_ENABLE		0x00000100
32632c3d3b6SJohn Baldwin # define APIC_SVR_SWDIS		0x00000000
32732c3d3b6SJohn Baldwin # define APIC_SVR_SWEN		0x00000100
32832c3d3b6SJohn Baldwin #define APIC_SVR_FOCUS		0x00000200
32932c3d3b6SJohn Baldwin # define APIC_SVR_FEN		0x00000000
33032c3d3b6SJohn Baldwin # define APIC_SVR_FDIS		0x00000200
33132c3d3b6SJohn Baldwin #define APIC_SVR_EOI_SUPPRESSION 0x00001000
33232c3d3b6SJohn Baldwin 
33332c3d3b6SJohn Baldwin /* fields in TPR */
33432c3d3b6SJohn Baldwin #define APIC_TPR_PRIO		0x000000ff
33532c3d3b6SJohn Baldwin # define APIC_TPR_INT		0x000000f0
33632c3d3b6SJohn Baldwin # define APIC_TPR_SUB		0x0000000f
33732c3d3b6SJohn Baldwin 
33832c3d3b6SJohn Baldwin /* fields in ESR */
33932c3d3b6SJohn Baldwin #define	APIC_ESR_SEND_CS_ERROR		0x00000001
34032c3d3b6SJohn Baldwin #define	APIC_ESR_RECEIVE_CS_ERROR	0x00000002
34132c3d3b6SJohn Baldwin #define	APIC_ESR_SEND_ACCEPT		0x00000004
34232c3d3b6SJohn Baldwin #define	APIC_ESR_RECEIVE_ACCEPT		0x00000008
34332c3d3b6SJohn Baldwin #define	APIC_ESR_SEND_ILLEGAL_VECTOR	0x00000020
34432c3d3b6SJohn Baldwin #define	APIC_ESR_RECEIVE_ILLEGAL_VECTOR	0x00000040
34532c3d3b6SJohn Baldwin #define	APIC_ESR_ILLEGAL_REGISTER	0x00000080
34632c3d3b6SJohn Baldwin 
34732c3d3b6SJohn Baldwin /* fields in ICR_LOW */
34832c3d3b6SJohn Baldwin #define APIC_VECTOR_MASK	0x000000ff
34932c3d3b6SJohn Baldwin 
35032c3d3b6SJohn Baldwin #define APIC_DELMODE_MASK	0x00000700
35132c3d3b6SJohn Baldwin # define APIC_DELMODE_FIXED	0x00000000
35232c3d3b6SJohn Baldwin # define APIC_DELMODE_LOWPRIO	0x00000100
35332c3d3b6SJohn Baldwin # define APIC_DELMODE_SMI	0x00000200
35432c3d3b6SJohn Baldwin # define APIC_DELMODE_RR	0x00000300
35532c3d3b6SJohn Baldwin # define APIC_DELMODE_NMI	0x00000400
35632c3d3b6SJohn Baldwin # define APIC_DELMODE_INIT	0x00000500
35732c3d3b6SJohn Baldwin # define APIC_DELMODE_STARTUP	0x00000600
35832c3d3b6SJohn Baldwin # define APIC_DELMODE_RESV	0x00000700
35932c3d3b6SJohn Baldwin 
36032c3d3b6SJohn Baldwin #define APIC_DESTMODE_MASK	0x00000800
36132c3d3b6SJohn Baldwin # define APIC_DESTMODE_PHY	0x00000000
36232c3d3b6SJohn Baldwin # define APIC_DESTMODE_LOG	0x00000800
36332c3d3b6SJohn Baldwin 
36432c3d3b6SJohn Baldwin #define APIC_DELSTAT_MASK	0x00001000
36532c3d3b6SJohn Baldwin # define APIC_DELSTAT_IDLE	0x00000000
36632c3d3b6SJohn Baldwin # define APIC_DELSTAT_PEND	0x00001000
36732c3d3b6SJohn Baldwin 
36832c3d3b6SJohn Baldwin #define APIC_RESV1_MASK		0x00002000
36932c3d3b6SJohn Baldwin 
37032c3d3b6SJohn Baldwin #define APIC_LEVEL_MASK		0x00004000
37132c3d3b6SJohn Baldwin # define APIC_LEVEL_DEASSERT	0x00000000
37232c3d3b6SJohn Baldwin # define APIC_LEVEL_ASSERT	0x00004000
37332c3d3b6SJohn Baldwin 
37432c3d3b6SJohn Baldwin #define APIC_TRIGMOD_MASK	0x00008000
37532c3d3b6SJohn Baldwin # define APIC_TRIGMOD_EDGE	0x00000000
37632c3d3b6SJohn Baldwin # define APIC_TRIGMOD_LEVEL	0x00008000
37732c3d3b6SJohn Baldwin 
37832c3d3b6SJohn Baldwin #define APIC_RRSTAT_MASK	0x00030000
37932c3d3b6SJohn Baldwin # define APIC_RRSTAT_INVALID	0x00000000
38032c3d3b6SJohn Baldwin # define APIC_RRSTAT_INPROG	0x00010000
38132c3d3b6SJohn Baldwin # define APIC_RRSTAT_VALID	0x00020000
38232c3d3b6SJohn Baldwin # define APIC_RRSTAT_RESV	0x00030000
38332c3d3b6SJohn Baldwin 
38432c3d3b6SJohn Baldwin #define APIC_DEST_MASK		0x000c0000
38532c3d3b6SJohn Baldwin # define APIC_DEST_DESTFLD	0x00000000
38632c3d3b6SJohn Baldwin # define APIC_DEST_SELF		0x00040000
38732c3d3b6SJohn Baldwin # define APIC_DEST_ALLISELF	0x00080000
38832c3d3b6SJohn Baldwin # define APIC_DEST_ALLESELF	0x000c0000
38932c3d3b6SJohn Baldwin 
39032c3d3b6SJohn Baldwin #define APIC_RESV2_MASK		0xfff00000
39132c3d3b6SJohn Baldwin 
39232c3d3b6SJohn Baldwin #define	APIC_ICRLO_RESV_MASK	(APIC_RESV1_MASK | APIC_RESV2_MASK)
39332c3d3b6SJohn Baldwin 
39432c3d3b6SJohn Baldwin /* fields in LVT1/2 */
39532c3d3b6SJohn Baldwin #define APIC_LVT_VECTOR		0x000000ff
39632c3d3b6SJohn Baldwin #define APIC_LVT_DM		0x00000700
39732c3d3b6SJohn Baldwin # define APIC_LVT_DM_FIXED	0x00000000
39832c3d3b6SJohn Baldwin # define APIC_LVT_DM_SMI	0x00000200
39932c3d3b6SJohn Baldwin # define APIC_LVT_DM_NMI	0x00000400
40032c3d3b6SJohn Baldwin # define APIC_LVT_DM_INIT	0x00000500
40132c3d3b6SJohn Baldwin # define APIC_LVT_DM_EXTINT	0x00000700
40232c3d3b6SJohn Baldwin #define APIC_LVT_DS		0x00001000
40332c3d3b6SJohn Baldwin #define APIC_LVT_IIPP		0x00002000
40432c3d3b6SJohn Baldwin #define APIC_LVT_IIPP_INTALO	0x00002000
40532c3d3b6SJohn Baldwin #define APIC_LVT_IIPP_INTAHI	0x00000000
40632c3d3b6SJohn Baldwin #define APIC_LVT_RIRR		0x00004000
40732c3d3b6SJohn Baldwin #define APIC_LVT_TM		0x00008000
40832c3d3b6SJohn Baldwin #define APIC_LVT_M		0x00010000
40932c3d3b6SJohn Baldwin 
41032c3d3b6SJohn Baldwin /* fields in LVT Timer */
41132c3d3b6SJohn Baldwin #define APIC_LVTT_VECTOR	0x000000ff
41232c3d3b6SJohn Baldwin #define APIC_LVTT_DS		0x00001000
41332c3d3b6SJohn Baldwin #define APIC_LVTT_M		0x00010000
4147c4e7693SKonstantin Belousov #define APIC_LVTT_TM		0x00060000
41532c3d3b6SJohn Baldwin # define APIC_LVTT_TM_ONE_SHOT	0x00000000
41632c3d3b6SJohn Baldwin # define APIC_LVTT_TM_PERIODIC	0x00020000
4177c4e7693SKonstantin Belousov # define APIC_LVTT_TM_TSCDLT	0x00040000
4187c4e7693SKonstantin Belousov # define APIC_LVTT_TM_RSRV	0x00060000
41932c3d3b6SJohn Baldwin 
42032c3d3b6SJohn Baldwin /* APIC timer current count */
42132c3d3b6SJohn Baldwin #define	APIC_TIMER_MAX_COUNT	0xffffffff
42232c3d3b6SJohn Baldwin 
42332c3d3b6SJohn Baldwin /* fields in TDCR */
42432c3d3b6SJohn Baldwin #define APIC_TDCR_2		0x00
42532c3d3b6SJohn Baldwin #define APIC_TDCR_4		0x01
42632c3d3b6SJohn Baldwin #define APIC_TDCR_8		0x02
42732c3d3b6SJohn Baldwin #define APIC_TDCR_16		0x03
42832c3d3b6SJohn Baldwin #define APIC_TDCR_32		0x08
42932c3d3b6SJohn Baldwin #define APIC_TDCR_64		0x09
43032c3d3b6SJohn Baldwin #define APIC_TDCR_128		0x0a
43132c3d3b6SJohn Baldwin #define APIC_TDCR_1		0x0b
43232c3d3b6SJohn Baldwin 
433bc1e6499SAndriy Gapon /* Constants related to AMD Extended APIC Features Register */
434bc1e6499SAndriy Gapon #define	APIC_EXTF_ELVT_MASK	0x00ff0000
435bc1e6499SAndriy Gapon #define	APIC_EXTF_ELVT_SHIFT	16
436bc1e6499SAndriy Gapon #define	APIC_EXTF_EXTID_CAP	0x00000004
437bc1e6499SAndriy Gapon #define	APIC_EXTF_SEIO_CAP	0x00000002
438bc1e6499SAndriy Gapon #define	APIC_EXTF_IER_CAP	0x00000001
439bc1e6499SAndriy Gapon 
440316032adSJohn Baldwin /* LVT table indices */
441316032adSJohn Baldwin #define	APIC_LVT_LINT0		0
442316032adSJohn Baldwin #define	APIC_LVT_LINT1		1
443316032adSJohn Baldwin #define	APIC_LVT_TIMER		2
444316032adSJohn Baldwin #define	APIC_LVT_ERROR		3
445316032adSJohn Baldwin #define	APIC_LVT_PMC		4
446316032adSJohn Baldwin #define	APIC_LVT_THERMAL	5
447316032adSJohn Baldwin #define	APIC_LVT_CMCI		6
448316032adSJohn Baldwin #define	APIC_LVT_MAX		APIC_LVT_CMCI
449316032adSJohn Baldwin 
450bc1e6499SAndriy Gapon /* AMD extended LVT constants, seem to be assigned by fiat */
451bc1e6499SAndriy Gapon #define	APIC_ELVT_IBS		0 /* Instruction based sampling */
452bc1e6499SAndriy Gapon #define	APIC_ELVT_MCA		1 /* MCE thresholding */
453bc1e6499SAndriy Gapon #define	APIC_ELVT_DEI		2 /* Deferred error interrupt */
454bc1e6499SAndriy Gapon #define	APIC_ELVT_SBI		3 /* Sideband interface */
455bc1e6499SAndriy Gapon #define	APIC_ELVT_MAX		APIC_ELVT_SBI
456bc1e6499SAndriy Gapon 
45732c3d3b6SJohn Baldwin /******************************************************************************
45832c3d3b6SJohn Baldwin  * I/O APIC defines
45932c3d3b6SJohn Baldwin  */
46032c3d3b6SJohn Baldwin 
46132c3d3b6SJohn Baldwin /* default physical locations of an IO APIC */
46232c3d3b6SJohn Baldwin #define DEFAULT_IO_APIC_BASE	0xfec00000
46332c3d3b6SJohn Baldwin 
46432c3d3b6SJohn Baldwin /* window register offset */
46532c3d3b6SJohn Baldwin #define IOAPIC_WINDOW		0x10
46632c3d3b6SJohn Baldwin #define IOAPIC_EOIR		0x40
46732c3d3b6SJohn Baldwin 
4681a92c840SKonstantin Belousov #define	IOAPIC_WND_SIZE		0x50
4691a92c840SKonstantin Belousov 
47032c3d3b6SJohn Baldwin /* indexes into IO APIC */
47132c3d3b6SJohn Baldwin #define IOAPIC_ID		0x00
47232c3d3b6SJohn Baldwin #define IOAPIC_VER		0x01
47332c3d3b6SJohn Baldwin #define IOAPIC_ARB		0x02
47432c3d3b6SJohn Baldwin #define IOAPIC_REDTBL		0x10
47532c3d3b6SJohn Baldwin #define IOAPIC_REDTBL0		IOAPIC_REDTBL
47632c3d3b6SJohn Baldwin #define IOAPIC_REDTBL1		(IOAPIC_REDTBL+0x02)
47732c3d3b6SJohn Baldwin #define IOAPIC_REDTBL2		(IOAPIC_REDTBL+0x04)
47832c3d3b6SJohn Baldwin #define IOAPIC_REDTBL3		(IOAPIC_REDTBL+0x06)
47932c3d3b6SJohn Baldwin #define IOAPIC_REDTBL4		(IOAPIC_REDTBL+0x08)
48032c3d3b6SJohn Baldwin #define IOAPIC_REDTBL5		(IOAPIC_REDTBL+0x0a)
48132c3d3b6SJohn Baldwin #define IOAPIC_REDTBL6		(IOAPIC_REDTBL+0x0c)
48232c3d3b6SJohn Baldwin #define IOAPIC_REDTBL7		(IOAPIC_REDTBL+0x0e)
48332c3d3b6SJohn Baldwin #define IOAPIC_REDTBL8		(IOAPIC_REDTBL+0x10)
48432c3d3b6SJohn Baldwin #define IOAPIC_REDTBL9		(IOAPIC_REDTBL+0x12)
48532c3d3b6SJohn Baldwin #define IOAPIC_REDTBL10		(IOAPIC_REDTBL+0x14)
48632c3d3b6SJohn Baldwin #define IOAPIC_REDTBL11		(IOAPIC_REDTBL+0x16)
48732c3d3b6SJohn Baldwin #define IOAPIC_REDTBL12		(IOAPIC_REDTBL+0x18)
48832c3d3b6SJohn Baldwin #define IOAPIC_REDTBL13		(IOAPIC_REDTBL+0x1a)
48932c3d3b6SJohn Baldwin #define IOAPIC_REDTBL14		(IOAPIC_REDTBL+0x1c)
49032c3d3b6SJohn Baldwin #define IOAPIC_REDTBL15		(IOAPIC_REDTBL+0x1e)
49132c3d3b6SJohn Baldwin #define IOAPIC_REDTBL16		(IOAPIC_REDTBL+0x20)
49232c3d3b6SJohn Baldwin #define IOAPIC_REDTBL17		(IOAPIC_REDTBL+0x22)
49332c3d3b6SJohn Baldwin #define IOAPIC_REDTBL18		(IOAPIC_REDTBL+0x24)
49432c3d3b6SJohn Baldwin #define IOAPIC_REDTBL19		(IOAPIC_REDTBL+0x26)
49532c3d3b6SJohn Baldwin #define IOAPIC_REDTBL20		(IOAPIC_REDTBL+0x28)
49632c3d3b6SJohn Baldwin #define IOAPIC_REDTBL21		(IOAPIC_REDTBL+0x2a)
49732c3d3b6SJohn Baldwin #define IOAPIC_REDTBL22		(IOAPIC_REDTBL+0x2c)
49832c3d3b6SJohn Baldwin #define IOAPIC_REDTBL23		(IOAPIC_REDTBL+0x2e)
49932c3d3b6SJohn Baldwin 
50032c3d3b6SJohn Baldwin /* fields in VER */
50132c3d3b6SJohn Baldwin #define IOART_VER_VERSION	0x000000ff
50232c3d3b6SJohn Baldwin #define IOART_VER_MAXREDIR	0x00ff0000
50332c3d3b6SJohn Baldwin #define MAXREDIRSHIFT		16
50432c3d3b6SJohn Baldwin 
50532c3d3b6SJohn Baldwin /*
50632c3d3b6SJohn Baldwin  * fields in the IO APIC's redirection table entries
50732c3d3b6SJohn Baldwin  */
50832c3d3b6SJohn Baldwin #define IOART_DEST	APIC_ID_MASK	/* broadcast addr: all APICs */
50932c3d3b6SJohn Baldwin 
51032c3d3b6SJohn Baldwin #define IOART_RESV	0x00fe0000	/* reserved */
51132c3d3b6SJohn Baldwin 
51232c3d3b6SJohn Baldwin #define IOART_INTMASK	0x00010000	/* R/W: INTerrupt mask */
51332c3d3b6SJohn Baldwin # define IOART_INTMCLR	0x00000000	/*       clear, allow INTs */
51432c3d3b6SJohn Baldwin # define IOART_INTMSET	0x00010000	/*       set, inhibit INTs */
51532c3d3b6SJohn Baldwin 
51632c3d3b6SJohn Baldwin #define IOART_TRGRMOD	0x00008000	/* R/W: trigger mode */
51732c3d3b6SJohn Baldwin # define IOART_TRGREDG	0x00000000	/*       edge */
51832c3d3b6SJohn Baldwin # define IOART_TRGRLVL	0x00008000	/*       level */
51932c3d3b6SJohn Baldwin 
52032c3d3b6SJohn Baldwin #define IOART_REM_IRR	0x00004000	/* RO: remote IRR */
52132c3d3b6SJohn Baldwin 
52232c3d3b6SJohn Baldwin #define IOART_INTPOL	0x00002000	/* R/W: INT input pin polarity */
52332c3d3b6SJohn Baldwin # define IOART_INTAHI	0x00000000	/*      active high */
52432c3d3b6SJohn Baldwin # define IOART_INTALO	0x00002000	/*      active low */
52532c3d3b6SJohn Baldwin 
52632c3d3b6SJohn Baldwin #define IOART_DELIVS	0x00001000	/* RO: delivery status */
52732c3d3b6SJohn Baldwin 
52832c3d3b6SJohn Baldwin #define IOART_DESTMOD	0x00000800	/* R/W: destination mode */
52932c3d3b6SJohn Baldwin # define IOART_DESTPHY	0x00000000	/*      physical */
53032c3d3b6SJohn Baldwin # define IOART_DESTLOG	0x00000800	/*      logical */
53132c3d3b6SJohn Baldwin 
53232c3d3b6SJohn Baldwin #define IOART_DELMOD	0x00000700	/* R/W: delivery mode */
53332c3d3b6SJohn Baldwin # define IOART_DELFIXED	0x00000000	/*       fixed */
53432c3d3b6SJohn Baldwin # define IOART_DELLOPRI	0x00000100	/*       lowest priority */
53532c3d3b6SJohn Baldwin # define IOART_DELSMI	0x00000200	/*       System Management INT */
53632c3d3b6SJohn Baldwin # define IOART_DELRSV1	0x00000300	/*       reserved */
53732c3d3b6SJohn Baldwin # define IOART_DELNMI	0x00000400	/*       NMI signal */
53832c3d3b6SJohn Baldwin # define IOART_DELINIT	0x00000500	/*       INIT signal */
53932c3d3b6SJohn Baldwin # define IOART_DELRSV2	0x00000600	/*       reserved */
54032c3d3b6SJohn Baldwin # define IOART_DELEXINT	0x00000700	/*       External INTerrupt */
54132c3d3b6SJohn Baldwin 
54232c3d3b6SJohn Baldwin #define IOART_INTVEC	0x000000ff	/* R/W: INTerrupt vector field */
54332c3d3b6SJohn Baldwin 
54432c3d3b6SJohn Baldwin #endif /* _X86_APICREG_H_ */
545