aboutsummaryrefslogtreecommitdiff
path: root/riscv/insns/sra_u.h
blob: d7c395b0c4f55143f1b358d3a5b1c8811d7ba203 (plain)
1
2
3
4
5
6
7
8
9
require_extension(EXT_ZPN);
sreg_t rs1 = sext_xlen(RS1);
reg_t sa = get_field(RS2, make_mask64(0, xlen == 32 ? 5 : 6));

if (sa > 0) {
  WRITE_RD(sext_xlen(((rs1 >> (sa - 1)) + 1) >> 1));
} else {
  WRITE_RD(sext_xlen(rs1));
}