Add running level management support
This commit is contained in:
parent
4701351bd7
commit
e245754d95
@ -18,6 +18,7 @@ list(APPEND XTOSKRNL_SOURCE
|
|||||||
${XTOSKRNL_SOURCE_DIR}/hl/globals.c
|
${XTOSKRNL_SOURCE_DIR}/hl/globals.c
|
||||||
${XTOSKRNL_SOURCE_DIR}/hl/pic.c
|
${XTOSKRNL_SOURCE_DIR}/hl/pic.c
|
||||||
${XTOSKRNL_SOURCE_DIR}/hl/${ARCH}/ioport.c
|
${XTOSKRNL_SOURCE_DIR}/hl/${ARCH}/ioport.c
|
||||||
|
${XTOSKRNL_SOURCE_DIR}/hl/${ARCH}/runlevel.c
|
||||||
${XTOSKRNL_SOURCE_DIR}/ke/apc.c
|
${XTOSKRNL_SOURCE_DIR}/ke/apc.c
|
||||||
${XTOSKRNL_SOURCE_DIR}/ke/dpc.c
|
${XTOSKRNL_SOURCE_DIR}/ke/dpc.c
|
||||||
${XTOSKRNL_SOURCE_DIR}/ke/event.c
|
${XTOSKRNL_SOURCE_DIR}/ke/event.c
|
||||||
@ -26,6 +27,7 @@ list(APPEND XTOSKRNL_SOURCE
|
|||||||
${XTOSKRNL_SOURCE_DIR}/ke/krnlinit.c
|
${XTOSKRNL_SOURCE_DIR}/ke/krnlinit.c
|
||||||
${XTOSKRNL_SOURCE_DIR}/ke/kthread.c
|
${XTOSKRNL_SOURCE_DIR}/ke/kthread.c
|
||||||
${XTOSKRNL_SOURCE_DIR}/ke/panic.c
|
${XTOSKRNL_SOURCE_DIR}/ke/panic.c
|
||||||
|
${XTOSKRNL_SOURCE_DIR}/ke/runlevel.c
|
||||||
${XTOSKRNL_SOURCE_DIR}/ke/semphore.c
|
${XTOSKRNL_SOURCE_DIR}/ke/semphore.c
|
||||||
${XTOSKRNL_SOURCE_DIR}/ke/spinlock.c
|
${XTOSKRNL_SOURCE_DIR}/ke/spinlock.c
|
||||||
${XTOSKRNL_SOURCE_DIR}/ke/timer.c
|
${XTOSKRNL_SOURCE_DIR}/ke/timer.c
|
||||||
|
75
xtoskrnl/hl/amd64/runlevel.c
Normal file
75
xtoskrnl/hl/amd64/runlevel.c
Normal file
@ -0,0 +1,75 @@
|
|||||||
|
/**
|
||||||
|
* PROJECT: ExectOS
|
||||||
|
* COPYRIGHT: See COPYING.md in the top level directory
|
||||||
|
* FILE: xtoskrnl/hl/amd64/runlevel.c
|
||||||
|
* DESCRIPTION: Run Level management support for AMD64 architecture
|
||||||
|
* DEVELOPERS: Rafal Kupiec <belliash@codingworkshop.eu.org>
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <xtos.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the current run level from APIC for the current processor.
|
||||||
|
*
|
||||||
|
* @return This routine returns the current run level.
|
||||||
|
*
|
||||||
|
* @since XT 1.0
|
||||||
|
*/
|
||||||
|
XTFASTCALL
|
||||||
|
KRUNLEVEL
|
||||||
|
HlGetRunLevel()
|
||||||
|
{
|
||||||
|
return (KRUNLEVEL)ArReadControlRegister(8);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets new run level for the current processor.
|
||||||
|
*
|
||||||
|
* @param RunLevel
|
||||||
|
* Supplies the new run level to store into APIC.
|
||||||
|
*
|
||||||
|
* @return This routine does not return any value.
|
||||||
|
*
|
||||||
|
* @since XT 1.0
|
||||||
|
*/
|
||||||
|
XTFASTCALL
|
||||||
|
VOID
|
||||||
|
HlSetRunLevel(IN KRUNLEVEL RunLevel)
|
||||||
|
{
|
||||||
|
ArWriteControlRegister(8, RunLevel);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Maps APIC interrupt vector to XT run level.
|
||||||
|
*
|
||||||
|
* @param Tpr
|
||||||
|
* Supplies the interrupt vector rad from APIC Task Priority Register.
|
||||||
|
*
|
||||||
|
* @return This routine returns the XT run level corresponding to the specified APIC interrupt vector.
|
||||||
|
*
|
||||||
|
* @since XT 1.0
|
||||||
|
*/
|
||||||
|
XTFASTCALL
|
||||||
|
KRUNLEVEL
|
||||||
|
HlpTransformApicTprToRunLevel(IN UCHAR Tpr)
|
||||||
|
{
|
||||||
|
return (KRUNLEVEL)(Tpr >> 4);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Maps XT run level to interrupt vector suitable for the APIC Task Priority Register.
|
||||||
|
*
|
||||||
|
* @param RunLevel
|
||||||
|
* Supplies the XT run level.
|
||||||
|
*
|
||||||
|
* @return This routine returns the APIC interrupt vector corresponding to the specified XT run level.
|
||||||
|
*
|
||||||
|
* @since XT 1.0
|
||||||
|
*/
|
||||||
|
XTFASTCALL
|
||||||
|
UCHAR
|
||||||
|
HlpTransformRunLevelToApicTpr(IN KRUNLEVEL RunLevel)
|
||||||
|
{
|
||||||
|
return (RunLevel << 4);
|
||||||
|
}
|
133
xtoskrnl/hl/i686/runlevel.c
Normal file
133
xtoskrnl/hl/i686/runlevel.c
Normal file
@ -0,0 +1,133 @@
|
|||||||
|
/**
|
||||||
|
* PROJECT: ExectOS
|
||||||
|
* COPYRIGHT: See COPYING.md in the top level directory
|
||||||
|
* FILE: xtoskrnl/hl/i686/runlevel.c
|
||||||
|
* DESCRIPTION: Run Level management support for i686 architecture
|
||||||
|
* DEVELOPERS: Rafal Kupiec <belliash@codingworkshop.eu.org>
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <xtos.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the current run level from APIC for the current processor.
|
||||||
|
*
|
||||||
|
* @return This routine returns the current run level.
|
||||||
|
*
|
||||||
|
* @since XT 1.0
|
||||||
|
*/
|
||||||
|
XTFASTCALL
|
||||||
|
KRUNLEVEL
|
||||||
|
HlGetRunLevel()
|
||||||
|
{
|
||||||
|
return HlpTransformApicTprToRunLevel(HlReadApicRegister(APIC_TPR));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets new run level for the current processor.
|
||||||
|
*
|
||||||
|
* @param RunLevel
|
||||||
|
* Supplies the new run level to store into APIC.
|
||||||
|
*
|
||||||
|
* @return This routine does not return any value.
|
||||||
|
*
|
||||||
|
* @since XT 1.0
|
||||||
|
*/
|
||||||
|
XTFASTCALL
|
||||||
|
VOID
|
||||||
|
HlSetRunLevel(IN KRUNLEVEL RunLevel)
|
||||||
|
{
|
||||||
|
HlWriteApicRegister(APIC_TPR, HlpTransformRunLevelToApicTpr(RunLevel));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Maps APIC interrupt vector to XT run level.
|
||||||
|
*
|
||||||
|
* @param Tpr
|
||||||
|
* Supplies the interrupt vector rad from APIC Task Priority Register.
|
||||||
|
*
|
||||||
|
* @return This routine returns the XT run level corresponding to the specified APIC interrupt vector.
|
||||||
|
*
|
||||||
|
* @since XT 1.0
|
||||||
|
*/
|
||||||
|
XTFASTCALL
|
||||||
|
KRUNLEVEL
|
||||||
|
HlpTransformApicTprToRunLevel(IN UCHAR Tpr)
|
||||||
|
{
|
||||||
|
KRUNLEVEL TransformationTable[16] =
|
||||||
|
{
|
||||||
|
PASSIVE_LEVEL,
|
||||||
|
PASSIVE_LEVEL,
|
||||||
|
PASSIVE_LEVEL,
|
||||||
|
APC_LEVEL,
|
||||||
|
DISPATCH_LEVEL,
|
||||||
|
DEVICE1_LEVEL,
|
||||||
|
DEVICE2_LEVEL,
|
||||||
|
DEVICE3_LEVEL,
|
||||||
|
DEVICE4_LEVEL,
|
||||||
|
DEVICE5_LEVEL,
|
||||||
|
DEVICE6_LEVEL,
|
||||||
|
DEVICE7_LEVEL,
|
||||||
|
PROFILE_LEVEL,
|
||||||
|
CLOCK_LEVEL,
|
||||||
|
IPI_LEVEL,
|
||||||
|
HIGH_LEVEL
|
||||||
|
};
|
||||||
|
|
||||||
|
/* Return the run level corresponding to the TPR from the transformation table. */
|
||||||
|
return TransformationTable[Tpr / 16];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Maps XT run level to interrupt vector suitable for the APIC Task Priority Register.
|
||||||
|
*
|
||||||
|
* @param RunLevel
|
||||||
|
* Supplies the XT run level.
|
||||||
|
*
|
||||||
|
* @return This routine returns the APIC interrupt vector corresponding to the specified XT run level.
|
||||||
|
*
|
||||||
|
* @since XT 1.0
|
||||||
|
*/
|
||||||
|
XTFASTCALL
|
||||||
|
UCHAR
|
||||||
|
HlpTransformRunLevelToApicTpr(IN KRUNLEVEL RunLevel)
|
||||||
|
{
|
||||||
|
UCHAR TransformationTable[32] =
|
||||||
|
{
|
||||||
|
APIC_VECTOR_ZERO,
|
||||||
|
APIC_VECTOR_APC,
|
||||||
|
APIC_VECTOR_DPC,
|
||||||
|
APIC_VECTOR_DPC,
|
||||||
|
APIC_VECTOR_DEVICE1,
|
||||||
|
APIC_VECTOR_DEVICE2,
|
||||||
|
APIC_VECTOR_DEVICE3,
|
||||||
|
APIC_VECTOR_DEVICE4,
|
||||||
|
APIC_VECTOR_DEVICE5,
|
||||||
|
APIC_VECTOR_DEVICE6,
|
||||||
|
APIC_VECTOR_DEVICE7,
|
||||||
|
APIC_VECTOR_DEVICE7,
|
||||||
|
APIC_VECTOR_DEVICE7,
|
||||||
|
APIC_VECTOR_DEVICE7,
|
||||||
|
APIC_VECTOR_DEVICE7,
|
||||||
|
APIC_VECTOR_DEVICE7,
|
||||||
|
APIC_VECTOR_DEVICE7,
|
||||||
|
APIC_VECTOR_DEVICE7,
|
||||||
|
APIC_VECTOR_DEVICE7,
|
||||||
|
APIC_VECTOR_DEVICE7,
|
||||||
|
APIC_VECTOR_DEVICE7,
|
||||||
|
APIC_VECTOR_DEVICE7,
|
||||||
|
APIC_VECTOR_DEVICE7,
|
||||||
|
APIC_VECTOR_DEVICE7,
|
||||||
|
APIC_VECTOR_DEVICE7,
|
||||||
|
APIC_VECTOR_DEVICE7,
|
||||||
|
APIC_VECTOR_DEVICE7,
|
||||||
|
APIC_VECTOR_GENERIC,
|
||||||
|
APIC_VECTOR_CLOCK,
|
||||||
|
APIC_VECTOR_IPI,
|
||||||
|
APIC_VECTOR_POWERFAIL,
|
||||||
|
APIC_VECTOR_NMI
|
||||||
|
};
|
||||||
|
|
||||||
|
/* Return the TPR corresponding to the run level from the transformation table. */
|
||||||
|
return TransformationTable[RunLevel];
|
||||||
|
}
|
@ -40,6 +40,11 @@ HlDrawPixel(IN ULONG PosX,
|
|||||||
IN ULONG PosY,
|
IN ULONG PosY,
|
||||||
IN ULONG Color);
|
IN ULONG Color);
|
||||||
|
|
||||||
|
XTFASTCALL
|
||||||
|
KRUNLEVEL
|
||||||
|
HlGetRunLevel();
|
||||||
|
|
||||||
|
|
||||||
XTCDECL
|
XTCDECL
|
||||||
XTSTATUS
|
XTSTATUS
|
||||||
HlInitializeComPort(IN OUT PCPPORT Port,
|
HlInitializeComPort(IN OUT PCPPORT Port,
|
||||||
@ -55,9 +60,21 @@ XTFASTCALL
|
|||||||
ULONG
|
ULONG
|
||||||
HlReadApicRegister(IN APIC_REGISTER Register);
|
HlReadApicRegister(IN APIC_REGISTER Register);
|
||||||
|
|
||||||
|
XTFASTCALL
|
||||||
|
VOID
|
||||||
|
HlSetRunLevel(IN KRUNLEVEL RunLevel);
|
||||||
|
|
||||||
XTFASTCALL
|
XTFASTCALL
|
||||||
VOID
|
VOID
|
||||||
HlWriteApicRegister(IN APIC_REGISTER Register,
|
HlWriteApicRegister(IN APIC_REGISTER Register,
|
||||||
IN ULONG Value);
|
IN ULONG Value);
|
||||||
|
|
||||||
|
XTFASTCALL
|
||||||
|
KRUNLEVEL
|
||||||
|
HlpTransformApicTprToRunLevel(IN UCHAR Tpr);
|
||||||
|
|
||||||
|
XTFASTCALL
|
||||||
|
UCHAR
|
||||||
|
HlpTransformRunLevelToApicTpr(IN KRUNLEVEL RunLevel);
|
||||||
|
|
||||||
#endif /* __XTOSKRNL_HL_H */
|
#endif /* __XTOSKRNL_HL_H */
|
||||||
|
@ -17,6 +17,10 @@ XTAPI
|
|||||||
VOID
|
VOID
|
||||||
KeClearEvent(IN PKEVENT Event);
|
KeClearEvent(IN PKEVENT Event);
|
||||||
|
|
||||||
|
XTFASTCALL
|
||||||
|
KRUNLEVEL
|
||||||
|
KeGetCurrentRunLevel();
|
||||||
|
|
||||||
XTAPI
|
XTAPI
|
||||||
VOID
|
VOID
|
||||||
KeHaltSystem();
|
KeHaltSystem();
|
||||||
@ -47,6 +51,10 @@ KeInitializeThread(IN PKPROCESS Process,
|
|||||||
IN PVOID Stack,
|
IN PVOID Stack,
|
||||||
IN BOOLEAN StartThread);
|
IN BOOLEAN StartThread);
|
||||||
|
|
||||||
|
XTFASTCALL
|
||||||
|
VOID
|
||||||
|
KeLowerRunLevel(IN KRUNLEVEL RunLevel);
|
||||||
|
|
||||||
XTAPI
|
XTAPI
|
||||||
VOID
|
VOID
|
||||||
KePanic(IN ULONG Code);
|
KePanic(IN ULONG Code);
|
||||||
@ -59,6 +67,10 @@ KePanicEx(IN ULONG Code,
|
|||||||
IN ULONG_PTR Parameter3,
|
IN ULONG_PTR Parameter3,
|
||||||
IN ULONG_PTR Parameter4);
|
IN ULONG_PTR Parameter4);
|
||||||
|
|
||||||
|
XTFASTCALL
|
||||||
|
KRUNLEVEL
|
||||||
|
KeRaiseRunLevel(IN KRUNLEVEL RunLevel);
|
||||||
|
|
||||||
XTAPI
|
XTAPI
|
||||||
LONG
|
LONG
|
||||||
KeSetEvent(IN PKEVENT Event,
|
KeSetEvent(IN PKEVENT Event,
|
||||||
|
81
xtoskrnl/ke/runlevel.c
Normal file
81
xtoskrnl/ke/runlevel.c
Normal file
@ -0,0 +1,81 @@
|
|||||||
|
/**
|
||||||
|
* PROJECT: ExectOS
|
||||||
|
* COPYRIGHT: See COPYING.md in the top level directory
|
||||||
|
* FILE: xtoskrnl/ke/runlevel.c
|
||||||
|
* DESCRIPTION: Running Level management support
|
||||||
|
* DEVELOPERS: Rafal Kupiec <belliash@codingworkshop.eu.org>
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <xtos.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the current running level of the current processor.
|
||||||
|
*
|
||||||
|
* @return This routine returns the current running level.
|
||||||
|
*
|
||||||
|
* @since XT 1.0
|
||||||
|
*/
|
||||||
|
XTFASTCALL
|
||||||
|
KRUNLEVEL
|
||||||
|
KeGetCurrentRunLevel()
|
||||||
|
{
|
||||||
|
return HlGetRunLevel();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Lowers the running level of the current processor.
|
||||||
|
*
|
||||||
|
* @param RunLevel
|
||||||
|
* Supplies the new running level to lower to.
|
||||||
|
*
|
||||||
|
* @return This routine does not return any value.
|
||||||
|
*
|
||||||
|
* @since XT 1.0
|
||||||
|
*/
|
||||||
|
XTFASTCALL
|
||||||
|
VOID
|
||||||
|
KeLowerRunLevel(IN KRUNLEVEL RunLevel)
|
||||||
|
{
|
||||||
|
KRUNLEVEL OldRunLevel;
|
||||||
|
|
||||||
|
/* Read current run level */
|
||||||
|
OldRunLevel = HlGetRunLevel();
|
||||||
|
|
||||||
|
/* Validate run level lowerage */
|
||||||
|
if(OldRunLevel > RunLevel)
|
||||||
|
{
|
||||||
|
/* Set new, lower run level */
|
||||||
|
HlSetRunLevel(RunLevel);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Raises the running level of the current processor.
|
||||||
|
*
|
||||||
|
* @param RunLevel
|
||||||
|
* Supplies the new running level to raise to.
|
||||||
|
*
|
||||||
|
* @return This routine returns the old running level.
|
||||||
|
*
|
||||||
|
* @since XT 1.0
|
||||||
|
*/
|
||||||
|
XTFASTCALL
|
||||||
|
KRUNLEVEL
|
||||||
|
KeRaiseRunLevel(IN KRUNLEVEL RunLevel)
|
||||||
|
{
|
||||||
|
KRUNLEVEL OldRunLevel;
|
||||||
|
|
||||||
|
/* Read current run level */
|
||||||
|
OldRunLevel = HlGetRunLevel();
|
||||||
|
|
||||||
|
/* Validate run level raise */
|
||||||
|
if(OldRunLevel < RunLevel)
|
||||||
|
{
|
||||||
|
/* Set new, higher run level */
|
||||||
|
HlSetRunLevel(RunLevel);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Return old run level */
|
||||||
|
return OldRunLevel;
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user