1 // RUN: %clang_cc1 -triple arm64-apple-ios7 -target-feature +neon -ffreestanding -S -o - -emit-llvm %s | FileCheck %s
2 
3 // Test ARM64 extract intrinsics
4 // can use as back end test by adding a run line with
5 // -check-prefix=CHECK-CODEGEN on the FileCheck
6 
7 #include <arm_neon.h>
8 
test_vext_s8()9 void test_vext_s8()
10 {
11   // CHECK: test_vext_s8
12   int8x8_t xS8x8;
13   xS8x8 = vext_s8(xS8x8, xS8x8, 1);
14   // CHECK: shufflevector
15   // CHECK-CODEGEN: test_vext_s8:
16   // CHECK-CODEGEN: {{ext.8.*#1}}
17 }
18 
test_vext_u8()19 void test_vext_u8()
20 {
21   // CHECK: test_vext_u8
22   uint8x8_t xU8x8;
23   xU8x8 = vext_u8(xU8x8, xU8x8, 2);
24   // CHECK: shufflevector
25   // CHECK-CODEGEN: test_vext_u8:
26   // CHECK-CODEGEN: {{ext.8.*#2}}
27 }
28 
test_vext_p8()29 void test_vext_p8()
30 {
31   // CHECK: test_vext_p8
32   poly8x8_t xP8x8;
33   xP8x8 = vext_p8(xP8x8, xP8x8, 3);
34   // CHECK: shufflevector
35   // CHECK-CODEGEN: test_vext_p8:
36   // CHECK-CODEGEN: {{ext.8.*#3}}
37 }
38 
test_vext_s16()39 void test_vext_s16()
40 {
41   // CHECK: test_vext_s16
42   int16x4_t xS16x4;
43   xS16x4 = vext_s16(xS16x4, xS16x4, 1);
44   // CHECK: shufflevector
45   // CHECK-CODEGEN: test_vext_s16:
46   // CHECK-CODEGEN: {{ext.8.*#2}}
47 }
48 
test_vext_u16()49 void test_vext_u16()
50 {
51   // CHECK: test_vext_u16
52   uint16x4_t xU16x4;
53   xU16x4 = vext_u16(xU16x4, xU16x4, 2);
54   // CHECK: shufflevector
55   // CHECK-CODEGEN: test_vext_u16:
56   // CHECK-CODEGEN: {{ext.8.*#4}}
57 }
58 
test_vext_p16()59 void test_vext_p16()
60 {
61   // CHECK: test_vext_p16
62   poly16x4_t xP16x4;
63   xP16x4 = vext_p16(xP16x4, xP16x4, 3);
64   // CHECK: shufflevector
65   // CHECK-CODEGEN: test_vext_p16:
66   // CHECK-CODEGEN: {{ext.8.*#6}}
67 }
68 
test_vext_s32()69 void test_vext_s32()
70 {
71   // CHECK: test_vext_s32
72   int32x2_t xS32x2;
73   xS32x2 = vext_s32(xS32x2, xS32x2, 1);
74   // CHECK: shufflevector
75   // CHECK-CODEGEN: test_vext_s32:
76   // CHECK-CODEGEN: {{ext.8.*#4}}
77 }
78 
test_vext_u32()79 void test_vext_u32()
80 {
81   // CHECK: test_vext_u32
82   uint32x2_t xU32x2;
83   xU32x2 = vext_u32(xU32x2, xU32x2, 1);
84   // CHECK: shufflevector
85   // CHECK-CODEGEN: test_vext_u32:
86   // CHECK-CODEGEN: {{ext.8.*#4}}
87 }
88 
test_vext_f32()89 void test_vext_f32()
90 {
91   // CHECK: test_vext_f32
92   float32x2_t xF32x2;
93   xF32x2 = vext_f32(xF32x2, xF32x2, 1);
94   // CHECK: shufflevector
95   // CHECK-CODEGEN: test_vext_f32:
96   // CHECK-CODEGEN: {{ext.8.*#4}}
97 }
98 
test_vext_s64()99 void test_vext_s64()
100 {
101   // CHECK: test_vext_s64
102   int64x1_t xS64x1;
103   // FIXME don't use 1 as index or check for now, clang has a bug?
104   xS64x1 = vext_s64(xS64x1, xS64x1, /*1*/0);
105   // CHECK: shufflevector
106   // CHECK-CODEGEN: test_vext_s64:
107   // CHECK_FIXME: {{ext.8.*#0}}
108 }
109 
test_vext_u64()110 void test_vext_u64()
111 {
112   // CHECK: test_vext_u64
113   uint64x1_t xU64x1;
114   // FIXME don't use 1 as index or check for now, clang has a bug?
115   xU64x1 = vext_u64(xU64x1, xU64x1, /*1*/0);
116   // CHECK: shufflevector
117   // CHECK-CODEGEN: test_vext_u64:
118   // CHECK_FIXME: {{ext.8.*#0}}
119 }
120 
test_vextq_s8()121 void test_vextq_s8()
122 {
123   // CHECK: test_vextq_s8
124   int8x16_t xS8x16;
125   xS8x16 = vextq_s8(xS8x16, xS8x16, 4);
126   // CHECK: shufflevector
127   // CHECK-CODEGEN: test_vextq_s8:
128   // CHECK-CODEGEN: {{ext.16.*#4}}
129 }
130 
test_vextq_u8()131 void test_vextq_u8()
132 {
133   // CHECK: test_vextq_u8
134   uint8x16_t xU8x16;
135   xU8x16 = vextq_u8(xU8x16, xU8x16, 5);
136   // CHECK: shufflevector
137   // CHECK-CODEGEN: test_vextq_u8:
138   // CHECK-CODEGEN: {{ext.16.*#5}}
139 }
140 
test_vextq_p8()141 void test_vextq_p8()
142 {
143   // CHECK: test_vextq_p8
144   poly8x16_t xP8x16;
145   xP8x16 = vextq_p8(xP8x16, xP8x16, 6);
146   // CHECK: shufflevector
147   // CHECK-CODEGEN: test_vextq_p8:
148   // CHECK-CODEGEN: {{ext.16.*#6}}
149 }
150 
test_vextq_s16()151 void test_vextq_s16()
152 {
153   // CHECK: test_vextq_s16
154   int16x8_t xS16x8;
155   xS16x8 = vextq_s16(xS16x8, xS16x8, 7);
156   // CHECK: shufflevector
157   // CHECK-CODEGEN: test_vextq_s16:
158   // CHECK-CODEGEN: {{ext.16.*#14}}
159 }
160 
test_vextq_u16()161 void test_vextq_u16()
162 {
163   // CHECK: test_vextq_u16
164   uint16x8_t xU16x8;
165   xU16x8 = vextq_u16(xU16x8, xU16x8, 4);
166   // CHECK: shufflevector
167   // CHECK-CODEGEN: test_vextq_u16:
168   // CHECK-CODEGEN: {{ext.16.*#8}}
169 }
170 
test_vextq_p16()171 void test_vextq_p16()
172 {
173   // CHECK: test_vextq_p16
174   poly16x8_t xP16x8;
175   xP16x8 = vextq_p16(xP16x8, xP16x8, 5);
176   // CHECK: shufflevector
177   // CHECK-CODEGEN: test_vextq_p16:
178   // CHECK-CODEGEN: {{ext.16.*#10}}
179 }
180 
test_vextq_s32()181 void test_vextq_s32()
182 {
183   // CHECK: test_vextq_s32
184   int32x4_t xS32x4;
185   xS32x4 = vextq_s32(xS32x4, xS32x4, 1);
186   // CHECK: shufflevector
187   // CHECK-CODEGEN: test_vextq_s32:
188   // CHECK-CODEGEN: {{ext.16.*#4}}
189 }
190 
test_vextq_u32()191 void test_vextq_u32()
192 {
193   // CHECK: test_vextq_u32
194   uint32x4_t xU32x4;
195   xU32x4 = vextq_u32(xU32x4, xU32x4, 2);
196   // CHECK: shufflevector
197   // CHECK-CODEGEN: test_vextq_u32:
198   // CHECK-CODEGEN: {{ext.16.*#8}}
199 }
200 
test_vextq_f32()201 void test_vextq_f32()
202 {
203   // CHECK: test_vextq_f32
204   float32x4_t xF32x4;
205   xF32x4 = vextq_f32(xF32x4, xF32x4, 3);
206   // CHECK: shufflevector
207   // CHECK-CODEGEN: test_vextq_f32:
208   // CHECK-CODEGEN: {{ext.16.*#12}}
209 }
210 
test_vextq_s64()211 void test_vextq_s64()
212 {
213   // CHECK: test_vextq_s64
214   int64x2_t xS64x2;
215   xS64x2 = vextq_s64(xS64x2, xS64x2, 1);
216   // CHECK: shufflevector
217   // CHECK-CODEGEN: test_vextq_s64:
218   // CHECK-CODEGEN: {{ext.16.*#8}}
219 }
220 
test_vextq_u64()221 void test_vextq_u64()
222 {
223   // CHECK: test_vextq_u64
224   uint64x2_t xU64x2;
225   xU64x2 = vextq_u64(xU64x2, xU64x2, 1);
226   // CHECK: shufflevector
227   // CHECK-CODEGEN: test_vextq_u64:
228   // CHECK-CODEGEN: {{ext.16.*#8}}
229 }
230 
test_vextq_f64()231 void test_vextq_f64()
232 {
233   // CHECK: test_vextq_f64
234   float64x2_t xF64x2;
235   xF64x2 = vextq_f64(xF64x2, xF64x2, 1);
236   // CHECK: shufflevector
237   // CHECK-CODEGEN: test_vextq_u64:
238   // CHECK-CODEGEN: {{ext.16.*#8}}
239 }
240