summaryrefslogtreecommitdiff
path: root/test/CodeGen/PowerPC/qpx-s-load.ll
blob: 57d7e3b0ded3c4db5e0bec055f103359dee0063f (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
; RUN: llc -verify-machineinstrs < %s -mcpu=a2q | FileCheck %s
target triple = "powerpc64-bgq-linux"

define <4 x float> @foo(<4 x float>* %p) {
entry:
  %v = load <4 x float>, <4 x float>* %p, align 4
  ret <4 x float> %v
}

; CHECK: @foo
; CHECK-DAG: li [[REG1:[0-9]+]], 15
; CHECK-DAG: qvlfsx [[REG4:[0-9]+]], 0, 3
; CHECK-DAG: qvlfsx [[REG2:[0-9]+]], 3, [[REG1]]
; CHECK-DAG: qvlpclsx [[REG3:[0-9]+]], 0, 3
; CHECK-DAG: qvfperm 1, [[REG4]], [[REG2]], [[REG3]]
; CHECK: blr

define <4 x float> @bar(<4 x float>* %p) {
entry:
  %v = load <4 x float>, <4 x float>* %p, align 16
  ret <4 x float> %v
}

; CHECK: @bar
; CHECK: qvlfsx