Compare commits
No commits in common. "70839bbbf2ffd76e9bb8c00edf6c4b0d361139b0" and "212fb1c8fff472723295a561dde59ab75ae069d2" have entirely different histories.
70839bbbf2
...
212fb1c8ff
86
gen_input/templates/CORENAME_decoder.cpp.gtl
Normal file
86
gen_input/templates/CORENAME_decoder.cpp.gtl
Normal file
@ -0,0 +1,86 @@
|
|||||||
|
#include "${coreDef.name.toLowerCase()}.h"
|
||||||
|
#include <vector>
|
||||||
|
#include <array>
|
||||||
|
#include <cstdlib>
|
||||||
|
#include <algorithm>
|
||||||
|
|
||||||
|
namespace iss {
|
||||||
|
namespace arch {
|
||||||
|
namespace {
|
||||||
|
// according to
|
||||||
|
// https://stackoverflow.com/questions/8871204/count-number-of-1s-in-binary-representation
|
||||||
|
#ifdef __GCC__
|
||||||
|
constexpr size_t bit_count(uint32_t u) { return __builtin_popcount(u); }
|
||||||
|
#elif __cplusplus < 201402L
|
||||||
|
constexpr size_t uCount(uint32_t u) { return u - ((u >> 1) & 033333333333) - ((u >> 2) & 011111111111); }
|
||||||
|
constexpr size_t bit_count(uint32_t u) { return ((uCount(u) + (uCount(u) >> 3)) & 030707070707) % 63; }
|
||||||
|
#else
|
||||||
|
constexpr size_t bit_count(uint32_t u) {
|
||||||
|
size_t uCount = u - ((u >> 1) & 033333333333) - ((u >> 2) & 011111111111);
|
||||||
|
return ((uCount + (uCount >> 3)) & 030707070707) % 63;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
using opcode_e = traits<${coreDef.name.toLowerCase()}>::opcode_e;
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* start opcode definitions
|
||||||
|
****************************************************************************/
|
||||||
|
struct instruction_desriptor {
|
||||||
|
size_t length;
|
||||||
|
uint32_t value;
|
||||||
|
uint32_t mask;
|
||||||
|
opcode_e op;
|
||||||
|
};
|
||||||
|
|
||||||
|
const std::array<instruction_desriptor, ${instructions.size}> instr_descr = {{
|
||||||
|
/* entries are: size, valid value, valid mask, function ptr */<%instructions.each{instr -> %>
|
||||||
|
{${instr.length}, ${instr.encoding}, ${instr.mask}, opcode_e::${instr.instruction.name}},<%}%>
|
||||||
|
}};
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
template<>
|
||||||
|
struct instruction_decoder<${coreDef.name.toLowerCase()}> {
|
||||||
|
using opcode_e = traits<${coreDef.name.toLowerCase()}>::opcode_e;
|
||||||
|
using code_word_t=traits<${coreDef.name.toLowerCase()}>::code_word_t;
|
||||||
|
|
||||||
|
struct instruction_pattern {
|
||||||
|
uint32_t value;
|
||||||
|
uint32_t mask;
|
||||||
|
opcode_e id;
|
||||||
|
};
|
||||||
|
|
||||||
|
std::array<std::vector<instruction_pattern>, 4> qlut;
|
||||||
|
|
||||||
|
template<typename T>
|
||||||
|
unsigned decode_instruction(T);
|
||||||
|
|
||||||
|
instruction_decoder() {
|
||||||
|
for (auto instr : instr_descr) {
|
||||||
|
auto quadrant = instr.value & 0x3;
|
||||||
|
qlut[quadrant].push_back(instruction_pattern{instr.value, instr.mask, instr.op});
|
||||||
|
}
|
||||||
|
for(auto& lut: qlut){
|
||||||
|
std::sort(std::begin(lut), std::end(lut), [](instruction_pattern const& a, instruction_pattern const& b){
|
||||||
|
return bit_count(a.mask) < bit_count(b.mask);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
template<>
|
||||||
|
unsigned instruction_decoder<${coreDef.name.toLowerCase()}>::decode_instruction<traits<${coreDef.name.toLowerCase()}>::code_word_t>(traits<${coreDef.name.toLowerCase()}>::code_word_t instr){
|
||||||
|
auto res = std::find_if(std::begin(qlut[instr&0x3]), std::end(qlut[instr&0x3]), [instr](instruction_pattern const& e){
|
||||||
|
return !((instr&e.mask) ^ e.value );
|
||||||
|
});
|
||||||
|
return static_cast<unsigned>(res!=std::end(qlut[instr&0x3])? res->id : opcode_e::MAX_OPCODE);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
std::unique_ptr<instruction_decoder<${coreDef.name.toLowerCase()}>> traits<${coreDef.name.toLowerCase()}>::get_decoder(){
|
||||||
|
return std::make_unique<instruction_decoder<${coreDef.name.toLowerCase()}>>();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
@ -305,8 +305,6 @@ template <typename ARCH> void vm_impl<ARCH>::gen_wait(tu_builder& tu, unsigned t
|
|||||||
}
|
}
|
||||||
|
|
||||||
template <typename ARCH> void vm_impl<ARCH>::gen_trap_behavior(tu_builder& tu) {
|
template <typename ARCH> void vm_impl<ARCH>::gen_trap_behavior(tu_builder& tu) {
|
||||||
tu("trap_entry_plugin:");
|
|
||||||
this->gen_sync(tu, POST_SYNC, -1);
|
|
||||||
tu("trap_entry:");
|
tu("trap_entry:");
|
||||||
tu("enter_trap(core_ptr, *trap_state, *pc, 0);");
|
tu("enter_trap(core_ptr, *trap_state, *pc, 0);");
|
||||||
tu.store(traits::LAST_BRANCH, tu.constant(std::numeric_limits<uint32_t>::max(),32));
|
tu.store(traits::LAST_BRANCH, tu.constant(std::numeric_limits<uint32_t>::max(),32));
|
||||||
|
175
src/iss/arch/tgc_c_decoder.cpp
Normal file
175
src/iss/arch/tgc_c_decoder.cpp
Normal file
@ -0,0 +1,175 @@
|
|||||||
|
#include "tgc_c.h"
|
||||||
|
#include <vector>
|
||||||
|
#include <array>
|
||||||
|
#include <cstdlib>
|
||||||
|
#include <algorithm>
|
||||||
|
|
||||||
|
namespace iss {
|
||||||
|
namespace arch {
|
||||||
|
namespace {
|
||||||
|
// according to
|
||||||
|
// https://stackoverflow.com/questions/8871204/count-number-of-1s-in-binary-representation
|
||||||
|
#ifdef __GCC__
|
||||||
|
constexpr size_t bit_count(uint32_t u) { return __builtin_popcount(u); }
|
||||||
|
#elif __cplusplus < 201402L
|
||||||
|
constexpr size_t uCount(uint32_t u) { return u - ((u >> 1) & 033333333333) - ((u >> 2) & 011111111111); }
|
||||||
|
constexpr size_t bit_count(uint32_t u) { return ((uCount(u) + (uCount(u) >> 3)) & 030707070707) % 63; }
|
||||||
|
#else
|
||||||
|
constexpr size_t bit_count(uint32_t u) {
|
||||||
|
size_t uCount = u - ((u >> 1) & 033333333333) - ((u >> 2) & 011111111111);
|
||||||
|
return ((uCount + (uCount >> 3)) & 030707070707) % 63;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
using opcode_e = traits<tgc_c>::opcode_e;
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* start opcode definitions
|
||||||
|
****************************************************************************/
|
||||||
|
struct instruction_desriptor {
|
||||||
|
size_t length;
|
||||||
|
uint32_t value;
|
||||||
|
uint32_t mask;
|
||||||
|
opcode_e op;
|
||||||
|
};
|
||||||
|
|
||||||
|
const std::array<instruction_desriptor, 90> instr_descr = {{
|
||||||
|
/* entries are: size, valid value, valid mask, function ptr */
|
||||||
|
{32, 0b00000000000000000000000000110111, 0b00000000000000000000000001111111, opcode_e::LUI},
|
||||||
|
{32, 0b00000000000000000000000000010111, 0b00000000000000000000000001111111, opcode_e::AUIPC},
|
||||||
|
{32, 0b00000000000000000000000001101111, 0b00000000000000000000000001111111, opcode_e::JAL},
|
||||||
|
{32, 0b00000000000000000000000001100111, 0b00000000000000000111000001111111, opcode_e::JALR},
|
||||||
|
{32, 0b00000000000000000000000001100011, 0b00000000000000000111000001111111, opcode_e::BEQ},
|
||||||
|
{32, 0b00000000000000000001000001100011, 0b00000000000000000111000001111111, opcode_e::BNE},
|
||||||
|
{32, 0b00000000000000000100000001100011, 0b00000000000000000111000001111111, opcode_e::BLT},
|
||||||
|
{32, 0b00000000000000000101000001100011, 0b00000000000000000111000001111111, opcode_e::BGE},
|
||||||
|
{32, 0b00000000000000000110000001100011, 0b00000000000000000111000001111111, opcode_e::BLTU},
|
||||||
|
{32, 0b00000000000000000111000001100011, 0b00000000000000000111000001111111, opcode_e::BGEU},
|
||||||
|
{32, 0b00000000000000000000000000000011, 0b00000000000000000111000001111111, opcode_e::LB},
|
||||||
|
{32, 0b00000000000000000001000000000011, 0b00000000000000000111000001111111, opcode_e::LH},
|
||||||
|
{32, 0b00000000000000000010000000000011, 0b00000000000000000111000001111111, opcode_e::LW},
|
||||||
|
{32, 0b00000000000000000100000000000011, 0b00000000000000000111000001111111, opcode_e::LBU},
|
||||||
|
{32, 0b00000000000000000101000000000011, 0b00000000000000000111000001111111, opcode_e::LHU},
|
||||||
|
{32, 0b00000000000000000000000000100011, 0b00000000000000000111000001111111, opcode_e::SB},
|
||||||
|
{32, 0b00000000000000000001000000100011, 0b00000000000000000111000001111111, opcode_e::SH},
|
||||||
|
{32, 0b00000000000000000010000000100011, 0b00000000000000000111000001111111, opcode_e::SW},
|
||||||
|
{32, 0b00000000000000000000000000010011, 0b00000000000000000111000001111111, opcode_e::ADDI},
|
||||||
|
{32, 0b00000000000000000010000000010011, 0b00000000000000000111000001111111, opcode_e::SLTI},
|
||||||
|
{32, 0b00000000000000000011000000010011, 0b00000000000000000111000001111111, opcode_e::SLTIU},
|
||||||
|
{32, 0b00000000000000000100000000010011, 0b00000000000000000111000001111111, opcode_e::XORI},
|
||||||
|
{32, 0b00000000000000000110000000010011, 0b00000000000000000111000001111111, opcode_e::ORI},
|
||||||
|
{32, 0b00000000000000000111000000010011, 0b00000000000000000111000001111111, opcode_e::ANDI},
|
||||||
|
{32, 0b00000000000000000001000000010011, 0b11111110000000000111000001111111, opcode_e::SLLI},
|
||||||
|
{32, 0b00000000000000000101000000010011, 0b11111110000000000111000001111111, opcode_e::SRLI},
|
||||||
|
{32, 0b01000000000000000101000000010011, 0b11111110000000000111000001111111, opcode_e::SRAI},
|
||||||
|
{32, 0b00000000000000000000000000110011, 0b11111110000000000111000001111111, opcode_e::ADD},
|
||||||
|
{32, 0b01000000000000000000000000110011, 0b11111110000000000111000001111111, opcode_e::SUB},
|
||||||
|
{32, 0b00000000000000000001000000110011, 0b11111110000000000111000001111111, opcode_e::SLL},
|
||||||
|
{32, 0b00000000000000000010000000110011, 0b11111110000000000111000001111111, opcode_e::SLT},
|
||||||
|
{32, 0b00000000000000000011000000110011, 0b11111110000000000111000001111111, opcode_e::SLTU},
|
||||||
|
{32, 0b00000000000000000100000000110011, 0b11111110000000000111000001111111, opcode_e::XOR},
|
||||||
|
{32, 0b00000000000000000101000000110011, 0b11111110000000000111000001111111, opcode_e::SRL},
|
||||||
|
{32, 0b01000000000000000101000000110011, 0b11111110000000000111000001111111, opcode_e::SRA},
|
||||||
|
{32, 0b00000000000000000110000000110011, 0b11111110000000000111000001111111, opcode_e::OR},
|
||||||
|
{32, 0b00000000000000000111000000110011, 0b11111110000000000111000001111111, opcode_e::AND},
|
||||||
|
{32, 0b00000000000000000000000000001111, 0b00000000000000000111000001111111, opcode_e::FENCE},
|
||||||
|
{32, 0b00000000000000000000000001110011, 0b11111111111111111111111111111111, opcode_e::ECALL},
|
||||||
|
{32, 0b00000000000100000000000001110011, 0b11111111111111111111111111111111, opcode_e::EBREAK},
|
||||||
|
{32, 0b00000000001000000000000001110011, 0b11111111111111111111111111111111, opcode_e::URET},
|
||||||
|
{32, 0b00010000001000000000000001110011, 0b11111111111111111111111111111111, opcode_e::SRET},
|
||||||
|
{32, 0b00110000001000000000000001110011, 0b11111111111111111111111111111111, opcode_e::MRET},
|
||||||
|
{32, 0b00010000010100000000000001110011, 0b11111111111111111111111111111111, opcode_e::WFI},
|
||||||
|
{32, 0b01111011001000000000000001110011, 0b11111111111111111111111111111111, opcode_e::DRET},
|
||||||
|
{32, 0b00000000000000000001000001110011, 0b00000000000000000111000001111111, opcode_e::CSRRW},
|
||||||
|
{32, 0b00000000000000000010000001110011, 0b00000000000000000111000001111111, opcode_e::CSRRS},
|
||||||
|
{32, 0b00000000000000000011000001110011, 0b00000000000000000111000001111111, opcode_e::CSRRC},
|
||||||
|
{32, 0b00000000000000000101000001110011, 0b00000000000000000111000001111111, opcode_e::CSRRWI},
|
||||||
|
{32, 0b00000000000000000110000001110011, 0b00000000000000000111000001111111, opcode_e::CSRRSI},
|
||||||
|
{32, 0b00000000000000000111000001110011, 0b00000000000000000111000001111111, opcode_e::CSRRCI},
|
||||||
|
{32, 0b00000000000000000001000000001111, 0b00000000000000000111000001111111, opcode_e::FENCE_I},
|
||||||
|
{32, 0b00000010000000000000000000110011, 0b11111110000000000111000001111111, opcode_e::MUL},
|
||||||
|
{32, 0b00000010000000000001000000110011, 0b11111110000000000111000001111111, opcode_e::MULH},
|
||||||
|
{32, 0b00000010000000000010000000110011, 0b11111110000000000111000001111111, opcode_e::MULHSU},
|
||||||
|
{32, 0b00000010000000000011000000110011, 0b11111110000000000111000001111111, opcode_e::MULHU},
|
||||||
|
{32, 0b00000010000000000100000000110011, 0b11111110000000000111000001111111, opcode_e::DIV},
|
||||||
|
{32, 0b00000010000000000101000000110011, 0b11111110000000000111000001111111, opcode_e::DIVU},
|
||||||
|
{32, 0b00000010000000000110000000110011, 0b11111110000000000111000001111111, opcode_e::REM},
|
||||||
|
{32, 0b00000010000000000111000000110011, 0b11111110000000000111000001111111, opcode_e::REMU},
|
||||||
|
{16, 0b0000000000000000, 0b1110000000000011, opcode_e::CADDI4SPN},
|
||||||
|
{16, 0b0100000000000000, 0b1110000000000011, opcode_e::CLW},
|
||||||
|
{16, 0b1100000000000000, 0b1110000000000011, opcode_e::CSW},
|
||||||
|
{16, 0b0000000000000001, 0b1110000000000011, opcode_e::CADDI},
|
||||||
|
{16, 0b0000000000000001, 0b1110111110000011, opcode_e::CNOP},
|
||||||
|
{16, 0b0010000000000001, 0b1110000000000011, opcode_e::CJAL},
|
||||||
|
{16, 0b0100000000000001, 0b1110000000000011, opcode_e::CLI},
|
||||||
|
{16, 0b0110000000000001, 0b1110000000000011, opcode_e::CLUI},
|
||||||
|
{16, 0b0110000100000001, 0b1110111110000011, opcode_e::CADDI16SP},
|
||||||
|
{16, 0b0110000000000001, 0b1111000001111111, opcode_e::__reserved_clui},
|
||||||
|
{16, 0b1000000000000001, 0b1111110000000011, opcode_e::CSRLI},
|
||||||
|
{16, 0b1000010000000001, 0b1111110000000011, opcode_e::CSRAI},
|
||||||
|
{16, 0b1000100000000001, 0b1110110000000011, opcode_e::CANDI},
|
||||||
|
{16, 0b1000110000000001, 0b1111110001100011, opcode_e::CSUB},
|
||||||
|
{16, 0b1000110000100001, 0b1111110001100011, opcode_e::CXOR},
|
||||||
|
{16, 0b1000110001000001, 0b1111110001100011, opcode_e::COR},
|
||||||
|
{16, 0b1000110001100001, 0b1111110001100011, opcode_e::CAND},
|
||||||
|
{16, 0b1010000000000001, 0b1110000000000011, opcode_e::CJ},
|
||||||
|
{16, 0b1100000000000001, 0b1110000000000011, opcode_e::CBEQZ},
|
||||||
|
{16, 0b1110000000000001, 0b1110000000000011, opcode_e::CBNEZ},
|
||||||
|
{16, 0b0000000000000010, 0b1111000000000011, opcode_e::CSLLI},
|
||||||
|
{16, 0b0100000000000010, 0b1110000000000011, opcode_e::CLWSP},
|
||||||
|
{16, 0b1000000000000010, 0b1111000000000011, opcode_e::CMV},
|
||||||
|
{16, 0b1000000000000010, 0b1111000001111111, opcode_e::CJR},
|
||||||
|
{16, 0b1000000000000010, 0b1111111111111111, opcode_e::__reserved_cmv},
|
||||||
|
{16, 0b1001000000000010, 0b1111000000000011, opcode_e::CADD},
|
||||||
|
{16, 0b1001000000000010, 0b1111000001111111, opcode_e::CJALR},
|
||||||
|
{16, 0b1001000000000010, 0b1111111111111111, opcode_e::CEBREAK},
|
||||||
|
{16, 0b1100000000000010, 0b1110000000000011, opcode_e::CSWSP},
|
||||||
|
{16, 0b0000000000000000, 0b1111111111111111, opcode_e::DII},
|
||||||
|
}};
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
template<>
|
||||||
|
struct instruction_decoder<tgc_c> {
|
||||||
|
using opcode_e = traits<tgc_c>::opcode_e;
|
||||||
|
using code_word_t=traits<tgc_c>::code_word_t;
|
||||||
|
|
||||||
|
struct instruction_pattern {
|
||||||
|
uint32_t value;
|
||||||
|
uint32_t mask;
|
||||||
|
opcode_e id;
|
||||||
|
};
|
||||||
|
|
||||||
|
std::array<std::vector<instruction_pattern>, 4> qlut;
|
||||||
|
|
||||||
|
template<typename T>
|
||||||
|
unsigned decode_instruction(T);
|
||||||
|
|
||||||
|
instruction_decoder() {
|
||||||
|
for (auto instr : instr_descr) {
|
||||||
|
auto quadrant = instr.value & 0x3;
|
||||||
|
qlut[quadrant].push_back(instruction_pattern{instr.value, instr.mask, instr.op});
|
||||||
|
}
|
||||||
|
for(auto& lut: qlut){
|
||||||
|
std::sort(std::begin(lut), std::end(lut), [](instruction_pattern const& a, instruction_pattern const& b){
|
||||||
|
return bit_count(a.mask) > bit_count(b.mask);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
template<>
|
||||||
|
unsigned instruction_decoder<tgc_c>::decode_instruction<traits<tgc_c>::code_word_t>(traits<tgc_c>::code_word_t instr){
|
||||||
|
auto res = std::find_if(std::begin(qlut[instr&0x3]), std::end(qlut[instr&0x3]), [instr](instruction_pattern const& e){
|
||||||
|
return !((instr&e.mask) ^ e.value );
|
||||||
|
});
|
||||||
|
return static_cast<unsigned>(res!=std::end(qlut[instr&0x3])? res->id : opcode_e::MAX_OPCODE);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
std::unique_ptr<instruction_decoder<tgc_c>> traits<tgc_c>::get_decoder(){
|
||||||
|
return std::make_unique<instruction_decoder<tgc_c>>();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
@ -462,11 +462,12 @@ private:
|
|||||||
this->gen_raise_trap(tu, 0, 2);
|
this->gen_raise_trap(tu, 0, 2);
|
||||||
}
|
}
|
||||||
else{
|
else{
|
||||||
|
auto addr_mask = tu.assignment(tu.constant((uint32_t)- 2,32),32);
|
||||||
auto new_pc = tu.assignment(tu.ext((tu.bitwise_and(
|
auto new_pc = tu.assignment(tu.ext((tu.bitwise_and(
|
||||||
(tu.add(
|
(tu.add(
|
||||||
tu.load(rs1+ traits::X0, 0),
|
tu.load(rs1+ traits::X0, 0),
|
||||||
tu.constant((int16_t)sext<12>(imm),16))),
|
tu.constant((int16_t)sext<12>(imm),16))),
|
||||||
tu.constant(~ 0x1,8))),32,false),32);
|
addr_mask)),32,false),32);
|
||||||
tu.open_if(tu.urem(
|
tu.open_if(tu.urem(
|
||||||
new_pc,
|
new_pc,
|
||||||
tu.constant(static_cast<uint32_t>(traits:: INSTR_ALIGNMENT),32)));
|
tu.constant(static_cast<uint32_t>(traits:: INSTR_ALIGNMENT),32)));
|
||||||
@ -476,9 +477,7 @@ private:
|
|||||||
tu.store(rd + traits::X0,
|
tu.store(rd + traits::X0,
|
||||||
tu.constant((uint32_t)(PC+ 4),32));
|
tu.constant((uint32_t)(PC+ 4),32));
|
||||||
}
|
}
|
||||||
auto PC_val_v = tu.assignment("PC_val", tu.bitwise_and(
|
auto PC_val_v = tu.assignment("PC_val", new_pc,32);
|
||||||
new_pc,
|
|
||||||
tu.constant(~ 0x1,8)),32);
|
|
||||||
tu.store(traits::NEXT_PC, PC_val_v);
|
tu.store(traits::NEXT_PC, PC_val_v);
|
||||||
tu.store(traits::LAST_BRANCH, tu.constant(2U, 2));
|
tu.store(traits::LAST_BRANCH, tu.constant(2U, 2));
|
||||||
tu.close_scope();
|
tu.close_scope();
|
||||||
@ -2473,7 +2472,7 @@ private:
|
|||||||
tu.open_if(tu.icmp(ICmpInst::ICMP_NE,
|
tu.open_if(tu.icmp(ICmpInst::ICMP_NE,
|
||||||
tu.load(rs2+ traits::X0, 0),
|
tu.load(rs2+ traits::X0, 0),
|
||||||
tu.constant( 0,8)));
|
tu.constant( 0,8)));
|
||||||
auto MMIN = tu.assignment(tu.constant( 1<<(static_cast<uint32_t>(traits:: XLEN)-1),8),32);
|
auto MMIN = tu.assignment(tu.constant((uint32_t)1<<(static_cast<uint32_t>(traits:: XLEN)-1),32),32);
|
||||||
tu.open_if(tu.logical_and(
|
tu.open_if(tu.logical_and(
|
||||||
tu.icmp(ICmpInst::ICMP_EQ,
|
tu.icmp(ICmpInst::ICMP_EQ,
|
||||||
tu.load(rs1+ traits::X0, 0),
|
tu.load(rs1+ traits::X0, 0),
|
||||||
@ -3304,10 +3303,10 @@ private:
|
|||||||
pc=pc+ 2;
|
pc=pc+ 2;
|
||||||
gen_set_pc(tu, pc, traits::NEXT_PC);
|
gen_set_pc(tu, pc, traits::NEXT_PC);
|
||||||
tu.open_scope();
|
tu.open_scope();
|
||||||
if(rs1&&rs1<static_cast<uint32_t>(traits:: RFS)) {
|
if(rs1&&rs1<static_cast<uint32_t>(traits:: RFS)){ auto addr_mask = tu.assignment(tu.constant((uint32_t)- 2,32),32);
|
||||||
auto PC_val_v = tu.assignment("PC_val", tu.bitwise_and(
|
auto PC_val_v = tu.assignment("PC_val", tu.bitwise_and(
|
||||||
tu.load(rs1%static_cast<uint32_t>(traits:: RFS)+ traits::X0, 0),
|
tu.load(rs1%static_cast<uint32_t>(traits:: RFS)+ traits::X0, 0),
|
||||||
tu.constant(~ 0x1,8)),32);
|
addr_mask),32);
|
||||||
tu.store(traits::NEXT_PC, PC_val_v);
|
tu.store(traits::NEXT_PC, PC_val_v);
|
||||||
tu.store(traits::LAST_BRANCH, tu.constant(2U, 2));
|
tu.store(traits::LAST_BRANCH, tu.constant(2U, 2));
|
||||||
}
|
}
|
||||||
@ -3402,12 +3401,13 @@ private:
|
|||||||
this->gen_raise_trap(tu, 0, 2);
|
this->gen_raise_trap(tu, 0, 2);
|
||||||
}
|
}
|
||||||
else{
|
else{
|
||||||
|
auto addr_mask = tu.assignment(tu.constant((uint32_t)- 2,32),32);
|
||||||
auto new_pc = tu.assignment(tu.load(rs1+ traits::X0, 0),32);
|
auto new_pc = tu.assignment(tu.load(rs1+ traits::X0, 0),32);
|
||||||
tu.store(1 + traits::X0,
|
tu.store(1 + traits::X0,
|
||||||
tu.constant((uint32_t)(PC+ 2),32));
|
tu.constant((uint32_t)(PC+ 2),32));
|
||||||
auto PC_val_v = tu.assignment("PC_val", tu.bitwise_and(
|
auto PC_val_v = tu.assignment("PC_val", tu.bitwise_and(
|
||||||
new_pc,
|
new_pc,
|
||||||
tu.constant(~ 0x1,8)),32);
|
addr_mask),32);
|
||||||
tu.store(traits::NEXT_PC, PC_val_v);
|
tu.store(traits::NEXT_PC, PC_val_v);
|
||||||
tu.store(traits::LAST_BRANCH, tu.constant(2U, 2));
|
tu.store(traits::LAST_BRANCH, tu.constant(2U, 2));
|
||||||
}
|
}
|
||||||
@ -3626,8 +3626,6 @@ template <typename ARCH> void vm_impl<ARCH>::gen_wait(tu_builder& tu, unsigned t
|
|||||||
}
|
}
|
||||||
|
|
||||||
template <typename ARCH> void vm_impl<ARCH>::gen_trap_behavior(tu_builder& tu) {
|
template <typename ARCH> void vm_impl<ARCH>::gen_trap_behavior(tu_builder& tu) {
|
||||||
tu("trap_entry_plugin:");
|
|
||||||
this->gen_sync(tu, POST_SYNC, -1);
|
|
||||||
tu("trap_entry:");
|
tu("trap_entry:");
|
||||||
tu("enter_trap(core_ptr, *trap_state, *pc, 0);");
|
tu("enter_trap(core_ptr, *trap_state, *pc, 0);");
|
||||||
tu.store(traits::LAST_BRANCH, tu.constant(std::numeric_limits<uint32_t>::max(),32));
|
tu.store(traits::LAST_BRANCH, tu.constant(std::numeric_limits<uint32_t>::max(),32));
|
||||||
|
Loading…
x
Reference in New Issue
Block a user