| /* { dg-options "-mdejagnu-cpu=power10" } */ |
| /* { dg-additional-options "-mbig" { target powerpc64le-*-* } } */ |
| |
| #include <altivec.h> |
| |
| extern void abort (void); |
| |
| int |
| main (int argc, char *argv []) |
| { |
| vector unsigned long long source_a = { 0, 14 }; |
| vector unsigned long long source_b = { 16, 30 }; |
| |
| vector unsigned long long int result_1 = { 0, 14 }; |
| vector unsigned long long int result_2 = { 0, 16 }; |
| vector unsigned long long int result_3 = { 0, 30 }; |
| vector unsigned long long int result_4 = { 0, 0 }; |
| |
| if (!vec_all_eq (vec_extractl (source_a, source_b, 8), result_1)) |
| abort (); |
| if (!vec_all_eq (vec_extractl (source_a, source_b, 16), result_2)) |
| abort (); |
| if (!vec_all_eq (vec_extractl (source_b, source_a, 8), result_3)) |
| abort (); |
| if (!vec_all_eq (vec_extractl (source_b, source_a, 16), result_4)) |
| abort (); |
| |
| return 0; |
| } |
| |
| /* { dg-final { scan-assembler {\mvextddvlx\M} } } */ |