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"
61 scpLow(
p.lowp_scp2ap),
62 scpHigh(
p.highp_scp2ap),
65 apHigh(
p.highp_ap2scp),
67 pid{ 0x98, 0xb0, 0x1b, 0x0, 0x4 },
68 compid{ 0x0d, 0xf0, 0x05, 0xb1 },
72 apHigh->setScp(
p.scp);
92 pkt->
setUintX(value, ByteOrder::little);
146 panic(
"Invalid register read at address: %#x\n",
addr);
155 assert(pkt->
getSize() ==
sizeof(uint32_t));
156 const uint32_t value = pkt->
getLE<uint32_t>();
201 panic(
"Invalid register write at address: %#x\n",
addr);
211 const bool int_old =
channel != 0;
212 const bool int_new = new_val != 0;
215 if (int_old && !int_new) {
217 }
else if (!int_old && int_new) {
void raiseInterrupt() override
Addr pioAddr
Address that the device listens to.
Tick write(PacketPtr pkt) override
Pure virtual function that the device must implement.
AddrRange RangeSize(Addr start, Addr size)
Ap2ScpDoorbell(const Ap2ScpDoorbellParams &p)
std::list< AddrRange > AddrRangeList
Convenience typedef for a collection of address ranges.
AddrRangeList getAddrRanges() const override
Every PIO device is obliged to provide an implementation that returns the address ranges the device r...
void clearInterrupt() override
void makeAtomicResponse()
void update(uint32_t new_val)
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
virtual void clearInterrupt()=0
uint64_t Tick
Tick count type.
virtual void clear()=0
Clear a signalled interrupt.
Scp2ApDoorbell(const Scp2ApDoorbellParams &p)
uint32_t read32(const Addr addr, bool secure_access)
Tick pioDelay
Delay that the device experinces on an access.
@ SCP_INTR_L_STAT
From SCP to Application Processor.
constexpr T bits(T val, unsigned first, unsigned last)
Extract the bitfield from position 'first' to 'last' (inclusive) from 'val' and right justify it.
void clearInterrupt() override
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
static const uint32_t SVI_INT
Tick read(PacketPtr pkt) override
Pure virtual function that the device must implement.
virtual void raiseInterrupt()=0
virtual void raiseInterrupt(const Doorbell *doorbell)=0
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.
ArmInterruptPin * interrupt
virtual void raise()=0
Signal an interrupt.
@ CPU_INTR_L_STAT
From Application Processor to SCP.
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 raiseInterrupt() override
#define panic(...)
This implements a cprintf based panic() function.
virtual void clearInterrupt(const Doorbell *doorbell)=0
Generated on Tue Dec 21 2021 11:34:27 for gem5 by doxygen 1.8.17