aboutsummaryrefslogtreecommitdiff
path: root/llvm/test/Transforms/SLPVectorizer/pr31599.ll
blob: 10b9b224d556e5d0ac41b04f2643b2e0b730cf75 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
; RUN: %if x86-registered-target %{ opt -passes=slp-vectorizer -S -mtriple=x86_64-unknown-linux-gnu < %s | FileCheck %s %}
; RUN: %if aarch64-registered-target %{ opt -passes=slp-vectorizer -S -mtriple=aarch64-unknown-linux-gnu < %s | FileCheck %s %}

define <2 x float> @foo() {
; CHECK-LABEL: @foo(
; CHECK-NEXT:  entry:
; CHECK-NEXT:    [[SOURCE:%.*]] = insertelement <2 x float> undef, float undef, i32 0
; CHECK-NEXT:    [[TMP0:%.*]] = fsub <2 x float> [[SOURCE]], [[SOURCE]]
; CHECK-NEXT:    ret <2 x float> [[TMP0]]
;
entry:
  %source = insertelement <2 x float> undef, float undef, i32 0
  %e0 = extractelement <2 x float> %source, i32 0
  %e0.dup = extractelement <2 x float> %source, i32 0
  %sub1 = fsub float %e0, %e0.dup
  %e1 = extractelement <2 x float> %source, i32 1
  %e1.dup = extractelement <2 x float> %source, i32 1
  %sub2 = fsub float %e1, %e1.dup
  %res1 = insertelement <2 x float> undef, float %sub1, i32 0
  %res2 = insertelement <2 x float> %res1, float %sub2, i32 1
  ret <2 x float> %res2
}

!llvm.ident = !{!0, !0}

!0 = !{!"clang version 4.0.0 "}