Go to the documentation of this file.
42 #include "debug/SCMI.hh"
54 readMessageEvent([
this]{ readMessage(); },
name()),
55 handleMessageEvent([
this]{ handleMessage(); },
name())
66 DPRINTF(SCMI,
"Pending message\n");
87 DPRINTF(SCMI,
"SCMI Virtual channel %u, channel.status: %u\n",
113 DPRINTF(SCMI,
"SCMI Virtual channel %u, message.length: %u\n",
126 "SCMI Virtual channel %u, message.header: %#x\n",
138 notifyAgentEvent([
this]{ notifyAgent(); },
name()),
139 completeEvent([
this]{ complete(); },
name()),
141 platformDoorbellVal(0)
148 "SCMI Virtual channel %u, writing back message %u"
149 " with status code: %d\n",
167 "SCMI Virtual channel %u, clearing doorbell\n",
185 "SCMI Virtual channel %u, notifying agent\n",
209 for (
auto comm :
comms) {
210 comm->agentChan->dmaPort = &
dmaPort;
211 comm->agentChan->setPlatform(
this);
213 comm->platformChan->dmaPort = &
dmaPort;
214 comm->platformChan->setPlatform(
this);
218 "The number of instantiated protocols are not matching the"
219 " architected limit");
232 if (if_name ==
"dma") {
246 "Unimplemented SCMI protocol: %u\n", prot_id);
261 DPRINTF(SCMI,
"Raise interrupt in SCMI platform\n");
267 for (
auto comm :
comms) {
268 auto channel = comm->agentChan;
269 if (channel->doorbell == doorbell) {
272 channel->initiateRead();
277 panic(
"No matching virtual channel\n");
283 DPRINTF(SCMI,
"Clear interrupt in SCMI platform\n");
289 for (
auto comm :
comms) {
290 if (comm->platformChan == platform) {
291 return comm->agentChan;
301 for (
auto comm :
comms) {
302 if (comm->agentChan == agent) {
303 return comm->platformChan;
int16_t PortID
Port index/ID type, and a symbolic name for an invalid port id.
virtual Port & getPort(const std::string &if_name, PortID idx=InvalidPortID)
Get a port with a given name and index.
Addr start() const
Get the start address of the range.
virtual void handleMessage(Message &msg)=0
void dmaAction(Packet::Command cmd, Addr addr, int size, Event *event, uint8_t *data, Tick delay, Request::Flags flag=0)
EventFunctionWrapper readMessageEvent
Generic communication channel between the Agent and the Platform.
This protocol describes the properties of the implementation and provides generic error management.
This is a Agent to Platform channel (The agent is the initiator)
EventFunctionWrapper handleMessageEvent
AgentChannel(const ScmiChannelParams &p)
static const uint8_t PROTOCOL_MAX
@ UNCACHEABLE
The request is to an uncacheable address.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
const std::string & name()
EventFunctionWrapper readLengthEvent
#define panic_if(cond,...)
Conditional panic macro that checks the supplied condition and only panics if the condition is true a...
Generic doorbell interface.
Ports are used to interface objects to each other.
Addr clearAddress() const
#define fatal_if(cond,...)
Conditional fatal macro that checks the supplied condition and only causes a fatal error if the condi...
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
#define panic(...)
This implements a cprintf based panic() function.
Generated on Sun Jul 30 2023 01:56:54 for gem5 by doxygen 1.8.17