1 /* { dg-do compile } */
2 /* { dg-options "-march=rv32gc_zbb -mabi=ilp32" } */
3 /* { dg-skip-if "" { *-*-* } { "-g" } } */
4
5 unsigned int foo1(unsigned int rs1, unsigned int rs2)
6 {
7 unsigned int shamt = rs2 & (32 - 1);
8 return (rs1 << shamt) | (rs1 >> ((32 - shamt) & (32 - 1)));
9 }
10 unsigned int foo2(unsigned int rs1, unsigned int rs2)
11 {
12 unsigned int shamt = rs2 & (32 - 1);
13 return (rs1 >> shamt) | (rs1 << ((32 - shamt) & (32 - 1)));
14 }
15
16 /* { dg-final { scan-assembler-times "rol" 2 } } */
17 /* { dg-final { scan-assembler-times "ror" 2 } } */