9f040b7eed
Signed-off-by: Chloe M. <chloe@mensia.org>
68 lines
1.5 KiB
C
68 lines
1.5 KiB
C
/*
|
|
* Copyright (c) 2026, Chloe M.
|
|
* Provided under the BSD-3 clause.
|
|
*
|
|
* Description: Local APIC driver
|
|
* Author: Chloe M.
|
|
*/
|
|
|
|
#ifndef _MACHINE_LAPIC_H_
|
|
#define _MACHINE_LAPIC_H_ 1
|
|
|
|
#include <stdef.h>
|
|
#include <hal/kpcr.h>
|
|
|
|
/*
|
|
* Destination shorthand values for inter-processor
|
|
* interrupts.
|
|
*
|
|
* @IPI_XND_NONE: No shorthand
|
|
* @IPI_XND_SELF: Self shorthand
|
|
* @IPI_XND_AIS: All including self shorthand
|
|
* @IPI_XND_AES: All exclduing self shorthand
|
|
*/
|
|
typedef enum {
|
|
IPI_XND_NONE,
|
|
IPI_XND_SELF,
|
|
IPI_XND_AIS,
|
|
IPI_XND_AES
|
|
} IPI_SHORTHAND;
|
|
|
|
/*
|
|
* Delivery mode values for inter-processor
|
|
* interrupts.
|
|
*
|
|
* @IPI_DELMOD_FIXED: Deliver a specific interrupt vector to a slutty core~
|
|
* @IPI_LOWPRI: Equivalent to a FIXED IPI but lowest priority
|
|
* @IPI_DELMOD_SMI: Sends an SMI, we don't use this
|
|
* @IPI_DELMOD_RESERVED: Reserved
|
|
* @IPI_DELMOD_NMI: Deliver a non-maskable interrupt
|
|
* @IPI_DELMOD_INIT: Deliver an INIT IPI to a processor
|
|
* @IPI_DELMOD_STARTUP: Deliver a STARTUP IPI to a processor
|
|
*/
|
|
typedef enum {
|
|
IPI_DELMOD_FIXED,
|
|
IPI_DELMOD_LOWPRI,
|
|
IPI_DELMOD_SMI,
|
|
IPI_DELMOD_RESERVED,
|
|
IPI_DELMOD_NMI,
|
|
IPI_DEMOD_INIT,
|
|
IPI_DELMOD_STARTUP
|
|
} IPI_DELMOD;
|
|
|
|
/* IPI Delivery status bits */
|
|
#define IPI_DELSTAT_PENDING BIT(0)
|
|
|
|
/* IPI Destination mode */
|
|
#define IPI_DELMOD_LOGICAL BIT(0)
|
|
|
|
/*
|
|
* Initialize the Local APIC unit for the current
|
|
* processor.
|
|
*
|
|
* @Kpcr: KPCR of current processor
|
|
*/
|
|
VOID MdLapicInit(KPCR *Kpcr);
|
|
|
|
#endif /* !_MACHINE_LAPIC_H_ */
|