summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.dg/vect/costmodel/ppc/costmodel-slp-34.c
blob: c092848dfc9d093e6fc78ce171bb4c1f59a0cf85 (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
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
/* { dg-require-effective-target vect_int } */
/* { dg-skip-if "cost too high" { powerpc*le-*-* } } */

#include <stdarg.h>
#include "../../tree-vect.h"

struct mystr {
  int f1;
  int f2;
};

struct mystr af[16] = {
  10, 11, 12, 13, 14, 15, 16, 17,
  20, 21, 22, 23, 24, 25, 26, 27,
  30, 31, 32, 33, 34, 35, 36, 37,
  40, 41, 42, 43, 44, 45, 46, 47
};

struct mystr bf[16] = {
  12, 13, 14, 15, 16, 17, 18, 19,
  22, 23, 24, 25, 26, 27, 28, 29,
  32, 33, 34, 35, 36, 37, 38, 39,
  42, 43, 44, 45, 46, 47, 48, 49
};

struct mystr cf[16];

int res1[16] = {
  22, 26, 30, 34, 42, 46, 50, 54,
  62, 66, 70, 74, 82, 86, 90, 94,
};

int res2[16] = {
  24, 28, 32, 36, 44, 48, 52, 56,
  64, 68, 72, 76, 84, 88, 92, 96,
};

__attribute__ ((noinline)) void
foo (void)
{
  int i;

  for (i = 0; i < 16; i++)
  {
    cf[i].f1 = af[i].f1 + bf[i].f1;
    cf[i].f2 = af[i].f2 + bf[i].f2;
  }
}



int
main (void)
{ 
  int i;

  check_vect ();
  foo ();

  /* Check resiults. */ 
  for (i = 0; i < 16; i++)
    {
      if (cf[i].f1 != res1[i])
	abort ();
      if (cf[i].f2 != res2[i])
        abort ();

    }
  return 0;
} 

/* { dg-final { scan-tree-dump-times "vectorization not profitable" 0 "vect" } } */
/* { dg-final { scan-tree-dump-times "vectorized 1 loops" 1 "vect" } } */
/* { dg-final { scan-tree-dump-times "vectorizing stmts using SLP" 1 "vect"  } } */