| /* { 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} } } */ |