pluto/src/kernel/kmain.zig

66 lines
2.5 KiB
Zig
Raw Normal View History

2019-05-23 17:50:37 +01:00
const std = @import("std");
const builtin = @import("builtin");
const is_test = builtin.is_test;
const build_options = @import("build_options");
const mock_path = build_options.mock_path;
const arch = @import("arch.zig").internals;
const multiboot = @import("multiboot.zig");
const tty = @import("tty.zig");
const vga = @import("vga.zig");
2019-06-22 10:00:57 +01:00
const log = @import("log.zig");
2019-06-16 23:48:32 +01:00
const serial = @import("serial.zig");
2019-09-09 23:38:06 +01:00
const pmm = @import("pmm.zig");
const mem = if (is_test) @import(mock_path ++ "mem_mock.zig") else @import("mem.zig");
2019-11-02 02:18:02 +00:00
const panic_root = if (is_test) @import(mock_path ++ "panic_mock.zig") else @import("panic.zig");
const options = @import("build_options");
comptime {
if (!is_test) {
switch (builtin.arch) {
.i386 => _ = @import("arch/x86/boot.zig"),
else => {},
}
}
}
// This is for unit testing as we need to export KERNEL_ADDR_OFFSET as it is no longer available
// from the linker script
export var KERNEL_ADDR_OFFSET: u32 = if (builtin.is_test) 0xC0000000 else undefined;
// Just call the panic function, as this need to be in the root source file
pub fn panic(msg: []const u8, error_return_trace: ?*builtin.StackTrace) noreturn {
@setCold(true);
2020-01-01 19:12:36 +00:00
panic_root.panic(error_return_trace, "{}", .{msg});
}
export fn kmain(mb_info: *multiboot.multiboot_info_t, mb_magic: u32) void {
if (mb_magic == multiboot.MULTIBOOT_BOOTLOADER_MAGIC) {
// Booted with compatible bootloader
2019-10-08 11:20:37 +01:00
serial.init(serial.DEFAULT_BAUDRATE, serial.Port.COM1) catch |e| {
2020-01-01 19:12:36 +00:00
panic_root.panic(@errorReturnTrace(), "Failed to initialise serial: {}", .{e});
2019-10-08 11:20:37 +01:00
};
if (build_options.rt_test) log.runtimeTests();
2019-11-02 02:00:49 +00:00
const mem_profile = mem.init(mb_info);
var buffer = mem_profile.vaddr_end[0..mem_profile.fixed_alloc_size];
var fixed_allocator = std.heap.FixedBufferAllocator.init(buffer);
2019-06-22 10:00:57 +01:00
2019-09-09 23:38:06 +01:00
pmm.init(&mem_profile, &fixed_allocator.allocator);
2020-01-01 19:12:36 +00:00
log.logInfo("Init arch " ++ @tagName(builtin.arch) ++ "\n", .{});
2019-11-02 02:00:49 +00:00
arch.init(mb_info, &mem_profile, &fixed_allocator.allocator);
2020-01-01 19:12:36 +00:00
log.logInfo("Arch init done\n", .{});
2019-11-02 02:18:02 +00:00
panic_root.init(&mem_profile, &fixed_allocator.allocator) catch |e| {
2020-01-01 19:12:36 +00:00
panic_root.panic(@errorReturnTrace(), "Failed to initialise panic: {}", .{e});
2019-11-02 02:18:02 +00:00
};
vga.init();
tty.init();
2019-06-16 23:48:32 +01:00
2020-01-01 19:12:36 +00:00
log.logInfo("Init done\n", .{});
2020-01-01 19:12:36 +00:00
tty.print("Hello Pluto from kernel :)\n", .{});
2019-11-02 02:18:02 +00:00
// The panic runtime tests must run last as they never return
if (options.rt_test) panic_root.runtimeTests();
}
}