| 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 |