Go to the documentation of this file.
40 #include "debug/MHU.hh"
44 #include "params/Ap2ScpDoorbell.hh"
45 #include "params/MHU.hh"
46 #include "params/Scp2ApDoorbell.hh"
58 scpLow(
p.lowp_scp2ap),
59 scpHigh(
p.highp_scp2ap),
62 apHigh(
p.highp_ap2scp),
64 pid{ 0x98, 0xb0, 0x1b, 0x0, 0x4 },
65 compid{ 0x0d, 0xf0, 0x05, 0xb1 },
69 apHigh->setScp(
p.scp);
89 pkt->
setUintX(value, ByteOrder::little);
143 panic(
"Invalid register read at address: %#x\n",
addr);
152 assert(pkt->
getSize() ==
sizeof(uint32_t));
153 const uint32_t value = pkt->
getLE<uint32_t>();
198 panic(
"Invalid register write at address: %#x\n",
addr);
208 const bool int_old =
channel != 0;
209 const bool int_new = new_val != 0;
212 if (int_old && !int_new) {
214 }
else if (!int_old && int_new) {
void makeAtomicResponse()
Addr pioAddr
Address that the device listens to.
@ SCP_INTR_L_STAT
From SCP to Application Processor.
virtual void raiseInterrupt(const Doorbell *doorbell)=0
void raiseInterrupt() override
virtual void clear()=0
Clear a signalled interrupt.
virtual void clearInterrupt()=0
ArmInterruptPin * interrupt
ArmInterruptPin * get(ThreadContext *tc=nullptr) override
virtual void raise()=0
Signal an interrupt.
uint64_t Tick
Tick count type.
uint32_t read32(const Addr addr, bool secure_access)
void clearInterrupt() override
AddrRangeList getAddrRanges() const override
Every PIO device is obliged to provide an implementation that returns the address ranges the device r...
std::list< AddrRange > AddrRangeList
Convenience typedef for a collection of address ranges.
void update(uint32_t new_val)
Ap2ScpDoorbell(const Ap2ScpDoorbellParams &p)
AddrRange RangeSize(Addr start, Addr size)
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 ...
@ CPU_INTR_L_STAT
From Application Processor to SCP.
Addr pioSize
Size that the device's address range.
static const uint32_t SVI_INT
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
Tick write(PacketPtr pkt) override
Pure virtual function that the device must implement.
void raiseInterrupt() override
virtual void clearInterrupt(const Doorbell *doorbell)=0
T getLE() const
Get the data in the packet byte swapped from little endian to host endian.
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
Tick pioDelay
Delay that the device experinces on an access.
constexpr T bits(T val, unsigned first, unsigned last)
Extract the bitfield from position 'first' to 'last' (inclusive) from 'val' and right justify it.
virtual void raiseInterrupt()=0
Tick read(PacketPtr pkt) override
Pure virtual function that the device must implement.
Scp2ApDoorbell(const Scp2ApDoorbellParams &p)
void clearInterrupt() override
#define panic(...)
This implements a cprintf based panic() function.
Generated on Tue Mar 23 2021 19:41:25 for gem5 by doxygen 1.8.17