; RUN: not --crash opt -passes='consthoist' -S -o - -consthoist-gep=1 -mtriple=x86_64-unknown-linux-gnu < %s 2>&1 | FileCheck %s ; REQUIRES: asserts ; My changes fixed this likely by accident, please update as necessary when ; you work on this: ; XFAIL: * ; Matching assertion strings is not easy as they might differ on different ; platforms. So limit this to x86_64-linux. ; REQUIRES: x86_64-linux ; This is a reproducer for https://github.com/llvm/llvm-project/issues/52689 ; ; opt: ../lib/Transforms/Scalar/ConstantHoisting.cpp:919: bool llvm::ConstantHoistingPass::emitBaseConstants(llvm::GlobalVariable *): Assertion `UsesNum == (ReBasesNum + NotRebasedNum) && "Not all uses are rebased"' failed. ; CHECK: UsesNum == (ReBasesNum + NotRebasedNum) ; CHECK-SAME: Not all uses are rebased @g_77 = external global [5 x i32] define internal ptr @func_29(i1 %p1, i1 %p2, ptr %p3) { entry: br i1 %p1, label %crit_edge, label %if.else3089 crit_edge: ; preds = %entry br label %for.cond1063 for.cond1063: ; preds = %cleanup1660, %crit_edge %l_323.sroa.0.0 = phi ptr [ getelementptr inbounds ([5 x i32], ptr @g_77, i32 0, i32 3), %cleanup1660 ], [ null, %crit_edge ] %l_323.sroa.2.0 = phi ptr [ getelementptr inbounds ([5 x i32], ptr @g_77, i32 0, i32 3), %cleanup1660 ], [ null, %crit_edge ] br i1 %p2, label %cleanup1660.thread, label %cleanup1674 cleanup1660.thread: ; preds = %for.cond1063 br label %cleanup1674 cleanup1660: ; No predecessors! br label %for.cond1063 cleanup1674: ; preds = %cleanup1660.thread, %for.cond1063 store ptr getelementptr inbounds ([5 x i32], ptr @g_77, i32 0, i32 1), ptr %p3, align 1 ret ptr null if.else3089: ; preds = %entry store ptr getelementptr inbounds ([5 x i32], ptr @g_77, i32 0, i32 1), ptr %p3, align 1 ret ptr null }