RTEMS 5.2
All Data Structures Files Functions Variables Typedefs Enumerations Enumerator Macros Modules Pages
apic.h
Go to the documentation of this file.
1
7/*
8 * Author: Erich Boleyn <erich@uruk.org>
9 * http://www.uruk.org/~erich/
10 *
11 * Copyright (c) 1997-2011 Erich Boleyn. All rights reserved.
12 *
13 * Redistribution and use in source and binary forms, with or without
14 * modification, are permitted provided that the following conditions
15 * are met:
16 * 1. Redistributions of source code must retain the above copyright
17 * notice, this list of conditions and the following disclaimer.
18 * 2. Redistributions in binary form must reproduce the above copyright
19 * notice, this list of conditions and the following disclaimer in the
20 * documentation and/or other materials provided with the distribution.
21 * 3. The name of the author may not be used to endorse or promote products
22 * derived from this software without specific prior written permission.
23 *
24 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
25 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
26 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
27 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
28 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
29 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
30 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
31 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
32 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
33 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
34 */
35
43/*
44 * Header file for Intel Architecture local and I/O APIC definitions.
45 *
46 * This file was created from information in the Intel Pentium Pro
47 * Family Developer's Manual, Volume 3: Operating System Writer's
48 * Manual, order number 242692-001, which can be ordered from the
49 * Intel literature center.
50 */
51
52#ifndef _APIC_H
53#define _APIC_H
54
55/*
56 * APIC Defines.
57 */
58
59/*
60 * Recommendation: Don't use this except for MSI interrupt delivery.
61 * In general, the "Destination Mode" can be used to control this, since
62 * it is DIFFERENT (0xF) for Pentium and P6, but not on the same APIC
63 * version for AMD Opteron.
64 */
65#define APIC_BCAST_ID 0xFF
66
67/*
68 * APIC register definitions
69 */
70
71/*
72 * Shared defines for I/O and local APIC definitions
73 */
75#define APIC_VERSION(x) ((x) & 0xFF)
76#define APIC_MAXREDIR(x) (((x) >> 16) & 0xFF)
78#define APIC_ID(x) ((x) >> 24)
79#define APIC_VER_NEW 0x10
80
81#define IOAPIC_REGSEL 0
82#define IOAPIC_RW 0x10
83#define IOAPIC_ID 0
84#define IOAPIC_VER 1
85#define IOAPIC_REDIR 0x10
86
87#define LAPIC_ID 0x20
88#define LAPIC_VER 0x30
89#define LAPIC_TPR 0x80
90#define LAPIC_APR 0x90
91#define LAPIC_PPR 0xA0
92#define LAPIC_EOI 0xB0
93#define LAPIC_LDR 0xD0
94#define LAPIC_DFR 0xE0
95#define LAPIC_SPIV 0xF0
96#define LAPIC_SPIV_ENABLE_APIC 0x100
97#define LAPIC_ISR 0x100
98#define LAPIC_TMR 0x180
99#define LAPIC_IRR 0x200
100#define LAPIC_ESR 0x280
101#define LAPIC_ICR 0x300
102#define LAPIC_ICR_DS_SELF 0x40000
103#define LAPIC_ICR_DS_ALLINC 0x80000
104#define LAPIC_ICR_DS_ALLEX 0xC0000
105#define LAPIC_ICR_TM_LEVEL 0x8000
106#define LAPIC_ICR_LEVELASSERT 0x4000
107#define LAPIC_ICR_STATUS_PEND 0x1000
108#define LAPIC_ICR_DM_LOGICAL 0x800
109#define LAPIC_ICR_DM_LOWPRI 0x100
110#define LAPIC_ICR_DM_SMI 0x200
111#define LAPIC_ICR_DM_NMI 0x400
112#define LAPIC_ICR_DM_INIT 0x500
113#define LAPIC_ICR_DM_SIPI 0x600
114#define LAPIC_LVTT 0x320
115#define LAPIC_LVTPC 0x340
116#define LAPIC_LVT0 0x350
117#define LAPIC_LVT1 0x360
118#define LAPIC_LVTE 0x370
119#define LAPIC_TICR 0x380
120#define LAPIC_TCCR 0x390
121#define LAPIC_TDCR 0x3E0
122
123#endif /* _APIC_H */
124