Go to the documentation of this file.
38 #ifndef __DEV_RISCV_CLINT_HH__
39 #define __DEV_RISCV_CLINT_HH__
48 #include "params/Clint.hh"
54 using namespace RiscvISA;
89 void raiseInterruptPin(
int id);
106 const Addr mtimecmpStart = 0x4000;
107 const Addr mtimeStart = 0xBFF8;
108 const Addr maxBankSize = 0xC000;
141 void init()
override;
142 Port & getPort(
const std::string &if_name,
151 #endif // __DEV_RISCV_CLINT_HH__
int16_t PortID
Port index/ID type, and a symbolic name for an invalid port id.
void unserialize(ThreadContext &tc, CheckpointIn &cp)
IntSinkPin< Clint > signal
const PortID InvalidPortID
std::vector< RegisterRaz > reserved
std::vector< Register64 > mtimecmp
NOTE: This implementation of CLINT is based on the SiFive U54MC datasheet: https://sifive....
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
uint64_t Tick
Tick count type.
ClintRegisters(const std::string &name, Addr base, Clint *clint)
void serialize(const ThreadContext &tc, CheckpointOut &cp)
Thread context serialization helpers.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
const std::string & name()
MMIO Registers 0x0000 - 0x3FFF: msip (write-through to misc reg file) ...: reserved[0] 0x4000 - 0xBFF...
Ports are used to interface objects to each other.
std::ostream CheckpointOut
const FlagsType init
This Stat is Initialized.
void lowerInterruptPin(int id)
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
std::vector< Register32 > msip
Generated on Wed May 4 2022 12:13:57 for gem5 by doxygen 1.8.17