File: vect-gather-1.c

package info (click to toggle)
gcc-arm-none-eabi 15%3A12.2.rel1-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 959,712 kB
  • sloc: cpp: 3,275,382; ansic: 2,061,766; ada: 840,956; f90: 208,513; makefile: 76,132; asm: 73,433; xml: 50,448; exp: 34,146; sh: 32,436; objc: 15,637; fortran: 14,012; python: 11,991; pascal: 6,787; awk: 4,779; perl: 3,054; yacc: 338; ml: 285; lex: 201; haskell: 122
file content (20 lines) | stat: -rw-r--r-- 771 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
/* { dg-do compile } */
/* Profitable from Power8 since it supports efficient unaligned load.  */
/* { dg-options "-Ofast -mdejagnu-cpu=power8 -fdump-tree-vect-details -fdump-tree-forwprop4" } */

#ifndef INDEXTYPE
#define INDEXTYPE unsigned int
#endif
double vmul(INDEXTYPE *rowstart, INDEXTYPE *rowend,
	    double *luval, double *dst)
{
  double res = 0;
  for (const INDEXTYPE * col = rowstart; col != rowend; ++col, ++luval)
        res += *luval * dst[*col];
  return res;
}

/* With gather emulation this should be profitable to vectorize from Power8.  */
/* { dg-final { scan-tree-dump "loop vectorized" "vect" } } */
/* The index vector loads and promotions should be scalar after forwprop.  */
/* { dg-final { scan-tree-dump-not "vec_unpack" "forwprop4" } } */