263 B2INFO(
"trgrawdata: event() started.");
267 int _exp = bevt->getExperiment();
268 int _run = bevt->getRun();
269 unsigned _eve = bevt->getEvent();
271 std::cout <<
"**************_eve(" << _eve
273 <<
"), m_nclk_cdctrg(" << m_nclk_cdctrg
274 <<
"), _exp(" << _exp
275 <<
"), _run(" << _run
276 <<
"), _eve(" << _eve
277 <<
"), _Form(" << Form(
"he%010d", (
int)_eve)
280 TH2D* h_0 =
new TH2D(Form(
"he%010d", (
int)_eve),
281 Form(
"e%02dr%04d ev %08d", _exp, _run, (
int)_eve),
283 m_nclk_cdctrg, 0, m_nclk_cdctrg);
286 h_0->GetXaxis()->SetBinLabel(4 * i + 1, Form(
"%s hdevt", moduleNames[i]));
287 h_0->GetXaxis()->SetBinLabel(4 * i + 2, Form(
"%s dtevt", moduleNames[i]));
288 h_0->GetXaxis()->SetBinLabel(4 * i + 3, Form(
"%s L1rvc", moduleNames[i]));
289 h_0->GetXaxis()->SetBinLabel(4 * i + 4, Form(
"%s cc", moduleNames[i]));
295 unsigned gdlrvc12 = -1;
296 for (
int i = 0; i < raw_trgarray.
getEntries(); i++) {
297 for (
int j = 0; j < raw_trgarray[i]->GetNumEntries(); j++) {
298 int cprid = (int)raw_trgarray[i]->GetNodeID(j);
299 unsigned eve20 = (_eve & 0xfffff);
300 for (
int hslb = 0; hslb < 2; hslb++) {
301 int nword = raw_trgarray[i]->GetDetectorNwords(j, hslb);
302 int* buf = raw_trgarray[i]->GetDetectorBuffer(j, hslb);
303 if (0x15000001 == cprid && hslb == 0) {
306 printf(
"aa:GDL start: 0x%x%c exp(%d), run(%d), eve(%u), eve(0x%x), nword(%d)\n",
307 cprid,
'a' + hslb, _exp, _run, _eve, _eve, nword);
311 if (nword > 0) buf0 = (unsigned)buf[0];
313 if (nword > 1) buf1 = (unsigned)buf[1];
315 if (nword > 2) buf2 = (unsigned)buf[2];
320 m_cntr_nwe_badnwd[e_gdl]++;
321 printf(
"ab:GDL(0x%x%c) exp(%d), run(%d), eve(%u), eve(0x%x), nword(%d), ",
322 cprid,
'a' + hslb, _exp, _run, _eve, _eve, nword);
323 printf(
"buf0(0x%x), buf1(0x%x), buf2(0x%x)\n", buf0, buf1, buf2);
328 printf(
"ad:GDL(0x%x%c) exp(%d), run(%d), eve(%u), eve(0x%x), nword(%d)\n",
329 cprid,
'a' + hslb, _exp, _run, _eve, _eve, nword);
330 m_cntr_nwe_badnwd[e_gdl]++;
332 unsigned buf5 = (unsigned)buf[m_hdr_nwd_gdl - 1];
334 unsigned buf6 = (unsigned)buf[626];
335 unsigned buf7 = (unsigned)buf[627];
336 unsigned lastdd = (buf6 >> 24) & 0xff;
337 unsigned last_rvc = (buf6 >> 4) & 0xfff;
338 unsigned cnttrg_data_15to12 = buf6 & (0xf);
339 unsigned cnttrg_data_12 = (buf7 >> 20) & (0xfff);
340 gdlrvc12 = (buf5 & 0xfff);
341 unsigned gdlhdrcnttrg20 = (buf5 >> 12) & 0xfffff;
348 unsigned cnttrg_data_16 = (cnttrg_data_15to12 << 12) + cnttrg_data_12;
349 unsigned eve16 = (_eve & 0xffff);
351 h_0->SetBinContent(4 * (
int)e_gdl + 1, m_nclk_gdl, gdlhdrcnttrg20);
352 h_0->SetBinContent(4 * (
int)e_gdl + 2, m_nclk_gdl, cnttrg_data_16);
353 h_0->SetBinContent(4 * (
int)e_gdl + 3, m_nclk_gdl, gdlrvc12);
355 if (nword != m_nwd_gdl || buf0 != m_fmid_gdl || lastdd != 0xdd ||
356 gdlhdrcnttrg20 != eve20 ||
357 !(eve16 == cnttrg_data_16 + 1 || (eve16 == 0 && cnttrg_data_16 == 0xffff))
361 diag |= (nword != m_nwd_gdl) ? 1 : 0;
362 diag |= (buf0 != m_fmid_gdl) ? 2 : 0;
363 diag |= (lastdd != 0xdd) ? 4 : 0;
364 diag |= (gdlhdrcnttrg20 != eve20) ? 8 : 0;
365 diag |= !(eve16 == cnttrg_data_16 + 1 || (eve16 == 0 && cnttrg_data_16 == 0xffff)) ? 16 : 0;
366 printf(
"ae:GDL(0x%x%c) exp(%d), run(%d), evedaq(%u=0x%x), gdlhdrcnttrg20(%u,0x%x), "
367 "cnttrg_data16(%u=0x%x), l1rvc(%u)-lastrvc(%u)=%u, nword(%d), diag(%u)\n",
368 cprid,
'a' + hslb, _exp, _run, _eve, _eve, gdlhdrcnttrg20, gdlhdrcnttrg20,
369 cnttrg_data_16, cnttrg_data_16, gdlrvc12, last_rvc, gdlrvc12 - last_rvc, nword, diag);
371 m_cntr_nwn_badtrg[e_gdl]++;
382 for (
int i = 0; i < raw_trgarray.
getEntries(); i++) {
383 for (
int j = 0; j < raw_trgarray[i]->GetNumEntries(); j++) {
384 unsigned cprid = raw_trgarray[i]->GetNodeID(j);
386 unsigned eve20 = (_eve & 0xfffff);
387 for (
int hslb = 0; hslb < 2; hslb++) {
390 unsigned _scale = -1;
392 unsigned _hdr_nwd = 3;
393 if (m_cpr_2d0 == cprid && hslb == 0 && m_on_2d0) {
394 e_mdl = e_2d0; _nwd = m_nwd_2ds; _scale = m_scale_2ds; _nclk = m_nclk_2ds; _hdr_nwd = m_hdr_nwd_2d0;
395 }
else if (m_cpr_2d1 == cprid && hslb == 1 && m_on_2d1) {
396 e_mdl = e_2d1; _nwd = m_nwd_2ds; _scale = m_scale_2ds; _nclk = m_nclk_2ds; _hdr_nwd = m_hdr_nwd_2d1;
397 }
else if (m_cpr_2d2 == cprid && hslb == 0 && m_on_2d2) {
398 e_mdl = e_2d2; _nwd = m_nwd_2ds; _scale = m_scale_2ds; _nclk = m_nclk_2ds; _hdr_nwd = m_hdr_nwd_2d2;
399 }
else if (m_cpr_2d3 == cprid && hslb == 1 && m_on_2d3) {
400 e_mdl = e_2d3; _nwd = m_nwd_2ds; _scale = m_scale_2ds; _nclk = m_nclk_2ds; _hdr_nwd = m_hdr_nwd_2d3;
401 }
else if (m_cpr_3d0 == cprid && hslb == 0 && m_on_3d0) {
402 e_mdl = e_3d0; _nwd = m_nwd_3ds; _scale = m_scale_3ds; _nclk = m_nclk_3ds; _hdr_nwd = m_hdr_nwd_3d0;
403 }
else if (m_cpr_3d1 == cprid && hslb == 1 && m_on_3d1) {
404 e_mdl = e_3d1; _nwd = m_nwd_3ds; _scale = m_scale_3ds; _nclk = m_nclk_3ds; _hdr_nwd = m_hdr_nwd_3d1;
405 }
else if (m_cpr_3d2 == cprid && hslb == 0 && m_on_3d2) {
406 e_mdl = e_3d2; _nwd = m_nwd_3ds; _scale = m_scale_3ds; _nclk = m_nclk_3ds; _hdr_nwd = m_hdr_nwd_3d2;
407 }
else if (m_cpr_3d3 == cprid && hslb == 1 && m_on_3d3) {
408 e_mdl = e_3d3; _nwd = m_nwd_3ds; _scale = m_scale_3ds; _nclk = m_nclk_3ds; _hdr_nwd = m_hdr_nwd_3d3;
409 }
else if (m_cpr_nn0 == cprid && hslb == 0 && m_on_nn0) {
410 e_mdl = e_nn0; _nwd = m_nwd_nns; _scale = m_scale_nns; _nclk = m_nclk_nns; _hdr_nwd = m_hdr_nwd_nn0;
411 }
else if (m_cpr_nn1 == cprid && hslb == 1 && m_on_nn1) {
412 e_mdl = e_nn1; _nwd = m_nwd_nns; _scale = m_scale_nns; _nclk = m_nclk_nns; _hdr_nwd = m_hdr_nwd_nn1;
413 }
else if (m_cpr_nn2 == cprid && hslb == 0 && m_on_nn2) {
414 e_mdl = e_nn2; _nwd = m_nwd_nns; _scale = m_scale_nns; _nclk = m_nclk_nns; _hdr_nwd = m_hdr_nwd_nn2;
415 }
else if (m_cpr_nn3 == cprid && hslb == 1 && m_on_nn3) {
416 e_mdl = e_nn3; _nwd = m_nwd_nns; _scale = m_scale_nns; _nclk = m_nclk_nns; _hdr_nwd = m_hdr_nwd_nn3;
417 }
else if (m_cpr_sl0 == cprid && hslb == 0 && m_on_sl0) {
418 e_mdl = e_sl0; _nwd = m_nwd_sl0; _scale = m_scale_sl0; _nclk = m_nclk_sl0; _hdr_nwd = m_hdr_nwd_sl0;
419 }
else if (m_cpr_sl1 == cprid && hslb == 0 && m_on_sl1) {
420 e_mdl = e_sl1; _nwd = m_nwd_sl1; _scale = m_scale_sl1; _nclk = m_nclk_sl1; _hdr_nwd = m_hdr_nwd_sl1;
421 }
else if (m_cpr_sl2 == cprid && hslb == 0 && m_on_sl2) {
422 e_mdl = e_sl2; _nwd = m_nwd_sl2; _scale = m_scale_sl2; _nclk = m_nclk_sl2; _hdr_nwd = m_hdr_nwd_sl2;
423 }
else if (m_cpr_sl3 == cprid && hslb == 1 && m_on_sl3) {
424 e_mdl = e_sl3; _nwd = m_nwd_sl3; _scale = m_scale_sl3; _nclk = m_nclk_sl3; _hdr_nwd = m_hdr_nwd_sl3;
425 }
else if (m_cpr_sl4 == cprid && hslb == 1 && m_on_sl4) {
426 e_mdl = e_sl4; _nwd = m_nwd_sl4; _scale = m_scale_sl4; _nclk = m_nclk_sl4; _hdr_nwd = m_hdr_nwd_sl4;
427 }
else if (m_cpr_sl5 == cprid && hslb == 1 && m_on_sl5) {
428 e_mdl = e_sl5; _nwd = m_nwd_sl5; _scale = m_scale_sl5; _nclk = m_nclk_sl5; _hdr_nwd = m_hdr_nwd_sl5;
429 }
else if (m_cpr_sl6 == cprid && hslb == 0 && m_on_sl6) {
430 e_mdl = e_sl6; _nwd = m_nwd_sl6; _scale = m_scale_sl6; _nclk = m_nclk_sl6; _hdr_nwd = m_hdr_nwd_sl6;
431 }
else if (m_cpr_sl8 == cprid && hslb == 0 && m_on_sl8) {
432 e_mdl = e_sl8; _nwd = m_nwd_sl8; _scale = m_scale_sl8; _nclk = m_nclk_sl8; _hdr_nwd = m_hdr_nwd_sl8;
433 }
else if (m_cpr_etf == cprid && hslb == 1 && m_on_etf) {
434 e_mdl = e_etf; _nwd = m_nwd_etf; _scale = m_scale_etf; _nclk = m_nclk_etf; _hdr_nwd = m_hdr_nwd_etf;
435 }
else if (m_cpr_top == cprid && hslb == 0 && m_on_top) {
436 e_mdl = e_top; _nwd = m_nwd_top; _scale = m_scale_top; _nclk = m_nclk_top; _hdr_nwd = m_hdr_nwd_top;
441 unsigned nword = raw_trgarray[i]->GetDetectorNwords(j, hslb);
442 int* buf = raw_trgarray[i]->GetDetectorBuffer(j, hslb);
444 if (nword > 0) buf0 = (unsigned)buf[0];
446 if (nword > 1) buf1 = (unsigned)buf[1];
448 if (nword > 2) buf2 = (unsigned)buf[2];
449 unsigned buf2cnttrg20 = (buf2 >> 12) & 0xfffff;
450 unsigned buf2rvc12 = (buf2 & 0xfff);
454 m_cntr_nwe_badnwd[e_mdl]++;
455 printf(
"ah:%s(0x%x%c) exp(%d), run(%d), eve(%u), eve(0x%x), nword(%u), ",
456 moduleNames[e_mdl], cprid,
'a' + hslb, _exp, _run, _eve, _eve, nword);
457 printf(
"buf0(0x%x), buf1(0x%x), buf2(0x%x)\n", buf0, buf1, buf2);
459 }
else if (nword == _hdr_nwd) {
461 if (gdlrvc12 != buf2rvc12) {
462 printf(
"ai:%s(0x%x%c) exp(%d), run(%d), eve(%u,0x%x), nword(%u), gdlrvc12(0x%x), buf2rvc12(0x%x)\n",
463 moduleNames[e_mdl], cprid,
'a' + hslb, _exp, _run, _eve, _eve, nword, gdlrvc12, buf2rvc12);
464 m_cntr_nw3_badrvc[e_mdl]++;
465 }
else if (eve20 != buf2cnttrg20) {
466 printf(
"aj:%s(0x%x%c) exp(%d), run(%d), eve(%u,0x%x), nword(%u), cnttrg20(0x%x)\n",
467 moduleNames[e_mdl], cprid,
'a' + hslb, _exp, _run, _eve, _eve, nword, buf2cnttrg20);
468 m_cntr_nw3_badtrg[e_mdl]++;
469 }
else if ((_eve % _scale) == 0) {
470 m_cntr_nw3_badvet[e_mdl]++;
475 }
else if (nword != _nwd) {
477 printf(
"bo:wrong nword: %s(0x%x%c) exp(%d), run(%d), eve(%u,0x%x), nword(%u), buf0(0x%x), buf2(0x%x)\n",
478 moduleNames[e_mdl], cprid,
'a' + hslb, _exp, _run, _eve, _eve, nword, buf0, buf2);
479 m_cntr_nwe_badnwd[e_mdl]++;
483 unsigned buf3 = (unsigned)buf[_hdr_nwd];
484 unsigned buf3dddd = ((buf3 >> 16) & 0xffff);
485 unsigned buf4 = (unsigned)buf[_hdr_nwd + 1];
486 unsigned buf5 = (unsigned)buf[_hdr_nwd + 2];
487 unsigned wdperclk = (_nwd - _hdr_nwd) / _nclk;
489 unsigned ibuf_lastclk_msw = _nwd - wdperclk;
491 unsigned buf_lastclk_msw2 = (unsigned)buf[ibuf_lastclk_msw + 1];
492 unsigned buf_lastclk_msw3 = (unsigned)buf[ibuf_lastclk_msw + 2];
494 unsigned datacnttrg32 = 0;
495 unsigned buf4_msb16 = (buf4 & 0xffff);
496 unsigned buf5_lsb16 = ((buf5 >> 16) & 0xffff);
499 printf(
"af:Debug0: %s(0x%x%c) exp(%d), run(%d), eve(%u), eve(0x%x), nword(%u)\n",
500 moduleNames[e_mdl], cprid,
'a' + hslb, _exp, _run, _eve, _eve, nword);
510 if ((0x11000009 == cprid && hslb == 0) ||
511 (0x11000008 == cprid && hslb == 1) ||
512 (0x11000009 == cprid && hslb == 1)
523 }
else if ((0x11000007 == cprid && hslb == 0) ||
524 (0x11000007 == cprid && hslb == 1) ||
525 (0x1100000a == cprid && hslb == 0)
536 datacnttrg32 = (buf4_msb16 << 16) + buf5_lsb16;
538 }
else if ((m_cpr_2d0 == cprid && hslb == 0 && m_on_2d0) ||
539 (m_cpr_2d1 == cprid && hslb == 1 && m_on_2d1) ||
540 (m_cpr_2d2 == cprid && hslb == 0 && m_on_2d2) ||
541 (m_cpr_2d3 == cprid && hslb == 1 && m_on_2d3)) {
546 unsigned buf_lastclk_lsb = (unsigned)buf[_nwd - 1];
547 unsigned buf_lastclk_lsb2 = (unsigned)buf[_nwd - 2];
551 datacnttrg32 = ((buf_lastclk_lsb2 & 0xff) << 24) + (buf_lastclk_lsb >> 8);
553 }
else if ((m_cpr_3d0 == cprid && hslb == 0 && m_on_3d0) ||
554 (m_cpr_3d1 == cprid && hslb == 1 && m_on_3d1) ||
555 (m_cpr_3d2 == cprid && hslb == 0 && m_on_3d2) ||
556 (m_cpr_3d3 == cprid && hslb == 1 && m_on_3d3)) {
566 unsigned datacnttrg_msb16 = (buf_lastclk_msw2 & 0xffff);
567 unsigned datacnttrg_lsb16 = ((buf_lastclk_msw3 >> 16) & 0xffff);
568 datacnttrg32 = (datacnttrg_msb16 << 16) + datacnttrg_lsb16;
570 }
else if ((m_cpr_nn0 == cprid && hslb == 0 && m_on_nn0) ||
571 (m_cpr_nn1 == cprid && hslb == 1 && m_on_nn1) ||
572 (m_cpr_nn2 == cprid && hslb == 0 && m_on_nn2) ||
573 (m_cpr_nn3 == cprid && hslb == 1 && m_on_nn3)) {
595 unsigned datacnttrg_msb16 = (buf_lastclk_msw2 & 0xffff);
596 unsigned datacnttrg_lsb16 = ((buf_lastclk_msw3 >> 16) & 0xffff);
597 datacnttrg32 = (datacnttrg_msb16 << 16) + datacnttrg_lsb16;
598 }
else if (m_cpr_top == cprid && hslb == 0 && m_on_top) {
602 bool something_bad =
false;
603 h_0->SetBinContent(4 * e_mdl + 1, _nclk, buf2cnttrg20);
604 h_0->SetBinContent(4 * e_mdl + 2, _nclk, datacnttrg32);
605 h_0->SetBinContent(4 * e_mdl + 3, _nclk, buf2rvc12);
606 if (gdlrvc12 != buf2rvc12) {
607 printf(
"ba:%s(0x%x%c) exp(%d), run(%d), eve(%u,0x%x), nword(%u), gdlrvc12(0x%x), buf2rvc12(0x%x)\n",
608 moduleNames[e_mdl], cprid,
'a' + hslb, _exp, _run, _eve, _eve, nword, gdlrvc12, buf2rvc12);
609 m_cntr_nwn_badrvc[e_mdl]++;
610 something_bad =
true;
612 if (buf3dddd == 0xbbbb) {
613 m_cntr_nwn_badbbb[e_mdl]++;
614 printf(
"bv:%s(0x%x%c) exp(%d), run(%d), eve(%u,0x%x), nword(%u), cnttrg20(0x%x), dddd(0x%x), datacnttrg32(0x%x)\n",
615 moduleNames[e_mdl], cprid,
'a' + hslb, _exp, _run, _eve, _eve, nword, buf2cnttrg20, buf3dddd, datacnttrg32);
616 something_bad =
true;
618 if (buf3dddd != 0xdddd) {
619 m_cntr_nwn_badddd[e_mdl]++;
620 printf(
"bb:%s(0x%x%c) exp(%d), run(%d), eve(%u,0x%x), nword(%u), cnttrg20(0x%x), dddd(0x%x), datacnttrg32(0x%x)\n",
621 moduleNames[e_mdl], cprid,
'a' + hslb, _exp, _run, _eve, _eve, nword, buf2cnttrg20, buf3dddd, datacnttrg32);
622 something_bad =
true;
624 if (datacnttrg32 + 1 != _eve) {
626 (m_cpr_top == cprid) ||
627 (m_cpr_3d0 <= cprid && cprid <= m_cpr_3d3)
630 printf(
"bc:%s(0x%x%c) exp(%d), run(%d), eve(%u,0x%x), nword(%u), cnttrg20(0x%x), dddd(0x%x), datacnttrg32(0x%x)\n",
631 moduleNames[e_mdl], cprid,
'a' + hslb, _exp, _run, _eve, _eve, nword, buf2cnttrg20, buf3dddd, datacnttrg32);
632 m_cntr_nwn_badtrg[e_mdl]++;
633 something_bad =
true;
636 if (! something_bad) m_cntr_nwn[e_mdl]++;
643 for (
int i = 0; i < raw_trgarray.
getEntries(); i++) {
644 for (
int j = 0; j < raw_trgarray[i]->GetNumEntries(); j++) {
645 unsigned cprid = raw_trgarray[i]->GetNodeID(j);
648 unsigned _eveRaw = raw_trgarray[i]->GetEveNo(j);
649 if ((0x11000001 <= cprid && cprid <= 0x1100000a) ||
650 (0x15000001 <= cprid && cprid <= 0x15000002) ||
651 (0x12000001 == cprid)
656 for (
int hslb = 0; hslb < 2; hslb++) {
657 int nclks = m_nclk_cdctrg;
658 unsigned _hdr_nwd = 3;
661 if (m_cpr_top == cprid && hslb == 0 && m_on_top) {
662 e_mdl = e_top; _nwd = m_nwd_top;
663 nclks = m_nclk_top; _hdr_nwd = m_hdr_nwd_top;
664 }
else if (m_cpr_2d0 == cprid && hslb == 0 && m_on_2d0) {
665 e_mdl = e_2d0; _nwd = m_nwd_2ds; _hdr_nwd = m_hdr_nwd_2d0;
666 }
else if (m_cpr_2d1 == cprid && hslb == 1 && m_on_2d1) {
667 e_mdl = e_2d1; _nwd = m_nwd_2ds; _hdr_nwd = m_hdr_nwd_2d1;
668 }
else if (m_cpr_2d2 == cprid && hslb == 0 && m_on_2d2) {
669 e_mdl = e_2d2; _nwd = m_nwd_2ds; _hdr_nwd = m_hdr_nwd_2d2;
670 }
else if (m_cpr_2d3 == cprid && hslb == 1 && m_on_2d3) {
671 e_mdl = e_2d3; _nwd = m_nwd_2ds; _hdr_nwd = m_hdr_nwd_2d3;
672 }
else if (m_cpr_3d0 == cprid && hslb == 0 && m_on_3d0) {
673 e_mdl = e_3d0; _nwd = m_nwd_3ds; _hdr_nwd = m_hdr_nwd_3d0;
674 }
else if (m_cpr_3d1 == cprid && hslb == 1 && m_on_3d1) {
675 e_mdl = e_3d1; _nwd = m_nwd_3ds; _hdr_nwd = m_hdr_nwd_3d1;
676 }
else if (m_cpr_3d2 == cprid && hslb == 0 && m_on_3d2) {
677 e_mdl = e_3d2; _nwd = m_nwd_3ds; _hdr_nwd = m_hdr_nwd_3d2;
678 }
else if (m_cpr_3d3 == cprid && hslb == 1 && m_on_3d3) {
679 e_mdl = e_3d3; _nwd = m_nwd_3ds; _hdr_nwd = m_hdr_nwd_3d3;
680 }
else if (m_cpr_nn0 == cprid && hslb == 0 && m_on_nn0) {
681 e_mdl = e_nn0; _nwd = m_nwd_nns; _hdr_nwd = m_hdr_nwd_nn0;
682 }
else if (m_cpr_nn1 == cprid && hslb == 1 && m_on_nn1) {
683 e_mdl = e_nn1; _nwd = m_nwd_nns; _hdr_nwd = m_hdr_nwd_nn1;
684 }
else if (m_cpr_nn2 == cprid && hslb == 0 && m_on_nn2) {
685 e_mdl = e_nn2; _nwd = m_nwd_nns; _hdr_nwd = m_hdr_nwd_nn2;
686 }
else if (m_cpr_nn3 == cprid && hslb == 1 && m_on_nn3) {
687 e_mdl = e_nn3; _nwd = m_nwd_nns; _hdr_nwd = m_hdr_nwd_nn3;
688 }
else if (m_cpr_sl0 == cprid && hslb == 0 && m_on_sl0) {
689 e_mdl = e_sl0; _nwd = m_nwd_sl0; _hdr_nwd = m_hdr_nwd_sl0;
690 }
else if (m_cpr_sl1 == cprid && hslb == 0 && m_on_sl1) {
691 e_mdl = e_sl1; _nwd = m_nwd_sl1; _hdr_nwd = m_hdr_nwd_sl1;
692 }
else if (m_cpr_sl2 == cprid && hslb == 0 && m_on_sl2) {
693 e_mdl = e_sl2; _nwd = m_nwd_sl2; _hdr_nwd = m_hdr_nwd_sl2;
694 }
else if (m_cpr_sl3 == cprid && hslb == 1 && m_on_sl3) {
695 e_mdl = e_sl3; _nwd = m_nwd_sl3; _hdr_nwd = m_hdr_nwd_sl3;
696 }
else if (m_cpr_sl4 == cprid && hslb == 1 && m_on_sl4) {
697 e_mdl = e_sl4; _nwd = m_nwd_sl4; _hdr_nwd = m_hdr_nwd_sl4;
698 }
else if (m_cpr_sl5 == cprid && hslb == 1 && m_on_sl5) {
699 e_mdl = e_sl5; _nwd = m_nwd_sl5; _hdr_nwd = m_hdr_nwd_sl5;
700 }
else if (m_cpr_sl6 == cprid && hslb == 0 && m_on_sl6) {
701 e_mdl = e_sl6; _nwd = m_nwd_sl6; _hdr_nwd = m_hdr_nwd_sl6;
702 }
else if (m_cpr_sl8 == cprid && hslb == 0 && m_on_sl8) {
703 e_mdl = e_sl8; _nwd = m_nwd_sl8; _hdr_nwd = m_hdr_nwd_sl8;
704 }
else if (m_cpr_etf == cprid && hslb == 1 && m_on_etf) {
705 e_mdl = e_etf; _nwd = m_nwd_etf; _hdr_nwd = m_hdr_nwd_etf;
706 }
else if (m_cpr_gdl == cprid && hslb == 0 && m_on_gdl) {
707 e_mdl = e_gdl; _nwd = m_nwd_gdl;
708 nclks = m_nclk_gdl; _hdr_nwd = 6;
712 unsigned nword = raw_trgarray[i]->GetDetectorNwords(j, hslb);
713 if (nword == _hdr_nwd)
continue;
715 printf(
"bu:Nword mismatch:nword(%u),expected(%u). eve(%u), %s(0x%x%c), nword(%u)\n",
716 nword, _nwd, _eveRaw, moduleNames[e_mdl], cprid,
'a' + hslb, nword);
718 int* buf = raw_trgarray[i]->GetDetectorBuffer(j, hslb);
719 int i47 = _hdr_nwd + (nclks - 1) * (_nwd - _hdr_nwd) / nclks;
720 if (i47 >
int(nword) - 1) {
721 if (m_print_clkcyc_err)
722 printf(
"bp:data truncation. eve(%u), %s(0x%x%c), nword(%u)\n",
723 _eveRaw, moduleNames[e_mdl], cprid,
'a' + hslb, nword);
726 unsigned buf47 = buf[i47];
727 bool break_this_module =
false;
728 bool cc_disorder =
false;
730 unsigned prev_cc = buf47 & 0xffff;
731 if (e_mdl == e_gdl) {
732 prev_cc = (buf47 >> 4) & 0xfff;
735 sprintf(ccc,
"i47(%d),buf47(0x%x),%x", i47, buf47, prev_cc);
736 std::string ccs(ccc);
737 for (
int clk = 0; clk < nclks; clk++) {
738 unsigned ibuf = _hdr_nwd + clk * (nword - _hdr_nwd) / nclks;
739 if (ibuf > nword - 1) {
740 if (m_print_clkcyc_err)
741 printf(
"bq:data truncation. eve(%u), %s(0x%x%c), nword(%u)\n",
742 _eveRaw, moduleNames[e_mdl], cprid,
'a' + hslb, nword);
743 break_this_module =
true;
744 m_cntr_bad_nwd[e_mdl]++;
747 unsigned ddddcc = buf[ibuf];
748 unsigned dddd = (ddddcc >> 16) & 0xffff;
749 unsigned cc = ddddcc & 0xffff;
750 if (e_mdl == e_gdl) {
751 cc = (ddddcc >> 4) & 0xfff;
753 h_0->SetBinContent(4 * e_mdl + 4, clk + 1, cc);
754 sprintf(ccc,
",%x", cc);
755 if ((
int)e_2d0 <= (
int)e_mdl && (
int)e_mdl <= (
int)e_2d3 &&
768 int i_addr = ibuf + 79;
769 int val_addr = buf[i_addr];
770 int addr_o = (val_addr >> 8) & 0xff;
771 int addr_i = val_addr & 0xff;
772 sprintf(ccc,
",%x(%d,%d)", cc, addr_i, addr_o);
775 if (e_mdl == e_gdl) {
776 dddd = (ddddcc >> 24);
778 if (m_print_clkcyc_err)
779 printf(
"br:dddd not found. eve(%u), %s(0x%x%c), nword(%u)\n",
780 _eveRaw, moduleNames[e_mdl], cprid,
'a' + hslb, nword);
781 break_this_module =
true;
782 m_cntr_bad_ddd[e_mdl]++;
785 }
else if (dddd != 0xdddd) {
786 if (m_print_clkcyc_err)
787 printf(
"bs:dddd not found. eve(%u), %s(0x%x%c), nword(%u)\n",
788 _eveRaw, moduleNames[e_mdl], cprid,
'a' + hslb, nword);
789 break_this_module =
true;
790 m_cntr_bad_ddd[e_mdl]++;
794 if (!(cc == prev_cc + 4 || prev_cc == cc + 4 * (nclks - 1) || prev_cc + 0x500 == cc + 4 * (nclks - 1)
795 || cc + 0x500 == prev_cc + 4)) {
801 if (break_this_module)
continue;
803 m_cntr_bad_odr[e_mdl]++;
805 printf(
"bt:ccdisorder: eve(%u), %s(0x%x%c), nword(%u), %s\n",
806 _eveRaw, moduleNames[e_mdl], cprid,
'a' + hslb, nword, ccs.c_str());
809 m_cntr_good_odr[e_mdl]++;
816 if (! m_histRecord) {