system: Add a memory manager stub
This commit is contained in:
parent
23334004a5
commit
6390785c4b
@ -5,3 +5,4 @@ default 1 1000
|
|||||||
menuentry Astryon default
|
menuentry Astryon default
|
||||||
kernel core
|
kernel core
|
||||||
module init
|
module init
|
||||||
|
module memory
|
||||||
|
BIN
boot/memory
Executable file
BIN
boot/memory
Executable file
Binary file not shown.
@ -1,9 +1,11 @@
|
|||||||
const std = @import("std");
|
const std = @import("std");
|
||||||
const init = @import("init/build.zig");
|
const init = @import("init/build.zig");
|
||||||
|
const memory = @import("memory/build.zig");
|
||||||
|
|
||||||
pub fn buildAsSubmodule(b: *std.Build, build_step: *std.Build.Step, optimize: std.builtin.OptimizeMode, system_module: *std.Build.Module) void {
|
pub fn buildAsSubmodule(b: *std.Build, build_step: *std.Build.Step, optimize: std.builtin.OptimizeMode, system_module: *std.Build.Module) void {
|
||||||
const system_step = b.step("system", "Build core system services");
|
const system_step = b.step("system", "Build core system services");
|
||||||
init.buildAsSubmodule(b, system_step, optimize, system_module);
|
init.buildAsSubmodule(b, system_step, optimize, system_module);
|
||||||
|
memory.buildAsSubmodule(b, system_step, optimize, system_module);
|
||||||
|
|
||||||
build_step.dependOn(system_step);
|
build_step.dependOn(system_step);
|
||||||
}
|
}
|
||||||
|
45
system/memory/build.zig
Normal file
45
system/memory/build.zig
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
const std = @import("std");
|
||||||
|
|
||||||
|
const here = "system/memory";
|
||||||
|
|
||||||
|
pub fn buildAsSubmodule(b: *std.Build, build_step: *std.Build.Step, optimize: std.builtin.OptimizeMode, system_module: *std.Build.Module) void {
|
||||||
|
var disabled_features = std.Target.Cpu.Feature.Set.empty;
|
||||||
|
var enabled_features = std.Target.Cpu.Feature.Set.empty;
|
||||||
|
|
||||||
|
disabled_features.addFeature(@intFromEnum(std.Target.x86.Feature.mmx));
|
||||||
|
disabled_features.addFeature(@intFromEnum(std.Target.x86.Feature.sse));
|
||||||
|
disabled_features.addFeature(@intFromEnum(std.Target.x86.Feature.sse2));
|
||||||
|
disabled_features.addFeature(@intFromEnum(std.Target.x86.Feature.avx));
|
||||||
|
disabled_features.addFeature(@intFromEnum(std.Target.x86.Feature.avx2));
|
||||||
|
enabled_features.addFeature(@intFromEnum(std.Target.x86.Feature.soft_float));
|
||||||
|
|
||||||
|
const target_query = std.Target.Query{
|
||||||
|
.cpu_arch = std.Target.Cpu.Arch.x86_64,
|
||||||
|
.os_tag = std.Target.Os.Tag.freestanding,
|
||||||
|
.abi = std.Target.Abi.none,
|
||||||
|
.cpu_features_sub = disabled_features,
|
||||||
|
.cpu_features_add = enabled_features,
|
||||||
|
};
|
||||||
|
|
||||||
|
const memory = b.addExecutable(.{
|
||||||
|
.name = "memory",
|
||||||
|
.root_source_file = b.path(here ++ "/main.zig"),
|
||||||
|
.target = b.resolveTargetQuery(target_query),
|
||||||
|
.optimize = optimize,
|
||||||
|
.code_model = .default,
|
||||||
|
});
|
||||||
|
|
||||||
|
memory.root_module.addImport("system", system_module);
|
||||||
|
|
||||||
|
const install = b.addInstallArtifact(memory, .{
|
||||||
|
.dest_dir = .{
|
||||||
|
.override = .{ .custom = "boot/" },
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
var memory_step = b.step("memory", "Build the memory manager");
|
||||||
|
memory_step.dependOn(&memory.step);
|
||||||
|
memory_step.dependOn(&install.step);
|
||||||
|
|
||||||
|
build_step.dependOn(memory_step);
|
||||||
|
}
|
16
system/memory/main.zig
Normal file
16
system/memory/main.zig
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
const system = @import("system");
|
||||||
|
|
||||||
|
const vm = system.vm;
|
||||||
|
const syscalls = system.syscalls;
|
||||||
|
|
||||||
|
fn setTokens() void {
|
||||||
|
var tokens: u64 = 0;
|
||||||
|
tokens |= @intFromEnum(system.kernel.Token.PhysicalMemory);
|
||||||
|
syscalls.setTokens(syscalls.getThreadId(), tokens) catch {};
|
||||||
|
}
|
||||||
|
|
||||||
|
export fn _start(_: u64, _: u64) callconv(.C) noreturn {
|
||||||
|
setTokens();
|
||||||
|
|
||||||
|
while (true) {}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user