gem5  v21.0.1.0
system.cc
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2011-2014,2017-2019 ARM Limited
3  * All rights reserved
4  *
5  * The license below extends only to copyright in the software and shall
6  * not be construed as granting a license to any other intellectual
7  * property including but not limited to intellectual property relating
8  * to a hardware implementation of the functionality of the software
9  * licensed hereunder. You may use the software subject to the license
10  * terms below provided that you ensure that this notice is replicated
11  * unmodified and in its entirety in all distributions of the software,
12  * modified or unmodified, in source code or in binary form.
13  *
14  * Copyright (c) 2003-2006 The Regents of The University of Michigan
15  * Copyright (c) 2011 Regents of the University of California
16  * All rights reserved.
17  *
18  * Redistribution and use in source and binary forms, with or without
19  * modification, are permitted provided that the following conditions are
20  * met: redistributions of source code must retain the above copyright
21  * notice, this list of conditions and the following disclaimer;
22  * redistributions in binary form must reproduce the above copyright
23  * notice, this list of conditions and the following disclaimer in the
24  * documentation and/or other materials provided with the distribution;
25  * neither the name of the copyright holders nor the names of its
26  * contributors may be used to endorse or promote products derived from
27  * this software without specific prior written permission.
28  *
29  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
30  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
31  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
32  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
33  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
34  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
35  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
36  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
37  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
38  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
39  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
40  */
41 
42 #include "sim/system.hh"
43 
44 #include <algorithm>
45 
46 #include "arch/remote_gdb.hh"
47 #include "arch/utility.hh"
48 #include "base/compiler.hh"
50 #include "base/loader/symtab.hh"
51 #include "base/str.hh"
52 #include "base/trace.hh"
53 #include "config/the_isa.hh"
54 #include "config/use_kvm.hh"
55 #if USE_KVM
56 #include "cpu/kvm/base.hh"
57 #include "cpu/kvm/vm.hh"
58 #endif
59 #if THE_ISA != NULL_ISA
60 #include "cpu/base.hh"
61 #endif
62 #include "cpu/thread_context.hh"
63 #include "debug/Loader.hh"
64 #include "debug/Quiesce.hh"
65 #include "debug/WorkItems.hh"
66 #include "mem/abstract_mem.hh"
67 #include "mem/physical.hh"
68 #include "params/System.hh"
69 #include "sim/byteswap.hh"
70 #include "sim/debug.hh"
71 #include "sim/full_system.hh"
72 #include "sim/redirect_path.hh"
73 
75 
76 void
78 {
79 # if THE_ISA != NULL_ISA
80  DPRINTFS(Quiesce, context->getCpuPtr(), "activating\n");
81  context->activate();
82 # endif
83 }
84 
85 std::string
87 {
88  assert(context);
89  return csprintf("%s.threads[%d]", context->getSystemPtr()->name(),
90  context->contextId());
91 }
92 
93 void
95 {
96  context->suspend();
97  auto *workload = context->getSystemPtr()->workload;
98  if (workload)
100 }
101 
102 ContextID
104 {
105  if (id == InvalidContextID) {
106  for (id = 0; id < size(); id++) {
107  if (!threads[id].context)
108  break;
109  }
110  }
111 
112  if (id >= size())
113  threads.resize(id + 1);
114 
115  fatal_if(threads[id].context,
116  "Cannot have two thread contexts with the same id (%d).", id);
117 
118  auto *sys = tc->getSystemPtr();
119 
120  auto &t = thread(id);
121  t.context = tc;
122  // Look up this thread again on resume, in case the threads vector has
123  // been reallocated.
124  t.resumeEvent = new EventFunctionWrapper(
125  [this, id](){ thread(id).resume(); }, sys->name());
126 # if THE_ISA != NULL_ISA
127  int port = getRemoteGDBPort();
128  if (port) {
129  t.gdb = new TheISA::RemoteGDB(sys, tc, port + id);
130  t.gdb->listen();
131  }
132 # endif
133 
134  return id;
135 }
136 
137 void
139 {
140  auto &t = thread(id);
141  panic_if(!t.context, "Can't replace a context which doesn't exist.");
142  if (t.gdb)
143  t.gdb->replaceThreadContext(tc);
144 # if THE_ISA != NULL_ISA
145  if (t.resumeEvent->scheduled()) {
146  Tick when = t.resumeEvent->when();
147  t.context->getCpuPtr()->deschedule(t.resumeEvent);
148  tc->getCpuPtr()->schedule(t.resumeEvent, when);
149  }
150 # endif
151  t.context = tc;
152 }
153 
156 {
157  for (auto &thread: threads) {
159  return thread.context;
160  }
161  return nullptr;
162 }
163 
164 int
166 {
167  int count = 0;
168  for (auto &thread: threads) {
169  auto status = thread.context->status();
170  if (status != ThreadContext::Halted &&
172  count++;
173  }
174  }
175  return count;
176 }
177 
178 void
180 {
181  auto &t = thread(id);
182 # if THE_ISA != NULL_ISA
183  M5_VAR_USED BaseCPU *cpu = t.context->getCpuPtr();
184  DPRINTFS(Quiesce, cpu, "quiesce()\n");
185 # endif
186  t.quiesce();
187 }
188 
189 void
191 {
192 # if THE_ISA != NULL_ISA
193  auto &t = thread(id);
194  BaseCPU *cpu = t.context->getCpuPtr();
195 
196  DPRINTFS(Quiesce, cpu, "quiesceTick until %u\n", when);
197  t.quiesce();
198 
199  cpu->reschedule(t.resumeEvent, when, true);
200 # endif
201 }
202 
204 
206  : SimObject(p), _systemPort("system_port", this),
207  multiThread(p.multi_thread),
208  pagePtr(0),
210  physProxy(_systemPort, p.cache_line_size),
212 #if USE_KVM
213  kvmVM(p.kvm_vm),
214 #else
215  kvmVM(nullptr),
216 #endif
217  physmem(name() + ".physmem", p.memories, p.mmap_using_noreserve,
218  p.shared_backstore),
219  memoryMode(p.mem_mode),
220  _cacheLineSize(p.cache_line_size),
221  workItemsBegin(0),
222  workItemsEnd(0),
223  numWorkIds(p.num_work_ids),
224  thermalModel(p.thermal_model),
225  _m5opRange(p.m5ops_base ?
226  RangeSize(p.m5ops_base, 0x10000) :
227  AddrRange(1, 0)), // Create an empty range if disabled
228  redirectPaths(p.redirect_paths)
229 {
230  if (workload)
231  workload->system = this;
232 
233  // add self to global system list
234  systemList.push_back(this);
235 
236 #if USE_KVM
237  if (kvmVM) {
238  kvmVM->setSystem(this);
239  }
240 #endif
241 
242  // check if the cache line size is a value known to work
243  if (!(_cacheLineSize == 16 || _cacheLineSize == 32 ||
244  _cacheLineSize == 64 || _cacheLineSize == 128))
245  warn_once("Cache line size is neither 16, 32, 64 nor 128 bytes.\n");
246 
247  // Get the generic system requestor IDs
248  M5_VAR_USED RequestorID tmp_id;
249  tmp_id = getRequestorId(this, "writebacks");
250  assert(tmp_id == Request::wbRequestorId);
251  tmp_id = getRequestorId(this, "functional");
252  assert(tmp_id == Request::funcRequestorId);
253  tmp_id = getRequestorId(this, "interrupt");
254  assert(tmp_id == Request::intRequestorId);
255 
256  // increment the number of running systems
258 
259  // Set back pointers to the system in all memories
260  for (int x = 0; x < params().memories.size(); x++)
261  params().memories[x]->system(this);
262 }
263 
265 {
266  for (uint32_t j = 0; j < numWorkIds; j++)
267  delete workItemStats[j];
268 }
269 
270 void
272 {
274 
275  // Now that we're about to start simulation, wait for GDB connections if
276  // requested.
277 #if THE_ISA != NULL_ISA
278  for (int i = 0; i < threads.size(); i++) {
279  auto *gdb = threads.thread(i).gdb;
280  auto *cpu = threads[i]->getCpuPtr();
281  if (gdb && cpu->waitForRemoteGDB()) {
282  inform("%s: Waiting for a remote GDB connection on port %d.",
283  cpu->name(), gdb->port());
284  gdb->connect();
285  }
286  }
287 #endif
288 }
289 
290 Port &
291 System::getPort(const std::string &if_name, PortID idx)
292 {
293  // no need to distinguish at the moment (besides checking)
294  return _systemPort;
295 }
296 
297 void
298 System::setMemoryMode(Enums::MemoryMode mode)
299 {
300  assert(drainState() == DrainState::Drained);
301  memoryMode = mode;
302 }
303 
305 {
306  if (!threads.size())
307  return false;
308  auto *gdb = threads.thread(0).gdb;
309  if (!gdb)
310  return false;
311  return gdb->breakpoint();
312 }
313 
314 ContextID
316 {
317  ContextID id = threads.insert(tc, assigned);
318 
319  for (auto *e: liveEvents)
320  tc->schedule(e);
321 
322  return id;
323 }
324 
325 bool
327 {
328  bool all = true;
329  liveEvents.push_back(event);
330  for (auto *tc: threads)
331  all = tc->schedule(event) && all;
332  return all;
333 }
334 
335 bool
337 {
338  bool all = true;
339  liveEvents.remove(event);
340  for (auto *tc: threads)
341  all = tc->remove(event) && all;
342  return all;
343 }
344 
345 void
347 {
348  auto *otc = threads[context_id];
349  threads.replace(tc, context_id);
350 
351  for (auto *e: liveEvents) {
352  otc->remove(e);
353  tc->schedule(e);
354  }
355 }
356 
357 bool
359 {
360 #if USE_KVM
361  if (threads.empty())
362  return false;
363 
364  for (auto *tc: threads) {
365  if (!dynamic_cast<BaseKvmCPU *>(tc->getCpuPtr()))
366  return false;
367  }
368 
369  return true;
370 #else
371  return false;
372 #endif
373 }
374 
375 Addr
377 {
378  Addr return_addr = pagePtr << TheISA::PageShift;
379  pagePtr += npages;
380 
381  Addr next_return_addr = pagePtr << TheISA::PageShift;
382 
383  if (_m5opRange.contains(next_return_addr)) {
384  warn("Reached m5ops MMIO region\n");
385  return_addr = 0xffffffff;
386  pagePtr = 0xffffffff >> TheISA::PageShift;
387  }
388 
390  fatal("Out of memory, please increase size of physical memory.");
391  return return_addr;
392 }
393 
394 Addr
396 {
397  return physmem.totalSize();
398 }
399 
400 Addr
402 {
403  return physmem.totalSize() - (pagePtr << TheISA::PageShift);
404 }
405 
406 bool
408 {
409  return physmem.isMemAddr(addr);
410 }
411 
412 void
414 {
415  if (!deviceMemMap.count(requestor_id)) {
416  deviceMemMap.insert(std::make_pair(requestor_id, deviceMemory));
417  }
418 }
419 
420 bool
422 {
423  const RequestorID& id = pkt->requestorId();
424 
425  return (deviceMemMap.count(id) &&
426  deviceMemMap.at(id)->getAddrRange().contains(pkt->getAddr()));
427 }
428 
431 {
432  panic_if(!deviceMemMap.count(id),
433  "No device memory found for RequestorID %d\n", id);
434  return deviceMemMap.at(id);
435 }
436 
437 void
439 {
441 
442  for (auto &t: threads.threads) {
443  Tick when = 0;
444  if (t.resumeEvent && t.resumeEvent->scheduled())
445  when = t.resumeEvent->when();
446  ContextID id = t.context->contextId();
447  paramOut(cp, csprintf("quiesceEndTick_%d", id), when);
448  }
449 
450  // also serialize the memories in the system
451  physmem.serializeSection(cp, "physmem");
452 }
453 
454 
455 void
457 {
459 
460  for (auto &t: threads.threads) {
461  Tick when = 0;
462  ContextID id = t.context->contextId();
463  if (!optParamIn(cp, csprintf("quiesceEndTick_%d", id), when) ||
464  !when || !t.resumeEvent) {
465  continue;
466  }
467 # if THE_ISA != NULL_ISA
468  t.context->getCpuPtr()->schedule(t.resumeEvent, when);
469 # endif
470  }
471 
472  // also unserialize the memories in the system
473  physmem.unserializeSection(cp, "physmem");
474 }
475 
476 void
478 {
480 
481  for (uint32_t j = 0; j < numWorkIds ; j++) {
482  workItemStats[j] = new Stats::Histogram(this);
483  std::stringstream namestr;
484  ccprintf(namestr, "work_item_type%d", j);
485  workItemStats[j]->init(20)
486  .name(namestr.str())
487  .desc("Run time stat for" + namestr.str())
488  .prereq(*workItemStats[j]);
489  }
490 }
491 
492 void
493 System::workItemEnd(uint32_t tid, uint32_t workid)
494 {
495  std::pair<uint32_t,uint32_t> p(tid, workid);
496  if (!lastWorkItemStarted.count(p))
497  return;
498 
499  Tick samp = curTick() - lastWorkItemStarted[p];
500  DPRINTF(WorkItems, "Work item end: %d\t%d\t%lld\n", tid, workid, samp);
501 
502  if (workid >= numWorkIds)
503  fatal("Got workid greater than specified in system configuration\n");
504 
505  workItemStats[workid]->sample(samp);
506  lastWorkItemStarted.erase(p);
507 }
508 
509 void
511 {
512  std::ios::fmtflags flags(std::cerr.flags());
513 
516  for (; i != end; ++i) {
517  System *sys = *i;
518  std::cerr << "System " << sys->name() << ": " << std::hex << sys
519  << std::endl;
520  }
521 
522  std::cerr.flags(flags);
523 }
524 
525 void
527 {
529 }
530 
531 std::string
532 System::stripSystemName(const std::string& requestor_name) const
533 {
534  if (startswith(requestor_name, name())) {
535  return requestor_name.substr(name().size() + 1);
536  } else {
537  return requestor_name;
538  }
539 }
540 
543 {
545 
546  // number of occurrences of the SimObject pointer
547  // in the requestor list.
548  auto obj_number = 0;
549 
550  for (int i = 0; i < requestors.size(); i++) {
551  if (requestors[i].obj == obj) {
552  id = i;
553  obj_number++;
554  }
555  }
556 
557  fatal_if(obj_number > 1,
558  "Cannot lookup RequestorID by SimObject pointer: "
559  "More than one requestor is sharing the same SimObject\n");
560 
561  return id;
562 }
563 
565 System::lookupRequestorId(const std::string& requestor_name) const
566 {
567  std::string name = stripSystemName(requestor_name);
568 
569  for (int i = 0; i < requestors.size(); i++) {
570  if (requestors[i].req_name == name) {
571  return i;
572  }
573  }
574 
576 }
577 
579 System::getGlobalRequestorId(const std::string& requestor_name)
580 {
581  return _getRequestorId(nullptr, requestor_name);
582 }
583 
585 System::getRequestorId(const SimObject* requestor, std::string subrequestor)
586 {
587  auto requestor_name = leafRequestorName(requestor, subrequestor);
588  return _getRequestorId(requestor, requestor_name);
589 }
590 
593  const std::string& requestor_name)
594 {
595  std::string name = stripSystemName(requestor_name);
596 
597  // CPUs in switch_cpus ask for ids again after switching
598  for (int i = 0; i < requestors.size(); i++) {
599  if (requestors[i].req_name == name) {
600  return i;
601  }
602  }
603 
604  // Verify that the statistics haven't been enabled yet
605  // Otherwise objects will have sized their stat buckets and
606  // they will be too small
607 
608  if (Stats::enabled()) {
609  fatal("Can't request a requestorId after regStats(). "
610  "You must do so in init().\n");
611  }
612 
613  // Generate a new RequestorID incrementally
614  RequestorID requestor_id = requestors.size();
615 
616  // Append the new Requestor metadata to the group of system Requestors.
617  requestors.emplace_back(requestor, name, requestor_id);
618 
619  return requestors.back().id;
620 }
621 
622 std::string
624  const std::string& subrequestor)
625 {
626  if (subrequestor.empty()) {
627  return requestor->name();
628  } else {
629  // Get the full requestor name by appending the subrequestor name to
630  // the root SimObject requestor name
631  return requestor->name() + "." + subrequestor;
632  }
633 }
634 
635 std::string
637 {
638  if (requestor_id >= requestors.size())
639  fatal("Invalid requestor_id passed to getRequestorName()\n");
640 
641  const auto& requestor_info = requestors[requestor_id];
642  return requestor_info.req_name;
643 }
BaseRemoteGDB::breakpoint
bool breakpoint()
Definition: remote_gdb.hh:48
fatal
#define fatal(...)
This implements a cprintf based fatal() function.
Definition: logging.hh:183
ArmISA::status
Bitfield< 5, 0 > status
Definition: miscregs_types.hh:417
System::deviceMemMap
std::unordered_map< RequestorID, AbstractMemory * > deviceMemMap
Definition: system.hh:102
Stats::Group::regStats
virtual void regStats()
Callback to set stat parameters.
Definition: group.cc:63
System::getRequestorId
RequestorID getRequestorId(const SimObject *requestor, std::string subrequestor=std::string())
Request an id used to create a request object in the system.
Definition: system.cc:585
System::pagePtr
Addr pagePtr
Definition: system.hh:313
System::System
System(const Params &p)
Definition: system.cc:205
Serializable::unserializeSection
void unserializeSection(CheckpointIn &cp, const char *name)
Unserialize an a child object.
Definition: serialize.cc:177
System::Threads::numRunning
int numRunning() const
Definition: system.cc:165
warn
#define warn(...)
Definition: logging.hh:239
SimObject::Params
SimObjectParams Params
Definition: sim_object.hh:162
system.hh
Request::intRequestorId
@ intRequestorId
This requestor id is used for message signaled interrupts.
Definition: request.hh:254
System::liveEvents
std::list< PCEvent * > liveEvents
Definition: system.hh:98
ThreadContext::activate
virtual void activate()=0
Set the status to Active.
UNSERIALIZE_SCALAR
#define UNSERIALIZE_SCALAR(scalar)
Definition: serialize.hh:591
Packet::getAddr
Addr getAddr() const
Definition: packet.hh:755
System::startup
void startup() override
startup() is the final initialization call before simulation.
Definition: system.cc:271
abstract_mem.hh
warn_once
#define warn_once(...)
Definition: logging.hh:243
ArmISA::i
Bitfield< 7 > i
Definition: miscregs_types.hh:63
System::workItemEnd
void workItemEnd(uint32_t tid, uint32_t workid)
Definition: system.cc:493
System::physProxy
PortProxy physProxy
Port to physical memory used for writing object files into ram at boot.
Definition: system.hh:319
EventManager::reschedule
void reschedule(Event &event, Tick when, bool always=false)
Definition: eventq.hh:1034
ThreadContext::Halting
@ Halting
Trying to exit and waiting for an event to completely exit.
Definition: thread_context.hh:111
Request::invldRequestorId
@ invldRequestorId
Invalid requestor id for assertion checking only.
Definition: request.hh:259
Workload::recordQuiesce
void recordQuiesce()
Definition: workload.hh:70
ContextID
int ContextID
Globally unique thread context ID.
Definition: types.hh:237
System::_getRequestorId
RequestorID _getRequestorId(const SimObject *requestor, const std::string &requestor_name)
helper function for getRequestorId
Definition: system.cc:592
System::Threads::Thread::quiesce
void quiesce() const
Definition: system.cc:94
Tick
uint64_t Tick
Tick count type.
Definition: types.hh:59
redirect_path.hh
System::registerThreadContext
ContextID registerThreadContext(ThreadContext *tc, ContextID assigned=InvalidContextID)
Definition: system.cc:315
System::redirectPaths
std::vector< RedirectPath * > redirectPaths
Definition: system.hh:619
PortID
int16_t PortID
Port index/ID type, and a symbolic name for an invalid port id.
Definition: types.hh:243
AddrRange::contains
bool contains(const Addr &a) const
Determine if the range contains an address.
Definition: addr_range.hh:435
System::_cacheLineSize
const unsigned int _cacheLineSize
Definition: system.hh:411
Workload::system
System * system
Definition: workload.hh:73
System::getGlobalRequestorId
RequestorID getGlobalRequestorId(const std::string &requestor_name)
Registers a GLOBAL RequestorID, which is a RequestorID not related to any particular SimObject; since...
Definition: system.cc:579
Packet::requestorId
RequestorID requestorId() const
Definition: packet.hh:741
std::vector< System * >
InvalidContextID
const ContextID InvalidContextID
Definition: types.hh:238
X86ISA::count
count
Definition: misc.hh:703
System::validKvmEnvironment
bool validKvmEnvironment() const
Verify gem5 configuration will support KVM emulation.
Definition: system.cc:358
System::replaceThreadContext
void replaceThreadContext(ThreadContext *tc, ContextID context_id)
Definition: system.cc:346
System::systemList
static std::vector< System * > systemList
Definition: system.hh:600
Request::wbRequestorId
@ wbRequestorId
This requestor id is used for writeback requests by the caches.
Definition: request.hh:247
Serializable::serializeSection
void serializeSection(CheckpointOut &cp, const char *name) const
Serialize an object into a new section.
Definition: serialize.cc:170
System::Threads::replace
void replace(ThreadContext *tc, ContextID id)
Definition: system.cc:138
System::Threads::findFree
ThreadContext * findFree()
Definition: system.cc:155
System::printSystems
static void printSystems()
Definition: system.cc:510
EventFunctionWrapper
Definition: eventq.hh:1112
printSystems
void printSystems()
Definition: system.cc:526
System::stripSystemName
std::string stripSystemName(const std::string &requestor_name) const
Strips off the system name from a requestor name.
Definition: system.cc:532
Stats::Histogram
A simple histogram stat.
Definition: statistics.hh:2126
System::lookupRequestorId
RequestorID lookupRequestorId(const SimObject *obj) const
Looks up the RequestorID for a given SimObject returns an invalid RequestorID (invldRequestorId) if n...
Definition: system.cc:542
DrainState::Drained
@ Drained
Buffers drained, ready for serialization/handover.
str.hh
System::memoryMode
Enums::MemoryMode memoryMode
Definition: system.hh:409
SimObject::startup
virtual void startup()
startup() is the final initialization call before simulation.
Definition: sim_object.cc:93
System::breakpoint
bool breakpoint()
Definition: system.cc:304
AbstractMemory
An abstract memory represents a contiguous block of physical memory, with an associated address range...
Definition: abstract_mem.hh:104
RequestorID
uint16_t RequestorID
Definition: request.hh:89
optParamIn
bool optParamIn(CheckpointIn &cp, const std::string &name, T &param, bool do_warn=true)
This function is used for restoring optional parameters from the checkpoint.
Definition: serialize.hh:363
System::Threads::Thread::gdb
BaseRemoteGDB * gdb
Definition: system.hh:113
ArmISA::j
Bitfield< 24 > j
Definition: miscregs_types.hh:54
System::workItemsEnd
uint64_t workItemsEnd
Definition: system.hh:414
cp
Definition: cprintf.cc:37
EventManager::schedule
void schedule(Event &event, Tick when)
Definition: eventq.hh:1016
System::workload
Workload * workload
OS kernel.
Definition: system.hh:322
BaseKvmCPU
Base class for KVM based CPU models.
Definition: base.hh:77
Stats::enabled
bool enabled()
Definition: statistics.cc:275
System::physmem
PhysicalMemory physmem
Definition: system.hh:407
System::setMemoryMode
void setMemoryMode(Enums::MemoryMode mode)
Change the memory mode of the system.
Definition: system.cc:298
System::Threads::Thread::name
std::string name() const
Definition: system.cc:86
ThreadContext
ThreadContext is the external interface to all thread state for anything outside of the CPU.
Definition: thread_context.hh:88
AddrRange
The AddrRange class encapsulates an address range, and supports a number of tests to check if two ran...
Definition: addr_range.hh:68
PCEventScope::schedule
virtual bool schedule(PCEvent *event)=0
System::init_param
uint64_t init_param
Definition: system.hh:315
System
Definition: system.hh:73
System::multiThread
const bool multiThread
Definition: system.hh:306
DPRINTF
#define DPRINTF(x,...)
Definition: trace.hh:237
PhysicalMemory::totalSize
uint64_t totalSize() const
Get the total physical memory size.
Definition: physical.hh:207
ThreadContext::Halted
@ Halted
Permanently shut down.
Definition: thread_context.hh:116
ArmISA::PageShift
const Addr PageShift
Definition: isa_traits.hh:52
System::~System
~System()
Definition: system.cc:264
MipsISA::event
Bitfield< 10, 5 > event
Definition: pra_constants.hh:297
debug.hh
System::numWorkIds
uint32_t numWorkIds
Definition: system.hh:415
Port
Ports are used to interface objects to each other.
Definition: port.hh:56
System::Threads::quiesceTick
void quiesceTick(ContextID id, Tick when)
Definition: system.cc:190
System::Threads::quiesce
void quiesce(ContextID id)
Definition: system.cc:179
KvmVM::setSystem
void setSystem(System *s)
Initialize system pointer.
Definition: vm.cc:537
RangeSize
AddrRange RangeSize(Addr start, Addr size)
Definition: addr_range.hh:651
ArmISA::mode
Bitfield< 4, 0 > mode
Definition: miscregs_types.hh:70
System::Threads::insert
ContextID insert(ThreadContext *tc, ContextID id=InvalidContextID)
Definition: system.cc:103
System::schedule
bool schedule(PCEvent *event) override
Definition: system.cc:326
System::Threads::size
int size() const
Definition: system.hh:204
compiler.hh
System::leafRequestorName
std::string leafRequestorName(const SimObject *requestor, const std::string &subrequestor)
Helper function for constructing the full (sub)requestor name by providing the root requestor and the...
Definition: system.cc:623
System::memSize
Addr memSize() const
Amount of physical memory that exists.
Definition: system.cc:395
System::numSystemsRunning
static int numSystemsRunning
Definition: system.hh:601
System::Threads::Thread::resume
void resume()
Definition: system.cc:77
RiscvISA::x
Bitfield< 3 > x
Definition: pagetable.hh:70
std::pair
STL pair class.
Definition: stl.hh:58
ThreadContext::status
virtual Status status() const =0
Addr
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
Definition: types.hh:148
System::Threads::thread
Thread & thread(ContextID id)
Definition: system.hh:124
base.hh
SERIALIZE_SCALAR
#define SERIALIZE_SCALAR(scalar)
Definition: serialize.hh:584
System::unserialize
void unserialize(CheckpointIn &cp) override
Unserialize an object.
Definition: system.cc:456
paramOut
void paramOut(CheckpointOut &cp, const std::string &name, ExtMachInst const &machInst)
Definition: types.cc:37
vm.hh
Request::funcRequestorId
@ funcRequestorId
This requestor id is used for functional requests that don't come from a particular device.
Definition: request.hh:252
full_system.hh
ArmISA::e
Bitfield< 9 > e
Definition: miscregs_types.hh:61
Drainable::drainState
DrainState drainState() const
Return the current drain state of an object.
Definition: drain.hh:320
System::workItemsBegin
uint64_t workItemsBegin
Definition: system.hh:413
System::freeMemSize
Addr freeMemSize() const
Amount of physical memory that is still free.
Definition: system.cc:401
X86ISA::addr
Bitfield< 3 > addr
Definition: types.hh:80
SimObject::name
virtual const std::string name() const
Definition: sim_object.hh:182
System::_systemPort
SystemPort _systemPort
Definition: system.hh:99
BaseCPU
Definition: base.hh:104
System::lastWorkItemStarted
std::map< std::pair< uint32_t, uint32_t >, Tick > lastWorkItemStarted
Definition: system.hh:591
panic_if
#define panic_if(cond,...)
Conditional panic macro that checks the supplied condition and only panics if the condition is true a...
Definition: logging.hh:197
System::threads
Threads threads
Definition: system.hh:304
System::getPort
Port & getPort(const std::string &if_name, PortID idx=InvalidPortID) override
Additional function to return the Port of a memory object.
Definition: system.cc:291
System::workItemStats
std::map< uint32_t, Stats::Histogram * > workItemStats
Definition: system.hh:592
System::_m5opRange
const AddrRange _m5opRange
Range for memory-mapped m5 pseudo ops.
Definition: system.hh:563
inform
#define inform(...)
Definition: logging.hh:240
PhysicalMemory::isMemAddr
bool isMemAddr(Addr addr) const
Check if a physical address is within a range of a memory that is part of the global address map.
Definition: physical.cc:250
System::isDeviceMemAddr
bool isDeviceMemAddr(PacketPtr pkt) const
Similar to isMemAddr but for devices.
Definition: system.cc:421
base.hh
System::kvmVM
KvmVM *const kvmVM
Definition: system.hh:405
ArmISA::t
Bitfield< 5 > t
Definition: miscregs_types.hh:67
startswith
bool startswith(const char *s, const char *prefix)
Return true if 's' starts with the prefix string 'prefix'.
Definition: str.hh:239
System::serialize
void serialize(CheckpointOut &cp) const override
Serialize an object.
Definition: system.cc:438
Packet
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
Definition: packet.hh:258
physical.hh
DPRINTFS
#define DPRINTFS(x,...)
Definition: trace.hh:238
ccprintf
void ccprintf(cp::Print &print)
Definition: cprintf.hh:127
System::requestors
std::vector< RequestorInfo > requestors
This array is a per-system list of all devices capable of issuing a memory system request and an asso...
Definition: system.hh:422
CheckpointOut
std::ostream CheckpointOut
Definition: serialize.hh:64
System::addDeviceMemory
void addDeviceMemory(RequestorID requestorId, AbstractMemory *deviceMemory)
Add a physical memory range for a device.
Definition: system.cc:413
System::remove
bool remove(PCEvent *event) override
Definition: system.cc:336
System::getRequestorName
std::string getRequestorName(RequestorID requestor_id)
Get the name of an object for a given request id.
Definition: system.cc:636
System::allocPhysPages
Addr allocPhysPages(int npages)
Allocate npages contiguous unused physical pages.
Definition: system.cc:376
PCEvent
Definition: pc_event.hh:42
System::getDeviceMemory
AbstractMemory * getDeviceMemory(RequestorID _id) const
Return a pointer to the device memory.
Definition: system.cc:430
curTick
Tick curTick()
The universal simulation clock.
Definition: cur_tick.hh:43
trace.hh
symtab.hh
System::Threads::empty
bool empty() const
Definition: system.hh:205
SimObject::params
const Params & params() const
Definition: sim_object.hh:168
MipsISA::p
Bitfield< 0 > p
Definition: pra_constants.hh:323
fatal_if
#define fatal_if(cond,...)
Conditional fatal macro that checks the supplied condition and only causes a fatal error if the condi...
Definition: logging.hh:219
CheckpointIn
Definition: serialize.hh:68
getRemoteGDBPort
int getRemoteGDBPort()
Definition: debug.cc:117
System::Threads::Thread::context
ThreadContext * context
Definition: system.hh:111
ThreadContext::getCpuPtr
virtual BaseCPU * getCpuPtr()=0
System::regStats
void regStats() override
Callback to set stat parameters.
Definition: system.cc:477
object_file.hh
System::isMemAddr
bool isMemAddr(Addr addr) const
Check if a physical address is within a range of a memory that is part of the global address map.
Definition: system.cc:407
System::Threads::threads
std::vector< Thread > threads
Definition: system.hh:121
csprintf
std::string csprintf(const char *format, const Args &...args)
Definition: cprintf.hh:158
thread_context.hh
ArmISA::id
Bitfield< 33 > id
Definition: miscregs_types.hh:247
byteswap.hh
ThreadContext::getSystemPtr
virtual System * getSystemPtr()=0
System::thermalModel
ThermalModel * thermalModel
Definition: system.hh:424
SimObject
Abstract superclass for simulation objects.
Definition: sim_object.hh:141

Generated on Tue Jun 22 2021 15:28:21 for gem5 by doxygen 1.8.17