CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
DCCSRPBlock.cc
Go to the documentation of this file.
1 #include "DCCSRPBlock.h"
2 #include "DCCDataParser.h"
3 #include "DCCDataMapper.h"
4 #include "DCCEventBlock.h"
5 
7  DCCTBEventBlock * dccBlock,
9  uint32_t * buffer,
10  uint32_t numbBytes,
11  uint32_t wordsToEnd,
12  uint32_t wordEventOffset
13 ) : DCCTBBlockPrototype(parser,"SRP", buffer, numbBytes,wordsToEnd,wordEventOffset), dccBlock_(dccBlock){
14 
15  //Reset error counters ///////
16  errors_["SRP::HEADER"] = 0;
17  errors_["SRP::BLOCKID"] = 0;
19 
20  // Get data fields from the mapper and retrieve data /////////////////////////////////////
21  if( parser_->numbSRF() == 68){ mapperFields_ = parser_->mapper()->srp68Fields();}
22  else if( parser_->numbSRF() == 32){ mapperFields_ = parser_->mapper()->srp32Fields();}
23  else if( parser_->numbSRF() == 16){ mapperFields_ = parser_->mapper()->srp16Fields();}
24  parseData();
26 
27  // check internal data ////////////
28  if(parser_->debug()){ dataCheck();}
30 
31 }
32 
33 
34 
36 
37  std::string checkErrors("");
38 
39  std::pair <bool,std::string> res;
40 
41  res = checkDataField("BX", BXMASK & (dccBlock_->getDataField("BX")));
42  if(!res.first){ checkErrors += res.second; (errors_["SRP::HEADER"])++; }
43  res = checkDataField("LV1", L1MASK & (dccBlock_->getDataField("LV1")));
44  if(!res.first){ checkErrors += res.second; (errors_["SRP::HEADER"])++; }
45 
46 
47  res = checkDataField("SRP ID",parser_->srpId());
48  if(!res.first){ checkErrors += res.second; (errors_["SRP::HEADER"])++; }
49 
50 
51  if(checkErrors!=""){
52  errorString_ +="\n ======================================================================\n";
53  errorString_ += std::string(" ") + name_ + std::string(" data fields checks errors : ") ;
54  errorString_ += checkErrors ;
55  errorString_ += "\n ======================================================================";
56  blockError_ = true;
57  }
58 
59 
60 }
61 
62 
63 void DCCTBSRPBlock::increment(uint32_t numb){
65  else {
66  for(uint32_t counter=0; counter<numb; counter++, dataP_++,wordCounter_++){
67  uint32_t blockID = (*dataP_)>>BPOSITION_BLOCKID;
68  if( blockID != BLOCKID ){
69  (errors_["SRP::BLOCKID"])++;
70  //errorString_ += std::string("\n") + parser_->index(nunb)+(" blockId has value ") + parser_->getDecString(blockID);
71  //errorString += std::string(", while ")+parser_->getDecString(BLOCKID)+std::string(" is expected");
72  }
73  }
74  }
75 
76 
77 }
78 
79 
virtual std::pair< bool, std::string > checkDataField(std::string name, uint32_t data)
virtual uint32_t getDataField(std::string name)
std::set< DCCTBDataField *, DCCTBDataFieldComparator > * mapperFields_
virtual void increment(uint32_t numb, std::string msg="")
std::set< DCCTBDataField *, DCCTBDataFieldComparator > * srp32Fields()
virtual void parseData()
DCCTBDataParser * parser_
void increment(uint32_t numb)
Definition: DCCSRPBlock.cc:63
DCCTBSRPBlock(DCCTBEventBlock *dccBlock, DCCTBDataParser *parser, uint32_t *buffer, uint32_t numbBytes, uint32_t wordsToEnd, uint32_t wordEventOffset)
Definition: DCCSRPBlock.cc:6
DCCTBEventBlock * dccBlock_
Definition: DCCSRPBlock.h:49
void dataCheck()
Definition: DCCSRPBlock.cc:35
DCCTBDataMapper * mapper()
std::map< std::string, uint32_t > errors_
uint32_t numbSRF()
std::set< DCCTBDataField *, DCCTBDataFieldComparator > * srp16Fields()
uint32_t srpId()
static std::atomic< unsigned int > counter
std::set< DCCTBDataField *, DCCTBDataFieldComparator > * srp68Fields()