[clang][modules] Don't prevent translation of FW_Private includes when explicitly...
[llvm-project.git] / llvm / test / Transforms / LoopStrengthReduce / Power / memory-intrinsic.ll
blob82e3ab761fb3dd2e20e3d30c37e6af3d4b52b6e3
1 ; REQUIRES: asserts
2 ; RUN: opt -loop-reduce -debug-only=loop-reduce -S  < %s 2>&1 | FileCheck %s
4 target datalayout = "e-m:e-i64:64-n32:64"
5 target triple = "powerpc64le-unknown-linux-gnu"
7 ; CHECK: LSR Use: Kind=Address
8 ; CHECK: LSR Use: Kind=Address
9 ; CHECK-NOT: LSR Use: Kind=Basic
10 ; CHECK-NOT: LSR Use: Kind=Basic
12 declare <4 x i32> @llvm.ppc.altivec.lvx(i8*)
13 declare void @llvm.ppc.altivec.stvx(<4 x i32>, i8*)
15 ; Function Attrs: nofree norecurse nounwind
16 define void @foo(<4 x i32>* %0, <4 x i32>* %1, i32 signext %2) {
17   %4 = icmp sgt i32 %2, 0
18   br i1 %4, label %5, label %7
20 5:                                                ; preds = %3
21   %6 = zext i32 %2 to i64
22   br label %8
24 7:                                                ; preds = %8, %3
25   ret void
27 8:                                                ; preds = %5, %8
28   %9 = phi i64 [ 0, %5 ], [ %15, %8 ]
29   %10 = getelementptr inbounds <4 x i32>, <4 x i32>* %1, i64 %9
30   %11 = bitcast <4 x i32>* %10 to i8*
31   %12 = call <4 x i32> @llvm.ppc.altivec.lvx(i8* %11)
32   %13 = getelementptr inbounds <4 x i32>, <4 x i32>* %0, i64 %9
33   %14 = bitcast <4 x i32>* %13 to i8*
34   call void @llvm.ppc.altivec.stvx(<4 x i32> %12, i8* %14)
35   %15 = add nuw nsw i64 %9, 10
36   %16 = icmp ult i64 %15, %6
37   br i1 %16, label %8, label %7