summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.target/i386/avx2-vpmaskloadd256-2.c
blob: b5a82bddde258d78f44616f4e5024c2613dea8f1 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
/* { dg-do run } */
/* { dg-require-effective-target avx2 } */
/* { dg-options "-O2 -mavx2" } */

#include "avx2-check.h"

#ifndef MASK
#define MASK 134
#endif

#define mask_v(pos) (((MASK & (0x1 << (pos))) >> (pos)) << 31)

void static
avx2_test (void)
{
  int i;
  int m[8] =
    { mask_v (0), mask_v (1), mask_v (2), mask_v (3), mask_v (4), mask_v (5),
mask_v (6), mask_v (7) };
  int s[8] = { 1, 2, 3, 4, 5, 6, 7, 8 };
  union256i_d u, mask;
  int e[8] = { 0 };

  mask.x = _mm256_loadu_si256 ((__m256i *) m);
  u.x = _mm256_maskload_epi32 (s, mask.x);

  for (i = 0; i < 8; i++)
    e[i] = m[i] ? s[i] : 0;

  if (check_union256i_d (u, e))
    abort ();
}