summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.target/riscv/zbb-rol-ror-02.c
blob: d0d5813580922ca45b8dab28a4ce4f200bfd3320 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
/* { dg-do compile } */
/* { dg-options "-march=rv32gc_zbb -mabi=ilp32" } */
/* { dg-skip-if "" { *-*-* } { "-g" } } */

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 } } */
/* { dg-final { scan-assembler-not {and} { target { no-opts "-O0" } } } } */