27 lines
938 B
C
27 lines
938 B
C
|
/* { dg-do compile } */
|
||
|
/* { dg-require-effective-target power10_ok } */
|
||
|
/* { dg-options "-mdejagnu-cpu=power10 -O2" } */
|
||
|
|
||
|
void
|
||
|
foo (__vector_pair *dst, __vector_pair *src, long idx)
|
||
|
{
|
||
|
dst[0] = __builtin_vsx_lxvp (0, src);
|
||
|
dst[2] = __builtin_vsx_lxvp (32, src);
|
||
|
dst[4] = __builtin_vsx_lxvp (64, src);
|
||
|
/* Non-constant offset should generate a lxvpx. */
|
||
|
dst[6] = __builtin_vsx_lxvp (idx, src);
|
||
|
/* Non-aligned offset should generate a plxvp. */
|
||
|
dst[8] = __builtin_vsx_lxvp (257, src);
|
||
|
}
|
||
|
|
||
|
#if !__has_builtin (__builtin_vsx_lxvp)
|
||
|
# error "__has_builtin (__builtin_vsx_lxvp) failed"
|
||
|
#endif
|
||
|
|
||
|
/* { dg-final { scan-assembler-not {\mlxv\M} } } */
|
||
|
/* { dg-final { scan-assembler-not {\mstxv\M} } } */
|
||
|
/* { dg-final { scan-assembler-times {\mlxvp\M} 3 } } */
|
||
|
/* { dg-final { scan-assembler-times {\mlxvpx\M} 1 } } */
|
||
|
/* { dg-final { scan-assembler-times {\mplxvp\M} 1 } } */
|
||
|
/* { dg-final { scan-assembler-times {\mstxvp\M} 5 } } */
|