aboutsummaryrefslogtreecommitdiff
path: root/riscv/insns/psshlr_dws.h
blob: 483d9d41b116cd11786d6d64b8d144774ea419eb (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
require_rv32;
sreg_t sshamt = P_FIELD(RS2, 0, 8);
P_RD_RS1_DW_LOOP(32, 32, {
  if (sshamt < 0) {
    uint64_t shx;
    if (sshamt < -32)
      shx = 0;
    else if (sshamt == -32)
      shx = ((uint32_t)p_rs1 >> 31) & 1;
    else
      shx = ((uint64_t)(uint32_t)p_rs1 << 1) >> (-sshamt);
    p_rd = (uint32_t)((shx + 1) >> 1);
  } else {
    uint64_t shx = (sshamt >= 32) ? ((uint64_t)(uint32_t)p_rs1 << 32) : ((uint64_t)(uint32_t)p_rs1 << sshamt);
    if (shx > 0xFFFFFFFFULL) {
      P.VU.vxsat->write(1);
      p_rd = 0xFFFFFFFF;
    } else {
      p_rd = (uint32_t)shx;
    }
  }
})