gem5  v21.0.0.0
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages
plic.cc
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2021 Huawei International
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  * Redistribution and use in source and binary forms, with or without
15  * modification, are permitted provided that the following conditions are
16  * met: redistributions of source code must retain the above copyright
17  * notice, this list of conditions and the following disclaimer;
18  * redistributions in binary form must reproduce the above copyright
19  * notice, this list of conditions and the following disclaimer in the
20  * documentation and/or other materials provided with the distribution;
21  * neither the name of the copyright holders nor the names of its
22  * contributors may be used to endorse or promote products derived from
23  * this software without specific prior written permission.
24  *
25  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
26  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
27  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
28  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
29  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
30  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
31  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
32  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
33  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
34  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
35  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
36  */
37 
38 
39 #include "dev/riscv/plic.hh"
40 
41 #include <algorithm>
42 
43 #include "arch/riscv/registers.hh"
44 #include "debug/Plic.hh"
45 #include "mem/packet.hh"
46 #include "mem/packet_access.hh"
47 #include "params/Plic.hh"
48 #include "sim/system.hh"
49 
50 using namespace RiscvISA;
51 
52 Plic::Plic(const Params &params) :
53  BasicPioDevice(params, params.pio_size),
54  system(params.system),
55  intrctrl(params.intrctrl),
56  nSrc(params.n_src),
57  registers(params.name, pioAddr, this),
58  update([this]{updateOutput();}, name() + ".update")
59 {
60 }
61 
62 void
63 Plic::post(int src_id)
64 {
65  // Sanity check
66  assert(src_id < nSrc && src_id >= 0);
67 
68  // Update pending bit
69  int src_index = src_id >> 5;
70  int src_offset = src_id & 0x1F;
71 
72  uint32_t& pending = registers.pending[src_index].get();
73  std::bitset<32> pending_bits(pending);
74  pending_bits[src_offset] = 1;
75  pending = (uint32_t) pending_bits.to_ulong();
76 
77  // Update states
78  pendingPriority[src_id] = registers.priority[src_id].get();
79  for (int i = 0; i < nContext; i++) {
80  bool enabled = bits(registers.enable[i][src_index].get(), src_offset);
81  effPriority[i][src_id] = enabled ? pendingPriority[src_id] : 0;
82  }
83  DPRINTF(Plic,
84  "Int post request - source: %#x, current priority: %#x\n",
85  src_id, pendingPriority[src_id]);
86 
87  // Propagate output changes
89 }
90 
91 void
92 Plic::clear(int src_id)
93 {
94  // Sanity check
95  assert(src_id < nSrc);
96  assert(src_id >= 0);
97 
98  // Update pending bit
99  int src_index = src_id >> 5;
100  int src_offset = src_id & 0x1F;
101  uint32_t& pending = registers.pending[src_index].get();
102  std::bitset<32> pending_bits(pending);
103  pending_bits[src_offset] = 0;
104  pending = (uint32_t) pending_bits.to_ulong();
105 
106  // Update states
107  pendingPriority[src_id] = 0;
108  for (int i = 0; i < nContext; i++) {
109  effPriority[i][src_id] = 0;
110  }
111  DPRINTF(Plic,
112  "Int clear request - source: %#x, current priority: %#x\n",
113  src_id, pendingPriority[src_id]);
114 
115  // Propagate output changes
116  propagateOutput();
117 }
118 
119 Tick
121 {
122  // Check for atomic operation
123  bool is_atomic = pkt->isAtomicOp() && pkt->cmd == MemCmd::SwapReq;
124  DPRINTF(Plic,
125  "Read request - addr: %#x, size: %#x, atomic:%d\n",
126  pkt->getAddr(), pkt->getSize(), is_atomic);
127 
128  // Perform register read
129  registers.read(pkt->getAddr(), pkt->getPtr<void>(), pkt->getSize());
130 
131  if (is_atomic) {
132  // Perform atomic operation
133  (*(pkt->getAtomicOp()))(pkt->getPtr<uint8_t>());
134  return write(pkt);
135  } else {
136  pkt->makeResponse();
137  return pioDelay;
138  }
139 }
140 
141 Tick
143 {
144  DPRINTF(Plic,
145  "Write request - addr: %#x, size: %#x\n",
146  pkt->getAddr(), pkt->getSize());
147 
148  // Perform register write
149  registers.write(pkt->getAddr(), pkt->getPtr<void>(), pkt->getSize());
150 
151  // Propagate output changes
152  propagateOutput();
153 
154  // Apply threshold changes
155  updateInt();
156 
157  pkt->makeResponse();
158  return pioDelay;
159 }
160 
161 void
163 {
164  // Number of contexts
165  nContext = system->threads.size() * 2;
166  // Number of 32-bit pending registesrs where
167  // each bit correspondings to one interrupt source
168  nSrc32 = divCeil(nSrc, 32);
169 
170  // Setup register bank
171  registers.init();
172 
173  // Setup internal states
174  pendingPriority.resize(nSrc, 0x0);
175  for (int i = 0; i < nContext; i++) {
176  std::vector<uint32_t> context_priority(nSrc, 0x0);
177  effPriority.push_back(context_priority);
178  }
179  lastID.resize(nContext, 0x0);
180 
181  // Setup outputs
182  output = PlicOutput{
185 
186  DPRINTF(Plic,
187  "Device init - %d contexts, %d sources, %d pending registers\n",
188  nContext, nSrc, nSrc32);
189 
191 }
192 
193 void
195 {
196  using namespace std::placeholders;
197 
198  // Calculate reserved space size
199  const size_t reserve0_size = pendingStart - plic->nSrc * 4;
200  reserved.emplace_back("reserved0", reserve0_size);
201  const size_t reserve1_size = enableStart - pendingStart
202  - plic->nSrc32 * 4;
203  reserved.emplace_back("reserved1", reserve1_size);
204  const size_t reserve2_size = thresholdStart - enableStart
206  reserved.emplace_back("reserved2", reserve2_size);
207  const size_t reserve3_size = plic->pioSize - thresholdStart
209  reserved.emplace_back("reserved3", reserve3_size);
210 
211  // Sanity check
212  assert(plic->pioSize >= thresholdStart
214  assert((int) plic->pioSize <= maxBankSize);
215 
216  // Calculate hole sizes
217  const size_t enable_hole_size = enablePadding - plic->nSrc32 * 4;
218  const size_t claim_hole_size = thresholdPadding - 0x8;
219 
220  // Initialize registers
221  for (int i = 0; i < plic->nSrc; i++) {
222  priority.emplace_back(
223  std::string("priority") + std::to_string(i), 0);
224  }
225  for (int i = 0; i < plic->nSrc32; i++) {
226  pending.emplace_back(
227  std::string("pending") + std::to_string(i), 0);
228  }
229  for (int i = 0; i < plic->nContext; i++) {
230 
231  enable.push_back(std::vector<Register32>());
232  for (int j = 0; j < plic->nSrc32; j++) {
233  enable[i].emplace_back(
234  std::string("enable") + std::to_string(i)
235  + "_" + std::to_string(j), 0);
236  }
237  enable_holes.emplace_back(
238  std::string("enable_hole") + std::to_string(i), enable_hole_size);
239 
240  threshold.emplace_back(
241  std::string("threshold") + std::to_string(i), 0);
242  claim.emplace_back(
243  std::string("claim") + std::to_string(i), 0);
244  claim_holes.emplace_back(
245  std::string("claim_hole") + std::to_string(i), claim_hole_size);
246  }
247 
248  // Add registers to bank
249  // Priority
250  for (int i = 0; i < plic->nSrc; i++) {
251  auto write_cb = std::bind(&Plic::writePriority, plic, _1, _2, i);
252  priority[i].writer(write_cb);
254  }
255  addRegister(reserved[0]);
256 
257  // Pending
258  for (int i = 0; i < plic->nSrc32; i++) {
259  pending[i].readonly();
261  }
262  addRegister(reserved[1]);
263 
264  // Enable
265  for (int i = 0; i < plic->nContext; i++) {
266  for (int j = 0; j < plic->nSrc32; j++) {
267  auto write_cb = std::bind(&Plic::writeEnable, plic, _1, _2, j, i);
268  enable[i][j].writer(write_cb);
269  addRegister(enable[i][j]);
270  }
272  }
273  addRegister(reserved[2]);
274 
275  // Threshold and claim
276  for (int i = 0; i < plic->nContext; i++) {
277  auto threshold_cb = std::bind(&Plic::writeThreshold, plic, _1, _2, i);
278  threshold[i].writer(threshold_cb);
279  auto read_cb = std::bind(&Plic::readClaim, plic, _1, i);
280  auto write_cb = std::bind(&Plic::writeClaim, plic, _1, _2, i);
281  claim[i].reader(read_cb)
282  .writer(write_cb);
284  addRegister(claim[i]);
286  }
287  addRegister(reserved[3]);
288 }
289 
290 void
291 Plic::writePriority(Register32& reg, const uint32_t& data, const int src_id)
292 {
293  reg.update(data);
294 
295  // Calculate indices
296  int src_index = src_id >> 5;
297  int src_offset = src_id & 0x1F;
298 
299  // Update states
300  bool pending = bits(registers.pending[src_index].get(), src_offset);
301  pendingPriority[src_id] = pending ? reg.get() : 0;
302  for (int i = 0; i < nContext; i++) {
303  bool enabled = bits(
304  registers.enable[i][src_index].get(), src_offset);
305  effPriority[i][src_id] = enabled ? pendingPriority[src_id] : 0;
306  }
307 
308  DPRINTF(Plic,
309  "Priority updated - src: %d, val: %d\n",
310  src_id, reg.get());
311 }
312 
313 void
315  const int src32_id, const int context_id)
316 {
317  reg.update(data);
318 
319  for (int i = 0; i < 32; i ++) {
320  int src_id = (src32_id << 5) + i;
321  if (src_id < nSrc) {
322  effPriority[context_id][src_id] =
323  bits(reg.get(), i) ? pendingPriority[src_id] : 0;
324  }
325  }
326  DPRINTF(Plic,
327  "Enable updated - context: %d, src32: %d, val: %#x\n",
328  context_id, src32_id, reg.get());
329 }
330 
331 void
333  const int context_id)
334 {
335  DPRINTF(Plic,
336  "Threshold updated - context: %d, val: %d\n",
337  context_id, reg.get());
338 }
339 
340 uint32_t
341 Plic::readClaim(Register32& reg, const int context_id)
342 {
343  if (lastID[context_id] == 0) {
344  // Calculate indices
345  uint32_t max_int_id = output.maxID[context_id];
346  int src_index = max_int_id >> 5;
347  int src_offset = max_int_id & 0x1F;
348 
349  // Check pending bits
350  if (bits(registers.pending[src_index].get(), src_offset)) {
351  lastID[context_id] = max_int_id;
352  DPRINTF(Plic,
353  "Claim success - context: %d, interrupt ID: %d\n",
354  context_id, max_int_id);
355  clear(max_int_id);
356  reg.update(max_int_id);
357  return reg.get();
358  } else {
359  DPRINTF(Plic,
360  "Claim already cleared - context: %d, interrupt ID: %d\n",
361  context_id, max_int_id);
362  return 0;
363  }
364  } else {
365  warn("PLIC claim repeated (not completed) - context: %d, last: %d",
366  context_id, lastID[context_id]);
367  return lastID[context_id];
368  }
369 }
370 
371 void
372 Plic::writeClaim(Register32& reg, const uint32_t& data, const int context_id)
373 {
374  reg.update(data);
375 
380  assert(lastID[context_id] == reg.get());
381  lastID[context_id] = 0;
382  DPRINTF(Plic,
383  "Complete - context: %d, interrupt ID: %d\n",
384  context_id, reg.get());
385  updateInt();
386 }
387 
388 void
390 {
391  // Calculate new output
392  PlicOutput new_output{
395  uint32_t max_id;
396  uint32_t max_priority;
397  for (int i = 0; i < nContext; i++) {
398  max_id = max_element(effPriority[i].begin(),
399  effPriority[i].end()) - effPriority[i].begin();
400  max_priority = effPriority[i][max_id];
401  new_output.maxID[i] = max_id;
402  new_output.maxPriority[i] = max_priority;
403  }
404 
405  // Add new output to outputQueue
406  Tick next_update = curTick() + cyclesToTicks(Cycles(3));
407  if (outputQueue.find(next_update) != outputQueue.end()) {
408  outputQueue[next_update] = new_output;
409  } else {
410  outputQueue.insert({next_update, new_output});
411  }
412 
413  // Schedule next update event
414  if (!update.scheduled()) {
415  DPRINTF(Plic, "Update scheduled - tick: %d\n", next_update);
416  schedule(update, next_update);
417  }
418 }
419 
420 void
422 {
423  DPRINTF(Plic, "Update triggered\n");
424  // Set current output to new output
425  output = outputQueue.begin()->second;
426  outputQueue.erase(outputQueue.begin()->first);
427 
428  // Schedule next update event (if any)
429  if (!outputQueue.empty()) {
430  DPRINTF(Plic, "Update scheduled - tick: %d\n",
431  outputQueue.begin()->first);
432  schedule(update, outputQueue.begin()->first);
433  }
434 
435  updateInt();
436 }
437 
438 void
440 {
441  // Update xEIP lines
442  for (int i = 0; i < nContext; i++) {
443  int thread_id = i >> 1;
444  int int_id = (i & 1) ?
446 
447  uint32_t max_id = output.maxID[i];
448  uint32_t priority = output.maxPriority[i];
449  uint32_t threshold = registers.threshold[i].get();
450  if (priority > threshold && max_id > 0 && lastID[i] == 0) {
451  DPRINTF(Plic,
452  "Int posted - thread: %d, int id: %d, ",
453  thread_id, int_id);
454  DPRINTFR(Plic,
455  "pri: %d, thres: %d\n", priority, threshold);
456  intrctrl->post(thread_id, int_id, 0);
457  } else {
458  if (priority > 0) {
459  DPRINTF(Plic,
460  "Int filtered - thread: %d, int id: %d, ",
461  thread_id, int_id);
462  DPRINTFR(Plic,
463  "pri: %d, thres: %d\n", priority, threshold);
464  }
465  intrctrl->clear(thread_id, int_id, 0);
466  }
467  }
468 }
469 
470 void
472 {
473  int n_outputs = 0;
474 
475  for (auto const &reg: registers.pending) {
476  paramOut(cp, reg.name(), reg);
477  }
478  for (auto const &reg: registers.priority) {
479  paramOut(cp, reg.name(), reg);
480  }
481  for (auto const &reg: registers.enable) {
482  for (auto const &reg_inner: reg) {
483  paramOut(cp, reg_inner.name(), reg_inner);
484  }
485  }
486  for (auto const &reg: registers.threshold) {
487  paramOut(cp, reg.name(), reg);
488  }
489  for (auto const &reg: registers.claim) {
490  paramOut(cp, reg.name(), reg);
491  }
492  for (auto const & it : outputQueue) {
493  paramOut(cp, std::string("output_tick") +
494  std::to_string(n_outputs), it.first);
495  arrayParamOut(cp, std::string("output_id") +
496  std::to_string(n_outputs), it.second.maxID);
497  arrayParamOut(cp, std::string("output_pri") +
498  std::to_string(n_outputs), it.second.maxPriority);
499  n_outputs++;
500  }
501  SERIALIZE_SCALAR(n_outputs);
505  for (int i=0; i < effPriority.size(); i++) {
506  arrayParamOut(cp, std::string("effPriority") +
508  }
510 }
511 
512 void
514 {
515  int n_outputs;
516  UNSERIALIZE_SCALAR(n_outputs);
517 
518  for (auto &reg: registers.pending) {
519  paramIn(cp, reg.name(), reg);
520  }
521  for (auto &reg: registers.priority) {
522  paramIn(cp, reg.name(), reg);
523  }
524  for (auto &reg: registers.enable) {
525  for (auto &reg_inner: reg) {
526  paramIn(cp, reg_inner.name(), reg_inner);
527  }
528  }
529  for (auto &reg: registers.threshold) {
530  paramIn(cp, reg.name(), reg);
531  }
532  for (auto &reg: registers.claim) {
533  paramIn(cp, reg.name(), reg);
534  }
535  for (int i = 0; i < n_outputs; i++) {
536  Tick output_tick;
537  std::vector<uint32_t> output_id;
538  std::vector<uint32_t> output_pri;
539  paramIn(cp, std::string("output_tick") +
540  std::to_string(i), output_tick);
541  arrayParamIn(cp, std::string("output_id") +
542  std::to_string(i), output_id);
543  arrayParamIn(cp, std::string("output_pri") +
544  std::to_string(i), output_pri);
545  outputQueue[output_tick] = PlicOutput{output_id, output_pri};
546  }
547  if (!outputQueue.empty()) {
548  schedule(update, outputQueue.begin()->first);
549  }
553  for (int i=0; i < effPriority.size(); i++) {
554  arrayParamIn(cp, std::string("effPriority") +
556  }
558  updateInt();
559 }
Plic::writeClaim
void writeClaim(Register32 &reg, const uint32_t &data, const int context_id)
Definition: plic.cc:372
Plic::readClaim
uint32_t readClaim(Register32 &reg, const int context_id)
Definition: plic.cc:341
Event::scheduled
bool scheduled() const
Determine if the current event is scheduled.
Definition: eventq.hh:462
RegisterBank::Register
Definition: reg_bank.hh:485
warn
#define warn(...)
Definition: logging.hh:239
IntrControl::clear
void clear(int cpu_id, int int_num, int index)
Definition: intr_control.cc:53
Plic::PlicRegisters::thresholdPadding
const Addr thresholdPadding
Definition: plic.hh:191
system.hh
Plic::update
EventFunctionWrapper update
Definition: plic.hh:258
RiscvISA::INT_EXT_MACHINE
@ INT_EXT_MACHINE
Definition: faults.hh:88
data
const char data[]
Definition: circlebuf.test.cc:47
Plic::outputQueue
std::map< Tick, PlicOutput > outputQueue
Definition: plic.hh:257
IntrControl::post
void post(int cpu_id, int int_num, int index)
Definition: intr_control.cc:45
UNSERIALIZE_SCALAR
#define UNSERIALIZE_SCALAR(scalar)
Definition: serialize.hh:591
Packet::getAddr
Addr getAddr() const
Definition: packet.hh:755
Plic::read
Tick read(PacketPtr pkt) override
PioDevice funcitons.
Definition: plic.cc:120
PioDevice::init
void init() override
init() is called after all C++ SimObjects have been created and all ports are connected.
Definition: io_device.cc:56
Plic::init
void init() override
SimObject functions.
Definition: plic.cc:162
ArmISA::i
Bitfield< 7 > i
Definition: miscregs_types.hh:63
UNSERIALIZE_CONTAINER
#define UNSERIALIZE_CONTAINER(member)
Definition: serialize.hh:650
PlicOutput::maxPriority
std::vector< uint32_t > maxPriority
Definition: plic.hh:91
Plic::pendingPriority
std::vector< uint32_t > pendingPriority
Definition: plic.hh:238
Plic::PlicRegisters::claim
std::vector< Register32 > claim
Definition: plic.hh:199
RegisterBank::addRegister
void addRegister(RegisterBase &reg)
Definition: reg_bank.hh:798
sc_dt::to_string
const std::string to_string(sc_enc enc)
Definition: sc_fxdefs.cc:91
Plic::nContext
int nContext
Number of interrupt contexts = nThread * 2 e.g.
Definition: plic.hh:115
Tick
uint64_t Tick
Tick count type.
Definition: types.hh:59
Packet::isAtomicOp
bool isAtomicOp() const
Definition: packet.hh:794
Plic::Plic
Plic(const Params &params)
Definition: plic.cc:52
Plic::writeThreshold
void writeThreshold(Register32 &reg, const uint32_t &data, const int context_id)
Definition: plic.cc:332
std::vector< uint32_t >
Packet::getSize
unsigned getSize() const
Definition: packet.hh:765
Plic::unserialize
void unserialize(CheckpointIn &cp) override
Unserialize an object.
Definition: plic.cc:513
RegisterBank::write
virtual void write(Addr addr, const void *buf, Addr bytes)
Definition: reg_bank.hh:862
Plic::registers
Plic::PlicRegisters registers
X86ISA::reg
Bitfield< 5, 3 > reg
Definition: types.hh:88
Plic::PlicRegisters::enable
std::vector< std::vector< Register32 > > enable
Definition: plic.hh:197
RiscvISA
Definition: fs_workload.cc:36
Plic::effPriority
std::vector< std::vector< uint32_t > > effPriority
Definition: plic.hh:240
packet.hh
Plic::writePriority
void writePriority(Register32 &reg, const uint32_t &data, const int src_id)
Register read / write callbacks.
Definition: plic.cc:291
RegisterBank::read
virtual void read(Addr addr, void *buf, Addr bytes)
Definition: reg_bank.hh:805
X86ISA::system
Bitfield< 15 > system
Definition: misc.hh:997
ArmISA::j
Bitfield< 24 > j
Definition: miscregs_types.hh:54
divCeil
T divCeil(const T &a, const U &b)
Definition: intmath.hh:114
cp
Definition: cprintf.cc:37
MemCmd::SwapReq
@ SwapReq
Definition: packet.hh:112
EventManager::schedule
void schedule(Event &event, Tick when)
Definition: eventq.hh:1016
arrayParamOut
decltype(std::begin(std::declval< const T & >()), std::end(std::declval< const T & >()), void()) arrayParamOut(CheckpointOut &os, const std::string &name, const T &param)
Definition: serialize.hh:415
Plic::post
void post(int src_id)
Interrupt interface.
Definition: plic.cc:63
Clocked::cyclesToTicks
Tick cyclesToTicks(Cycles c) const
Definition: clocked_object.hh:224
Stats::enabled
bool enabled()
Definition: statistics.cc:275
Plic::updateInt
void updateInt()
Trigger:
Definition: plic.cc:439
DPRINTF
#define DPRINTF(x,...)
Definition: trace.hh:237
Plic::PlicRegisters::init
void init()
Definition: plic.cc:194
Plic::PlicRegisters::plic
Plic * plic
Definition: plic.hh:208
Packet::getAtomicOp
AtomicOpFunctor * getAtomicOp() const
Accessor function to atomic op.
Definition: packet.hh:793
Plic::serialize
void serialize(CheckpointOut &cp) const override
Serialize an object.
Definition: plic.cc:471
Plic::system
System * system
Definition: plic.hh:98
DPRINTFR
#define DPRINTFR(...)
Definition: trace.hh:239
Plic::output
PlicOutput output
Definition: plic.hh:243
System::Threads::size
int size() const
Definition: system.hh:204
Plic::lastID
std::vector< uint32_t > lastID
Definition: plic.hh:242
BasicPioDevice::pioSize
Addr pioSize
Size that the device's address range.
Definition: io_device.hh:151
PlicOutput::maxID
std::vector< uint32_t > maxID
Definition: plic.hh:90
Plic::writeEnable
void writeEnable(Register32 &reg, const uint32_t &data, const int src32_id, const int context_id)
Definition: plic.cc:314
Packet::makeResponse
void makeResponse()
Take a request packet and modify it in place to be suitable for returning as a response to that reque...
Definition: packet.hh:1005
name
const std::string & name()
Definition: trace.cc:48
Plic::PlicRegisters::claim_holes
std::vector< RegisterRaz > claim_holes
Definition: plic.hh:201
SERIALIZE_SCALAR
#define SERIALIZE_SCALAR(scalar)
Definition: serialize.hh:584
paramOut
void paramOut(CheckpointOut &cp, const std::string &name, ExtMachInst const &machInst)
Definition: types.cc:37
Plic::PlicRegisters::enablePadding
const Addr enablePadding
Definition: plic.hh:190
Plic::PlicRegisters::pendingStart
const Addr pendingStart
Definition: plic.hh:187
packet_access.hh
registers.hh
Plic::PlicRegisters::priority
std::vector< Register32 > priority
Definition: plic.hh:195
Plic::write
Tick write(PacketPtr pkt) override
Pure virtual function that the device must implement.
Definition: plic.cc:142
Packet::cmd
MemCmd cmd
The command field of the packet.
Definition: packet.hh:336
System::threads
Threads threads
Definition: system.hh:304
Plic::nSrc
int nSrc
Definition: plic.hh:102
Plic::nSrc32
int nSrc32
Number of 32-bit pending registers needed = ceil(nSrc / 32)
Definition: plic.hh:107
Plic::PlicRegisters::thresholdStart
const Addr thresholdStart
Definition: plic.hh:189
SERIALIZE_CONTAINER
#define SERIALIZE_CONTAINER(member)
Definition: serialize.hh:642
Packet
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
Definition: packet.hh:258
BasicPioDevice
Definition: io_device.hh:144
Plic::PlicRegisters::enableStart
const Addr enableStart
Definition: plic.hh:188
Plic
Definition: plic.hh:94
PlicOutput
NOTE: This implementation of CLINT is based on the SiFive U54MC datasheet: https://sifive....
Definition: plic.hh:89
Cycles
Cycles is a wrapper class for representing cycle counts, i.e.
Definition: types.hh:79
BasicPioDevice::pioDelay
Tick pioDelay
Delay that the device experinces on an access.
Definition: io_device.hh:154
plic.hh
Packet::getPtr
T * getPtr()
get a pointer to the data ptr.
Definition: packet.hh:1158
CheckpointOut
std::ostream CheckpointOut
Definition: serialize.hh:64
bits
constexpr T bits(T val, unsigned first, unsigned last)
Extract the bitfield from position 'first' to 'last' (inclusive) from 'val' and right justify it.
Definition: bitfield.hh:73
Plic::PlicRegisters::reserved
std::vector< RegisterRaz > reserved
Definition: plic.hh:202
arrayParamIn
void arrayParamIn(CheckpointIn &cp, const std::string &name, CircleBuf< T > &param)
Definition: circlebuf.hh:254
curTick
Tick curTick()
The universal simulation clock.
Definition: cur_tick.hh:43
Plic::PlicRegisters::threshold
std::vector< Register32 > threshold
Definition: plic.hh:198
Plic::propagateOutput
void propagateOutput()
Trigger:
Definition: plic.cc:389
Plic::PlicRegisters::enable_holes
std::vector< RegisterRaz > enable_holes
Definition: plic.hh:200
paramIn
void paramIn(CheckpointIn &cp, const std::string &name, ExtMachInst &machInst)
Definition: types.cc:69
CheckpointIn
Definition: serialize.hh:68
Plic::clear
void clear(int src_id)
Definition: plic.cc:92
PioDevice::Params
PioDeviceParams Params
Definition: io_device.hh:131
Plic::updateOutput
void updateOutput()
Trigger:
Definition: plic.cc:421
Plic::PlicRegisters::pending
std::vector< Register32 > pending
Definition: plic.hh:196
RiscvISA::INT_EXT_SUPER
@ INT_EXT_SUPER
Definition: faults.hh:87
Plic::PlicRegisters::maxBankSize
const Addr maxBankSize
Definition: plic.hh:192
Plic::intrctrl
IntrControl * intrctrl
Definition: plic.hh:99

Generated on Tue Mar 23 2021 19:41:26 for gem5 by doxygen 1.8.17