CMS 3D CMS Logo

List of all members | Classes | Public Member Functions | Static Public Member Functions | Static Public Attributes | Private Member Functions | Static Private Member Functions | Private Attributes | Static Private Attributes | Friends
edm::service::InitRootHandlers Class Reference
Inheritance diagram for edm::service::InitRootHandlers:
edm::RootHandlers

Classes

class  ThreadTracker
 

Public Member Functions

 InitRootHandlers (ParameterSet const &pset, ActivityRegistry &iReg)
 
 ~InitRootHandlers () override
 
- Public Member Functions inherited from edm::RootHandlers
template<typename F >
void ignoreWarningsWhileDoing (F iFunc, SeverityLevel level=SeverityLevel::kWarning)
 
virtual ~RootHandlers ()
 

Static Public Member Functions

static void fillDescriptions (ConfigurationDescriptions &descriptions)
 
static void stacktraceFromThread ()
 
static int stackTracePause ()
 
static const ThreadTracker::Container_typethreadIDs ()
 

Static Public Attributes

static std::atomic< std::size_t > doneModules_
 
static std::vector< std::array< char, moduleBufferSize > > moduleListBuffers_
 
static std::atomic< std::size_t > nextModule_
 

Private Member Functions

void cachePidInfo ()
 
void enableWarnings_ () override
 
void ignoreWarnings_ (edm::RootHandlers::SeverityLevel level) override
 
void willBeUsingThreads () override
 

Static Private Member Functions

static char const *const * getPstackArgv ()
 
static void stacktraceHelperThread ()
 

Private Attributes

bool autoClassParser_
 
bool autoLibraryLoader_
 
bool interactiveDebug_
 
bool loadAllDictionaries_
 
bool resetErrHandler_
 
std::shared_ptr< const void > sigAbrtHandler_
 
std::shared_ptr< const void > sigBusHandler_
 
std::shared_ptr< const void > sigFpeHandler_
 
std::shared_ptr< const void > sigIllHandler_
 
std::shared_ptr< const void > sigSegvHandler_
 
std::shared_ptr< const void > sigTermHandler_
 
bool unloadSigHandler_
 

Static Private Attributes

static int childToParent_ [2] = {-1, -1}
 
static std::unique_ptr< std::thread > helperThread_
 
static int parentToChild_ [2] = {-1, -1}
 
static char pidString_ [pidStringLength_] = {}
 
static constexpr int pidStringLength_ = 200
 
static char const *const pstackArgv_ [] = {pstackName, dashC, InitRootHandlers::pidString_, nullptr}
 
static int stackTracePause_ = 300
 
static std::unique_ptr< ThreadTrackerthreadTracker_
 

Friends

int cmssw_stacktrace (void *)
 

Additional Inherited Members

- Public Types inherited from edm::RootHandlers
enum  SeverityLevel {
  SeverityLevel::kInfo, SeverityLevel::kWarning, SeverityLevel::kError, SeverityLevel::kSysError,
  SeverityLevel::kFatal
}
 

Detailed Description

Definition at line 69 of file InitRootHandlers.cc.

Constructor & Destructor Documentation

◆ InitRootHandlers()

edm::service::InitRootHandlers::InitRootHandlers ( ParameterSet const &  pset,
ActivityRegistry iReg 
)
explicit

Definition at line 771 of file InitRootHandlers.cc.

References autoClassParser_, autoLibraryLoader_, edm::TypeWithDict::byName(), cachePidInfo(), HLT_2023v12_cff::debugLevel, edm::hasDictionary(), edm::installCustomHandler(), edm::service::SystemBounds::maxNumberOfThreads(), moduleListBuffers_, muonDTDigis_cfi::pset, resetErrHandler_, edm::setRefCoreStreamerInTClass(), sigAbrtHandler_, sigBusHandler_, sigFpeHandler_, sigIllHandler_, sigSegvHandler_, watchdog::SIGTERM, sigTermHandler_, stackTracePause_, threadTracker_, unloadSigHandler_, trackerHitRTTI::vector, edm::ActivityRegistry::watchPostEndJob(), edm::ActivityRegistry::watchPostModuleConstruction(), edm::ActivityRegistry::watchPreallocate(), and edm::ActivityRegistry::watchPreModuleConstruction().

772  : RootHandlers(),
773  unloadSigHandler_(pset.getUntrackedParameter<bool>("UnloadRootSigHandler")),
774  resetErrHandler_(pset.getUntrackedParameter<bool>("ResetRootErrHandler")),
775  loadAllDictionaries_(pset.getUntrackedParameter<bool>("LoadAllDictionaries")),
776  autoLibraryLoader_(loadAllDictionaries_ or pset.getUntrackedParameter<bool>("AutoLibraryLoader")),
777  autoClassParser_(pset.getUntrackedParameter<bool>("AutoClassParser")),
778  interactiveDebug_(pset.getUntrackedParameter<bool>("InteractiveDebug")) {
779  stackTracePause_ = pset.getUntrackedParameter<int>("StackTracePauseTime");
780 
781  if (not threadTracker_) {
782  threadTracker_ = std::make_unique<ThreadTracker>();
783  iReg.watchPostEndJob([]() {
784  if (threadTracker_) {
785  threadTracker_->observe(false);
786  }
787  });
788  }
789 
790  if (unloadSigHandler_) {
791  // Deactivate all the Root signal handlers and restore the system defaults
792  gSystem->ResetSignal(kSigChild);
793  gSystem->ResetSignal(kSigBus);
794  gSystem->ResetSignal(kSigSegmentationViolation);
795  gSystem->ResetSignal(kSigIllegalInstruction);
796  gSystem->ResetSignal(kSigSystem);
797  gSystem->ResetSignal(kSigPipe);
798  gSystem->ResetSignal(kSigAlarm);
799  gSystem->ResetSignal(kSigUrgent);
800  gSystem->ResetSignal(kSigFloatingException);
801  gSystem->ResetSignal(kSigWindowChanged);
802  } else if (pset.getUntrackedParameter<bool>("AbortOnSignal")) {
803  cachePidInfo();
804 
805  //NOTE: ROOT can also be told to abort on these kinds of problems BUT
806  // it requires an TApplication to be instantiated which causes problems
807  gSystem->ResetSignal(kSigBus);
808  gSystem->ResetSignal(kSigSegmentationViolation);
809  gSystem->ResetSignal(kSigIllegalInstruction);
810  gSystem->ResetSignal(kSigFloatingException);
811  installCustomHandler(SIGBUS, sig_dostack_then_abort);
812  sigBusHandler_ = std::shared_ptr<const void>(nullptr, [](void*) { installCustomHandler(SIGBUS, sig_abort); });
813  installCustomHandler(SIGSEGV, sig_dostack_then_abort);
814  sigSegvHandler_ = std::shared_ptr<const void>(nullptr, [](void*) { installCustomHandler(SIGSEGV, sig_abort); });
815  installCustomHandler(SIGILL, sig_dostack_then_abort);
816  sigIllHandler_ = std::shared_ptr<const void>(nullptr, [](void*) { installCustomHandler(SIGILL, sig_abort); });
817  installCustomHandler(SIGTERM, sig_dostack_then_abort);
818  sigTermHandler_ = std::shared_ptr<const void>(nullptr, [](void*) { installCustomHandler(SIGTERM, sig_abort); });
819  installCustomHandler(SIGFPE, sig_dostack_then_abort);
820  sigFpeHandler_ = std::shared_ptr<const void>(nullptr, [](void*) { installCustomHandler(SIGFPE, sig_abort); });
821  installCustomHandler(SIGABRT, sig_dostack_then_abort);
822  sigAbrtHandler_ = std::shared_ptr<const void>(nullptr, [](void*) {
823  signal(SIGABRT, SIG_DFL); // release SIGABRT to default
824  });
825  }
826 
827  iReg.watchPreallocate([](edm::service::SystemBounds const& iBounds) {
828  if (iBounds.maxNumberOfThreads() > moduleListBuffers_.size()) {
829  moduleListBuffers_.resize(iBounds.maxNumberOfThreads());
830  }
831  });
832 
833  if (resetErrHandler_) {
834  // Replace the Root error handler with one that uses the MessageLogger
835  SetErrorHandler(RootErrorHandler);
836  }
837 
838  // Enable automatic Root library loading.
839  if (autoLibraryLoader_) {
840  gInterpreter->SetClassAutoloading(1);
841  }
842 
843  // Enable/disable automatic parsing of headers
844  if (not autoClassParser_) {
845  // Disable automatic parsing of headers during module construction
846  iReg.watchPreModuleConstruction(
847  [](edm::ModuleDescription const&) { gInterpreter->SetClassAutoparsing(false); });
848  iReg.watchPostModuleConstruction(
849  [](edm::ModuleDescription const&) { gInterpreter->SetClassAutoparsing(true); });
850  }
851 
852  // Set ROOT parameters.
853  TTree::SetMaxTreeSize(kMaxLong64);
854  TH1::AddDirectory(kFALSE);
855  //G__SetCatchException(0);
856 
857  // Set custom streamers
859 
860  // Load the library containing dictionaries for std:: classes, if not already loaded.
861  if (!hasDictionary(typeid(std::vector<std::vector<unsigned int>>))) {
862  TypeWithDict::byName("std::vector<std::vector<unsigned int> >");
863  }
864 
865  int debugLevel = pset.getUntrackedParameter<int>("DebugLevel");
866  if (debugLevel > 0) {
867  gDebug = debugLevel;
868  }
869 
870  // Enable Root implicit multi-threading
871  bool imt = pset.getUntrackedParameter<bool>("EnableIMT");
872  if (imt && not ROOT::IsImplicitMTEnabled()) {
873  //cmsRun uses global_control to set the number of allowed threads to use
874  // we need to tell ROOT the same value in order to avoid unnecessary warnings
875  ROOT::EnableImplicitMT(
876  oneapi::tbb::global_control::active_value(oneapi::tbb::global_control::max_allowed_parallelism));
877  }
878  }
void setRefCoreStreamerInTClass()
void installCustomHandler(int signum, CFUNC func)
std::shared_ptr< const void > sigSegvHandler_
std::shared_ptr< const void > sigFpeHandler_
std::shared_ptr< const void > sigBusHandler_
static TypeWithDict byName(std::string const &name)
Definition: TypeWithDict.cc:74
std::shared_ptr< const void > sigAbrtHandler_
The Signals That Services Can Subscribe To This is based on ActivityRegistry and is current per Services can connect to the signals distributed by the ActivityRegistry in order to monitor the activity of the application Each possible callback has some defined which we here list in angle e< void, edm::EventID const &, edm::Timestamp const & > We also list in braces which AR_WATCH_USING_METHOD_ is used for those or
Definition: Activities.doc:12
std::shared_ptr< const void > sigIllHandler_
std::shared_ptr< const void > sigTermHandler_
static std::vector< std::array< char, moduleBufferSize > > moduleListBuffers_
static std::unique_ptr< ThreadTracker > threadTracker_
unsigned int maxNumberOfThreads() const
Definition: SystemBounds.h:38
bool hasDictionary(std::type_info const &)

◆ ~InitRootHandlers()

edm::service::InitRootHandlers::~InitRootHandlers ( )
override

Definition at line 880 of file InitRootHandlers.cc.

References f, getGTfromDQMFile::obj, and threadTracker_.

880  {
881  // close all open ROOT files
882  TIter iter(gROOT->GetListOfFiles());
883  TObject* obj = nullptr;
884  while (nullptr != (obj = iter.Next())) {
885  TFile* f = dynamic_cast<TFile*>(obj);
886  if (f) {
887  // We get a new iterator each time,
888  // because closing a file can invalidate the iterator
889  f->Close();
890  iter = TIter(gROOT->GetListOfFiles());
891  }
892  }
893  //disengage from TBB to avoid possible at exit problems
894  threadTracker_.reset();
895  }
double f[11][100]
static std::unique_ptr< ThreadTracker > threadTracker_

Member Function Documentation

◆ cachePidInfo()

void edm::service::InitRootHandlers::cachePidInfo ( )
private

Definition at line 946 of file InitRootHandlers.cc.

References childToParent_, helperThread_, interactiveDebug_, edm::errors::OtherCMS, parentToChild_, pidString_, pidStringLength_, stacktraceHelperThread(), and AlCaHLTBitMon_QueryRunRegistry::string.

Referenced by InitRootHandlers().

946  {
947  if (helperThread_) {
948  //Another InitRootHandlers was initialized in this job, possibly
949  // because multiple EventProcessors are being used.
950  //In that case, we are already all setup
951  return;
952  }
953  std::string gdbcmd{"date; gdb -quiet -p %d"};
954  if (!interactiveDebug_) {
955  gdbcmd +=
956  " 2>&1 <<EOF |\n"
957  "set width 0\n"
958  "set height 0\n"
959  "set pagination no\n"
960  "thread apply all bt\n"
961  "EOF\n"
962  "/bin/sed -n -e 's/^\\((gdb) \\)*//' -e '/^#/p' -e '/^Thread/p'";
963  }
964  if (snprintf(pidString_, pidStringLength_ - 1, gdbcmd.c_str(), getpid()) >= pidStringLength_) {
965  std::ostringstream sstr;
966  sstr << "Unable to pre-allocate stacktrace handler information";
967  edm::Exception except(edm::errors::OtherCMS, sstr.str());
968  throw except;
969  }
970 
971  // These are initialized to -1; harmless to close an invalid FD.
972  // If this is called post-fork, we don't want to be communicating on
973  // these FDs as they are used internally by the parent.
974  close(childToParent_[0]);
975  close(childToParent_[1]);
976  childToParent_[0] = -1;
977  childToParent_[1] = -1;
978  close(parentToChild_[0]);
979  close(parentToChild_[1]);
980  parentToChild_[0] = -1;
981  parentToChild_[1] = -1;
982 
983  if (-1 == pipe2(childToParent_, O_CLOEXEC)) {
984  std::ostringstream sstr;
985  sstr << "Failed to create child-to-parent pipes (errno=" << errno << "): " << strerror(errno);
986  edm::Exception except(edm::errors::OtherCMS, sstr.str());
987  throw except;
988  }
989 
990  if (-1 == pipe2(parentToChild_, O_CLOEXEC)) {
991  close(childToParent_[0]);
992  close(childToParent_[1]);
993  childToParent_[0] = -1;
994  childToParent_[1] = -1;
995  std::ostringstream sstr;
996  sstr << "Failed to create child-to-parent pipes (errno=" << errno << "): " << strerror(errno);
997  edm::Exception except(edm::errors::OtherCMS, sstr.str());
998  throw except;
999  }
1000 
1001  helperThread_ = std::make_unique<std::thread>(stacktraceHelperThread);
1002  helperThread_->detach();
1003  }
static char pidString_[pidStringLength_]
static std::unique_ptr< std::thread > helperThread_
static constexpr int pidStringLength_

◆ enableWarnings_()

void edm::service::InitRootHandlers::enableWarnings_ ( )
overrideprivatevirtual

◆ fillDescriptions()

void edm::service::InitRootHandlers::fillDescriptions ( ConfigurationDescriptions descriptions)
static

Definition at line 908 of file InitRootHandlers.cc.

References edm::ConfigurationDescriptions::add(), and submitPVResolutionJobs::desc.

908  {
910  desc.setComment("Centralized interface to ROOT.");
911  desc.addUntracked<bool>("UnloadRootSigHandler", false)
912  ->setComment("If True, signals are handled by this service, rather than by ROOT.");
913  desc.addUntracked<bool>("ResetRootErrHandler", true)
914  ->setComment(
915  "If True, ROOT messages (e.g. errors, warnings) are handled by this service, rather than by ROOT.");
916  desc.addUntracked<bool>("AutoLibraryLoader", true)
917  ->setComment("If True, enables automatic loading of data dictionaries.");
918  desc.addUntracked<bool>("AutoClassParser", true)
919  ->setComment(
920  "If False, the automatic parsing of class headers for dictionaries when pre-built dictionaries are "
921  "missing is disable during module construction. The current implementation of disabling the parsing is "
922  "fragile, and may work only in a single-thread job that does not use reco::parser::cutParser() or "
923  "reco::parser::expressionParser() (and it certainly does not work on multiple threads).");
924  desc.addUntracked<bool>("LoadAllDictionaries", false)->setComment("If True, loads all ROOT dictionaries.");
925  desc.addUntracked<bool>("EnableIMT", true)->setComment("If True, calls ROOT::EnableImplicitMT().");
926  desc.addUntracked<bool>("AbortOnSignal", true)
927  ->setComment(
928  "If True, do an abort when a signal occurs that causes a crash. If False, ROOT will do an exit which "
929  "attempts to do a clean shutdown.");
930  desc.addUntracked<bool>("InteractiveDebug", false)
931  ->setComment(
932  "If True, leave gdb attached to cmsRun after a crash; "
933  "if False, attach gdb, print a stack trace, and quit gdb");
934  desc.addUntracked<int>("DebugLevel", 0)->setComment("Sets ROOT's gDebug value.");
935  desc.addUntracked<int>("StackTracePauseTime", 300)
936  ->setComment("Seconds to pause other threads during stack trace.");
937  descriptions.add("InitRootHandlers", desc);
938  }

◆ getPstackArgv()

char const *const * edm::service::InitRootHandlers::getPstackArgv ( )
staticprivate

Definition at line 940 of file InitRootHandlers.cc.

References pstackArgv_.

Referenced by edm::service::cmssw_stacktrace().

940 { return pstackArgv_; }
static char const *const pstackArgv_[]

◆ ignoreWarnings_()

void edm::service::InitRootHandlers::ignoreWarnings_ ( edm::RootHandlers::SeverityLevel  level)
overrideprivatevirtual

Implements edm::RootHandlers.

Definition at line 944 of file InitRootHandlers.cc.

References personalPlayback::level.

944 { s_ignoreWarnings = level; }

◆ stacktraceFromThread()

void edm::service::InitRootHandlers::stacktraceFromThread ( )
static

Definition at line 690 of file InitRootHandlers.cc.

References visDQMUpload::buf, childToParent_, parentToChild_, and mps_fire::result.

690  {
691  int result = full_write(parentToChild_[1], "1");
692  if (result < 0) {
693  full_cerr_write("\n\nAttempt to request stacktrace failed: ");
694  full_cerr_write(strerror(-result));
695  full_cerr_write("\n");
696  return;
697  }
698  char buf[2];
699  buf[1] = '\0';
700  if ((result = full_read(childToParent_[0], buf, 1, 5 * 60)) < 0) {
701  full_cerr_write("\n\nWaiting for stacktrace completion failed: ");
702  if (result == -ETIMEDOUT) {
703  full_cerr_write("timed out waiting for GDB to complete.");
704  } else {
705  full_cerr_write(strerror(-result));
706  }
707  full_cerr_write("\n");
708  return;
709  }
710  }

◆ stacktraceHelperThread()

void edm::service::InitRootHandlers::stacktraceHelperThread ( )
staticprivate

Definition at line 647 of file InitRootHandlers.cc.

References visDQMUpload::buf, childToParent_, edm::service::cmssw_stacktrace_fork(), parentToChild_, and mps_fire::result.

Referenced by cachePidInfo().

647  {
648  int toParent = childToParent_[1];
649  int fromParent = parentToChild_[0];
650  char buf[2];
651  buf[1] = '\0';
652 
653  while (true) {
654  int result = full_read(fromParent, buf, 1);
655  if (result < 0) {
656  // To avoid a deadlock (this function is NOT re-entrant), reset signals
657  // We never set them back to the CMSSW handler because we assume the parent
658  // thread will abort for us.
659  set_default_signals();
660  close(toParent);
661  full_cerr_write("\n\nTraceback helper thread failed to read from parent: ");
662  full_cerr_write(strerror(-result));
663  full_cerr_write("\n");
664  ::abort();
665  }
666  if (buf[0] == '1') {
667  set_default_signals();
669  full_write(toParent, buf);
670  } else if (buf[0] == '2') {
671  // We have just finished forking. Reload the file descriptors for thread
672  // communication.
673  close(toParent);
674  close(fromParent);
675  toParent = childToParent_[1];
676  fromParent = parentToChild_[0];
677  } else if (buf[0] == '3') {
678  break;
679  } else {
680  set_default_signals();
681  close(toParent);
682  full_cerr_write("\n\nTraceback helper thread got unknown command from parent: ");
683  full_cerr_write(buf);
684  full_cerr_write("\n");
685  ::abort();
686  }
687  }
688  }
static void cmssw_stacktrace_fork()

◆ stackTracePause()

static int edm::service::InitRootHandlers::stackTracePause ( )
inlinestatic

Definition at line 108 of file InitRootHandlers.cc.

References stackTracePause_.

108 { return stackTracePause_; }

◆ threadIDs()

static const ThreadTracker::Container_type& edm::service::InitRootHandlers::threadIDs ( )
inlinestatic

Definition at line 101 of file InitRootHandlers.cc.

References relativeConstraints::empty, and threadTracker_.

101  {
103  if (threadTracker_) {
104  return threadTracker_->IDs();
105  }
106  return empty;
107  }
oneapi::tbb::concurrent_unordered_set< pthread_t > Container_type
static std::unique_ptr< ThreadTracker > threadTracker_

◆ willBeUsingThreads()

void edm::service::InitRootHandlers::willBeUsingThreads ( )
overrideprivatevirtual

Implements edm::RootHandlers.

Definition at line 897 of file InitRootHandlers.cc.

897  {
898  //Tell Root we want to be multi-threaded
899  ROOT::EnableThreadSafety();
900 
901  //When threading, also have to keep ROOT from logging all TObjects into a list
902  TObject::SetObjectStat(false);
903 
904  //Have to avoid having Streamers modify themselves after they have been used
905  TVirtualStreamerInfo::Optimize(false);
906  }

Friends And Related Function Documentation

◆ cmssw_stacktrace

int cmssw_stacktrace ( void *  )
friend

Definition at line 743 of file InitRootHandlers.cc.

743  {
744  set_default_signals();
745 
747  // NOTE: this is NOT async-signal-safe at CERN's lxplus service.
748  // CERN uses LD_PRELOAD to replace execv with a function from libsnoopy which
749  // calls dlsym.
750 #ifdef __linux__
751  syscall(SYS_execve, "/bin/sh", argv, __environ);
752 #else
753  execv("/bin/sh", argv);
754 #endif
755  ::abort();
756  return 1;
757  }
static char const *const * getPstackArgv()

Member Data Documentation

◆ autoClassParser_

bool edm::service::InitRootHandlers::autoClassParser_
private

Definition at line 135 of file InitRootHandlers.cc.

Referenced by InitRootHandlers().

◆ autoLibraryLoader_

bool edm::service::InitRootHandlers::autoLibraryLoader_
private

Definition at line 134 of file InitRootHandlers.cc.

Referenced by InitRootHandlers().

◆ childToParent_

int edm::service::InitRootHandlers::childToParent_ = {-1, -1}
staticprivate

Definition at line 126 of file InitRootHandlers.cc.

Referenced by cachePidInfo(), stacktraceFromThread(), and stacktraceHelperThread().

◆ doneModules_

std::atomic< std::size_t > edm::service::InitRootHandlers::doneModules_
static

Definition at line 111 of file InitRootHandlers.cc.

◆ helperThread_

std::unique_ptr< std::thread > edm::service::InitRootHandlers::helperThread_
staticprivate

Definition at line 127 of file InitRootHandlers.cc.

Referenced by cachePidInfo().

◆ interactiveDebug_

bool edm::service::InitRootHandlers::interactiveDebug_
private

Definition at line 136 of file InitRootHandlers.cc.

Referenced by cachePidInfo().

◆ loadAllDictionaries_

bool edm::service::InitRootHandlers::loadAllDictionaries_
private

Definition at line 133 of file InitRootHandlers.cc.

◆ moduleListBuffers_

std::vector< std::array< char, moduleBufferSize > > edm::service::InitRootHandlers::moduleListBuffers_
static

Definition at line 110 of file InitRootHandlers.cc.

Referenced by InitRootHandlers().

◆ nextModule_

std::atomic< std::size_t > edm::service::InitRootHandlers::nextModule_
static

Definition at line 111 of file InitRootHandlers.cc.

◆ parentToChild_

int edm::service::InitRootHandlers::parentToChild_ = {-1, -1}
staticprivate

Definition at line 125 of file InitRootHandlers.cc.

Referenced by cachePidInfo(), stacktraceFromThread(), and stacktraceHelperThread().

◆ pidString_

char edm::service::InitRootHandlers::pidString_ = {}
staticprivate

Definition at line 123 of file InitRootHandlers.cc.

Referenced by cachePidInfo().

◆ pidStringLength_

constexpr int edm::service::InitRootHandlers::pidStringLength_ = 200
staticprivate

Definition at line 122 of file InitRootHandlers.cc.

Referenced by cachePidInfo().

◆ pstackArgv_

char const *const edm::service::InitRootHandlers::pstackArgv_ = {pstackName, dashC, InitRootHandlers::pidString_, nullptr}
staticprivate

Definition at line 124 of file InitRootHandlers.cc.

Referenced by getPstackArgv().

◆ resetErrHandler_

bool edm::service::InitRootHandlers::resetErrHandler_
private

Definition at line 132 of file InitRootHandlers.cc.

Referenced by InitRootHandlers().

◆ sigAbrtHandler_

std::shared_ptr<const void> edm::service::InitRootHandlers::sigAbrtHandler_
private

Definition at line 141 of file InitRootHandlers.cc.

Referenced by InitRootHandlers().

◆ sigBusHandler_

std::shared_ptr<const void> edm::service::InitRootHandlers::sigBusHandler_
private

Definition at line 137 of file InitRootHandlers.cc.

Referenced by InitRootHandlers().

◆ sigFpeHandler_

std::shared_ptr<const void> edm::service::InitRootHandlers::sigFpeHandler_
private

Definition at line 142 of file InitRootHandlers.cc.

Referenced by InitRootHandlers().

◆ sigIllHandler_

std::shared_ptr<const void> edm::service::InitRootHandlers::sigIllHandler_
private

Definition at line 139 of file InitRootHandlers.cc.

Referenced by InitRootHandlers().

◆ sigSegvHandler_

std::shared_ptr<const void> edm::service::InitRootHandlers::sigSegvHandler_
private

Definition at line 138 of file InitRootHandlers.cc.

Referenced by InitRootHandlers().

◆ sigTermHandler_

std::shared_ptr<const void> edm::service::InitRootHandlers::sigTermHandler_
private

Definition at line 140 of file InitRootHandlers.cc.

Referenced by InitRootHandlers().

◆ stackTracePause_

int edm::service::InitRootHandlers::stackTracePause_ = 300
staticprivate

Definition at line 129 of file InitRootHandlers.cc.

Referenced by InitRootHandlers(), and stackTracePause().

◆ threadTracker_

std::unique_ptr< InitRootHandlers::ThreadTracker > edm::service::InitRootHandlers::threadTracker_
staticprivate

Definition at line 128 of file InitRootHandlers.cc.

Referenced by InitRootHandlers(), threadIDs(), and ~InitRootHandlers().

◆ unloadSigHandler_

bool edm::service::InitRootHandlers::unloadSigHandler_
private

Definition at line 131 of file InitRootHandlers.cc.

Referenced by InitRootHandlers().