[TTI] getTypeBasedIntrinsicInstrCost - add basic handling for strided load/store...
[llvm-project.git] / llvm / test / Transforms / SLPVectorizer / one-element-vector.ll
blobcab9188832284d5bb12e2059cdcb4bddf46e9b00
1 ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 3
2 ; RUN: %if x86-registered-target %{ opt -S --passes=slp-vectorizer -mtriple=x86_64-unknown-linux-gnu < %s | FileCheck %s %}
3 ; RUN: %if aarch64-registered-target %{ opt -S --passes=slp-vectorizer -mtriple=aarch64-unknown-linux-gnu < %s | FileCheck %s %}
5 define void @test() {
6 ; CHECK-LABEL: define void @test() {
7 ; CHECK-NEXT:  entry:
8 ; CHECK-NEXT:    [[TMP0:%.*]] = extractelement <1 x i64> zeroinitializer, i64 0
9 ; CHECK-NEXT:    [[BF_VALUE:%.*]] = and i64 [[TMP0]], 0
10 ; CHECK-NEXT:    [[BF_CLEAR:%.*]] = and i64 0, 1
11 ; CHECK-NEXT:    [[BF_SET:%.*]] = or i64 [[BF_CLEAR]], [[BF_VALUE]]
12 ; CHECK-NEXT:    store i64 [[BF_SET]], ptr null, align 8
13 ; CHECK-NEXT:    ret void
15 entry:
16   %0 = extractelement <1 x i64> zeroinitializer, i64 0
17   %bf.value = and i64 %0, 0
18   %bf.clear = and i64 0, 1
19   %bf.set = or i64 %bf.clear, %bf.value
20   store i64 %bf.set, ptr null, align 8
21   ret void