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);