gem5 [DEVELOP-FOR-25.0]
Loading...
Searching...
No Matches
gem5::GenericISA::DelaySlotPCState< InstWidth > Class Template Reference

#include <pcstate.hh>

Inheritance diagram for gem5::GenericISA::DelaySlotPCState< InstWidth >:
gem5::GenericISA::SimplePCState< InstWidth > gem5::GenericISA::PCStateWithNext gem5::PCStateBase gem5::Serializable gem5::GenericISA::DelaySlotUPCState< 4 > gem5::GenericISA::DelaySlotUPCState< InstWidth >

Public Member Functions

void output (std::ostream &os) const override
 
PCStateBaseclone () const override
 
void update (const PCStateBase &other) override
 
Addr nnpc () const
 
void nnpc (Addr val)
 
void set (Addr val) override
 
 DelaySlotPCState (const DelaySlotPCState &other)
 
DelaySlotPCStateoperator= (const DelaySlotPCState &other)=default
 
 DelaySlotPCState ()
 
 DelaySlotPCState (Addr val)
 
bool branching () const override
 
void advance () override
 
bool equals (const PCStateBase &other) const override
 
void serialize (CheckpointOut &cp) const override
 Serialize an object.
 
void unserialize (CheckpointIn &cp) override
 Unserialize an object.
 
- Public Member Functions inherited from gem5::GenericISA::SimplePCState< InstWidth >
 SimplePCState (const SimplePCState &other)
 
SimplePCStateoperator= (const SimplePCState &other)=default
 
 SimplePCState ()
 
 SimplePCState (Addr val)
 
PCStateBaseclone () const override
 
void set (Addr val) override
 Force this PC to reflect a particular value, resetting all its other fields around it.
 
bool branching () const override
 
void advance () override
 
- Public Member Functions inherited from gem5::GenericISA::PCStateWithNext
Addr pc () const
 
void pc (Addr val)
 
Addr npc () const
 
void npc (Addr val)
 
MicroPC upc () const
 
void upc (MicroPC val)
 
MicroPC nupc () const
 
void nupc (MicroPC val)
 
void uReset () override
 
void setNPC (Addr val)
 
void output (std::ostream &os) const override
 
void update (const PCStateBase &other) override
 
bool equals (const PCStateBase &other) const override
 
void serialize (CheckpointOut &cp) const override
 Serialize an object.
 
void unserialize (CheckpointIn &cp) override
 Unserialize an object.
 
- Public Member Functions inherited from gem5::PCStateBase
virtual ~PCStateBase ()=default
 
template<class Target>
Target & as ()
 
template<class Target>
const Target & as () const
 
void update (const PCStateBase *ptr)
 
Addr instAddr () const
 Returns the memory address of the instruction this PC points to.
 
MicroPC microPC () const
 Returns the current micropc.
 
- Public Member Functions inherited from gem5::Serializable
 Serializable ()
 
virtual ~Serializable ()
 
void serializeSection (CheckpointOut &cp, const char *name) const
 Serialize an object into a new section.
 
void serializeSection (CheckpointOut &cp, const std::string &name) const
 
void unserializeSection (CheckpointIn &cp, const char *name)
 Unserialize an a child object.
 
void unserializeSection (CheckpointIn &cp, const std::string &name)
 

Protected Types

typedef SimplePCState< InstWidth > Base
 
- Protected Types inherited from gem5::GenericISA::SimplePCState< InstWidth >
typedef PCStateWithNext Base
 

Protected Attributes

Addr _nnpc
 
- Protected Attributes inherited from gem5::GenericISA::PCStateWithNext
Addr _npc = 0
 
MicroPC _nupc = 1
 
- Protected Attributes inherited from gem5::PCStateBase
Addr _pc = 0
 
MicroPC _upc = 0
 

Additional Inherited Members

- Static Public Member Functions inherited from gem5::Serializable
static const std::string & currentSection ()
 Gets the fully-qualified name of the active section.
 
static void generateCheckpointOut (const std::string &cpt_dir, std::ofstream &outstream)
 Generate a checkpoint file so that the serialization can be routed to it.
 
- Protected Member Functions inherited from gem5::GenericISA::PCStateWithNext
 PCStateWithNext (const PCStateWithNext &other)
 
PCStateWithNextoperator= (const PCStateWithNext &other)=default
 
 PCStateWithNext ()
 
- Protected Member Functions inherited from gem5::PCStateBase
 PCStateBase (const PCStateBase &other)
 
PCStateBaseoperator= (const PCStateBase &other)=default
 
 PCStateBase ()
 

Detailed Description

template<int InstWidth>
class gem5::GenericISA::DelaySlotPCState< InstWidth >

Definition at line 460 of file pcstate.hh.

Member Typedef Documentation

◆ Base

template<int InstWidth>
typedef SimplePCState<InstWidth> gem5::GenericISA::DelaySlotPCState< InstWidth >::Base
protected

Definition at line 463 of file pcstate.hh.

Constructor & Destructor Documentation

◆ DelaySlotPCState() [1/3]

template<int InstWidth>
gem5::GenericISA::DelaySlotPCState< InstWidth >::DelaySlotPCState ( const DelaySlotPCState< InstWidth > & other)
inline

Definition at line 498 of file pcstate.hh.

◆ DelaySlotPCState() [2/3]

template<int InstWidth>
gem5::GenericISA::DelaySlotPCState< InstWidth >::DelaySlotPCState ( )
inline

Definition at line 502 of file pcstate.hh.

Referenced by gem5::GenericISA::DelaySlotPCState< 4 >::clone().

◆ DelaySlotPCState() [3/3]

template<int InstWidth>
gem5::GenericISA::DelaySlotPCState< InstWidth >::DelaySlotPCState ( Addr val)
inlineexplicit

Definition at line 503 of file pcstate.hh.

Member Function Documentation

◆ advance()

template<int InstWidth>
void gem5::GenericISA::DelaySlotPCState< InstWidth >::advance ( )
inlineoverridevirtual

Implements gem5::PCStateBase.

Definition at line 515 of file pcstate.hh.

Referenced by gem5::GenericISA::DelaySlotUPCState< 4 >::uEnd().

◆ branching()

template<int InstWidth>
bool gem5::GenericISA::DelaySlotPCState< InstWidth >::branching ( ) const
inlineoverridevirtual

◆ clone()

template<int InstWidth>
PCStateBase * gem5::GenericISA::DelaySlotPCState< InstWidth >::clone ( ) const
inlineoverridevirtual

◆ equals()

template<int InstWidth>
bool gem5::GenericISA::DelaySlotPCState< InstWidth >::equals ( const PCStateBase & other) const
inlineoverridevirtual

Reimplemented from gem5::PCStateBase.

Definition at line 523 of file pcstate.hh.

◆ nnpc() [1/2]

◆ nnpc() [2/2]

template<int InstWidth>
void gem5::GenericISA::DelaySlotPCState< InstWidth >::nnpc ( Addr val)
inline

Definition at line 489 of file pcstate.hh.

◆ operator=()

template<int InstWidth>
DelaySlotPCState & gem5::GenericISA::DelaySlotPCState< InstWidth >::operator= ( const DelaySlotPCState< InstWidth > & other)
default

◆ output()

template<int InstWidth>
void gem5::GenericISA::DelaySlotPCState< InstWidth >::output ( std::ostream & os) const
inlineoverridevirtual

◆ serialize()

template<int InstWidth>
void gem5::GenericISA::DelaySlotPCState< InstWidth >::serialize ( CheckpointOut & cp) const
inlineoverridevirtual

Serialize an object.

Output an object's state into the current checkpoint section.

Parameters
cpCheckpoint state

Implements gem5::Serializable.

Definition at line 530 of file pcstate.hh.

◆ set()

template<int InstWidth>
void gem5::GenericISA::DelaySlotPCState< InstWidth >::set ( Addr val)
inlineoverridevirtual

◆ unserialize()

template<int InstWidth>
void gem5::GenericISA::DelaySlotPCState< InstWidth >::unserialize ( CheckpointIn & cp)
inlineoverridevirtual

Unserialize an object.

Read an object's state from the current checkpoint section.

Parameters
cpCheckpoint state

Implements gem5::Serializable.

Definition at line 537 of file pcstate.hh.

◆ update()

template<int InstWidth>
void gem5::GenericISA::DelaySlotPCState< InstWidth >::update ( const PCStateBase & other)
inlineoverridevirtual

Reimplemented from gem5::PCStateBase.

Definition at line 481 of file pcstate.hh.

Member Data Documentation

◆ _nnpc

template<int InstWidth>
Addr gem5::GenericISA::DelaySlotPCState< InstWidth >::_nnpc
protected

Definition at line 465 of file pcstate.hh.


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

Generated on Mon May 26 2025 09:19:32 for gem5 by doxygen 1.13.2