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 | 061b369d288ba4e3fdb145c025fb4d80378cb851 (patch) | |
tree | 2e027ce597f6798394d9114c24f2477d7db8597c /src | |
parent | b195da9345c00c2961558f80715660c0c0a629fc (diff) | |
download | gem5-061b369d288ba4e3fdb145c025fb4d80378cb851.tar.xz |
inorder: cleanup intercomm. structs/squash info
Diffstat (limited to 'src')
-rw-r--r-- | src/cpu/inorder/comm.hh | 49 |
1 files changed, 5 insertions, 44 deletions
diff --git a/src/cpu/inorder/comm.hh b/src/cpu/inorder/comm.hh index ba9322079..b05ec4eff 100644 --- a/src/cpu/inorder/comm.hh +++ b/src/cpu/inorder/comm.hh @@ -44,62 +44,23 @@ /** Struct that defines the information passed from in between stages */ /** This information mainly goes forward through the pipeline. */ struct InterStageStruct { + //@todo: probably should make this a list since the amount of + // instructions that get passed forward per cycle is + // really dependent on issue width, CPI, etc. std::vector<ThePipeline::DynInstPtr> insts; - bool squash; - bool branchMispredict; - bool branchTaken; - uint64_t mispredPC; - uint64_t nextPC; - InstSeqNum squashedSeqNum; - bool includeSquashInst; - - InterStageStruct() - : squash(false), - branchMispredict(false), branchTaken(false), - mispredPC(0), nextPC(0), - squashedSeqNum(0), includeSquashInst(false) - { } + // Add any information that needs to be passed forward to stages + // below ... }; -/** Turn This into a Class */ /** Struct that defines all backwards communication. */ struct TimeStruct { struct stageComm { bool squash; - bool predIncorrect; - uint64_t branchAddr; - - // @todo: Might want to package this kind of branch stuff into a single - // struct as it is used pretty frequently. - bool branchMispredict; - bool branchTaken; - Addr mispredPC; - TheISA::PCState nextPC; - - unsigned branchCount; - - // Represents the instruction that has either been retired or - // squashed. Similar to having a single bus that broadcasts the - // retired or squashed sequence number. InstSeqNum doneSeqNum; - InstSeqNum bdelayDoneSeqNum; - bool squashDelaySlot; - - //Just in case we want to do a commit/squash on a cycle - //(necessary for multiple ROBs?) - bool commitInsts; - InstSeqNum squashSeqNum; - - // Communication specifically to the IQ to tell the IQ that it can - // schedule a non-speculative instruction. - InstSeqNum nonSpecSeqNum; bool uncached; ThePipeline::DynInstPtr uncachedLoad; - - bool interruptPending; - bool clearInterrupt; }; stageComm stageInfo[ThePipeline::NumStages][ThePipeline::MaxThreads]; |