gem5  v21.0.0.0
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages
mhu.cc
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2020 ARM Limited
3  * All rights reserved
4  *
5  * The license below extends only to copyright in the software and shall
6  * not be construed as granting a license to any other intellectual
7  * property including but not limited to intellectual property relating
8  * to a hardware implementation of the functionality of the software
9  * licensed hereunder. You may use the software subject to the license
10  * terms below provided that you ensure that this notice is replicated
11  * unmodified and in its entirety in all distributions of the software,
12  * modified or unmodified, in source code or in binary form.
13  *
14  * Redistribution and use in source and binary forms, with or without
15  * modification, are permitted provided that the following conditions are
16  * met: redistributions of source code must retain the above copyright
17  * notice, this list of conditions and the following disclaimer;
18  * redistributions in binary form must reproduce the above copyright
19  * notice, this list of conditions and the following disclaimer in the
20  * documentation and/or other materials provided with the distribution;
21  * neither the name of the copyright holders nor the names of its
22  * contributors may be used to endorse or promote products derived from
23  * this software without specific prior written permission.
24  *
25  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
26  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
27  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
28  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
29  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
30  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
31  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
32  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
33  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
34  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
35  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
36  */
37 
38 #include "dev/arm/css/mhu.hh"
39 
40 #include "debug/MHU.hh"
41 #include "dev/arm/base_gic.hh"
42 #include "dev/arm/css/scp.hh"
43 #include "mem/packet_access.hh"
44 #include "params/Ap2ScpDoorbell.hh"
45 #include "params/MHU.hh"
46 #include "params/Scp2ApDoorbell.hh"
47 
48 Scp2ApDoorbell::Scp2ApDoorbell(const Scp2ApDoorbellParams &p)
49  : MhuDoorbell(p), interrupt(p.interrupt->get())
50 {}
51 
52 Ap2ScpDoorbell::Ap2ScpDoorbell(const Ap2ScpDoorbellParams &p)
53  : MhuDoorbell(p)
54 {}
55 
56 MHU::MHU(const MHUParams &p)
57  : BasicPioDevice(p, p.pio_size),
58  scpLow(p.lowp_scp2ap),
59  scpHigh(p.highp_scp2ap),
60  scpSec(p.sec_scp2ap),
61  apLow(p.lowp_ap2scp),
62  apHigh(p.highp_ap2scp),
63  apSec(p.sec_ap2scp),
64  pid{ 0x98, 0xb0, 0x1b, 0x0, 0x4 },
65  compid{ 0x0d, 0xf0, 0x05, 0xb1 },
66  scfg(0)
67 {
68  apLow->setScp(p.scp);
69  apHigh->setScp(p.scp);
70  apSec->setScp(p.scp);
71 }
72 
75 {
76  return AddrRangeList({ RangeSize(pioAddr, pioSize) });
77 }
78 
79 Tick
81 {
82  const Addr addr = pkt->getAddr() - pioAddr;
83  const bool secure = pkt->isSecure();
84 
85  uint32_t value = read32(addr, secure);
86 
87  DPRINTF(MHU, "Reading %#x at address: %#x\n", value, addr);
88 
89  pkt->setUintX(value, ByteOrder::little);
90  pkt->makeAtomicResponse();
91  return pioDelay;
92 }
93 
94 uint32_t
95 MHU::read32(const Addr addr, bool secure_access)
96 {
97  switch (addr) {
98  case SCP_INTR_L_STAT:
99  return scpLow->channel;
100  case SCP_INTR_H_STAT:
101  return scpHigh->channel;
102  case CPU_INTR_L_STAT:
103  return apLow->channel;
104  case CPU_INTR_H_STAT:
105  return apHigh->channel;
106  case SCP_INTR_S_STAT:
107  if (secure_access) {
108  return scpSec->channel;
109  } else {
110  if (!bits(scfg, 0))
111  scpSec->set(SVI_INT);
112  return 0;
113  }
114  case CPU_INTR_S_STAT:
115  if (secure_access) {
116  return apSec->channel;
117  } else {
118  if (!bits(scfg, 0))
119  scpSec->set(SVI_INT);
120  return 0;
121  }
122  case MHU_SCFG:
123  return scfg;
124  case PID4:
125  return pid[4];
126  case PID0:
127  return pid[0];
128  case PID1:
129  return pid[1];
130  case PID2:
131  return pid[2];
132  case PID3:
133  return pid[3];
134  case COMPID0:
135  return compid[0];
136  case COMPID1:
137  return compid[1];
138  case COMPID2:
139  return compid[2];
140  case COMPID3:
141  return compid[3];
142  default:
143  panic("Invalid register read at address: %#x\n", addr);
144  }
145 }
146 
147 Tick
149 {
150  const Addr addr = pkt->getAddr() - pioAddr;
151 
152  assert(pkt->getSize() == sizeof(uint32_t));
153  const uint32_t value = pkt->getLE<uint32_t>();
154 
155  DPRINTF(MHU, "Writing %#x at address: %#x\n", value, addr);
156 
157  switch (addr) {
158  case SCP_INTR_L_SET:
159  scpLow->set(value);
160  break;
161  case SCP_INTR_L_CLEAR:
162  scpLow->clear(value);
163  break;
164  case SCP_INTR_H_SET:
165  scpHigh->set(value);
166  break;
167  case SCP_INTR_H_CLEAR:
168  scpHigh->clear(value);
169  break;
170  case CPU_INTR_L_SET:
171  apLow->set(value);
172  break;
173  case CPU_INTR_L_CLEAR:
174  apLow->clear(value);
175  break;
176  case CPU_INTR_H_SET:
177  apHigh->set(value);
178  break;
179  case CPU_INTR_H_CLEAR:
180  apHigh->clear(value);
181  break;
182  case SCP_INTR_S_SET:
183  scpSec->set(value);
184  break;
185  case SCP_INTR_S_CLEAR:
186  scpSec->clear(value);
187  break;
188  case CPU_INTR_S_SET:
189  apSec->set(value);
190  break;
191  case CPU_INTR_S_CLEAR:
192  apSec->clear(value);
193  break;
194  case MHU_SCFG:
195  scfg = value;
196  break;
197  default:
198  panic("Invalid register write at address: %#x\n", addr);
199  }
200 
201  pkt->makeAtomicResponse();
202  return pioDelay;
203 }
204 
205 void
206 MhuDoorbell::update(uint32_t new_val)
207 {
208  const bool int_old = channel != 0;
209  const bool int_new = new_val != 0;
210 
211  channel = new_val;
212  if (int_old && !int_new) {
213  clearInterrupt();
214  } else if (!int_old && int_new) {
215  raiseInterrupt();
216  }
217 }
218 
219 void
221 {
222  interrupt->raise();
223 }
224 
225 void
227 {
228  interrupt->clear();
229 }
230 
231 void
233 {
234  scp->raiseInterrupt(this);
235 }
236 
237 void
239 {
240  scp->clearInterrupt(this);
241 }
MHU::scfg
uint32_t scfg
Definition: mhu.hh:166
Packet::makeAtomicResponse
void makeAtomicResponse()
Definition: packet.hh:1017
BasicPioDevice::pioAddr
Addr pioAddr
Address that the device listens to.
Definition: io_device.hh:148
MHU::SCP_INTR_L_STAT
@ SCP_INTR_L_STAT
From SCP to Application Processor.
Definition: mhu.hh:105
MHU::apHigh
Ap2ScpDoorbell * apHigh
Definition: mhu.hh:159
MHU::SCP_INTR_L_SET
@ SCP_INTR_L_SET
Definition: mhu.hh:106
Scp::raiseInterrupt
virtual void raiseInterrupt(const Doorbell *doorbell)=0
MHU::COMPID0
@ COMPID0
Definition: mhu.hh:135
Packet::getAddr
Addr getAddr() const
Definition: packet.hh:755
MHU::CPU_INTR_H_STAT
@ CPU_INTR_H_STAT
Definition: mhu.hh:116
MHU::CPU_INTR_H_SET
@ CPU_INTR_H_SET
Definition: mhu.hh:117
MHU::scpLow
Scp2ApDoorbell * scpLow
Definition: mhu.hh:154
Ap2ScpDoorbell::raiseInterrupt
void raiseInterrupt() override
Definition: mhu.cc:232
MHU::PID1
@ PID1
Definition: mhu.hh:131
ArmInterruptPin::clear
virtual void clear()=0
Clear a signalled interrupt.
MhuDoorbell::clearInterrupt
virtual void clearInterrupt()=0
base_gic.hh
Scp2ApDoorbell::interrupt
ArmInterruptPin * interrupt
Definition: mhu.hh:81
MHU::CPU_INTR_S_CLEAR
@ CPU_INTR_S_CLEAR
Definition: mhu.hh:125
ArmPPIGen::get
ArmInterruptPin * get(ThreadContext *tc=nullptr) override
Definition: base_gic.cc:100
MHU::CPU_INTR_S_STAT
@ CPU_INTR_S_STAT
Definition: mhu.hh:123
ArmInterruptPin::raise
virtual void raise()=0
Signal an interrupt.
Tick
uint64_t Tick
Tick count type.
Definition: types.hh:59
MHU::apSec
Ap2ScpDoorbell * apSec
Definition: mhu.hh:160
Packet::getSize
unsigned getSize() const
Definition: packet.hh:765
MHU::CPU_INTR_S_SET
@ CPU_INTR_S_SET
Definition: mhu.hh:124
MHU
Message Handling Unit.
Definition: mhu.hh:99
Packet::isSecure
bool isSecure() const
Definition: packet.hh:784
MHU::read32
uint32_t read32(const Addr addr, bool secure_access)
Definition: mhu.cc:95
MHU::CPU_INTR_L_SET
@ CPU_INTR_L_SET
Definition: mhu.hh:114
Scp2ApDoorbell::clearInterrupt
void clearInterrupt() override
Definition: mhu.cc:226
scp.hh
MHU::SCP_INTR_H_SET
@ SCP_INTR_H_SET
Definition: mhu.hh:109
MhuDoorbell
Definition: mhu.hh:51
MHU::getAddrRanges
AddrRangeList getAddrRanges() const override
Every PIO device is obliged to provide an implementation that returns the address ranges the device r...
Definition: mhu.cc:74
mhu.hh
AddrRangeList
std::list< AddrRange > AddrRangeList
Convenience typedef for a collection of address ranges.
Definition: addr_range.hh:631
MHU::CPU_INTR_H_CLEAR
@ CPU_INTR_H_CLEAR
Definition: mhu.hh:118
DPRINTF
#define DPRINTF(x,...)
Definition: trace.hh:237
MHU::MHU_SCFG
@ MHU_SCFG
Definition: mhu.hh:127
MHU::PID2
@ PID2
Definition: mhu.hh:132
MhuDoorbell::update
void update(uint32_t new_val)
Definition: mhu.cc:206
MHU::PID0
@ PID0
Definition: mhu.hh:130
Ap2ScpDoorbell::Ap2ScpDoorbell
Ap2ScpDoorbell(const Ap2ScpDoorbellParams &p)
Definition: mhu.cc:52
RangeSize
AddrRange RangeSize(Addr start, Addr size)
Definition: addr_range.hh:651
MHU::PID4
@ PID4
Definition: mhu.hh:129
Packet::setUintX
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 ...
Definition: packet.cc:367
MHU::CPU_INTR_L_STAT
@ CPU_INTR_L_STAT
From Application Processor to SCP.
Definition: mhu.hh:113
MHU::SCP_INTR_H_STAT
@ SCP_INTR_H_STAT
Definition: mhu.hh:108
BasicPioDevice::pioSize
Addr pioSize
Size that the device's address range.
Definition: io_device.hh:151
MhuDoorbell::set
void set(uint32_t val)
Definition: mhu.hh:60
MHU::CPU_INTR_L_CLEAR
@ CPU_INTR_L_CLEAR
Definition: mhu.hh:115
MHU::SVI_INT
static const uint32_t SVI_INT
Definition: mhu.hh:143
Addr
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
Definition: types.hh:148
packet_access.hh
MHU::SCP_INTR_S_CLEAR
@ SCP_INTR_S_CLEAR
Definition: mhu.hh:122
MHU::write
Tick write(PacketPtr pkt) override
Pure virtual function that the device must implement.
Definition: mhu.cc:148
X86ISA::addr
Bitfield< 3 > addr
Definition: types.hh:80
Scp2ApDoorbell::raiseInterrupt
void raiseInterrupt() override
Definition: mhu.cc:220
MHU::scpHigh
Scp2ApDoorbell * scpHigh
Definition: mhu.hh:155
Scp::clearInterrupt
virtual void clearInterrupt(const Doorbell *doorbell)=0
MHU::apLow
Ap2ScpDoorbell * apLow
Definition: mhu.hh:158
MHU::PID3
@ PID3
Definition: mhu.hh:133
Packet::getLE
T getLE() const
Get the data in the packet byte swapped from little endian to host endian.
Definition: packet_access.hh:75
MHU::compid
uint32_t compid[4]
Definition: mhu.hh:164
MHU::SCP_INTR_H_CLEAR
@ SCP_INTR_H_CLEAR
Definition: mhu.hh:110
MHU::MHU
MHU(const MHUParams &p)
Definition: mhu.cc:56
MHU::SCP_INTR_S_STAT
@ SCP_INTR_S_STAT
Definition: mhu.hh:120
Packet
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
Definition: packet.hh:258
BasicPioDevice
Definition: io_device.hh:144
Ap2ScpDoorbell::scp
Scp * scp
Definition: mhu.hh:95
BasicPioDevice::pioDelay
Tick pioDelay
Delay that the device experinces on an access.
Definition: io_device.hh:154
MHU::SCP_INTR_L_CLEAR
@ SCP_INTR_L_CLEAR
Definition: mhu.hh:107
bits
constexpr T bits(T val, unsigned first, unsigned last)
Extract the bitfield from position 'first' to 'last' (inclusive) from 'val' and right justify it.
Definition: bitfield.hh:73
MHU::COMPID3
@ COMPID3
Definition: mhu.hh:138
MhuDoorbell::raiseInterrupt
virtual void raiseInterrupt()=0
MHU::read
Tick read(PacketPtr pkt) override
Pure virtual function that the device must implement.
Definition: mhu.cc:80
MHU::scpSec
Scp2ApDoorbell * scpSec
Definition: mhu.hh:156
MipsISA::p
Bitfield< 0 > p
Definition: pra_constants.hh:323
std::list< AddrRange >
MHU::pid
uint32_t pid[5]
Definition: mhu.hh:163
MHU::COMPID2
@ COMPID2
Definition: mhu.hh:137
MHU::SCP_INTR_S_SET
@ SCP_INTR_S_SET
Definition: mhu.hh:121
MhuDoorbell::channel
uint32_t channel
Definition: mhu.hh:69
Scp2ApDoorbell::Scp2ApDoorbell
Scp2ApDoorbell(const Scp2ApDoorbellParams &p)
Definition: mhu.cc:48
MhuDoorbell::clear
void clear(uint32_t val)
Definition: mhu.hh:61
Ap2ScpDoorbell::clearInterrupt
void clearInterrupt() override
Definition: mhu.cc:238
panic
#define panic(...)
This implements a cprintf based panic() function.
Definition: logging.hh:171
MHU::COMPID1
@ COMPID1
Definition: mhu.hh:136

Generated on Tue Mar 23 2021 19:41:25 for gem5 by doxygen 1.8.17