2011-09-02 04:43:51 +02:00
|
|
|
/** @file
|
|
|
|
Public include file for I/O APIC library.
|
|
|
|
|
|
|
|
I/O APIC library assumes I/O APIC is enabled. It does not
|
|
|
|
handles cases where I/O APIC is disabled.
|
|
|
|
|
2018-06-27 15:12:46 +02:00
|
|
|
Copyright (c) 2011 - 2018, Intel Corporation. All rights reserved.<BR>
|
2019-04-04 01:06:35 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2011-09-02 04:43:51 +02:00
|
|
|
|
|
|
|
**/
|
2011-09-07 04:42:52 +02:00
|
|
|
#ifndef __IO_APIC_LIB_H__
|
|
|
|
#define __IO_APIC_LIB_H__
|
2011-09-02 04:43:51 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
Read a 32-bit I/O APIC register.
|
|
|
|
|
|
|
|
If Index is >= 0x100, then ASSERT().
|
2018-06-27 15:12:46 +02:00
|
|
|
|
2011-09-02 04:43:51 +02:00
|
|
|
@param Index Specifies the I/O APIC register to read.
|
|
|
|
|
|
|
|
@return The 32-bit value read from the I/O APIC register specified by Index.
|
|
|
|
**/
|
|
|
|
UINT32
|
|
|
|
EFIAPI
|
|
|
|
IoApicRead (
|
|
|
|
IN UINTN Index
|
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Write a 32-bit I/O APIC register.
|
|
|
|
|
|
|
|
If Index is >= 0x100, then ASSERT().
|
2018-06-27 15:12:46 +02:00
|
|
|
|
2011-09-02 04:43:51 +02:00
|
|
|
@param Index Specifies the I/O APIC register to write.
|
|
|
|
@param Value Specifies the value to write to the I/O APIC register specified by Index.
|
|
|
|
|
|
|
|
@return The 32-bit value written to I/O APIC register specified by Index.
|
|
|
|
**/
|
|
|
|
UINT32
|
|
|
|
EFIAPI
|
|
|
|
IoApicWrite (
|
|
|
|
IN UINTN Index,
|
|
|
|
IN UINT32 Value
|
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Set the interrupt mask of an I/O APIC interrupt.
|
|
|
|
|
2018-06-27 15:12:46 +02:00
|
|
|
If Irq is larger than the maximum number I/O APIC redirection entries, then ASSERT().
|
|
|
|
|
2011-09-02 04:43:51 +02:00
|
|
|
@param Irq Specifies the I/O APIC interrupt to enable or disable.
|
|
|
|
@param Enable If TRUE, then enable the I/O APIC interrupt specified by Irq.
|
|
|
|
If FALSE, then disable the I/O APIC interrupt specified by Irq.
|
|
|
|
**/
|
|
|
|
VOID
|
|
|
|
EFIAPI
|
|
|
|
IoApicEnableInterrupt (
|
|
|
|
IN UINTN Irq,
|
|
|
|
IN BOOLEAN Enable
|
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Configures an I/O APIC interrupt.
|
2018-06-27 15:12:46 +02:00
|
|
|
|
2011-09-02 04:43:51 +02:00
|
|
|
Configure an I/O APIC Redirection Table Entry to deliver an interrupt in physical
|
2019-10-09 06:55:54 +02:00
|
|
|
mode to the Local APIC of the currently executing CPU. The default state of the
|
2011-09-02 04:43:51 +02:00
|
|
|
entry is for the interrupt to be disabled (masked). IoApicEnableInterrupts() must
|
|
|
|
be used to enable(unmask) the I/O APIC Interrupt.
|
|
|
|
|
2018-06-27 15:12:46 +02:00
|
|
|
If Irq is larger than the maximum number I/O APIC redirection entries, then ASSERT().
|
2011-09-02 04:43:51 +02:00
|
|
|
If Vector >= 0x100, then ASSERT().
|
|
|
|
If DeliveryMode is not supported, then ASSERT().
|
|
|
|
|
|
|
|
@param Irq Specifies the I/O APIC interrupt to initialize.
|
|
|
|
@param Vector The 8-bit interrupt vector associated with the I/O APIC
|
|
|
|
Interrupt. Must be in the range 0x10..0xFE.
|
|
|
|
@param DeliveryMode A 3-bit value that specifies how the recept of the I/O APIC
|
|
|
|
interrupt is handled. The only supported values are:
|
|
|
|
0: IO_APIC_DELIVERY_MODE_FIXED
|
|
|
|
1: IO_APIC_DELIVERY_MODE_LOWEST_PRIORITY
|
|
|
|
2: IO_APIC_DELIVERY_MODE_SMI
|
|
|
|
4: IO_APIC_DELIVERY_MODE_NMI
|
|
|
|
5: IO_APIC_DELIVERY_MODE_INIT
|
|
|
|
7: IO_APIC_DELIVERY_MODE_EXTINT
|
|
|
|
@param LevelTriggered TRUE specifies a level triggered interrupt.
|
|
|
|
FALSE specifies an edge triggered interrupt.
|
|
|
|
@param AssertionLevel TRUE specified an active high interrupt.
|
|
|
|
FALSE specifies an active low interrupt.
|
|
|
|
**/
|
|
|
|
VOID
|
|
|
|
EFIAPI
|
|
|
|
IoApicConfigureInterrupt (
|
|
|
|
IN UINTN Irq,
|
|
|
|
IN UINTN Vector,
|
|
|
|
IN UINTN DeliveryMode,
|
|
|
|
IN BOOLEAN LevelTriggered,
|
|
|
|
IN BOOLEAN AssertionLevel
|
|
|
|
);
|
2011-09-07 04:42:52 +02:00
|
|
|
#endif
|