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;