mirror of
https://github.com/ziglang/zig.git
synced 2025-12-12 09:13:11 +00:00
stage2: sparc64: Implement airWrapErrUnionPayload
This commit is contained in:
parent
1b5b9eb365
commit
a72362f395
@ -683,7 +683,7 @@ fn genBody(self: *Self, body: []const Air.Inst.Index) InnerError!void {
|
|||||||
.save_err_return_trace_index=> @panic("TODO try self.airSaveErrReturnTraceIndex(inst)"),
|
.save_err_return_trace_index=> @panic("TODO try self.airSaveErrReturnTraceIndex(inst)"),
|
||||||
|
|
||||||
.wrap_optional => try self.airWrapOptional(inst),
|
.wrap_optional => try self.airWrapOptional(inst),
|
||||||
.wrap_errunion_payload => @panic("TODO try self.airWrapErrUnionPayload(inst)"),
|
.wrap_errunion_payload => try self.airWrapErrUnionPayload(inst),
|
||||||
.wrap_errunion_err => try self.airWrapErrUnionErr(inst),
|
.wrap_errunion_err => try self.airWrapErrUnionErr(inst),
|
||||||
|
|
||||||
.add_optimized,
|
.add_optimized,
|
||||||
@ -2493,6 +2493,13 @@ fn airWrapErrUnionErr(self: *Self, inst: Air.Inst.Index) !void {
|
|||||||
return self.finishAir(inst, result, .{ ty_op.operand, .none, .none });
|
return self.finishAir(inst, result, .{ ty_op.operand, .none, .none });
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// T to E!T
|
||||||
|
fn airWrapErrUnionPayload(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 wrap errunion payload for {}", .{self.target.cpu.arch});
|
||||||
|
return self.finishAir(inst, result, .{ ty_op.operand, .none, .none });
|
||||||
|
}
|
||||||
|
|
||||||
fn airWrapOptional(self: *Self, inst: Air.Inst.Index) !void {
|
fn airWrapOptional(self: *Self, inst: Air.Inst.Index) !void {
|
||||||
const ty_op = self.air.instructions.items(.data)[inst].ty_op;
|
const ty_op = self.air.instructions.items(.data)[inst].ty_op;
|
||||||
const result: MCValue = if (self.liveness.isUnused(inst)) .dead else result: {
|
const result: MCValue = if (self.liveness.isUnused(inst)) .dead else result: {
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user