Commit 199782edd1
2024-11-02 08:59:14
1 parent
bf21e4fChanged files (1)
src
arch
riscv64
src/arch/riscv64/CodeGen.zig
@@ -1768,8 +1768,15 @@ fn finishAirBookkeeping(func: *Func) void {
fn finishAirResult(func: *Func, inst: Air.Inst.Index, result: MCValue) void {
if (func.liveness.isUnused(inst)) switch (result) {
.none, .dead, .unreach => {},
- else => unreachable, // Why didn't the result die?
+ // Why didn't the result die?
+ .register => |r| if (r != .zero) unreachable,
+ else => unreachable,
} else {
+ switch (result) {
+ .register => |r| if (r == .zero) unreachable, // Why did we discard a used result?
+ else => {},
+ }
+
tracking_log.debug("%{d} => {} (birth)", .{ inst, result });
func.inst_tracking.putAssumeCapacityNoClobber(inst, InstTracking.init(result));
// In some cases, an operand may be reused as the result.