Propagate allocation failures from idle process and thread setup
This commit is contained in:
@@ -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,
|
||||||
|
|||||||
@@ -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);
|
||||||
|
|||||||
@@ -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);
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@@ -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());
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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;
|
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user