1 /* { dg-do run { target powerpc*-*-darwin* } } */
2 /* { dg-options "-faltivec" } */
4 /* Program to test PowerPC AltiVec instructions. */
6 #include "altivec_check.h"
8 extern void abort (void);
9 #define CHECK_IF(E) if(!(E)) abort()
11 vector
int a1
= (vector
int){ 100, 200, 300, 400 };
12 vector
int a2
= (vector
int){ 500, 600, 700, 800 };
13 vector
int addi
= (vector
int){ 600, 800, 1000, 1200 };
14 vector
int avgi
= (vector
int){ 300, 400, 500, 600 };
16 vector
float f1
= (vector
float){ 1.0, 2.0, 3.0, 4.0 };
17 vector
float f2
= (vector
float){ 5.0, 6.0, 7.0, 8.0 };
19 vector
float addf1
= (vector
float){ 6.0, 8.0, 10.0, 12.0 };
20 vector
float addf2
= (vector
float){ 6.1, 8.1, 10.1, 12.1 };
21 vector
float addf3
= (vector
float){ 6.0, 8.0, 9.9, 12.1 };
28 altivec_check(); /* Exit if AltiVec not available. */
31 CHECK_IF (vec_all_eq (addi
, k
));
32 CHECK_IF (vec_all_ge (addi
, k
));
33 CHECK_IF (vec_all_le (addi
, k
));
34 CHECK_IF (vec_any_eq (addi
, k
));
35 CHECK_IF (vec_any_ge (addi
, k
));
36 CHECK_IF (vec_any_le (addi
, k
));
37 CHECK_IF (!vec_any_ne (addi
, k
));
38 CHECK_IF (!vec_any_lt (addi
, k
));
39 CHECK_IF (!vec_any_gt (addi
, k
));
40 CHECK_IF (!vec_any_ne (addi
, k
));
41 CHECK_IF (!vec_any_lt (addi
, k
));
42 CHECK_IF (!vec_any_gt (addi
, k
));
45 CHECK_IF (vec_all_eq (k
, avgi
));
48 CHECK_IF (vec_all_eq (h
, addf1
));
49 CHECK_IF (vec_all_ge (h
, addf1
));
50 CHECK_IF (vec_all_le (h
, addf1
));
51 CHECK_IF (vec_any_eq (h
, addf1
));
52 CHECK_IF (vec_any_ge (h
, addf1
));
53 CHECK_IF (vec_any_le (h
, addf1
));
54 CHECK_IF (!vec_any_ne (h
, addf1
));
55 CHECK_IF (!vec_any_lt (h
, addf1
));
56 CHECK_IF (!vec_any_gt (h
, addf1
));
57 CHECK_IF (!vec_any_ne (h
, addf1
));
58 CHECK_IF (!vec_any_lt (h
, addf1
));
59 CHECK_IF (!vec_any_gt (h
, addf1
));
61 CHECK_IF (vec_all_gt (addf2
, addf1
));
62 CHECK_IF (vec_any_gt (addf2
, addf1
));
63 CHECK_IF (vec_all_ge (addf2
, addf1
));
64 CHECK_IF (vec_any_ge (addf2
, addf1
));
65 CHECK_IF (vec_all_ne (addf2
, addf1
));
66 CHECK_IF (vec_any_ne (addf2
, addf1
));
67 CHECK_IF (!vec_all_lt (addf2
, addf1
));
68 CHECK_IF (!vec_any_lt (addf2
, addf1
));
69 CHECK_IF (!vec_all_le (addf2
, addf1
));
70 CHECK_IF (!vec_any_le (addf2
, addf1
));
71 CHECK_IF (!vec_all_eq (addf2
, addf1
));
72 CHECK_IF (!vec_any_eq (addf2
, addf1
));
74 CHECK_IF (vec_any_eq (addf3
, addf1
));
75 CHECK_IF (vec_any_ne (addf3
, addf1
));
76 CHECK_IF (vec_any_lt (addf3
, addf1
));
77 CHECK_IF (vec_any_le (addf3
, addf1
));
78 CHECK_IF (vec_any_gt (addf3
, addf1
));
79 CHECK_IF (vec_any_ge (addf3
, addf1
));
80 CHECK_IF (!vec_all_eq (addf3
, addf1
));
81 CHECK_IF (!vec_all_ne (addf3
, addf1
));
82 CHECK_IF (!vec_all_lt (addf3
, addf1
));
83 CHECK_IF (!vec_all_le (addf3
, addf1
));
84 CHECK_IF (!vec_all_gt (addf3
, addf1
));
85 CHECK_IF (!vec_all_ge (addf3
, addf1
));
87 CHECK_IF (vec_all_numeric (addf3
));
88 CHECK_IF (vec_all_in (addf1
, addf2
));
90 CHECK_IF (vec_step (vector
bool char) == 16);
91 CHECK_IF (vec_step (addf3
) == 4);