20 (uint64_t) 0xfe00707f,
32rd += R_rd_0.
read(ba) << 0;
35rs1 += R_rs1_0.
read(ba) << 0;
38rs2 += R_rs2_0.
read(ba) << 0;
46 cp.
code() = std::string(
"//MUL\n");
49cp.
code() +=
"etiss_coverage_count(1, 240);\n";
51cp.
code() +=
"etiss_coverage_count(1, 1189);\n";
52cp.
code() +=
"{ // block\n";
54cp.
code() +=
"etiss_coverage_count(7, 1188, 1181, 1187, 1184, 1182, 1183, 1185);\n";
55cp.
code() +=
"} // block\n";
58cp.
code() +=
"etiss_coverage_count(1, 9457);\n";
59cp.
code() +=
"{ // block\n";
60cp.
code() +=
"etiss_coverage_count(1, 9425);\n";
61if ((rd % 32ULL) != 0LL) {
62cp.
code() +=
"etiss_coverage_count(5, 9431, 9428, 9426, 9429, 9430);\n";
64cp.
code() +=
"etiss_coverage_count(1, 9456);\n";
65cp.
code() +=
"{ // block\n";
66cp.
code() +=
"etiss_int64 res = (etiss_int64)(*((RV64IMACFD*)cpu)->X[" + std::to_string(rs1 % 32ULL) +
"ULL]) * (etiss_int64)(*((RV64IMACFD*)cpu)->X[" + std::to_string(rs2 % 32ULL) +
"ULL]);\n";
67cp.
code() +=
"etiss_coverage_count(10, 9446, 9445, 9438, 9437, 9436, 9434, 9444, 9443, 9442, 9440);\n";
68cp.
code() +=
"*((RV64IMACFD*)cpu)->X[" + std::to_string(rd % 32ULL) +
"ULL] = (etiss_uint64)(res);\n";
69cp.
code() +=
"etiss_coverage_count(6, 9455, 9451, 9450, 9448, 9454, 9452);\n";
70cp.
code() +=
"} // block\n";
73cp.
code() +=
"} // block\n";
76cp.
code() +=
"cpu->instructionPointer = cpu->nextPc;\n";
89rd += R_rd_0.read(ba) << 0;
92rs1 += R_rs1_0.read(ba) << 0;
95rs2 += R_rs2_0.read(ba) << 0;
101ss <<
"mul" <<
" # " << ba << (
" [rd=" + std::to_string(rd) +
" | rs1=" + std::to_string(rs1) +
" | rs2=" + std::to_string(rs2) +
"]");
111 (uint64_t) 0x2001033,
112 (uint64_t) 0xfe00707f,
124rd += R_rd_0.
read(ba) << 0;
127rs1 += R_rs1_0.
read(ba) << 0;
130rs2 += R_rs2_0.
read(ba) << 0;
138 cp.
code() = std::string(
"//MULH\n");
141cp.
code() +=
"etiss_coverage_count(1, 241);\n";
143cp.
code() +=
"etiss_coverage_count(1, 1189);\n";
144cp.
code() +=
"{ // block\n";
146cp.
code() +=
"etiss_coverage_count(7, 1188, 1181, 1187, 1184, 1182, 1183, 1185);\n";
147cp.
code() +=
"} // block\n";
150cp.
code() +=
"etiss_coverage_count(1, 9485);\n";
151cp.
code() +=
"{ // block\n";
152cp.
code() +=
"etiss_coverage_count(1, 9458);\n";
153if ((rd % 32ULL) != 0LL) {
154cp.
code() +=
"etiss_coverage_count(5, 9464, 9461, 9459, 9462, 9463);\n";
156cp.
code() +=
"etiss_coverage_count(1, 9484);\n";
157cp.
code() +=
"{ // block\n";
158cp.
code() +=
"*((RV64IMACFD*)cpu)->X[" + std::to_string(rd % 32ULL) +
"ULL] = RV64IMACFD_mulh((etiss_int64)(*((RV64IMACFD*)cpu)->X[" + std::to_string(rs1 % 32ULL) +
"ULL]), (etiss_int64)(*((RV64IMACFD*)cpu)->X[" + std::to_string(rs2 % 32ULL) +
"ULL]));\n";
159cp.
code() +=
"etiss_coverage_count(13, 9483, 9469, 9468, 9466, 9482, 9475, 9474, 9473, 9471, 9481, 9480, 9479, 9477);\n";
160cp.
code() +=
"} // block\n";
163cp.
code() +=
"} // block\n";
166cp.
code() +=
"cpu->instructionPointer = cpu->nextPc;\n";
179rd += R_rd_0.read(ba) << 0;
182rs1 += R_rs1_0.read(ba) << 0;
185rs2 += R_rs2_0.read(ba) << 0;
189 std::stringstream ss;
191ss <<
"mulh" <<
" # " << ba << (
" [rd=" + std::to_string(rd) +
" | rs1=" + std::to_string(rs1) +
" | rs2=" + std::to_string(rs2) +
"]");
201 (uint64_t) 0x2002033,
202 (uint64_t) 0xfe00707f,
214rd += R_rd_0.
read(ba) << 0;
217rs1 += R_rs1_0.
read(ba) << 0;
220rs2 += R_rs2_0.
read(ba) << 0;
228 cp.
code() = std::string(
"//MULHSU\n");
231cp.
code() +=
"etiss_coverage_count(1, 242);\n";
233cp.
code() +=
"etiss_coverage_count(1, 1189);\n";
234cp.
code() +=
"{ // block\n";
236cp.
code() +=
"etiss_coverage_count(7, 1188, 1181, 1187, 1184, 1182, 1183, 1185);\n";
237cp.
code() +=
"} // block\n";
240cp.
code() +=
"etiss_coverage_count(1, 9512);\n";
241cp.
code() +=
"{ // block\n";
242cp.
code() +=
"etiss_coverage_count(1, 9486);\n";
243if ((rd % 32ULL) != 0LL) {
244cp.
code() +=
"etiss_coverage_count(5, 9492, 9489, 9487, 9490, 9491);\n";
246cp.
code() +=
"etiss_coverage_count(1, 9511);\n";
247cp.
code() +=
"{ // block\n";
248cp.
code() +=
"*((RV64IMACFD*)cpu)->X[" + std::to_string(rd % 32ULL) +
"ULL] = RV64IMACFD_mulhsu((etiss_int64)(*((RV64IMACFD*)cpu)->X[" + std::to_string(rs1 % 32ULL) +
"ULL]), *((RV64IMACFD*)cpu)->X[" + std::to_string(rs2 % 32ULL) +
"ULL]);\n";
249cp.
code() +=
"etiss_coverage_count(12, 9510, 9497, 9496, 9494, 9509, 9503, 9502, 9501, 9499, 9508, 9507, 9505);\n";
250cp.
code() +=
"} // block\n";
253cp.
code() +=
"} // block\n";
256cp.
code() +=
"cpu->instructionPointer = cpu->nextPc;\n";
269rd += R_rd_0.read(ba) << 0;
272rs1 += R_rs1_0.read(ba) << 0;
275rs2 += R_rs2_0.read(ba) << 0;
279 std::stringstream ss;
281ss <<
"mulhsu" <<
" # " << ba << (
" [rd=" + std::to_string(rd) +
" | rs1=" + std::to_string(rs1) +
" | rs2=" + std::to_string(rs2) +
"]");
291 (uint64_t) 0x2003033,
292 (uint64_t) 0xfe00707f,
304rd += R_rd_0.
read(ba) << 0;
307rs1 += R_rs1_0.
read(ba) << 0;
310rs2 += R_rs2_0.
read(ba) << 0;
318 cp.
code() = std::string(
"//MULHU\n");
321cp.
code() +=
"etiss_coverage_count(1, 243);\n";
323cp.
code() +=
"etiss_coverage_count(1, 1189);\n";
324cp.
code() +=
"{ // block\n";
326cp.
code() +=
"etiss_coverage_count(7, 1188, 1181, 1187, 1184, 1182, 1183, 1185);\n";
327cp.
code() +=
"} // block\n";
330cp.
code() +=
"etiss_coverage_count(1, 9538);\n";
331cp.
code() +=
"{ // block\n";
332cp.
code() +=
"etiss_coverage_count(1, 9513);\n";
333if ((rd % 32ULL) != 0LL) {
334cp.
code() +=
"etiss_coverage_count(5, 9519, 9516, 9514, 9517, 9518);\n";
336cp.
code() +=
"etiss_coverage_count(1, 9537);\n";
337cp.
code() +=
"{ // block\n";
338cp.
code() +=
"*((RV64IMACFD*)cpu)->X[" + std::to_string(rd % 32ULL) +
"ULL] = RV64IMACFD_mulhu(*((RV64IMACFD*)cpu)->X[" + std::to_string(rs1 % 32ULL) +
"ULL], *((RV64IMACFD*)cpu)->X[" + std::to_string(rs2 % 32ULL) +
"ULL]);\n";
339cp.
code() +=
"etiss_coverage_count(11, 9536, 9524, 9523, 9521, 9535, 9529, 9528, 9526, 9534, 9533, 9531);\n";
340cp.
code() +=
"} // block\n";
343cp.
code() +=
"} // block\n";
346cp.
code() +=
"cpu->instructionPointer = cpu->nextPc;\n";
359rd += R_rd_0.read(ba) << 0;
362rs1 += R_rs1_0.read(ba) << 0;
365rs2 += R_rs2_0.read(ba) << 0;
369 std::stringstream ss;
371ss <<
"mulhu" <<
" # " << ba << (
" [rd=" + std::to_string(rd) +
" | rs1=" + std::to_string(rs1) +
" | rs2=" + std::to_string(rs2) +
"]");
etiss::instr::InstructionGroup ISA32_RV64IMACFD("ISA32_RV64IMACFD", 32)
static InstructionDefinition mulhu_rd_rs1_rs2(ISA32_RV64IMACFD, "mulhu",(uint64_t) 0x2003033,(uint64_t) 0xfe00707f, [](BitArray &ba, etiss::CodeSet &cs, InstructionContext &ic) { etiss_uint8 rd=0;static BitArrayRange R_rd_0(11, 7);rd+=R_rd_0.read(ba)<< 0;etiss_uint8 rs1=0;static BitArrayRange R_rs1_0(19, 15);rs1+=R_rs1_0.read(ba)<< 0;etiss_uint8 rs2=0;static BitArrayRange R_rs2_0(24, 20);rs2+=R_rs2_0.read(ba)<< 0;{ CodePart &cp=cs.append(CodePart::INITIALREQUIRED);cp.code()=std::string("//MULHU\n");cp.code()+="etiss_coverage_count(1, 243);\n";{ cp.code()+="etiss_coverage_count(1, 1189);\n";cp.code()+="{ // block\n";cp.code()+="cpu->nextPc = "+std::to_string((etiss_uint64)((ic.current_address_+4)))+"ULL;\n";cp.code()+="etiss_coverage_count(7, 1188, 1181, 1187, 1184, 1182, 1183, 1185);\n";cp.code()+="} // block\n";} { cp.code()+="etiss_coverage_count(1, 9538);\n";cp.code()+="{ // block\n";cp.code()+="etiss_coverage_count(1, 9513);\n";if((rd % 32ULL) !=0LL) { cp.code()+="etiss_coverage_count(5, 9519, 9516, 9514, 9517, 9518);\n";{ cp.code()+="etiss_coverage_count(1, 9537);\n";cp.code()+="{ // block\n";cp.code()+="*((RV64IMACFD*)cpu)->X["+std::to_string(rd % 32ULL)+"ULL] = RV64IMACFD_mulhu(*((RV64IMACFD*)cpu)->X["+std::to_string(rs1 % 32ULL)+"ULL], *((RV64IMACFD*)cpu)->X["+std::to_string(rs2 % 32ULL)+"ULL]);\n";cp.code()+="etiss_coverage_count(11, 9536, 9524, 9523, 9521, 9535, 9529, 9528, 9526, 9534, 9533, 9531);\n";cp.code()+="} // block\n";} } cp.code()+="} // block\n";} cp.code()+="instr_exit_"+std::to_string(ic.current_address_)+":\n";cp.code()+="cpu->instructionPointer = cpu->nextPc;\n";cp.getAffectedRegisters().add("instructionPointer", 32);} return true;}, 0, [](BitArray &ba, Instruction &instr) { etiss_uint8 rd=0;static BitArrayRange R_rd_0(11, 7);rd+=R_rd_0.read(ba)<< 0;etiss_uint8 rs1=0;static BitArrayRange R_rs1_0(19, 15);rs1+=R_rs1_0.read(ba)<< 0;etiss_uint8 rs2=0;static BitArrayRange R_rs2_0(24, 20);rs2+=R_rs2_0.read(ba)<< 0;std::stringstream ss;ss<< "mulhu"<< " # "<< ba<<(" [rd="+std::to_string(rd)+" | rs1="+std::to_string(rs1)+" | rs2="+std::to_string(rs2)+"]");return ss.str();})
static InstructionDefinition mulh_rd_rs1_rs2(ISA32_RV64IMACFD, "mulh",(uint64_t) 0x2001033,(uint64_t) 0xfe00707f, [](BitArray &ba, etiss::CodeSet &cs, InstructionContext &ic) { etiss_uint8 rd=0;static BitArrayRange R_rd_0(11, 7);rd+=R_rd_0.read(ba)<< 0;etiss_uint8 rs1=0;static BitArrayRange R_rs1_0(19, 15);rs1+=R_rs1_0.read(ba)<< 0;etiss_uint8 rs2=0;static BitArrayRange R_rs2_0(24, 20);rs2+=R_rs2_0.read(ba)<< 0;{ CodePart &cp=cs.append(CodePart::INITIALREQUIRED);cp.code()=std::string("//MULH\n");cp.code()+="etiss_coverage_count(1, 241);\n";{ cp.code()+="etiss_coverage_count(1, 1189);\n";cp.code()+="{ // block\n";cp.code()+="cpu->nextPc = "+std::to_string((etiss_uint64)((ic.current_address_+4)))+"ULL;\n";cp.code()+="etiss_coverage_count(7, 1188, 1181, 1187, 1184, 1182, 1183, 1185);\n";cp.code()+="} // block\n";} { cp.code()+="etiss_coverage_count(1, 9485);\n";cp.code()+="{ // block\n";cp.code()+="etiss_coverage_count(1, 9458);\n";if((rd % 32ULL) !=0LL) { cp.code()+="etiss_coverage_count(5, 9464, 9461, 9459, 9462, 9463);\n";{ cp.code()+="etiss_coverage_count(1, 9484);\n";cp.code()+="{ // block\n";cp.code()+="*((RV64IMACFD*)cpu)->X["+std::to_string(rd % 32ULL)+"ULL] = RV64IMACFD_mulh((etiss_int64)(*((RV64IMACFD*)cpu)->X["+std::to_string(rs1 % 32ULL)+"ULL]), (etiss_int64)(*((RV64IMACFD*)cpu)->X["+std::to_string(rs2 % 32ULL)+"ULL]));\n";cp.code()+="etiss_coverage_count(13, 9483, 9469, 9468, 9466, 9482, 9475, 9474, 9473, 9471, 9481, 9480, 9479, 9477);\n";cp.code()+="} // block\n";} } cp.code()+="} // block\n";} cp.code()+="instr_exit_"+std::to_string(ic.current_address_)+":\n";cp.code()+="cpu->instructionPointer = cpu->nextPc;\n";cp.getAffectedRegisters().add("instructionPointer", 32);} return true;}, 0, [](BitArray &ba, Instruction &instr) { etiss_uint8 rd=0;static BitArrayRange R_rd_0(11, 7);rd+=R_rd_0.read(ba)<< 0;etiss_uint8 rs1=0;static BitArrayRange R_rs1_0(19, 15);rs1+=R_rs1_0.read(ba)<< 0;etiss_uint8 rs2=0;static BitArrayRange R_rs2_0(24, 20);rs2+=R_rs2_0.read(ba)<< 0;std::stringstream ss;ss<< "mulh"<< " # "<< ba<<(" [rd="+std::to_string(rd)+" | rs1="+std::to_string(rs1)+" | rs2="+std::to_string(rs2)+"]");return ss.str();})
static InstructionDefinition mulhsu_rd_rs1_rs2(ISA32_RV64IMACFD, "mulhsu",(uint64_t) 0x2002033,(uint64_t) 0xfe00707f, [](BitArray &ba, etiss::CodeSet &cs, InstructionContext &ic) { etiss_uint8 rd=0;static BitArrayRange R_rd_0(11, 7);rd+=R_rd_0.read(ba)<< 0;etiss_uint8 rs1=0;static BitArrayRange R_rs1_0(19, 15);rs1+=R_rs1_0.read(ba)<< 0;etiss_uint8 rs2=0;static BitArrayRange R_rs2_0(24, 20);rs2+=R_rs2_0.read(ba)<< 0;{ CodePart &cp=cs.append(CodePart::INITIALREQUIRED);cp.code()=std::string("//MULHSU\n");cp.code()+="etiss_coverage_count(1, 242);\n";{ cp.code()+="etiss_coverage_count(1, 1189);\n";cp.code()+="{ // block\n";cp.code()+="cpu->nextPc = "+std::to_string((etiss_uint64)((ic.current_address_+4)))+"ULL;\n";cp.code()+="etiss_coverage_count(7, 1188, 1181, 1187, 1184, 1182, 1183, 1185);\n";cp.code()+="} // block\n";} { cp.code()+="etiss_coverage_count(1, 9512);\n";cp.code()+="{ // block\n";cp.code()+="etiss_coverage_count(1, 9486);\n";if((rd % 32ULL) !=0LL) { cp.code()+="etiss_coverage_count(5, 9492, 9489, 9487, 9490, 9491);\n";{ cp.code()+="etiss_coverage_count(1, 9511);\n";cp.code()+="{ // block\n";cp.code()+="*((RV64IMACFD*)cpu)->X["+std::to_string(rd % 32ULL)+"ULL] = RV64IMACFD_mulhsu((etiss_int64)(*((RV64IMACFD*)cpu)->X["+std::to_string(rs1 % 32ULL)+"ULL]), *((RV64IMACFD*)cpu)->X["+std::to_string(rs2 % 32ULL)+"ULL]);\n";cp.code()+="etiss_coverage_count(12, 9510, 9497, 9496, 9494, 9509, 9503, 9502, 9501, 9499, 9508, 9507, 9505);\n";cp.code()+="} // block\n";} } cp.code()+="} // block\n";} cp.code()+="instr_exit_"+std::to_string(ic.current_address_)+":\n";cp.code()+="cpu->instructionPointer = cpu->nextPc;\n";cp.getAffectedRegisters().add("instructionPointer", 32);} return true;}, 0, [](BitArray &ba, Instruction &instr) { etiss_uint8 rd=0;static BitArrayRange R_rd_0(11, 7);rd+=R_rd_0.read(ba)<< 0;etiss_uint8 rs1=0;static BitArrayRange R_rs1_0(19, 15);rs1+=R_rs1_0.read(ba)<< 0;etiss_uint8 rs2=0;static BitArrayRange R_rs2_0(24, 20);rs2+=R_rs2_0.read(ba)<< 0;std::stringstream ss;ss<< "mulhsu"<< " # "<< ba<<(" [rd="+std::to_string(rd)+" | rs1="+std::to_string(rs1)+" | rs2="+std::to_string(rs2)+"]");return ss.str();})
static InstructionDefinition mul_rd_rs1_rs2(ISA32_RV64IMACFD, "mul",(uint64_t) 0x2000033,(uint64_t) 0xfe00707f, [](BitArray &ba, etiss::CodeSet &cs, InstructionContext &ic) { etiss_uint8 rd=0;static BitArrayRange R_rd_0(11, 7);rd+=R_rd_0.read(ba)<< 0;etiss_uint8 rs1=0;static BitArrayRange R_rs1_0(19, 15);rs1+=R_rs1_0.read(ba)<< 0;etiss_uint8 rs2=0;static BitArrayRange R_rs2_0(24, 20);rs2+=R_rs2_0.read(ba)<< 0;{ CodePart &cp=cs.append(CodePart::INITIALREQUIRED);cp.code()=std::string("//MUL\n");cp.code()+="etiss_coverage_count(1, 240);\n";{ cp.code()+="etiss_coverage_count(1, 1189);\n";cp.code()+="{ // block\n";cp.code()+="cpu->nextPc = "+std::to_string((etiss_uint64)((ic.current_address_+4)))+"ULL;\n";cp.code()+="etiss_coverage_count(7, 1188, 1181, 1187, 1184, 1182, 1183, 1185);\n";cp.code()+="} // block\n";} { cp.code()+="etiss_coverage_count(1, 9457);\n";cp.code()+="{ // block\n";cp.code()+="etiss_coverage_count(1, 9425);\n";if((rd % 32ULL) !=0LL) { cp.code()+="etiss_coverage_count(5, 9431, 9428, 9426, 9429, 9430);\n";{ cp.code()+="etiss_coverage_count(1, 9456);\n";cp.code()+="{ // block\n";cp.code()+="etiss_int64 res = (etiss_int64)(*((RV64IMACFD*)cpu)->X["+std::to_string(rs1 % 32ULL)+"ULL]) * (etiss_int64)(*((RV64IMACFD*)cpu)->X["+std::to_string(rs2 % 32ULL)+"ULL]);\n";cp.code()+="etiss_coverage_count(10, 9446, 9445, 9438, 9437, 9436, 9434, 9444, 9443, 9442, 9440);\n";cp.code()+="*((RV64IMACFD*)cpu)->X["+std::to_string(rd % 32ULL)+"ULL] = (etiss_uint64)(res);\n";cp.code()+="etiss_coverage_count(6, 9455, 9451, 9450, 9448, 9454, 9452);\n";cp.code()+="} // block\n";} } cp.code()+="} // block\n";} cp.code()+="instr_exit_"+std::to_string(ic.current_address_)+":\n";cp.code()+="cpu->instructionPointer = cpu->nextPc;\n";cp.getAffectedRegisters().add("instructionPointer", 32);} return true;}, 0, [](BitArray &ba, Instruction &instr) { etiss_uint8 rd=0;static BitArrayRange R_rd_0(11, 7);rd+=R_rd_0.read(ba)<< 0;etiss_uint8 rs1=0;static BitArrayRange R_rs1_0(19, 15);rs1+=R_rs1_0.read(ba)<< 0;etiss_uint8 rs2=0;static BitArrayRange R_rs2_0(24, 20);rs2+=R_rs2_0.read(ba)<< 0;std::stringstream ss;ss<< "mul"<< " # "<< ba<<(" [rd="+std::to_string(rd)+" | rs1="+std::to_string(rs1)+" | rs2="+std::to_string(rs2)+"]");return ss.str();})
Contains a small code snipped.
RegisterSet & getAffectedRegisters()
void append(const CodePart &part, CodePart::TYPE type)
void add(const RegisterPart &rp)
add a registerPart to the set or just its relevant bits if a register with the same name is already p...
Reading through it will only return bits within the range.
I read(const BitArray &ba)
reads bits from the range to the return value starting at the lsb.
this class contains parameters that persist in between instruction lookpus/translation within a trans...
uint64_t current_address_
start address of current instruction
holds information and translation callbacks for an instruction.