| 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 | 8c686cc | 2019-09-20 13:46:02 -0500 | [diff] [blame] | 4 | #include "severity.hpp" | 
 | 5 |  | 
 | 6 | namespace openpower | 
 | 7 | { | 
 | 8 | namespace pels | 
 | 9 | { | 
 | 10 |  | 
 | 11 | using LogSeverity = phosphor::logging::Entry::Level; | 
 | 12 |  | 
| Matt Spinler | 8b81ec0 | 2022-07-12 13:25:37 -0500 | [diff] [blame] | 13 | namespace | 
 | 14 | { | 
 | 15 |  | 
 | 16 | LogSeverity convertPELSeverityToOBMC(SeverityType pelSeverity) | 
 | 17 | { | 
 | 18 |     LogSeverity logSeverity = LogSeverity::Error; | 
 | 19 |  | 
 | 20 |     const std::map<SeverityType, LogSeverity> severities{ | 
 | 21 |         {SeverityType::nonError, LogSeverity::Informational}, | 
 | 22 |         {SeverityType::recovered, LogSeverity::Informational}, | 
 | 23 |         {SeverityType::predictive, LogSeverity::Warning}, | 
 | 24 |         {SeverityType::unrecoverable, LogSeverity::Error}, | 
 | 25 |         {SeverityType::critical, LogSeverity::Critical}, | 
 | 26 |         {SeverityType::diagnostic, LogSeverity::Error}, | 
 | 27 |         {SeverityType::symptom, LogSeverity::Warning}}; | 
 | 28 |  | 
 | 29 |     auto s = severities.find(pelSeverity); | 
 | 30 |     if (s != severities.end()) | 
 | 31 |     { | 
 | 32 |         logSeverity = s->second; | 
 | 33 |     } | 
 | 34 |  | 
 | 35 |     return logSeverity; | 
 | 36 | } | 
 | 37 |  | 
 | 38 | } // namespace | 
 | 39 |  | 
| Matt Spinler | 8c686cc | 2019-09-20 13:46:02 -0500 | [diff] [blame] | 40 | uint8_t convertOBMCSeverityToPEL(LogSeverity severity) | 
 | 41 | { | 
| Matt Spinler | a7525aa | 2019-11-01 11:11:07 -0500 | [diff] [blame] | 42 |     uint8_t pelSeverity = static_cast<uint8_t>(SeverityType::unrecoverable); | 
| Matt Spinler | 8c686cc | 2019-09-20 13:46:02 -0500 | [diff] [blame] | 43 |     switch (severity) | 
 | 44 |     { | 
 | 45 |         case (LogSeverity::Notice): | 
 | 46 |         case (LogSeverity::Informational): | 
 | 47 |         case (LogSeverity::Debug): | 
| Matt Spinler | a7525aa | 2019-11-01 11:11:07 -0500 | [diff] [blame] | 48 |             pelSeverity = static_cast<uint8_t>(SeverityType::nonError); | 
| Matt Spinler | 8c686cc | 2019-09-20 13:46:02 -0500 | [diff] [blame] | 49 |             break; | 
 | 50 |  | 
 | 51 |         case (LogSeverity::Warning): | 
| Matt Spinler | a7525aa | 2019-11-01 11:11:07 -0500 | [diff] [blame] | 52 |             pelSeverity = static_cast<uint8_t>(SeverityType::predictive); | 
| Matt Spinler | 8c686cc | 2019-09-20 13:46:02 -0500 | [diff] [blame] | 53 |             break; | 
 | 54 |  | 
 | 55 |         case (LogSeverity::Critical): | 
| Matt Spinler | a7525aa | 2019-11-01 11:11:07 -0500 | [diff] [blame] | 56 |             pelSeverity = static_cast<uint8_t>(SeverityType::critical); | 
| Matt Spinler | 8c686cc | 2019-09-20 13:46:02 -0500 | [diff] [blame] | 57 |             break; | 
 | 58 |  | 
 | 59 |         case (LogSeverity::Emergency): | 
 | 60 |         case (LogSeverity::Alert): | 
 | 61 |         case (LogSeverity::Error): | 
| Matt Spinler | a7525aa | 2019-11-01 11:11:07 -0500 | [diff] [blame] | 62 |             pelSeverity = static_cast<uint8_t>(SeverityType::unrecoverable); | 
| Matt Spinler | 8c686cc | 2019-09-20 13:46:02 -0500 | [diff] [blame] | 63 |             break; | 
 | 64 |     } | 
 | 65 |  | 
 | 66 |     return pelSeverity; | 
 | 67 | } | 
| Matt Spinler | 8b81ec0 | 2022-07-12 13:25:37 -0500 | [diff] [blame] | 68 |  | 
| Patrick Williams | 2529115 | 2025-02-01 08:21:42 -0500 | [diff] [blame] | 69 | std::optional<LogSeverity> fixupLogSeverity(LogSeverity obmcSeverity, | 
 | 70 |                                             SeverityType pelSeverity) | 
| Matt Spinler | 8b81ec0 | 2022-07-12 13:25:37 -0500 | [diff] [blame] | 71 | { | 
 | 72 |     bool isNonErrPelSev = (pelSeverity == SeverityType::nonError) || | 
 | 73 |                           (pelSeverity == SeverityType::recovered); | 
 | 74 |  | 
 | 75 |     bool isNonErrObmcSev = (obmcSeverity == LogSeverity::Notice) || | 
 | 76 |                            (obmcSeverity == LogSeverity::Informational) || | 
 | 77 |                            (obmcSeverity == LogSeverity::Debug); | 
 | 78 |  | 
 | 79 |     // If a nonError/recovered PEL, then the LogSeverity must be | 
 | 80 |     // Notice/Informational/Debug, otherwise set it to Informational. | 
 | 81 |     if (isNonErrPelSev && !isNonErrObmcSev) | 
 | 82 |     { | 
 | 83 |         return LogSeverity::Informational; | 
 | 84 |     } | 
 | 85 |  | 
 | 86 |     // If a Notice/Informational/Debug LogSeverity, then the PEL | 
 | 87 |     // severity must be nonError/recovered, otherwise set it | 
 | 88 |     // to an appropriate value based on the actual PEL severity. | 
 | 89 |     if (isNonErrObmcSev && !isNonErrPelSev) | 
 | 90 |     { | 
 | 91 |         return convertPELSeverityToOBMC(pelSeverity); | 
 | 92 |     } | 
 | 93 |  | 
 | 94 |     // If PEL is critical, the LogSeverity should be as well. | 
 | 95 |     if ((obmcSeverity != LogSeverity::Critical) && | 
 | 96 |         (pelSeverity == SeverityType::critical)) | 
 | 97 |     { | 
 | 98 |         return LogSeverity::Critical; | 
 | 99 |     } | 
 | 100 |  | 
 | 101 |     return std::nullopt; | 
 | 102 | } | 
 | 103 |  | 
| Matt Spinler | 8c686cc | 2019-09-20 13:46:02 -0500 | [diff] [blame] | 104 | } // namespace pels | 
 | 105 | } // namespace openpower |