summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.target/aarch64/sve_ld1r_2_run.c
blob: 510b2eca5172da165f46c454ed9b8a25209a3a98 (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
33
34
35
36
37
38
/* { dg-do run { target aarch64_sve_hw } } */
/* { dg-options "-O3 -march=armv8-a+sve -fno-tree-loop-distribute-patterns" } */

#include "sve_ld1r_2.c"

#define TEST_LOAD_BROADCAST(TYPE)		\
  {						\
    TYPE v[NUM_ELEMS (TYPE)];			\
    TYPE val = 99;				\
    set_##TYPE (v, &val);			\
    for (int i = 0; i < NUM_ELEMS (TYPE); i++)	\
      {						\
	if (v[i] != (TYPE) 99)			\
	  __builtin_abort ();			\
	asm volatile ("" ::: "memory");		\
      }						\
  }

#define TEST_LOAD_BROADCAST_IMM(TYPE, IMM, SUFFIX)	\
  {							\
    TYPE v[NUM_ELEMS (TYPE)];				\
    set_##TYPE##_##SUFFIX (v);				\
    for (int i = 0; i < NUM_ELEMS (TYPE); i++ )		\
      {							\
	if (v[i] != (TYPE) IMM)				\
	  __builtin_abort ();				\
	asm volatile ("" ::: "memory");			\
      }							\
  }

int __attribute__ ((optimize (1)))
main (int argc, char **argv)
{
  FOR_EACH_LOAD_BROADCAST (TEST_LOAD_BROADCAST)
  FOR_EACH_LOAD_BROADCAST_IMM (TEST_LOAD_BROADCAST_IMM)

  return 0;
}