AVR: target/116953 - ICE due to operands clobber in avr_out_sbxx_branch.
[official-gcc.git] / gcc / testsuite / gcc.dg / vect / tsvc / vect-tsvc-s4115.c
blobf85e75e4710f6e0edb9b37185a14727193010f55
1 /* This file is distributed under the University of Illinois Open Source
2 License. See license.txt for details. */
4 /* { dg-additional-options "--param vect-epilogues-nomask=0" } */
5 /* { dg-require-effective-target vect_float } */
7 #include "tsvc.h"
9 real_t s4115(struct args_t * func_args)
11 // indirect addressing
12 // sparse dot product
13 // gather is required
15 int * __restrict__ ip = func_args->arg_info;
17 initialise_arrays(__func__);
19 real_t sum;
20 for (int nl = 0; nl < iterations; nl++) {
21 sum = 0.;
22 for (int i = 0; i < LEN_1D; i++) {
23 sum += a[i] * b[ip[i]];
25 dummy(a, b, c, d, e, aa, bb, cc, 0.);
28 return sum;
31 int main (int argc, char **argv)
33 int n1 = 1;
34 int n3 = 1;
35 int* ip;
36 real_t s1,s2;
37 init(&ip, &s1, &s2);
39 run(&s4115, "s4115", ip);
41 return 0;
44 /* { dg-final { scan-tree-dump-times "vectorized 1 loops" 1 "vect" } } */