CMS 3D CMS Logo

SiStripSpyEventSummaryProducer.cc
Go to the documentation of this file.
1 //Class to produce a dummy SiStripEventSummary object so that spy channel data can be used with commissioning software.
2 //Run types which need additional parameters from the trigger FED buffer or DAQ registers are not supported.
3 //If an unsupported run type is used, an error message will be printed and parameters will be set to zero.
4 //Author: Nick Cripps
5 //Date: 10/05/2010
6 
23 #include <memory>
24 #include <string>
25 #include "boost/scoped_array.hpp"
26 #include <cstdint>
27 
28 using edm::LogError;
29 using edm::LogInfo;
30 using edm::LogWarning;
31 
32 namespace sistrip {
33 
35  public:
37  ~SpyEventSummaryProducer() override;
38  void produce(edm::Event& event, const edm::EventSetup&) override;
39 
40  private:
42  static const char* messageLabel_;
46  };
47 
48 } // namespace sistrip
49 
50 namespace sistrip {
51 
52  const char* SpyEventSummaryProducer::messageLabel_ = "SiStripSpyEventSummaryProducer";
53 
55  : rawDataTag_(config.getParameter<edm::InputTag>("RawDataTag")),
56  runType_(sistrip::RunType(config.getParameter<uint32_t>("RunType"))) {
57  rawDataToken_ = consumes<FEDRawDataCollection>(rawDataTag_);
58  produces<SiStripEventSummary>();
60  }
61 
63 
66 
67  //get the event number and Bx counter from the first valud FED buffer
69  event.getByToken(rawDataToken_, rawDataHandle);
70  const FEDRawDataCollection& rawData = *rawDataHandle;
71  bool fedFound = false;
72  uint32_t fedEventNumber = 0;
73  uint32_t fedBxNumber = 0;
74  for (uint16_t fedId = sistrip::FED_ID_MIN; fedId <= sistrip::FED_ID_MAX; ++fedId) {
75  const FEDRawData& fedData = rawData.FEDData(fedId);
76  if (fedData.size() && fedData.data()) {
77  const auto st_buffer = preconstructCheckFEDBufferBase(fedData);
78  if (sistrip::FEDBufferStatusCode::SUCCESS != st_buffer) {
79  LogInfo(messageLabel_) << "Skipping FED " << fedId << " because of exception: "
80  << "An exception of category 'FEDBuffer' occurred.\n"
81  << st_buffer;
82  continue;
83  }
84  const sistrip::FEDBufferBase buffer{fedData};
85  fedEventNumber = buffer.daqLvl1ID();
86  fedBxNumber = buffer.daqBXID();
87  fedFound = true;
88  break;
89  }
90  }
91  if (!fedFound) {
92  LogError(messageLabel_) << "No SiStrip FED data found in raw data.";
93  return;
94  }
95 
96  //create summary object
97  std::unique_ptr<SiStripEventSummary> pSummary(new SiStripEventSummary);
98  //set the trigger FED number to zero to indicate that it doesn't exist
99  pSummary->triggerFed(0);
100  //set the event number and Bx from the FED packets
101  pSummary->event(fedEventNumber);
102  pSummary->bx(fedBxNumber);
103  //create a fake trigger FED buffer to take comissioning parameters from
104  const int maxTriggerFedBufferSize = 84;
105  boost::scoped_array<uint32_t> fakeTriggerFedData(new uint32_t[maxTriggerFedBufferSize]);
106  for (uint8_t i = 0; i < maxTriggerFedBufferSize; ++i) {
107  fakeTriggerFedData[i] = 0;
108  }
109  //set the FED readout mode to virgin raw
110  fakeTriggerFedData[15] = 1;
111  //set the spill number
112  fakeTriggerFedData[0] = 0;
113  //set the number of data senders
114  fakeTriggerFedData[20] = 1;
115  //set the run type
116  fakeTriggerFedData[10] = runType_;
117  //fill the summarry using trigger FED buffer with no data
118  pSummary->commissioningInfo(fakeTriggerFedData.get(), fedEventNumber);
119 
120  //store in event
121  event.put(std::move(pSummary));
122  }
123 
125  switch (runType_) {
127  case sistrip::PHYSICS:
128  case sistrip::PHYSICS_ZS:
129  case sistrip::PEDESTALS:
130  case sistrip::MULTI_MODE:
131  case sistrip::PEDS_ONLY:
132  case sistrip::NOISE:
136  break;
142  case sistrip::OPTO_SCAN:
143  case sistrip::APV_TIMING:
144  case sistrip::FED_TIMING:
145  case sistrip::FINE_DELAY:
151  case sistrip::VPSP_SCAN:
152  LogWarning(messageLabel_) << "Unsupported run type: " << runType_
153  << ". Parameters need to be set from real trigger FED. Parameters will be set to 0.";
154  break;
155  }
156  }
157 
158 } // namespace sistrip
159 
sistrip::CALIBRATION_SCAN
Definition: ConstantsForRunType.h:87
sistrip::PHYSICS_ZS
Definition: ConstantsForRunType.h:86
sistrip::DAQ_SCOPE_MODE
Definition: ConstantsForRunType.h:83
Handle.h
mps_fire.i
i
Definition: mps_fire.py:355
sistrip::CALIBRATION
Definition: ConstantsForRunType.h:73
MessageLogger.h
sistrip::PEDS_FULL_NOISE
Definition: ConstantsForRunType.h:92
sistrip::VPSP_SCAN
Definition: ConstantsForRunType.h:82
sistrip::FAST_CABLING
Definition: ConstantsForRunType.h:89
EDProducer.h
sistrip::APV_TIMING
Definition: ConstantsForRunType.h:75
ESHandle.h
edm::EDGetTokenT< FEDRawDataCollection >
FEDRawDataCollection
Definition: FEDRawDataCollection.h:18
edm
HLT enums.
Definition: AlignableModifier.h:19
edm::LogInfo
Definition: MessageLogger.h:254
l1tstage2_dqm_sourceclient-live_cfg.rawData
rawData
Definition: l1tstage2_dqm_sourceclient-live_cfg.py:156
sistrip::OPTO_SCAN
Definition: ConstantsForRunType.h:74
sistrip::SpyEventSummaryProducer::rawDataToken_
edm::EDGetTokenT< FEDRawDataCollection > rawDataToken_
Definition: SiStripSpyEventSummaryProducer.cc:44
sistrip::FED_ID_MIN
static const uint16_t FED_ID_MIN
Definition: ConstantsForHardwareSystems.h:21
sistrip::RunType
RunType
Definition: ConstantsForRunType.h:70
sistrip::SpyEventSummaryProducer::warnAboutUnsupportedRunType
void warnAboutUnsupportedRunType()
Definition: SiStripSpyEventSummaryProducer.cc:124
FEDRawData.h
edm::Handle
Definition: AssociativeIterator.h:50
sistrip::FEDBufferBase
Definition: SiStripFEDBufferComponents.h:643
sistrip::SpyEventSummaryProducer::SpyEventSummaryProducer
SpyEventSummaryProducer(const edm::ParameterSet &config)
Definition: SiStripSpyEventSummaryProducer.cc:54
FEDRawData::data
const unsigned char * data() const
Return a const pointer to the beginning of the data buffer.
Definition: FEDRawData.cc:24
FEDRawData
Definition: FEDRawData.h:19
edmScanValgrind.buffer
buffer
Definition: edmScanValgrind.py:171
sistrip::FINE_DELAY
Definition: ConstantsForRunType.h:85
config
Definition: config.py:1
MakerMacros.h
sistrip::FED_CABLING
Definition: ConstantsForRunType.h:81
DEFINE_FWK_MODULE
#define DEFINE_FWK_MODULE(type)
Definition: MakerMacros.h:16
sistrip::SpyEventSummaryProducer::produce
void produce(edm::Event &event, const edm::EventSetup &) override
Definition: SiStripSpyEventSummaryProducer.cc:64
sistrip::FINE_DELAY_TTC
Definition: ConstantsForRunType.h:78
sistrip::SpyEventSummaryProducer::runType_
const sistrip::RunType runType_
Definition: SiStripSpyEventSummaryProducer.cc:45
EDGetToken.h
SiStripEventSummary.h
edm::LogWarning
Definition: MessageLogger.h:141
SiStripSpyEventSummaryProducer
sistrip::SpyEventSummaryProducer SiStripSpyEventSummaryProducer
Definition: SiStripSpyEventSummaryProducer.cc:160
HLT_2018_cff.InputTag
InputTag
Definition: HLT_2018_cff.py:79016
edm::ParameterSet
Definition: ParameterSet.h:36
sistrip::CALIBRATION_DECO
Definition: ConstantsForRunType.h:93
edm::LogError
Definition: MessageLogger.h:183
Event.h
sistrip::QUITE_FAST_CABLING
Definition: ConstantsForRunType.h:84
SiStripFEDBufferComponents.h
sistrip::PEDESTALS
Definition: ConstantsForRunType.h:72
sistrip::UNKNOWN_RUN_TYPE
Definition: ConstantsForRunType.h:94
sistrip::FEDBufferStatusCode::SUCCESS
FEDRawDataCollection.h
sistrip::FED_TIMING
Definition: ConstantsForRunType.h:80
sistrip::PEDS_ONLY
Definition: ConstantsForRunType.h:90
edm::EventSetup
Definition: EventSetup.h:57
l1tstage2_dqm_sourceclient-live_cfg.fedId
fedId
Definition: l1tstage2_dqm_sourceclient-live_cfg.py:82
FEDRawData::size
size_t size() const
Lenght of the data buffer in bytes.
Definition: FEDRawData.h:45
sistrip::FED_ID_MAX
static const uint16_t FED_ID_MAX
Definition: ConstantsForHardwareSystems.h:22
InputTag.h
sistrip::MULTI_MODE
Definition: ConstantsForRunType.h:79
sistrip::preconstructCheckFEDBufferBase
FEDBufferStatusCode preconstructCheckFEDBufferBase(const FEDRawData &fedBuffer, bool checkRecognizedFormat=true)
Definition: SiStripFEDBufferComponents.h:757
sistrip::FINE_DELAY_PLL
Definition: ConstantsForRunType.h:77
sistrip::CALIBRATION_SCAN_DECO
Definition: ConstantsForRunType.h:88
eostools.move
def move(src, dest)
Definition: eostools.py:511
sistrip::SpyEventSummaryProducer
Definition: SiStripSpyEventSummaryProducer.cc:34
sistrip::PHYSICS
Definition: ConstantsForRunType.h:71
ConstantsForRunType.h
Constants and enumerated type for sistrip::RunType.
Frameworkfwd.h
sistrip::SpyEventSummaryProducer::rawDataTag_
const edm::InputTag rawDataTag_
Definition: SiStripSpyEventSummaryProducer.cc:43
sistrip::APV_LATENCY
Definition: ConstantsForRunType.h:76
sistrip::UNDEFINED_RUN_TYPE
Definition: ConstantsForRunType.h:95
sistrip::SpyEventSummaryProducer::messageLabel_
static const char * messageLabel_
Definition: SiStripSpyEventSummaryProducer.cc:42
sistrip::NOISE
Definition: ConstantsForRunType.h:91
EventSetup.h
sistrip::SpyEventSummaryProducer::~SpyEventSummaryProducer
~SpyEventSummaryProducer() override
Definition: SiStripSpyEventSummaryProducer.cc:62
edm::EDProducer
Definition: EDProducer.h:36
ParameterSet.h
sistrip
sistrip classes
Definition: SiStripQualityHelpers.h:14
SiStripEventSummary
Definition: SiStripEventSummary.h:22
event
Definition: event.py:1
edm::Event
Definition: Event.h:73
edm::InputTag
Definition: InputTag.h:15