From c8087a42fc6b57a31ad24cd73ab1c617adfbd0ab Mon Sep 17 00:00:00 2001 From: Andreas Kling Date: Wed, 8 Apr 2020 14:07:12 +0200 Subject: [PATCH] Kernel: Move more things from init() to init_stage2() The purpose of init() is to get multi-tasking up and running. We don't want to do anything in init() that doesn't advance that goal. This patch moves some things from init() to init_stage2(), and adds a comment block explaining the split. --- Kernel/init.cpp | 87 ++++++++++++++++++++++++++----------------------- 1 file changed, 47 insertions(+), 40 deletions(-) diff --git a/Kernel/init.cpp b/Kernel/init.cpp index ab28f7512b8..26a41d11ef1 100644 --- a/Kernel/init.cpp +++ b/Kernel/init.cpp @@ -24,11 +24,6 @@ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ -#include "Devices/PATADiskDevice.h" -#include "KSyms.h" -#include "Process.h" -#include "RTC.h" -#include "Scheduler.h" #include #include #include @@ -48,6 +43,7 @@ #include #include #include +#include #include #include #include @@ -61,12 +57,16 @@ #include #include #include +#include #include #include #include #include #include +#include +#include #include +#include #include #include #include @@ -92,6 +92,16 @@ static void setup_time_management(); VirtualConsole* tty0; +// SerenityOS Kernel C++ entry point :^) +// +// This is where C++ execution begins, after boot.S transfers control here. +// +// The purpose of init() is to start multi-tasking. It does the bare minimum +// amount of work needed to start the scheduler. +// +// Once multi-tasking is ready, we spawn a new thread that starts in the +// init_stage2() function. Initialization continues there. + extern "C" [[noreturn]] void init() { setup_serial_debug(); @@ -105,7 +115,6 @@ extern "C" [[noreturn]] void init() MemoryManager::initialize(); - bool text_debug = kernel_command_line().contains("text_debug"); gdt_init(); idt_init(); @@ -113,8 +122,10 @@ extern "C" [[noreturn]] void init() setup_acpi(); new VFS; + new KeyboardDevice; + new PS2MouseDevice; + setup_vmmouse(); new DebugLogDevice; - new Console; klog() << "Starting SerenityOS..."; @@ -127,11 +138,6 @@ extern "C" [[noreturn]] void init() for (ctor_func_t* ctor = &start_ctors; ctor < &end_ctors; ctor++) (*ctor)(); - new KeyboardDevice; - new PS2MouseDevice; - setup_vmmouse(); - - new SB16; new NullDevice; if (!get_serial_debug()) new SerialDevice(SERIAL_COM1_ADDR, 64); @@ -144,33 +150,22 @@ extern "C" [[noreturn]] void init() new VirtualConsole(1); VirtualConsole::switch_to(0); - // Sample test to see if the ACPI parser is working... - klog() << "ACPI: HPET table @ " << ACPI::Parser::the().find_table("HPET"); - - setup_pci(); - - if (text_debug) { - dbg() << "Text mode enabled"; - } else { - if (multiboot_info_ptr->framebuffer_type == 1 || multiboot_info_ptr->framebuffer_type == 2) { - new MBVGADevice( - PhysicalAddress((u32)(multiboot_info_ptr->framebuffer_addr)), - multiboot_info_ptr->framebuffer_pitch, - multiboot_info_ptr->framebuffer_width, - multiboot_info_ptr->framebuffer_height); - } else { - new BXVGADevice; - } - } - - LoopbackAdapter::the(); - Process::initialize(); Thread::initialize(); Thread* init_stage2_thread = nullptr; Process::create_kernel_process(init_stage2_thread, "init_stage2", init_stage2); + Scheduler::pick_next(); + + sti(); + + Scheduler::idle_loop(); + ASSERT_NOT_REACHED(); +} + +void init_stage2() +{ Thread* syncd_thread = nullptr; Process::create_kernel_process(syncd_thread, "syncd", [] { for (;;) { @@ -193,22 +188,34 @@ extern "C" [[noreturn]] void init() } }); - Scheduler::pick_next(); + // Sample test to see if the ACPI parser is working... + klog() << "ACPI: HPET table @ " << ACPI::Parser::the().find_table("HPET"); - sti(); + setup_pci(); - Scheduler::idle_loop(); - ASSERT_NOT_REACHED(); -} + if (kernel_command_line().contains("text_debug")) { + dbg() << "Text mode enabled"; + } else { + if (multiboot_info_ptr->framebuffer_type == 1 || multiboot_info_ptr->framebuffer_type == 2) { + new MBVGADevice( + PhysicalAddress((u32)(multiboot_info_ptr->framebuffer_addr)), + multiboot_info_ptr->framebuffer_pitch, + multiboot_info_ptr->framebuffer_width, + multiboot_info_ptr->framebuffer_height); + } else { + new BXVGADevice; + } + } + + LoopbackAdapter::the(); -void init_stage2() -{ Syscall::initialize(); new ZeroDevice; new FullDevice; new RandomDevice; new PTYMultiplexer; + new SB16; bool dmi_unreliable = kernel_command_line().contains("dmi_unreliable"); if (dmi_unreliable) {