Go to the documentation of this file.
38 #ifndef __DEV_ARM_SMMU_V3_HH__
39 #define __DEV_ARM_SMMU_V3_HH__
57 #include "params/SMMUv3.hh"
83 class SMMUTranslationProcess;
181 virtual void init()
override;
This is a simple scalar statistic, like a counter.
std::queue< SMMUAction > packetsToRetry
int16_t PortID
Port index/ID type, and a symbolic name for an invalid port id.
A simple distribution stat.
const PageTableOps * getPageTableOps(uint8_t trans_granule)
const unsigned requestPortWidth
DrainState drain() override
Draining is the process of clearing out the states of SimObjects.These are the SimObjects that are pa...
SMMUAction runProcessTiming(SMMUProcess *proc, PacketPtr pkt)
SMMUControlPort controlPort
const RequestorID requestorId
const bool ipaCacheEnable
statistics::Distribution ptwTimeDist
const unsigned walkCacheS1Levels
statistics::Scalar cdFetches
statistics::Scalar steFetches
Tick writeControl(PacketPtr pkt)
Tick recvAtomic(PacketPtr pkt, PortID id)
statistics::Scalar steL1Fetches
const PortID InvalidPortID
SMMURequestPort requestPort
void unserialize(CheckpointIn &cp) override
Unserialize an object.
const bool walkCacheEnable
bool recvTimingResp(PacketPtr pkt)
SMMUAction runProcessAtomic(SMMUProcess *proc, PacketPtr pkt)
SMMUv3(const SMMUv3Params &p)
const bool walkCacheNonfinalEnable
statistics::Distribution translationTimeDist
Cycles is a wrapper class for representing cycle counts, i.e.
DrainState
Object drain/handover states.
virtual std::string name() const
const bool irqInterfaceEnable
void tableWalkRecvReqRetry()
SMMUSemaphore requestPortSem
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
uint64_t Tick
Tick count type.
Tick readControl(PacketPtr pkt)
virtual Port & getPort(const std::string &name, PortID id=InvalidPortID) override
Get a port with a given name and index.
bool inSecureBlock(uint32_t offs) const
void processCommand(const SMMUCommand &cmd)
virtual void init() override
init() is called after all C++ SimObjects have been created and all ports are connected.
SMMUv3Stats(statistics::Group *parent)
bool tableWalkRecvTimingResp(PacketPtr pkt)
The ClockedObject class extends the SimObject with a clock and accessor functions to relate ticks to ...
EventWrapper< SMMUv3, &SMMUv3::processCommands > processCommandsEvent
const unsigned walkCacheS2Levels
std::queue< SMMUAction > packetsTableWalkToRetry
SMMUTableWalkPort tableWalkPort
Ports are used to interface objects to each other.
const bool configCacheEnable
void serialize(CheckpointOut &cp) const override
Serialize an object.
std::ostream CheckpointOut
std::vector< SMMUv3DeviceInterface * > deviceInterfaces
The AddrRange class encapsulates an address range, and supports a number of tests to check if two ran...
gem5::SMMUv3::SMMUv3Stats stats
bool recvTimingReq(PacketPtr pkt, PortID id)
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
void scheduleDeviceRetries()
SMMUAction runProcess(SMMUProcess *proc, PacketPtr pkt)
statistics::Scalar cdL1Fetches
SMMUCommandExecProcess commandExecutor
Generated on Tue Sep 7 2021 14:53:45 for gem5 by doxygen 1.8.17