commit cd24ab7f6e56c8365896a9b2dfc506a787346ecb (tree)
parent fde1ec5d0e57471b43bab226a78da2eb61e6bb66
Author: Jacob Young <jacobly0@users.noreply.github.com>
Date: Mon, 3 Apr 2023 01:34:05 -0400
x86_64: canonicalise loops
Diffstat:
1 file changed, 22 insertions(+), 1 deletion(-)
diff --git a/src/arch/x86_64/CodeGen.zig b/src/arch/x86_64/CodeGen.zig
@@ -6132,7 +6132,28 @@ fn airLoop(self: *Self, inst: Air.Inst.Index) !void {
const loop = self.air.extraData(Air.Block, ty_pl.payload);
const body = self.air.extra[loop.end..][0..loop.data.body_len];
const jmp_target = @intCast(u32, self.mir_instructions.len);
- try self.genBody(body);
+
+ {
+ try self.branch_stack.append(.{});
+ errdefer _ = self.branch_stack.pop();
+
+ try self.genBody(body);
+ }
+
+ var branch = self.branch_stack.pop();
+ defer branch.deinit(self.gpa);
+
+ log.debug("airLoop: %{d}", .{inst});
+ log.debug("Upper branches:", .{});
+ for (self.branch_stack.items) |bs| {
+ log.debug("{}", .{bs.fmtDebug()});
+ }
+ log.debug("Loop branch: {}", .{branch.fmtDebug()});
+
+ var dummy_branch = Branch{};
+ defer dummy_branch.deinit(self.gpa);
+ try self.canonicaliseBranches(true, &dummy_branch, &branch, true, false);
+
_ = try self.asmJmpReloc(jmp_target);
return self.finishAirBookkeeping();
}