mirror of
https://github.com/CloverHackyColor/CloverBootloader.git
synced 2024-11-14 10:05:43 +01:00
7c0aa811ec
Signed-off-by: Sergey Isakov <isakov-sl@bk.ru>
81 lines
1.9 KiB
C
81 lines
1.9 KiB
C
/** @file
|
|
I/O APIC Register Definitions from 82093AA I/O Advanced Programmable Interrupt
|
|
Controller (IOAPIC), 1996.
|
|
|
|
Copyright (c) 2011 - 2018, Intel Corporation. All rights reserved.<BR>
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
|
|
|
**/
|
|
|
|
#ifndef __IO_APIC_H__
|
|
#define __IO_APIC_H__
|
|
|
|
///
|
|
/// I/O APIC Register Offsets
|
|
///
|
|
#define IOAPIC_INDEX_OFFSET 0x00
|
|
#define IOAPIC_DATA_OFFSET 0x10
|
|
|
|
///
|
|
/// I/O APIC Indirect Register Indexes
|
|
///
|
|
#define IO_APIC_IDENTIFICATION_REGISTER_INDEX 0x00
|
|
#define IO_APIC_VERSION_REGISTER_INDEX 0x01
|
|
#define IO_APIC_REDIRECTION_TABLE_ENTRY_INDEX 0x10
|
|
|
|
///
|
|
/// I/O APIC Interrupt Deliver Modes
|
|
///
|
|
#define IO_APIC_DELIVERY_MODE_FIXED 0
|
|
#define IO_APIC_DELIVERY_MODE_LOWEST_PRIORITY 1
|
|
#define IO_APIC_DELIVERY_MODE_SMI 2
|
|
#define IO_APIC_DELIVERY_MODE_NMI 4
|
|
#define IO_APIC_DELIVERY_MODE_INIT 5
|
|
#define IO_APIC_DELIVERY_MODE_EXTINT 7
|
|
|
|
#pragma pack(1)
|
|
|
|
typedef union {
|
|
struct {
|
|
UINT32 Reserved0:24;
|
|
UINT32 Identification:4;
|
|
UINT32 Reserved1:4;
|
|
} Bits;
|
|
UINT32 Uint32;
|
|
} IO_APIC_IDENTIFICATION_REGISTER;
|
|
|
|
typedef union {
|
|
struct {
|
|
UINT32 Version:8;
|
|
UINT32 Reserved0:8;
|
|
UINT32 MaximumRedirectionEntry:8;
|
|
UINT32 Reserved1:8;
|
|
} Bits;
|
|
UINT32 Uint32;
|
|
} IO_APIC_VERSION_REGISTER;
|
|
|
|
typedef union {
|
|
struct {
|
|
UINT32 Vector: 8;
|
|
UINT32 DeliveryMode: 3;
|
|
UINT32 DestinationMode: 1;
|
|
UINT32 DeliveryStatus: 1;
|
|
UINT32 Polarity: 1;
|
|
UINT32 RemoteIRR: 1;
|
|
UINT32 TriggerMode: 1;
|
|
UINT32 Mask: 1;
|
|
UINT32 Reserved0: 15;
|
|
UINT32 Reserved1: 24;
|
|
UINT32 DestinationID: 8;
|
|
} Bits;
|
|
struct {
|
|
UINT32 Low;
|
|
UINT32 High;
|
|
} Uint32;
|
|
UINT64 Uint64;
|
|
} IO_APIC_REDIRECTION_TABLE_ENTRY;
|
|
|
|
#pragma pack()
|
|
|
|
#endif
|