1 /* Verify that overloaded built-ins for vec_orc and vec_nand with short
2 * inputs produce the right results. These intrinsics (vec_orc,
3 * vec_nand) were added as part of ISA 2.07 (P8). */
5 /* { dg-do compile } */
6 /* { dg-require-effective-target powerpc_vsx_ok } */
7 /* { dg-options "-mvsx -O1" } */
8 /* { dg-additional-options "-mdejagnu-cpu=power8" { target { ! has_arch_pwr8 } } } */
13 test1_orc (vector
bool short x
, vector
signed short y
)
15 vector
signed short *foo
;
16 *foo
+= vec_orc (x
, y
);
21 test1_nand (vector
bool short x
, vector
signed short y
)
23 vector
signed short *foo
;
24 *foo
+= vec_nand (x
, y
);
29 test2_orc (vector
signed short x
, vector
bool short y
)
31 vector
signed short *foo
;
32 *foo
+= vec_orc (x
, y
);
37 test2_nand (vector
signed short x
, vector
bool short y
)
39 vector
signed short *foo
;
40 *foo
+= vec_nand (x
, y
);
45 test3_orc (vector
signed short x
, vector
signed short y
)
47 vector
signed short *foo
;
48 *foo
+= vec_orc (x
, y
);
53 test3_nand (vector
signed short x
, vector
signed short y
)
55 vector
signed short *foo
;
56 *foo
+= vec_nand (x
, y
);
61 test4_orc (vector
bool short x
, vector
unsigned short y
)
63 vector
unsigned short *foo
;
64 *foo
+= vec_orc (x
, y
);
69 test4_nand (vector
bool short x
, vector
unsigned short y
)
71 vector
unsigned short *foo
;
72 *foo
+= vec_nand (x
, y
);
77 test5_orc (vector
unsigned short x
, vector
bool short y
)
79 vector
unsigned short *foo
;
80 *foo
+= vec_orc (x
, y
);
85 test5_nand (vector
unsigned short x
, vector
bool short y
)
87 vector
unsigned short *foo
;
88 *foo
+= vec_nand (x
, y
);
93 test6_orc (vector
unsigned short x
, vector
unsigned short y
)
95 vector
unsigned short *foo
;
96 *foo
+= vec_orc (x
, y
);
100 vector
unsigned short
101 test6_nand (vector
unsigned short x
, vector
unsigned short y
)
103 vector
unsigned short *foo
;
104 *foo
+= vec_nand (x
, y
);
108 /* { dg-final { scan-assembler-times {\mxxlnand\M} 6 } } */
109 /* { dg-final { scan-assembler-times {\mxxlorc\M} 6 } } */