DUNE-DAQ
DUNE Trigger and Data Acquisition software
Loading...
Searching...
No Matches
dunedaq::cibmodules::util Namespace Reference

Functions

uint32_t bitmask (uint32_t highbit, uint32_t lowbit)
 
int32_t cast_to_signed (const uint32_t reg, const uint32_t mask)
 
int32_t get_m1 (dunedaq::cib::daq::iols_trigger_t &t)
 
int32_t get_m2 (dunedaq::cib::daq::iols_trigger_t &t)
 
int32_t get_m3 (dunedaq::cib::daq::iols_trigger_t &t)
 
bool parse_hex (std::string_view s, std::uint32_t &out)
 

Function Documentation

◆ bitmask()

uint32_t dunedaq::cibmodules::util::bitmask ( uint32_t highbit,
uint32_t lowbit )

Definition at line 13 of file cib_utilities.cpp.

14 {
15 // sort the bit order or this fails miserably
16 if (highbit < lowbit)
17 {
18 uint32_t tmp = lowbit;
19 lowbit = highbit;
20 highbit = tmp;
21 }
22
23 uint32_t i = ~0U;
24 return ~(i << highbit << 1) & (i << lowbit);
25 }

◆ cast_to_signed()

int32_t dunedaq::cibmodules::util::cast_to_signed ( const uint32_t reg,
const uint32_t mask )

Definition at line 29 of file cib_utilities.cpp.

30 {
31 // first find the msb in the mask. That will be the signed bit
32 uint32_t msb = 0;
33 int32_t res = 0;
34 for (size_t bit = 31; bit > 0; bit--)
35 {
36 if ((1U << bit) & mask)
37 {
38 msb = bit;
39 break;
40 }
41 }
42 // check the msb of the register. That is the sign bit
43 if ((1U << msb) & reg)
44 {
45 // spdlog::trace("MSB of the mask is {0}",msb);
46
47 res = bitmask(31, msb + 1); // set all bits to 1 above the mask
48 res = res | (reg & mask);
49 // it is a negative value. Set the msb in the result
50 }
51 else
52 {
53 // it is a positive value. No need to set the sign bit, but still need to
54 // apply the mask or we're carrying out the other bits that may be outside the mask
55 res = (reg & mask);
56 }
57 return res;
58 }

◆ get_m1()

int32_t dunedaq::cibmodules::util::get_m1 ( dunedaq::cib::daq::iols_trigger_t & t)

Definition at line 60 of file cib_utilities.cpp.

61 {
62 return cast_to_signed(t.pos_m1, t.bitmask_m1);
63 }
int32_t cast_to_signed(const uint32_t reg, const uint32_t mask)

◆ get_m2()

int32_t dunedaq::cibmodules::util::get_m2 ( dunedaq::cib::daq::iols_trigger_t & t)

Definition at line 65 of file cib_utilities.cpp.

66 {
67 uint32_t m2_lsb = t.pos_m2_lsb;
68 uint32_t m2_msb = t.pos_m2_msb;
69 uint32_t m2 = (m2_msb << 15) | m2_lsb;
70 // the bitmask is the same
71 return cast_to_signed(m2, t.bitmask_m2);
72 }

◆ get_m3()

int32_t dunedaq::cibmodules::util::get_m3 ( dunedaq::cib::daq::iols_trigger_t & t)

Definition at line 74 of file cib_utilities.cpp.

75 {
76 return cast_to_signed(t.pos_m3, t.bitmask_m3);
77 }

◆ parse_hex()

bool dunedaq::cibmodules::util::parse_hex ( std::string_view s,
std::uint32_t & out )

Definition at line 79 of file cib_utilities.cpp.

80 {
81 // Optional 0x / 0X prefix
82 if (s.size() >= 2 && s[0] == '0' && (s[1] == 'x' || s[1] == 'X'))
83 s.remove_prefix(2);
84
85 // Empty after stripping?
86 if (s.empty())
87 return false;
88
89 auto [ptr, ec] = std::from_chars(s.data(), s.data() + s.size(), out, 16);
90
91 // ec=={} means parse OK; ptr at end means no trailing garbage
92 return ec == std::errc{} && ptr == s.data() + s.size();
93 }