32rd += R_rd_0.
read(ba) << 0;
35rs1 += R_rs1_0.
read(ba) << 0;
38csr += R_csr_0.
read(ba) << 0;
46 cp.
code() = std::string(
"//CSRRW\n");
49cp.
code() +=
"etiss_coverage_count(1, 153);\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, 6390);\n";
59cp.
code() +=
"{ // block\n";
60cp.
code() +=
"etiss_uint64 xrs1 = *((RV64IMACFD*)cpu)->X[" + std::to_string(rs1 % 32ULL) +
"ULL];\n";
61cp.
code() +=
"etiss_coverage_count(4, 6363, 6362, 6361, 6359);\n";
62cp.
code() +=
"etiss_coverage_count(1, 6364);\n";
63if ((rd % 32ULL) != 0LL) {
64cp.
code() +=
"etiss_coverage_count(5, 6370, 6367, 6365, 6368, 6369);\n";
66cp.
code() +=
"etiss_coverage_count(1, 6385);\n";
67cp.
code() +=
"{ // block\n";
68cp.
code() +=
"etiss_uint64 xrd = RV64IMACFD_csr_read(cpu, system, plugin_pointers, " + std::to_string(csr) +
"ULL);\n";
69cp.
code() +=
"etiss_coverage_count(3, 6374, 6373, 6372);\n";
70cp.
code() +=
"RV64IMACFD_csr_write(cpu, system, plugin_pointers, " + std::to_string(csr) +
"ULL, xrs1);\n";
71cp.
code() +=
"etiss_coverage_count(3, 6377, 6375, 6376);\n";
72cp.
code() +=
"*((RV64IMACFD*)cpu)->X[" + std::to_string(rd % 32ULL) +
"ULL] = xrd;\n";
73cp.
code() +=
"etiss_coverage_count(5, 6384, 6382, 6381, 6379, 6383);\n";
74cp.
code() +=
"} // block\n";
79cp.
code() +=
"etiss_coverage_count(1, 6389);\n";
80cp.
code() +=
"{ // block\n";
81cp.
code() +=
"RV64IMACFD_csr_write(cpu, system, plugin_pointers, " + std::to_string(csr) +
"ULL, xrs1);\n";
82cp.
code() +=
"etiss_coverage_count(3, 6388, 6386, 6387);\n";
83cp.
code() +=
"} // block\n";
86cp.
code() +=
"} // block\n";
89cp.
code() +=
"cpu->instructionPointer = cpu->nextPc;\n";
102rd += R_rd_0.read(ba) << 0;
105rs1 += R_rs1_0.read(ba) << 0;
108csr += R_csr_0.read(ba) << 0;
112 std::stringstream ss;
114ss <<
"csrrw" <<
" # " << ba << (
" [rd=" + std::to_string(rd) +
" | rs1=" + std::to_string(rs1) +
" | csr=" + std::to_string(csr) +
"]");
137rd += R_rd_0.
read(ba) << 0;
140rs1 += R_rs1_0.
read(ba) << 0;
143csr += R_csr_0.
read(ba) << 0;
151 cp.
code() = std::string(
"//CSRRS\n");
154cp.
code() +=
"etiss_coverage_count(1, 154);\n";
156cp.
code() +=
"etiss_coverage_count(1, 1189);\n";
157cp.
code() +=
"{ // block\n";
159cp.
code() +=
"etiss_coverage_count(7, 1188, 1181, 1187, 1184, 1182, 1183, 1185);\n";
160cp.
code() +=
"} // block\n";
163cp.
code() +=
"etiss_coverage_count(1, 6425);\n";
164cp.
code() +=
"{ // block\n";
165cp.
code() +=
"etiss_uint64 xrd = RV64IMACFD_csr_read(cpu, system, plugin_pointers, " + std::to_string(csr) +
"ULL);\n";
166cp.
code() +=
"etiss_coverage_count(3, 6394, 6393, 6392);\n";
167cp.
code() +=
"etiss_uint64 xrs1 = *((RV64IMACFD*)cpu)->X[" + std::to_string(rs1 % 32ULL) +
"ULL];\n";
168cp.
code() +=
"etiss_coverage_count(4, 6401, 6400, 6399, 6397);\n";
169cp.
code() +=
"etiss_coverage_count(1, 6402);\n";
171cp.
code() +=
"etiss_coverage_count(3, 6405, 6403, 6404);\n";
172cp.
code() +=
"RV64IMACFD_csr_write(cpu, system, plugin_pointers, " + std::to_string(csr) +
"ULL, xrd | xrs1);\n";
173cp.
code() +=
"etiss_coverage_count(5, 6410, 6406, 6409, 6407, 6408);\n";
175cp.
code() +=
"etiss_coverage_count(1, 6411);\n";
176if ((rd % 32ULL) != 0LL) {
177cp.
code() +=
"etiss_coverage_count(5, 6417, 6414, 6412, 6415, 6416);\n";
178cp.
code() +=
"*((RV64IMACFD*)cpu)->X[" + std::to_string(rd % 32ULL) +
"ULL] = xrd;\n";
179cp.
code() +=
"etiss_coverage_count(5, 6424, 6422, 6421, 6419, 6423);\n";
181cp.
code() +=
"} // block\n";
184cp.
code() +=
"cpu->instructionPointer = cpu->nextPc;\n";
197rd += R_rd_0.read(ba) << 0;
200rs1 += R_rs1_0.read(ba) << 0;
203csr += R_csr_0.read(ba) << 0;
207 std::stringstream ss;
209ss <<
"csrrs" <<
" # " << ba << (
" [rd=" + std::to_string(rd) +
" | rs1=" + std::to_string(rs1) +
" | csr=" + std::to_string(csr) +
"]");
232rd += R_rd_0.
read(ba) << 0;
235rs1 += R_rs1_0.
read(ba) << 0;
238csr += R_csr_0.
read(ba) << 0;
246 cp.
code() = std::string(
"//CSRRC\n");
249cp.
code() +=
"etiss_coverage_count(1, 155);\n";
251cp.
code() +=
"etiss_coverage_count(1, 1189);\n";
252cp.
code() +=
"{ // block\n";
254cp.
code() +=
"etiss_coverage_count(7, 1188, 1181, 1187, 1184, 1182, 1183, 1185);\n";
255cp.
code() +=
"} // block\n";
258cp.
code() +=
"etiss_coverage_count(1, 6461);\n";
259cp.
code() +=
"{ // block\n";
260cp.
code() +=
"etiss_uint64 xrd = RV64IMACFD_csr_read(cpu, system, plugin_pointers, " + std::to_string(csr) +
"ULL);\n";
261cp.
code() +=
"etiss_coverage_count(3, 6429, 6428, 6427);\n";
262cp.
code() +=
"etiss_uint64 xrs1 = *((RV64IMACFD*)cpu)->X[" + std::to_string(rs1 % 32ULL) +
"ULL];\n";
263cp.
code() +=
"etiss_coverage_count(4, 6436, 6435, 6434, 6432);\n";
264cp.
code() +=
"etiss_coverage_count(1, 6437);\n";
266cp.
code() +=
"etiss_coverage_count(3, 6440, 6438, 6439);\n";
267cp.
code() +=
"RV64IMACFD_csr_write(cpu, system, plugin_pointers, " + std::to_string(csr) +
"ULL, xrd & ~(xrs1));\n";
268cp.
code() +=
"etiss_coverage_count(6, 6446, 6441, 6445, 6442, 6444, 6443);\n";
270cp.
code() +=
"etiss_coverage_count(1, 6447);\n";
271if ((rd % 32ULL) != 0LL) {
272cp.
code() +=
"etiss_coverage_count(5, 6453, 6450, 6448, 6451, 6452);\n";
273cp.
code() +=
"*((RV64IMACFD*)cpu)->X[" + std::to_string(rd % 32ULL) +
"ULL] = xrd;\n";
274cp.
code() +=
"etiss_coverage_count(5, 6460, 6458, 6457, 6455, 6459);\n";
276cp.
code() +=
"} // block\n";
279cp.
code() +=
"cpu->instructionPointer = cpu->nextPc;\n";
292rd += R_rd_0.read(ba) << 0;
295rs1 += R_rs1_0.read(ba) << 0;
298csr += R_csr_0.read(ba) << 0;
302 std::stringstream ss;
304ss <<
"csrrc" <<
" # " << ba << (
" [rd=" + std::to_string(rd) +
" | rs1=" + std::to_string(rs1) +
" | csr=" + std::to_string(csr) +
"]");
327rd += R_rd_0.
read(ba) << 0;
330zimm += R_zimm_0.
read(ba) << 0;
333csr += R_csr_0.
read(ba) << 0;
341 cp.
code() = std::string(
"//CSRRWI\n");
344cp.
code() +=
"etiss_coverage_count(1, 156);\n";
346cp.
code() +=
"etiss_coverage_count(1, 1189);\n";
347cp.
code() +=
"{ // block\n";
349cp.
code() +=
"etiss_coverage_count(7, 1188, 1181, 1187, 1184, 1182, 1183, 1185);\n";
350cp.
code() +=
"} // block\n";
353cp.
code() +=
"etiss_coverage_count(1, 6485);\n";
354cp.
code() +=
"{ // block\n";
355cp.
code() +=
"etiss_uint64 xrd = RV64IMACFD_csr_read(cpu, system, plugin_pointers, " + std::to_string(csr) +
"ULL);\n";
356cp.
code() +=
"etiss_coverage_count(3, 6465, 6464, 6463);\n";
357cp.
code() +=
"RV64IMACFD_csr_write(cpu, system, plugin_pointers, " + std::to_string(csr) +
"ULL, " + std::to_string((
etiss_uint64)(zimm)) +
"ULL);\n";
358cp.
code() +=
"etiss_coverage_count(4, 6470, 6466, 6469, 6467);\n";
359cp.
code() +=
"etiss_coverage_count(1, 6471);\n";
360if ((rd % 32ULL) != 0LL) {
361cp.
code() +=
"etiss_coverage_count(5, 6477, 6474, 6472, 6475, 6476);\n";
362cp.
code() +=
"*((RV64IMACFD*)cpu)->X[" + std::to_string(rd % 32ULL) +
"ULL] = xrd;\n";
363cp.
code() +=
"etiss_coverage_count(5, 6484, 6482, 6481, 6479, 6483);\n";
365cp.
code() +=
"} // block\n";
368cp.
code() +=
"cpu->instructionPointer = cpu->nextPc;\n";
381rd += R_rd_0.read(ba) << 0;
384zimm += R_zimm_0.read(ba) << 0;
387csr += R_csr_0.read(ba) << 0;
391 std::stringstream ss;
393ss <<
"csrrwi" <<
" # " << ba << (
" [rd=" + std::to_string(rd) +
" | zimm=" + std::to_string(zimm) +
" | csr=" + std::to_string(csr) +
"]");
416rd += R_rd_0.
read(ba) << 0;
419zimm += R_zimm_0.
read(ba) << 0;
422csr += R_csr_0.
read(ba) << 0;
430 cp.
code() = std::string(
"//CSRRSI\n");
433cp.
code() +=
"etiss_coverage_count(1, 157);\n";
435cp.
code() +=
"etiss_coverage_count(1, 1189);\n";
436cp.
code() +=
"{ // block\n";
438cp.
code() +=
"etiss_coverage_count(7, 1188, 1181, 1187, 1184, 1182, 1183, 1185);\n";
439cp.
code() +=
"} // block\n";
442cp.
code() +=
"etiss_coverage_count(1, 6515);\n";
443cp.
code() +=
"{ // block\n";
444cp.
code() +=
"etiss_uint64 xrd = RV64IMACFD_csr_read(cpu, system, plugin_pointers, " + std::to_string(csr) +
"ULL);\n";
445cp.
code() +=
"etiss_coverage_count(3, 6489, 6488, 6487);\n";
446cp.
code() +=
"etiss_coverage_count(1, 6490);\n";
448cp.
code() +=
"etiss_coverage_count(3, 6493, 6491, 6492);\n";
449cp.
code() +=
"RV64IMACFD_csr_write(cpu, system, plugin_pointers, " + std::to_string(csr) +
"ULL, xrd | " + std::to_string((
etiss_uint64)(zimm)) +
"ULL);\n";
450cp.
code() +=
"etiss_coverage_count(6, 6500, 6494, 6499, 6495, 6498, 6496);\n";
452cp.
code() +=
"etiss_coverage_count(1, 6501);\n";
453if ((rd % 32ULL) != 0LL) {
454cp.
code() +=
"etiss_coverage_count(5, 6507, 6504, 6502, 6505, 6506);\n";
455cp.
code() +=
"*((RV64IMACFD*)cpu)->X[" + std::to_string(rd % 32ULL) +
"ULL] = xrd;\n";
456cp.
code() +=
"etiss_coverage_count(5, 6514, 6512, 6511, 6509, 6513);\n";
458cp.
code() +=
"} // block\n";
461cp.
code() +=
"cpu->instructionPointer = cpu->nextPc;\n";
474rd += R_rd_0.read(ba) << 0;
477zimm += R_zimm_0.read(ba) << 0;
480csr += R_csr_0.read(ba) << 0;
484 std::stringstream ss;
486ss <<
"csrrsi" <<
" # " << ba << (
" [rd=" + std::to_string(rd) +
" | zimm=" + std::to_string(zimm) +
" | csr=" + std::to_string(csr) +
"]");
509rd += R_rd_0.
read(ba) << 0;
512zimm += R_zimm_0.
read(ba) << 0;
515csr += R_csr_0.
read(ba) << 0;
523 cp.
code() = std::string(
"//CSRRCI\n");
526cp.
code() +=
"etiss_coverage_count(1, 158);\n";
528cp.
code() +=
"etiss_coverage_count(1, 1189);\n";
529cp.
code() +=
"{ // block\n";
531cp.
code() +=
"etiss_coverage_count(7, 1188, 1181, 1187, 1184, 1182, 1183, 1185);\n";
532cp.
code() +=
"} // block\n";
535cp.
code() +=
"etiss_coverage_count(1, 6547);\n";
536cp.
code() +=
"{ // block\n";
537cp.
code() +=
"etiss_uint64 xrd = RV64IMACFD_csr_read(cpu, system, plugin_pointers, " + std::to_string(csr) +
"ULL);\n";
538cp.
code() +=
"etiss_coverage_count(3, 6519, 6518, 6517);\n";
539cp.
code() +=
"etiss_coverage_count(1, 6520);\n";
541cp.
code() +=
"etiss_coverage_count(3, 6523, 6521, 6522);\n";
542cp.
code() +=
"RV64IMACFD_csr_write(cpu, system, plugin_pointers, " + std::to_string(csr) +
"ULL, xrd & " + std::to_string(~(((
etiss_uint64)(zimm)))) +
"ULL);\n";
543cp.
code() +=
"etiss_coverage_count(8, 6532, 6524, 6531, 6525, 6530, 6528, 6526, 6529);\n";
545cp.
code() +=
"etiss_coverage_count(1, 6533);\n";
546if ((rd % 32ULL) != 0LL) {
547cp.
code() +=
"etiss_coverage_count(5, 6539, 6536, 6534, 6537, 6538);\n";
548cp.
code() +=
"*((RV64IMACFD*)cpu)->X[" + std::to_string(rd % 32ULL) +
"ULL] = xrd;\n";
549cp.
code() +=
"etiss_coverage_count(5, 6546, 6544, 6543, 6541, 6545);\n";
551cp.
code() +=
"} // block\n";
554cp.
code() +=
"cpu->instructionPointer = cpu->nextPc;\n";
567rd += R_rd_0.read(ba) << 0;
570zimm += R_zimm_0.read(ba) << 0;
573csr += R_csr_0.read(ba) << 0;
577 std::stringstream ss;
579ss <<
"csrrci" <<
" # " << ba << (
" [rd=" + std::to_string(rd) +
" | zimm=" + std::to_string(zimm) +
" | csr=" + std::to_string(csr) +
"]");
etiss::instr::InstructionGroup ISA32_RV64IMACFD("ISA32_RV64IMACFD", 32)
static InstructionDefinition csrrs_rd_rs1_csr(ISA32_RV64IMACFD, "csrrs",(uint64_t) 0x002073,(uint64_t) 0x00707f, [](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_uint16 csr=0;static BitArrayRange R_csr_0(31, 20);csr+=R_csr_0.read(ba)<< 0;{ CodePart &cp=cs.append(CodePart::INITIALREQUIRED);cp.code()=std::string("//CSRRS\n");cp.code()+="etiss_coverage_count(1, 154);\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, 6425);\n";cp.code()+="{ // block\n";cp.code()+="etiss_uint64 xrd = RV64IMACFD_csr_read(cpu, system, plugin_pointers, "+std::to_string(csr)+"ULL);\n";cp.code()+="etiss_coverage_count(3, 6394, 6393, 6392);\n";cp.code()+="etiss_uint64 xrs1 = *((RV64IMACFD*)cpu)->X["+std::to_string(rs1 % 32ULL)+"ULL];\n";cp.code()+="etiss_coverage_count(4, 6401, 6400, 6399, 6397);\n";cp.code()+="etiss_coverage_count(1, 6402);\n";if(rs1 !=0LL) { cp.code()+="etiss_coverage_count(3, 6405, 6403, 6404);\n";cp.code()+="RV64IMACFD_csr_write(cpu, system, plugin_pointers, "+std::to_string(csr)+"ULL, xrd | xrs1);\n";cp.code()+="etiss_coverage_count(5, 6410, 6406, 6409, 6407, 6408);\n";} cp.code()+="etiss_coverage_count(1, 6411);\n";if((rd % 32ULL) !=0LL) { cp.code()+="etiss_coverage_count(5, 6417, 6414, 6412, 6415, 6416);\n";cp.code()+="*((RV64IMACFD*)cpu)->X["+std::to_string(rd % 32ULL)+"ULL] = xrd;\n";cp.code()+="etiss_coverage_count(5, 6424, 6422, 6421, 6419, 6423);\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_uint16 csr=0;static BitArrayRange R_csr_0(31, 20);csr+=R_csr_0.read(ba)<< 0;std::stringstream ss;ss<< "csrrs"<< " # "<< ba<<(" [rd="+std::to_string(rd)+" | rs1="+std::to_string(rs1)+" | csr="+std::to_string(csr)+"]");return ss.str();})
static InstructionDefinition csrrw_rd_rs1_csr(ISA32_RV64IMACFD, "csrrw",(uint64_t) 0x001073,(uint64_t) 0x00707f, [](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_uint16 csr=0;static BitArrayRange R_csr_0(31, 20);csr+=R_csr_0.read(ba)<< 0;{ CodePart &cp=cs.append(CodePart::INITIALREQUIRED);cp.code()=std::string("//CSRRW\n");cp.code()+="etiss_coverage_count(1, 153);\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, 6390);\n";cp.code()+="{ // block\n";cp.code()+="etiss_uint64 xrs1 = *((RV64IMACFD*)cpu)->X["+std::to_string(rs1 % 32ULL)+"ULL];\n";cp.code()+="etiss_coverage_count(4, 6363, 6362, 6361, 6359);\n";cp.code()+="etiss_coverage_count(1, 6364);\n";if((rd % 32ULL) !=0LL) { cp.code()+="etiss_coverage_count(5, 6370, 6367, 6365, 6368, 6369);\n";{ cp.code()+="etiss_coverage_count(1, 6385);\n";cp.code()+="{ // block\n";cp.code()+="etiss_uint64 xrd = RV64IMACFD_csr_read(cpu, system, plugin_pointers, "+std::to_string(csr)+"ULL);\n";cp.code()+="etiss_coverage_count(3, 6374, 6373, 6372);\n";cp.code()+="RV64IMACFD_csr_write(cpu, system, plugin_pointers, "+std::to_string(csr)+"ULL, xrs1);\n";cp.code()+="etiss_coverage_count(3, 6377, 6375, 6376);\n";cp.code()+="*((RV64IMACFD*)cpu)->X["+std::to_string(rd % 32ULL)+"ULL] = xrd;\n";cp.code()+="etiss_coverage_count(5, 6384, 6382, 6381, 6379, 6383);\n";cp.code()+="} // block\n";} } else { { cp.code()+="etiss_coverage_count(1, 6389);\n";cp.code()+="{ // block\n";cp.code()+="RV64IMACFD_csr_write(cpu, system, plugin_pointers, "+std::to_string(csr)+"ULL, xrs1);\n";cp.code()+="etiss_coverage_count(3, 6388, 6386, 6387);\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_uint16 csr=0;static BitArrayRange R_csr_0(31, 20);csr+=R_csr_0.read(ba)<< 0;std::stringstream ss;ss<< "csrrw"<< " # "<< ba<<(" [rd="+std::to_string(rd)+" | rs1="+std::to_string(rs1)+" | csr="+std::to_string(csr)+"]");return ss.str();})
static InstructionDefinition csrrc_rd_rs1_csr(ISA32_RV64IMACFD, "csrrc",(uint64_t) 0x003073,(uint64_t) 0x00707f, [](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_uint16 csr=0;static BitArrayRange R_csr_0(31, 20);csr+=R_csr_0.read(ba)<< 0;{ CodePart &cp=cs.append(CodePart::INITIALREQUIRED);cp.code()=std::string("//CSRRC\n");cp.code()+="etiss_coverage_count(1, 155);\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, 6461);\n";cp.code()+="{ // block\n";cp.code()+="etiss_uint64 xrd = RV64IMACFD_csr_read(cpu, system, plugin_pointers, "+std::to_string(csr)+"ULL);\n";cp.code()+="etiss_coverage_count(3, 6429, 6428, 6427);\n";cp.code()+="etiss_uint64 xrs1 = *((RV64IMACFD*)cpu)->X["+std::to_string(rs1 % 32ULL)+"ULL];\n";cp.code()+="etiss_coverage_count(4, 6436, 6435, 6434, 6432);\n";cp.code()+="etiss_coverage_count(1, 6437);\n";if(rs1 !=0LL) { cp.code()+="etiss_coverage_count(3, 6440, 6438, 6439);\n";cp.code()+="RV64IMACFD_csr_write(cpu, system, plugin_pointers, "+std::to_string(csr)+"ULL, xrd & ~(xrs1));\n";cp.code()+="etiss_coverage_count(6, 6446, 6441, 6445, 6442, 6444, 6443);\n";} cp.code()+="etiss_coverage_count(1, 6447);\n";if((rd % 32ULL) !=0LL) { cp.code()+="etiss_coverage_count(5, 6453, 6450, 6448, 6451, 6452);\n";cp.code()+="*((RV64IMACFD*)cpu)->X["+std::to_string(rd % 32ULL)+"ULL] = xrd;\n";cp.code()+="etiss_coverage_count(5, 6460, 6458, 6457, 6455, 6459);\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_uint16 csr=0;static BitArrayRange R_csr_0(31, 20);csr+=R_csr_0.read(ba)<< 0;std::stringstream ss;ss<< "csrrc"<< " # "<< ba<<(" [rd="+std::to_string(rd)+" | rs1="+std::to_string(rs1)+" | csr="+std::to_string(csr)+"]");return ss.str();})
static InstructionDefinition csrrsi_rd_zimm_csr(ISA32_RV64IMACFD, "csrrsi",(uint64_t) 0x006073,(uint64_t) 0x00707f, [](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 zimm=0;static BitArrayRange R_zimm_0(19, 15);zimm+=R_zimm_0.read(ba)<< 0;etiss_uint16 csr=0;static BitArrayRange R_csr_0(31, 20);csr+=R_csr_0.read(ba)<< 0;{ CodePart &cp=cs.append(CodePart::INITIALREQUIRED);cp.code()=std::string("//CSRRSI\n");cp.code()+="etiss_coverage_count(1, 157);\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, 6515);\n";cp.code()+="{ // block\n";cp.code()+="etiss_uint64 xrd = RV64IMACFD_csr_read(cpu, system, plugin_pointers, "+std::to_string(csr)+"ULL);\n";cp.code()+="etiss_coverage_count(3, 6489, 6488, 6487);\n";cp.code()+="etiss_coverage_count(1, 6490);\n";if(zimm !=0LL) { cp.code()+="etiss_coverage_count(3, 6493, 6491, 6492);\n";cp.code()+="RV64IMACFD_csr_write(cpu, system, plugin_pointers, "+std::to_string(csr)+"ULL, xrd | "+std::to_string((etiss_uint64)(zimm))+"ULL);\n";cp.code()+="etiss_coverage_count(6, 6500, 6494, 6499, 6495, 6498, 6496);\n";} cp.code()+="etiss_coverage_count(1, 6501);\n";if((rd % 32ULL) !=0LL) { cp.code()+="etiss_coverage_count(5, 6507, 6504, 6502, 6505, 6506);\n";cp.code()+="*((RV64IMACFD*)cpu)->X["+std::to_string(rd % 32ULL)+"ULL] = xrd;\n";cp.code()+="etiss_coverage_count(5, 6514, 6512, 6511, 6509, 6513);\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 zimm=0;static BitArrayRange R_zimm_0(19, 15);zimm+=R_zimm_0.read(ba)<< 0;etiss_uint16 csr=0;static BitArrayRange R_csr_0(31, 20);csr+=R_csr_0.read(ba)<< 0;std::stringstream ss;ss<< "csrrsi"<< " # "<< ba<<(" [rd="+std::to_string(rd)+" | zimm="+std::to_string(zimm)+" | csr="+std::to_string(csr)+"]");return ss.str();})
static InstructionDefinition csrrwi_rd_zimm_csr(ISA32_RV64IMACFD, "csrrwi",(uint64_t) 0x005073,(uint64_t) 0x00707f, [](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 zimm=0;static BitArrayRange R_zimm_0(19, 15);zimm+=R_zimm_0.read(ba)<< 0;etiss_uint16 csr=0;static BitArrayRange R_csr_0(31, 20);csr+=R_csr_0.read(ba)<< 0;{ CodePart &cp=cs.append(CodePart::INITIALREQUIRED);cp.code()=std::string("//CSRRWI\n");cp.code()+="etiss_coverage_count(1, 156);\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, 6485);\n";cp.code()+="{ // block\n";cp.code()+="etiss_uint64 xrd = RV64IMACFD_csr_read(cpu, system, plugin_pointers, "+std::to_string(csr)+"ULL);\n";cp.code()+="etiss_coverage_count(3, 6465, 6464, 6463);\n";cp.code()+="RV64IMACFD_csr_write(cpu, system, plugin_pointers, "+std::to_string(csr)+"ULL, "+std::to_string((etiss_uint64)(zimm))+"ULL);\n";cp.code()+="etiss_coverage_count(4, 6470, 6466, 6469, 6467);\n";cp.code()+="etiss_coverage_count(1, 6471);\n";if((rd % 32ULL) !=0LL) { cp.code()+="etiss_coverage_count(5, 6477, 6474, 6472, 6475, 6476);\n";cp.code()+="*((RV64IMACFD*)cpu)->X["+std::to_string(rd % 32ULL)+"ULL] = xrd;\n";cp.code()+="etiss_coverage_count(5, 6484, 6482, 6481, 6479, 6483);\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 zimm=0;static BitArrayRange R_zimm_0(19, 15);zimm+=R_zimm_0.read(ba)<< 0;etiss_uint16 csr=0;static BitArrayRange R_csr_0(31, 20);csr+=R_csr_0.read(ba)<< 0;std::stringstream ss;ss<< "csrrwi"<< " # "<< ba<<(" [rd="+std::to_string(rd)+" | zimm="+std::to_string(zimm)+" | csr="+std::to_string(csr)+"]");return ss.str();})
static InstructionDefinition csrrci_rd_zimm_csr(ISA32_RV64IMACFD, "csrrci",(uint64_t) 0x007073,(uint64_t) 0x00707f, [](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 zimm=0;static BitArrayRange R_zimm_0(19, 15);zimm+=R_zimm_0.read(ba)<< 0;etiss_uint16 csr=0;static BitArrayRange R_csr_0(31, 20);csr+=R_csr_0.read(ba)<< 0;{ CodePart &cp=cs.append(CodePart::INITIALREQUIRED);cp.code()=std::string("//CSRRCI\n");cp.code()+="etiss_coverage_count(1, 158);\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, 6547);\n";cp.code()+="{ // block\n";cp.code()+="etiss_uint64 xrd = RV64IMACFD_csr_read(cpu, system, plugin_pointers, "+std::to_string(csr)+"ULL);\n";cp.code()+="etiss_coverage_count(3, 6519, 6518, 6517);\n";cp.code()+="etiss_coverage_count(1, 6520);\n";if(zimm !=0LL) { cp.code()+="etiss_coverage_count(3, 6523, 6521, 6522);\n";cp.code()+="RV64IMACFD_csr_write(cpu, system, plugin_pointers, "+std::to_string(csr)+"ULL, xrd & "+std::to_string(~(((etiss_uint64)(zimm))))+"ULL);\n";cp.code()+="etiss_coverage_count(8, 6532, 6524, 6531, 6525, 6530, 6528, 6526, 6529);\n";} cp.code()+="etiss_coverage_count(1, 6533);\n";if((rd % 32ULL) !=0LL) { cp.code()+="etiss_coverage_count(5, 6539, 6536, 6534, 6537, 6538);\n";cp.code()+="*((RV64IMACFD*)cpu)->X["+std::to_string(rd % 32ULL)+"ULL] = xrd;\n";cp.code()+="etiss_coverage_count(5, 6546, 6544, 6543, 6541, 6545);\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 zimm=0;static BitArrayRange R_zimm_0(19, 15);zimm+=R_zimm_0.read(ba)<< 0;etiss_uint16 csr=0;static BitArrayRange R_csr_0(31, 20);csr+=R_csr_0.read(ba)<< 0;std::stringstream ss;ss<< "csrrci"<< " # "<< ba<<(" [rd="+std::to_string(rd)+" | zimm="+std::to_string(zimm)+" | csr="+std::to_string(csr)+"]");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.