diff options
author | Korey Sewell <ksewell@umich.edu> | 2011-06-19 21:43:35 -0400 |
---|---|---|
committer | Korey Sewell <ksewell@umich.edu> | 2011-06-19 21:43:35 -0400 |
commit | 4f34bc8b7ba3ef73fa0511560869c7a22c1b187c (patch) | |
tree | f3ba76ca36f9660349886bc3f18cb2a0f0c4feb7 /src/cpu | |
parent | 946b0ed4f48e92b5286544369945c6a16663b590 (diff) | |
download | gem5-4f34bc8b7ba3ef73fa0511560869c7a22c1b187c.tar.xz |
inorder: make marking of dest. regs an explicit request
formerly, this was implicit when you accessed the execution unit
or the use-def unit but it's better that this just be something
that a user can specify.
Diffstat (limited to 'src/cpu')
-rw-r--r-- | src/cpu/inorder/cpu.cc | 1 | ||||
-rw-r--r-- | src/cpu/inorder/resources/execution_unit.cc | 12 | ||||
-rw-r--r-- | src/cpu/inorder/resources/use_def.cc | 13 | ||||
-rw-r--r-- | src/cpu/inorder/resources/use_def.hh | 3 |
4 files changed, 10 insertions, 19 deletions
diff --git a/src/cpu/inorder/cpu.cc b/src/cpu/inorder/cpu.cc index 9352d8e9d..ce3796528 100644 --- a/src/cpu/inorder/cpu.cc +++ b/src/cpu/inorder/cpu.cc @@ -419,6 +419,7 @@ InOrderCPU::createBackEndSked(DynInstPtr inst) } // EXECUTE + X.needs(RegManager, UseDefUnit::MarkDestRegs); for (int idx=0; idx < inst->numSrcRegs(); idx++) { if (!idx || !inst->isStore()) { X.needs(RegManager, UseDefUnit::ReadSrcReg, idx); diff --git a/src/cpu/inorder/resources/execution_unit.cc b/src/cpu/inorder/resources/execution_unit.cc index 8ea320b6b..ca1f4ade4 100644 --- a/src/cpu/inorder/resources/execution_unit.cc +++ b/src/cpu/inorder/resources/execution_unit.cc @@ -99,18 +99,6 @@ ExecutionUnit::execute(int slot_num) return; } - - //@todo: may want to make a separate schedule entry for setting - // destination register dependencies - //@note: typically want to set the output dependencies right - // before we do any reading or writing of registers - // (in RegFile Manager(use_def.cc)) but there are some - // instructions that dont have src regs, so just in case - // take care of reg. dep. map stuff here - if (!inst->isRegDepEntry()) { - regDepMap[tid]->insert(inst); - } - switch (exec_req->cmd) { case ExecuteInst: diff --git a/src/cpu/inorder/resources/use_def.cc b/src/cpu/inorder/resources/use_def.cc index 642998021..a66b64bfc 100644 --- a/src/cpu/inorder/resources/use_def.cc +++ b/src/cpu/inorder/resources/use_def.cc @@ -172,12 +172,6 @@ UseDefUnit::execute(int slot_idx) *nonSpecSeqNum[tid] = seq_num; } - //@todo: may want to make a separate schedule entry for setting - // destination register dependencies - if (!inst->isRegDepEntry()) { - regDepMap[tid]->insert(inst); - } - switch (ud_req->cmd) { case ReadSrcReg: @@ -446,6 +440,13 @@ UseDefUnit::execute(int slot_idx) } break; + case MarkDestRegs: + { + regDepMap[tid]->insert(inst); + ud_req->done(); + } + break; + default: fatal("Unrecognized command to %s", resName); } diff --git a/src/cpu/inorder/resources/use_def.hh b/src/cpu/inorder/resources/use_def.hh index 4c3eceef8..7e2a77469 100644 --- a/src/cpu/inorder/resources/use_def.hh +++ b/src/cpu/inorder/resources/use_def.hh @@ -50,7 +50,8 @@ class UseDefUnit : public Resource { enum Command { ReadSrcReg, - WriteDestReg + WriteDestReg, + MarkDestRegs }; public: |