diff options
| author | Matthew Simpson <mssimpso@codeaurora.org> | 2016-10-13 14:54:31 +0000 |
|---|---|---|
| committer | Matthew Simpson <mssimpso@codeaurora.org> | 2016-10-13 14:54:31 +0000 |
| commit | 1d4b163fc0fadab7ffe87149f3d1c897ded184f9 (patch) | |
| tree | e748d3f5d998378ef704eaea0ea3667143f70a94 /llvm/test/Transforms/LoopVectorize | |
| parent | 8295d54868a6b8a60a68e81b4c4a92d2803f0d0c (diff) | |
| download | bcm5719-llvm-1d4b163fc0fadab7ffe87149f3d1c897ded184f9.tar.gz bcm5719-llvm-1d4b163fc0fadab7ffe87149f3d1c897ded184f9.zip | |
[LV] Account for predicated stores in instruction costs
This patch ensures that we scale the estimated cost of predicated stores by
block probability. This is a follow-on patch for r284123.
llvm-svn: 284126
Diffstat (limited to 'llvm/test/Transforms/LoopVectorize')
| -rw-r--r-- | llvm/test/Transforms/LoopVectorize/AArch64/predication_costs.ll | 40 |
1 files changed, 39 insertions, 1 deletions
diff --git a/llvm/test/Transforms/LoopVectorize/AArch64/predication_costs.ll b/llvm/test/Transforms/LoopVectorize/AArch64/predication_costs.ll index 150073aa2ab..8307a962b13 100644 --- a/llvm/test/Transforms/LoopVectorize/AArch64/predication_costs.ll +++ b/llvm/test/Transforms/LoopVectorize/AArch64/predication_costs.ll @@ -1,5 +1,5 @@ ; REQUIRES: asserts -; RUN: opt < %s -force-vector-width=2 -loop-vectorize -debug-only=loop-vectorize -disable-output 2>&1 | FileCheck %s +; RUN: opt < %s -force-vector-width=2 -enable-cond-stores-vec -loop-vectorize -debug-only=loop-vectorize -disable-output 2>&1 | FileCheck %s target datalayout = "e-m:e-i64:64-i128:128-n32:64-S128" target triple = "aarch64--linux-gnu" @@ -51,3 +51,41 @@ for.end: %tmp7 = phi i32 [ %tmp6, %for.inc ] ret i32 %tmp7 } + +; CHECK-LABEL: predicated_store +; +; This test checks that we correctly compute the cost of the predicated store +; instruction. If we assume the block probability is 50%, we compute the cost +; as: +; +; Cost for vector lane zero: +; (store(2) + 2 * extractelement(0)) / 2 = 1 +; Cost for vector lane one: +; (store(2) + 2 * extractelement(3)) / 2 = 4 +; +; CHECK: Found an estimated cost of 5 for VF 2 For instruction: store i32 %tmp2, i32* %tmp0, align 4 +; CHECK: Scalarizing and predicating: store i32 %tmp2, i32* %tmp0, align 4 +; +define void @predicated_store(i32* %a, i1 %c, i32 %x, i64 %n) { +entry: + br label %for.body + +for.body: + %i = phi i64 [ 0, %entry ], [ %i.next, %for.inc ] + %tmp0 = getelementptr inbounds i32, i32* %a, i64 %i + %tmp1 = load i32, i32* %tmp0, align 4 + br i1 %c, label %if.then, label %for.inc + +if.then: + %tmp2 = add nsw i32 %tmp1, %x + store i32 %tmp2, i32* %tmp0, align 4 + br label %for.inc + +for.inc: + %i.next = add nuw nsw i64 %i, 1 + %cond = icmp slt i64 %i.next, %n + br i1 %cond, label %for.body, label %for.end + +for.end: + ret void +} |

