Start application processor
This commit is contained in:
parent
ca87eab663
commit
188e4e7a3d
@ -51,6 +51,12 @@
|
||||
#define APIC_DM_INIT 0x00000500
|
||||
#define APIC_DM_STARTUP 0x00000600
|
||||
#define APIC_DM_EXTINT 0x00000700
|
||||
#define APIC_DM_ASSERT 0x00004000
|
||||
#define APIC_DM_LEVEL 0x00008000
|
||||
#define APIC_DM_BROADCAST 0x00080000
|
||||
|
||||
/* APIC delivery status */
|
||||
#define APIC_DELIVERY_PENDING 0x00001000
|
||||
|
||||
/* APIC trigger modes */
|
||||
#define APIC_TGM_EDGE 0
|
||||
|
@ -56,6 +56,12 @@
|
||||
#define APIC_DM_INIT 0x00000500
|
||||
#define APIC_DM_STARTUP 0x00000600
|
||||
#define APIC_DM_EXTINT 0x00000700
|
||||
#define APIC_DM_ASSERT 0x00004000
|
||||
#define APIC_DM_LEVEL 0x00008000
|
||||
#define APIC_DM_BROADCAST 0x00080000
|
||||
|
||||
/* APIC delivery status */
|
||||
#define APIC_DELIVERY_PENDING 0x00001000
|
||||
|
||||
/* APIC trigger modes */
|
||||
#define APIC_TGM_EDGE 0
|
||||
|
@ -45,3 +45,36 @@ HlInitializeProcessor(VOID)
|
||||
/* Set the APIC running level */
|
||||
HlSetRunLevel(KeGetCurrentProcessorBlock()->RunLevel);
|
||||
}
|
||||
|
||||
XTAPI
|
||||
XTSTATUS
|
||||
HlStartProcessor(IN ULONG CpuId,
|
||||
IN PHYSICAL_ADDRESS EntryPoint)
|
||||
{
|
||||
ULONG Attempt;
|
||||
|
||||
/* Wait until command register is clear */
|
||||
while((HlReadApicRegister(APIC_ICR0) & APIC_DELIVERY_PENDING) != 0);
|
||||
|
||||
/* Trigger INIT IPI and wait for delivery bit to be cleared */
|
||||
HlpSendIpi(CpuId, APIC_DM_INIT | APIC_DM_LEVEL | APIC_DM_ASSERT);
|
||||
while((HlReadApicRegister(APIC_ICR0) & APIC_DELIVERY_PENDING) != 0);
|
||||
|
||||
/* Deassert INIT IPI to take CPU out of reset and wait for delivery bit to be cleared */
|
||||
HlpSendIpi(CpuId, APIC_DM_INIT | APIC_DM_LEVEL);
|
||||
while((HlReadApicRegister(APIC_ICR0) & APIC_DELIVERY_PENDING) != 0);
|
||||
|
||||
/* Two attempts to send STARTUP IPI */
|
||||
for(Attempt = 0; Attempt < 2; Attempt++)
|
||||
{
|
||||
/* Trigger STARTUP IPI and wait for delivery bit to be cleared */
|
||||
HlpSendIpi(CpuId, APIC_DM_STARTUP | (EntryPoint.LowPart >> 12));
|
||||
while((HlReadApicRegister(APIC_ICR0) & APIC_DELIVERY_PENDING) != 0);
|
||||
}
|
||||
|
||||
/* Memory barrier */
|
||||
ArMemoryBarrier();
|
||||
|
||||
/* Return success */
|
||||
return STATUS_SUCCESS;
|
||||
}
|
||||
|
@ -117,6 +117,10 @@ XTCDECL
|
||||
VOID
|
||||
ArSetInterruptFlag(VOID);
|
||||
|
||||
XTCDECL
|
||||
VOID
|
||||
ArStartApplicationProcessor();
|
||||
|
||||
XTCDECL
|
||||
VOID
|
||||
ArStoreGlobalDescriptorTable(OUT PVOID Destination);
|
||||
|
@ -113,6 +113,10 @@ XTCDECL
|
||||
VOID
|
||||
ArSetInterruptFlag(VOID);
|
||||
|
||||
XTCDECL
|
||||
VOID
|
||||
ArStartApplicationProcessor();
|
||||
|
||||
XTCDECL
|
||||
VOID
|
||||
ArStoreGlobalDescriptorTable(OUT PVOID Destination);
|
||||
|
Loading…
Reference in New Issue
Block a user