i386: Adjust rtx cost for imulq and imulw [PR115749]
[official-gcc.git] / gcc / testsuite / gcc.dg / vect / vect-reduc-dot-18.c
blob81ecb158d29e97f04f16e5d497629e892b23b2a9
1 /* { dg-require-effective-target vect_int } */
2 /* { dg-require-effective-target arm_v8_2a_dotprod_neon_hw { target { aarch64*-*-* || arm*-*-* } } } */
3 /* { dg-add-options arm_v8_2a_dotprod_neon } */
5 #include "tree-vect.h"
7 #define N 50
9 #ifndef SIGNEDNESS_1
10 #define SIGNEDNESS_1 unsigned
11 #define SIGNEDNESS_2 signed
12 #define SIGNEDNESS_3 signed
13 #define SIGNEDNESS_4 unsigned
14 #endif
16 SIGNEDNESS_1 int __attribute__ ((noipa))
17 f (SIGNEDNESS_1 int res, SIGNEDNESS_3 char *restrict a,
18 SIGNEDNESS_4 char *restrict b)
20 for (__INTPTR_TYPE__ i = 0; i < N; ++i)
22 int av = a[i];
23 int bv = b[i];
24 SIGNEDNESS_2 int mult = av * bv;
25 res += mult;
27 return res;
30 #define BASE ((SIGNEDNESS_3 int) -1 < 0 ? -126 : 4)
31 #define OFFSET 20
33 int
34 main (void)
36 check_vect ();
38 SIGNEDNESS_3 char a[N];
39 SIGNEDNESS_4 char b[N];
40 SIGNEDNESS_1 int expected = 0x12345;
41 for (int i = 0; i < N; ++i)
43 a[i] = BASE + i * 5;
44 b[i] = BASE + OFFSET + i * 4;
45 asm volatile ("" ::: "memory");
46 expected += (SIGNEDNESS_2 int) (a[i] * b[i]);
48 if (f (0x12345, a, b) != expected)
49 __builtin_abort ();
52 /* { dg-final { scan-tree-dump "vect_recog_dot_prod_pattern: detected" "vect" } } */
53 /* { dg-final { scan-tree-dump-times "vectorized 1 loop" 1 "vect" { target vect_sdot_qi } } } */