#include <gic_v3_distributor.hh>
|
| Gicv3Distributor (Gicv3 *gic, uint32_t it_lines) |
|
void | deassertSPI (uint32_t int_id) |
|
void | clearIrqCpuInterface (uint32_t int_id) |
|
void | init () |
|
uint64_t | read (Addr addr, size_t size, bool is_secure_access) |
|
void | sendInt (uint32_t int_id) |
|
void | write (Addr addr, uint64_t data, size_t size, bool is_secure_access) |
|
| Serializable () |
|
virtual | ~Serializable () |
|
void | serializeSection (CheckpointOut &cp, const char *name) const |
| Serialize an object into a new section. More...
|
|
void | serializeSection (CheckpointOut &cp, const std::string &name) const |
|
void | unserializeSection (CheckpointIn &cp, const char *name) |
| Unserialize an a child object. More...
|
|
void | unserializeSection (CheckpointIn &cp, const std::string &name) |
|
|
enum | {
GICD_CTLR = 0x0000,
GICD_TYPER = 0x0004,
GICD_IIDR = 0x0008,
GICD_STATUSR = 0x0010,
GICD_SETSPI_NSR = 0x0040,
GICD_CLRSPI_NSR = 0x0048,
GICD_SETSPI_SR = 0x0050,
GICD_CLRSPI_SR = 0x0058,
GICD_SGIR = 0x0f00,
GICD_PIDR0 = 0xffe0,
GICD_PIDR1 = 0xffe4,
GICD_PIDR2 = 0xffe8,
GICD_PIDR3 = 0xffec,
GICD_PIDR4 = 0xffd0,
GICD_PIDR5 = 0xffd4,
GICD_PIDR6 = 0xffd8,
GICD_PIDR7 = 0xffdc
} |
|
Definition at line 50 of file gic_v3_distributor.hh.
◆ anonymous enum
Enumerator |
---|
GICD_CTLR | |
GICD_TYPER | |
GICD_IIDR | |
GICD_STATUSR | |
GICD_SETSPI_NSR | |
GICD_CLRSPI_NSR | |
GICD_SETSPI_SR | |
GICD_CLRSPI_SR | |
GICD_SGIR | |
GICD_PIDR0 | |
GICD_PIDR1 | |
GICD_PIDR2 | |
GICD_PIDR3 | |
GICD_PIDR4 | |
GICD_PIDR5 | |
GICD_PIDR6 | |
GICD_PIDR7 | |
Definition at line 63 of file gic_v3_distributor.hh.
◆ Gicv3Distributor()
Gicv3Distributor::Gicv3Distributor |
( |
Gicv3 * |
gic, |
|
|
uint32_t |
it_lines |
|
) |
| |
◆ activateIRQ()
void Gicv3Distributor::activateIRQ |
( |
uint32_t |
int_id | ) |
|
|
protected |
◆ BitUnion64()
Gicv3Distributor::BitUnion64 |
( |
IROUTER |
| ) |
|
|
protected |
◆ clearIrqCpuInterface()
void Gicv3Distributor::clearIrqCpuInterface |
( |
uint32_t |
int_id | ) |
|
◆ deactivateIRQ()
void Gicv3Distributor::deactivateIRQ |
( |
uint32_t |
int_id | ) |
|
|
protected |
◆ deassertSPI()
void Gicv3Distributor::deassertSPI |
( |
uint32_t |
int_id | ) |
|
◆ EndBitUnion()
Gicv3Distributor::EndBitUnion |
( |
IROUTER |
| ) |
const |
|
protected |
◆ fullUpdate()
void Gicv3Distributor::fullUpdate |
( |
| ) |
|
|
protected |
◆ getIntGroup()
Definition at line 1116 of file gic_v3_distributor.cc.
References DS, Gicv3::G0S, Gicv3::G1NS, Gicv3::G1S, irqGroup, irqGrpmod, itLines, panic_if, Gicv3::PPI_MAX, and Gicv3::SGI_MAX.
Referenced by nsAccessToSecInt(), read(), route(), Gicv3CPUInterface::setMiscReg(), update(), Gicv3CPUInterface::virtualDeactivateIRQ(), and write().
◆ groupEnabled()
◆ init()
void Gicv3Distributor::init |
( |
| ) |
|
◆ intStatus()
◆ isNotSPI()
bool Gicv3Distributor::isNotSPI |
( |
uint32_t |
int_id | ) |
const |
|
inlineprotected |
◆ nsAccessToSecInt()
bool Gicv3Distributor::nsAccessToSecInt |
( |
uint32_t |
int_id, |
|
|
bool |
is_secure_access |
|
) |
| const |
|
inlineprotected |
Definition at line 227 of file gic_v3_distributor.hh.
References addr, clearIrqCpuInterface(), data, deassertSPI(), DS, Gicv3::G1NS, getIntGroup(), Gicv3Distributor(), init(), read(), route(), sendInt(), serialize(), Gicv3Its::size, unserialize(), update(), and write().
Referenced by read(), and write().
◆ read()
uint64_t Gicv3Distributor::read |
( |
Addr |
addr, |
|
|
size_t |
size, |
|
|
bool |
is_secure_access |
|
) |
| |
Definition at line 138 of file gic_v3_distributor.cc.
References ARE, AddrRange::contains(), DS, EnableGrp0, EnableGrp1NS, EnableGrp1S, Gicv3::G1NS, getIntGroup(), GICD_CPENDSGIR, GICD_CTLR, GICD_ICACTIVER, GICD_ICENABLER, GICD_ICFGR, GICD_ICPENDR, GICD_IGROUPR, GICD_IGRPMODR, GICD_IIDR, GICD_IPRIORITYR, GICD_IROUTER, GICD_ISACTIVER, GICD_ISENABLER, GICD_ISPENDR, GICD_ITARGETSR, GICD_NSACR, GICD_PIDR0, GICD_PIDR1, GICD_PIDR2, GICD_PIDR3, GICD_PIDR4, GICD_PIDR5, GICD_PIDR6, GICD_PIDR7, GICD_SPENDSGIR, GICD_STATUSR, GICD_TYPER, gicdPidr0, gicdPidr1, gicdPidr2, gicdPidr3, gicdPidr4, gicdTyper, ArmISA::i, Gicv3::INT_EDGE_TRIGGERED, irqActive, irqAffinityRouting, irqConfig, irqEnabled, irqGroup, irqGrpmod, irqNsacr, irqPending, irqPriority, isNotSPI(), itLines, nsAccessToSecInt(), panic, AddrRange::start(), X86ISA::val, and warn.
Referenced by nsAccessToSecInt(), and Gicv3::read().
◆ route()
Definition at line 1017 of file gic_v3_distributor.cc.
References Gicv3Redistributor::canBeSelectedFor1toNInterrupt(), Gicv3Redistributor::getCPUInterface(), getIntGroup(), Gicv3::getRedistributor(), Gicv3::getRedistributorByAffinity(), BaseGic::getSystem(), gic, ArmISA::i, irqAffinityRouting, and System::numContexts().
Referenced by clearIrqCpuInterface(), nsAccessToSecInt(), and update().
◆ sendInt()
void Gicv3Distributor::sendInt |
( |
uint32_t |
int_id | ) |
|
◆ serialize()
Serialize an object.
Output an object's state into the current checkpoint section.
- Parameters
-
Implements Serializable.
Definition at line 1156 of file gic_v3_distributor.cc.
References ARE, DS, EnableGrp0, EnableGrp1NS, EnableGrp1S, irqActive, irqAffinityRouting, irqConfig, irqEnabled, irqGroup, irqGrpmod, irqNsacr, irqPending, irqPriority, SERIALIZE_CONTAINER, and SERIALIZE_SCALAR.
Referenced by nsAccessToSecInt().
◆ unserialize()
Unserialize an object.
Read an object's state from the current checkpoint section.
- Parameters
-
Implements Serializable.
Definition at line 1175 of file gic_v3_distributor.cc.
References ARE, DS, EnableGrp0, EnableGrp1NS, EnableGrp1S, irqActive, irqAffinityRouting, irqConfig, irqEnabled, irqGroup, irqGrpmod, irqNsacr, irqPending, irqPriority, UNSERIALIZE_CONTAINER, and UNSERIALIZE_SCALAR.
Referenced by nsAccessToSecInt().
◆ update()
void Gicv3Distributor::update |
( |
| ) |
|
|
protected |
Definition at line 1062 of file gic_v3_distributor.cc.
References getIntGroup(), Gicv3::getRedistributor(), BaseGic::getSystem(), gic, Gicv3CPUInterface::hppi_t::group, groupEnabled(), Gicv3CPUInterface::hppi, ArmISA::i, Gicv3CPUInterface::hppi_t::intid, irqActive, irqEnabled, irqPending, irqPriority, itLines, System::numContexts(), Gicv3::PPI_MAX, Gicv3CPUInterface::hppi_t::prio, route(), Gicv3::SGI_MAX, and Gicv3Redistributor::update().
Referenced by deassertSPI(), nsAccessToSecInt(), sendInt(), Gicv3Redistributor::updateDistributor(), Gicv3CPUInterface::updateDistributor(), and write().
◆ write()
void Gicv3Distributor::write |
( |
Addr |
addr, |
|
|
uint64_t |
data, |
|
|
size_t |
size, |
|
|
bool |
is_secure_access |
|
) |
| |
Definition at line 507 of file gic_v3_distributor.cc.
References bits(), clearIrqCpuInterface(), AddrRange::contains(), data, deassertSPI(), Trace::disable(), DPRINTF, DS, X86ISA::enable, EnableGrp0, EnableGrp1NS, EnableGrp1S, Gicv3::G1NS, getIntGroup(), GICD_CLRSPI_NSR, GICD_CLRSPI_SR, GICD_CTLR, GICD_CTLR_DS, GICD_CTLR_ENABLEGRP1A, GICD_CTLR_ENABLEGRP1NS, GICD_CTLR_ENABLEGRP1S, GICD_ICACTIVER, GICD_ICENABLER, GICD_ICFGR, GICD_ICPENDR, GICD_IGROUPR, GICD_IGRPMODR, GICD_IPRIORITYR, GICD_IROUTER, GICD_ISACTIVER, GICD_ISENABLER, GICD_ISPENDR, GICD_ITARGETSR, GICD_NSACR, GICD_SETSPI_NSR, GICD_SETSPI_SR, GICD_SGIR, ArmISA::i, Gicv3::INT_EDGE_TRIGGERED, Gicv3::INT_LEVEL_SENSITIVE, irqActive, irqAffinityRouting, irqConfig, irqEnabled, irqGroup, irqGrpmod, irqNsacr, irqPending, irqPriority, isNotSPI(), itLines, nsAccessToSecInt(), panic, sendInt(), AddrRange::start(), update(), and warn.
Referenced by nsAccessToSecInt(), and Gicv3::write().
◆ Gicv3CPUInterface
◆ Gicv3Its
◆ Gicv3Redistributor
◆ ADDR_RANGE_SIZE
const uint32_t Gicv3Distributor::ADDR_RANGE_SIZE = 0x10000 |
|
static |
◆ Aff0
Bitfield<7, 0> Gicv3Distributor::Aff0 |
|
protected |
◆ Aff1
Bitfield<15, 8> Gicv3Distributor::Aff1 |
|
protected |
◆ Aff2
Bitfield<23, 16> Gicv3Distributor::Aff2 |
|
protected |
◆ Aff3
Bitfield<39, 32> Gicv3Distributor::Aff3 |
|
protected |
◆ ARE
bool Gicv3Distributor::ARE |
|
protected |
◆ DS
bool Gicv3Distributor::DS |
|
protected |
Definition at line 149 of file gic_v3_distributor.hh.
Referenced by Gicv3CPUInterface::getHPPIR0(), Gicv3CPUInterface::getHPPIR1(), getIntGroup(), Gicv3Redistributor::getIntGroup(), Gicv3Distributor(), Gicv3CPUInterface::intSignalType(), nsAccessToSecInt(), Gicv3Redistributor::read(), read(), Gicv3Redistributor::sendSGI(), serialize(), Gicv3CPUInterface::setMiscReg(), unserialize(), Gicv3Redistributor::write(), and write().
◆ EnableGrp0
bool Gicv3Distributor::EnableGrp0 |
|
protected |
◆ EnableGrp1NS
bool Gicv3Distributor::EnableGrp1NS |
|
protected |
◆ EnableGrp1S
bool Gicv3Distributor::EnableGrp1S |
|
protected |
◆ gic
Gicv3* Gicv3Distributor::gic |
|
protected |
◆ GICD_CPENDSGIR
const AddrRange Gicv3Distributor::GICD_CPENDSGIR |
|
staticprotected |
◆ GICD_CTLR_DS
const uint32_t Gicv3Distributor::GICD_CTLR_DS = 1 << 6 |
|
staticprotected |
◆ GICD_CTLR_ENABLEGRP1
const uint32_t Gicv3Distributor::GICD_CTLR_ENABLEGRP1 = 1 << 0 |
|
staticprotected |
◆ GICD_CTLR_ENABLEGRP1A
const uint32_t Gicv3Distributor::GICD_CTLR_ENABLEGRP1A = 1 << 1 |
|
staticprotected |
◆ GICD_CTLR_ENABLEGRP1NS
const uint32_t Gicv3Distributor::GICD_CTLR_ENABLEGRP1NS = 1 << 1 |
|
staticprotected |
◆ GICD_CTLR_ENABLEGRP1S
const uint32_t Gicv3Distributor::GICD_CTLR_ENABLEGRP1S = 1 << 2 |
|
staticprotected |
◆ GICD_ICACTIVER
const AddrRange Gicv3Distributor::GICD_ICACTIVER |
|
staticprotected |
◆ GICD_ICENABLER
const AddrRange Gicv3Distributor::GICD_ICENABLER |
|
staticprotected |
◆ GICD_ICFGR
◆ GICD_ICPENDR
const AddrRange Gicv3Distributor::GICD_ICPENDR |
|
staticprotected |
◆ GICD_IGROUPR
const AddrRange Gicv3Distributor::GICD_IGROUPR |
|
staticprotected |
◆ GICD_IGRPMODR
const AddrRange Gicv3Distributor::GICD_IGRPMODR |
|
staticprotected |
◆ GICD_IPRIORITYR
const AddrRange Gicv3Distributor::GICD_IPRIORITYR |
|
staticprotected |
◆ GICD_IROUTER
const AddrRange Gicv3Distributor::GICD_IROUTER |
|
staticprotected |
◆ GICD_ISACTIVER
const AddrRange Gicv3Distributor::GICD_ISACTIVER |
|
staticprotected |
◆ GICD_ISENABLER
const AddrRange Gicv3Distributor::GICD_ISENABLER |
|
staticprotected |
◆ GICD_ISPENDR
const AddrRange Gicv3Distributor::GICD_ISPENDR |
|
staticprotected |
◆ GICD_ITARGETSR
const AddrRange Gicv3Distributor::GICD_ITARGETSR |
|
staticprotected |
◆ GICD_NSACR
◆ GICD_SPENDSGIR
const AddrRange Gicv3Distributor::GICD_SPENDSGIR |
|
staticprotected |
◆ gicdPidr0
uint32_t Gicv3Distributor::gicdPidr0 |
|
protected |
◆ gicdPidr1
uint32_t Gicv3Distributor::gicdPidr1 |
|
protected |
◆ gicdPidr2
uint32_t Gicv3Distributor::gicdPidr2 |
|
protected |
◆ gicdPidr3
uint32_t Gicv3Distributor::gicdPidr3 |
|
protected |
◆ gicdPidr4
uint32_t Gicv3Distributor::gicdPidr4 |
|
protected |
◆ gicdTyper
uint32_t Gicv3Distributor::gicdTyper |
|
protected |
◆ IDBITS
const uint32_t Gicv3Distributor::IDBITS = 0xf |
|
static |
◆ IRM
Bitfield<31> Gicv3Distributor::IRM |
|
protected |
◆ irqActive
◆ irqAffinityRouting
std::vector<IROUTER> Gicv3Distributor::irqAffinityRouting |
|
protected |
◆ irqConfig
◆ irqEnabled
◆ irqGroup
◆ irqGrpmod
◆ irqNsacr
◆ irqPending
◆ irqPriority
◆ itLines
const uint32_t Gicv3Distributor::itLines |
|
protected |
◆ res0_1
◆ res0_2
Bitfield<30, 24> Gicv3Distributor::res0_2 |
|
protected |
The documentation for this class was generated from the following files: