mirror of
https://github.com/RGBCube/serenity
synced 2025-07-24 21:57:35 +00:00
Kernel: Ignore allocation failures during thread finalization
We ignore allocation failures above the first 32 guaranteed thread slots, and just flag our future-selves to finalize these threads at a later point.
This commit is contained in:
parent
7e9df6ddba
commit
a0f404551e
2 changed files with 11 additions and 4 deletions
|
@ -14,10 +14,12 @@ static void finalizer_task(void*)
|
|||
{
|
||||
Thread::current()->set_priority(THREAD_PRIORITY_LOW);
|
||||
for (;;) {
|
||||
g_finalizer_wait_queue->wait_forever("FinalizerTask");
|
||||
|
||||
// The order of this if-else is important: We want to continue trying to finalize the threads in case
|
||||
// Thread::finalize_dying_threads set g_finalizer_has_work back to true due to OOM conditions
|
||||
if (g_finalizer_has_work.exchange(false, AK::MemoryOrder::memory_order_acq_rel) == true)
|
||||
Thread::finalize_dying_threads();
|
||||
else
|
||||
g_finalizer_wait_queue->wait_forever("FinalizerTask");
|
||||
}
|
||||
};
|
||||
|
||||
|
|
|
@ -529,8 +529,13 @@ void Thread::finalize_dying_threads()
|
|||
{
|
||||
SpinlockLocker lock(g_scheduler_lock);
|
||||
for_each_in_state(Thread::State::Dying, [&](Thread& thread) {
|
||||
if (thread.is_finalizable())
|
||||
dying_threads.append(&thread);
|
||||
if (!thread.is_finalizable())
|
||||
return;
|
||||
auto result = dying_threads.try_append(&thread);
|
||||
// We ignore allocation failures above the first 32 guaranteed thread slots, and
|
||||
// just flag our future-selves to finalize these threads at a later point
|
||||
if (result.is_error())
|
||||
g_finalizer_has_work.store(true, AK::MemoryOrder::memory_order_release);
|
||||
});
|
||||
}
|
||||
for (auto* thread : dying_threads) {
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue