Go to the documentation of this file.
   43 #include "debug/Checkpoint.hh" 
   44 #include "debug/Timer.hh" 
   50     : 
AmbaIntDevice(
p, 0x1000), lastWrittenTick(0), loadVal(0), matchVal(0),
 
   51       rawInt(false), maskInt(false), pendingInt(false),
 
   55     struct tm local_time = 
p.time;
 
   68     DPRINTF(Timer, 
"Reading from RTC at offset: %#x\n", daddr);
 
   98         panic(
"Tried to read PL031 at offset %#x that doesn't exist\n", daddr);
 
  113     DPRINTF(Timer, 
"Writing to RTC at offset: %#x\n", daddr);
 
  134         if (pkt->
getLE<uint32_t>()) {
 
  142         panic(
"Tried to read PL031 at offset %#x that doesn't exist\n", daddr);
 
  153     DPRINTF(Timer, 
"Setting up new match event match=%d time=%d\n", 
matchVal,
 
  160         DPRINTF(Timer, 
"-- Event was already schedule, de-scheduling\n");
 
  164     DPRINTF(Timer, 
"-- Scheduling new event for: %d\n", 
curTick() + ticks_until);
 
  170     DPRINTF(Timer, 
"Counter reached zero\n");
 
  176         DPRINTF(Timer, 
"-- Causing interrupt\n");
 
  184     DPRINTF(Checkpoint, 
"Serializing Arm PL031\n");
 
  206     DPRINTF(Checkpoint, 
"Unserializing Arm PL031\n");
 
  
bool scheduled() const
Determine if the current event is scheduled.
void makeAtomicResponse()
Tick read(PacketPtr pkt) override
Handle a read to the device.
Addr pioAddr
Address that the device listens to.
Tick write(PacketPtr pkt) override
Handle writes to the device.
#define UNSERIALIZE_SCALAR(scalar)
time_t mkutctime(struct tm *time)
virtual void raise()=0
Signal an interrupt.
uint64_t Tick
Tick count type.
void deschedule(Event &event)
Tick when() const
Get the time that the event is scheduled.
EventFunctionWrapper matchEvent
void schedule(Event &event, Tick when)
void resyncMatch()
Called to update the matchEvent when the load Value or match value are written.
ArmInterruptPin *const interrupt
uint64_t getUintX(ByteOrder endian) const
Get the data in the packet byte swapped from the specified endianness and zero-extended to 64 bits.
bool maskInt
If the timer interrupt mask that is anded with the raw interrupt to generate a pending interrupt.
void unserialize(CheckpointIn &cp) override
Unserialize an object.
bool rawInt
If timer has caused an interrupt.
void serialize(CheckpointOut &cp) const override
Serialize an object.
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 ...
bool readId(PacketPtr pkt, uint64_t amba_id, Addr pio_addr)
Addr pioSize
Size that the device's address range.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
const std::string & name()
#define SERIALIZE_SCALAR(scalar)
T getLE() const
Get the data in the packet byte swapped from little endian to host endian.
AmbaPioDeviceParams Params
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
void counterMatch()
Called when the counter reaches matches.
Tick pioDelay
Delay that the device experinces on an access.
std::ostream CheckpointOut
Tick curTick()
The universal simulation clock.
PL031(const Params &p)
The constructor for RealView just registers itself with the MMU.
bool pendingInt
If an interrupt is currently pending.
#define panic(...)
This implements a cprintf based panic() function.
Generated on Tue Jun 22 2021 15:28:27 for gem5 by  doxygen 1.8.17