Go to the documentation of this file.
43 #include "debug/Checkpoint.hh"
44 #include "debug/Timer.hh"
53 :
AmbaIntDevice(
p, 0x1000), lastWrittenTick(0), loadVal(0), matchVal(0),
54 rawInt(false), maskInt(false), pendingInt(false),
58 struct tm local_time =
p.time;
71 DPRINTF(Timer,
"Reading from RTC at offset: %#x\n", daddr);
102 panic(
"Tried to read PL031 at offset %#x that doesn't exist\n", daddr);
117 DPRINTF(Timer,
"Writing to RTC at offset: %#x\n", daddr);
138 if (pkt->
getLE<uint32_t>()) {
146 panic(
"Tried to read PL031 at offset %#x that doesn't exist\n", daddr);
157 DPRINTF(Timer,
"Setting up new match event match=%d time=%d\n",
matchVal,
164 DPRINTF(Timer,
"-- Event was already schedule, de-scheduling\n");
168 DPRINTF(Timer,
"-- Scheduling new event for: %d\n",
curTick() + ticks_until);
174 DPRINTF(Timer,
"Counter reached zero\n");
180 DPRINTF(Timer,
"-- Causing interrupt\n");
188 DPRINTF(Checkpoint,
"Serializing Arm PL031\n");
210 DPRINTF(Checkpoint,
"Unserializing Arm PL031\n");
Tick curTick()
The universal simulation clock.
Tick when() const
Get the time that the event is scheduled.
Addr pioAddr
Address that the device listens to.
uint64_t getUintX(ByteOrder endian) const
Get the data in the packet byte swapped from the specified endianness and zero-extended to 64 bits.
#define UNSERIALIZE_SCALAR(scalar)
PL031(const Params &p)
The constructor for RealView just registers itself with the MMU.
bool pendingInt
If an interrupt is currently pending.
void schedule(Event &event, Tick when)
void makeAtomicResponse()
bool maskInt
If the timer interrupt mask that is anded with the raw interrupt to generate a pending interrupt.
AmbaPioDeviceParams Params
bool rawInt
If timer has caused an interrupt.
void unserialize(CheckpointIn &cp) override
Unserialize an object.
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
uint64_t Tick
Tick count type.
EventFunctionWrapper matchEvent
void counterMatch()
Called when the counter reaches matches.
Tick pioDelay
Delay that the device experinces on an access.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
const std::string & name()
#define SERIALIZE_SCALAR(scalar)
void deschedule(Event &event)
ArmInterruptPin *const interrupt
time_t mkutctime(struct tm *time)
Tick read(PacketPtr pkt) override
Handle a read to the device.
void resyncMatch()
Called to update the matchEvent when the load Value or match value are written.
T getLE() const
Get the data in the packet byte swapped from little endian to host endian.
Addr pioSize
Size that the device's address range.
std::ostream CheckpointOut
virtual void raise()=0
Signal an interrupt.
bool readId(PacketPtr pkt, uint64_t amba_id, Addr pio_addr)
Tick write(PacketPtr pkt) override
Handle writes to the device.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
void setUintX(uint64_t w, ByteOrder endian)
Set the value in the word w after truncating it to the length of the packet and then byteswapping it ...
void serialize(CheckpointOut &cp) const override
Serialize an object.
bool scheduled() const
Determine if the current event is scheduled.
#define panic(...)
This implements a cprintf based panic() function.
Generated on Tue Dec 21 2021 11:34:28 for gem5 by doxygen 1.8.17