wires

summary refs log tree commit diff
path: root/src/DtParser.zig
diff options
context:
space:
mode:
authorwires <wires@noreply.wires.systems>2025-10-09 20:52:54 -0400
committerwires <wires@noreply.wires.systems>2025-10-09 20:52:54 -0400
commita778e63f8174a2e416aa7d15883c983830428cc0 (patch)
tree2bc3b3b18b266c7b7d53baecc3ba982271dc02bd /src/DtParser.zig
parentslight build.zig change (diff)
downloadzosimos-a778e63f8174a2e416aa7d15883c983830428cc0.tar.gz
start working on devicetree
Diffstat (limited to 'src/DtParser.zig')
-rw-r--r--src/DtParser.zig73
1 files changed, 73 insertions, 0 deletions
diff --git a/src/DtParser.zig b/src/DtParser.zig
new file mode 100644
index 0000000..5ff3dfb
--- /dev/null
+++ b/src/DtParser.zig
@@ -0,0 +1,73 @@
+const std = @import("std");
+const bigToNative = std.mem.bigToNative;
+
+const Self = @This();
+
+const Header = struct {
+    magic: u32,
+    total_size: u32,
+    off_dt_struct: u32,
+    off_dt_strings: u32,
+    off_mem_rsvmap: u32,
+    version: u32,
+    last_comp_version: u32,
+    boot_cpuid_phys: u32,
+    size_dt_strings: u32,
+    size_dt_struct: u32,
+};
+
+base: [*]const u8,
+
+pub fn new(base: [*]const u8) Self {
+    return .{ .base = base };
+}
+
+fn getHeaderField(self: Self, comptime field_name: []const u8) u32 {
+    const ptr: *const u32 = @ptrCast(
+        @alignCast(self.base + @offsetOf(Header, field_name)),
+    );
+    return bigToNative(u32, ptr.*);
+}
+
+pub fn magic(self: Self) u32 {
+    return self.getHeaderField("magic");
+}
+
+pub fn totalSize(self: Self) u32 {
+    return self.getHeaderField("total_size");
+}
+
+pub fn version(self: Self) u32 {
+    return self.getHeaderField("version");
+}
+
+pub const ReserveEntry = struct {
+    address: u64,
+    size: u64,
+};
+
+const MemRsvmapIter = struct {
+    cur: [*]const u64,
+
+    pub fn next(self: *@This()) ?ReserveEntry {
+        const address = bigToNative(u64, self.cur[0]);
+        const size = bigToNative(u64, self.cur[1]);
+
+        if (address == 0 and size == 0) {
+            return null;
+        } else {
+            self.cur += 2;
+            return .{
+                .address = address,
+                .size = size,
+            };
+        }
+    }
+};
+
+pub fn memRsvmap(self: Self) MemRsvmapIter {
+    const offset = self.getHeaderField("off_mem_rsvmap");
+    return .{
+        .cur = @ptrCast(@alignCast(self.base + offset)),
+    };
+}