blob: a8c6912f0c739f649315b77884f41174e85341ab [file] [log] [blame]
Ulrich Weigandce4c1092015-05-05 19:25:42 +00001; Test vector loads.
2;
3; RUN: llc < %s -mtriple=s390x-linux-gnu -mcpu=z13 | FileCheck %s
4
5; Test v16i8 loads.
6define <16 x i8> @f1(<16 x i8> *%ptr) {
7; CHECK-LABEL: f1:
8; CHECK: vl %v24, 0(%r2)
9; CHECK: br %r14
10 %ret = load <16 x i8>, <16 x i8> *%ptr
11 ret <16 x i8> %ret
12}
13
14; Test v8i16 loads.
15define <8 x i16> @f2(<8 x i16> *%ptr) {
16; CHECK-LABEL: f2:
17; CHECK: vl %v24, 0(%r2)
18; CHECK: br %r14
19 %ret = load <8 x i16>, <8 x i16> *%ptr
20 ret <8 x i16> %ret
21}
22
23; Test v4i32 loads.
24define <4 x i32> @f3(<4 x i32> *%ptr) {
25; CHECK-LABEL: f3:
26; CHECK: vl %v24, 0(%r2)
27; CHECK: br %r14
28 %ret = load <4 x i32>, <4 x i32> *%ptr
29 ret <4 x i32> %ret
30}
31
32; Test v2i64 loads.
33define <2 x i64> @f4(<2 x i64> *%ptr) {
34; CHECK-LABEL: f4:
35; CHECK: vl %v24, 0(%r2)
36; CHECK: br %r14
37 %ret = load <2 x i64>, <2 x i64> *%ptr
38 ret <2 x i64> %ret
39}
40
Ulrich Weigandcd808232015-05-05 19:26:48 +000041; Test v2f64 loads.
42define <2 x double> @f6(<2 x double> *%ptr) {
43; CHECK-LABEL: f6:
44; CHECK: vl %v24, 0(%r2)
45; CHECK: br %r14
46 %ret = load <2 x double>, <2 x double> *%ptr
47 ret <2 x double> %ret
48}
49
Ulrich Weigandce4c1092015-05-05 19:25:42 +000050; Test the highest aligned in-range offset.
51define <16 x i8> @f7(<16 x i8> *%base) {
52; CHECK-LABEL: f7:
53; CHECK: vl %v24, 4080(%r2)
54; CHECK: br %r14
55 %ptr = getelementptr <16 x i8>, <16 x i8> *%base, i64 255
56 %ret = load <16 x i8>, <16 x i8> *%ptr
57 ret <16 x i8> %ret
58}
59
60; Test the highest unaligned in-range offset.
61define <16 x i8> @f8(i8 *%base) {
62; CHECK-LABEL: f8:
63; CHECK: vl %v24, 4095(%r2)
64; CHECK: br %r14
65 %addr = getelementptr i8, i8 *%base, i64 4095
66 %ptr = bitcast i8 *%addr to <16 x i8> *
67 %ret = load <16 x i8>, <16 x i8> *%ptr, align 1
68 ret <16 x i8> %ret
69}
70
71; Test the next offset up, which requires separate address logic,
72define <16 x i8> @f9(<16 x i8> *%base) {
73; CHECK-LABEL: f9:
74; CHECK: aghi %r2, 4096
75; CHECK: vl %v24, 0(%r2)
76; CHECK: br %r14
77 %ptr = getelementptr <16 x i8>, <16 x i8> *%base, i64 256
78 %ret = load <16 x i8>, <16 x i8> *%ptr
79 ret <16 x i8> %ret
80}
81
82; Test negative offsets, which also require separate address logic,
83define <16 x i8> @f10(<16 x i8> *%base) {
84; CHECK-LABEL: f10:
85; CHECK: aghi %r2, -16
86; CHECK: vl %v24, 0(%r2)
87; CHECK: br %r14
88 %ptr = getelementptr <16 x i8>, <16 x i8> *%base, i64 -1
89 %ret = load <16 x i8>, <16 x i8> *%ptr
90 ret <16 x i8> %ret
91}
92
93; Check that indexes are allowed.
94define <16 x i8> @f11(i8 *%base, i64 %index) {
95; CHECK-LABEL: f11:
96; CHECK: vl %v24, 0(%r3,%r2)
97; CHECK: br %r14
98 %addr = getelementptr i8, i8 *%base, i64 %index
99 %ptr = bitcast i8 *%addr to <16 x i8> *
100 %ret = load <16 x i8>, <16 x i8> *%ptr, align 1
101 ret <16 x i8> %ret
102}