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 22 of file FRDStreamSource.cc.

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

24  verifyAdler32_(pset.getUntrackedParameter<bool>("verifyAdler32", true)),
25  verifyChecksum_(pset.getUntrackedParameter<bool>("verifyChecksum", true)),
26  useL1EventID_(pset.getUntrackedParameter<bool>("useL1EventID", false)) {
28  endFileName_ = fileNames_.end();
30  produces<FEDRawDataCollection>();
31 }
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 194 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().

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

◆ produce()

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

Implements edm::ProducerSourceBase.

Definition at line 192 of file FRDStreamSource.cc.

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

192 { 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 33 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(), edm::streamer::FRDHeaderMaxVersion, edm::streamer::FRDHeaderVersionSize, evf::evtn::get(), edm::streamer::getFRDFileHeaderVersion(), evf::evtn::getgpshigh(), evf::evtn::getgpslow(), evf::evtn::gtpe_board_sense(), evf::evtn::gtpe_get(), edm::streamer::FRDFileHeaderContent_v1::headerSize_, edm::streamer::FRDFileHeaderContent_v2::headerSize_, edm::streamer::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 edm::streamer::FRDFileHeaderIdentifier::version_.

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