summaryrefslogtreecommitdiff
path: root/test/Transforms/IndVarSimplify
diff options
context:
space:
mode:
authorAndrew Trick <atrick@apple.com>2011-11-02 17:19:57 +0000
committerAndrew Trick <atrick@apple.com>2011-11-02 17:19:57 +0000
commitd3714b60b5adf15376a8803e6622c74694884b28 (patch)
tree8ad325293d2ec884f0e238fdf9936d1b941522ae /test/Transforms/IndVarSimplify
parenta71b7b09116059e2a4359026f72eb429b6d2da8d (diff)
downloadllvm-d3714b60b5adf15376a8803e6622c74694884b28.tar.gz
llvm-d3714b60b5adf15376a8803e6622c74694884b28.tar.bz2
llvm-d3714b60b5adf15376a8803e6622c74694884b28.tar.xz
Rewrite LinearFunctionTestReplace to handle pointer-type IVs.
We've been hitting asserts in this code due to the many supported combintions of modes (iv-rewrite/no-iv-rewrite) and IV types. This second rewrite of the code attempts to deal with these cases systematically. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@143546 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/Transforms/IndVarSimplify')
-rw-r--r--test/Transforms/IndVarSimplify/2011-11-01-lftrptr.ll126
1 files changed, 115 insertions, 11 deletions
diff --git a/test/Transforms/IndVarSimplify/2011-11-01-lftrptr.ll b/test/Transforms/IndVarSimplify/2011-11-01-lftrptr.ll
index 050c169a2a..c7809b8410 100644
--- a/test/Transforms/IndVarSimplify/2011-11-01-lftrptr.ll
+++ b/test/Transforms/IndVarSimplify/2011-11-01-lftrptr.ll
@@ -1,21 +1,45 @@
-; RUN: opt < %s -indvars -S -enable-iv-rewrite=true | FileCheck %s
+; RUN: opt < %s -indvars -S -enable-iv-rewrite=false "-default-data-layout=e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64" | FileCheck %s
+; RUN: opt < %s -indvars -S -enable-iv-rewrite=true "-default-data-layout=e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64" | FileCheck %s
+; RUN: opt < %s -indvars -S -enable-iv-rewrite=false "-default-data-layout=e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:32:64-f32:32:32-f64:32:64-v64:64:64-v128:128:128-a0:0:64-f80:128:128-n8:16:32" | FileCheck %s
+; RUN: opt < %s -indvars -S -enable-iv-rewrite=true "-default-data-layout=e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:32:64-f32:32:32-f64:32:64-v64:64:64-v128:128:128-a0:0:64-f80:128:128-n8:16:32" | FileCheck %s
;
; PR11279: Assertion !IVLimit->getType()->isPointerTy()
;
-; Test a non-integer BECount. It doesn't make sense, but that's what
-; falls out of SCEV. Since it's an i8*, we never adjust in a way that
-; would convert it to an integer type.
-;
-; enable-iv-rewrite=false does not currently perform LFTR when the the
-; taken count is a pointer expression, but that will change son.
+; Test LinearFunctionTestReplace of a pointer-type loop counter. Note
+; that BECount may or may not be a pointer type. A pointer type
+; BECount doesn't really make sense, but that's what falls out of
+; SCEV. Since it's an i8*, it has unit stride so we never adjust the
+; SCEV expression in a way that would convert it to an integer type.
+
+; CHECK: @testnullptrptr
+; CHECK: loop:
+; CHECK: icmp ne
+define i8 @testnullptrptr(i8* %buf, i8* %end) nounwind {
+ br label %loopguard
+
+loopguard:
+ %guard = icmp ult i8* null, %end
+ br i1 %guard, label %preheader, label %exit
+
+preheader:
+ br label %loop
+
+loop:
+ %p.01.us.us = phi i8* [ null, %preheader ], [ %gep, %loop ]
+ %s = phi i8 [0, %preheader], [%snext, %loop]
+ %gep = getelementptr inbounds i8* %p.01.us.us, i64 1
+ %snext = load i8* %gep
+ %cmp = icmp ult i8* %gep, %end
+ br i1 %cmp, label %loop, label %exit
-target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64"
-target triple = "x86_64-apple-darwin"
+exit:
+ ret i8 %snext
+}
-; CHECK: @test8
+; CHECK: @testptrptr
; CHECK: loop:
; CHECK: icmp ne
-define i8 @test8(i8* %buf, i8* %end) nounwind {
+define i8 @testptrptr(i8* %buf, i8* %end) nounwind {
br label %loopguard
loopguard:
@@ -36,3 +60,83 @@ loop:
exit:
ret i8 %snext
}
+
+; CHECK: @testnullptrint
+; CHECK: loop:
+; CHECK: icmp ne
+define i8 @testnullptrint(i8* %buf, i8* %end) nounwind {
+ br label %loopguard
+
+loopguard:
+ %bi = ptrtoint i8* %buf to i32
+ %ei = ptrtoint i8* %end to i32
+ %cnt = sub i32 %ei, %bi
+ %guard = icmp ult i32 0, %cnt
+ br i1 %guard, label %preheader, label %exit
+
+preheader:
+ br label %loop
+
+loop:
+ %p.01.us.us = phi i8* [ null, %preheader ], [ %gep, %loop ]
+ %iv = phi i32 [ 0, %preheader ], [ %ivnext, %loop ]
+ %s = phi i8 [0, %preheader], [%snext, %loop]
+ %gep = getelementptr inbounds i8* %p.01.us.us, i64 1
+ %snext = load i8* %gep
+ %ivnext = add i32 %iv, 1
+ %cmp = icmp ult i32 %ivnext, %cnt
+ br i1 %cmp, label %loop, label %exit
+
+exit:
+ ret i8 %snext
+}
+
+; CHECK: @testptrint
+; CHECK: loop:
+; CHECK: icmp ne
+define i8 @testptrint(i8* %buf, i8* %end) nounwind {
+ br label %loopguard
+
+loopguard:
+ %bi = ptrtoint i8* %buf to i32
+ %ei = ptrtoint i8* %end to i32
+ %cnt = sub i32 %ei, %bi
+ %guard = icmp ult i32 %bi, %cnt
+ br i1 %guard, label %preheader, label %exit
+
+preheader:
+ br label %loop
+
+loop:
+ %p.01.us.us = phi i8* [ %buf, %preheader ], [ %gep, %loop ]
+ %iv = phi i32 [ %bi, %preheader ], [ %ivnext, %loop ]
+ %s = phi i8 [0, %preheader], [%snext, %loop]
+ %gep = getelementptr inbounds i8* %p.01.us.us, i64 1
+ %snext = load i8* %gep
+ %ivnext = add i32 %iv, 1
+ %cmp = icmp ult i32 %ivnext, %cnt
+ br i1 %cmp, label %loop, label %exit
+
+exit:
+ ret i8 %snext
+}
+
+; IV and BECount have two different pointer types here.
+define void @testnullptr([512 x i8]* %base) nounwind {
+entry:
+ %add.ptr1603 = getelementptr [512 x i8]* %base, i64 0, i64 512
+ br label %preheader
+
+preheader:
+ %cmp1604192 = icmp ult i8* undef, %add.ptr1603
+ br i1 %cmp1604192, label %for.body, label %for.end1609
+
+for.body:
+ %r.17193 = phi i8* [ %incdec.ptr1608, %for.body ], [ null, %preheader ]
+ %incdec.ptr1608 = getelementptr i8* %r.17193, i64 1
+ %cmp1604 = icmp ult i8* %incdec.ptr1608, %add.ptr1603
+ br i1 %cmp1604, label %for.body, label %for.end1609
+
+for.end1609:
+ unreachable
+}