gem5  v20.0.0.0
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages
Public Member Functions | Protected Member Functions | Protected Attributes | Friends | List of all members
ArmInterruptPin Class Referenceabstract

Generic representation of an Arm interrupt pin. More...

#include <base_gic.hh>

Inheritance diagram for ArmInterruptPin:
ArmPPI ArmSPI

Public Member Functions

void setThreadContext (ThreadContext *tc)
 Set the thread context owning this interrupt. More...
 
uint32_t num () const
 Get interrupt number. More...
 
virtual void raise ()=0
 Signal an interrupt. More...
 
virtual void clear ()=0
 Clear a signalled interrupt. More...
 

Protected Member Functions

 ArmInterruptPin (Platform *platform, ThreadContext *tc, uint32_t int_num)
 
ContextID targetContext () const
 Get the target context ID of this interrupt. More...
 

Protected Attributes

const ThreadContextthreadContext
 Pointer to the thread context that owns this interrupt in case it is a thread-/CPU-private interrupt. More...
 
RealView *const platform
 Arm platform to use for interrupt generation. More...
 
const uint32_t intNum
 Interrupt number to generate. More...
 

Friends

class ArmInterruptPinGen
 

Detailed Description

Generic representation of an Arm interrupt pin.

Definition at line 176 of file base_gic.hh.

Constructor & Destructor Documentation

◆ ArmInterruptPin()

ArmInterruptPin::ArmInterruptPin ( Platform platform,
ThreadContext tc,
uint32_t  int_num 
)
protected

Definition at line 121 of file base_gic.cc.

References fatal_if, and platform.

Member Function Documentation

◆ clear()

virtual void ArmInterruptPin::clear ( )
pure virtual

Clear a signalled interrupt.

Implemented in ArmPPI, and ArmSPI.

Referenced by ArmISA::PMU::clearInterrupt(), and MmioVirtIO::setInterrupts().

◆ num()

uint32_t ArmInterruptPin::num ( ) const
inline

Get interrupt number.

Definition at line 194 of file base_gic.hh.

◆ raise()

virtual void ArmInterruptPin::raise ( )
pure virtual

◆ setThreadContext()

void ArmInterruptPin::setThreadContext ( ThreadContext tc)

Set the thread context owning this interrupt.

This method is used to set the thread context for interrupts that are thread/CPU-specific. Only devices that are used in such a context are expected to call this method.

Definition at line 130 of file base_gic.cc.

References panic_if, and threadContext.

◆ targetContext()

ContextID ArmInterruptPin::targetContext ( ) const
protected

Get the target context ID of this interrupt.

Precondition
setThreadContext() must have been called prior to calling this method.

Definition at line 139 of file base_gic.cc.

References ThreadContext::contextId(), panic_if, and threadContext.

Referenced by ArmPPI::clear(), and ArmPPI::raise().

Friends And Related Function Documentation

◆ ArmInterruptPinGen

friend class ArmInterruptPinGen
friend

Definition at line 178 of file base_gic.hh.

Member Data Documentation

◆ intNum

const uint32_t ArmInterruptPin::intNum
protected

Interrupt number to generate.

Definition at line 220 of file base_gic.hh.

Referenced by ArmSPI::clear(), ArmPPI::clear(), ArmSPI::raise(), and ArmPPI::raise().

◆ platform

RealView* const ArmInterruptPin::platform
protected

Arm platform to use for interrupt generation.

Definition at line 217 of file base_gic.hh.

Referenced by ArmInterruptPin(), ArmSPI::clear(), ArmPPI::clear(), ArmSPI::raise(), and ArmPPI::raise().

◆ threadContext

const ThreadContext* ArmInterruptPin::threadContext
protected

Pointer to the thread context that owns this interrupt in case it is a thread-/CPU-private interrupt.

Definition at line 214 of file base_gic.hh.

Referenced by setThreadContext(), and targetContext().


The documentation for this class was generated from the following files:

Generated on Thu May 28 2020 16:21:41 for gem5 by doxygen 1.8.13