Spike, a RISC-V ISA Simulator
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

24 lines
566 B

// See LICENSE for license details.
#include "config.h"
#include "processor.h"
#include "mmu.h"
#include "hwacha.h"
#include "decode_hwacha.h"
#include "rocc.h"
#include <assert.h>
reg_t hwacha_NAME(processor_t* p, insn_t insn, reg_t pc)
{
int xprlen = 64;
reg_t npc = sext_xprlen(pc + insn_length(OPCODE));
hwacha_t* h = static_cast<hwacha_t*>(p->get_extension());
rocc_insn_union_t u;
u.i = insn;
reg_t xs1 = u.r.xs1 ? RS1 : -1;
reg_t xs2 = u.r.xs2 ? RS2 : -1;
reg_t xd = -1;
#include "insns/NAME.h"
if (u.r.xd) WRITE_RD(xd);
return npc;
}