/* { dg-do compile } */ /* { dg-options "-march=rv32gc_zbb -mabi=ilp32 -O2" } */ unsigned int foo1(unsigned int rs1, unsigned int rs2) { unsigned int shamt = rs2 & (32 - 1); return (rs1 << shamt) | (rs1 >> ((32 - shamt) & (32 - 1))); } unsigned int foo2(unsigned int rs1, unsigned int rs2) { unsigned int shamt = rs2 & (32 - 1); return (rs1 >> shamt) | (rs1 << ((32 - shamt) & (32 - 1))); } /* { dg-final { scan-assembler-times "rol" 2 } } */ /* { dg-final { scan-assembler-times "ror" 2 } } */