15#include <fairlogger/Logger.h>
29 LOGF(info,
"EP:%d CRU:0x%04x Link:%-3d FEEID:0x%04x HBOrb:%-9u TrOrb:%-9u Trg:%32s HBBC:%-4d TrBC:%-4d Packet:%-3d Page:%-5d Stop:%d Par:%-5d DetFld:0x%04x MemSize:%-4d OffsNext:%-4d prio.:%d BL:%-5d HS:%-2d HV:%d",
40 LOGF(info,
"EP:%d CRU:0x%04x Link:%-3d FEEID:0x%04x Orbit:%-9u BC:%-4d Stop:%d Page:%-5d Packet:%-3d Trg:%32s Par:%-5d DetFld:0x%04x MemSize:%-5d OffsNext:%-5d prio.:%d HS:%-2d HV:%d",
50 LOGF(info,
"EP:%d CRU:0x%04x Link:%-3d FEEID:0x%04x SrcID:%s[%d] Orbit:%-9u BC:%-4d DataFormat:%-2d Stop:%d Page:%-5d Packet:%-3d Trg:%32s Par:%-5d DetFld:0x%04x MemSize:%-5d OffsNext:%-5d prio.:%d HS:%-2d HV:%d",
51 int(rdh.
endPointID),
int(rdh.
cruID),
int(rdh.
linkID),
int(rdh.
feeId),
DAQID::DAQtoO2(rdh.
sourceID).
str,
int(rdh.
sourceID), rdh.
orbit,
int(rdh.
bunchCrossing),
int(rdh.
dataFormat),
int(rdh.
stop),
int(rdh.
pageCnt),
int(rdh.
packetCounter),
59 LOGF(info,
"EP:%d CRU:0x%04x Link:%-3d FEEID:0x%04x SrcID:%s[%d] Orbit:%-9u BC:%-4d Stop:%d Page:%-5d Packet:%-3d Trg:%32s Par:%-5d DetFld:0x%04x MemSize:%-5d OffsNext:%-5d prio.:%d HS:%-2d HV:%d",
60 int(rdh.
endPointID),
int(rdh.
cruID),
int(rdh.
linkID),
int(rdh.
feeId),
DAQID::DAQtoO2(rdh.
sourceID).
str,
int(rdh.
sourceID), rdh.
orbit,
int(rdh.
bunchCrossing),
int(rdh.
stop),
int(rdh.
pageCnt),
83 LOG(error) <<
"Unexpected RDH version " <<
version <<
" from";
85 throw std::runtime_error(
"invalid RDH provided");
93 const uint32_t* w32 =
reinterpret_cast<const uint32_t*
>(rdhP);
94 for (
int i = 0;
i < 4;
i++) {
96 LOGF(info,
"[rdh%d] 0x%08x 0x%08x 0x%08x 0x%08x",
i, w32[l + 3], w32[l + 2], w32[l + 1], w32[l]);
122 LOG(alarm) <<
"Unexpected RDH version " <<
version <<
" from";
126 if (!ok && verbose) {
139 LOG(alarm) <<
"RDH version 4 is expected instead of " <<
int(rdh.
version);
145 LOG(alarm) <<
"RDH with header size of 64 B is expected instead of " <<
int(rdh.
headerSize);
151 LOG(alarm) <<
"RDH expected to have memorySize/offsetToNext in 64 : 8192 bytes range instead of "
158 LOG(alarm) <<
"Some reserved fields of RDH v4 are not empty";
162 if (!ok && verbose) {
175 LOG(alarm) <<
"RDH version 5 is expected instead of " <<
int(rdh.
version);
181 LOG(alarm) <<
"RDH with header size of 64 B is expected instead of " <<
int(rdh.
headerSize);
187 LOG(alarm) <<
"RDH expected to have memory size and offset to next >= 64 B instead of "
194 LOG(alarm) <<
"Some reserved fields of RDH v5 are not empty";
198 if (!ok && verbose) {
211 LOG(alarm) <<
"RDH version 6 is expected instead of " <<
int(rdh.
version);
217 LOG(alarm) <<
"RDH with header size of 64 B is expected instead of " <<
int(rdh.
headerSize);
223 LOG(alarm) <<
"RDH expected to have memory size and offset to next >= 64 B instead of "
230 LOG(alarm) <<
"Some reserved fields of RDH v6 are not empty";
234 if (!ok && verbose) {
247 LOG(alarm) <<
"RDH version 7 is expected instead of " <<
int(rdh.
version);
253 LOG(alarm) <<
"RDH with header size of 64 B is expected instead of " <<
int(rdh.
headerSize);
259 LOG(alarm) <<
"RDH expected to have memory size and offset to next >= 64 B instead of "
266 LOG(alarm) <<
"Some reserved fields of RDH v7 are not empty";
270 if (!ok && verbose) {
279uint32_t RDHUtils::fletcher32(
const uint16_t*
data,
int len)
284 for (c0 =
c1 = 0;
len > 0;
len -= 360) {
285 int blocklen =
len < 360 ?
len : 360;
286 for (
int i = 0;
i < blocklen; ++
i) {
293 return (
c1 << 16 | c0);
297void RDHUtils::processError(
int v,
const char* field)
299 LOG(alarm) <<
"Wrong field " << field <<
" for RDHv" <<
v;
300 throw std::runtime_error(
"wrong RDH field accessed");
bool const GPUTPCGMMerger::trackCluster * c1
GLenum GLenum GLsizei len
static constexpr int MAXCRUPage
static void printRDH(const RDHv4 &rdh)
static bool checkRDH(const RDHv4 &rdh, bool verbose=true, bool checkZeros=false)
static void dumpRDH(const H &rdh, NOTPTR(H))
static constexpr int getVersion()
get numeric version of the RDH
LOG(info)<< "Compressed in "<< sw.CpuTime()<< " s"