12 #ifndef SST_CORE_LINK_H
13 #define SST_CORE_LINK_H
15 #include <sst/core/sst_types.h>
17 #include <sst/core/event.h>
22 #define _LINK_DBG( fmt, args...) __DBG( DBG_LINK, Link, fmt, ## args )
34 typedef enum { POLL, HANDLER, QUEUE } Type_t;
126 #ifdef __SST_DEBUG_EVENT_TRACKING__
127 void setSendingComponentInfo(
const std::string& comp_in,
const std::string& type_in,
const std::string& port_in) {
133 const std::string& getSendingComponentName() {
return comp; }
134 const std::string& getSendingComponentType() {
return ctype; }
135 const std::string& getSendingPort() {
return port; }
179 void sendInitData_sync(
Event* init_data);
180 void finalizeConfiguration();
185 #ifdef __SST_DEBUG_EVENT_TRACKING__
209 #endif // SST_CORE_LINK_H
Definition: syncManager.h:68
Definition: syncManager.h:103
Link(LinkId_t id)
Create a new link with a given ID.
Definition: link.cc:34
void setLatency(Cycle_t lat)
set minimum link latency
Definition: link.cc:94
Main control class for a SST Simulation.
Definition: simulation.h:72
Self Links are links from a component to itself.
Definition: link.h:196
A class to convert between a component's view of time and the core's view of time.
Definition: timeConverter.h:25
void send(SimTime_t delay, TimeConverter *tc, Event *event)
Send an event over the link with additional delay.
Definition: link.cc:107
Event::HandlerBase * rFunctor
Recieve functor.
Definition: link.h:158
SimTime_t latency
Latency of the link.
Definition: link.h:171
LinkId_t getId()
Return the ID of this link.
Definition: link.h:119
Definition: syncManager.h:33
void setPolling()
Specifies that this link has no callback, and is poll-based only.
Definition: link.cc:88
TimeConverter * defaultTimeBase
Timebase used if no other timebase is specified.
Definition: link.h:165
ActivityQueue * recvQueue
Queue of events to be received by the owning component.
Definition: link.h:145
void deliverEvent(Event *event) const
Causes an event to be delivered to the registered callback.
Definition: link.h:114
Link * pair_link
Pointer to the opposite side of this link.
Definition: link.h:174
Definition: threadSync.h:35
Event * recv()
Retrieve a pending event from the Link.
Definition: link.cc:132
void addRecvLatency(int cycles, std::string timebase)
Set additional Latency to be added on to events coming in on this link.
Definition: link.cc:98
Event * recvInitData()
Receive an event (if any) during the init() phase.
Definition: link.cc:173
void setFunctor(Event::HandlerBase *functor)
Set the callback function to be called when a message is delivered.
Definition: link.h:65
static ActivityQueue * uninitQueue
Unitialized queue.
Definition: link.h:151
void sendInitData(Event *init_data)
Send data during the init() phase.
Definition: link.cc:147
void setDefaultTimeBase(TimeConverter *tc)
Manually set the default detaulTimeBase.
Definition: link.cc:200
SyncBase defines the API for Sync objects, which are used to synchronize between MPI ranks in a simul...
Definition: syncBase.h:34
Defines a pair of links (to define a connected link)
Definition: linkPair.h:24
void send(SimTime_t delay, Event *event)
Send an event with additional delay.
Definition: link.h:88
static ActivityQueue * afterInitQueue
Unitialized queue.
Definition: link.h:153
Functor classes for Event handling.
Definition: event.h:86
ActivityQueue * configuredQueue
Currently active Queue.
Definition: link.h:149
ActivityQueue * initQueue
Queue of events to be received during init by the owning component.
Definition: link.h:147
Definition: componentInfo.h:34
Base Class for a queue of Activities.
Definition: activityQueue.h:22
Base class for Events - Items sent across links to communicate between components.
Definition: event.h:31
void send(Event *event)
Send an event with the Link's default delay.
Definition: link.h:95
Link between two components.
Definition: link.h:33
TimeConverter * getDefaultTimeBase()
Return the default Time Base for this link.
Definition: link.cc:204