tdaq-develop-2025-02-12
UDPFragmentWriter.hh
1 #ifndef artdaq_ots_Overlays_UDPFragmentWriter_hh
2 #define artdaq_ots_Overlays_UDPFragmentWriter_hh
3 
16 
17 #include "artdaq-core/Data/Fragment.hh"
18 #include "artdaq-ots/Overlays/UDPFragment.hh"
19 
20 #include <iostream>
21 
22 namespace ots
23 {
24 class UDPFragmentWriter;
25 }
26 
28 {
29  public:
30  UDPFragmentWriter(artdaq::Fragment& f);
31 
35  uint8_t* dataBegin();
36  uint8_t* dataEnd();
37 
42  {
43  assert(artdaq_Fragment_.dataSizeBytes() >= sizeof(Header));
44  return reinterpret_cast<Header*>(artdaq_Fragment_.dataBeginBytes());
45  }
46 
47  void set_hdr_type(Header::data_type_t dataType) { header_()->type = dataType & 0xF; }
48 
49  void resize(size_t nBytes);
50 
51  private:
52  size_t calc_event_size_words_(size_t nBytes);
53 
54  static size_t bytes_to_words_(size_t nBytes);
55 
57  artdaq::Fragment& artdaq_Fragment_;
58 };
59 
65  : UDPFragment(f), artdaq_Fragment_(f)
66 {
67  if(!f.hasMetadata() || f.dataSizeBytes() > 0)
68  {
69  throw cet::exception(
70  "Error in UDPFragmentWriter: Raw artdaq::Fragment object does not appear to "
71  "consist of (and only of) its own header + the UDPFragment::Metadata object");
72  }
73 
75  artdaq_Fragment_.resizeBytes(sizeof(Header));
76 }
77 
79 {
81  assert(artdaq_Fragment_.dataSizeBytes() >=
82  sizeof(Header) + sizeof(artdaq::Fragment::value_type));
83  return reinterpret_cast<uint8_t*>(header_() + 1);
84 }
85 
86 inline uint8_t* ots::UDPFragmentWriter::dataEnd()
87 {
88  return dataBegin() + udp_data_words();
89 }
90 
91 inline void ots::UDPFragmentWriter::resize(size_t nBytes)
92 {
93  artdaq_Fragment_.resizeBytes(sizeof(Header::data_t) * calc_event_size_words_(nBytes));
94  header_()->event_size = calc_event_size_words_(nBytes);
95 }
96 
97 inline size_t ots::UDPFragmentWriter::calc_event_size_words_(size_t nBytes)
98 {
99  return bytes_to_words_(nBytes) + hdr_size_words();
100 }
101 
102 inline size_t ots::UDPFragmentWriter::bytes_to_words_(size_t nBytes)
103 {
104  auto mod(nBytes % bytes_per_word_());
105  return (mod == 0) ? nBytes / bytes_per_word_() : nBytes / bytes_per_word_() + 1;
106 }
107 
108 #endif /* artdaq_demo_Overlays_UDPFragmentWriter_hh */
UDPFragmentWriter(artdaq::Fragment &f)