[PATCH] D88806: [SCEV] Model ptrtoint(SCEVUnknown) cast not as unknown, but as zext/trunc/self of SCEVUnknown
Roman Lebedev via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Tue Oct 13 01:06:37 PDT 2020
lebedev.ri added a comment.
In D88806#2326944 <https://reviews.llvm.org/D88806#2326944>, @uabelho wrote:
> Hi,
>
> I got my share of doom too, even after the fix.
> So
>
> opt -S -o - bbi-48445.ll -indvars
>
> crashes with
>
> opt: ../lib/IR/Constants.cpp:1896: static llvm::Constant *llvm::ConstantExpr::getZExt(llvm::Constant *, llvm::Type *, bool): Assertion `C->getType()->isIntOrIntVectorTy() && "ZEXt operand must be integral"' failed.
>
> for the following input:
>
> target datalayout = "p:16:16"
>
> @a_i32 = external global [21 x i32], section ".bss,bss", align 1
>
> define void @test_array_ldm_i32() {
> entry:
> br label %for.body42
>
> crit_edge: ; preds = %for.body42
> %split = phi i32 [ %add58, %for.body42 ]
> %add132 = add i32 %split, undef
> unreachable
>
> for.body42: ; preds = %for.body42, %entry
> %sub.ptr.sub49 = sub i32 undef, ptrtoint ([21 x i32]* @a_i32 to i32)
> %sub.ptr.div50 = sdiv exact i32 %sub.ptr.sub49, 2
> %conv51 = sext i32 %sub.ptr.div50 to i64
> %cmp53 = icmp eq i64 %conv51, undef
> %cond55 = select i1 %cmp53, i16 0, i16 1
> %conv56 = sext i16 %cond55 to i32
> %add57 = add i32 65536, %conv56
> %add58 = add i32 undef, %add57
> br i1 false, label %for.body42, label %crit_edge
> }
Perfect, thank you. That's the test case i was missing. Will fix in a moment.
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D88806/new/
https://reviews.llvm.org/D88806
More information about the llvm-commits
mailing list