/******************************************************************************** * Copyright (C) 2014 GSI Helmholtzzentrum fuer Schwerionenforschung GmbH * * * * This software is distributed under the terms of the * * GNU Lesser General Public Licence version 3 (LGPL) version 3, * * copied verbatim in the file "LICENSE" * ********************************************************************************/ #ifndef FAIRMQTRANSPORTFACTORYSHM_H_ #define FAIRMQTRANSPORTFACTORYSHM_H_ #include #include #include #include #include #include "FairMQTransportFactory.h" #include "FairMQMessageSHM.h" #include "FairMQSocketSHM.h" #include "FairMQPollerSHM.h" #include "FairMQShmDeviceCounter.h" class FairMQTransportFactorySHM : public FairMQTransportFactory { public: FairMQTransportFactorySHM(); void Initialize(const FairMQProgOptions* config) override; FairMQMessagePtr CreateMessage() const override; FairMQMessagePtr CreateMessage(const size_t size) const override; FairMQMessagePtr CreateMessage(void* data, const size_t size, fairmq_free_fn* ffn, void* hint = nullptr) const override; FairMQSocketPtr CreateSocket(const std::string& type, const std::string& name, const std::string& id = "") const override; FairMQPollerPtr CreatePoller(const std::vector& channels) const override; FairMQPollerPtr CreatePoller(const std::unordered_map>& channelsMap, const std::vector& channelList) const override; FairMQPollerPtr CreatePoller(const FairMQSocket& cmdSocket, const FairMQSocket& dataSocket) const override; FairMQ::Transport GetType() const override; void Shutdown() override; void Terminate() override; void SendHeartbeats(); ~FairMQTransportFactorySHM() override {}; private: static FairMQ::Transport fTransportType; void* fContext; void* fHeartbeatSocket; std::thread fHeartbeatThread; std::atomic fSendHeartbeats; boost::interprocess::named_mutex fShMutex; FairMQ::shmem::FairMQShmDeviceCounter* fDeviceCounter; }; #endif /* FAIRMQTRANSPORTFACTORYSHM_H_ */