feat(loader, kernel): impl part of loader and initialize kernel structure

This commit is contained in:
2026-04-11 09:42:09 +08:00
parent 1233ae9e9b
commit 34ccf69569
53 changed files with 1743 additions and 777 deletions

View File

@@ -1,35 +1,25 @@
const std = @import("std");
const kernel_build = @import("kernel/build.zig");
fn buildImage(b: *std.Build, target: std.Build.ResolvedTarget, optimize: std.builtin.OptimizeMode) *std.Build.Step {
switch (target.result.cpu.arch) {
.x86_64 => {
const arch_build = @import("arch/x86/boot/build.zig");
return arch_build.buildImage(b, optimize);
},
else => {
@panic("target architecture unsupported");
}
}
}
pub fn build(b: *std.Build) void {
const kernel_only_step = b.step("kernel", "Build the kernel only");
const full_step = b.step("full", "Build the full OS image");
const qemu_step = b.step("qemu", "Build and run in QEMU");
const target = b.resolveTargetQuery(.{
.cpu_arch = .x86_64,
.os_tag = .freestanding,
.abi = .none
var arch_build_image: ?*const fn(*std.Build)void = null;
const target = b.standardTargetOptions(.{
.default_target = .{
.cpu_arch = .x86_64,
.os_tag = .freestanding,
.abi = .none,
}
});
const optimize = b.standardOptimizeOption(.{});
const kernel_install = kernel_build.buildKernelBin(b, target, optimize);
kernel_only_step.dependOn(&kernel_install.step);
const image_step = buildImage(b, target, optimize);
b.getInstallStep().dependOn(image_step);
full_step.dependOn(image_step);
qemu_step.dependOn(image_step);
if (target.query.cpu_arch) |arch| {
switch (arch) {
.x86_64 => {
arch_build_image = @import("arch/x86_64/build_arch.zig").buildImage;
},
else => {},
}
}
if (arch_build_image) |build_fn| {
build_fn(b);
} else {
@panic("Architecture not specified or unsupported");
}
}