gem5  v21.0.1.0
base_gic.cc
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2012, 2017-2018 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/base_gic.hh"
39 
40 #include "cpu/thread_context.hh"
41 #include "dev/arm/realview.hh"
42 #include "params/ArmInterruptPin.hh"
43 #include "params/ArmPPI.hh"
44 #include "params/ArmSPI.hh"
45 #include "params/BaseGic.hh"
46 
48  : PioDevice(p),
49  platform(p.platform)
50 {
51  RealView *const rv = dynamic_cast<RealView*>(p.platform);
52  // The platform keeps track of the GIC that is hooked up to the
53  // system. Due to quirks in gem5's configuration system, the
54  // platform can't take a GIC as parameter. Instead, we need to
55  // register with the platform when a new GIC is created. If we
56  // can't find a platform, something is seriously wrong.
57  fatal_if(!rv, "GIC model can't register with platform code");
58  rv->setGic(this);
59 }
60 
62 {
63 }
64 
65 void
67 {
69  getSystem()->setGIC(this);
70 }
71 
72 const BaseGic::Params &
74 {
75  return dynamic_cast<const Params &>(_params);
76 }
77 
78 ArmInterruptPinGen::ArmInterruptPinGen(const ArmInterruptPinParams &p)
79  : SimObject(p)
80 {
81 }
82 
83 ArmSPIGen::ArmSPIGen(const ArmSPIParams &p)
84  : ArmInterruptPinGen(p), pin(new ArmSPI(p))
85 {
86 }
87 
90 {
91  return pin;
92 }
93 
94 ArmPPIGen::ArmPPIGen(const ArmPPIParams &p)
96 {
97 }
98 
101 {
102  panic_if(!tc, "Invalid Thread Context\n");
103  ContextID cid = tc->contextId();
104 
105  auto pin_it = pins.find(cid);
106 
107  if (pin_it != pins.end()) {
108  // PPI Pin Already generated
109  return pin_it->second;
110  } else {
111  // Generate PPI Pin
112  ArmPPI *pin = new ArmPPI(ArmPPIGen::params(), tc);
113 
114  pins.insert({cid, pin});
115 
116  return pin;
117  }
118 }
119 
121  const ArmInterruptPinParams &p, ThreadContext *tc)
122  : threadContext(tc), platform(dynamic_cast<RealView*>(p.platform)),
123  intNum(p.num), triggerType(p.int_type), _active(false)
124 {
125  fatal_if(!platform, "Interrupt not connected to a RealView platform");
126 }
127 
128 void
130 {
132  "InterruptLine::setThreadContext called twice\n");
133 
134  threadContext = tc;
135 }
136 
137 ContextID
139 {
140  panic_if(!threadContext, "Per-context interrupt triggered without a " \
141  "call to InterruptLine::setThreadContext.\n");
142  return threadContext->contextId();
143 }
144 
145 void
147 {
149 }
150 
151 void
153 {
155 }
156 
158  const ArmSPIParams &p)
159  : ArmInterruptPin(p, nullptr)
160 {
161 }
162 
163 void
165 {
166  _active = true;
168 }
169 
170 void
172 {
173  _active = false;
175 }
176 
178  const ArmPPIParams &p, ThreadContext *tc)
179  : ArmInterruptPin(p, tc)
180 {
181 }
182 
183 void
185 {
186  _active = true;
188 }
189 
190 void
192 {
193  _active = false;
195 }
ArmSPI::raise
void raise() override
Signal an interrupt.
Definition: base_gic.cc:164
BaseGic::Params
BaseGicParams Params
Definition: base_gic.hh:67
ArmSPI::ArmSPI
ArmSPI(const ArmSPIParams &p)
Definition: base_gic.cc:157
ArmSPI::clear
void clear() override
Clear a signalled interrupt.
Definition: base_gic.cc:171
RealView
Definition: realview.hh:57
ArmSPIGen::ArmSPIGen
ArmSPIGen(const ArmSPIParams &p)
Definition: base_gic.cc:83
UNSERIALIZE_SCALAR
#define UNSERIALIZE_SCALAR(scalar)
Definition: serialize.hh:591
PioDevice::init
void init() override
init() is called after all C++ SimObjects have been created and all ports are connected.
Definition: io_device.cc:56
ArmPPIGen::pins
std::unordered_map< ContextID, ArmPPI * > pins
Definition: base_gic.hh:173
RealView::setGic
void setGic(BaseGic *_gic)
Give platform a pointer to interrupt controller.
Definition: realview.hh:77
sc_dt::int_type
int64 int_type
Definition: sc_nbdefs.hh:240
ArmInterruptPin::setThreadContext
void setThreadContext(ThreadContext *tc)
Set the thread context owning this interrupt.
Definition: base_gic.cc:129
ContextID
int ContextID
Globally unique thread context ID.
Definition: types.hh:237
base_gic.hh
ArmPPIGen::get
ArmInterruptPin * get(ThreadContext *tc=nullptr) override
Definition: base_gic.cc:100
ArmPPI::ArmPPI
ArmPPI(const ArmPPIParams &p, ThreadContext *tc)
Definition: base_gic.cc:177
ArmInterruptPin::_active
bool _active
True if interrupt pin is active, false otherwise.
Definition: base_gic.hh:235
ArmInterruptPin::ArmInterruptPin
ArmInterruptPin(const ArmInterruptPinParams &p, ThreadContext *tc)
Definition: base_gic.cc:120
realview.hh
BaseGic::params
const Params & params() const
Definition: base_gic.cc:73
RealView::gic
BaseGic * gic
Definition: realview.hh:63
ArmInterruptPin::intNum
const uint32_t intNum
Interrupt number to generate.
Definition: base_gic.hh:229
BaseGic::init
void init() override
init() is called after all C++ SimObjects have been created and all ports are connected.
Definition: base_gic.cc:66
ArmSPIGen::get
ArmInterruptPin * get(ThreadContext *tc=nullptr) override
Definition: base_gic.cc:89
cp
Definition: cprintf.cc:37
PioDevice
This device is the base class which all devices senstive to an address range inherit from.
Definition: io_device.hh:99
ThreadContext
ThreadContext is the external interface to all thread state for anything outside of the CPU.
Definition: thread_context.hh:88
ArmInterruptPin::targetContext
ContextID targetContext() const
Get the target context ID of this interrupt.
Definition: base_gic.cc:138
ArmInterruptPinGen
This SimObject is instantiated in the python world and serves as an ArmInterruptPin generator.
Definition: base_gic.hh:137
ArmPPI::clear
void clear() override
Clear a signalled interrupt.
Definition: base_gic.cc:191
ArmInterruptPinGen::ArmInterruptPinGen
ArmInterruptPinGen(const ArmInterruptPinParams &p)
Definition: base_gic.cc:78
ThreadContext::contextId
virtual ContextID contextId() const =0
ArmInterruptPin::threadContext
const ThreadContext * threadContext
Pointer to the thread context that owns this interrupt in case it is a thread-/CPU-private interrupt.
Definition: base_gic.hh:223
BaseGic::clearPPInt
virtual void clearPPInt(uint32_t num, uint32_t cpu)=0
SimObject::_params
const SimObjectParams & _params
Cached copy of the object parameters.
Definition: sim_object.hh:159
ArmInterruptPin::platform
RealView *const platform
Arm platform to use for interrupt generation.
Definition: base_gic.hh:226
SERIALIZE_SCALAR
#define SERIALIZE_SCALAR(scalar)
Definition: serialize.hh:584
BaseGic::sendInt
virtual void sendInt(uint32_t num)=0
Post an interrupt from a device that is connected to the GIC.
BaseGic::~BaseGic
virtual ~BaseGic()
Definition: base_gic.cc:61
BaseGic::clearInt
virtual void clearInt(uint32_t num)=0
Clear an interrupt from a device that is connected to the GIC.
panic_if
#define panic_if(cond,...)
Conditional panic macro that checks the supplied condition and only panics if the condition is true a...
Definition: logging.hh:197
ArmSPIGen::pin
ArmSPI * pin
Definition: base_gic.hh:157
ArmSystem::setGIC
void setGIC(BaseGic *gic)
Sets the pointer to the GIC.
Definition: system.hh:183
ArmInterruptPin
Generic representation of an Arm interrupt pin.
Definition: base_gic.hh:179
BaseGic::BaseGic
BaseGic(const Params &p)
Definition: base_gic.cc:47
CheckpointOut
std::ostream CheckpointOut
Definition: serialize.hh:64
BaseGic::getSystem
ArmSystem * getSystem() const
Definition: base_gic.hh:106
ArmPPI::raise
void raise() override
Signal an interrupt.
Definition: base_gic.cc:184
SimObject::params
const Params & params() const
Definition: sim_object.hh:168
MipsISA::p
Bitfield< 0 > p
Definition: pra_constants.hh:323
BaseGic::sendPPInt
virtual void sendPPInt(uint32_t num, uint32_t cpu)=0
Interface call for private peripheral interrupts.
fatal_if
#define fatal_if(cond,...)
Conditional fatal macro that checks the supplied condition and only causes a fatal error if the condi...
Definition: logging.hh:219
ArmPPIGen::ArmPPIGen
ArmPPIGen(const Params &p)
Definition: base_gic.cc:94
CheckpointIn
Definition: serialize.hh:68
ArmInterruptPin::serialize
void serialize(CheckpointOut &cp) const override
Serialize an object.
Definition: base_gic.cc:146
ArmSPI
Definition: base_gic.hh:238
ArmPPI
Definition: base_gic.hh:249
ArmInterruptPin::unserialize
void unserialize(CheckpointIn &cp) override
Unserialize an object.
Definition: base_gic.cc:152
thread_context.hh
SimObject
Abstract superclass for simulation objects.
Definition: sim_object.hh:141

Generated on Tue Jun 22 2021 15:28:27 for gem5 by doxygen 1.8.17