aboutsummaryrefslogtreecommitdiff
path: root/riscv/insns/kslraw_u.h
blob: e1c53eef444e752e21388155741087ec590583fb (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
require_extension('P');
sreg_t rs1 = sext32(RS1);
sreg_t sa = int64_t(RS2) << (64 - 6) >> (64 - 6);

if (sa < 0) {
  sa = -sa;
  sa = (sa == 32) ? 31 : sa;
  WRITE_RD(sext32(((rs1 >> (sa - 1)) + 1)) >> 1);
} else {
  auto res = rs1 << sa;
  P_SAT(res, 32);
  WRITE_RD(sext32(res));
}