From fb21345bfd0d5e7a2481a79c242881010743a1da Mon Sep 17 00:00:00 2001 From: Yonas Habteab Date: Fri, 25 Feb 2022 15:17:33 +0100 Subject: [PATCH 1/2] ConfigItem: Use atomic variables for notified and commited items count --- lib/config/configitem.cpp | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/lib/config/configitem.cpp b/lib/config/configitem.cpp index 8e6ab0e91..37c711d65 100644 --- a/lib/config/configitem.cpp +++ b/lib/config/configitem.cpp @@ -21,6 +21,7 @@ #include "base/function.hpp" #include "base/utility.hpp" #include +#include #include #include #include @@ -462,7 +463,7 @@ bool ConfigItem::CommitNewItems(const ActivationContext::Ptr& context, WorkQueue if (unresolved_dep) continue; - int committed_items = 0; + std::atomic committed_items(0); upq.ParallelFor(items, [&type, &committed_items](const ItemPair& ip) { const ConfigItem::Ptr& item = ip.first; @@ -514,7 +515,7 @@ bool ConfigItem::CommitNewItems(const ActivationContext::Ptr& context, WorkQueue if (unresolved_dep) continue; - int notified_items = 0; + std::atomic notified_items(0); upq.ParallelFor(items, [&type, ¬ified_items](const ItemPair& ip) { const ConfigItem::Ptr& item = ip.first; From f00a3c96931cfeb70e48fc7427e8a07c2e090224 Mon Sep 17 00:00:00 2001 From: Yonas Habteab Date: Fri, 25 Feb 2022 15:18:28 +0100 Subject: [PATCH 2/2] ConfigObject: Initialize local static var at declaration to ensure thread safety --- lib/base/configobject.cpp | 8 +------- 1 file changed, 1 insertion(+), 7 deletions(-) diff --git a/lib/base/configobject.cpp b/lib/base/configobject.cpp index 81ea917b6..d4592b4ef 100644 --- a/lib/base/configobject.cpp +++ b/lib/base/configobject.cpp @@ -413,13 +413,7 @@ void ConfigObject::OnConfigLoaded() void ConfigObject::OnAllConfigLoaded() { - static ConfigType *ctype; - - if (!ctype) { - Type::Ptr type = Type::GetByName("Zone"); - ctype = dynamic_cast(type.get()); - } - + static ConfigType *ctype = dynamic_cast(Type::GetByName("Zone").get()); String zoneName = GetZoneName(); if (!zoneName.IsEmpty())