diff options
| author | Koakuma <koachan@protonmail.com> | 2022-10-14 22:14:43 +0700 |
|---|---|---|
| committer | Koakuma <koachan@protonmail.com> | 2022-12-10 21:11:14 +0700 |
| commit | 0bc936685bbba38759b8029bada3c21b0ae2c353 (patch) | |
| tree | bcd62c9f576b1d4c8bd832c6bb26719cdd56a294 /src | |
| parent | 4ddedb388560afe2458fff6e1cca26ba6e70add2 (diff) | |
| download | zig-0bc936685bbba38759b8029bada3c21b0ae2c353.tar.gz zig-0bc936685bbba38759b8029bada3c21b0ae2c353.zip | |
stage2: sparc64: Implement airErrorName
Diffstat (limited to 'src')
| -rw-r--r-- | src/arch/sparc64/CodeGen.zig | 12 |
1 files changed, 11 insertions, 1 deletions
diff --git a/src/arch/sparc64/CodeGen.zig b/src/arch/sparc64/CodeGen.zig index af6cb8b466..bec70fb7d8 100644 --- a/src/arch/sparc64/CodeGen.zig +++ b/src/arch/sparc64/CodeGen.zig @@ -609,7 +609,7 @@ fn genBody(self: *Self, body: []const Air.Inst.Index) InnerError!void { .byte_swap => @panic("TODO try self.airByteSwap(inst)"), .bit_reverse => @panic("TODO try self.airBitReverse(inst)"), .tag_name => try self.airTagName(inst), - .error_name => @panic("TODO try self.airErrorName(inst)"), + .error_name => try self.airErrorName(inst), .splat => @panic("TODO try self.airSplat(inst)"), .select => @panic("TODO try self.airSelect(inst)"), .shuffle => @panic("TODO try self.airShuffle(inst)"), @@ -1519,6 +1519,16 @@ fn airDiv(self: *Self, inst: Air.Inst.Index) !void { return self.finishAir(inst, result, .{ bin_op.lhs, bin_op.rhs, .none }); } +fn airErrorName(self: *Self, inst: Air.Inst.Index) !void { + const un_op = self.air.instructions.items(.data)[inst].un_op; + const operand = try self.resolveInst(un_op); + const result: MCValue = if (self.liveness.isUnused(inst)) .dead else { + _ = operand; + return self.fail("TODO implement airErrorName for {}", .{self.target.cpu.arch}); + }; + return self.finishAir(inst, result, .{ un_op, .none, .none }); +} + fn airErrUnionPayloadPtrSet(self: *Self, inst: Air.Inst.Index) !void { const ty_op = self.air.instructions.items(.data)[inst].ty_op; const result: MCValue = if (self.liveness.isUnused(inst)) .dead else return self.fail("TODO implement .errunion_payload_ptr_set for {}", .{self.target.cpu.arch}); |
