From 8c686cca8a3a0f9e010ef282cfd902c6f97d9e90 Mon Sep 17 00:00:00 2001 From: Matt Spinler Date: Fri, 20 Sep 2019 13:46:02 -0500 Subject: PEL: OpenBMC event log sev to PEL sev helper Add a function to map the OpenBMC event log severity values to PEL severity values. When creating a PEL from an OpenBMC event log, the event log will have its own severity property, and if the PEL message registry entry for that error doesn't supply its own severity (it's optional), use this function to come up with the PEL severity value to use. Signed-off-by: Matt Spinler Change-Id: I66aa001265d8acadb165de874e4ade03a8e28007 --- extensions/openpower-pels/openpower-pels.mk | 1 + extensions/openpower-pels/severity.cpp | 54 +++++++++++++++++++++++++++++ extensions/openpower-pels/severity.hpp | 20 +++++++++++ 3 files changed, 75 insertions(+) create mode 100644 extensions/openpower-pels/severity.cpp create mode 100644 extensions/openpower-pels/severity.hpp (limited to 'extensions') diff --git a/extensions/openpower-pels/openpower-pels.mk b/extensions/openpower-pels/openpower-pels.mk index aa69a2e..89143b2 100644 --- a/extensions/openpower-pels/openpower-pels.mk +++ b/extensions/openpower-pels/openpower-pels.mk @@ -12,4 +12,5 @@ phosphor_log_manager_SOURCES += \ extensions/openpower-pels/private_header.cpp \ extensions/openpower-pels/registry.cpp \ extensions/openpower-pels/repository.cpp \ + extensions/openpower-pels/severity.cpp \ extensions/openpower-pels/user_header.cpp diff --git a/extensions/openpower-pels/severity.cpp b/extensions/openpower-pels/severity.cpp new file mode 100644 index 0000000..1911c12 --- /dev/null +++ b/extensions/openpower-pels/severity.cpp @@ -0,0 +1,54 @@ +#include "severity.hpp" + +namespace openpower +{ +namespace pels +{ + +using LogSeverity = phosphor::logging::Entry::Level; + +/** + * @brief The major types of severity values, based on the + * the left nibble of the severity value. + */ +enum class PELSeverityType : uint8_t +{ + nonError = 0x00, + recovered = 0x10, + predictive = 0x20, + unrecoverable = 0x40, + critical = 0x50, + diagnostic = 0x60, + symptom = 0x70 +}; + +uint8_t convertOBMCSeverityToPEL(LogSeverity severity) +{ + uint8_t pelSeverity = static_cast(PELSeverityType::unrecoverable); + switch (severity) + { + case (LogSeverity::Notice): + case (LogSeverity::Informational): + case (LogSeverity::Debug): + pelSeverity = static_cast(PELSeverityType::nonError); + break; + + case (LogSeverity::Warning): + pelSeverity = static_cast(PELSeverityType::predictive); + break; + + case (LogSeverity::Critical): + pelSeverity = static_cast(PELSeverityType::critical); + break; + + case (LogSeverity::Emergency): + case (LogSeverity::Alert): + case (LogSeverity::Error): + pelSeverity = static_cast(PELSeverityType::unrecoverable); + break; + } + + return pelSeverity; +} +} // namespace pels +} // namespace openpower diff --git a/extensions/openpower-pels/severity.hpp b/extensions/openpower-pels/severity.hpp new file mode 100644 index 0000000..f2b9921 --- /dev/null +++ b/extensions/openpower-pels/severity.hpp @@ -0,0 +1,20 @@ +#pragma once + +#include "elog_entry.hpp" + +namespace openpower +{ +namespace pels +{ + +/** + * @brief Convert an OpenBMC event log severity to a PEL severity + * + * @param[in] severity - The OpenBMC event log severity + * + * @return uint8_t - The PEL severity value + */ +uint8_t convertOBMCSeverityToPEL(phosphor::logging::Entry::Level severity); + +} // namespace pels +} // namespace openpower -- cgit v1.2.1