[PATCH] D61807: [Polly] Don't crash on invalid delinearization result.
Eli Friedman via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Tue May 14 14:30:47 PDT 2019
This revision was automatically updated to reflect the committed changes.
Closed by commit rL360708: [Polly] Don't crash on invalid delinearization result. (authored by efriedma, committed by ).
Changed prior to commit:
https://reviews.llvm.org/D61807?vs=199095&id=199515#toc
Repository:
rL LLVM
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D61807/new/
https://reviews.llvm.org/D61807
Files:
polly/trunk/lib/Analysis/ScopDetection.cpp
polly/trunk/test/ScopInfo/multidim_invalid_dimension.ll
Index: polly/trunk/test/ScopInfo/multidim_invalid_dimension.ll
===================================================================
--- polly/trunk/test/ScopInfo/multidim_invalid_dimension.ll
+++ polly/trunk/test/ScopInfo/multidim_invalid_dimension.ll
@@ -0,0 +1,27 @@
+; RUN: opt %loadPolly -polly-scops -analyze < %s | FileCheck %s
+target datalayout = "e-m:e-i8:8:32-i16:16:32-i64:64-i128:128-n32:64-S128"
+target triple = "aarch64-unknown-linux-gnueabi"
+
+; Make sure we don't crash trying delinearize the memory access
+; CHECK: region: 'bb4 => bb14'
+; CHECK-NEXT: Invalid Scop!
+define void @f(i8* %arg, i32 %arg1, i32 %arg2, i32 %arg3) {
+bb:
+ br label %bb4
+
+bb4:
+ %tmp = phi i32 [ %arg2, %bb ], [ %tmp12, %bb4 ]
+ %tmp5 = icmp sgt i32 %tmp, 0
+ %tmp6 = select i1 %tmp5, i32 %tmp, i32 0
+ %tmp7 = mul nsw i32 %tmp6, %arg3
+ %tmp8 = sext i32 %tmp7 to i64
+ %tmp9 = getelementptr inbounds i8, i8* %arg, i64 %tmp8
+ %tmp10 = bitcast i8* %tmp9 to i32*
+ %tmp11 = load i32, i32* %tmp10, align 4
+ %tmp12 = add nsw i32 %tmp, 1
+ %tmp13 = icmp slt i32 %tmp, %arg1
+ br i1 %tmp13, label %bb4, label %bb14
+
+bb14:
+ ret void
+}
Index: polly/trunk/lib/Analysis/ScopDetection.cpp
===================================================================
--- polly/trunk/lib/Analysis/ScopDetection.cpp
+++ polly/trunk/lib/Analysis/ScopDetection.cpp
@@ -913,7 +913,9 @@
Value *BaseValue = BasePointer->getValue();
Region &CurRegion = Context.CurRegion;
for (const SCEV *DelinearizedSize : Sizes) {
- if (!isAffine(DelinearizedSize, Scope, Context)) {
+ // Don't pass down the scope to isAfffine; array dimensions must be
+ // invariant across the entire scop.
+ if (!isAffine(DelinearizedSize, nullptr, Context)) {
Sizes.clear();
break;
}
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D61807.199515.patch
Type: text/x-patch
Size: 1786 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20190514/fd7e8451/attachment.bin>
More information about the llvm-commits
mailing list