Skip to content

Commit

Permalink
Fix root-project#11383 (deadlock at initialization)
Browse files Browse the repository at this point in the history
Previously if a message (for example warning of duplicate dictionary)
happened during intialization, it would trigger the initialization of gROOT
and could trigger a nested Warning. for example due to the duplicate rootmap
file entry and would cause a dead lock (recursiverly taking the
non recursive lock GetErrorMutex().
  • Loading branch information
pcanal committed Sep 16, 2022
1 parent 304a9ab commit d2afcb3
Showing 1 changed file with 3 additions and 1 deletion.
4 changes: 3 additions & 1 deletion core/base/src/TErrorDefaultHandler.cxx
Original file line number Diff line number Diff line change
Expand Up @@ -101,12 +101,14 @@ static void DebugPrint(const char *fmt, ...)
void DefaultErrorHandler(Int_t level, Bool_t abort_bool, const char *location, const char *msg)
{
if (gErrorIgnoreLevel == kUnset) {
// This can also print error messages, so we need to do it outside the lock
auto cstrlevel = gEnv->GetValue("Root.ErrorIgnoreLevel", "Print");

std::lock_guard<std::mutex> guard(*GetErrorMutex());

gErrorIgnoreLevel = 0;
if (gEnv) {
std::string slevel;
auto cstrlevel = gEnv->GetValue("Root.ErrorIgnoreLevel", "Print");
while (cstrlevel && *cstrlevel) {
slevel.push_back(tolower(*cstrlevel));
cstrlevel++;
Expand Down

0 comments on commit d2afcb3

Please sign in to comment.