aboutsummaryrefslogtreecommitdiff
path: root/riscv/insns/pack.h
blob: acc49877ab7b4c68b10a932f4d44719709ddf6be (plain)
1
2
3
4
5
6
// RV32Zbb contains zext.h but not general pack
require(((xlen == 32) && (insn.rs2() == 0) && p->extension_enabled(EXT_ZBB))
  || p->extension_enabled(EXT_ZBKB));
reg_t lo = zext_xlen(RS1 << (xlen/2)) >> (xlen/2);
reg_t hi = zext_xlen(RS2 << (xlen/2));
WRITE_RD(sext_xlen(lo | hi));