(root)/
gcc-13.2.0/
gcc/
testsuite/
gcc.target/
riscv/
zbs-bseti-02.c
       1  /* { dg-do compile } */
       2  /* { dg-options "-march=rv64gc_zbs -mabi=lp64" } */
       3  /* { dg-skip-if "" { *-*-* } { "-O0" "-Og" } } */
       4  
       5  /* bexti */
       6  int f(int* a, int b)
       7  {
       8    return ((*a << b) | (1 << 14));
       9  }
      10  
      11  int g(int a, int b)
      12  {
      13    return ((a + b)| (1 << 30));
      14  }
      15  
      16  int h(int a, int b)
      17  {
      18    return ((a + b)| (1ULL << 33));
      19  }
      20  
      21  /* { dg-final { scan-assembler-times "addw\t" 2 } } */
      22  /* { dg-final { scan-assembler-times "sllw\t" 1 } } */
      23  /* { dg-final { scan-assembler-times "bseti\t" 2 } } */
      24  /* { dg-final { scan-assembler-not "sext.w\t" } } */
      25