1 /* Verify that overloaded built-ins for vec_mule,vec_mulo with short
2    inputs produce the right results.  */
3 
4 /* { dg-do compile } */
5 /* { dg-require-effective-target powerpc_altivec_ok } */
6 /* { dg-options "-maltivec -O2" } */
7 
8 #include <altivec.h>
9 
10 vector signed int
test_even(vector signed short x,vector signed short y)11 test_even (vector signed short x, vector signed short y)
12 {
13   return vec_mule (x, y);
14 }
15 
16 vector unsigned int
test_uns_even(vector unsigned short x,vector unsigned short y)17 test_uns_even (vector unsigned short x, vector unsigned short y)
18 {
19   return vec_mule (x, y);
20 }
21 
22 vector signed int
test_odd(vector signed short x,vector signed short y)23 test_odd (vector signed short x, vector signed short y)
24 {
25   return vec_mulo (x, y);
26 }
27 
28 vector unsigned int
test_uns_odd(vector unsigned short x,vector unsigned short y)29 test_uns_odd (vector unsigned short x, vector unsigned short y)
30 {
31   return vec_mulo (x, y);
32 }
33 
34 /* { dg-final { scan-assembler-times "vmuleuh" 1 } } */
35 /* { dg-final { scan-assembler-times "vmulesh" 1 } } */
36 /* { dg-final { scan-assembler-times "vmulouh" 1 } } */
37 /* { dg-final { scan-assembler-times "vmulosh" 1 } } */
38