aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authormparadinha <miguel.p.paradinha@gmail.com>2022-01-30 02:39:37 +0000
committermparadinha <miguel.p.paradinha@gmail.com>2022-02-02 08:50:37 +0000
commitcc16ac9314752681300c7e72a4989aeba2ba2579 (patch)
tree5fe6d3fb0b7b13e04d9487791c25a2acec83516d
parent5cf918143c7c5857142ac12c3587928ed74b2052 (diff)
downloadzig-cc16ac9314752681300c7e72a4989aeba2ba2579.tar.gz
zig-cc16ac9314752681300c7e72a4989aeba2ba2579.zip
implement storing to MCValue.memory
-rw-r--r--src/arch/x86_64/CodeGen.zig15
1 files changed, 13 insertions, 2 deletions
diff --git a/src/arch/x86_64/CodeGen.zig b/src/arch/x86_64/CodeGen.zig
index 4d3f899cd5..a60a407beb 100644
--- a/src/arch/x86_64/CodeGen.zig
+++ b/src/arch/x86_64/CodeGen.zig
@@ -1762,8 +1762,19 @@ fn store(self: *Self, ptr: MCValue, value: MCValue, ptr_ty: Type, value_ty: Type
},
}
},
- .memory => {
- return self.fail("TODO implement storing to MCValue.memory", .{});
+ .memory => |addr| {
+ const reg = try self.copyToTmpRegister(ptr_ty, .{ .memory = addr });
+ // mov reg, [reg]
+ _ = try self.addInst(.{
+ .tag = .mov,
+ .ops = (Mir.Ops{
+ .reg1 = reg.to64(),
+ .reg2 = reg.to64(),
+ .flags = 0b10,
+ }).encode(),
+ .data = .{ .imm = 0 },
+ });
+ return self.store(.{ .register = reg }, value, ptr_ty, value_ty);
},
.stack_offset => {
return self.fail("TODO implement storing to MCValue.stack_offset", .{});