diff options
Diffstat (limited to 'llvm')
| -rw-r--r-- | llvm/lib/Analysis/ScalarEvolutionExpander.cpp | 4 | ||||
| -rw-r--r-- | llvm/test/CodeGen/ARM/lsr-undef-in-binop.ll | 251 | ||||
| -rw-r--r-- | llvm/test/Transforms/LoopDistribute/bounds-expansion-bug.ll | 16 | 
3 files changed, 262 insertions, 9 deletions
diff --git a/llvm/lib/Analysis/ScalarEvolutionExpander.cpp b/llvm/lib/Analysis/ScalarEvolutionExpander.cpp index cd323fcb897..16d0bd64bf0 100644 --- a/llvm/lib/Analysis/ScalarEvolutionExpander.cpp +++ b/llvm/lib/Analysis/ScalarEvolutionExpander.cpp @@ -60,12 +60,10 @@ Value *SCEVExpander::ReuseOrCreateCast(Value *V, Type *Ty,            // instructions that might be inserted before BIP.            if (BasicBlock::iterator(CI) != IP || BIP == IP) {              // Create a new cast, and leave the old cast in place in case -            // it is being used as an insert point. Clear its operand -            // so that it doesn't hold anything live. +            // it is being used as an insert point.              Ret = CastInst::Create(Op, V, Ty, "", &*IP);              Ret->takeName(CI);              CI->replaceAllUsesWith(Ret); -            CI->setOperand(0, UndefValue::get(V->getType()));              break;            }            Ret = CI; diff --git a/llvm/test/CodeGen/ARM/lsr-undef-in-binop.ll b/llvm/test/CodeGen/ARM/lsr-undef-in-binop.ll new file mode 100644 index 00000000000..564328d9999 --- /dev/null +++ b/llvm/test/CodeGen/ARM/lsr-undef-in-binop.ll @@ -0,0 +1,251 @@ +; REQUIRES: arm-registered-target +; RUN: opt -S -loop-reduce %s -o - | FileCheck %s + +target datalayout = "e-m:e-p:32:32-i64:64-v128:64:128-a:0:32-n32-S64" +target triple = "armv8-unknown-hurd-eabihf" + +%"class.std::__1::vector.182" = type { %"class.std::__1::__vector_base.183" } +%"class.std::__1::__vector_base.183" = type { i8*, i8*, %"class.std::__1::__compressed_pair.184" } +%"class.std::__1::__compressed_pair.184" = type { %"struct.std::__1::__compressed_pair_elem.185" } +%"struct.std::__1::__compressed_pair_elem.185" = type { i8* } +%"class.std::__1::__vector_base_common" = type { i8 } + +$vector_insert = comdat any + +declare i8* @Allocate(i32) local_unnamed_addr +declare void @Free(i8*) local_unnamed_addr +declare void @_ZNKSt3__120__vector_base_commonILb1EE20__throw_length_errorEv(%"class.std::__1::__vector_base_common"*) local_unnamed_addr +declare i8* @memmove(i8*, i8*, i32) local_unnamed_addr + +; Function Attrs: noimplicitfloat nounwind uwtable +define linkonce_odr i32 @vector_insert(%"class.std::__1::vector.182"*, [1 x i32], i8*, i8*) local_unnamed_addr #1 comdat align 2 { +; CHECK-LABEL: vector_insert +  %5 = extractvalue [1 x i32] %1, 0 +  %6 = getelementptr inbounds %"class.std::__1::vector.182", %"class.std::__1::vector.182"* %0, i32 0, i32 0, i32 0 +  %7 = load i8*, i8** %6, align 4 +; CHECK: [[LOAD:%[0-9]+]] = load i8*, i8** +  %8 = bitcast %"class.std::__1::vector.182"* %0 to i32* +  %9 = ptrtoint i8* %7 to i32 +; CHECK: [[NEW_CAST:%[0-9]+]] = ptrtoint i8* [[LOAD]] to i32 +; CHECK: [[OLD_CAST:%[0-9]+]] = ptrtoint i8* [[LOAD]] to i32 +  %10 = sub i32 %5, %9 +  %11 = getelementptr inbounds i8, i8* %7, i32 %10 +  %12 = ptrtoint i8* %3 to i32 +  %13 = ptrtoint i8* %2 to i32 +  %14 = sub i32 %12, %13 +  %15 = icmp sgt i32 %14, 0 +  br i1 %15, label %18, label %16 + +; <label>:16:                                     ; preds = %4 +  %17 = ptrtoint i8* %11 to i32 +  br label %148 + +; <label>:18:                                     ; preds = %4 +  %19 = getelementptr inbounds %"class.std::__1::vector.182", %"class.std::__1::vector.182"* %0, i32 0, i32 0, i32 2, i32 0, i32 0 +  %20 = bitcast i8** %19 to i32* +  %21 = load i32, i32* %20, align 4 +  %22 = getelementptr inbounds %"class.std::__1::vector.182", %"class.std::__1::vector.182"* %0, i32 0, i32 0, i32 1 +  %23 = load i8*, i8** %22, align 4 +  %24 = ptrtoint i8* %23 to i32 +  %25 = sub i32 %21, %24 +  %26 = icmp sgt i32 %14, %25 +  %27 = bitcast i8** %22 to i32* +  br i1 %26, label %77, label %28 + +; <label>:28:                                     ; preds = %18 +  %29 = ptrtoint i8* %11 to i32 +  %30 = sub i32 %24, %29 +  %31 = icmp sgt i32 %14, %30 +  br i1 %31, label %32, label %48 + +; <label>:32:                                     ; preds = %28 +  %33 = getelementptr inbounds i8, i8* %2, i32 %30 +  %34 = icmp eq i8* %33, %3 +  br i1 %34, label %43, label %35 + +; <label>:35:                                     ; preds = %32, %35 +  %36 = phi i8* [ %41, %35 ], [ %23, %32 ] +  %37 = phi i8* [ %39, %35 ], [ %33, %32 ] +  %38 = load i8, i8* %37, align 1 +  store i8 %38, i8* %36, align 1 +  %39 = getelementptr inbounds i8, i8* %37, i32 1 +  %40 = load i8*, i8** %22, align 4 +  %41 = getelementptr inbounds i8, i8* %40, i32 1 +  store i8* %41, i8** %22, align 4 +  %42 = icmp eq i8* %39, %3 +  br i1 %42, label %43, label %35 + +; <label>:43:                                     ; preds = %35, %32 +  %44 = phi i8* [ %23, %32 ], [ %41, %35 ] +  %45 = icmp sgt i32 %30, 0 +  br i1 %45, label %46, label %148 + +; <label>:46:                                     ; preds = %43 +  %47 = ptrtoint i8* %44 to i32 +  br label %48 + +; <label>:48:                                     ; preds = %46, %28 +  %49 = phi i32 [ %47, %46 ], [ %24, %28 ] +  %50 = phi i8* [ %44, %46 ], [ %23, %28 ] +  %51 = phi i8* [ %33, %46 ], [ %3, %28 ] +  %52 = getelementptr inbounds i8, i8* %11, i32 %14 +  %53 = ptrtoint i8* %52 to i32 +  %54 = sub i32 %49, %53 +  %55 = getelementptr inbounds i8, i8* %11, i32 %54 +  %56 = icmp ult i8* %55, %23 +  br i1 %56, label %63, label %57 + +; <label>:57:                                     ; preds = %63, %48 +  %58 = icmp eq i32 %54, 0 +  br i1 %58, label %71, label %59 + +; <label>:59:                                     ; preds = %57 +  %60 = sub i32 0, %54 +  %61 = getelementptr inbounds i8, i8* %50, i32 %60 +  %62 = tail call i8* @memmove(i8* %61, i8* %11, i32 %54) #13 +  br label %71 + +; <label>:63:                                     ; preds = %48, %63 +  %64 = phi i8* [ %69, %63 ], [ %50, %48 ] +  %65 = phi i8* [ %67, %63 ], [ %55, %48 ] +  %66 = load i8, i8* %65, align 1 +  store i8 %66, i8* %64, align 1 +  %67 = getelementptr inbounds i8, i8* %65, i32 1 +  %68 = load i8*, i8** %22, align 4 +  %69 = getelementptr inbounds i8, i8* %68, i32 1 +  store i8* %69, i8** %22, align 4 +  %70 = icmp eq i8* %67, %23 +  br i1 %70, label %57, label %63 + +; <label>:71:                                     ; preds = %57, %59 +  %72 = ptrtoint i8* %51 to i32 +  %73 = sub i32 %72, %13 +  %74 = icmp eq i32 %73, 0 +  br i1 %74, label %148, label %75 + +; <label>:75:                                     ; preds = %71 +  %76 = tail call i8* @memmove(i8* %11, i8* %2, i32 %73) #13 +  br label %148 + +; <label>:77:                                     ; preds = %18 +  %78 = sub i32 %24, %9 +  %79 = add i32 %78, %14 +  %80 = icmp slt i32 %79, 0 +  br i1 %80, label %81, label %83 + +; <label>:81:                                     ; preds = %77 +  %82 = bitcast %"class.std::__1::vector.182"* %0 to %"class.std::__1::__vector_base_common"* +  tail call void @_ZNKSt3__120__vector_base_commonILb1EE20__throw_length_errorEv(%"class.std::__1::__vector_base_common"* %82) #15 +  unreachable + +; <label>:83:                                     ; preds = %77 +  %84 = sub i32 %21, %9 +  %85 = icmp ult i32 %84, 1073741823 +  br i1 %85, label %86, label %91 + +; <label>:86:                                     ; preds = %83 +  %87 = shl i32 %84, 1 +  %88 = icmp ult i32 %87, %79 +  %89 = select i1 %88, i32 %79, i32 %87 +  %90 = icmp eq i32 %89, 0 +  br i1 %90, label %94, label %91 + +; <label>:91:                                     ; preds = %83, %86 +  %92 = phi i32 [ %89, %86 ], [ 2147483647, %83 ] +  %93 = tail call i8* @Allocate(i32 %92) #13 +  br label %94 + +; <label>:94:                                     ; preds = %86, %91 +  %95 = phi i32 [ %92, %91 ], [ 0, %86 ] +  %96 = phi i8* [ %93, %91 ], [ null, %86 ] +  %97 = getelementptr inbounds i8, i8* %96, i32 %10 +  %98 = ptrtoint i8* %97 to i32 +  %99 = getelementptr inbounds i8, i8* %96, i32 %95 +  %100 = ptrtoint i8* %99 to i32 +  %101 = icmp eq i8* %2, %3 +  br i1 %101, label %111, label %102 + +; <label>:102:                                    ; preds = %94, %102 +  %103 = phi i8* [ %106, %102 ], [ %97, %94 ] +  %104 = phi i8* [ %107, %102 ], [ %2, %94 ] +  %105 = load i8, i8* %104, align 1 +  store i8 %105, i8* %103, align 1 +  %106 = getelementptr inbounds i8, i8* %103, i32 1 +  %107 = getelementptr inbounds i8, i8* %104, i32 1 +  %108 = icmp eq i8* %107, %3 +  br i1 %108, label %109, label %102 + +; <label>:109:                                    ; preds = %102 +  %110 = ptrtoint i8* %106 to i32 +  br label %111 + +; <label>:111:                                    ; preds = %109, %94 +  %112 = phi i32 [ %98, %94 ], [ %110, %109 ] +  %113 = load i8*, i8** %6, align 4 +  %114 = icmp eq i8* %113, %11 +  br i1 %114, label %124, label %115 + +; CHECK-LABEL: .preheader: +; CHECK-NEXT: sub i32 [[OLD_CAST]], [[NEW_CAST]] +; <label>:115:                                    ; preds = %111, %115 +  %116 = phi i8* [ %118, %115 ], [ %97, %111 ] +  %117 = phi i8* [ %119, %115 ], [ %11, %111 ] +  %118 = getelementptr inbounds i8, i8* %116, i32 -1 +  %119 = getelementptr inbounds i8, i8* %117, i32 -1 +  %120 = load i8, i8* %119, align 1 +  store i8 %120, i8* %118, align 1 +  %121 = icmp eq i8* %119, %113 +  br i1 %121, label %122, label %115 + +; <label>:122:                                    ; preds = %115 +  %123 = ptrtoint i8* %118 to i32 +  br label %124 + +; <label>:124:                                    ; preds = %122, %111 +  %125 = phi i32 [ %98, %111 ], [ %123, %122 ] +  %126 = phi i8* [ %97, %111 ], [ %118, %122 ] +  %127 = load i8*, i8** %22, align 4 +  %128 = icmp eq i8* %127, %11 +  br i1 %128, label %129, label %131 + +; <label>:129:                                    ; preds = %124 +  %130 = ptrtoint i8* %126 to i32 +  br label %142 + +; <label>:131:                                    ; preds = %124 +  %132 = inttoptr i32 %112 to i8* +  br label %133 + +; <label>:133:                                    ; preds = %133, %131 +  %134 = phi i8* [ %138, %133 ], [ %132, %131 ] +  %135 = phi i8* [ %137, %133 ], [ %11, %131 ] +  %136 = load i8, i8* %135, align 1 +  store i8 %136, i8* %134, align 1 +  %137 = getelementptr inbounds i8, i8* %135, i32 1 +  %138 = getelementptr inbounds i8, i8* %134, i32 1 +  %139 = icmp eq i8* %137, %127 +  br i1 %139, label %140, label %133 + +; <label>:140:                                    ; preds = %133 +  %141 = ptrtoint i8* %138 to i32 +  br label %142 + +; <label>:142:                                    ; preds = %140, %129 +  %143 = phi i32 [ %112, %129 ], [ %141, %140 ] +  %144 = phi i32 [ %130, %129 ], [ %125, %140 ] +  %145 = load i8*, i8** %6, align 4 +  store i32 %144, i32* %8, align 4 +  store i32 %143, i32* %27, align 4 +  store i32 %100, i32* %20, align 4 +  %146 = icmp eq i8* %145, null +  br i1 %146, label %148, label %147 + +; <label>:147:                                    ; preds = %142 +  tail call void @Free(i8* nonnull %145) #13 +  br label %148 + +; <label>:148:                                    ; preds = %16, %147, %142, %43, %71, %75 +  %149 = phi i32 [ %17, %16 ], [ %98, %147 ], [ %98, %142 ], [ %29, %43 ], [ %29, %71 ], [ %29, %75 ] +  ret i32 %149 +} + diff --git a/llvm/test/Transforms/LoopDistribute/bounds-expansion-bug.ll b/llvm/test/Transforms/LoopDistribute/bounds-expansion-bug.ll index 64104e5c299..673b2942bad 100644 --- a/llvm/test/Transforms/LoopDistribute/bounds-expansion-bug.ll +++ b/llvm/test/Transforms/LoopDistribute/bounds-expansion-bug.ll @@ -52,7 +52,7 @@ join:  ;     %c = phi i32* [ %c1, %one ], [ %c2, %two ]  ;     %a3 = bitcast i32* %a to i8*                   <--- new  ;     %c5 = bitcast i32* %c to i8* -;     %0 = bitcast i32* undef to i8*                 <--- old, invalidated +;     %0 = bitcast i32* %a to i8*                 <--- old, invalidated  ;  ; 3. Finally, when C is expanded again:  ; @@ -61,16 +61,20 @@ join:  ;     %c = phi i32* [ %c1, %one ], [ %c2, %two ]  ;     %c5 = bitcast i32* %c to i8*                   <--- new  ;     %a3 = bitcast i32* %a to i8* -;     %0 = bitcast i32* undef to i8*                 <--- old, invalidated -;     %1 = bitcast i32* undef to i8* +;     %0 = bitcast i32* %c to i8*                 <--- old, invalidated +;     %1 = bitcast i32* %a to i8*    %a = phi i32* [%a1, %one], [%a2, %two]    %c = phi i32* [%c1, %one], [%c2, %two]    br label %for.body - -; CHECK: [[VALUE:%[0-9a-z]+]] = bitcast i32* undef to i8* -; CHECK-NOT: [[VALUE]] +; CHECK: join +; CHECK: {{%[0-9a-z]+}} = bitcast i32* %c to i8* +; CHECK: {{%[0-9a-z]+}} = bitcast i32* %a to i8* +; CHECK: [[OLD_C:%[0-9a-z]+]] = bitcast i32* %c to i8* +; CHECK: [[OLD_A:%[0-9a-z]+]] = bitcast i32* %a to i8* +; CHECK-NOT: [[OLD_C]] +; CHECK-NOT: [[OLD_A]]  for.body:                                         ; preds = %for.body, %entry    %ind = phi i64 [ 0, %join ], [ %add, %for.body ]  | 

