1 /* { dg-do compile { target { powerpc*-*-* && lp64 } } } */
2 /* { dg-skip-if "" { powerpc*-*-darwin* } { "*" } { "" } } */
3 /* { dg-require-effective-target powerpc_vsx_ok } */
4 /* { dg-options "-mvsx -O2" } */
5
6 #include <altivec.h>
7
foo(vector double * out,vector double * in,vector long * p_l,vector bool long * p_b,vector unsigned char * p_uc,int * i)8 void foo (vector double *out, vector double *in, vector long *p_l, vector bool long *p_b, vector unsigned char *p_uc, int *i)
9 {
10 vector double in0 = in[0];
11 vector double in1 = in[1];
12 vector double in2 = in[2];
13 vector long inl = *p_l;
14 vector bool long inb = *p_b;
15 vector unsigned char uc = *p_uc;
16
17 *out++ = vec_abs (in0);
18 *out++ = vec_add (in0, in1);
19 *out++ = vec_and (in0, in1);
20 *out++ = vec_and (in0, inb);
21 *out++ = vec_and (inb, in0);
22 *out++ = vec_andc (in0, in1);
23 *out++ = vec_andc (in0, inb);
24 *out++ = vec_andc (inb, in0);
25 *out++ = vec_ceil (in0);
26 *p_b++ = vec_cmpeq (in0, in1);
27 *p_b++ = vec_cmpgt (in0, in1);
28 *p_b++ = vec_cmpge (in0, in1);
29 *p_b++ = vec_cmplt (in0, in1);
30 *p_b++ = vec_cmple (in0, in1);
31 *out++ = vec_div (in0, in1);
32 *out++ = vec_floor (in0);
33 *out++ = vec_madd (in0, in1, in2);
34 *out++ = vec_msub (in0, in1, in2);
35 *out++ = vec_max (in0, in1);
36 *out++ = vec_min (in0, in1);
37 *out++ = vec_msub (in0, in1, in2);
38 *out++ = vec_mul (in0, in1);
39 *out++ = vec_nearbyint (in0);
40 *out++ = vec_nmadd (in0, in1, in2);
41 *out++ = vec_nmsub (in0, in1, in2);
42 *out++ = vec_nor (in0, in1);
43 *out++ = vec_or (in0, in1);
44 *out++ = vec_or (in0, inb);
45 *out++ = vec_or (inb, in0);
46 *out++ = vec_perm (in0, in1, uc);
47 *out++ = vec_rint (in0);
48 *out++ = vec_sel (in0, in1, inl);
49 *out++ = vec_sel (in0, in1, inb);
50 *out++ = vec_sub (in0, in1);
51 *out++ = vec_sqrt (in0);
52 *out++ = vec_trunc (in0);
53 *out++ = vec_xor (in0, in1);
54 *out++ = vec_xor (in0, inb);
55 *out++ = vec_xor (inb, in0);
56
57 *i++ = vec_all_eq (in0, in1);
58 *i++ = vec_all_ge (in0, in1);
59 *i++ = vec_all_gt (in0, in1);
60 *i++ = vec_all_le (in0, in1);
61 *i++ = vec_all_lt (in0, in1);
62 *i++ = vec_all_nan (in0);
63 *i++ = vec_all_ne (in0, in1);
64 *i++ = vec_all_nge (in0, in1);
65 *i++ = vec_all_ngt (in0, in1);
66 *i++ = vec_all_nle (in0, in1);
67 *i++ = vec_all_nlt (in0, in1);
68 *i++ = vec_all_numeric (in0);
69 *i++ = vec_any_eq (in0, in1);
70 *i++ = vec_any_ge (in0, in1);
71 *i++ = vec_any_gt (in0, in1);
72 *i++ = vec_any_le (in0, in1);
73 *i++ = vec_any_lt (in0, in1);
74 *i++ = vec_any_nan (in0);
75 *i++ = vec_any_ne (in0, in1);
76 *i++ = vec_any_nge (in0, in1);
77 *i++ = vec_any_ngt (in0, in1);
78 *i++ = vec_any_nle (in0, in1);
79 *i++ = vec_any_nlt (in0, in1);
80 *i++ = vec_any_numeric (in0);
81 }
82