diff options
| author | Chad Rosier <mcrosier@codeaurora.org> | 2014-09-26 20:05:35 +0000 | 
|---|---|---|
| committer | Chad Rosier <mcrosier@codeaurora.org> | 2014-09-26 20:05:35 +0000 | 
| commit | 7b974b73ae0d0a2533431b3f22845ee9aeb3d837 (patch) | |
| tree | 739501b4d607eb499a09214763fe0530f3c98d5c | |
| parent | 7e38e429b7360ffac1f0853bb8023f9dd88b9fea (diff) | |
| download | bcm5719-llvm-7b974b73ae0d0a2533431b3f22845ee9aeb3d837.tar.gz bcm5719-llvm-7b974b73ae0d0a2533431b3f22845ee9aeb3d837.zip  | |
[IndVar] Don't widen loop compare unless IV user is sign extended.
PR21030
llvm-svn: 218539
| -rw-r--r-- | llvm/lib/Transforms/Scalar/IndVarSimplify.cpp | 8 | ||||
| -rw-r--r-- | llvm/test/Transforms/IndVarSimplify/widen-loop-comp.ll | 26 | 
2 files changed, 32 insertions, 2 deletions
diff --git a/llvm/lib/Transforms/Scalar/IndVarSimplify.cpp b/llvm/lib/Transforms/Scalar/IndVarSimplify.cpp index 7cc34e1ad86..68a134ebfd8 100644 --- a/llvm/lib/Transforms/Scalar/IndVarSimplify.cpp +++ b/llvm/lib/Transforms/Scalar/IndVarSimplify.cpp @@ -650,7 +650,7 @@ namespace {    struct WideIVInfo {      PHINode *NarrowIV;      Type *WidestNativeType; // Widest integer type created [sz]ext -    bool IsSigned;          // Was an sext user seen before a zext? +    bool IsSigned;          // Was a sext user seen before a zext?      WideIVInfo() : NarrowIV(nullptr), WidestNativeType(nullptr),                     IsSigned(false) {} @@ -936,7 +936,11 @@ bool WidenIV::WidenLoopCompare(NarrowIVDefUse DU) {    if (!Cmp)      return false; -  bool IsSigned = CmpInst::isSigned(Cmp->getPredicate()); +  // Must be a signed compare. +  if (!CmpInst::isSigned(Cmp->getPredicate())) +    return false; + +  // Must be a signed IV user.    if (!IsSigned)      return false; diff --git a/llvm/test/Transforms/IndVarSimplify/widen-loop-comp.ll b/llvm/test/Transforms/IndVarSimplify/widen-loop-comp.ll index a6963948d8b..b85fc6d1e4c 100644 --- a/llvm/test/Transforms/IndVarSimplify/widen-loop-comp.ll +++ b/llvm/test/Transforms/IndVarSimplify/widen-loop-comp.ll @@ -136,3 +136,29 @@ for.body:  for.end:    ret i32 %sum.0  } + +declare i32 @fn1(i8 signext) + +; PR21030 +; CHECK-LABEL: @test4 +; CHECK: for.body: +; CHECK: phi i32 +; CHECK: icmp sgt i8 + +define i32 @test4(i32 %a) { +entry: +  br label %for.body + +for.body: +  %c.07 = phi i8 [ -3, %entry ], [ %dec, %for.body ] +  %conv6 = zext i8 %c.07 to i32 +  %or = or i32 %a, %conv6 +  %conv3 = trunc i32 %or to i8 +  %call = call i32 @fn1(i8 signext %conv3) +  %dec = add i8 %c.07, -1 +  %cmp = icmp sgt i8 %dec, -14 +  br i1 %cmp, label %for.body, label %for.end + +for.end: +  ret i32 0 +}  | 

