aboutsummaryrefslogtreecommitdiff
path: root/riscv/insns/c_lui.h
blob: 3e0e02f4e54480d6f25f981885a66f0aff2a7e2b (plain)
1
2
3
4
5
6
7
8
9
10
11
require_extension(EXT_ZCA);
if (insn.rvc_rd() == 2) { // c.addi16sp
  require(insn.rvc_addi16sp_imm() != 0);
  WRITE_REG(X_SP, sext_xlen(RVC_SP + insn.rvc_addi16sp_imm()));
} else if (insn.rvc_imm() != 0) { // c.lui
  WRITE_RD(insn.rvc_imm() << 12);
} else if ((insn.rvc_rd() & 1) != 0) { // c.mop.N
  #include "c_mop_N.h"
} else {
  require(false);
}