aboutsummaryrefslogtreecommitdiff
path: root/riscv/insns/pack.h
blob: 0622b92291b900872a9fb6b7643f2d17d72c6fa0 (plain)
1
2
3
4
5
6
7
// RV32Zbb contains zext.h but not general pack
require(((xlen == 32) && (insn.rs2() == 0) && p->extension_enabled(EXT_ZBB))
  || p->extension_enabled(EXT_ZPN)
  || 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));