annotate gcc/testsuite/gcc.target/i386/avx2-pr94460.c @ 152:2b5abeee2509

update gcc11
author anatofuz
date Mon, 25 May 2020 07:50:57 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
152
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
1 /* PR target/94460 */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
2 /* { dg-do run { target { avx2 && int128 } } } */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
3 /* { dg-options "-O2 -mavx2" } */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
4
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
5 #include <x86intrin.h>
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
6 #include "avx2-check.h"
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
7
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
8 typedef __int128 v2ti __attribute__ ((__vector_size__ (32)));
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
9
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
10 static inline v2ti
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
11 foo (__v16hi b)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
12 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
13 return (v2ti) _mm256_hsub_epi16 ((__m256i) b, (__m256i) b);
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
14 }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
15
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
16 static inline v2ti
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
17 bar (__v8si b)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
18 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
19 return (v2ti) _mm256_hsub_epi32 ((__m256i) b, (__m256i) b);
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
20 }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
21
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
22 static void
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
23 avx2_test (void)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
24 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
25 v2ti x = foo ((__v16hi) { 1 });
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
26 if (x[0] != ((__int128)1 << 64 | 1) || x[1] != 0)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
27 abort ();
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
28 x = bar ((__v8si) { 1 });
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
29 if (x[0] != ((__int128)1 << 64 | 1) || x[1] != 0)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
30 abort ();
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
31 }