41 <<
"\n Unable to unpack Tower block for event "<<
event_->
l1A()<<
" in fed "<<activeDCC
42 <<
"\n The end of event was reached " 43 <<
"\n(or, previously, pointers intended to navigate outside of FedBlock (based on block sizes), and were stopped by setting dwToEnd_ to zero)" ;
74 expTowerID_ <= mapper_->getNumChannelsInDcc(activeDCC) ){
79 <<
" => Skipping to next FE block...";
95 <<
"\n the FE_id found: "<<
towerId_<<
" exceeds max number of FE foreseen in fed" 96 <<
"\n => Skipping to next FE block...";
114 <<
"Synchronization error for Tower Block" 116 <<
" dccBx = " << dccBx <<
" bx_ = " <<
bx_ <<
" dccL1 = " << dccL1 <<
" l1_ = " <<
l1_ <<
"\n" 117 <<
" => Skipping to next tower block";
132 <<
"\n => Skipping to next tower block...";
147 <<
"\n Only "<<((*dwToEnd_)*8)<<
" bytes are available while "<<
blockSize_<<
" are needed!" 148 <<
"\n => Skipping to next fed block...";
162 <<
"\n => Skipping to next fed block...";
182 <<
"\n => Keeps unpacking as the unpacker was forced to keep FR data (by configuration) ...";
194 <<
"\n => Skipping to next fed block...";
220 unsigned int expStripID(0), expXtalID(0);
224 int statusUnpackXtal =0;
226 for(
unsigned int numbXtal=1; numbXtal <= numbOfXtalBlocks && statusUnpackXtal!=
SKIP_BLOCK_UNPACKING; numbXtal++){
230 expStripID = ( numbXtal-1)/5 + 1;
231 expXtalID = numbXtal - (expStripID-1)*5;
240 <<
"\n The tower "<<
towerId_<<
" won't be unpacked further";
256 o<<
"\n Unpacked Info for DCC Tower Block" 257 <<
"\n DW1 ============================="
std::unique_ptr< EcalElectronicsIdCollection > * invalidTTIds_
bool isSynced(const unsigned int dccBx, const unsigned int bx, const unsigned int dccL1, const unsigned int l1, const BlockType type, const unsigned int fov)
std::unique_ptr< EcalElectronicsIdCollection > * invalidBlockLengths_
std::unique_ptr< EcalElectronicsIdCollection > * invalidBlockLengthsCollection()
unsigned int getActiveDCC()
unsigned int xtalBlockSize_
unsigned int getNumChannelsInDcc(unsigned int aDCCId)
int unpack(const uint64_t **data, unsigned int *dwToEnd, bool zs, unsigned int expectedTowerID)
virtual void fillEcalElectronicsError(std::unique_ptr< EcalElectronicsIdCollection > *)
DCCFEBlock(DCCDataUnpacker *u, EcalElectronicsMapper *m, DCCEventBlock *e, bool unpack, bool forceToKeepFRdata)
virtual void updateCollectors()
std::unique_ptr< EcalElectronicsIdCollection > * invalidTTIdsCollection()
static std::atomic< bool > silentMode_
unsigned int blockLength_
void setFESyncNumbers(short l1, short bx, short id)
unsigned int numbXtalTSamples()
unsigned long long uint64_t
unsigned int expXtalTSamples_
std::unique_ptr< EcalElectronicsIdCollection > * invalidZSXtalIdsCollection()
unsigned int lastStripId_
DCCDataUnpacker * unpacker_
unsigned int getUnfilteredTowerBlockLength()
virtual int unpackXtalData(unsigned int stripID, unsigned int xtalID)
char data[epos_bytes_allocation]
short getHLTChannel(int channel)
virtual void updateEventPointers()
unsigned int numbDWInXtalBlock_
unsigned int unfilteredDataBlockLength_
EcalElectronicsMapper * mapper_
std::unique_ptr< EcalElectronicsIdCollection > * invalidZSXtalIds_
unsigned int getActiveSM()
void display(std::ostream &o)