summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.dg/tree-ssa/vector-6.c
blob: 785e5dfe424c755e511857b8ddc3bfb46d50fa8c (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
/* { dg-do compile } */
/* { dg-options "-O -fdump-tree-ccp1 -Wno-psabi -w" } */
/* { dg-additional-options "-msse2" { target i?86-*-* x86_64-*-* } } */
/* { dg-additional-options "-maltivec" { target powerpc_altivec_ok } } */

typedef int v4si __attribute__((vector_size (4 * sizeof (int))));

v4si test1 (v4si v, int i)
{
  ((int *)&v)[0] = i;
  return v;
}

v4si test2 (v4si v, int i)
{
  int *p = (int *)&v;
  *p = i;
  return v;
}

v4si test3 (v4si v, int i)
{
  ((int *)&v)[3] = i;
  return v;
}

v4si test4 (v4si v, int i)
{
  int *p = (int *)&v;
  p += 3;
  *p = i;
  return v;
}

/* { dg-final { scan-tree-dump-times "Now a gimple register: v" 4 "ccp1" { target { { i?86-*-* x86_64-*-* aarch64*-*-* spu*-*-* } || { powerpc_altivec_ok } } } } } */