mirror of
https://github.com/RGBCube/serenity
synced 2025-05-31 08:58:11 +00:00
Kernel: Make Thread::kernel_stack_base() work for kernel processes.
This commit is contained in:
parent
c414e65498
commit
45ff3a7e6a
2 changed files with 6 additions and 3 deletions
|
@ -44,11 +44,13 @@ Thread::Thread(Process& process)
|
|||
if (m_process.is_ring0()) {
|
||||
// FIXME: This memory is leaked.
|
||||
// But uh, there's also no kernel process termination, so I guess it's not technically leaked...
|
||||
dword stack_bottom = (dword)kmalloc_eternal(default_kernel_stack_size);
|
||||
m_tss.esp = (stack_bottom + default_kernel_stack_size) & 0xfffffff8u;
|
||||
m_kernel_stack_base = (dword)kmalloc_eternal(default_kernel_stack_size);
|
||||
m_tss.esp = (m_kernel_stack_base + default_kernel_stack_size) & 0xfffffff8u;
|
||||
|
||||
} else {
|
||||
// Ring3 processes need a separate stack for Ring0.
|
||||
m_kernel_stack_region = MM.allocate_kernel_region(default_kernel_stack_size, String::format("Kernel Stack (Thread %d)", m_tid));
|
||||
m_kernel_stack_base = m_kernel_stack_region->laddr().get();
|
||||
m_tss.ss0 = 0x10;
|
||||
m_tss.esp0 = m_kernel_stack_region->laddr().offset(default_kernel_stack_size).get() & 0xfffffff8u;
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue