DUNE-DAQ
DUNE Trigger and Data Acquisition software
Loading...
Searching...
No Matches
SourceModel.hpp
Go to the documentation of this file.
1
8#ifndef CRTMODULES_SRC_SOURCEMODEL_HPP_
9#define CRTMODULES_SRC_SOURCEMODEL_HPP_
10
11#include "SourceConcept.hpp"
12
13
15#include "iomanager/Sender.hpp"
16#include "logging/Logging.hpp"
17
19
20// #include "datahandlinglibs/utils/ReusableThread.hpp"
23
24// #include <folly/ProducerConsumerQueue.h>
25// #include <nlohmann/json.hpp>
26
27#include <atomic>
28#include <memory>
29#include <mutex>
30#include <string>
31
32
33namespace dunedaq::crtmodules {
34
35template<class TargetPayloadType>
37{
38public:
41 using data_t = nlohmann::json;
42
46 static constexpr auto buffer_size = sizeof(TargetPayloadType);
47
54 {}
56
57 void set_sink(const std::string& sink_name, bool callback_mode) override
58 {
59 m_callback_mode = callback_mode;
60 if (callback_mode) {
61 TLOG_DEBUG(5) << "Callback mode requested. Won't acquire iom sender!";
62 } else {
63 if (m_sink_is_set) {
64 TLOG_DEBUG(5) << "SourceModel sink is already set in initialized!";
65 } else {
67 m_sink_is_set = true;
68 }
69 }
70 }
71
72 void acquire_callback() override
73 {
74 if (m_callback_mode) {
76 TLOG_DEBUG(5) << "SourceModel callback is already acquired!";
77 } else {
78 // Getting DataMoveCBRegistry
80 m_sink_callback = dmcbr->get_callback<TargetPayloadType>(inherited::m_sink_name);
82 }
83 } else {
84 TLOG_DEBUG(5) << "Won't acquire callback, as IOM sink is set!";
85 }
86 }
87
88 std::shared_ptr<sink_t>& get_sink() { return m_sink_queue; }
89
90 bool handle_payload(char* message, std::size_t size) // NOLINT(build/unsigned)
91 {
92 bool push_out = true;
93 if (push_out) {
94
95 TargetPayloadType& target_payload = *reinterpret_cast<TargetPayloadType*>(message);
96
97 if (m_callback_mode) {
98 (*m_sink_callback)(std::move(target_payload));
99 } else {
100 if (!m_sink_queue->try_send(std::move(target_payload), iomanager::Sender::s_no_block)) {
101 //if(m_dropped_packets == 0 || m_dropped_packets%10000) {
102 // TLOG() << "Dropped data " << m_dropped_packets;
103 //}
105 }
106 }
107
108 } else {
109 TargetPayloadType target_payload;
110 uint32_t bytes_copied = 0;
111 datahandlinglibs::buffer_copy(message, size, static_cast<void*>(&target_payload), bytes_copied, sizeof(target_payload));
112 }
113
114 return true;
115 }
116
117 std::size_t get_frame_size() const override {
118 TargetPayloadType target_payload;
119 return target_payload.get_frame_size(); // TODO (DTE): Could be a static function?
120 }
121
122 void generate_opmon_data() override {
123
125 info.set_dropped_frames( m_dropped_packets.load() );
126
127 publish( std::move(info) );
128 }
129
130private:
131 // Sink internals
132 std::string m_sink_id;
133 bool m_sink_is_set{ false };
134 std::shared_ptr<sink_t> m_sink_queue;
135
136 // Callback internals
139 using sink_cb_t = std::shared_ptr<std::function<void(TargetPayloadType&&)>>;
141
142 std::atomic<uint64_t> m_dropped_packets{0};
143
144};
145
146} // namespace dunedaq::crtmodules
147
148#endif // CRTMODULES_SRC_SOURCEMODEL_HPP_
static constexpr auto buffer_size
Buffer size based on TargetPayloadType.
bool handle_payload(char *message, std::size_t size)
std::atomic< uint64_t > m_dropped_packets
std::shared_ptr< sink_t > m_sink_queue
void set_sink(const std::string &sink_name, bool callback_mode) override
SourceModel()
SourceModel Constructor.
std::shared_ptr< sink_t > & get_sink()
std::shared_ptr< std::function< void(TargetPayloadType &&)> > sink_cb_t
std::size_t get_frame_size() const override
static std::shared_ptr< DataMoveCallbackRegistry > get()
static constexpr timeout_t s_no_block
Definition Sender.hpp:26
void publish(google::protobuf::Message &&, CustomOrigin &&co={}, OpMonLevel l=to_level(EntryOpMonLevel::kDefault)) const noexcept
#define TLOG_DEBUG(lvl,...)
Definition Logging.hpp:112
void buffer_copy(const char *data, std::size_t size, void *buffer, std::uint32_t buffer_pos, const std::size_t &buffer_size)
static std::shared_ptr< iomanager::SenderConcept< Datatype > > get_iom_sender(iomanager::ConnectionId const &id)
Unknown serialization Cannot deserialize message
FELIX Initialization std::string initerror FELIX queue timed std::string queuename Unexpected chunk size