1 /* PR target/98461 */
2 /* { dg-do compile } */
3 /* { dg-options "-O2 -mavx2 -masm=att" } */
4 /* { dg-final { scan-assembler-times "\tvpmovmskb\t" 6 } } */
5 /* { dg-final { scan-assembler-times "\tnotl\t" 6 } } */
6 /* { dg-final { scan-assembler-not "\tvpcmpeq" } } */
7 /* { dg-final { scan-assembler-not "\tvpxor" } } */
8 /* { dg-final { scan-assembler-not "\tvpandn" } } */
9
10 #include <x86intrin.h>
11
12 int
f1(__m256i x)13 f1 (__m256i x)
14 {
15 return ~_mm256_movemask_epi8 (x);
16 }
17
18 int
f2(__m256i x)19 f2 (__m256i x)
20 {
21 return _mm256_movemask_epi8 (_mm256_andnot_si256 (x, _mm256_set1_epi8 (255)));
22 }
23
24 int
f3(__v32qi x)25 f3 (__v32qi x)
26 {
27 x ^= (__v32qi) { -1, -1, -1, -1, -1, -1, -1, -1,
28 -1, -1, -1, -1, -1, -1, -1, -1,
29 -1, -1, -1, -1, -1, -1, -1, -1,
30 -1, -1, -1, -1, -1, -1, -1, -1 };
31 return _mm256_movemask_epi8 ((__m256i) x);
32 }
33
34 long
f4(__m256i x)35 f4 (__m256i x)
36 {
37 return (unsigned) ~_mm256_movemask_epi8 (x);
38 }
39
40 long
f5(__m256i x)41 f5 (__m256i x)
42 {
43 return (unsigned) _mm256_movemask_epi8 (_mm256_andnot_si256 (x, _mm256_set1_epi8 (255)));
44 }
45
46 long
f6(__v32qi x)47 f6 (__v32qi x)
48 {
49 x ^= (__v32qi) { -1, -1, -1, -1, -1, -1, -1, -1,
50 -1, -1, -1, -1, -1, -1, -1, -1,
51 -1, -1, -1, -1, -1, -1, -1, -1,
52 -1, -1, -1, -1, -1, -1, -1, -1 };
53 return (unsigned) _mm256_movemask_epi8 ((__m256i) x);
54 }
55