(root)/
gcc-13.2.0/
gcc/
testsuite/
gcc.target/
i386/
avx512f-broadcast-pr87767-4.c
       1  /* PR target/87767 */
       2  /* { dg-do run } */
       3  /* { dg-options "-O2 -mavx512f" } */
       4  /* { dg-require-effective-target avx512f } */
       5  
       6  #include "avx512f-helper.h"
       7  
       8  #include "avx512f-broadcast-pr87767-3.c"
       9  
      10  #define RTEST(VTYPE, TYPE, N, OP_NAME, OP1, OP2)				\
      11    do									\
      12      {									\
      13        TYPE exp[N], src1[N], src2[N];					\
      14        VTYPE res;							\
      15        for (int i = 0; i < N; i++)					\
      16  	{								\
      17  	  src1[i] = i * i * 107.2f;					\
      18  	  src2[i] = i * 2.f - 404.f;					\
      19  	}								\
      20        res = foo_##OP_NAME##_##VTYPE (*(VTYPE*)&src1[0], *(VTYPE*)&src2[0]); \
      21        for (int i = 0; i < N; i ++)					\
      22  	exp[i] = (OP1 src1[i] * src2[i]) OP2 CONSTANT;			\
      23        for (int j = 0; j < N; j++)					\
      24  	{								\
      25  	  if (res[j] != exp[j])						\
      26  	    abort();							\
      27  	}								\
      28      }									\
      29    while (0)
      30  
      31  void
      32  test_512 (void)
      33  {
      34    RTEST (v16sf, float, 16, fma,, +);
      35    RTEST (v8df, double, 8, fma,, +);
      36    RTEST (v16sf, float, 16, fms,, -);
      37    RTEST (v8df, double, 8, fms,, -);
      38    RTEST (v16sf, float, 16, fnma,-, +);
      39    RTEST (v8df, double, 8, fnma,-, +);
      40    RTEST (v16sf, float, 16, fnms,-, -);
      41    RTEST (v8df, double, 8, fnms,-, -);
      42  }