| Alexander Hansen | 40fb549 | 2025-10-28 17:56:12 +0100 | [diff] [blame^] | 1 | // SPDX-License-Identifier: Apache-2.0 | 
 | 2 | // SPDX-FileCopyrightText: Copyright 2019 IBM Corporation | 
 | 3 |  | 
| Matt Spinler | 03c1d91 | 2019-07-10 14:12:15 -0500 | [diff] [blame] | 4 | #include "user_header.hpp" | 
 | 5 |  | 
| Harisuddin Mohamed Isa | 600d15a | 2019-12-20 12:42:26 +0800 | [diff] [blame] | 6 | #include "json_utils.hpp" | 
| Matt Spinler | 1a94cc3 | 2019-09-11 13:32:12 -0500 | [diff] [blame] | 7 | #include "pel_types.hpp" | 
| Aatir | c148935 | 2019-12-09 13:13:20 -0600 | [diff] [blame] | 8 | #include "pel_values.hpp" | 
| Matt Spinler | fdb6a20 | 2019-09-20 14:09:20 -0500 | [diff] [blame] | 9 | #include "severity.hpp" | 
| Matt Spinler | 1a94cc3 | 2019-09-11 13:32:12 -0500 | [diff] [blame] | 10 |  | 
| Arya K Padman | 5bc2653 | 2024-04-10 06:19:25 -0500 | [diff] [blame] | 11 | #include <phosphor-logging/lg2.hpp> | 
| Matt Spinler | 03c1d91 | 2019-07-10 14:12:15 -0500 | [diff] [blame] | 12 |  | 
 | 13 | namespace openpower | 
 | 14 | { | 
 | 15 | namespace pels | 
 | 16 | { | 
 | 17 |  | 
| Aatir | c148935 | 2019-12-09 13:13:20 -0600 | [diff] [blame] | 18 | namespace pv = openpower::pels::pel_values; | 
| Matt Spinler | 03c1d91 | 2019-07-10 14:12:15 -0500 | [diff] [blame] | 19 |  | 
| Matt Spinler | cf5a8d0 | 2019-09-05 12:58:53 -0500 | [diff] [blame] | 20 | void UserHeader::unflatten(Stream& stream) | 
| Matt Spinler | 03c1d91 | 2019-07-10 14:12:15 -0500 | [diff] [blame] | 21 | { | 
| Matt Spinler | cf5a8d0 | 2019-09-05 12:58:53 -0500 | [diff] [blame] | 22 |     stream >> _header >> _eventSubsystem >> _eventScope >> _eventSeverity >> | 
 | 23 |         _eventType >> _reserved4Byte1 >> _problemDomain >> _problemVector >> | 
| Matt Spinler | eb11144 | 2019-11-07 13:05:36 -0600 | [diff] [blame] | 24 |         _actionFlags >> _states; | 
| Matt Spinler | 03c1d91 | 2019-07-10 14:12:15 -0500 | [diff] [blame] | 25 | } | 
 | 26 |  | 
| Matt Spinler | 0688545 | 2019-11-06 10:35:42 -0600 | [diff] [blame] | 27 | void UserHeader::flatten(Stream& stream) const | 
| Matt Spinler | 03c1d91 | 2019-07-10 14:12:15 -0500 | [diff] [blame] | 28 | { | 
| Matt Spinler | cf5a8d0 | 2019-09-05 12:58:53 -0500 | [diff] [blame] | 29 |     stream << _header << _eventSubsystem << _eventScope << _eventSeverity | 
 | 30 |            << _eventType << _reserved4Byte1 << _problemDomain << _problemVector | 
| Matt Spinler | eb11144 | 2019-11-07 13:05:36 -0600 | [diff] [blame] | 31 |            << _actionFlags << _states; | 
| Matt Spinler | 03c1d91 | 2019-07-10 14:12:15 -0500 | [diff] [blame] | 32 | } | 
 | 33 |  | 
| Matt Spinler | fdb6a20 | 2019-09-20 14:09:20 -0500 | [diff] [blame] | 34 | UserHeader::UserHeader(const message::Entry& entry, | 
| Matt Spinler | aadccc8 | 2020-04-10 14:33:42 -0500 | [diff] [blame] | 35 |                        phosphor::logging::Entry::Level severity, | 
| Vijay Lobo | 6b3f345 | 2021-04-15 23:04:42 -0500 | [diff] [blame] | 36 |                        const AdditionalData& additionalData, | 
| Matt Spinler | aadccc8 | 2020-04-10 14:33:42 -0500 | [diff] [blame] | 37 |                        const DataInterfaceBase& dataIface) | 
| Matt Spinler | fdb6a20 | 2019-09-20 14:09:20 -0500 | [diff] [blame] | 38 | { | 
 | 39 |     _header.id = static_cast<uint16_t>(SectionID::userHeader); | 
 | 40 |     _header.size = UserHeader::flattenedSize(); | 
 | 41 |     _header.version = userHeaderVersion; | 
 | 42 |     _header.subType = 0; | 
 | 43 |     _header.componentID = static_cast<uint16_t>(ComponentID::phosphorLogging); | 
 | 44 |  | 
| Matt Spinler | 23970b0 | 2022-02-25 16:34:46 -0600 | [diff] [blame] | 45 |     std::optional<uint8_t> subsys; | 
| Matt Spinler | fdb6a20 | 2019-09-20 14:09:20 -0500 | [diff] [blame] | 46 |  | 
| Sumit Kumar | 50bfa69 | 2022-01-06 06:48:26 -0600 | [diff] [blame] | 47 |     // Check for additional data - PEL_SUBSYSTEM | 
 | 48 |     auto ss = additionalData.getValue("PEL_SUBSYSTEM"); | 
 | 49 |     if (ss) | 
 | 50 |     { | 
| Matt Spinler | 6f07df3 | 2025-05-09 11:42:39 -0500 | [diff] [blame] | 51 |         auto eventSubsystem = std::stoul(*ss, nullptr, 16); | 
| Patrick Williams | 075c792 | 2024-08-16 15:19:49 -0400 | [diff] [blame] | 52 |         std::string subsystemString = | 
 | 53 |             pv::getValue(eventSubsystem, pel_values::subsystemValues); | 
| Matt Spinler | 23970b0 | 2022-02-25 16:34:46 -0600 | [diff] [blame] | 54 |         if (subsystemString == "invalid") | 
| Sumit Kumar | 50bfa69 | 2022-01-06 06:48:26 -0600 | [diff] [blame] | 55 |         { | 
| Arya K Padman | 5bc2653 | 2024-04-10 06:19:25 -0500 | [diff] [blame] | 56 |             lg2::warning( | 
 | 57 |                 "UH: Invalid SubSystem value in PEL_SUBSYSTEM: {PEL_SUBSYSTEM}", | 
 | 58 |                 "PEL_SUBSYSTEM", lg2::hex, eventSubsystem); | 
| Sumit Kumar | 50bfa69 | 2022-01-06 06:48:26 -0600 | [diff] [blame] | 59 |         } | 
 | 60 |         else | 
 | 61 |         { | 
| Matt Spinler | 23970b0 | 2022-02-25 16:34:46 -0600 | [diff] [blame] | 62 |             subsys = eventSubsystem; | 
| Sumit Kumar | 50bfa69 | 2022-01-06 06:48:26 -0600 | [diff] [blame] | 63 |         } | 
 | 64 |     } | 
| Matt Spinler | 23970b0 | 2022-02-25 16:34:46 -0600 | [diff] [blame] | 65 |     else | 
 | 66 |     { | 
 | 67 |         subsys = entry.subsystem; | 
 | 68 |     } | 
 | 69 |  | 
 | 70 |     if (subsys) | 
 | 71 |     { | 
 | 72 |         _eventSubsystem = *subsys; | 
 | 73 |     } | 
 | 74 |     else | 
 | 75 |     { | 
 | 76 |         // Gotta use something, how about 'others'. | 
| Arya K Padman | 5bc2653 | 2024-04-10 06:19:25 -0500 | [diff] [blame] | 77 |         lg2::warning( | 
| Matt Spinler | 23970b0 | 2022-02-25 16:34:46 -0600 | [diff] [blame] | 78 |             "No PEL subystem value supplied for error, using 'others'"); | 
 | 79 |         _eventSubsystem = 0x70; | 
 | 80 |     } | 
| Sumit Kumar | 50bfa69 | 2022-01-06 06:48:26 -0600 | [diff] [blame] | 81 |  | 
| Matt Spinler | fdb6a20 | 2019-09-20 14:09:20 -0500 | [diff] [blame] | 82 |     _eventScope = entry.eventScope.value_or( | 
 | 83 |         static_cast<uint8_t>(EventScope::entirePlatform)); | 
 | 84 |  | 
| Matt Spinler | aadccc8 | 2020-04-10 14:33:42 -0500 | [diff] [blame] | 85 |     { | 
| Sumit Kumar | 3b8ed7f | 2021-05-18 12:38:35 -0500 | [diff] [blame] | 86 |         bool mfgSevStatus = false; | 
 | 87 |         bool mfgActionFlagStatus = false; | 
| Sumit Kumar | 3b8ed7f | 2021-05-18 12:38:35 -0500 | [diff] [blame] | 88 |  | 
 | 89 |         // Get the mfg severity & action flags | 
 | 90 |         if (entry.mfgSeverity || entry.mfgActionFlags) | 
| Matt Spinler | aadccc8 | 2020-04-10 14:33:42 -0500 | [diff] [blame] | 91 |         { | 
| Matt Spinler | be952d2 | 2022-07-01 11:30:11 -0500 | [diff] [blame] | 92 |             std::optional<uint8_t> sev = std::nullopt; | 
 | 93 |             uint16_t val = 0; | 
 | 94 |  | 
| Sumit Kumar | 3b8ed7f | 2021-05-18 12:38:35 -0500 | [diff] [blame] | 95 |             if (entry.mfgSeverity) | 
 | 96 |             { | 
 | 97 |                 // Find the mf severity possibly dependent on the system type. | 
 | 98 |                 sev = getSeverity(entry.mfgSeverity.value(), dataIface); | 
 | 99 |             } | 
 | 100 |  | 
 | 101 |             if (entry.mfgActionFlags) | 
 | 102 |             { | 
 | 103 |                 // Find the mfg action flags | 
 | 104 |                 val = entry.mfgActionFlags.value(); | 
 | 105 |             } | 
 | 106 |  | 
 | 107 |             if (sev || val) | 
 | 108 |             { | 
 | 109 |                 bool mfgProp = dataIface.getQuiesceOnError(); | 
 | 110 |                 if (mfgProp) | 
 | 111 |                 { | 
 | 112 |                     if (sev) | 
 | 113 |                     { | 
 | 114 |                         _eventSeverity = *sev; | 
 | 115 |                         mfgSevStatus = true; | 
 | 116 |                     } | 
 | 117 |  | 
 | 118 |                     if (val) | 
 | 119 |                     { | 
 | 120 |                         _actionFlags = val; | 
 | 121 |                         mfgActionFlagStatus = true; | 
 | 122 |                     } | 
 | 123 |                 } | 
 | 124 |             } | 
 | 125 |         } | 
 | 126 |  | 
 | 127 |         if (!mfgSevStatus) | 
 | 128 |         { | 
 | 129 |             // Get the severity from the registry if it's there, otherwise get | 
 | 130 |             // it from the OpenBMC event log severity value. | 
 | 131 |             if (!entry.severity) | 
 | 132 |             { | 
 | 133 |                 _eventSeverity = convertOBMCSeverityToPEL(severity); | 
 | 134 |             } | 
 | 135 |             else | 
 | 136 |             { | 
 | 137 |                 // Find the severity possibly dependent on the system type. | 
 | 138 |                 auto sev = getSeverity(entry.severity.value(), dataIface); | 
 | 139 |                 if (sev) | 
 | 140 |                 { | 
 | 141 |                     _eventSeverity = *sev; | 
 | 142 |                 } | 
 | 143 |                 else | 
 | 144 |                 { | 
 | 145 |                     // Either someone  screwed up the message registry | 
 | 146 |                     // or getSystemNames failed. | 
| Arya K Padman | 5bc2653 | 2024-04-10 06:19:25 -0500 | [diff] [blame] | 147 |                     lg2::error( | 
 | 148 |                         "Failed finding the severity in the message registry ERROR={ERROR}", | 
 | 149 |                         "ERROR", entry.name); | 
| Sumit Kumar | 3b8ed7f | 2021-05-18 12:38:35 -0500 | [diff] [blame] | 150 |  | 
 | 151 |                     // Have to choose something, just use informational. | 
 | 152 |                     _eventSeverity = 0; | 
 | 153 |                 } | 
 | 154 |             } | 
 | 155 |         } | 
 | 156 |  | 
 | 157 |         // Convert Critical error (0x50) to Critical Error-System Termination | 
 | 158 |         // (0x51), if the AdditionalData is set to SYSTEM_TERM | 
 | 159 |         auto sevLevel = additionalData.getValue("SEVERITY_DETAIL"); | 
 | 160 |         if ((_eventSeverity & 0xF0) == 0x50) | 
 | 161 |         { | 
 | 162 |             if (sevLevel.value_or("") == "SYSTEM_TERM") | 
 | 163 |             { | 
 | 164 |                 // Change to Critical Error, System Termination | 
 | 165 |                 _eventSeverity = 0x51; | 
 | 166 |             } | 
 | 167 |         } | 
 | 168 |  | 
 | 169 |         if (entry.eventType) | 
 | 170 |         { | 
 | 171 |             _eventType = *entry.eventType; | 
| Matt Spinler | aadccc8 | 2020-04-10 14:33:42 -0500 | [diff] [blame] | 172 |         } | 
 | 173 |         else | 
 | 174 |         { | 
| Sumit Kumar | 3b8ed7f | 2021-05-18 12:38:35 -0500 | [diff] [blame] | 175 |             // There are different default event types for info errors | 
 | 176 |             // vs non info ones. | 
 | 177 |             auto sevType = static_cast<SeverityType>(_eventSeverity & 0xF0); | 
 | 178 |             _eventType = | 
 | 179 |                 (sevType == SeverityType::nonError) | 
 | 180 |                     ? static_cast<uint8_t>(EventType::miscInformational) | 
 | 181 |                     : static_cast<uint8_t>(EventType::notApplicable); | 
| Matt Spinler | aadccc8 | 2020-04-10 14:33:42 -0500 | [diff] [blame] | 182 |         } | 
| Matt Spinler | fdb6a20 | 2019-09-20 14:09:20 -0500 | [diff] [blame] | 183 |  | 
| Sumit Kumar | 3b8ed7f | 2021-05-18 12:38:35 -0500 | [diff] [blame] | 184 |         _reserved4Byte1 = 0; | 
 | 185 |  | 
 | 186 |         // No uses for problem domain or vector | 
 | 187 |         _problemDomain = 0; | 
 | 188 |         _problemVector = 0; | 
 | 189 |  | 
 | 190 |         // These will be set in pel_rules::check() if they're still | 
 | 191 |         // at the default value. | 
 | 192 |         if (!mfgActionFlagStatus) | 
| Vijay Lobo | 6b3f345 | 2021-04-15 23:04:42 -0500 | [diff] [blame] | 193 |         { | 
| Sumit Kumar | 3b8ed7f | 2021-05-18 12:38:35 -0500 | [diff] [blame] | 194 |             _actionFlags = entry.actionFlags.value_or(actionFlagsDefault); | 
| Vijay Lobo | 6b3f345 | 2021-04-15 23:04:42 -0500 | [diff] [blame] | 195 |         } | 
| Sumit Kumar | 3b8ed7f | 2021-05-18 12:38:35 -0500 | [diff] [blame] | 196 |  | 
 | 197 |         _states = 0; | 
 | 198 |  | 
 | 199 |         _valid = true; | 
| Vijay Lobo | 6b3f345 | 2021-04-15 23:04:42 -0500 | [diff] [blame] | 200 |     } | 
| Matt Spinler | fdb6a20 | 2019-09-20 14:09:20 -0500 | [diff] [blame] | 201 | } | 
 | 202 |  | 
| Matt Spinler | 03c1d91 | 2019-07-10 14:12:15 -0500 | [diff] [blame] | 203 | UserHeader::UserHeader(Stream& pel) | 
 | 204 | { | 
 | 205 |     try | 
 | 206 |     { | 
| Matt Spinler | cf5a8d0 | 2019-09-05 12:58:53 -0500 | [diff] [blame] | 207 |         unflatten(pel); | 
| Matt Spinler | 03c1d91 | 2019-07-10 14:12:15 -0500 | [diff] [blame] | 208 |         validate(); | 
 | 209 |     } | 
 | 210 |     catch (const std::exception& e) | 
 | 211 |     { | 
| Arya K Padman | 5bc2653 | 2024-04-10 06:19:25 -0500 | [diff] [blame] | 212 |         lg2::error("Cannot unflatten user header: {EXCEPTION}", "EXCEPTION", e); | 
| Matt Spinler | 03c1d91 | 2019-07-10 14:12:15 -0500 | [diff] [blame] | 213 |         _valid = false; | 
 | 214 |     } | 
 | 215 | } | 
 | 216 |  | 
 | 217 | void UserHeader::validate() | 
 | 218 | { | 
 | 219 |     bool failed = false; | 
| Matt Spinler | 1a94cc3 | 2019-09-11 13:32:12 -0500 | [diff] [blame] | 220 |     if (header().id != static_cast<uint16_t>(SectionID::userHeader)) | 
| Matt Spinler | 03c1d91 | 2019-07-10 14:12:15 -0500 | [diff] [blame] | 221 |     { | 
| Arya K Padman | 5bc2653 | 2024-04-10 06:19:25 -0500 | [diff] [blame] | 222 |         lg2::error("Invalid user header section ID: {HEADER_ID}", "HEADER_ID", | 
 | 223 |                    lg2::hex, header().id); | 
| Matt Spinler | 03c1d91 | 2019-07-10 14:12:15 -0500 | [diff] [blame] | 224 |         failed = true; | 
| Matt Spinler | 03c1d91 | 2019-07-10 14:12:15 -0500 | [diff] [blame] | 225 |     } | 
 | 226 |  | 
 | 227 |     if (header().version != userHeaderVersion) | 
 | 228 |     { | 
| Arya K Padman | 5bc2653 | 2024-04-10 06:19:25 -0500 | [diff] [blame] | 229 |         lg2::error("Invalid user header version: {HEADER_VERSION}", | 
 | 230 |                    "HEADER_VERSION", lg2::hex, header().version); | 
| Matt Spinler | 03c1d91 | 2019-07-10 14:12:15 -0500 | [diff] [blame] | 231 |         failed = true; | 
| Matt Spinler | 03c1d91 | 2019-07-10 14:12:15 -0500 | [diff] [blame] | 232 |     } | 
 | 233 |  | 
 | 234 |     _valid = (failed) ? false : true; | 
 | 235 | } | 
 | 236 |  | 
| Matt Spinler | b832aa5 | 2023-03-21 15:32:34 -0500 | [diff] [blame] | 237 | std::optional<std::string> UserHeader::getJSON(uint8_t creatorID) const | 
| Aatir Manzur | ad0e047 | 2019-10-07 13:18:37 -0500 | [diff] [blame] | 238 | { | 
 | 239 |     std::string severity; | 
 | 240 |     std::string subsystem; | 
 | 241 |     std::string eventScope; | 
 | 242 |     std::string eventType; | 
| Harisuddin Mohamed Isa | 600d15a | 2019-12-20 12:42:26 +0800 | [diff] [blame] | 243 |     std::vector<std::string> actionFlags; | 
| Aatir | c148935 | 2019-12-09 13:13:20 -0600 | [diff] [blame] | 244 |     severity = pv::getValue(_eventSeverity, pel_values::severityValues); | 
 | 245 |     subsystem = pv::getValue(_eventSubsystem, pel_values::subsystemValues); | 
 | 246 |     eventScope = pv::getValue(_eventScope, pel_values::eventScopeValues); | 
 | 247 |     eventType = pv::getValue(_eventType, pel_values::eventTypeValues); | 
| Patrick Williams | 075c792 | 2024-08-16 15:19:49 -0400 | [diff] [blame] | 248 |     actionFlags = | 
 | 249 |         pv::getValuesBitwise(_actionFlags, pel_values::actionFlagsValues); | 
| Matt Spinler | 455587e | 2020-01-15 14:31:52 -0600 | [diff] [blame] | 250 |  | 
 | 251 |     std::string hostState{"Invalid"}; | 
| Vijay Lobo | 2fb1021 | 2021-08-22 23:24:16 -0500 | [diff] [blame] | 252 |     std::string hmcState{"Invalid"}; | 
| Matt Spinler | 455587e | 2020-01-15 14:31:52 -0600 | [diff] [blame] | 253 |     auto iter = pv::transmissionStates.find( | 
 | 254 |         static_cast<TransmissionState>(hostTransmissionState())); | 
 | 255 |     if (iter != pv::transmissionStates.end()) | 
 | 256 |     { | 
 | 257 |         hostState = iter->second; | 
 | 258 |     } | 
| Vijay Lobo | 2fb1021 | 2021-08-22 23:24:16 -0500 | [diff] [blame] | 259 |     auto iter1 = pv::transmissionStates.find( | 
 | 260 |         static_cast<TransmissionState>(hmcTransmissionState())); | 
 | 261 |     if (iter1 != pv::transmissionStates.end()) | 
 | 262 |     { | 
 | 263 |         hmcState = iter1->second; | 
 | 264 |     } | 
| Matt Spinler | 455587e | 2020-01-15 14:31:52 -0600 | [diff] [blame] | 265 |  | 
| Harisuddin Mohamed Isa | 600d15a | 2019-12-20 12:42:26 +0800 | [diff] [blame] | 266 |     std::string uh; | 
| Harisuddin Mohamed Isa | bebeb94 | 2020-03-12 17:12:24 +0800 | [diff] [blame] | 267 |     jsonInsert(uh, pv::sectionVer, getNumberString("%d", userHeaderVersion), 1); | 
 | 268 |     jsonInsert(uh, pv::subSection, getNumberString("%d", _header.subType), 1); | 
 | 269 |     jsonInsert(uh, "Log Committed by", | 
| Matt Spinler | b832aa5 | 2023-03-21 15:32:34 -0500 | [diff] [blame] | 270 |                getComponentName(_header.componentID, creatorID), 1); | 
| Harisuddin Mohamed Isa | 600d15a | 2019-12-20 12:42:26 +0800 | [diff] [blame] | 271 |     jsonInsert(uh, "Subsystem", subsystem, 1); | 
 | 272 |     jsonInsert(uh, "Event Scope", eventScope, 1); | 
 | 273 |     jsonInsert(uh, "Event Severity", severity, 1); | 
 | 274 |     jsonInsert(uh, "Event Type", eventType, 1); | 
 | 275 |     jsonInsertArray(uh, "Action Flags", actionFlags, 1); | 
| Matt Spinler | 455587e | 2020-01-15 14:31:52 -0600 | [diff] [blame] | 276 |     jsonInsert(uh, "Host Transmission", hostState, 1); | 
| Vijay Lobo | 2fb1021 | 2021-08-22 23:24:16 -0500 | [diff] [blame] | 277 |     jsonInsert(uh, "HMC Transmission", hmcState, 1); | 
| Harisuddin Mohamed Isa | 600d15a | 2019-12-20 12:42:26 +0800 | [diff] [blame] | 278 |     uh.erase(uh.size() - 2); | 
| Aatir Manzur | ad0e047 | 2019-10-07 13:18:37 -0500 | [diff] [blame] | 279 |     return uh; | 
 | 280 | } | 
| Matt Spinler | aadccc8 | 2020-04-10 14:33:42 -0500 | [diff] [blame] | 281 |  | 
 | 282 | std::optional<uint8_t> UserHeader::getSeverity( | 
 | 283 |     const std::vector<message::RegistrySeverity>& severities, | 
| Matt Spinler | 1ab6696 | 2020-10-29 13:21:44 -0500 | [diff] [blame] | 284 |     const DataInterfaceBase& dataIface) const | 
| Matt Spinler | aadccc8 | 2020-04-10 14:33:42 -0500 | [diff] [blame] | 285 | { | 
 | 286 |     const uint8_t* s = nullptr; | 
| Matt Spinler | 1ab6696 | 2020-10-29 13:21:44 -0500 | [diff] [blame] | 287 |     std::vector<std::string> systemNames; | 
 | 288 |  | 
 | 289 |     // getSystemNames makes D-Bus calls, so only call it if we | 
 | 290 |     // know we'll need it because there is a system name in the sev list | 
 | 291 |     if (std::any_of(severities.begin(), severities.end(), | 
 | 292 |                     [](const auto& sev) { return !sev.system.empty(); })) | 
 | 293 |     { | 
 | 294 |         try | 
 | 295 |         { | 
 | 296 |             systemNames = dataIface.getSystemNames(); | 
 | 297 |         } | 
 | 298 |         catch (const std::exception& e) | 
 | 299 |         { | 
| Arya K Padman | 5bc2653 | 2024-04-10 06:19:25 -0500 | [diff] [blame] | 300 |             lg2::error( | 
 | 301 |                 "Failed trying to look up system names on D-Bus ERROR={ERROR}", | 
 | 302 |                 "ERROR", e); | 
| Matt Spinler | 1ab6696 | 2020-10-29 13:21:44 -0500 | [diff] [blame] | 303 |             return std::nullopt; | 
 | 304 |         } | 
 | 305 |     } | 
| Matt Spinler | aadccc8 | 2020-04-10 14:33:42 -0500 | [diff] [blame] | 306 |  | 
 | 307 |     // Find the severity to use for this system type, or use the default | 
 | 308 |     // entry (where no system type is specified). | 
 | 309 |     for (const auto& sev : severities) | 
 | 310 |     { | 
| Matt Spinler | 6ea4d5f | 2020-05-20 13:31:07 -0500 | [diff] [blame] | 311 |         if (std::find(systemNames.begin(), systemNames.end(), sev.system) != | 
 | 312 |             systemNames.end()) | 
| Matt Spinler | aadccc8 | 2020-04-10 14:33:42 -0500 | [diff] [blame] | 313 |         { | 
 | 314 |             s = &sev.severity; | 
 | 315 |             break; | 
 | 316 |         } | 
 | 317 |         else if (sev.system.empty()) | 
 | 318 |         { | 
 | 319 |             s = &sev.severity; | 
 | 320 |         } | 
 | 321 |     } | 
 | 322 |  | 
 | 323 |     if (s) | 
 | 324 |     { | 
 | 325 |         return *s; | 
 | 326 |     } | 
 | 327 |  | 
 | 328 |     return std::nullopt; | 
 | 329 | } | 
 | 330 |  | 
| Matt Spinler | 03c1d91 | 2019-07-10 14:12:15 -0500 | [diff] [blame] | 331 | } // namespace pels | 
 | 332 | } // namespace openpower |