From: Korey Sewell Date: Fri, 18 Feb 2011 19:30:38 +0000 (-0500) Subject: inorder: ignore nops in execution unit X-Git-Tag: stable_2012_02_02~553^2~5 X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=64d31e75b960f08de57cf78f8bdc793d1135c5cd;p=gem5.git inorder: ignore nops in execution unit --- diff --git a/src/cpu/inorder/resources/execution_unit.cc b/src/cpu/inorder/resources/execution_unit.cc index e4d0c20b9..b2540cff8 100644 --- a/src/cpu/inorder/resources/execution_unit.cc +++ b/src/cpu/inorder/resources/execution_unit.cc @@ -101,8 +101,17 @@ ExecutionUnit::execute(int slot_num) { case ExecuteInst: { - DPRINTF(InOrderExecute, "[tid:%i] Executing [sn:%i] [PC:%s] %s.\n", - inst->readTid(), seq_num, inst->pcState(), inst->instName()); + if (inst->isNop()) { + DPRINTF(InOrderExecute, "[tid:%i] [sn:%i] [PC:%s] Ignoring execution" + "of %s.\n", inst->readTid(), seq_num, inst->pcState(), + inst->instName()); + inst->setExecuted(); + exec_req->done(); + return; + } else { + DPRINTF(InOrderExecute, "[tid:%i] Executing [sn:%i] [PC:%s] %s.\n", + inst->readTid(), seq_num, inst->pcState(), inst->instName()); + } if (cur_tick != lastExecuteTick) { lastExecuteTick = cur_tick;