cpu: quiesce pseudoinsts: Always do full quiesce

The O3CPU blocks the Fetch when it sees a quiesce instruction (IsQuiesce flag).
When the inst. is executed, a quiesce event is created to reactivate the
context and unblock the Fetch.

If the quiesceNs or quiesceCycles are called with a value of 0, the
QuiesceEvent will not be created and the Fetch stage will remain blocked.


Committed by Joel Hestness <jthestness@gmail.com>
This commit is contained in:
Emilio Castillo 2015-08-26 14:20:30 -05:00
parent ce4f6a9020
commit 88b1fd82a6

View file

@ -280,7 +280,7 @@ quiesceNs(ThreadContext *tc, uint64_t ns)
BaseCPU *cpu = tc->getCpuPtr(); BaseCPU *cpu = tc->getCpuPtr();
if (!cpu->params()->do_quiesce || ns == 0) if (!cpu->params()->do_quiesce)
return; return;
EndQuiesceEvent *quiesceEvent = tc->getQuiesceEvent(); EndQuiesceEvent *quiesceEvent = tc->getQuiesceEvent();
@ -306,7 +306,7 @@ quiesceCycles(ThreadContext *tc, uint64_t cycles)
BaseCPU *cpu = tc->getCpuPtr(); BaseCPU *cpu = tc->getCpuPtr();
if (!cpu->params()->do_quiesce || cycles == 0) if (!cpu->params()->do_quiesce)
return; return;
EndQuiesceEvent *quiesceEvent = tc->getQuiesceEvent(); EndQuiesceEvent *quiesceEvent = tc->getQuiesceEvent();