(root)/
gcc-13.2.0/
gcc/
testsuite/
gcc.target/
riscv/
zbb-rol-ror-02.c
       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 } } */