root/usr/src/grub/grub-0.97/stage2/apic.h
/*
 *  <Insert copyright here : it must be BSD-like so everyone can use it>
 *
 *  Author:  Erich Boleyn  <erich@uruk.org>   http://www.uruk.org/~erich/
 *
 *  Header file for Intel Architecture local and I/O APIC definitions.
 *
 *  This file was created from information in the Intel Pentium Pro
 *  Family Developer's Manual, Volume 3: Operating System Writer's
 *  Manual, order number 242692-001, which can be ordered from the
 *  Intel literature center.
 */

#ifndef _APIC_H
#define _APIC_H

/*
 *  APIC Defines.
 */

#define APIC_BROADCAST_ID                       0xFF

/*
 *  APIC register definitions
 */

/*
 *  Shared defines for I/O and local APIC definitions
 */
/* APIC version register */
#define APIC_VERSION(x)                         ((x) & 0xFF)
/* if the APIC version is equal or greater than APIC_VER_NEW, it
   is a "new" APIC */
#define APIC_VER_NEW                            0x10
/* this next one is used in all cases but an old local APIC, which has
   2 entries in it's LVT */
#define APIC_MAXREDIR(x)                        (((x) >> 16) & 0xFF)
/* APIC id register */
#define APIC_OLD_ID(x)                          ((x) >> 24)
#define APIC_NEW_ID(x)                          (((x) >> 24) & 0xF)

#define IOAPIC_REGSEL                           0
#define IOAPIC_RW                               0x10
#define         IOAPIC_ID                       0
#define         IOAPIC_VER                      1
#define         IOAPIC_REDIR                    0x10
#define LAPIC_ID                                0x20
#define LAPIC_VER                               0x30
#define LAPIC_TPR                               0x80
#define LAPIC_APR                               0x90
#define LAPIC_PPR                               0xA0
#define LAPIC_EOI                               0xB0
#define LAPIC_LDR                               0xD0
#define LAPIC_DFR                               0xE0
#define LAPIC_SPIV                              0xF0
#define         LAPIC_SPIV_ENABLE_APIC          0x100
#define LAPIC_ISR                               0x100
#define LAPIC_TMR                               0x180
#define LAPIC_IRR                               0x200
#define LAPIC_ESR                               0x280
#define LAPIC_ICR                               0x300
#define         LAPIC_DEST_MASK                 0xFFFFFF
#define LAPIC_LVTT                              0x320
#define LAPIC_LVTPC                             0x340
#define LAPIC_LVT0                              0x350
#define LAPIC_LVT1                              0x360
#define LAPIC_LVTE                              0x370
#define LAPIC_TICR                              0x380
#define LAPIC_TCCR                              0x390
#define LAPIC_TDCR                              0x3E0

#endif /* _APIC_H */