23#include <unordered_map>
46 RawDump(
bool TOFUncompressed =
false);
72 bool mFatalOnDeadBeef{
false};
73 bool mSkipDump{
false};
74 bool mTOFUncompressed{
false};
75 bool mImposeSOX{
false};
78 uint64_t mTPCLinkRej{0};
80 std::string mOutDir{};
81 std::unordered_map<uint64_t, LinkInfo> mLinksInfo{};
82 std::unordered_map<std::string, FILE*> mName2File{};
83 std::unordered_map<int, DetID> mOrigin2DetID{};
84 std::array<std::string, o2::detectors::DetID::getNDetectors()> mConfigEntries{};
85 std::array<
int, o2::detectors::DetID::getNDetectors()> mFilesPerDet{};
99 mFatalOnDeadBeef = ic.
options().
get<
bool>(
"fatal-on-deadbeef");
100 mVerbosity = ic.
options().
get<
int>(
"dump-verbosity");
101 mOutDir = ic.
options().
get<std::string>(
"output-directory");
102 mSkipDump = ic.
options().
get<
bool>(
"skip-dump");
103 mImposeSOX = !ic.
options().
get<
bool>(
"skip-impose-sox");
104 auto vrej = o2::RangeTokenizer::tokenize<int>(ic.
options().
get<std::string>(
"reject-tpc-links"));
105 for (
auto i : vrej) {
107 mTPCLinkRej |= 0x1UL <<
i;
108 LOGP(info,
"Will reject TPC link {}",
i);
110 LOGP(error,
"LinkID cannot exceed 63, asked {}",
i);
113 if (mOutDir.size()) {
114 if (!std::filesystem::exists(mOutDir)) {
115#if defined(__clang__)
120 std::filesystem::create_directories(mOutDir);
121 if (!std::filesystem::exists(mOutDir)) {
122 LOG(fatal) <<
"could not create output directory " << mOutDir;
125 if (!std::filesystem::create_directories(mOutDir)) {
126 LOG(fatal) <<
"could not create output directory " << mOutDir;
129 LOGP(info,
"Created output directory {}", mOutDir);
144 if (dh->subSpecification == 0xdeadbeef && dh->payloadSize == 0) {
145 if (this->mFatalOnDeadBeef) {
146 LOGP(fatal,
"Found input [{}/{}/{:#x}] TF#{} 1st_orbit:{}", dh->dataOrigin.str, dh->dataDescription.str, dh->subSpecification, dh->tfCounter, dh->firstTForbit);
148 if (!repDeadBeef[
DetID(dh->dataOrigin.str)] || this->mVerbosity > 0) {
149 LOGP(warn,
"Skipping input [{}/{}/{:#x}] TF#{} 1st_orbit:{}", dh->dataOrigin.str, dh->dataDescription.str, dh->subSpecification, dh->tfCounter, dh->firstTForbit);
162 if (mTFCount == 0 && mImposeSOX) {
163 for (
auto it = parser.
begin(),
end = parser.
end(); it !=
end; ++it) {
164 auto const* dh = it.o2DataHeader();
165 if (!procDEADBEEF(dh)) {
168 const auto rdh =
reinterpret_cast<const header::RDHAny*
>(it.raw());
173 auto& lInfo = getLinkInfo(dh->dataOrigin, rdh);
174 if (!lInfo.firstIR.isDummy()) {
177 lInfo.firstIR = {0, o2::raw::RDHUtils::getTriggerOrbit(rdh)};
178 if (lInfo.firstIR < mFirstIR) {
179 mFirstIR = lInfo.firstIR;
181 auto trig = o2::raw::RDHUtils::getTriggerType(rdh);
184 lInfo.detID = mOrigin2DetID[dh->dataOrigin];
187 for (
auto& lit : mLinksInfo) {
188 auto& lInfo = lit.second;
189 if (!lInfo.hasSOX && lInfo.fileHandler) {
190 auto trig = o2::raw::RDHUtils::getTriggerType(lInfo.rdhSOX);
191 if (o2::raw::RDHUtils::getTriggerIR(lInfo.rdhSOX) != mFirstIR) {
199 if (mVerbosity > 0) {
200 LOGP(info,
"Writing cooked up RDH with SOX");
203 auto ws = std::fwrite(&lInfo.rdhSOX, 1,
sizeof(
o2::header::RDHAny), lInfo.fileHandler);
205 LOGP(fatal,
"Failed to write cooked up RDH with SOX");
209 }
else if (lInfo.fileHandler && o2::raw::RDHUtils::getTriggerOrbit(lInfo.rdhSOX) != mFirstIR.
orbit) {
211 LOGP(error,
"Original data had SOX set but the orbit differs from the smallest seen {}, keep original one", mFirstIR.
orbit);
216 for (
auto it = parser.
begin(),
end = parser.
end(); it !=
end; ++it) {
217 auto const* dh = it.o2DataHeader();
218 if (!procDEADBEEF(dh)) {
221 const auto rdh =
reinterpret_cast<const header::RDHAny*
>(it.raw());
226 if (mVerbosity > 1) {
230 auto& lInfo = getLinkInfo(dh->dataOrigin, rdh);
231 if (!mSkipDump && lInfo.fileHandler) {
232 auto sz = o2::raw::RDHUtils::getOffsetToNext(rdh);
234 if (mTFCount == 0 && !lInfo.hasSOX && o2::raw::RDHUtils::getTriggerIR(rdh) == mFirstIR) {
235 auto trig = o2::raw::RDHUtils::getTriggerType(rdh);
239 if (mVerbosity > 0) {
240 LOGP(info,
"Write existing RDH with SOX added");
245 LOGP(fatal,
"Failed to write RDH with SOX added");
249 if (o2::raw::RDHUtils::getStop(rdhC)) {
253 auto ws = std::fwrite(raw, 1, sz, lInfo.fileHandler);
255 LOGP(fatal,
"Failed to write payload of {} bytes", sz);
265 LOGP(info,
"closing {} output files", mName2File.size());
266 for (
auto h : mName2File) {
267 std::fclose(
h.second);
270 if (mConfigEntries[
id].
empty()) {
273 auto fnm = fmt::format(
"{}{}{}raw.cfg", mOutDir, mOutDir.back() ==
'/' ?
"" :
"/",
DetID::getName(
id));
274 auto fh = std::fopen(fnm.c_str(),
"w");
276 LOGP(fatal,
"Failed to create configuration file {}", fnm);
278 auto ws = std::fwrite(mConfigEntries[
id].
data(), 1, mConfigEntries[
id].
size(), fh);
279 if (ws != mConfigEntries[
id].
size()) {
280 LOGP(fatal,
"Failed to write configuration to {}", fnm);
290 uint32_t feeid = RDHUtils::getFEEID(rdh);
291 uint64_t
id = (uint64_t(detOr) << 32) + feeid;
292 auto& linkInfo = mLinksInfo[
id];
293 if (!linkInfo.fileHandler) {
294 DetID detID = mOrigin2DetID[detOr];
295 auto name = getFileName(detID, rdh);
299 linkInfo.fileHandler = mName2File[
name];
300 if (!linkInfo.fileHandler) {
301 linkInfo.fileHandler = std::fopen(
name.c_str(),
"w");
302 if (!linkInfo.fileHandler) {
303 LOGP(fatal,
"Failed to create file {} for Det={} / FeeID=0x{:05x}",
name, detOr.
str, feeid);
305 mName2File[
name] = linkInfo.fileHandler;
306 mConfigEntries[detID] += fmt::format(
309 "dataDescription = {}\n"
314 if (mVerbosity > 0) {
326 std::string baseName{};
329 baseName = getBaseFileNameITS(rdh);
332 baseName = getBaseFileNameMFT(rdh);
335 baseName = getBaseFileNameTPC(rdh);
338 baseName = getBaseFileNameTRD(rdh);
341 baseName = getBaseFileNameTOF(rdh);
344 baseName = getBaseFileNameEMC(rdh);
347 baseName = getBaseFileNamePHS(rdh);
350 baseName = getBaseFileNameCPV(rdh);
353 baseName = getBaseFileNameCTP(rdh);
356 baseName = getBaseFileNameMID(rdh);
359 baseName = getBaseFileNameMCH(rdh);
362 baseName = getBaseFileNameFT0(rdh);
365 baseName = getBaseFileNameFV0(rdh);
368 baseName = getBaseFileNameFDD(rdh);
371 baseName = getBaseFileNameZDC(rdh);
374 baseName = getBaseFileNameHMP(rdh);
378 baseName = fmt::format(
"feeID0x{:05x}", RDHUtils::getFEEID(rdh));
381 return baseName.empty() ? std::string{} : fmt::format(
"{}{}{}_{}.raw", mOutDir, mOutDir.back() ==
'/' ?
"" :
"/", detID.
getName(), baseName);
387 return "alio2-cr1-flp163_cru1111_0";
393 return fmt::format(
"alio2-cr1-flp200_cru{}_{}", RDHUtils::getCRUID(rdh), RDHUtils::getEndPointID(rdh));
399 return fmt::format(
"alio2-cr1-flp180_cru{}_{}", RDHUtils::getCRUID(rdh), RDHUtils::getEndPointID(rdh));
405 return fmt::format(
"alio2-cr1-flp201_cru{}_{}", RDHUtils::getCRUID(rdh), RDHUtils::getEndPointID(rdh));
411 uint16_t cruID = RDHUtils::getCRUID(rdh);
412 if (cruID < 120 || cruID > 123) {
413 auto flpname = fmt::format(
"flp-unknown_crorc{}_{}_ddlID{}", cruID, RDHUtils::getLinkID(rdh), RDHUtils::getFEEID(rdh));
414 LOGP(error,
"Unrecognized HMP flp, setting to {}", flpname);
417 return fmt::format(
"alio2-cr1-flp{}_crorc{}_{}", cruID < 122 ? 160 : 161, cruID,
RDHUtils::getLinkID(rdh));
423 static const std::array<int, 20> CRORCID = {110, 112, 110, 112, 110, 112, 111, 113, 111, 113, 111, 113, 114, 116, 114, 116, 115, 117, 115, 117};
424 static const std::array<int, 40> CRORCLink = {0, 1, 0, 1, 2, 3, 2, 3, 4, 5, 4, 5, 0, 1, 0, 1, 2, 3, 2, 3, 4, -1, 4, 5, 0, 1, 0, 1, 2, 3, 2, 3, 0, 1, 0, 1, 1, 3, 2};
426 uint16_t ddlID = RDHUtils::getFEEID(rdh), crorc = -1, link = -1, flpID = -1;
428 crorc = CRORCID[ddlID / 2];
429 link = CRORCLink[ddlID];
430 flpID = ddlID <= 23 ? 146 : 147;
431 }
else if (ddlID == 44) {
435 }
else if (ddlID == 45) {
440 auto flpname = fmt::format(
"flp-unknown_crorc{}_{}_ddlID{}", RDHUtils::getCRUID(rdh), RDHUtils::getLinkID(rdh), ddlID);
441 LOGP(error,
"Unrecognized EMC flp, setting to {}", flpname);
444 return fmt::format(
"alio2-cr1-flp{}_crorc{}_{}", flpID, crorc, link);
450 uint16_t ddlID = RDHUtils::getFEEID(rdh), crorc = -1, link = -1, flpID = -1;
460 }
else if (ddlID < 14) {
467 link = (ddlID - 6) % 4;
470 auto flpname = fmt::format(
"flp-unknown_crorc{}_{}_ddlID{}", RDHUtils::getCRUID(rdh), RDHUtils::getLinkID(rdh), ddlID);
471 LOGP(error,
"Unrecognized PHS flp, setting to {}", flpname);
474 return fmt::format(
"alio2-cr1-flp{}_crorc{}_{}", flpID, crorc, link);
480 constexpr int NLinks = 72;
481 static constexpr int CRUFROMLINK[
NLinks] = {
482 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3,
483 3, 3, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
484 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
485 1, 1, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2};
486 static constexpr Int_t CRUID[4] = {225, 226, 227, 228};
487 static constexpr Int_t FLPFROMCRU[4] = {179, 179, 178, 178};
488 uint16_t feeID = RDHUtils::getFEEID(rdh);
490 auto flpname = fmt::format(
"flp-unknown_cru{}_ep{}_feeid0x{:05x}", RDHUtils::getCRUID(rdh),
int(RDHUtils::getEndPointID(rdh)), feeID);
491 LOGP(error,
"Unrecognized TOF flp, setting to {}", flpname);
494 return fmt::format(
"alio2-cr1-flp{}_cru{}_{}", FLPFROMCRU[CRUFROMLINK[feeID]], CRUID[CRUFROMLINK[feeID]], RDHUtils::getEndPointID(rdh));
500 uint16_t feeID = RDHUtils::getFEEID(rdh);
502 auto flpname = fmt::format(
"flp-unknown_cru{}_ep{}_feeid0x{:05x}", RDHUtils::getCRUID(rdh),
int(RDHUtils::getEndPointID(rdh)), feeID);
503 LOGP(error,
"Unrecognized MID flp, setting to {}", flpname);
506 return fmt::format(
"alio2-cr1-flp159_cru{}_{}", feeID / 2, RDHUtils::getEndPointID(rdh));
512 uint16_t cruID = RDHUtils::getCRUID(rdh) & 0xff;
514 auto flpname = fmt::format(
"flp-unknown_cru{}_ep{}_feeid0x{:05x}", RDHUtils::getCRUID(rdh),
int(RDHUtils::getEndPointID(rdh)), RDHUtils::getFEEID(rdh));
515 LOGP(error,
"Unrecognized MCH flp, setting to {}", flpname);
519 return fmt::format(
"alio2-cr1-flp{}_cru{}_{}", 148 + cruID / 3, cruID, RDHUtils::getEndPointID(rdh));
525 return fmt::format(
"alio2-cr1-flp181_cru{}_{}", RDHUtils::getCRUID(rdh), RDHUtils::getEndPointID(rdh));
531 uint16_t feeid = RDHUtils::getFEEID(rdh);
533 auto flpname = fmt::format(
"flp-unknown_cru{}_ep{}_feeid0x{:05x}", RDHUtils::getCRUID(rdh),
int(RDHUtils::getEndPointID(rdh)), RDHUtils::getFEEID(rdh));
534 LOGP(error,
"Unrecognized CPV flp, setting to {}", flpname);
537 return fmt::format(
"alio2-cr1-flp162_cru{}_{}", RDHUtils::getCRUID(rdh), RDHUtils::getEndPointID(rdh));
543 static const std::unordered_map<int, std::string> cru2name = {
544 {183,
"alio2-cr1-flp187"},
545 {172,
"alio2-cr1-flp198"},
546 {181,
"alio2-cr1-flp188"},
547 {196,
"alio2-cr1-flp203"},
548 {184,
"alio2-cr1-flp189"},
549 {191,
"alio2-cr1-flp189"},
550 {179,
"alio2-cr1-flp190"},
551 {192,
"alio2-cr1-flp190"},
552 {175,
"alio2-cr1-flp191"},
553 {182,
"alio2-cr1-flp191"},
554 {187,
"alio2-cr1-flp192"},
555 {176,
"alio2-cr1-flp192"},
556 {177,
"alio2-cr1-flp193"},
557 {178,
"alio2-cr1-flp193"},
558 {194,
"alio2-cr1-flp194"},
559 {174,
"alio2-cr1-flp194"},
560 {180,
"alio2-cr1-flp195"},
561 {193,
"alio2-cr1-flp195"},
562 {185,
"alio2-cr1-flp196"},
563 {189,
"alio2-cr1-flp196"},
564 {186,
"alio2-cr1-flp197"},
565 {195,
"alio2-cr1-flp197"},
567 auto ent = cru2name.find(RDHUtils::getCRUID(rdh));
568 if (ent == cru2name.end()) {
569 auto flpname = fmt::format(
"flp-unknown_cru{}_ep{}_feeid0x{:05x}", RDHUtils::getCRUID(rdh),
int(RDHUtils::getEndPointID(rdh)), RDHUtils::getFEEID(rdh));
570 LOGP(error,
"Unrecognized ITS flp, setting to {}", flpname);
573 return fmt::format(
"{}_cru{}_{}", ent->second, RDHUtils::getCRUID(rdh), RDHUtils::getEndPointID(rdh));
579 static const std::unordered_map<int, std::pair<int, std::string>> cru2name = {
580 {0x800, {570,
"alio2-cr1-flp182"}},
581 {0x801, {542,
"alio2-cr1-flp186"}},
582 {0x802, {548,
"alio2-cr1-flp183"}},
583 {0x803, {211,
"alio2-cr1-flp185"}},
584 {0x804, {569,
"alio2-cr1-flp184"}},
585 {0x805, {543,
"alio2-cr1-flp184"}},
586 {0x806, {552,
"alio2-cr1-flp185"}},
587 {0x807, {554,
"alio2-cr1-flp183"}},
588 {0x808, {547,
"alio2-cr1-flp186"}},
589 {0x809, {567,
"alio2-cr1-flp182"}},
591 auto ent = cru2name.find(RDHUtils::getCRUID(rdh));
592 if (ent == cru2name.end()) {
593 auto flpname = fmt::format(
"flp-unknown_cru{}_ep{}_feeid0x{:05x}", RDHUtils::getCRUID(rdh),
int(RDHUtils::getEndPointID(rdh)), RDHUtils::getFEEID(rdh));
594 LOGP(error,
"Unrecognized MFT flp, setting to {}", flpname);
597 return fmt::format(
"{}_cru{}_{}", ent->second.second, RDHUtils::getCRUID(rdh),
int(RDHUtils::getEndPointID(rdh)));
603 constexpr int NFLP = 361;
604 constexpr const char* CRU_FLPS[
NFLP] = {
605 "alio2-cr1-flp070",
"alio2-cr1-flp069",
"alio2-cr1-flp070",
"alio2-cr1-flp069",
"alio2-cr1-flp072",
"alio2-cr1-flp071",
"alio2-cr1-flp072",
"alio2-cr1-flp071",
"alio2-cr1-flp072",
"alio2-cr1-flp071",
"alio2-cr1-flp002",
"alio2-cr1-flp001",
"alio2-cr1-flp002",
"alio2-cr1-flp001",
"alio2-cr1-flp004",
"alio2-cr1-flp003",
"alio2-cr1-flp004",
"alio2-cr1-flp003",
606 "alio2-cr1-flp004",
"alio2-cr1-flp003",
"alio2-cr1-flp006",
"alio2-cr1-flp005",
"alio2-cr1-flp006",
"alio2-cr1-flp005",
"alio2-cr1-flp008",
"alio2-cr1-flp007",
"alio2-cr1-flp008",
"alio2-cr1-flp007",
"alio2-cr1-flp008",
"alio2-cr1-flp007",
"alio2-cr1-flp010",
"alio2-cr1-flp009",
"alio2-cr1-flp010",
"alio2-cr1-flp009",
"alio2-cr1-flp012",
"alio2-cr1-flp011",
607 "alio2-cr1-flp012",
"alio2-cr1-flp011",
"alio2-cr1-flp012",
"alio2-cr1-flp011",
"alio2-cr1-flp014",
"alio2-cr1-flp013",
"alio2-cr1-flp014",
"alio2-cr1-flp013",
"alio2-cr1-flp016",
"alio2-cr1-flp015",
"alio2-cr1-flp016",
"alio2-cr1-flp015",
"alio2-cr1-flp016",
"alio2-cr1-flp015",
"alio2-cr1-flp018",
"alio2-cr1-flp017",
"alio2-cr1-flp018",
"alio2-cr1-flp017",
608 "alio2-cr1-flp020",
"alio2-cr1-flp019",
"alio2-cr1-flp020",
"alio2-cr1-flp019",
"alio2-cr1-flp020",
"alio2-cr1-flp019",
"alio2-cr1-flp022",
"alio2-cr1-flp021",
"alio2-cr1-flp022",
"alio2-cr1-flp021",
"alio2-cr1-flp024",
"alio2-cr1-flp023",
"alio2-cr1-flp024",
"alio2-cr1-flp023",
"alio2-cr1-flp024",
"alio2-cr1-flp023",
"alio2-cr1-flp026",
"alio2-cr1-flp025",
609 "alio2-cr1-flp026",
"alio2-cr1-flp025",
"alio2-cr1-flp028",
"alio2-cr1-flp027",
"alio2-cr1-flp028",
"alio2-cr1-flp027",
"alio2-cr1-flp028",
"alio2-cr1-flp027",
"alio2-cr1-flp030",
"alio2-cr1-flp029",
"alio2-cr1-flp030",
"alio2-cr1-flp029",
"alio2-cr1-flp032",
"alio2-cr1-flp031",
"alio2-cr1-flp032",
"alio2-cr1-flp031",
"alio2-cr1-flp032",
"alio2-cr1-flp031",
610 "alio2-cr1-flp034",
"alio2-cr1-flp033",
"alio2-cr1-flp034",
"alio2-cr1-flp033",
"alio2-cr1-flp036",
"alio2-cr1-flp035",
"alio2-cr1-flp036",
"alio2-cr1-flp035",
"alio2-cr1-flp036",
"alio2-cr1-flp035",
"alio2-cr1-flp038",
"alio2-cr1-flp037",
"alio2-cr1-flp038",
"alio2-cr1-flp037",
"alio2-cr1-flp040",
"alio2-cr1-flp039",
"alio2-cr1-flp040",
"alio2-cr1-flp039",
611 "alio2-cr1-flp040",
"alio2-cr1-flp039",
"alio2-cr1-flp042",
"alio2-cr1-flp041",
"alio2-cr1-flp042",
"alio2-cr1-flp041",
"alio2-cr1-flp044",
"alio2-cr1-flp043",
"alio2-cr1-flp044",
"alio2-cr1-flp043",
"alio2-cr1-flp044",
"alio2-cr1-flp043",
"alio2-cr1-flp046",
"alio2-cr1-flp045",
"alio2-cr1-flp046",
"alio2-cr1-flp045",
"alio2-cr1-flp048",
"alio2-cr1-flp047",
612 "alio2-cr1-flp048",
"alio2-cr1-flp047",
"alio2-cr1-flp048",
"alio2-cr1-flp047",
"alio2-cr1-flp050",
"alio2-cr1-flp049",
"alio2-cr1-flp050",
"alio2-cr1-flp049",
"alio2-cr1-flp052",
"alio2-cr1-flp051",
"alio2-cr1-flp052",
"alio2-cr1-flp051",
"alio2-cr1-flp052",
"alio2-cr1-flp051",
"alio2-cr1-flp054",
"alio2-cr1-flp053",
"alio2-cr1-flp054",
"alio2-cr1-flp053",
613 "alio2-cr1-flp056",
"alio2-cr1-flp055",
"alio2-cr1-flp056",
"alio2-cr1-flp055",
"alio2-cr1-flp056",
"alio2-cr1-flp055",
"alio2-cr1-flp058",
"alio2-cr1-flp057",
"alio2-cr1-flp058",
"alio2-cr1-flp057",
"alio2-cr1-flp060",
"alio2-cr1-flp059",
"alio2-cr1-flp060",
"alio2-cr1-flp059",
"alio2-cr1-flp060",
"alio2-cr1-flp059",
"alio2-cr1-flp062",
"alio2-cr1-flp061",
614 "alio2-cr1-flp062",
"alio2-cr1-flp061",
"alio2-cr1-flp064",
"alio2-cr1-flp063",
"alio2-cr1-flp064",
"alio2-cr1-flp063",
"alio2-cr1-flp064",
"alio2-cr1-flp063",
"alio2-cr1-flp066",
"alio2-cr1-flp065",
"alio2-cr1-flp066",
"alio2-cr1-flp065",
"alio2-cr1-flp068",
"alio2-cr1-flp067",
"alio2-cr1-flp068",
"alio2-cr1-flp067",
"alio2-cr1-flp068",
"alio2-cr1-flp067",
615 "alio2-cr1-flp074",
"alio2-cr1-flp073",
"alio2-cr1-flp074",
"alio2-cr1-flp073",
"alio2-cr1-flp076",
"alio2-cr1-flp075",
"alio2-cr1-flp076",
"alio2-cr1-flp075",
"alio2-cr1-flp076",
"alio2-cr1-flp075",
"alio2-cr1-flp078",
"alio2-cr1-flp077",
"alio2-cr1-flp078",
"alio2-cr1-flp077",
"alio2-cr1-flp080",
"alio2-cr1-flp079",
"alio2-cr1-flp080",
"alio2-cr1-flp079",
616 "alio2-cr1-flp080",
"alio2-cr1-flp079",
"alio2-cr1-flp082",
"alio2-cr1-flp081",
"alio2-cr1-flp082",
"alio2-cr1-flp081",
"alio2-cr1-flp084",
"alio2-cr1-flp083",
"alio2-cr1-flp084",
"alio2-cr1-flp083",
"alio2-cr1-flp084",
"alio2-cr1-flp083",
"alio2-cr1-flp086",
"alio2-cr1-flp085",
"alio2-cr1-flp086",
"alio2-cr1-flp085",
"alio2-cr1-flp088",
"alio2-cr1-flp087",
617 "alio2-cr1-flp088",
"alio2-cr1-flp087",
"alio2-cr1-flp088",
"alio2-cr1-flp087",
"alio2-cr1-flp090",
"alio2-cr1-flp089",
"alio2-cr1-flp090",
"alio2-cr1-flp089",
"alio2-cr1-flp092",
"alio2-cr1-flp091",
"alio2-cr1-flp092",
"alio2-cr1-flp091",
"alio2-cr1-flp092",
"alio2-cr1-flp091",
"alio2-cr1-flp094",
"alio2-cr1-flp093",
"alio2-cr1-flp094",
"alio2-cr1-flp093",
618 "alio2-cr1-flp096",
"alio2-cr1-flp095",
"alio2-cr1-flp096",
"alio2-cr1-flp095",
"alio2-cr1-flp096",
"alio2-cr1-flp095",
"alio2-cr1-flp098",
"alio2-cr1-flp097",
"alio2-cr1-flp098",
"alio2-cr1-flp097",
"alio2-cr1-flp100",
"alio2-cr1-flp099",
"alio2-cr1-flp100",
"alio2-cr1-flp099",
"alio2-cr1-flp100",
"alio2-cr1-flp099",
"alio2-cr1-flp102",
"alio2-cr1-flp101",
619 "alio2-cr1-flp102",
"alio2-cr1-flp101",
"alio2-cr1-flp104",
"alio2-cr1-flp103",
"alio2-cr1-flp104",
"alio2-cr1-flp103",
"alio2-cr1-flp104",
"alio2-cr1-flp103",
"alio2-cr1-flp106",
"alio2-cr1-flp105",
"alio2-cr1-flp106",
"alio2-cr1-flp105",
"alio2-cr1-flp108",
"alio2-cr1-flp107",
"alio2-cr1-flp108",
"alio2-cr1-flp107",
"alio2-cr1-flp108",
"alio2-cr1-flp107",
620 "alio2-cr1-flp110",
"alio2-cr1-flp109",
"alio2-cr1-flp110",
"alio2-cr1-flp109",
"alio2-cr1-flp112",
"alio2-cr1-flp111",
"alio2-cr1-flp112",
"alio2-cr1-flp111",
"alio2-cr1-flp112",
"alio2-cr1-flp111",
"alio2-cr1-flp114",
"alio2-cr1-flp113",
"alio2-cr1-flp114",
"alio2-cr1-flp113",
"alio2-cr1-flp116",
"alio2-cr1-flp115",
"alio2-cr1-flp116",
"alio2-cr1-flp115",
621 "alio2-cr1-flp116",
"alio2-cr1-flp115",
"alio2-cr1-flp118",
"alio2-cr1-flp117",
"alio2-cr1-flp118",
"alio2-cr1-flp117",
"alio2-cr1-flp120",
"alio2-cr1-flp119",
"alio2-cr1-flp120",
"alio2-cr1-flp119",
"alio2-cr1-flp120",
"alio2-cr1-flp119",
"alio2-cr1-flp122",
"alio2-cr1-flp121",
"alio2-cr1-flp122",
"alio2-cr1-flp121",
"alio2-cr1-flp124",
"alio2-cr1-flp123",
622 "alio2-cr1-flp124",
"alio2-cr1-flp123",
"alio2-cr1-flp124",
"alio2-cr1-flp123",
"alio2-cr1-flp126",
"alio2-cr1-flp125",
"alio2-cr1-flp126",
"alio2-cr1-flp125",
"alio2-cr1-flp128",
"alio2-cr1-flp127",
"alio2-cr1-flp128",
"alio2-cr1-flp127",
"alio2-cr1-flp128",
"alio2-cr1-flp127",
"alio2-cr1-flp130",
"alio2-cr1-flp129",
"alio2-cr1-flp130",
"alio2-cr1-flp129",
623 "alio2-cr1-flp132",
"alio2-cr1-flp131",
"alio2-cr1-flp132",
"alio2-cr1-flp131",
"alio2-cr1-flp132",
"alio2-cr1-flp131",
"alio2-cr1-flp134",
"alio2-cr1-flp133",
"alio2-cr1-flp134",
"alio2-cr1-flp133",
"alio2-cr1-flp136",
"alio2-cr1-flp135",
"alio2-cr1-flp136",
"alio2-cr1-flp135",
"alio2-cr1-flp136",
"alio2-cr1-flp135",
"alio2-cr1-flp138",
"alio2-cr1-flp137",
624 "alio2-cr1-flp138",
"alio2-cr1-flp137",
"alio2-cr1-flp140",
"alio2-cr1-flp139",
"alio2-cr1-flp140",
"alio2-cr1-flp139",
"alio2-cr1-flp140",
"alio2-cr1-flp139",
"alio2-cr1-flp142",
"alio2-cr1-flp141",
"alio2-cr1-flp142",
"alio2-cr1-flp141",
"alio2-cr1-flp144",
"alio2-cr1-flp143",
"alio2-cr1-flp144",
"alio2-cr1-flp143",
"alio2-cr1-flp144",
"alio2-cr1-flp143",
627 if (mTPCLinkRej && (mTPCLinkRej & (0x1UL << RDHUtils::getLinkID(rdh)))) {
631 int cru = RDHUtils::getCRUID(rdh);
633 auto flpname = fmt::format(
"flp-unknown_cru{}_ep{}_feeid0x{:05x}", RDHUtils::getCRUID(rdh),
int(RDHUtils::getEndPointID(rdh)), RDHUtils::getFEEID(rdh));
634 LOGP(error,
"Unrecognized TPC flp, setting to {}", flpname);
637 return fmt::format(
"{}_cru{}_{}", CRU_FLPS[cru], cru,
int(RDHUtils::getEndPointID(rdh)));
643 constexpr int NLinks = 72;
644 struct TRDCRUMapping {
650 {166, 250, 0}, {166, 583, 0}, {166, 585, 0}, {167, 248, 0}, {167, 249, 0}, {167, 596, 0}, {168, 246, 0}, {168, 247, 0}, {168, 594, 0}, {169, 252, 0}, {169, 253, 0}, {169, 254, 0}, {170, 245, 0}, {170, 593, 0}, {170, 595, 0}, {171, 258, 0}, {171, 259, 0}, {171, 260, 0}, {172, 579, 0}, {172, 581, 0}, {172, 586, 0}, {173, 578, 0}, {173, 580, 0}, {173, 597, 0}, {174, 256, 0}, {174, 582, 0}, {174, 587, 0}, {175, 251, 0}, {175, 255, 0}, {175, 588, 0}, {176, 264, 0}, {176, 591, 0}, {176, 592, 0}, {177, 263, 0}, {177, 589, 0}, {177, 590, 0}};
653 uint16_t feeID = RDHUtils::getFEEID(rdh);
654 int ep = feeID & 0x1,
supermodule = feeID >> 8,
side = (feeID & (0x1 << 4)) & 0x1;
656 if (link >= NLinks) {
657 auto flpname = fmt::format(
"flp-unknown_cru{}_ep{}_feeid0x{:05x}", cru,
int(RDHUtils::getEndPointID(rdh)), RDHUtils::getFEEID(rdh));
658 LOGP(error,
"Got wrong link {}, setting TRF file name to unrecognized flp {}", link, flpname);
661 return fmt::format(
"alio2-cr1-flp{}_cru{}_{}", trdHWMap[cru].flpid, trdHWMap[cru].cruHWID, ep);
673 std::vector<InputSpec> inputs;
685 {
ConfigParamSpec{
"fatal-on-deadbeef", VariantType::Bool,
false, {
"produce fata if 0xdeadbeef received for some detector"}},
686 ConfigParamSpec{
"skip-dump", VariantType::Bool,
false, {
"do not produce binary data"}},
687 ConfigParamSpec{
"dump-verbosity", VariantType::Int, 0, {
"0:minimal, 1:report Det/FeeID->filename, 2: print RDH"}},
688 ConfigParamSpec{
"reject-tpc-links", VariantType::String,
"", {
"comma-separated list TPC links to reject"}},
689 ConfigParamSpec{
"skip-impose-sox", VariantType::Bool,
false, {
"do not impose SOX for 1st TF"}},
690 ConfigParamSpec{
"output-directory", VariantType::String,
"./", {
"Output directory (create if needed)"}}}};
Definition of the 32 Central Trigger System (CTS) Trigger Types defined in https://twiki....
std::string getName(const TDataMember *dm, int index, int size)
A raw page parser for DPL input.
Helper function to tokenize sequences and ranges of integral numbers.
Class for time synchronization of RawReader instances.
Static class with identifiers, bitmasks and names for ALICE detectors.
static constexpr const char * getName(ID id)
names of defined detectors
static constexpr ID First
static constexpr ID Last
if extra detectors added, update this !!!
static constexpr o2h::DataOrigin getDataOrigin(ID id)
static mask_t getMask(const std::string_view detList)
detector masks from any non-alpha-num delimiter-separated list (empty if NONE is supplied)
T get(const char *key) const
The parser handles transparently input in the format of raw pages.
const_iterator end() const
const_iterator begin() const
ConfigParamRegistry const & options()
InputRecord & inputs()
The inputs associated with this processing context.
static std::string getReadoutType(DetID id)
void run(ProcessingContext &pc) final
void endOfStream(EndOfStreamContext &ec) final
This is invoked whenever we have an EndOfStream event.
void init(InitContext &ic) final
static constexpr o2h::DataDescription DESCCRaw
static constexpr o2h::DataDescription DESCRaw
RawDump(bool TOFUncompressed=false)
GLuint const GLchar * name
constexpr o2::header::DataOrigin gDataOriginInvalid
Defining PrimaryVertex explicitly as messageable.
o2::framework::DataProcessorSpec getRawDumpSpec(o2::detectors::DetID::mask_t detMask, bool TOFUncompressed)
o2::detectors::DetID DetID
constexpr int NFLP
the number of FLP we have.
const TRDCRUMapping trdHWMap[constants::NHALFCRU/2]
a couple of static helper functions to create timestamp values for CCDB queries or override obsolete ...
Common utility functions.
static void setTriggerType(H &rdh, uint32_t v, NOTPTR(H))
static void setMemorySize(H &rdh, uint16_t v, NOTPTR(H))
static void printRDH(const RDHv4 &rdh)
static bool checkRDH(const RDHv4 &rdh, bool verbose=true, bool checkZeros=false)
static void setPacketCounter(H &rdh, uint8_t v, NOTPTR(H))
static void setTriggerOrbit(RDHv4 &rdh, uint32_t v)
static void setOffsetToNext(H &rdh, uint16_t v, NOTPTR(H))
static void setStop(H &rdh, uint8_t v, NOTPTR(H))
o2::InteractionRecord firstIR
o2::header::RDHAny rdhSOX
static std::string getFullPath(const std::string_view p)
LOG(info)<< "Compressed in "<< sw.CpuTime()<< " s"