44 using namespace ArmISA;
50 printMnemonic(
ss,
"",
false);
60 printMnemonic(
ss,
"",
false);
61 printIntReg(
ss, dest);
73 printMnemonic(
ss,
"",
false);
74 printIntReg(
ss, dest);
97 if (
el <=
EL1 && checkEL1Trap(tc, misc_reg,
el,
ec, immediate)) {
98 return std::make_shared<SupervisorTrap>(machInst, immediate,
ec);
103 checkEL2Trap(tc, misc_reg,
el,
ec, immediate)) {
104 return std::make_shared<HypervisorTrap>(machInst, immediate,
ec);
109 checkEL3Trap(tc, misc_reg,
el,
ec, immediate)) {
110 return std::make_shared<SecureMonitorTrap>(machInst, immediate,
ec);
119 uint32_t &immediate)
const
126 bool trap_to_sup =
false;
129 trap_to_sup = !scr.ns && !scr.eel2 && !sctlr.uma &&
el ==
EL0;
130 trap_to_sup = trap_to_sup ||
131 (
el ==
EL0 && (scr.ns || scr.eel2) && !hcr.tge && !sctlr.uma);
140 trap_to_sup =
el ==
EL0 && !sctlr.uci;
145 if ((
el ==
EL0 && cpacr.fpen != 0x3) ||
146 (
el ==
EL1 && !(cpacr.fpen & 0x1))) {
149 immediate = 0x1E00000;
153 trap_to_sup = !sctlr.uci && (!hcr.tge || (!scr.ns && !scr.eel2)) &&
157 trap_to_sup =
el ==
EL0 && !sctlr.uct &&
158 (!hcr.tge || (!scr.ns && !scr.eel2));
163 trap_to_sup =
el ==
EL0 && mdscr.tdcc &&
164 (hcr.tge == 0x0 || ( scr.ns == 0x0));
168 trap_to_sup =
el ==
EL1 && ((cpacr.zen & 0x1) == 0x0);
172 trap_to_sup =
el ==
EL0 &&
184 uint32_t &immediate)
const
193 bool trap_to_hyp =
false;
203 if (isa->haveGICv3CpuIfc())
211 if (isa->haveGICv3CpuIfc())
219 bool from_el2 = (
el ==
EL2) && (scr.ns || scr.eel2) &&
221 ((!hcr.e2h && cptr.tfp) ||
222 (hcr.e2h && (cptr.fpen == 0x0 ||
224 bool from_el1 = (
el ==
EL1) && hcr.nv &&
225 (!hcr.e2h || (hcr.e2h && !hcr.tge));
226 trap_to_hyp = from_el2 || from_el1;
228 immediate = 0x1E00000;
246 bool tvm = miscRead? hcr.trvm: hcr.tvm;
266 (hcr.nv && (hcr.nv1 || !hcr.nv2));
308 if (
el ==
EL0 && el2_en) {
309 const bool in_host = hcr.e2h && hcr.tge;
310 const bool general_trap = el2_en && !in_host && hcr.tge &&
312 const bool tpu_trap = el2_en && !in_host && hcr.tpu;
313 const bool host_trap = el2_en && in_host && !sctlr2.uci;
314 trap_to_hyp = general_trap || tpu_trap || host_trap;
316 else if (
el ==
EL1 && el2_en) {
317 trap_to_hyp = hcr.tpu;
329 if (
el ==
EL0 && el2_en) {
331 const bool in_host = hcr.e2h && hcr.tge;
332 const bool general_trap = el2_en && !in_host && hcr.tge &&
334 const bool tpc_trap = el2_en && !in_host && hcr.tpc;
335 const bool host_trap = el2_en && in_host && !sctlr2.uci;
336 trap_to_hyp = general_trap || tpc_trap || host_trap;
337 }
else if (
el ==
EL1 && el2_en) {
338 trap_to_hyp = hcr.tpc;
398 if (
el ==
EL0 && el2_en) {
399 const bool in_host = hcr.e2h && hcr.tge;
400 const bool general_trap = el2_en && !in_host && hcr.tge &&
402 const bool tid_trap = el2_en && !in_host && hcr.tid2;
403 const bool host_trap = el2_en && in_host && !sctlr2.uct;
404 trap_to_hyp = general_trap || tid_trap || host_trap;
405 }
else if (
el ==
EL1 && el2_en) {
406 trap_to_hyp = hcr.tid2;
422 trap_to_hyp =
el <=
EL1 &&
427 (hcr.tge && (hcr.e2h || !sctlr.uma));
538 if (
el ==
EL0 && el2_en) {
539 const bool in_host = hcr.e2h && hcr.tge;
540 const bool general_trap = el2_en && !in_host && hcr.tge &&
542 const bool tdz_trap = el2_en && !in_host && hcr.tdz;
543 const bool host_trap = el2_en && in_host && !sctlr2.dze;
544 trap_to_hyp = general_trap || tdz_trap || host_trap;
545 }
else if (
el ==
EL1 && el2_en) {
546 trap_to_hyp = hcr.tdz;
620 ELIs64(tc,
EL2) && ((!hcr.e2h && cptr.tz) ||
621 (hcr.e2h && ((cptr.zen & 0x1) == 0x0)));
622 bool from_el2 = (
el ==
EL2) && ((!hcr.e2h && cptr.tz) ||
623 (hcr.e2h && ((cptr.zen & 0x1) == 0x0)));
624 trap_to_hyp = from_el1 || from_el2;
632 bool from_el2 = (
el ==
EL2) && ((!hcr.e2h && cptr.tz) ||
633 (hcr.e2h && ((cptr.zen & 0x1) == 0x0)));
634 trap_to_hyp = from_el1 || from_el2;
648 uint32_t &immediate)
const
654 bool trap_to_mon =
false;
661 trap_to_mon = cptr.tfp &&
ELIs64(tc,
EL3);
663 immediate = 0x1E00000;
669 (!hcr.nv2 || hcr.nv1 || !hcr.nv))) ;
676 trap_to_mon = cptr.tcpac;
700 trap_to_mon = (
el ==
EL1 ||
el ==
EL2) && scr.apk == 0 &&
705 trap_to_mon =
el ==
EL1 &&
778 trap_to_mon = !cptr.ez && ((
el ==
EL3) ||
784 trap_to_mon = !cptr.ez && ((
el ==
EL3) ||
790 trap_to_mon = !cptr.ez && (
el ==
EL3);
801 MiscRegImmOp64::miscRegImm()
const
806 return (
imm & 0x1) << 22;
808 panic(
"Not a valid PSTATE field register\n");
813 MiscRegImmOp64::generateDisassembly(
816 std::stringstream
ss;
818 printMiscReg(
ss, dest);
825 MiscRegRegImmOp64::generateDisassembly(
828 std::stringstream
ss;
830 printMiscReg(
ss, dest);
832 printIntReg(
ss, op1);
837 RegMiscRegImmOp64::generateDisassembly(
840 std::stringstream
ss;
842 printIntReg(
ss, dest);
844 printMiscReg(
ss, op1);
862 warn_once(
"\tinstruction '%s' unimplemented\n", fullMnemonic.c_str());
866 return std::make_shared<UndefinedInstruction>(machInst,
false,
872 MiscRegImplDefined64::generateDisassembly(
875 return csprintf(
"%-10s (implementation defined)", fullMnemonic.c_str());
879 RegNone::generateDisassembly(
882 std::stringstream
ss;
884 printIntReg(
ss, dest);