annotate gcc/testsuite/g++.target/aarch64/sve/dup_sel_4.C @ 145:1830386684a0

gcc-9.2.0
author anatofuz
date Thu, 13 Feb 2020 11:34:05 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
145
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
1 /* { dg-do compile } */
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
2 /* { dg-options "-O2 -msve-vector-bits=256" } */
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
3
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
4 #include <stdint.h>
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
5
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
6 typedef int32_t vnx4si __attribute__((vector_size(32)));
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
7 typedef float vnx4sf __attribute__((vector_size(32)));
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
8
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
9 void
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
10 foo (float val)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
11 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
12 register vnx4sf x asm ("z0");
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
13 register vnx4sf y asm ("z1");
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
14 asm volatile ("" : "=w" (y));
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
15 vnx4sf z = { val, val, val, val, val, val, val, val };
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
16 x = (vnx4si) { -1, 0, 0, -1, 0, -1, 0, -1 } ? z : y;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
17 asm volatile ("" :: "w" (x));
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
18 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
19
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
20 /* { dg-final { scan-assembler {\tmovprfx\tz0, z1\n\tmov\tz0\.s, p[0-7]/m, s[0-9]+\n} } } */