Propagate allocation failures from idle process and thread setup
All checks were successful
Builds / ExectOS (amd64, release) (push) Successful in 33s
Builds / ExectOS (i686, debug) (push) Successful in 31s
Builds / ExectOS (i686, release) (push) Successful in 44s
Builds / ExectOS (amd64, debug) (push) Successful in 48s

This commit is contained in:
2026-06-04 14:30:01 +02:00
parent f13326ffaf
commit 53a239958f
7 changed files with 68 additions and 26 deletions

View File

@@ -23,7 +23,7 @@ namespace KE
public: public:
STATIC XTAPI PKPROCESS GetIdleProcess(VOID); STATIC XTAPI PKPROCESS GetIdleProcess(VOID);
STATIC XTAPI PEPROCESS GetInitialProcess(VOID); STATIC XTAPI PEPROCESS GetInitialProcess(VOID);
STATIC XTAPI VOID InitializeIdleProcess(IN OUT PKPROCESS Process, STATIC XTAPI XTSTATUS InitializeIdleProcess(IN OUT PKPROCESS Process,
IN PULONG_PTR DirectoryTable); IN PULONG_PTR DirectoryTable);
STATIC XTAPI VOID InitializeProcess(IN OUT PKPROCESS Process, STATIC XTAPI VOID InitializeProcess(IN OUT PKPROCESS Process,
IN KPRIORITY Priority, IN KPRIORITY Priority,

View File

@@ -22,7 +22,7 @@ namespace KE
public: public:
STATIC XTAPI PETHREAD GetInitialThread(VOID); STATIC XTAPI PETHREAD GetInitialThread(VOID);
STATIC XTAPI VOID InitializeIdleThread(IN PKPROCESS IdleProcess, STATIC XTAPI XTSTATUS InitializeIdleThread(IN PKPROCESS IdleProcess,
IN OUT PKTHREAD IdleThread, IN OUT PKTHREAD IdleThread,
IN PKPROCESSOR_CONTROL_BLOCK Prcb, IN PKPROCESSOR_CONTROL_BLOCK Prcb,
IN PVOID Stack); IN PVOID Stack);

View File

@@ -18,7 +18,7 @@ namespace PS
class Process class Process
{ {
public: public:
STATIC XTAPI VOID CreateIdleProcess(IN PKPROCESSOR_CONTROL_BLOCK Prcb); STATIC XTAPI XTSTATUS CreateIdleProcess(IN PKPROCESSOR_CONTROL_BLOCK Prcb);
}; };
} }

View File

@@ -52,12 +52,13 @@ KE::KProcess::GetInitialProcess(VOID)
* @since XT 1.0 * @since XT 1.0
*/ */
XTAPI XTAPI
VOID XTSTATUS
KE::KProcess::InitializeIdleProcess(IN OUT PKPROCESS Process, KE::KProcess::InitializeIdleProcess(IN OUT PKPROCESS Process,
IN PULONG_PTR DirectoryTable) IN PULONG_PTR DirectoryTable)
{ {
ULONG AffinitySize, MapSize; ULONG AffinitySize, MapSize;
PACPI_SYSTEM_INFO SysInfo; PACPI_SYSTEM_INFO SysInfo;
XTSTATUS Status;
/* Retrieve hardware topology from ACPI */ /* Retrieve hardware topology from ACPI */
HL::Acpi::GetSystemInformation(&SysInfo); HL::Acpi::GetSystemInformation(&SysInfo);
@@ -69,9 +70,21 @@ KE::KProcess::InitializeIdleProcess(IN OUT PKPROCESS Process,
/* Align size to the 8-byte boundary */ /* Align size to the 8-byte boundary */
MapSize = (MapSize + 7) & ~7; MapSize = (MapSize + 7) & ~7;
/* Allocate the process-level affinity structures */ /* Allocate the process-level affinity structure */
MM::Allocator::AllocatePool(NonPagedPool, MapSize, (PVOID*)&Process->Affinity); Status = MM::Allocator::AllocatePool(NonPagedPool, MapSize, (PVOID*)&Process->Affinity);
MM::Allocator::AllocatePool(NonPagedPool, MapSize, (PVOID*)&Process->ActiveProcessors); if(Status != STATUS_SUCCESS)
{
/* Memory allocation failed, return the status code */
return Status;
}
/* Allocate the process-level active processors structure */
Status = MM::Allocator::AllocatePool(NonPagedPool, MapSize, (PVOID*)&Process->ActiveProcessors);
if(Status != STATUS_SUCCESS)
{
/* Memory allocation failed, return the status code */
return Status;
}
/* Zero the process-level affinity structures */ /* Zero the process-level affinity structures */
RTL::Memory::ZeroMemory(Process->Affinity, MapSize); RTL::Memory::ZeroMemory(Process->Affinity, MapSize);
@@ -85,6 +98,9 @@ KE::KProcess::InitializeIdleProcess(IN OUT PKPROCESS Process,
/* Initialize Idle process */ /* Initialize Idle process */
KE::KProcess::InitializeProcess(Process, 0, DirectoryTable, FALSE); KE::KProcess::InitializeProcess(Process, 0, DirectoryTable, FALSE);
Process->Quantum = MAXCHAR; Process->Quantum = MAXCHAR;
/* Return success */
return STATUS_SUCCESS;
} }
/** /**

View File

@@ -43,7 +43,7 @@ KE::KThread::GetInitialThread(VOID)
* @since XT 1.0 * @since XT 1.0
*/ */
XTAPI XTAPI
VOID XTSTATUS
KE::KThread::InitializeIdleThread(IN PKPROCESS IdleProcess, KE::KThread::InitializeIdleThread(IN PKPROCESS IdleProcess,
IN OUT PKTHREAD IdleThread, IN OUT PKTHREAD IdleThread,
IN PKPROCESSOR_CONTROL_BLOCK Prcb, IN PKPROCESSOR_CONTROL_BLOCK Prcb,
@@ -51,6 +51,7 @@ KE::KThread::InitializeIdleThread(IN PKPROCESS IdleProcess,
{ {
ULONG AffinitySize, CpuIndex, CpuTargetBit, MapSize; ULONG AffinitySize, CpuIndex, CpuTargetBit, MapSize;
PACPI_SYSTEM_INFO SysInfo; PACPI_SYSTEM_INFO SysInfo;
XTSTATUS Status;
/* Retrieve hardware topology from ACPI */ /* Retrieve hardware topology from ACPI */
HL::Acpi::GetSystemInformation(&SysInfo); HL::Acpi::GetSystemInformation(&SysInfo);
@@ -62,17 +63,34 @@ KE::KThread::InitializeIdleThread(IN PKPROCESS IdleProcess,
/* Align size to the 8-byte boundary */ /* Align size to the 8-byte boundary */
MapSize = (MapSize + 7) & ~7; MapSize = (MapSize + 7) & ~7;
/* Allocate the thread-level affinity structures */ /* Allocate the thread-level affinity structure */
MM::Allocator::AllocatePool(NonPagedPool, MapSize, (PVOID*)&IdleThread->Affinity); Status = MM::Allocator::AllocatePool(NonPagedPool, MapSize, (PVOID*)&IdleThread->Affinity);
MM::Allocator::AllocatePool(NonPagedPool, MapSize, (PVOID*)&IdleThread->UserAffinity); if(Status != STATUS_SUCCESS)
{
/* Memory allocation failed, return the status code */
return Status;
}
/* Allocate the thread-level user affinity structure */
Status = MM::Allocator::AllocatePool(NonPagedPool, MapSize, (PVOID*)&IdleThread->UserAffinity);
if(Status != STATUS_SUCCESS)
{
/* Memory allocation failed, return the status code */
return Status;
}
/* Zero the thread-level affinity structures */ /* Zero the thread-level affinity structures */
RTL::Memory::ZeroMemory(IdleThread->Affinity, MapSize); RTL::Memory::ZeroMemory(IdleThread->Affinity, MapSize);
RTL::Memory::ZeroMemory(IdleThread->UserAffinity, MapSize); RTL::Memory::ZeroMemory(IdleThread->UserAffinity, MapSize);
/* Initialize Idle thread */ /* Initialize Idle thread */
KE::KThread::InitializeThread(IdleProcess, IdleThread, NULLPTR, NULLPTR, NULLPTR, Status = KE::KThread::InitializeThread(IdleProcess, IdleThread, NULLPTR, NULLPTR, NULLPTR,
NULLPTR, NULLPTR, Stack, TRUE); NULLPTR, NULLPTR, Stack, TRUE);
if(Status != STATUS_SUCCESS)
{
/* Failed to initialize IDLE thread, return status code */
return Status;
}
/* Configure Idle thread scheduling parameters */ /* Configure Idle thread scheduling parameters */
IdleThread->NextProcessor = Prcb->CpuNumber; IdleThread->NextProcessor = Prcb->CpuNumber;
@@ -96,6 +114,9 @@ KE::KThread::InitializeIdleThread(IN PKPROCESS IdleProcess,
/* Register this CPU as active in the Idle Process */ /* Register this CPU as active in the Idle Process */
IdleProcess->ActiveProcessors->Bitmap[CpuIndex] |= ((KAFFINITY)1 << CpuTargetBit); IdleProcess->ActiveProcessors->Bitmap[CpuIndex] |= ((KAFFINITY)1 << CpuTargetBit);
/* Return success */
return STATUS_SUCCESS;
} }
/** /**

View File

@@ -20,12 +20,13 @@
* @since XT 1.0 * @since XT 1.0
*/ */
XTAPI XTAPI
VOID XTSTATUS
PS::Process::CreateIdleProcess(IN PKPROCESSOR_CONTROL_BLOCK Prcb) PS::Process::CreateIdleProcess(IN PKPROCESSOR_CONTROL_BLOCK Prcb)
{ {
ULONG_PTR PageDirectory[2]; ULONG_PTR PageDirectory[2];
PKPROCESS IdleProcess; PKPROCESS IdleProcess;
PKTHREAD IdleThread; PKTHREAD IdleThread;
XTSTATUS Status;
/* Get initial IDLE thread */ /* Get initial IDLE thread */
IdleThread = Prcb->CurrentThread; IdleThread = Prcb->CurrentThread;
@@ -37,7 +38,14 @@ PS::Process::CreateIdleProcess(IN PKPROCESSOR_CONTROL_BLOCK Prcb)
PageDirectory[0] = 0; PageDirectory[0] = 0;
PageDirectory[1] = 0; PageDirectory[1] = 0;
/* Initialize Idle process and Idle thread */ /* Initialize IDLE process */
KE::KProcess::InitializeIdleProcess(IdleProcess, PageDirectory); Status = KE::KProcess::InitializeIdleProcess(IdleProcess, PageDirectory);
KE::KThread::InitializeIdleThread(IdleProcess, IdleThread, Prcb, AR::ProcessorSupport::GetBootStack()); if(Status != STATUS_SUCCESS)
{
/* Failed to initialize IDLE process, return status code */
return Status;
}
/* Initialize IDLE thread */
return KE::KThread::InitializeIdleThread(IdleProcess, IdleThread, Prcb, AR::ProcessorSupport::GetBootStack());
} }

View File

@@ -38,7 +38,7 @@ PS::Thread::CreateIdleThread(IN PKPROCESSOR_CONTROL_BLOCK Prcb,
Status = MM::Allocator::AllocatePool(NonPagedPool, sizeof(ETHREAD), (PVOID*)&IdleThread); Status = MM::Allocator::AllocatePool(NonPagedPool, sizeof(ETHREAD), (PVOID*)&IdleThread);
if(Status != STATUS_SUCCESS) if(Status != STATUS_SUCCESS)
{ {
/* Allocation failed, return the status code */ /* Memory allocation failed, return the status code */
return Status; return Status;
} }
@@ -50,8 +50,5 @@ PS::Thread::CreateIdleThread(IN PKPROCESSOR_CONTROL_BLOCK Prcb,
Prcb->IdleThread = &IdleThread->ThreadControlBlock; Prcb->IdleThread = &IdleThread->ThreadControlBlock;
/* Initialize the IDLE thread */ /* Initialize the IDLE thread */
KE::KThread::InitializeIdleThread(IdleProcess, &IdleThread->ThreadControlBlock, Prcb, Stack); return KE::KThread::InitializeIdleThread(IdleProcess, &IdleThread->ThreadControlBlock, Prcb, Stack);
/* Return success */
return STATUS_SUCCESS;
} }