CMS 3D CMS Logo

List of all members | Public Member Functions | Private Member Functions | Private Attributes
FRDStreamSource Class Reference

#include <FRDStreamSource.h>

Inheritance diagram for FRDStreamSource:
edm::ProducerSourceFromFiles edm::ProducerSourceBase edm::FromFiles edm::IDGeneratorSourceBase< PuttableSourceBase > edm::PuttableSourceBase edm::InputSource edm::ProducerBase edm::ProductRegistryHelper

Public Member Functions

 FRDStreamSource (edm::ParameterSet const &pset, edm::InputSourceDescription const &desc)
 
 ~FRDStreamSource () override
 
- Public Member Functions inherited from edm::ProducerSourceFromFiles
InputFileCatalogcatalog ()
 
std::vector< std::string > fileNames (unsigned iCatalog) const
 
std::vector< std::string > const & logicalFileNames () const
 
 ProducerSourceFromFiles (ParameterSet const &pset, InputSourceDescription const &desc, bool realData)
 
 ~ProducerSourceFromFiles () override
 
- Public Member Functions inherited from edm::ProducerSourceBase
 ProducerSourceBase (ParameterSet const &pset, InputSourceDescription const &desc, bool realData)
 
 ~ProducerSourceBase () noexcept(false) override
 
- Public Member Functions inherited from edm::IDGeneratorSourceBase< PuttableSourceBase >
EventNumber_t event () const
 
unsigned int eventCreationDelay () const
 
EventID const & eventID () const
 
 IDGeneratorSourceBase (ParameterSet const &pset, InputSourceDescription const &desc, bool realData)
 
LuminosityBlockNumber_t luminosityBlock () const
 
unsigned int numberEventsInLumi () const
 
unsigned int numberEventsInRun () const
 
unsigned int numberEventsInThisLumi () const
 
unsigned int numberEventsInThisRun () const
 
TimeValue_t presentTime () const
 
RunNumber_t run () const
 
unsigned int timeBetweenEvents () const
 
 ~IDGeneratorSourceBase () noexcept(false) override
 
- Public Member Functions inherited from edm::PuttableSourceBase
bool hasAbilityToProduceInBeginLumis () const final
 
bool hasAbilityToProduceInBeginRuns () const final
 
PuttableSourceBaseoperator= (const PuttableSourceBase &)=delete
 
 PuttableSourceBase (ParameterSet const &, InputSourceDescription const &)
 
 PuttableSourceBase (const PuttableSourceBase &)=delete
 
void registerProducts (ProducerBase *, ProductRegistry *, ModuleDescription const &)
 
void registerProducts () final
 Register any produced products. More...
 
void resolvePutIndicies (BranchType iBranchType, ModuleToResolverIndicies const &iIndicies, std::string const &moduleLabel)
 
- Public Member Functions inherited from edm::InputSource
std::shared_ptr< ActivityRegistryactReg () const
 Accessor for Activity Registry. More...
 
std::shared_ptr< BranchIDListHelper const > branchIDListHelper () const
 Accessors for branchIDListHelper. More...
 
std::shared_ptr< BranchIDListHelper > & branchIDListHelper ()
 
void closeFile (FileBlock *, bool cleaningUpAfterException)
 close current file More...
 
void doBeginJob ()
 Called by framework at beginning of job. More...
 
void doEndJob ()
 Called by framework at end of job. More...
 
void fillProcessBlockHelper ()
 Fill the ProcessBlockHelper with info for the current file. More...
 
ProcessingController::ForwardState forwardState () const
 
bool goToEvent (EventID const &eventID)
 
 InputSource (ParameterSet const &, InputSourceDescription const &)
 Constructor. More...
 
 InputSource (InputSource const &)=delete
 
void issueReports (EventID const &eventID, StreamID streamID)
 issue an event report More...
 
LuminosityBlockNumber_t luminosityBlock () const
 Accessor for current luminosity block number. More...
 
std::shared_ptr< LuminosityBlockAuxiliaryluminosityBlockAuxiliary () const
 Called by the framework to merge or insert lumi in principal cache. More...
 
int maxEvents () const
 
int maxLuminosityBlocks () const
 
ModuleDescription const & moduleDescription () const
 Accessor for 'module' description. More...
 
ItemTypeInfo nextItemType ()
 Advances the source to the next item. More...
 
bool nextProcessBlock (ProcessBlockPrincipal &)
 Next process block, return false if there is none, sets the processName in the principal. More...
 
InputSourceoperator= (InputSource const &)=delete
 
std::shared_ptr< ProcessBlockHelper const > processBlockHelper () const
 Accessors for processBlockHelper. More...
 
std::shared_ptr< ProcessBlockHelper > & processBlockHelper ()
 
ProcessConfiguration const & processConfiguration () const
 Accessor for Process Configuration. More...
 
std::string const & processGUID () const
 Accessor for global process identifier. More...
 
ProcessHistoryRegistry const & processHistoryRegistry () const
 Accessors for process history registry. More...
 
ProcessHistoryRegistryprocessHistoryRegistry ()
 
ProcessingMode processingMode () const
 RunsLumisAndEvents (default), RunsAndLumis, or Runs. More...
 
std::shared_ptr< ProductRegistry const > productRegistry () const
 Accessors for product registry. More...
 
bool randomAccess () const
 
void readAndMergeLumi (LuminosityBlockPrincipal &lbp)
 Read next luminosity block (same as a prior lumi) More...
 
void readAndMergeRun (RunPrincipal &rp)
 Read next run (same as a prior run) More...
 
void readEvent (EventPrincipal &ep, StreamContext &)
 Read next event. More...
 
bool readEvent (EventPrincipal &ep, EventID const &, StreamContext &)
 Read a specific event. More...
 
std::shared_ptr< FileBlockreadFile ()
 Read next file. More...
 
void readLuminosityBlock (LuminosityBlockPrincipal &lumiPrincipal, HistoryAppender &historyAppender)
 Read next luminosity block (new lumi) More...
 
std::shared_ptr< LuminosityBlockAuxiliaryreadLuminosityBlockAuxiliary ()
 Read next luminosity block Auxilary. More...
 
void readProcessBlock (ProcessBlockPrincipal &)
 Read next process block. More...
 
void readRun (RunPrincipal &runPrincipal, HistoryAppender &historyAppender)
 Read next run (new run) More...
 
std::shared_ptr< RunAuxiliaryreadRunAuxiliary ()
 Read next run Auxiliary. More...
 
ProcessHistoryID const & reducedProcessHistoryID () const
 
int remainingEvents () const
 
int remainingLuminosityBlocks () const
 
void repeat ()
 Reset the remaining number of events/lumis to the maximum number. More...
 
std::pair< SharedResourcesAcquirer *, std::recursive_mutex * > resourceSharedWithDelayedReader ()
 Returns nullptr if no resource shared between the Source and a DelayedReader. More...
 
ProcessingController::ReverseState reverseState () const
 
void rewind ()
 Begin again at the first event. More...
 
RunNumber_t run () const
 Accessor for current run number. More...
 
std::shared_ptr< RunAuxiliaryrunAuxiliary () const
 Called by the framework to merge or insert run in principal cache. More...
 
void setLuminosityBlockNumber_t (LuminosityBlockNumber_t lb)
 Set the luminosity block ID. More...
 
void setRunNumber (RunNumber_t r)
 Set the run number. More...
 
void skipEvents (int offset)
 
void switchTo (std::shared_ptr< ProductRegistry > iOther)
 switch to a different ProductRegistry. More...
 
std::shared_ptr< ThinnedAssociationsHelper const > thinnedAssociationsHelper () const
 Accessors for thinnedAssociationsHelper. More...
 
std::shared_ptr< ThinnedAssociationsHelper > & thinnedAssociationsHelper ()
 
Timestamp const & timestamp () const
 Accessor for the current time, as seen by the input source. More...
 
virtual ~InputSource () noexcept(false)
 Destructor. More...
 
- Public Member Functions inherited from edm::ProducerBase
void callWhenNewProductsRegistered (std::function< void(BranchDescription const &)> const &func)
 
std::vector< edm::ProductResolverIndex > const & indiciesForPutProducts (BranchType iBranchType) const
 
 ProducerBase ()
 
std::vector< edm::ProductResolverIndex > const & putTokenIndexToProductResolverIndex () const
 
std::vector< bool > const & recordProvenanceList () const
 
void registerProducts (ProducerBase *, ProductRegistry *, ModuleDescription const &)
 
std::function< void(BranchDescription const &)> registrationCallback () const
 used by the fwk to register list of products More...
 
void resolvePutIndicies (BranchType iBranchType, ModuleToResolverIndicies const &iIndicies, std::string const &moduleLabel)
 
TypeLabelList const & typeLabelList () const
 used by the fwk to register the list of products of this module More...
 
 ~ProducerBase () noexcept(false) override
 

Private Member Functions

bool openFile (const std::string &fileName)
 
void produce (edm::Event &e) override
 
bool setRunAndEventInfo (edm::EventID &id, edm::TimeValue_t &theTime, edm::EventAuxiliary::ExperimentType &eType) override
 

Private Attributes

std::vector< char > buffer_
 
uint16_t detectedFRDversion_ = 0
 
std::vector< std::string >::const_iterator endFileName_
 
std::vector< std::string > fileNames_
 
std::ifstream fin_
 
uint16_t flags_ = 0
 
std::vector< std::string >::const_iterator itFileName_
 
std::unique_ptr< FEDRawDataCollectionrawData_
 
const bool useL1EventID_
 
const bool verifyAdler32_
 
const bool verifyChecksum_
 

Additional Inherited Members

- Public Types inherited from edm::InputSource
enum  ItemPosition : char { ItemPosition::Invalid, ItemPosition::LastItemToBeMerged, ItemPosition::NotLastItemToBeMerged }
 
enum  ItemType : char {
  ItemType::IsInvalid, ItemType::IsStop, ItemType::IsFile, ItemType::IsRun,
  ItemType::IsLumi, ItemType::IsEvent, ItemType::IsRepeat, ItemType::IsSynchronize
}
 
enum  ProcessingMode { Runs, RunsAndLumis, RunsLumisAndEvents }
 
- Public Types inherited from edm::ProducerBase
template<typename T >
using BranchAliasSetterT = ProductRegistryHelper::BranchAliasSetterT< T >
 
using ModuleToResolverIndicies = std::unordered_multimap< std::string, std::tuple< edm::TypeID const *, const char *, edm::ProductResolverIndex > >
 
typedef ProductRegistryHelper::TypeLabelList TypeLabelList
 
- Static Public Member Functions inherited from edm::ProducerSourceFromFiles
static void fillDescription (ParameterSetDescription &desc)
 
- Static Public Member Functions inherited from edm::IDGeneratorSourceBase< PuttableSourceBase >
static void fillDescription (ParameterSetDescription &desc)
 
- Static Public Member Functions inherited from edm::InputSource
static const std::string & baseType ()
 
static void fillDescription (ParameterSetDescription &desc)
 
static void fillDescriptions (ConfigurationDescriptions &descriptions)
 
static void prevalidate (ConfigurationDescriptions &)
 
- Public Attributes inherited from edm::InputSource
signalslot::Signal< void(StreamContext const &, ModuleCallingContext const &)> postEventReadFromSourceSignal_
 
signalslot::Signal< void(StreamContext const &, ModuleCallingContext const &)> preEventReadFromSourceSignal_
 
- Protected Member Functions inherited from edm::ProducerSourceFromFiles
void incrementFileIndex ()
 
- Protected Member Functions inherited from edm::IDGeneratorSourceBase< PuttableSourceBase >
void doReadEvent (EventPrincipal &eventPrincipal, F &&f)
 
void doReadEventWithDelayedReader (EventPrincipal &eventPrincipal, ProcessHistoryID const &historyID, EventSelectionIDVector eventSelectionIDs, BranchListIndexes branchListIndexes, DelayedReader *reader)
 
- Protected Member Functions inherited from edm::InputSource
void decreaseRemainingEventsBy (int iSkipped)
 
bool eventCached () const
 
bool newLumi () const
 
bool newRun () const
 
ProcessHistoryRegistryprocessHistoryRegistryForUpdate ()
 
ProductRegistryproductRegistryUpdate ()
 
void reset () const
 
void resetEventCached ()
 
void resetLuminosityBlockAuxiliary (bool isNewLumi=true) const
 
void resetNewLumi ()
 
void resetNewRun ()
 
void resetRunAuxiliary (bool isNewRun=true) const
 
void setEventCached ()
 Called by the framework to merge or ached() const {return eventCached_;}. More...
 
void setLuminosityBlockAuxiliary (LuminosityBlockAuxiliary *lbp)
 
void setNewLumi ()
 
void setNewRun ()
 
void setRunAuxiliary (RunAuxiliary *rp)
 
void setTimestamp (Timestamp const &theTime)
 To set the current time, as seen by the input source. More...
 
ItemTypeInfo state () const
 
- Protected Member Functions inherited from edm::ProducerBase
template<Transition Tr = Transition::Event>
auto produces (std::string instanceName) noexcept
 declare what type of product will make and with which optional label More...
 
template<Transition B>
BranchAliasSetter produces (const TypeID &id, std::string instanceName=std::string(), bool recordProvenance=true)
 
template<BranchType B>
BranchAliasSetter produces (const TypeID &id, std::string instanceName=std::string(), bool recordProvenance=true)
 
BranchAliasSetter produces (const TypeID &id, std::string instanceName=std::string(), bool recordProvenance=true)
 
template<typename ProductType , Transition B>
BranchAliasSetterT< ProductType > produces (std::string instanceName)
 
template<class ProductType >
BranchAliasSetterT< ProductType > produces ()
 
template<typename ProductType , BranchType B>
BranchAliasSetterT< ProductType > produces (std::string instanceName)
 
template<typename ProductType , BranchType B>
BranchAliasSetterT< ProductType > produces ()
 
template<class ProductType >
BranchAliasSetterT< ProductType > produces (std::string instanceName)
 
template<typename ProductType , Transition B>
BranchAliasSetterT< ProductType > produces ()
 
template<Transition Tr = Transition::Event>
auto produces () noexcept
 
ProducesCollector producesCollector ()
 

Detailed Description

Definition at line 20 of file FRDStreamSource.h.

Constructor & Destructor Documentation

◆ FRDStreamSource()

FRDStreamSource::FRDStreamSource ( edm::ParameterSet const &  pset,
edm::InputSourceDescription const &  desc 
)

Definition at line 20 of file FRDStreamSource.cc.

References endFileName_, edm::FromFiles::fileNames(), fileNames_, itFileName_, and openFile().

22  verifyAdler32_(pset.getUntrackedParameter<bool>("verifyAdler32", true)),
23  verifyChecksum_(pset.getUntrackedParameter<bool>("verifyChecksum", true)),
24  useL1EventID_(pset.getUntrackedParameter<bool>("useL1EventID", false)) {
26  endFileName_ = fileNames_.end();
28  produces<FEDRawDataCollection>();
29 }
std::vector< std::string > fileNames_
const bool useL1EventID_
ProducerSourceFromFiles(ParameterSet const &pset, InputSourceDescription const &desc, bool realData)
bool openFile(const std::string &fileName)
std::vector< std::string >::const_iterator itFileName_
const bool verifyChecksum_
std::vector< std::string >::const_iterator endFileName_
const bool verifyAdler32_
std::vector< std::string > fileNames(unsigned iCatalog) const
Definition: FromFiles.h:22

◆ ~FRDStreamSource()

FRDStreamSource::~FRDStreamSource ( )
inlineoverride

Definition at line 24 of file FRDStreamSource.h.

24 {};

Member Function Documentation

◆ openFile()

bool FRDStreamSource::openFile ( const std::string &  fileName)
private

Definition at line 192 of file FRDStreamSource.cc.

References gather_cfg::cout, MillePedeFileConverter_cfg::fileName, fin_, recoMuon::in, hcallasereventfilter2012_cfi::prefix, and AlCaHLTBitMon_QueryRunRegistry::string.

Referenced by FRDStreamSource(), and setRunAndEventInfo().

192  {
193  std::cout << " open file.. " << fileName << std::endl;
194  fin_.close();
195  fin_.clear();
196  size_t pos = fileName.find(':');
197  if (pos != std::string::npos) {
198  std::string prefix = fileName.substr(0, pos);
199  if (prefix != "file")
200  return false;
201  pos++;
202  } else
203  pos = 0;
204 
205  fin_.open(fileName.substr(pos).c_str(), std::ios::in | std::ios::binary);
206  return fin_.is_open();
207 }
std::ifstream fin_

◆ produce()

void FRDStreamSource::produce ( edm::Event e)
overrideprivatevirtual

Implements edm::ProducerSourceBase.

Definition at line 190 of file FRDStreamSource.cc.

References MillePedeFileConverter_cfg::e, eostools::move(), and rawData_.

190 { e.put(std::move(rawData_)); }
std::unique_ptr< FEDRawDataCollection > rawData_
def move(src, dest)
Definition: eostools.py:511

◆ setRunAndEventInfo()

bool FRDStreamSource::setRunAndEventInfo ( edm::EventID id,
edm::TimeValue_t theTime,
edm::EventAuxiliary::ExperimentType eType 
)
overrideprivatevirtual

Implements edm::IDGeneratorSourceBase< PuttableSourceBase >.

Definition at line 31 of file FRDStreamSource.cc.

References cms::cuda::assert(), buffer_, runTheMatrix::const, ALPAKA_ACCELERATOR_NAMESPACE::brokenline::constexpr(), crc32c(), FEDRawData::data(), detectedFRDversion_, endFileName_, evf::evtn::evm_board_sense(), Exception, l1tstage2_dqm_sourceclient-live_cfg::fedId, fin_, flags_, FEDTrailer::fragmentLength(), FRDHeaderMaxVersion, FRDHeaderVersionSize, evf::evtn::get(), getFRDFileHeaderVersion(), evf::evtn::getgpshigh(), evf::evtn::getgpslow(), evf::evtn::gtpe_board_sense(), evf::evtn::gtpe_get(), FRDFileHeaderContent_v1::headerSize_, FRDFileHeaderContent_v2::headerSize_, FRDFileHeaderIdentifier::id_, createfilelist::int, itFileName_, dttmaxenums::L, FEDHeader::length, FEDTrailer::length, FEDNumbering::MAXFEDID, FEDNumbering::MINTCDSuTCAFEDID, FEDNumbering::MINTriggerEGTPFEDID, FEDNumbering::MINTriggerGTPFEDID, openFile(), rawData_, FEDRawData::resize(), FEDHeader::sourceID(), FEDHeader::triggerType(), useL1EventID_, verifyAdler32_, verifyChecksum_, and FRDFileHeaderIdentifier::version_.

33  {
34  if (fin_.peek() == EOF) {
35  if (++itFileName_ == endFileName_) {
36  fin_.close();
37  return false;
38  }
39  if (!openFile(*itFileName_)) {
40  throw cms::Exception("FRDStreamSource::setRunAndEventInfo") << "could not open file " << *itFileName_;
41  }
42  }
43  //look for FRD header at beginning of the file and skip it
44  if (fin_.tellg() == 0) {
45  constexpr size_t buf_sz = sizeof(FRDFileHeaderIdentifier);
46  char hdr[sizeof(FRDFileHeader_v2)];
47  fin_.read(hdr, buf_sz);
48 
49  if (fin_.gcount() == 0)
50  throw cms::Exception("FRDStreamSource::setRunAndEventInfo")
51  << "Unable to read file or empty file" << *itFileName_;
52  else if (fin_.gcount() < (ssize_t)buf_sz) {
53  //no header, very small file, go to event parsing
54  fin_.seekg(0);
55  } else {
57  uint16_t frd_version = getFRDFileHeaderVersion(fileId->id_, fileId->version_);
58 
59  if (frd_version == 1) {
60  constexpr size_t buf_sz_cont = sizeof(FRDFileHeaderContent_v1);
61  fin_.read(hdr, buf_sz_cont);
63  if (fin_.gcount() != buf_sz_cont || fhContent->headerSize_ != sizeof(FRDFileHeader_v1))
64  throw cms::Exception("FRDStreamSource::setRunAndEventInfo")
65  << "Invalid FRD file header (size mismatch) in file " << *itFileName_;
66  } else if (frd_version == 2) {
67  constexpr size_t buf_sz_cont = sizeof(FRDFileHeaderContent_v2);
68  fin_.read(hdr, buf_sz_cont);
70  if (fin_.gcount() != buf_sz_cont || fhContent->headerSize_ != sizeof(FRDFileHeader_v2))
71  throw cms::Exception("FRDStreamSource::setRunAndEventInfo")
72  << "Invalid FRD file header (size mismatch) in file " << *itFileName_;
73  } else if (frd_version > 2) {
74  throw cms::Exception("FRDStreamSource::setRunAndEventInfo") << "Unknown header version " << frd_version;
75  } else {
76  //no header
77  fin_.seekg(0, fin_.beg);
78  }
79  }
80  }
81 
82  if (detectedFRDversion_ == 0) {
83  fin_.read((char*)&detectedFRDversion_, sizeof(uint16_t));
84  fin_.read((char*)&flags_, sizeof(uint16_t));
88  *((uint32_t*)(&buffer_[0])) = detectedFRDversion_;
89  fin_.read(&buffer_[0] + sizeof(uint32_t), FRDHeaderVersionSize[detectedFRDversion_] - sizeof(uint32_t));
90  assert(fin_.gcount() == FRDHeaderVersionSize[detectedFRDversion_] - (unsigned int)(sizeof(uint32_t)));
91  } else {
96  }
97 
98  std::unique_ptr<FRDEventMsgView> frdEventMsg(new FRDEventMsgView(&buffer_[0]));
99  if (useL1EventID_)
100  id = edm::EventID(frdEventMsg->run(), frdEventMsg->lumi(), frdEventMsg->event());
101 
102  const uint32_t totalSize = frdEventMsg->size();
103  if (totalSize > buffer_.size()) {
104  buffer_.resize(totalSize);
105  }
106  if (totalSize > FRDHeaderVersionSize[detectedFRDversion_]) {
109  if (fin_.gcount() != totalSize - FRDHeaderVersionSize[detectedFRDversion_]) {
110  throw cms::Exception("FRDStreamSource::setRunAndEventInfo") << "premature end of file " << *itFileName_;
111  }
112  frdEventMsg = std::make_unique<FRDEventMsgView>(&buffer_[0]);
113  }
114 
115  if (verifyChecksum_ && frdEventMsg->version() >= 5) {
116  uint32_t crc = 0;
117  crc = crc32c(crc, (const unsigned char*)frdEventMsg->payload(), frdEventMsg->eventSize());
118  if (crc != frdEventMsg->crc32c()) {
119  throw cms::Exception("FRDStreamSource::getNextEvent") << "Found a wrong crc32c checksum: expected 0x" << std::hex
120  << frdEventMsg->crc32c() << " but calculated 0x" << crc;
121  }
122  } else if (verifyAdler32_ && frdEventMsg->version() >= 3) {
123  uint32_t adler = adler32(0L, Z_NULL, 0);
124  adler = adler32(adler, (Bytef*)frdEventMsg->payload(), frdEventMsg->eventSize());
125 
126  if (adler != frdEventMsg->adler32()) {
127  throw cms::Exception("FRDStreamSource::setRunAndEventInfo")
128  << "Found a wrong Adler32 checksum: expected 0x" << std::hex << frdEventMsg->adler32() << " but calculated 0x"
129  << adler;
130  }
131  }
132 
133  rawData_ = std::make_unique<FEDRawDataCollection>();
134 
135  uint32_t eventSize = frdEventMsg->eventSize();
136  unsigned char* event = (unsigned char*)frdEventMsg->payload();
137  bool foundTCDSFED = false;
138  bool foundGTPFED = false;
139 
140  while (eventSize > 0) {
141  assert(eventSize >= FEDTrailer::length);
142  eventSize -= FEDTrailer::length;
143  const FEDTrailer fedTrailer(event + eventSize);
144  const uint32_t fedSize = fedTrailer.fragmentLength() << 3; //trailer length counts in 8 bytes
145  assert(eventSize >= fedSize - FEDHeader::length);
146  eventSize -= (fedSize - FEDHeader::length);
147  const FEDHeader fedHeader(event + eventSize);
148  const uint16_t fedId = fedHeader.sourceID();
150  throw cms::Exception("FedRawDataInputSource::fillFEDRawDataCollection") << "Out of range FED ID : " << fedId;
151  }
153  foundTCDSFED = true;
154  tcds::Raw_v1 const* tcds = reinterpret_cast<tcds::Raw_v1 const*>(event + eventSize + FEDHeader::length);
155  id = edm::EventID(frdEventMsg->run(), tcds->header.lumiSection, tcds->header.eventNumber);
156  eType = static_cast<edm::EventAuxiliary::ExperimentType>(fedHeader.triggerType());
157  theTime = static_cast<edm::TimeValue_t>(((uint64_t)tcds->bst.gpstimehigh << 32) | tcds->bst.gpstimelow);
158  }
159 
160  if (fedId == FEDNumbering::MINTriggerGTPFEDID && !foundTCDSFED) {
161  foundGTPFED = true;
162  const bool GTPEvmBoardSense = evf::evtn::evm_board_sense(event + eventSize, fedSize);
163  if (!useL1EventID_) {
164  if (GTPEvmBoardSense)
165  id = edm::EventID(frdEventMsg->run(), frdEventMsg->lumi(), evf::evtn::get(event + eventSize, true));
166  else
167  id = edm::EventID(frdEventMsg->run(), frdEventMsg->lumi(), evf::evtn::get(event + eventSize, false));
168  }
169  //evf::evtn::evm_board_setformat(fedSize);
170  const uint64_t gpsl = evf::evtn::getgpslow(event + eventSize);
171  const uint64_t gpsh = evf::evtn::getgpshigh(event + eventSize);
172  theTime = static_cast<edm::TimeValue_t>((gpsh << 32) + gpsl);
173  }
174 
175  //take event ID from GTPE FED
176  if (fedId == FEDNumbering::MINTriggerEGTPFEDID && !foundGTPFED && !foundTCDSFED && !useL1EventID_) {
177  if (evf::evtn::gtpe_board_sense(event + eventSize)) {
178  id = edm::EventID(frdEventMsg->run(), frdEventMsg->lumi(), evf::evtn::gtpe_get(event + eventSize));
179  }
180  }
181  FEDRawData& fedData = rawData_->FEDData(fedId);
182  fedData.resize(fedSize);
183  memcpy(fedData.data(), event + eventSize, fedSize);
184  }
185  assert(eventSize == 0);
186 
187  return true;
188 }
uint16_t getFRDFileHeaderVersion(const std::array< uint8_t, 4 > &id, const std::array< uint8_t, 4 > &version)
Definition: FRDFileHeader.h:80
unsigned int getgpshigh(const unsigned char *)
std::ifstream fin_
bool gtpe_board_sense(const unsigned char *p)
constexpr size_t FRDHeaderMaxVersion
static const uint32_t length
Definition: FEDTrailer.h:57
std::unique_ptr< FEDRawDataCollection > rawData_
unsigned int get(const unsigned char *, bool)
static const uint32_t length
Definition: FEDHeader.h:54
std::vector< char > buffer_
const bool useL1EventID_
assert(be >=bs)
std::array< uint8_t, 4 > id_
Definition: FRDFileHeader.h:29
Definition: TCDSRaw.h:16
std::array< uint8_t, 4 > version_
Definition: FRDFileHeader.h:30
bool openFile(const std::string &fileName)
unsigned long long TimeValue_t
Definition: Timestamp.h:21
std::vector< std::string >::const_iterator itFileName_
bool evm_board_sense(const unsigned char *p, size_t size)
const bool verifyChecksum_
uint32_t crc32c(uint32_t crc, const unsigned char *buf, size_t len)
Definition: crc32c.cc:340
std::vector< std::string >::const_iterator endFileName_
unsigned long long uint64_t
Definition: Time.h:13
void resize(size_t newsize, size_t wordsize=8)
Definition: FEDRawData.cc:28
const bool verifyAdler32_
const unsigned char * data() const
Return a const pointer to the beginning of the data buffer.
Definition: FEDRawData.cc:24
unsigned int gtpe_get(const unsigned char *)
uint16_t detectedFRDversion_
constexpr std::array< uint32, FRDHeaderMaxVersion+1 > FRDHeaderVersionSize
unsigned int getgpslow(const unsigned char *)
Definition: event.py:1

Member Data Documentation

◆ buffer_

std::vector<char> FRDStreamSource::buffer_
private

Definition at line 42 of file FRDStreamSource.h.

Referenced by setRunAndEventInfo().

◆ detectedFRDversion_

uint16_t FRDStreamSource::detectedFRDversion_ = 0
private

Definition at line 46 of file FRDStreamSource.h.

Referenced by setRunAndEventInfo().

◆ endFileName_

std::vector<std::string>::const_iterator FRDStreamSource::endFileName_
private

Definition at line 39 of file FRDStreamSource.h.

Referenced by FRDStreamSource(), and setRunAndEventInfo().

◆ fileNames_

std::vector<std::string> FRDStreamSource::fileNames_
private

Definition at line 37 of file FRDStreamSource.h.

Referenced by FRDStreamSource().

◆ fin_

std::ifstream FRDStreamSource::fin_
private

Definition at line 40 of file FRDStreamSource.h.

Referenced by openFile(), and setRunAndEventInfo().

◆ flags_

uint16_t FRDStreamSource::flags_ = 0
private

Definition at line 47 of file FRDStreamSource.h.

Referenced by setRunAndEventInfo().

◆ itFileName_

std::vector<std::string>::const_iterator FRDStreamSource::itFileName_
private

Definition at line 38 of file FRDStreamSource.h.

Referenced by FRDStreamSource(), and setRunAndEventInfo().

◆ rawData_

std::unique_ptr<FEDRawDataCollection> FRDStreamSource::rawData_
private

Definition at line 41 of file FRDStreamSource.h.

Referenced by produce(), and setRunAndEventInfo().

◆ useL1EventID_

const bool FRDStreamSource::useL1EventID_
private

Definition at line 45 of file FRDStreamSource.h.

Referenced by setRunAndEventInfo().

◆ verifyAdler32_

const bool FRDStreamSource::verifyAdler32_
private

Definition at line 43 of file FRDStreamSource.h.

Referenced by setRunAndEventInfo().

◆ verifyChecksum_

const bool FRDStreamSource::verifyChecksum_
private

Definition at line 44 of file FRDStreamSource.h.

Referenced by setRunAndEventInfo().