| ; 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 |
| } |