Line data Source code
1 : /**
2 : * @file wibeth.cpp Python bindings for the TDEEthFrame format
3 : *
4 : * This is part of the DUNE DAQ Software Suite, copyright 2020.
5 : * Licensing/copyright details are in the COPYING file that you should have
6 : * received with this code.
7 : */
8 :
9 : #include "fddetdataformats/TDEEthFrame.hpp"
10 :
11 : #include <pybind11/pybind11.h>
12 : #include <pybind11/stl.h>
13 :
14 : namespace py = pybind11;
15 :
16 : namespace dunedaq::fddetdataformats::python {
17 :
18 : void
19 0 : register_tdeeth(py::module& m)
20 : {
21 :
22 :
23 : // py::class_<TDEEthFrame::TDEHeader>(m, "TDEHeader")
24 : // .def_property("channel",
25 : // [](TDEEthFrame::TDEHeader& self) -> uint32_t {return self.channel;},
26 : // [](TDEEthFrame::TDEHeader& self, uint32_t channel) {self.channel = channel;}
27 : // )
28 : // .def_property("version",
29 : // [](TDEEthFrame::TDEHeader& self) -> uint32_t {return self.version;},
30 : // [](TDEEthFrame::TDEHeader& self, uint32_t version) {self.version = version;}
31 : // )
32 : // // .def_property("reserved",
33 : // // [](TDEEthFrame::TDEHeader& self) -> uint32_t {return self.reserved;},
34 : // // [](TDEEthFrame::TDEHeader& self, uint32_t reserved) {self.reserved = reserved;}
35 : // // )
36 : // .def_property("cd",
37 : // [](TDEEthFrame::TDEHeader& self) -> uint32_t {return self.cd;},
38 : // [](TDEEthFrame::TDEHeader& self, uint32_t cd) {self.version = cd;}
39 : // )
40 : // .def_property("context",
41 : // [](TDEEthFrame::TDEHeader& self) -> uint32_t {return self.context;},
42 : // [](TDEEthFrame::TDEHeader& self, uint32_t context) {self.version = context;}
43 : // )
44 : // .def_property("ready",
45 : // [](TDEEthFrame::TDEHeader& self) -> uint32_t {return self.ready;},
46 : // [](TDEEthFrame::TDEHeader& self, uint32_t ready) {self.ready = ready;}
47 : // )
48 : // .def_property("calibration",
49 : // [](TDEEthFrame::TDEHeader& self) -> uint32_t {return self.calibration;},
50 : // [](TDEEthFrame::TDEHeader& self, uint32_t calibration) {self.calibration = calibration;}
51 : // )
52 : // .def_property("pulser",
53 : // [](TDEEthFrame::TDEHeader& self) -> uint32_t {return self.pulser;},
54 : // [](TDEEthFrame::TDEHeader& self, uint32_t pulser) {self.pulser = pulser;}
55 : // )
56 : // .def_property("femb_sync",
57 : // [](TDEEthFrame::TDEHeader& self) -> uint32_t {return self.femb_sync;},
58 : // [](TDEEthFrame::TDEHeader& self, uint32_t femb_sync) {self.femb_sync = femb_sync;}
59 : // )
60 : // .def_property("wib_sync",
61 : // [](TDEEthFrame::TDEHeader& self) -> uint32_t {return self.wib_sync;},
62 : // [](TDEEthFrame::TDEHeader& self, uint32_t wib_sync) {self.wib_sync = wib_sync;}
63 : // )
64 : // .def_property("lol",
65 : // [](TDEEthFrame::TDEHeader& self) -> uint32_t {return self.lol;},
66 : // [](TDEEthFrame::TDEHeader& self, uint32_t lol) {self.lol = lol;}
67 : // )
68 : // .def_property("link_valid",
69 : // [](TDEEthFrame::TDEHeader& self) -> uint32_t {return self.link_valid;},
70 : // [](TDEEthFrame::TDEHeader& self, uint32_t link_valid) {self.link_valid = link_valid;}
71 : // )
72 : // .def_property("crc_err",
73 : // [](TDEEthFrame::TDEHeader& self) -> uint32_t {return self.crc_err;},
74 : // [](TDEEthFrame::TDEHeader& self, uint32_t crc_err) {self.crc_err = crc_err;}
75 : // )
76 : // .def_property("colddata_timestamp_1",
77 : // [](TDEEthFrame::TDEHeader& self) -> uint32_t {return self.colddata_timestamp_1;},
78 : // [](TDEEthFrame::TDEHeader& self, uint32_t colddata_timestamp_1) {self.lol = colddata_timestamp_1;}
79 : // )
80 : // .def_property("colddata_timestamp_0",
81 : // [](TDEEthFrame::TDEHeader& self) -> uint32_t {return self.colddata_timestamp_0;},
82 : // [](TDEEthFrame::TDEHeader& self, uint32_t colddata_timestamp_0) {self.colddata_timestamp_0 = colddata_timestamp_0;}
83 : // )
84 : // .def_property("extra_data",
85 : // [](TDEEthFrame::TDEHeader& self) -> uint64_t {return self.extra_data;},
86 : // [](TDEEthFrame::TDEHeader& self, uint64_t extra_data) {self.extra_data = extra_data;}
87 : // )
88 : // ;
89 :
90 0 : py::class_<TDEEthFrame::TDEEthHeader>(m, "TDEEthHeader")
91 0 : .def_property("channel",
92 0 : [](TDEEthFrame::TDEEthHeader& self) -> uint16_t {return self.channel;},
93 0 : [](TDEEthFrame::TDEEthHeader& self, uint16_t channel) {self.channel = channel;}
94 : )
95 0 : .def_property("version",
96 0 : [](TDEEthFrame::TDEEthHeader& self) -> uint16_t {return self.version;},
97 0 : [](TDEEthFrame::TDEEthHeader& self, uint16_t version) {self.version = version;}
98 : )
99 0 : .def_property("tde_header",
100 0 : [](TDEEthFrame::TDEEthHeader& self) -> uint16_t {return self.tde_header;},
101 0 : [](TDEEthFrame::TDEEthHeader& self, uint16_t tde_header) {self.tde_header = tde_header;}
102 : )
103 0 : .def_property("tde_errors",
104 0 : [](TDEEthFrame::TDEEthHeader& self) -> uint16_t {return self.tde_errors;},
105 0 : [](TDEEthFrame::TDEEthHeader& self, uint16_t tde_errors) {self.tde_errors = tde_errors;}
106 : )
107 0 : .def_property("TAItime",
108 0 : [](TDEEthFrame::TDEEthHeader& self) -> uint64_t {return self.TAItime;},
109 0 : [](TDEEthFrame::TDEEthHeader& self, uint64_t TAItime) {self.TAItime = TAItime;}
110 : )
111 : ;
112 :
113 :
114 0 : py::class_<TDEEthFrame>(m, "TDEEthFrame", py::buffer_protocol())
115 0 : .def(py::init())
116 0 : .def(py::init([](py::capsule capsule) {
117 0 : auto tfp = *static_cast<TDEEthFrame*>(capsule.get_pointer());
118 0 : return tfp;
119 : } ))
120 0 : .def(py::init([](py::bytes bytes){
121 0 : py::buffer_info info(py::buffer(bytes).request());
122 0 : auto tfp = *static_cast<TDEEthFrame*>(info.ptr);
123 0 : return tfp;
124 0 : }))
125 0 : .def("get_daqheader", [](TDEEthFrame& self) -> const detdataformats::DAQEthHeader& {return self.daq_header;}, py::return_value_policy::reference_internal)
126 0 : .def("get_tdeheader", [](TDEEthFrame& self) -> const TDEEthFrame::TDEEthHeader& {return self.header;}, py::return_value_policy::reference_internal)
127 0 : .def("get_adc", &TDEEthFrame::get_adc)
128 0 : .def("set_adc", &TDEEthFrame::set_adc)
129 0 : .def("get_timestamp", &TDEEthFrame::get_timestamp)
130 0 : .def("set_timestamp", &TDEEthFrame::set_timestamp)
131 0 : .def("get_channel", &TDEEthFrame::get_channel)
132 0 : .def("set_channel", &TDEEthFrame::set_channel)
133 0 : .def_static("sizeof", [](){ return sizeof(TDEEthFrame); })
134 0 : .def("get_bytes",
135 0 : [](TDEEthFrame* fr) -> py::bytes {
136 0 : return py::bytes(reinterpret_cast<char*>(fr), sizeof(TDEEthFrame));
137 : })
138 : ;
139 0 : }
140 :
141 : } // namespace dunedaq::fddetdataformats::python
|