blob: 527f2cffe8dd55437289af1be5dee252990f0bb9 (
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
|
/* { dg-do compile { target { powerpc*-*-* && lp64 } } } */
/* { dg-skip-if "" { powerpc*-*-darwin* } } */
/* { dg-require-effective-target powerpc_p8vector_ok } */
/* { dg-options "-O2 -mdejagnu-cpu=power8" } */
#include <altivec.h>
int
add_int_0 (vector int *p)
{
return vec_extract (*p, 0) + 1;
}
int
add_int_1 (vector int *p)
{
return vec_extract (*p, 1) + 1;
}
int
add_int_2 (vector int *p)
{
return vec_extract (*p, 2) + 1;
}
int
add_int_3 (vector int *p)
{
return vec_extract (*p, 3) + 1;
}
int
add_int_n (vector int *p, int n)
{
return vec_extract (*p, n) + 1;
}
/* { dg-final { scan-assembler-not "lxvd2x" } } */
/* { dg-final { scan-assembler-not "lxvw4x" } } */
/* { dg-final { scan-assembler-not "lxvx" } } */
/* { dg-final { scan-assembler-not "lxv" } } */
/* With recent enhancements to the code generator, it is considered
* legal to implement vec_extract with lvx and xxpermdi. Previous
* versions of this test forbid both instructions. */
|