forked from xt-sys/exectos
Basic processor initialization code
This commit is contained in:
parent
d4ee87fd62
commit
f6c621c2a6
@ -70,6 +70,9 @@
|
|||||||
/* Serial port I/O addresses */
|
/* Serial port I/O addresses */
|
||||||
#define COMPORT_ADDRESSES {0x000, 0x3F8, 0x2F8, 0x3E8, 0x2E8, 0x5F8, 0x4F8, 0x5E8, 0x4E8}
|
#define COMPORT_ADDRESSES {0x000, 0x3F8, 0x2F8, 0x3E8, 0x2E8, 0x5F8, 0x4F8, 0x5E8, 0x4E8}
|
||||||
|
|
||||||
|
/* Initial stall factor */
|
||||||
|
#define INITIAL_STALL_FACTOR 100
|
||||||
|
|
||||||
/* APIC Base Register */
|
/* APIC Base Register */
|
||||||
typedef union _APIC_BASE_REGISTER
|
typedef union _APIC_BASE_REGISTER
|
||||||
{
|
{
|
||||||
@ -118,4 +121,14 @@ typedef union _APIC_SPURIOUS_REGISTER
|
|||||||
};
|
};
|
||||||
} APIC_SPURIOUS_REGISTER, *PAPIC_SPURIOUS_REGISTER;
|
} APIC_SPURIOUS_REGISTER, *PAPIC_SPURIOUS_REGISTER;
|
||||||
|
|
||||||
|
/* Processor identity structure */
|
||||||
|
typedef struct _HAL_PROCESSOR_IDENTITY
|
||||||
|
{
|
||||||
|
UCHAR ProcessorId;
|
||||||
|
UCHAR LApicId;
|
||||||
|
BOOLEAN Bsp;
|
||||||
|
BOOLEAN Started;
|
||||||
|
PKPROCESSOR_BLOCK ProcessorBlock;
|
||||||
|
} HAL_PROCESSOR_IDENTITY, *PHAL_PROCESSOR_IDENTITY;
|
||||||
|
|
||||||
#endif /* __XTDK_AMD64_HLTYPES_H */
|
#endif /* __XTDK_AMD64_HLTYPES_H */
|
||||||
|
@ -75,6 +75,9 @@
|
|||||||
/* Serial port I/O addresses */
|
/* Serial port I/O addresses */
|
||||||
#define COMPORT_ADDRESSES {0x000, 0x3F8, 0x2F8, 0x3E8, 0x2E8, 0x5F8, 0x4F8, 0x5E8, 0x4E8}
|
#define COMPORT_ADDRESSES {0x000, 0x3F8, 0x2F8, 0x3E8, 0x2E8, 0x5F8, 0x4F8, 0x5E8, 0x4E8}
|
||||||
|
|
||||||
|
/* Initial stall factor */
|
||||||
|
#define INITIAL_STALL_FACTOR 100
|
||||||
|
|
||||||
/* APIC Base Register */
|
/* APIC Base Register */
|
||||||
typedef union _APIC_BASE_REGISTER
|
typedef union _APIC_BASE_REGISTER
|
||||||
{
|
{
|
||||||
@ -123,4 +126,14 @@ typedef union _APIC_SPURIOUS_REGISTER
|
|||||||
};
|
};
|
||||||
} APIC_SPURIOUS_REGISTER, *PAPIC_SPURIOUS_REGISTER;
|
} APIC_SPURIOUS_REGISTER, *PAPIC_SPURIOUS_REGISTER;
|
||||||
|
|
||||||
|
/* Processor identity structure */
|
||||||
|
typedef struct _HAL_PROCESSOR_IDENTITY
|
||||||
|
{
|
||||||
|
UCHAR ProcessorId;
|
||||||
|
UCHAR LApicId;
|
||||||
|
BOOLEAN Bsp;
|
||||||
|
BOOLEAN Started;
|
||||||
|
PKPROCESSOR_BLOCK ProcessorBlock;
|
||||||
|
} HAL_PROCESSOR_IDENTITY, *PHAL_PROCESSOR_IDENTITY;
|
||||||
|
|
||||||
#endif /* __XTDK_I686_HLTYPES_H */
|
#endif /* __XTDK_I686_HLTYPES_H */
|
||||||
|
@ -14,6 +14,7 @@ list(APPEND XTOSKRNL_SOURCE
|
|||||||
${XTOSKRNL_SOURCE_DIR}/ar/${ARCH}/traps.c
|
${XTOSKRNL_SOURCE_DIR}/ar/${ARCH}/traps.c
|
||||||
${XTOSKRNL_SOURCE_DIR}/ex/rundown.c
|
${XTOSKRNL_SOURCE_DIR}/ex/rundown.c
|
||||||
${XTOSKRNL_SOURCE_DIR}/hl/cport.c
|
${XTOSKRNL_SOURCE_DIR}/hl/cport.c
|
||||||
|
${XTOSKRNL_SOURCE_DIR}/hl/cpu.c
|
||||||
${XTOSKRNL_SOURCE_DIR}/hl/efifb.c
|
${XTOSKRNL_SOURCE_DIR}/hl/efifb.c
|
||||||
${XTOSKRNL_SOURCE_DIR}/hl/globals.c
|
${XTOSKRNL_SOURCE_DIR}/hl/globals.c
|
||||||
${XTOSKRNL_SOURCE_DIR}/hl/pic.c
|
${XTOSKRNL_SOURCE_DIR}/hl/pic.c
|
||||||
|
47
xtoskrnl/hl/cpu.c
Normal file
47
xtoskrnl/hl/cpu.c
Normal file
@ -0,0 +1,47 @@
|
|||||||
|
/**
|
||||||
|
* PROJECT: ExectOS
|
||||||
|
* COPYRIGHT: See COPYING.md in the top level directory
|
||||||
|
* FILE: xtoskrnl/hl/cpu.c
|
||||||
|
* DESCRIPTION: HAL Processor support
|
||||||
|
* DEVELOPERS: Rafal Kupiec <belliash@codingworkshop.eu.org>
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <xtos.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Initializes the processor.
|
||||||
|
*
|
||||||
|
* @return This routine does not return any value.
|
||||||
|
*
|
||||||
|
* @since XT 1.0
|
||||||
|
*/
|
||||||
|
XTAPI
|
||||||
|
VOID
|
||||||
|
HlInitializeProcessor(VOID)
|
||||||
|
{
|
||||||
|
PKPROCESSOR_BLOCK ProcessorBlock;
|
||||||
|
KAFFINITY Affinity;
|
||||||
|
ULONG CpuNumber = 0;
|
||||||
|
|
||||||
|
/* Get current processor block */
|
||||||
|
ProcessorBlock = KeGetCurrentProcessorBlock();
|
||||||
|
|
||||||
|
/* Set initial stall factor */
|
||||||
|
ProcessorBlock->StallScaleFactor = INITIAL_STALL_FACTOR;
|
||||||
|
|
||||||
|
/* Record processor block in the processors table */
|
||||||
|
HlpProcessorsIdentity[CpuNumber].ProcessorBlock = ProcessorBlock;
|
||||||
|
|
||||||
|
/* Set processor affinity */
|
||||||
|
Affinity = (KAFFINITY) 1 << CpuNumber;
|
||||||
|
|
||||||
|
/* Apply affinity to a set of processors */
|
||||||
|
HlpActiveProcessors |= Affinity;
|
||||||
|
|
||||||
|
/* Initialize APIC for this processor */
|
||||||
|
HlpInitializeApic();
|
||||||
|
|
||||||
|
/* Set the APIC running level */
|
||||||
|
HlSetRunLevel(KeGetCurrentProcessorBlock()->RunLevel);
|
||||||
|
}
|
@ -9,8 +9,14 @@
|
|||||||
#include <xtos.h>
|
#include <xtos.h>
|
||||||
|
|
||||||
|
|
||||||
|
/* Active processors count */
|
||||||
|
KAFFINITY HlpActiveProcessors;
|
||||||
|
|
||||||
/* APIC mode */
|
/* APIC mode */
|
||||||
HAL_APIC_MODE HlpApicMode;
|
HAL_APIC_MODE HlpApicMode;
|
||||||
|
|
||||||
/* FrameBuffer information */
|
/* FrameBuffer information */
|
||||||
HAL_FRAMEBUFFER_DATA HlpFrameBufferData;
|
HAL_FRAMEBUFFER_DATA HlpFrameBufferData;
|
||||||
|
|
||||||
|
/* Processors identity table */
|
||||||
|
HAL_PROCESSOR_IDENTITY HlpProcessorsIdentity[MAXIMUM_PROCESSORS] = {{0}};
|
||||||
|
@ -12,12 +12,18 @@
|
|||||||
#include <xtos.h>
|
#include <xtos.h>
|
||||||
|
|
||||||
|
|
||||||
|
/* Active processors count */
|
||||||
|
EXTERN KAFFINITY HlpActiveProcessors;
|
||||||
|
|
||||||
/* APIC mode */
|
/* APIC mode */
|
||||||
EXTERN HAL_APIC_MODE HlpApicMode;
|
EXTERN HAL_APIC_MODE HlpApicMode;
|
||||||
|
|
||||||
/* FrameBuffer information */
|
/* FrameBuffer information */
|
||||||
EXTERN HAL_FRAMEBUFFER_DATA HlpFrameBufferData;
|
EXTERN HAL_FRAMEBUFFER_DATA HlpFrameBufferData;
|
||||||
|
|
||||||
|
/* Processors identity table */
|
||||||
|
EXTERN HAL_PROCESSOR_IDENTITY HlpProcessorsIdentity[MAXIMUM_PROCESSORS];
|
||||||
|
|
||||||
/* Pointer to boot loader provided DbgPrint() routine */
|
/* Pointer to boot loader provided DbgPrint() routine */
|
||||||
EXTERN VOID (*KeDbgPrint)(IN PWCHAR Format, IN ...);
|
EXTERN VOID (*KeDbgPrint)(IN PWCHAR Format, IN ...);
|
||||||
|
|
||||||
|
@ -85,6 +85,10 @@ XTAPI
|
|||||||
VOID
|
VOID
|
||||||
HlpInitializeApic(VOID);
|
HlpInitializeApic(VOID);
|
||||||
|
|
||||||
|
XTAPI
|
||||||
|
VOID
|
||||||
|
HlInitializeProcessor(VOID);
|
||||||
|
|
||||||
XTFASTCALL
|
XTFASTCALL
|
||||||
KRUNLEVEL
|
KRUNLEVEL
|
||||||
HlpTransformApicTprToRunLevel(IN UCHAR Tpr);
|
HlpTransformApicTprToRunLevel(IN UCHAR Tpr);
|
||||||
|
Loading…
Reference in New Issue
Block a user