From 33115367404c7e860853054c53e7ad613258516b Mon Sep 17 00:00:00 2001 From: Camille GILLOT Date: Sat, 1 Jul 2023 14:57:29 +0000 Subject: [PATCH] Workaround issue 112651. --- compiler/rustc_mir_transform/src/gvn.rs | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/compiler/rustc_mir_transform/src/gvn.rs b/compiler/rustc_mir_transform/src/gvn.rs index 2b96763c297..d4894d3c24d 100644 --- a/compiler/rustc_mir_transform/src/gvn.rs +++ b/compiler/rustc_mir_transform/src/gvn.rs @@ -96,7 +96,11 @@ fn propagate_ssa<'tcx>(tcx: TyCtxt<'tcx>, body: &mut Body<'tcx>) { for (local, rvalue, _) in ssa.assignments(body) { let value = state.insert_rvalue(rvalue).or_else(|| state.new_opaque()).unwrap(); - state.assign(local, value); + // FIXME(#112651) `rvalue` may have a subtype to `local`. We can only mark `local` as + // reusable if we have an exact type match. + if state.local_decls[local].ty == rvalue.ty(state.local_decls, tcx) { + state.assign(local, value); + } } // Stop creating opaques during replacement as it is useless.