gem5 v24.0.0.0
Loading...
Searching...
No Matches
MultiSocketSimpleSwitchAT Class Reference

#include <MultiSocketSimpleSwitchAT.h>

Inheritance diagram for MultiSocketSimpleSwitchAT:
sc_core::sc_module tlm::tlm_mm_interface sc_core::sc_object

Classes

class  BTag
 
class  ConnectionInfo
 
class  internalPEQTypes
 

Public Types

typedef tlm::tlm_generic_payload transaction_type
 
typedef tlm::tlm_phase phase_type
 
typedef tlm::tlm_sync_enum sync_enum_type
 
typedef tlm_utils::multi_passthrough_target_socket< MultiSocketSimpleSwitchATtarget_socket_type
 
typedef tlm_utils::multi_passthrough_initiator_socket< MultiSocketSimpleSwitchATinitiator_socket_type
 

Public Member Functions

 SC_HAS_PROCESS (MultiSocketSimpleSwitchAT)
 
 MultiSocketSimpleSwitchAT (sc_core::sc_module_name name)
 
void bindTargetSocket (initiator_socket_type::base_target_socket_type &target, sc_dt::uint64 low, sc_dt::uint64 high, sc_dt::uint64 mask=0xffffffffffffffffULL)
 
unsigned int decode (const sc_dt::uint64 &address)
 
void start_of_simulation ()
 
void b_transport (int initiator_id, transaction_type &trans, sc_core::sc_time &t)
 
void free (transaction_type *txn)
 
void initiatorNBTransport_core (transaction_type &trans, phase_type &phase, sc_core::sc_time &t, unsigned int tgtSocketNumber)
 
sync_enum_type initiatorNBTransport (int initiator_id, transaction_type &trans, phase_type &phase, sc_core::sc_time &t)
 
sync_enum_type targetNBTransport (int portId, transaction_type &trans, phase_type &phase, sc_core::sc_time &t)
 
void bwPEQcb (transaction_type &trans, const phase_type &phase)
 
void fwPEQcb (transaction_type &trans, const phase_type &phase)
 
void dump_status ()
 
- Public Member Functions inherited from sc_core::sc_module
virtual gem5::Portgem5_getPort (const std::string &if_name, int idx=-1)
 
virtual ~sc_module ()
 
virtual const char * kind () const
 
void operator() (const sc_bind_proxy &p001, const sc_bind_proxy &p002=SC_BIND_PROXY_NIL, const sc_bind_proxy &p003=SC_BIND_PROXY_NIL, const sc_bind_proxy &p004=SC_BIND_PROXY_NIL, const sc_bind_proxy &p005=SC_BIND_PROXY_NIL, const sc_bind_proxy &p006=SC_BIND_PROXY_NIL, const sc_bind_proxy &p007=SC_BIND_PROXY_NIL, const sc_bind_proxy &p008=SC_BIND_PROXY_NIL, const sc_bind_proxy &p009=SC_BIND_PROXY_NIL, const sc_bind_proxy &p010=SC_BIND_PROXY_NIL, const sc_bind_proxy &p011=SC_BIND_PROXY_NIL, const sc_bind_proxy &p012=SC_BIND_PROXY_NIL, const sc_bind_proxy &p013=SC_BIND_PROXY_NIL, const sc_bind_proxy &p014=SC_BIND_PROXY_NIL, const sc_bind_proxy &p015=SC_BIND_PROXY_NIL, const sc_bind_proxy &p016=SC_BIND_PROXY_NIL, const sc_bind_proxy &p017=SC_BIND_PROXY_NIL, const sc_bind_proxy &p018=SC_BIND_PROXY_NIL, const sc_bind_proxy &p019=SC_BIND_PROXY_NIL, const sc_bind_proxy &p020=SC_BIND_PROXY_NIL, const sc_bind_proxy &p021=SC_BIND_PROXY_NIL, const sc_bind_proxy &p022=SC_BIND_PROXY_NIL, const sc_bind_proxy &p023=SC_BIND_PROXY_NIL, const sc_bind_proxy &p024=SC_BIND_PROXY_NIL, const sc_bind_proxy &p025=SC_BIND_PROXY_NIL, const sc_bind_proxy &p026=SC_BIND_PROXY_NIL, const sc_bind_proxy &p027=SC_BIND_PROXY_NIL, const sc_bind_proxy &p028=SC_BIND_PROXY_NIL, const sc_bind_proxy &p029=SC_BIND_PROXY_NIL, const sc_bind_proxy &p030=SC_BIND_PROXY_NIL, const sc_bind_proxy &p031=SC_BIND_PROXY_NIL, const sc_bind_proxy &p032=SC_BIND_PROXY_NIL, const sc_bind_proxy &p033=SC_BIND_PROXY_NIL, const sc_bind_proxy &p034=SC_BIND_PROXY_NIL, const sc_bind_proxy &p035=SC_BIND_PROXY_NIL, const sc_bind_proxy &p036=SC_BIND_PROXY_NIL, const sc_bind_proxy &p037=SC_BIND_PROXY_NIL, const sc_bind_proxy &p038=SC_BIND_PROXY_NIL, const sc_bind_proxy &p039=SC_BIND_PROXY_NIL, const sc_bind_proxy &p040=SC_BIND_PROXY_NIL, const sc_bind_proxy &p041=SC_BIND_PROXY_NIL, const sc_bind_proxy &p042=SC_BIND_PROXY_NIL, const sc_bind_proxy &p043=SC_BIND_PROXY_NIL, const sc_bind_proxy &p044=SC_BIND_PROXY_NIL, const sc_bind_proxy &p045=SC_BIND_PROXY_NIL, const sc_bind_proxy &p046=SC_BIND_PROXY_NIL, const sc_bind_proxy &p047=SC_BIND_PROXY_NIL, const sc_bind_proxy &p048=SC_BIND_PROXY_NIL, const sc_bind_proxy &p049=SC_BIND_PROXY_NIL, const sc_bind_proxy &p050=SC_BIND_PROXY_NIL, const sc_bind_proxy &p051=SC_BIND_PROXY_NIL, const sc_bind_proxy &p052=SC_BIND_PROXY_NIL, const sc_bind_proxy &p053=SC_BIND_PROXY_NIL, const sc_bind_proxy &p054=SC_BIND_PROXY_NIL, const sc_bind_proxy &p055=SC_BIND_PROXY_NIL, const sc_bind_proxy &p056=SC_BIND_PROXY_NIL, const sc_bind_proxy &p057=SC_BIND_PROXY_NIL, const sc_bind_proxy &p058=SC_BIND_PROXY_NIL, const sc_bind_proxy &p059=SC_BIND_PROXY_NIL, const sc_bind_proxy &p060=SC_BIND_PROXY_NIL, const sc_bind_proxy &p061=SC_BIND_PROXY_NIL, const sc_bind_proxy &p062=SC_BIND_PROXY_NIL, const sc_bind_proxy &p063=SC_BIND_PROXY_NIL, const sc_bind_proxy &p064=SC_BIND_PROXY_NIL)
 
sc_moduleoperator<< (sc_interface &)
 
sc_moduleoperator<< (sc_port_base &)
 
sc_moduleoperator, (sc_interface &)
 
sc_moduleoperator, (sc_port_base &)
 
virtual const std::vector< sc_object * > & get_child_objects () const
 
virtual const std::vector< sc_event * > & get_child_events () const
 
- Public Member Functions inherited from sc_core::sc_object
const char * name () const
 
const char * basename () const
 
virtual void print (std::ostream &=std::cout) const
 
virtual void dump (std::ostream &=std::cout) const
 
sc_objectget_parent_object () const
 
bool add_attribute (sc_attr_base &)
 
sc_attr_baseget_attribute (const std::string &)
 
sc_attr_baseremove_attribute (const std::string &)
 
void remove_all_attributes ()
 
int num_attributes () const
 
sc_attr_cltnattr_cltn ()
 
const sc_attr_cltnattr_cltn () const
 
sc_simcontextsimcontext () const
 
- Public Member Functions inherited from tlm::tlm_mm_interface
virtual ~tlm_mm_interface ()
 

Public Attributes

target_socket_type target_socket
 

Private Attributes

initiator_socket_type initiator_socket
 
SimpleAddressMap m_addrMap
 
std::vector< std::deque< transaction_type * > > m_pendingReqs
 
std::vector< std::deque< transaction_type * > > m_pendingResps
 
std::vector< sc_dt::uint64m_masks
 
tlm_utils::instance_specific_extension_accessor accessMySpecificExtensions
 
tlm_utils::peq_with_cb_and_phase< MultiSocketSimpleSwitchATm_bwPEQ
 
tlm_utils::peq_with_cb_and_phase< MultiSocketSimpleSwitchATm_fwPEQ
 
ExtensionPool< ConnectionInfom_connInfoPool
 
unsigned int m_target_count
 

Additional Inherited Members

- Protected Member Functions inherited from sc_core::sc_module
 sc_module (const sc_module_name &)
 
 sc_module ()
 
 sc_module (const char *)
 
 sc_module (const std::string &)
 
void end_module ()
 
void reset_signal_is (const sc_in< bool > &, bool)
 
void reset_signal_is (const sc_inout< bool > &, bool)
 
void reset_signal_is (const sc_out< bool > &, bool)
 
void reset_signal_is (const sc_signal_in_if< bool > &, bool)
 
void async_reset_signal_is (const sc_in< bool > &, bool)
 
void async_reset_signal_is (const sc_inout< bool > &, bool)
 
void async_reset_signal_is (const sc_out< bool > &, bool)
 
void async_reset_signal_is (const sc_signal_in_if< bool > &, bool)
 
void dont_initialize ()
 
void set_stack_size (size_t)
 
void next_trigger ()
 
void next_trigger (const sc_event &)
 
void next_trigger (const sc_event_or_list &)
 
void next_trigger (const sc_event_and_list &)
 
void next_trigger (const sc_time &)
 
void next_trigger (double, sc_time_unit)
 
void next_trigger (const sc_time &, const sc_event &)
 
void next_trigger (double, sc_time_unit, const sc_event &)
 
void next_trigger (const sc_time &, const sc_event_or_list &)
 
void next_trigger (double, sc_time_unit, const sc_event_or_list &)
 
void next_trigger (const sc_time &, const sc_event_and_list &)
 
void next_trigger (double, sc_time_unit, const sc_event_and_list &)
 
bool timed_out ()
 
void wait ()
 
void wait (int)
 
void wait (const sc_event &)
 
void wait (const sc_event_or_list &)
 
void wait (const sc_event_and_list &)
 
void wait (const sc_time &)
 
void wait (double, sc_time_unit)
 
void wait (const sc_time &, const sc_event &)
 
void wait (double, sc_time_unit, const sc_event &)
 
void wait (const sc_time &, const sc_event_or_list &)
 
void wait (double, sc_time_unit, const sc_event_or_list &)
 
void wait (const sc_time &, const sc_event_and_list &)
 
void wait (double, sc_time_unit, const sc_event_and_list &)
 
void halt ()
 
void at_posedge (const sc_signal_in_if< bool > &)
 
void at_posedge (const sc_signal_in_if< sc_dt::sc_logic > &)
 
void at_negedge (const sc_signal_in_if< bool > &)
 
void at_negedge (const sc_signal_in_if< sc_dt::sc_logic > &)
 
virtual void before_end_of_elaboration ()
 
virtual void end_of_elaboration ()
 
virtual void end_of_simulation ()
 
- Protected Member Functions inherited from sc_core::sc_object
 sc_object ()
 
 sc_object (const char *)
 
 sc_object (const sc_object &)
 
sc_objectoperator= (const sc_object &)
 
virtual ~sc_object ()
 
- Protected Attributes inherited from sc_core::sc_module
sc_sensitive sensitive
 

Detailed Description

Definition at line 46 of file MultiSocketSimpleSwitchAT.h.

Member Typedef Documentation

◆ initiator_socket_type

◆ phase_type

◆ sync_enum_type

◆ target_socket_type

◆ transaction_type

Constructor & Destructor Documentation

◆ MultiSocketSimpleSwitchAT()

Member Function Documentation

◆ b_transport()

◆ bindTargetSocket()

void MultiSocketSimpleSwitchAT::bindTargetSocket ( initiator_socket_type::base_target_socket_type & target,
sc_dt::uint64 low,
sc_dt::uint64 high,
sc_dt::uint64 mask = 0xffffffffffffffffULL )
inline

◆ bwPEQcb()

◆ decode()

unsigned int MultiSocketSimpleSwitchAT::decode ( const sc_dt::uint64 & address)
inline

Definition at line 122 of file MultiSocketSimpleSwitchAT.h.

References SimpleAddressMap::decode(), and m_addrMap.

Referenced by initiatorNBTransport().

◆ dump_status()

◆ free()

◆ fwPEQcb()

◆ initiatorNBTransport()

◆ initiatorNBTransport_core()

◆ SC_HAS_PROCESS()

MultiSocketSimpleSwitchAT::SC_HAS_PROCESS ( MultiSocketSimpleSwitchAT )

◆ start_of_simulation()

◆ targetNBTransport()

Member Data Documentation

◆ accessMySpecificExtensions

tlm_utils::instance_specific_extension_accessor MultiSocketSimpleSwitchAT::accessMySpecificExtensions
private

◆ initiator_socket

initiator_socket_type MultiSocketSimpleSwitchAT::initiator_socket
private

◆ m_addrMap

SimpleAddressMap MultiSocketSimpleSwitchAT::m_addrMap
private

Definition at line 60 of file MultiSocketSimpleSwitchAT.h.

Referenced by bindTargetSocket(), decode(), and dump_status().

◆ m_bwPEQ

tlm_utils::peq_with_cb_and_phase<MultiSocketSimpleSwitchAT> MultiSocketSimpleSwitchAT::m_bwPEQ
private

◆ m_connInfoPool

ExtensionPool<ConnectionInfo> MultiSocketSimpleSwitchAT::m_connInfoPool
private

Definition at line 91 of file MultiSocketSimpleSwitchAT.h.

Referenced by fwPEQcb(), and initiatorNBTransport().

◆ m_fwPEQ

tlm_utils::peq_with_cb_and_phase<MultiSocketSimpleSwitchAT> MultiSocketSimpleSwitchAT::m_fwPEQ
private

Definition at line 66 of file MultiSocketSimpleSwitchAT.h.

Referenced by bwPEQcb(), and initiatorNBTransport().

◆ m_masks

std::vector<sc_dt::uint64> MultiSocketSimpleSwitchAT::m_masks
private

Definition at line 63 of file MultiSocketSimpleSwitchAT.h.

Referenced by bindTargetSocket(), and fwPEQcb().

◆ m_pendingReqs

std::vector<std::deque<transaction_type*> > MultiSocketSimpleSwitchAT::m_pendingReqs
private

Definition at line 61 of file MultiSocketSimpleSwitchAT.h.

Referenced by bwPEQcb(), dump_status(), fwPEQcb(), and start_of_simulation().

◆ m_pendingResps

std::vector<std::deque<transaction_type*> > MultiSocketSimpleSwitchAT::m_pendingResps
private

Definition at line 62 of file MultiSocketSimpleSwitchAT.h.

Referenced by bwPEQcb(), dump_status(), fwPEQcb(), and start_of_simulation().

◆ m_target_count

unsigned int MultiSocketSimpleSwitchAT::m_target_count
private

Definition at line 92 of file MultiSocketSimpleSwitchAT.h.

Referenced by bindTargetSocket().

◆ target_socket

target_socket_type MultiSocketSimpleSwitchAT::target_socket

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

Generated on Tue Jun 18 2024 16:24:09 for gem5 by doxygen 1.11.0