summaryrefslogtreecommitdiff
path: root/src/sim/system.hh
diff options
context:
space:
mode:
authorGabe Black <gabeblack@google.com>2020-01-12 22:58:48 -0800
committerGabe Black <gabeblack@google.com>2020-01-23 23:38:25 +0000
commit46fbd76595faea874773a2ecbbdb36c3b56e697e (patch)
tree2ba267daa02c23ded8168cbeb68c0a76febca3c0 /src/sim/system.hh
parente3c3d2a1a8aed9f67338ee08d678263525ffaddc (diff)
downloadgem5-46fbd76595faea874773a2ecbbdb36c3b56e697e.tar.xz
sim: Move findFreeContext to System.
This method searches through the ThreadContexts stored in the system, and has no concrete connection to Process other than it happened to be used by a Process in the clone system call. By moving it, we can use its functionality in classes other than Process. Change-Id: Ic6899c335dc13841c6fe948ea3a4f8ad67e562bb Reviewed-on: https://gem5-review.googlesource.com/c/public/gem5/+/24285 Reviewed-by: Giacomo Travaglini <giacomo.travaglini@arm.com> Reviewed-by: Jason Lowe-Power <jason@lowepower.com> Reviewed-by: Brandon Potter <Brandon.Potter@amd.com> Maintainer: Jason Lowe-Power <jason@lowepower.com> Tested-by: kokoro <noreply+kokoro@google.com>
Diffstat (limited to 'src/sim/system.hh')
-rw-r--r--src/sim/system.hh13
1 files changed, 8 insertions, 5 deletions
diff --git a/src/sim/system.hh b/src/sim/system.hh
index 6c63b327f..638e35249 100644
--- a/src/sim/system.hh
+++ b/src/sim/system.hh
@@ -188,6 +188,14 @@ class System : public SimObject, public PCEventScope
unsigned int cacheLineSize() const { return _cacheLineSize; }
std::vector<ThreadContext *> threadContexts;
+ ThreadContext *findFreeContext();
+
+ ThreadContext *
+ getThreadContext(ContextID tid) const
+ {
+ return threadContexts[tid];
+ }
+
const bool multiThread;
using SimObject::schedule;
@@ -195,11 +203,6 @@ class System : public SimObject, public PCEventScope
bool schedule(PCEvent *event) override;
bool remove(PCEvent *event) override;
- ThreadContext *getThreadContext(ContextID tid) const
- {
- return threadContexts[tid];
- }
-
unsigned numContexts() const { return threadContexts.size(); }
/** Return number of running (non-halted) thread contexts in