diff --git a/src/codegen/llvm.zig b/src/codegen/llvm.zig index 271555ee28..252d449fc2 100644 --- a/src/codegen/llvm.zig +++ b/src/codegen/llvm.zig @@ -2882,7 +2882,7 @@ pub const FuncGen = struct { const bin_op = self.air.extraData(Air.Bin, ty_pl.payload).data; const ptr_ty = self.air.typeOf(bin_op.lhs); const elem_ty = ptr_ty.childType(); - if (!elem_ty.hasRuntimeBits()) return null; + if (!elem_ty.hasRuntimeBits()) return self.dg.lowerPtrToVoid(ptr_ty); const base_ptr = try self.resolveInst(bin_op.lhs); const rhs = try self.resolveInst(bin_op.rhs); diff --git a/test/behavior/optional.zig b/test/behavior/optional.zig index ed0106188b..6cc174dbba 100644 --- a/test/behavior/optional.zig +++ b/test/behavior/optional.zig @@ -273,7 +273,10 @@ test "0-bit child type coerced to optional return ptr result location" { } test "0-bit child type coerced to optional" { - if (builtin.zig_backend != .stage1) return error.SkipZigTest; // TODO + if (builtin.zig_backend == .stage2_c) return error.SkipZigTest; // TODO + if (builtin.zig_backend == .stage2_x86_64) return error.SkipZigTest; // TODO + if (builtin.zig_backend == .stage2_aarch64) return error.SkipZigTest; // TODO + if (builtin.zig_backend == .stage2_arm) return error.SkipZigTest; // TODO const S = struct { fn doTheTest() !void {