blob: 876129eb633160af113c2965605411181f8a0196 [file] [log] [blame]
/* { dg-do compile { target { lp64 } } } */
/* { dg-require-effective-target power10_ok } */
/* { dg-options "-O2 -mdejagnu-cpu=power10" } */
/* This tests whether GCC generates the ISA 3.1 BRW byte swap instruction for
GPR data, but generates XXBRW for data in a vector register. */
unsigned long long
bswap_ll (unsigned long long a)
{
return __builtin_bswap64 (a); /* { dg-final { scan-assembler {\mbrd\M} } } */
}
double
bswap_ll_dbl (unsigned long long a)
{
unsigned int b = a;
/* Force the value to be loaded into a vector register. */
__asm__ (" # %x0" : "+wa" (b));
/* { dg-final { scan-assembler {\mxxbrd\M} } } */
return (double) __builtin_bswap64 (b);
}