29 #ifndef __ARCH_MIPS_MT_HH__ 
   30 #define __ARCH_MIPS_MT_HH__ 
   66     switch (
reg.classValue()) {
 
   76         panic(
"Unexpected reg class! (%s)", 
reg.className());
 
   90     switch (
reg.classValue()) {
 
  100         panic(
"Unexpected reg class! (%s)", 
reg.className());
 
  123     return tcbind.curVPE;
 
  131     return vpeCtrl.targTC;
 
  138     if (tc->status() == TC::Active) {
 
  144         auto &
pc = tc->pcState().template as<MipsISA::PCState>();
 
  147         warn(
"%i: Halting thread %i in %s @ PC %x, setting restart PC to %x",
 
  148                 curTick(), tc->threadId(), tc->getCpuPtr()->name(),
 
  157     if (tc->status() != TC::Active) {
 
  162         tc->pcState(restartPC);
 
  165         warn(
"%i: Restoring thread %i in %s @ PC %x",
 
  166                 curTick(), tc->threadId(), tc->getCpuPtr()->name(), restartPC);
 
  175     int num_threads = mvpConf.ptc + 1;
 
  178     for (
ThreadID tid = 0; tid < num_threads && success == 0; tid++) {
 
  179         TCBindReg tidTCBind =
 
  183         if (tidTCBind.curVPE == tcBind.curVPE) {
 
  185             TCStatusReg tidTCStatus =
 
  189             TCHaltReg tidTCHalt =
 
  193             if (tidTCStatus.da == 1 && tidTCHalt.h == 0 &&
 
  194                 tidTCStatus.a == 0 && success == 0) {
 
  204                 tidTCStatus.rnst = 0;
 
  212                 tidTCStatus.tksu = 
status.ksu;
 
  214                 tidTCStatus.asid = tcStatus.asid;
 
  224             std::cerr << 
"Bad VPEs" << std::endl;
 
  229         VPEControlReg vpeControl =
 
  231         vpeControl.excpt = 1;
 
  233         fault = std::make_shared<ThreadFault>();
 
  244         ThreadID num_threads = mvpConf0.ptc + 1;
 
  251         for (
ThreadID tid = 0; tid < num_threads; tid++) {
 
  252             TCStatusReg tidTCStatus =
 
  255             TCHaltReg tidTCHalt =
 
  258             TCBindReg tidTCBind =
 
  262             if (tidTCBind.curVPE == tcBind.curVPE &&
 
  263                 tidTCBind.curTC == tcBind.curTC &&
 
  264                 tidTCStatus.da == 1 &&
 
  266                 tidTCStatus.a == 1) {
 
  275             warn(
"%i: Deactivating Hardware Thread Context #%i",
 
  278     } 
else if (src_reg > 0) {
 
  279         if ((src_reg & ~yield_mask) != 0) {
 
  281             vpeControl.excpt = 2;
 
  283             fault = std::make_shared<ThreadFault>();
 
  286     } 
else if (src_reg != -2) {
 
  288         VPEControlReg vpeControl =
 
  291         if (vpeControl.ysi == 1 && tcStatus.dt == 1 ) {
 
  292             vpeControl.excpt = 4;
 
  293             fault = std::make_shared<ThreadFault>();
 
  298     return src_reg & yield_mask;
 
  315     status.ksu = tcStatus.tksu;
 
  333     tcStatus.tksu = 
status.ksu;