/******************************************************************************** * Copyright (C) 2018 GSI Helmholtzzentrum fuer Schwerionenforschung GmbH * * * * This software is distributed under the terms of the * * GNU Lesser General Public Licence (LGPL) version 3, * * copied verbatim in the file "LICENSE" * ********************************************************************************/ #ifndef FAIR_MQ_OFI_TRANSPORTFACTORY_H #define FAIR_MQ_OFI_TRANSPORTFACTORY_H #include #include #include #include namespace fair::mq::ofi { /** * @class TransportFactory TransportFactory.h * @brief FairMQ transport factory for the ofi transport * * @todo TODO insert long description */ class TransportFactory final : public FairMQTransportFactory { public: TransportFactory(const std::string& id = "", const fair::mq::ProgOptions* config = nullptr); TransportFactory(const TransportFactory&) = delete; TransportFactory operator=(const TransportFactory&) = delete; auto CreateMessage() -> MessagePtr override; auto CreateMessage(Alignment alignment) -> MessagePtr override; auto CreateMessage(const std::size_t size) -> MessagePtr override; auto CreateMessage(const std::size_t size, Alignment alignment) -> MessagePtr override; auto CreateMessage(void* data, const std::size_t size, fairmq_free_fn* ffn, void* hint = nullptr) -> MessagePtr override; auto CreateMessage(UnmanagedRegionPtr& region, void* data, const std::size_t size, void* hint = nullptr) -> MessagePtr override; auto CreateSocket(const std::string& type, const std::string& name) -> SocketPtr override; auto CreatePoller(const std::vector& channels) const -> PollerPtr override; auto CreatePoller(const std::vector& channels) const -> PollerPtr override; auto CreatePoller(const std::unordered_map>& channelsMap, const std::vector& channelList) const -> PollerPtr override; auto CreateUnmanagedRegion(const size_t size, RegionCallback callback = nullptr, const std::string& path = "", int flags = 0) -> UnmanagedRegionPtr override; auto CreateUnmanagedRegion(const size_t size, RegionBulkCallback callback = nullptr, const std::string& path = "", int flags = 0) -> UnmanagedRegionPtr override; auto CreateUnmanagedRegion(const size_t size, int64_t userFlags, RegionCallback callback = nullptr, const std::string& path = "", int flags = 0) -> UnmanagedRegionPtr override; auto CreateUnmanagedRegion(const size_t size, int64_t userFlags, RegionBulkCallback callback = nullptr, const std::string& path = "", int flags = 0) -> UnmanagedRegionPtr override; void SubscribeToRegionEvents(RegionEventCallback /* callback */) override { LOG(error) << "SubscribeToRegionEvents not yet implemented for OFI"; } bool SubscribedToRegionEvents() override { LOG(error) << "Region event subscriptions not yet implemented for OFI"; return false; } void UnsubscribeFromRegionEvents() override { LOG(error) << "UnsubscribeFromRegionEvents not yet implemented for OFI"; } std::vector GetRegionInfo() override { LOG(error) << "GetRegionInfo not yet implemented for OFI, returning empty vector"; return std::vector(); } auto GetType() const -> Transport override; void Interrupt() override { fContext.Interrupt(); } void Resume() override { fContext.Resume(); } void Reset() override { fContext.Reset(); } private: mutable Context fContext; asiofi::allocated_pool_resource fMemoryResource; }; /* class TransportFactory */ } // namespace fair::mq::ofi #endif /* FAIR_MQ_OFI_TRANSPORTFACTORY_H */