64 std::auto_ptr<PackingSetup>
prov_;
83 o <<
"L1T Block Header " << h.
getID() <<
" with size " << h.
getSize();
89 fedIds_(config.getParameter<std::vector<int>>(
"FedIds")),
90 minFeds_(config.getParameter<unsigned int>(
"MinFeds")),
91 fwId_(config.getParameter<unsigned int>(
"FWId")),
92 fwOverride_(config.getParameter<bool>(
"FWOverride")),
93 ctp7_mode_(config.getUntrackedParameter<bool>(
"CTP7")),
94 mtf7_mode_(config.getUntrackedParameter<bool>(
"MTF7"))
99 throw cms::Exception(
"L1TRawToDigi") <<
"Can only use one unpacking mode concurrently!";
103 prov_->registerProducts(*
this);
133 std::unique_ptr<UnpackerCollections>
coll =
prov_->getCollections(event);
138 if (!
feds.isValid()) {
139 LogError(
"L1T") <<
"Cannot unpack: no FEDRawDataCollection found";
143 unsigned valid_count = 0;
147 LogDebug(
"L1T") <<
"Found FEDRawDataCollection with ID " <<
fedId <<
" and size " << l1tRcd.
size();
150 if (l1tRcd.
size() > 0) {
151 LogError(
"L1T") <<
"Cannot unpack: invalid L1T raw data (size = "
152 << l1tRcd.
size() <<
") for ID " <<
fedId <<
". Returning empty collections!";
155 LogInfo(
"L1T") <<
"During unpacking, encountered empty L1T raw data (size = "
156 << l1tRcd.
size() <<
") for FED ID " <<
fedId <<
".";
163 const unsigned char *
data = l1tRcd.
data();
166 if (header.
check()) {
167 LogDebug(
"L1T") <<
"Found SLink header:"
169 <<
" L1 event ID " << header.
lvl1ID()
170 <<
" BX Number " << header.
bxID()
171 <<
" FED source " << header.
sourceID()
172 <<
" FED version " << header.
version();
174 LogWarning(
"L1T") <<
"Did not find a SLink header!";
179 if (trailer.
check()) {
180 LogDebug(
"L1T") <<
"Found SLink trailer:"
181 <<
" Length " << trailer.
lenght()
182 <<
" CRC " << trailer.
crc()
184 <<
" Throttling bits " << trailer.
ttsBits();
186 LogWarning(
"L1T") <<
"Did not find a SLink trailer!";
204 <<
"Could not extract AMC13 Packet.";
212 auto payload64 =
amc.data();
213 const uint32_t *
start = (
const uint32_t*) payload64.get();
216 const uint32_t *
end = start + (
amc.size() * 2);
218 std::auto_ptr<Payload> payload;
220 LogDebug(
"L1T") <<
"Using CTP7 mode";
223 LogDebug(
"L1T") <<
"Using MTF7 mode";
226 LogDebug(
"L1T") <<
"Using MP7 mode";
227 payload.reset(
new MP7Payload(start, end, legacy_mc));
229 unsigned fw = payload->getAlgorithmFWVersion();
235 unsigned board =
amc.blockHeader().getBoardID();
236 unsigned amc_no =
amc.blockHeader().getAMCNumber();
241 std::auto_ptr<Block>
block;
242 while ((block = payload->getBlock()).
get()) {
244 std::cout <<
">>> block to unpack <<<" << std::endl
245 <<
"hdr: " << std::hex << std::setw(8) << std::setfill(
'0') << block->header().raw() <<
std::dec
246 <<
" (ID " << block->header().getID() <<
", size " << block->header().getSize()
247 <<
", CapID 0x" << std::hex << std::setw(2) << std::setfill(
'0') << block->header().getCapID()
249 for (
const auto& word: block->payload()) {
251 std::cout <<
"data: " << std::hex << std::setw(8) << std::setfill(
'0') << word <<
std::dec << std::endl;
255 auto unpacker =
unpackers.find(block->header().getID());
257 block->amc(
amc.header());
260 LogDebug(
"L1T") <<
"Cannot find an unpacker for"
261 <<
"\n\tblock: ID " << block->header().getID() <<
", size " << block->header().getSize()
262 <<
"\n\tAMC: # " << amc_no <<
", board ID 0x" << std::hex << board <<
std::dec
263 <<
"\n\tFED ID " <<
fedId <<
", and FW ID " << fw;
265 }
else if (!unpacker->second->unpack(*block,
coll.get())) {
266 LogDebug(
"L1T") <<
"Error unpacking data for block ID "
267 << block->header().getID() <<
", AMC # " << amc_no
268 <<
", board ID " << board <<
", FED ID " <<
fedId
269 <<
", and FW ID " << fw <<
"!";
278 LogWarning(
"L1T") <<
"Unpacked " << valid_count <<
" non-empty FED IDs but minimum is set to " <<
minFeds_ <<
"\n";
288 desc.
add<std::vector<int>>(
"FedIds", {})->setComment(
"required parameter: default value is invalid");
289 desc.
add<
std::string>(
"Setup",
"")->setComment(
"required parameter: default value is invalid");
292 desc.
add<
unsigned int>(
"FWId",0)->setComment(
"Ignored unless FWOverride is true. Calo Stage1: 32 bits: if the first eight bits are 0xff, will read the 74x MC format.\n");
293 desc.
add<
bool>(
"FWOverride",
false)->setComment(
"Firmware version should be taken as FWId parameters");
303 desc.
addUntracked<
bool>(
"debug",
false)->setComment(
"turn on verbose output");
304 desc.
add<
unsigned int>(
"MinFeds", 0)->setComment(
"optional parameter: warn if less than MinFeds non-empty FED ids unpacked.");
305 descriptions.
add(
"l1tRawToDigi", desc);
virtual void produce(edm::Event &, const edm::EventSetup &) override
std::vector< amc::Packet > payload() const
T getParameter(std::string const &) const
T getUntrackedParameter(std::string const &, T const &) const
tuple start
Check for commandline option errors.
ParameterDescriptionBase * addUntracked(U const &iLabel, T const &value)
FWCore Framework interface EventSetupRecordImplementation h
Helper function to determine trigger accepts.
std::auto_ptr< PackingSetup > prov_
#define DEFINE_FWK_MODULE(type)
std::auto_ptr< PackingSetup > make(const std::string &) const
int evtStatus()
Event fragment status information.
std::ostream & operator<<(std::ostream &out, const ALILine &li)
size_t size() const
Lenght of the data buffer in bytes.
L1TRawToDigi(const edm::ParameterSet &)
std::vector< int > fedIds_
ParameterDescriptionBase * add(U const &iLabel, T const &value)
How EventSelector::AcceptEvent() decides whether to accept an event for output otherwise it is excluding the probing of A single or multiple positive and the trigger will pass if any such matching triggers are PASS or EXCEPTION[A criterion thatmatches no triggers at all is detected and causes a throw.] A single negative with an expectation of appropriate bit checking in the decision and the trigger will pass if any such matching triggers are FAIL or EXCEPTION A wildcarded negative criterion that matches more than one trigger in the trigger but the state exists so we define the behavior If all triggers are the negative crieriion will lead to accepting the event(this again matches the behavior of"!*"before the partial wildcard feature was incorporated).The per-event"cost"of each negative criterion with multiple relevant triggers is about the same as!*was in the past
int ttsBits()
Current value of the Trigger Throttling System bitsAQ).
unsigned long long uint64_t
int lenght()
The length of the event fragment counted in 64-bit words including header and trailer.
bool parse(const uint64_t *start, const uint64_t *data, unsigned int size, unsigned int lv1, unsigned int bx, bool legacy_mc=false, bool mtf7_mode=false)
virtual void beginLuminosityBlock(edm::LuminosityBlock const &, edm::EventSetup const &) override
void add(std::string const &label, ParameterSetDescription const &psetDescription)
static const PackingSetupFactory * get()
static void fillDescriptions(edm::ConfigurationDescriptions &descriptions)
char data[epos_bytes_allocation]
edm::EDGetTokenT< FEDRawDataCollection > fedData_
const unsigned char * data() const
Return a const pointer to the beginning of the data buffer.
int crc()
Cyclic Redundancy Code of the event fragment including header and trailer.
virtual void endRun(edm::Run const &, edm::EventSetup const &) override
virtual void endLuminosityBlock(edm::LuminosityBlock const &, edm::EventSetup const &) override
virtual void beginRun(edm::Run const &, edm::EventSetup const &) override