[ORC] Add std::tuple support to SimplePackedSerialization.
[llvm-project.git] / llvm / test / Transforms / LoopVectorize / AArch64 / scalable-alloca.ll
blobaa1bc240ebfda313ddbfe6398a7eaf88856a1229
1 ; RUN: opt -S -loop-vectorize -mattr=+sve -mtriple aarch64-unknown-linux-gnu -force-vector-width=2 -scalable-vectorization=preferred -pass-remarks-analysis=loop-vectorize -pass-remarks-missed=loop-vectorize < %s 2>%t | FileCheck %s
2 ; RUN: FileCheck %s --check-prefix=CHECK-REMARKS < %t
4 ; CHECK-REMARKS: UserVF ignored because of invalid costs.
5 ; CHECK-REMARKS: Instruction with invalid costs prevented vectorization at VF=(vscale x 1, vscale x 2): alloca
6 ; CHECK-REMARKS: Instruction with invalid costs prevented vectorization at VF=(vscale x 1): store
7 define void @alloca(i32** %vla, i64 %N) {
8 ; CHECK-LABEL: @alloca(
9 ; CHECK-NOT: <vscale x
11 entry:
12   br label %for.body
14 for.body:
15   %iv = phi i64 [ %iv.next, %for.body ], [ 0, %entry ]
16   %alloca = alloca i32, align 16
17   %arrayidx = getelementptr inbounds i32*, i32** %vla, i64 %iv
18   store i32* %alloca, i32** %arrayidx, align 8
19   %iv.next = add nuw nsw i64 %iv, 1
20   %exitcond.not = icmp eq i64 %iv.next, %N
21   br i1 %exitcond.not, label %for.end, label %for.body, !llvm.loop !0
23 for.end:
24   call void @foo(i32** nonnull %vla)
25   ret void
28 declare void @foo(i32**)
30 !0 = !{!0, !1}
31 !1 = !{!"llvm.loop.vectorize.scalable.enable", i1 true}