[PATCH] D24088: Create a getelementptr instead of sub expr for ValueOffsetPair if the value is a pointer
Wei Mi via llvm-commits
llvm-commits at lists.llvm.org
Fri Sep 9 09:43:27 PDT 2016
Hi Sanjoy,
Could you take a look? The patch is to fix a compiler crash.
Thanks,
Wei.
On Wed, Aug 31, 2016 at 9:56 AM, Wei Mi <wmi at google.com> wrote:
> wmi created this revision.
> wmi added a reviewer: sanjoy.
> wmi added a subscriber: llvm-commits.
> wmi set the repository for this revision to rL LLVM.
> Herald added a subscriber: mzolotukhin.
>
> This patch is to fix https://llvm.org/bugs/show_bug.cgi?id=30213
>
> When composing an expr for ValueOffsetPair, if the value is of pointer type, we can only create a getelementptr instead of sub expr.
>
>
>
> Repository:
> rL LLVM
>
> https://reviews.llvm.org/D24088
>
> Files:
> lib/Analysis/ScalarEvolutionExpander.cpp
> test/Analysis/ScalarEvolution/pr30213.ll
>
> Index: test/Analysis/ScalarEvolution/pr30213.ll
> ===================================================================
> --- test/Analysis/ScalarEvolution/pr30213.ll
> +++ test/Analysis/ScalarEvolution/pr30213.ll
> @@ -0,0 +1,35 @@
> +; PR30213
> +; RUN: opt < %s -loop-reduce -S | FileCheck %s
> +
> +; CHECK: %ptr4.ptr1 = select i1 %cmp.i, i8* %ptr4, i8* %ptr1
> +; CHECK-NEXT: %scevgep = getelementptr i8, i8* %ptr4.ptr1, i32 1
> +; CHECK-NEXT: br label %while.cond.i
> +
> +target datalayout = "e-m:o-p:32:32-f64:32:64-f80:128-n8:16:32-S128"
> +target triple = "i386-apple-macosx10.12.0"
> +
> +; Function Attrs: nounwind optsize ssp
> +define void @Foo() {
> +entry:
> + switch i2 undef, label %sw.epilog102 [
> + i2 -2, label %sw.bb28
> + ]
> +
> +sw.bb28: ; preds = %entry
> + %0 = load i8*, i8** undef, align 2
> + %ptr1 = getelementptr inbounds i8, i8* undef, i32 -1
> + %ptr4 = getelementptr inbounds i8, i8* %0, i32 -1
> + %cmp.i = icmp ult i8* undef, %0
> + %ptr4.ptr1 = select i1 %cmp.i, i8* %ptr4, i8* %ptr1
> + br label %while.cond.i
> +
> +while.cond.i: ; preds = %while.cond.i, %sw.bb28
> + %currPtr.1.i = phi i8* [ %incdec.ptr.i, %while.cond.i ], [ %ptr4.ptr1, %sw.bb28 ]
> + %incdec.ptr.i = getelementptr inbounds i8, i8* %currPtr.1.i, i32 1
> + %1 = load i8, i8* %incdec.ptr.i, align 1
> + br label %while.cond.i
> +
> +sw.epilog102: ; preds = %entry
> + unreachable
> +}
> +
> Index: lib/Analysis/ScalarEvolutionExpander.cpp
> ===================================================================
> --- lib/Analysis/ScalarEvolutionExpander.cpp
> +++ lib/Analysis/ScalarEvolutionExpander.cpp
> @@ -1703,9 +1703,17 @@
>
> if (!V)
> V = visit(S);
> - else if (VO.second)
> - V = Builder.CreateSub(V, VO.second);
> -
> + else if (VO.second) {
> + if (V->getType()->isPointerTy()) {
> + Type *Ety = V->getType()->getPointerElementType();
> + int64_t Offset = VO.second->getSExtValue();
> + ConstantInt *Idx = ConstantInt::getSigned(
> + VO.second->getType(), -Offset * 8 / Ety->getScalarSizeInBits());
> + V = Builder.CreateGEP(Ety, V, Idx, "scevgep");
> + } else {
> + V = Builder.CreateSub(V, VO.second);
> + }
> + }
> // Remember the expanded value for this SCEV at this location.
> //
> // This is independent of PostIncLoops. The mapped value simply materializes
>
>
More information about the llvm-commits
mailing list