Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

multithreading fix for 74x: L1GtTriggerMenu-related modules #11354

Merged
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
5 changes: 4 additions & 1 deletion CondCore/L1TPlugins/src/plugin.cc
Original file line number Diff line number Diff line change
Expand Up @@ -182,7 +182,10 @@ REGISTER_PLUGIN(L1GtTriggerMaskVetoTechTrigRcd, L1GtTriggerMask);
#include "CondFormats/L1TObjects/interface/L1GtTriggerMenu.h"
#include "CondFormats/DataRecord/interface/L1GtTriggerMenuRcd.h"

REGISTER_PLUGIN(L1GtTriggerMenuRcd, L1GtTriggerMenu);
namespace {
struct L1GtTriggerMenuInitializer { void operator()(L1GtTriggerMenu & _) { _.buildGtConditionMap(); } };
}
REGISTER_PLUGIN_INIT(L1GtTriggerMenuRcd, L1GtTriggerMenu, L1GtTriggerMenuInitializer);

#include "CondFormats/L1TObjects/interface/L1GtPsbSetup.h"
#include "CondFormats/DataRecord/interface/L1GtPsbSetupRcd.h"
Expand Down
2 changes: 0 additions & 2 deletions DQM/HLTEvF/plugins/TriggerRatesMonitor.cc
Original file line number Diff line number Diff line change
Expand Up @@ -186,8 +186,6 @@ void TriggerRatesMonitor::dqmBeginRun(edm::Run const & run, edm::EventSetup cons

// cache the L1 trigger menu
m_l1tMenu = get<L1GtTriggerMenuRcd, L1GtTriggerMenu>(setup);
// FIXME - do we really need this ?
//(const_cast<L1GtTriggerMenu *>(m_l1tMenu))->buildGtConditionMap();
m_l1tAlgoMask = get<L1GtTriggerMaskAlgoTrigRcd, L1GtTriggerMask>(setup);
m_l1tTechMask = get<L1GtTriggerMaskTechTrigRcd, L1GtTriggerMask>(setup);
if (m_l1tMenu and m_l1tAlgoMask and m_l1tTechMask) {
Expand Down
1 change: 0 additions & 1 deletion DQM/L1TMonitor/src/L1GtHwValidation.cc
Original file line number Diff line number Diff line change
Expand Up @@ -2330,7 +2330,6 @@ void L1GtHwValidation::excludedAlgoList() {


const AlgorithmMap& algorithmMap = m_l1GtMenu->gtAlgorithmMap();
(const_cast<L1GtTriggerMenu*> (m_l1GtMenu))->buildGtConditionMap(); //...ugly

for (CItAlgo itAlgo = algorithmMap.begin(); itAlgo != algorithmMap.end(); itAlgo++) {

Expand Down
1 change: 0 additions & 1 deletion HLTrigger/HLTcore/src/TriggerExpressionData.cc
Original file line number Diff line number Diff line change
Expand Up @@ -62,7 +62,6 @@ bool Data::setEvent(const edm::Event & event, const edm::EventSetup & setup) {
m_l1tUpdated = false;
} else {
m_l1tMenu = get<L1GtTriggerMenuRcd, L1GtTriggerMenu>(setup);
(const_cast<L1GtTriggerMenu *>(m_l1tMenu))->buildGtConditionMap();
m_l1tCacheID = l1tCacheID;
m_l1tUpdated = true;
}
Expand Down
2 changes: 1 addition & 1 deletion HLTrigger/HLTfilters/interface/HLTLevel1GTSeed.h
Original file line number Diff line number Diff line change
Expand Up @@ -112,7 +112,7 @@ class HLTLevel1GTSeed : public HLTStreamFilter
// cached stuff

/// trigger menu
L1GtTriggerMenu * m_l1GtMenu;
const L1GtTriggerMenu * m_l1GtMenu;
unsigned long long m_l1GtMenuCacheID;

/// logic parser for m_l1SeedsLogicalExpression
Expand Down
5 changes: 3 additions & 2 deletions HLTrigger/HLTfilters/interface/TriggerResultsFilter.h
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@

#include "FWCore/Framework/interface/Frameworkfwd.h"
#include "FWCore/Framework/interface/Event.h"
#include "FWCore/Framework/interface/EDFilter.h"
#include "FWCore/Framework/interface/stream/EDFilter.h"
#include "FWCore/ParameterSet/interface/ParameterSet.h"
#include "FWCore/Utilities/interface/InputTag.h"
#include "HLTrigger/HLTcore/interface/TriggerExpressionData.h"
Expand All @@ -36,7 +36,8 @@ namespace triggerExpression {
// class declaration
//

class TriggerResultsFilter : public edm::EDFilter {
class TriggerResultsFilter : public edm::stream::EDFilter<>
{
public:
explicit TriggerResultsFilter(const edm::ParameterSet &);
~TriggerResultsFilter();
Expand Down
5 changes: 3 additions & 2 deletions HLTrigger/HLTfilters/interface/TriggerResultsFilterFromDB.h
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@
#include <string>

#include "FWCore/Framework/interface/ESWatcher.h"
#include "FWCore/Framework/interface/EDFilter.h"
#include "FWCore/Framework/interface/stream/EDFilter.h"
#include "CondFormats/DataRecord/interface/AlCaRecoTriggerBitsRcd.h"
#include "HLTrigger/HLTcore/interface/TriggerExpressionData.h"

Expand All @@ -35,7 +35,8 @@ namespace triggerExpression {
// class declaration
//

class TriggerResultsFilterFromDB : public edm::EDFilter {
class TriggerResultsFilterFromDB : public edm::stream::EDFilter<>
{
public:
explicit TriggerResultsFilterFromDB(const edm::ParameterSet &);
~TriggerResultsFilterFromDB();
Expand Down
15 changes: 6 additions & 9 deletions HLTrigger/HLTfilters/src/HLTLevel1GTSeed.cc
Original file line number Diff line number Diff line change
Expand Up @@ -74,7 +74,11 @@

// constructors
HLTLevel1GTSeed::HLTLevel1GTSeed(const edm::ParameterSet& parSet) : HLTStreamFilter(parSet),
// seeding done via L1 trigger object maps, with objects that fired
// initialize the cache
m_l1GtMenu( nullptr ),
m_l1GtMenuCacheID( 0ULL ),

// seeding done via L1 trigger object maps, with objects that fired
m_l1UseL1TriggerObjectMaps(parSet.getParameter<bool> (
"L1UseL1TriggerObjectMaps")),

Expand Down Expand Up @@ -180,10 +184,6 @@ HLTLevel1GTSeed::HLTLevel1GTSeed(const edm::ParameterSet& parSet) : HLTStreamFil
<< m_l1CollectionsTag << " \n"
<< "Input tag for L1 muon collections: "
<< m_l1MuonCollectionTag << " \n" << std::endl;

// initialize cache
m_l1GtMenu = nullptr;
m_l1GtMenuCacheID = 0ULL;
}

// destructor
Expand Down Expand Up @@ -348,10 +348,7 @@ bool HLTLevel1GTSeed::hltFilter(edm::Event& iEvent, const edm::EventSetup& evSet

edm::ESHandle<L1GtTriggerMenu> l1GtMenu;
evSetup.get<L1GtTriggerMenuRcd>().get(l1GtMenu);
// make a copy of the L1GtTriggerMenu in order to call buildGtConditionMap() (FIXME - is this really needed ?)
delete m_l1GtMenu;
m_l1GtMenu = new L1GtTriggerMenu(* l1GtMenu.product());
m_l1GtMenu->buildGtConditionMap();
m_l1GtMenu = l1GtMenu.product();
m_l1GtMenuCacheID = l1GtMenuCacheID;

const AlgorithmMap& algorithmMap = l1GtMenu->gtAlgorithmMap();
Expand Down
50 changes: 22 additions & 28 deletions L1Trigger/GlobalTrigger/plugins/L1GlobalTrigger.h
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@
#include "CondFormats/L1TObjects/interface/L1GtBoard.h"

#include "FWCore/Framework/interface/Frameworkfwd.h"
#include "FWCore/Framework/interface/EDProducer.h"
#include "FWCore/Framework/interface/stream/EDProducer.h"

#include "FWCore/Framework/interface/Event.h"
#include "FWCore/Framework/interface/EventSetup.h"
Expand All @@ -52,7 +52,7 @@ class L1GtPrescaleFactors;
class L1GtTriggerMask;

// class declaration
class L1GlobalTrigger : public edm::EDProducer
class L1GlobalTrigger : public edm::stream::EDProducer<>
{

public:
Expand Down Expand Up @@ -164,39 +164,36 @@ class L1GlobalTrigger : public edm::EDProducer
std::vector<unsigned int> m_triggerMaskVetoAlgoTrig;
std::vector<unsigned int> m_triggerMaskVetoTechTrig;

private:


L1GlobalTriggerPSB* m_gtPSB;
L1GlobalTriggerGTL* m_gtGTL;
L1GlobalTriggerFDL* m_gtFDL;

/// input tag for muon collection from GMT
edm::InputTag m_muGmtInputTag;
const edm::InputTag m_muGmtInputTag;

/// input tag for calorimeter collections from GCT
edm::InputTag m_caloGctInputTag;
const edm::InputTag m_caloGctInputTag;

/// input tag for CASTOR record
edm::InputTag m_castorInputTag;
const edm::InputTag m_castorInputTag;

/// input tag for technical triggers
std::vector<edm::InputTag> m_technicalTriggersInputTags;
const std::vector<edm::InputTag> m_technicalTriggersInputTags;

/// logical flag to produce the L1 GT DAQ readout record
bool m_produceL1GtDaqRecord;
const bool m_produceL1GtDaqRecord;

/// logical flag to produce the L1 GT EVM readout record
bool m_produceL1GtEvmRecord;
const bool m_produceL1GtEvmRecord;

/// logical flag to produce the L1 GT object map record
bool m_produceL1GtObjectMapRecord;
const bool m_produceL1GtObjectMapRecord;

/// logical flag to write the PSB content in the L1 GT DAQ record
bool m_writePsbL1GtDaqRecord;
const bool m_writePsbL1GtDaqRecord;

/// logical flag to read the technical trigger records
bool m_readTechnicalTriggerRecords;
const bool m_readTechnicalTriggerRecords;

/// number of "bunch crossing in the event" (BxInEvent) to be emulated
/// symmetric around L1Accept (BxInEvent = 0):
Expand All @@ -207,47 +204,44 @@ class L1GlobalTrigger : public edm::EDProducer
/// number of BXs in the event corresponding to alternative 0 and 1 in altNrBxBoard()
/// EmulateBxInEvent >= max(RecordLength[0], RecordLength[1])
/// negative values: take the numbers from event setup, from L1GtParameters
std::vector<int> m_recordLength;
const std::vector<int> m_recordLength;

/// alternative for number of BX per active board in GT DAQ record: 0 or 1
/// the position is identical with the active board bit
unsigned int m_alternativeNrBxBoardDaq;
const unsigned int m_alternativeNrBxBoardDaq;

/// alternative for number of BX per active board in GT EVM record: 0 or 1
/// the position is identical with the active board bit
unsigned int m_alternativeNrBxBoardEvm;
const unsigned int m_alternativeNrBxBoardEvm;

/// length of BST record (in bytes) from parameter set
int m_psBstLengthBytes;
const int m_psBstLengthBytes;

/// run algorithm triggers
/// if true, unprescaled (all prescale factors 1)
/// will overwrite the event setup
bool m_algorithmTriggersUnprescaled;
const bool m_algorithmTriggersUnprescaled;

/// if true, unmasked - all enabled (all trigger masks set to 0)
/// will overwrite the event setup
bool m_algorithmTriggersUnmasked;
const bool m_algorithmTriggersUnmasked;

/// run technical triggers
/// if true, unprescaled (all prescale factors 1)
/// will overwrite the event setup
bool m_technicalTriggersUnprescaled;
const bool m_technicalTriggersUnprescaled;

/// if true, unmasked - all enabled (all trigger masks set to 0)
/// will overwrite the event setup
bool m_technicalTriggersUnmasked;
const bool m_technicalTriggersUnmasked;

/// if true, veto unmasked - all enabled (all trigger veto masks set to 0)
/// will overwrite the event setup
bool m_technicalTriggersVetoUnmasked;


private:
const bool m_technicalTriggersVetoUnmasked;

/// verbosity level
int m_verbosity;
bool m_isDebugEnabled;
const int m_verbosity;
const bool m_isDebugEnabled;

};

Expand Down
3 changes: 0 additions & 3 deletions L1Trigger/GlobalTrigger/src/L1GlobalTriggerGTL.cc
Original file line number Diff line number Diff line change
Expand Up @@ -197,10 +197,7 @@ void L1GlobalTriggerGTL::run(
edm::ESHandle< L1GtTriggerMenu> l1GtMenu;
evSetup.get< L1GtTriggerMenuRcd>().get(l1GtMenu) ;
m_l1GtMenu = l1GtMenu.product();
(const_cast<L1GtTriggerMenu*>(m_l1GtMenu))->buildGtConditionMap();

m_l1GtMenuCacheID = l1GtMenuCacheID;

}

const std::vector<ConditionMap>& conditionMap = m_l1GtMenu->gtConditionMap();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -230,11 +230,8 @@ void L1GtTriggerMenuTester::retrieveL1EventSetup(const edm::EventSetup& evSetup)
edm::ESHandle<L1GtTriggerMenu> l1GtMenu;
evSetup.get<L1GtTriggerMenuRcd> ().get(l1GtMenu);
m_l1GtMenu = l1GtMenu.product();
(const_cast<L1GtTriggerMenu*> (m_l1GtMenu))->buildGtConditionMap();

m_algorithmMap = &(m_l1GtMenu->gtAlgorithmMap());
m_algorithmAliasMap = &(m_l1GtMenu->gtAlgorithmAliasMap());

m_technicalTriggerMap = &(m_l1GtMenu->gtTechnicalTriggerMap());

}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2178,7 +2178,7 @@ bool L1GtTriggerMenuXmlParser::parseJetCounts(XERCES_CPP_NAMESPACE::DOMNode* nod

// get countIndex value and fill into structure
// they are expressed in base 10 (values: 0 - m_numberL1JetCounts)
char* endPtr = const_cast<char*>(type.c_str());
char* endPtr = nullptr;
long int typeInt = strtol(type.c_str(), &endPtr, 10); // base = 10

if (*endPtr != 0) {
Expand Down Expand Up @@ -2426,7 +2426,7 @@ bool L1GtTriggerMenuXmlParser::parseHfBitCounts(XERCES_CPP_NAMESPACE::DOMNode* n

// get countIndex value and fill into structure
// they are expressed in base 10
char* endPtr = const_cast<char*>(type.c_str());
char* endPtr = nullptr;
long int typeInt = strtol(type.c_str(), &endPtr, 10); // base = 10

if (*endPtr != 0) {
Expand Down Expand Up @@ -2558,7 +2558,7 @@ bool L1GtTriggerMenuXmlParser::parseHfRingEtSums(XERCES_CPP_NAMESPACE::DOMNode*

// get etSumIndex value and fill into structure
// they are expressed in base 10
char* endPtr = const_cast<char*>(type.c_str());
char* endPtr = nullptr;
long int typeInt = strtol(type.c_str(), &endPtr, 10); // base = 10

if (*endPtr != 0) {
Expand Down
12 changes: 4 additions & 8 deletions L1TriggerConfig/L1GtConfigProducers/src/L1GtVhdlWriterCore.cc
Original file line number Diff line number Diff line change
Expand Up @@ -847,18 +847,14 @@ bool L1GtVhdlWriterCore::processAlgorithmMap(std::vector< std::map<int, std::str
std::ostringstream newExpr;

// look for the condition on correct chip

std::vector<ConditionMap> * conditionMapCp = const_cast< std::vector<ConditionMap>* >(conditionMap_);

L1GtCondition* cond = (*conditionMapCp).at((algoIter->second).algoChipNumber())[conditions.at(i)];
ConditionMap const& chip = conditionMap_->at(algoIter->second.algoChipNumber());
L1GtCondition const* cond = (chip.find(conditions.at(i)) == chip.end()) ? nullptr : chip.at(conditions.at(i));

// check weather condition exists
if (cond!=NULL)
{
newExpr<<objType2Str_[(cond->objectType()).at(0)];

newExpr <<"_" << condType2Str_[cond->condType()] << "(";

newExpr << objType2Str_[(cond->objectType()).at(0)];
newExpr << "_" << condType2Str_[cond->condType()] << "(";
newExpr << conditionToIntegerMap_[conditions.at(i)] << ")";
dummy.findAndReplaceString(logicalExpr, conditions.at(i),
newExpr.str());
Expand Down
8 changes: 3 additions & 5 deletions PhysicsTools/PatAlgos/plugins/PATTriggerProducer.cc
Original file line number Diff line number Diff line change
Expand Up @@ -822,11 +822,9 @@ void PATTriggerProducer::produce( Event& iEvent, const EventSetup& iSetup )
l1GtUtils_.getL1GtRunCache( iEvent, iSetup, useL1EventSetup, useL1GtTriggerMenuLite );
ESHandle< L1GtTriggerMenu > handleL1GtTriggerMenu;
iSetup.get< L1GtTriggerMenuRcd >().get( handleL1GtTriggerMenu );
L1GtTriggerMenu l1GtTriggerMenu( *handleL1GtTriggerMenu );
const AlgorithmMap l1GtAlgorithms( l1GtTriggerMenu.gtAlgorithmMap() );
const AlgorithmMap l1GtTechTriggers( l1GtTriggerMenu.gtTechnicalTriggerMap() );
l1GtTriggerMenu.buildGtConditionMap();
const std::vector< ConditionMap > l1GtConditionsVector( l1GtTriggerMenu.gtConditionMap() );
auto const & l1GtAlgorithms = handleL1GtTriggerMenu->gtAlgorithmMap();
auto const & l1GtTechTriggers = handleL1GtTriggerMenu->gtTechnicalTriggerMap();
auto const & l1GtConditionsVector = handleL1GtTriggerMenu->gtConditionMap();
// cache conditions in one single condition map
ConditionMap l1GtConditions;
for ( size_t iCv = 0; iCv < l1GtConditionsVector.size(); ++iCv ) {
Expand Down