blob: ff75dad65285926c56df90e76512cb82aea5fa85 [file] [log] [blame]
/* { dg-do compile } */
/* { dg-options "-march=rv64gc_zbs -mabi=lp64" } */
/* { dg-skip-if "" { *-*-* } { "-O0" "-Og" } } */
/* bext */
long
foo0 (long i, long j)
{
return 1L & (i >> j);
}
/* bexti */
long
foo1 (long i)
{
return 1L & (i >> 20);
}
long bext64_1(long a, char bitno)
{
return (a & (1UL << bitno)) ? 1 : 0;
}
long bext64_2(long a, char bitno)
{
return (a & (1UL << bitno)) ? 0 : 1;
}
long bext64_3(long a, char bitno)
{
return (a & (1UL << bitno)) ? 0 : -1;
}
long bext64_4(long a, char bitno)
{
return (a & (1UL << bitno)) ? -1 : 0;
}
/* { dg-final { scan-assembler-times "bexti\t" 1 } } */
/* { dg-final { scan-assembler-times "bext\t" 5 } } */
/* { dg-final { scan-assembler-times "xori\t|snez\t" 1 } } */
/* { dg-final { scan-assembler-times "addi\t" 1 } } */
/* { dg-final { scan-assembler-times "neg\t" 1 } } */
/* { dg-final { scan-assembler-not {\mandi} } } */