12#ifndef SST_CORE_SYNC_RANKSYNCPARALLELSKIP_H
13#define SST_CORE_SYNC_RANKSYNCPARALLELSKIP_H
15#include "sst/core/sst_mpi.h"
16#include "sst/core/sst_types.h"
17#include "sst/core/sync/syncManager.h"
18#include "sst/core/threadsafe.h"
44 void execute(
int thread)
override;
54 void setSignals(
int end,
int usr,
int alrm)
override;
56 bool getSignals(
int& end,
int& usr,
int& alrm)
override;
60 void setShutdownFlags(
bool enter_shutdown, Simulation::ShutdownMode_t shutdown_mode)
override;
61 void setCkptFlag(
bool generate_ckpt)
override;
62 void setFlags(
bool enter_interactive,
bool enter_shutdown, Simulation::ShutdownMode_t shutdown_mode)
override;
64 void getShutdownFlags(
bool& enter_shutdown, Simulation::ShutdownMode_t& shutdown_mode)
override;
65 void getCkptFlag(
bool& generate_ckpt)
override;
66 void getFlags(
bool& enter_interactive,
bool& enter_shutdown, Simulation::ShutdownMode_t& shutdown_mode)
override;
70 SimTime_t getNextSyncTime()
override {
return myNextSyncTime; }
72 void setRestartTime(SimTime_t time)
override;
74 uint64_t getDataSize()
const override;
79 static SimTime_t myNextSyncTime;
82 void exchange_master(
int thread);
83 void exchange_slave(
int thread);
99 ImplementSerializable(comm_send_pair)
104 uint32_t remote_rank;
105 uint32_t local_thread;
107 std::vector<Activity*> activity_vec;
110#ifdef SST_CONFIG_HAVE_MPI
115 SST_SER(remote_rank);
116 SST_SER(local_thread);
122 ImplementSerializable(comm_recv_pair)
125 using comm_send_map_t = std::map<RankInfo, comm_send_pair>;
126 using comm_recv_map_t = std::map<RankInfo, comm_recv_pair>;
128 using link_map_t = std::map<std::string, uintptr_t>;
131 comm_send_map_t comm_send_map;
132 comm_recv_map_t comm_recv_map;
136 double deserializeTime;
141 std::atomic<int32_t> remaining_deser;
147 void deserializeMessage(comm_recv_pair* msg);
158 static int sig_alrm_;
159 static std::atomic<bool> enter_interactive_;
160 static std::atomic<bool> enter_shutdown_;
161 static std::atomic<unsigned> shutdown_mode_;
162 static std::atomic<bool> generate_ckpt_;
Base Class for a queue of Activities.
Definition activityQueue.h:22
Definition serializable.h:25
This class is basically a wrapper for objects to declare the order in which their members should be s...
Definition serializer.h:43
Definition threadsafe.h:50
Definition threadsafe.h:169
Definition threadsafe.h:138
Definition threadsafe.h:278
Link between two components.
Definition link.h:57
void getShutdownFlags(bool &enter_shutdown, Simulation::ShutdownMode_t &shutdown_mode) override
Return exchanged interactive flags after sync.
Definition rankSyncParallelSkip.cc:188
ActivityQueue * registerLink(const RankInfo &to_rank, const RankInfo &from_rank, Link *link) override
Register a Link which this Sync Object is responsible for.
Definition rankSyncParallelSkip.cc:88
void finalizeLinkConfigurations() override
Finish link configuration.
Definition rankSyncParallelSkip.cc:133
bool getSignals(int &end, int &usr, int &alrm) override
Return exchanged signals after sync.
Definition rankSyncParallelSkip.cc:155
void setSignals(int end, int usr, int alrm) override
Set signals to exchange during sync.
Definition rankSyncParallelSkip.cc:147
void setShutdownFlags(bool enter_shutdown, Simulation::ShutdownMode_t shutdown_mode) override
Set interactive flags to exchange during sync.
Definition rankSyncParallelSkip.cc:164
void clearFlags() override
Clear interactive flags before next run.
Definition rankSyncParallelSkip.cc:219
void exchangeLinkUntimedData(int thread, std::atomic< int > &msg_count) override
Cause an exchange of Untimed Data to occur.
Definition rankSyncParallelSkip.cc:467
void prepareForComplete() override
Prepare for complete() stage.
Definition rankSyncParallelSkip.cc:143
RankSyncParallelSkip(RankInfo num_ranks)
Create a new Sync object which fires with a specified period.
Definition rankSyncParallelSkip.cc:49
Definition syncQueue.h:62
A class to convert between a component's view of time and the core's view of time.
Definition timeConverter.h:31