| /* { dg-do compile { target lp64 } } */ |
| /* { dg-require-effective-target powerpc_p9vector_ok } */ |
| /* { dg-options "-mdejagnu-cpu=power9 -O2" } */ |
| |
| #include <altivec.h> |
| |
| vector int |
| insert_0_0 (vector int v) |
| { |
| return vec_insert (0, v, 0); |
| } |
| |
| vector int |
| insert_m1_1 (vector int v) |
| { |
| return vec_insert (-1, v, 1); |
| } |
| |
| vector int |
| insert_5_2 (vector int v) |
| { |
| return vec_insert (5, v, 2); |
| } |
| |
| vector int |
| insert_mem_3 (vector int v, int *p) |
| { |
| return vec_insert (*p, v, 3); |
| } |
| |
| /* { dg-final { scan-assembler "xxinsertw" } } */ |
| /* { dg-final { scan-assembler "xxspltib" } } */ |
| /* { dg-final { scan-assembler "vspltisw" } } */ |
| /* { dg-final { scan-assembler-not "mtvsrd" } } */ |
| /* { dg-final { scan-assembler-not "mtvsrdd" } } */ |
| /* { dg-final { scan-assembler-not "mtvsrwa" } } */ |
| /* { dg-final { scan-assembler-not "mtvsrwz" } } */ |
| /* { dg-final { scan-assembler-not "mfvsrd" } } */ |
| /* { dg-final { scan-assembler-not "mfvsrwz" } } */ |