diff options
author | Matt Spinler <spinler@us.ibm.com> | 2019-09-10 15:24:10 -0500 |
---|---|---|
committer | Matt Spinler <spinler@us.ibm.com> | 2019-09-27 14:26:13 -0500 |
commit | b666433986470ba76ed7357ea026db39ad0b404b (patch) | |
tree | b370fb517086b037a5c17b468f89003d987b4bd7 /extensions/openpower-pels | |
parent | 72575f51ed7b7ead4d55c87b23c186d882ae8345 (diff) | |
download | phosphor-logging-b666433986470ba76ed7357ea026db39ad0b404b.tar.gz phosphor-logging-b666433986470ba76ed7357ea026db39ad0b404b.zip |
PEL: MTMS class to handle the type-model and SN
This class represents the (M)achine (T)ype-(M)odel (S)erial number
structure for the PEL, where it is used in both the ExtendedUserHeader
and FailingMTMS sections.
It consists of an 8 byte machine type+model field of the form TTT-MMMM,
followed by a 12 byte machine serial number field. Unused bytes are set
to 0.
Note that this is not a PEL section itself. It's just used by other PEL
sections.
Signed-off-by: Matt Spinler <spinler@us.ibm.com>
Change-Id: I15f9858e951a913ab2353cf93b7f20cc2709c502
Diffstat (limited to 'extensions/openpower-pels')
-rw-r--r-- | extensions/openpower-pels/mtms.cpp | 80 | ||||
-rw-r--r-- | extensions/openpower-pels/mtms.hpp | 128 | ||||
-rw-r--r-- | extensions/openpower-pels/openpower-pels.mk | 1 |
3 files changed, 209 insertions, 0 deletions
diff --git a/extensions/openpower-pels/mtms.cpp b/extensions/openpower-pels/mtms.cpp new file mode 100644 index 0000000..355431f --- /dev/null +++ b/extensions/openpower-pels/mtms.cpp @@ -0,0 +1,80 @@ +#include "mtms.hpp" + +namespace openpower +{ +namespace pels +{ + +MTMS::MTMS() +{ + memset(_machineTypeAndModel.data(), 0, mtmSize); + memset(_serialNumber.data(), 0, snSize); +} + +MTMS::MTMS(const std::string& typeModel, const std::string& serialNumber) +{ + memset(_machineTypeAndModel.data(), 0, mtmSize); + memset(_serialNumber.data(), 0, snSize); + + // Copy in as much as the fields as possible + for (size_t i = 0; i < mtmSize; i++) + { + if (typeModel.size() > i) + { + _machineTypeAndModel[i] = typeModel[i]; + } + } + + for (size_t i = 0; i < snSize; i++) + { + if (serialNumber.size() > i) + { + _serialNumber[i] = serialNumber[i]; + } + } +} + +MTMS::MTMS(Stream& stream) +{ + for (size_t i = 0; i < mtmSize; i++) + { + stream >> _machineTypeAndModel[i]; + } + + for (size_t i = 0; i < snSize; i++) + { + stream >> _serialNumber[i]; + } +} + +Stream& operator<<(Stream& s, MTMS& mtms) +{ + for (size_t i = 0; i < MTMS::mtmSize; i++) + { + s << mtms.machineTypeAndModel()[i]; + } + + for (size_t i = 0; i < MTMS::snSize; i++) + { + s << mtms.machineSerialNumber()[i]; + } + + return s; +} + +Stream& operator>>(Stream& s, MTMS& mtms) +{ + for (size_t i = 0; i < MTMS::mtmSize; i++) + { + s >> mtms.machineTypeAndModel()[i]; + } + + for (size_t i = 0; i < MTMS::snSize; i++) + { + s >> mtms.machineSerialNumber()[i]; + } + + return s; +} +} // namespace pels +} // namespace openpower diff --git a/extensions/openpower-pels/mtms.hpp b/extensions/openpower-pels/mtms.hpp new file mode 100644 index 0000000..fe8723d --- /dev/null +++ b/extensions/openpower-pels/mtms.hpp @@ -0,0 +1,128 @@ +#pragma once + +#include "stream.hpp" + +#include <string> + +namespace openpower +{ +namespace pels +{ + +/** @class MTMS + * + * (M)achine (T)ype-(M)odel (S)erialNumber + * + * Represents the PEL's Machine Type / Model / Serial Number + * structure, which shows up in multiple places in a PEL. + * + * It holds 8 bytes for the Type+Model, and 12 for the SN. + * Unused bytes are set to 0s. + * + * The type and model are combined into a single field. + */ +class MTMS +{ + public: + MTMS(const MTMS&) = default; + MTMS& operator=(const MTMS&) = default; + MTMS(MTMS&&) = default; + MTMS& operator=(MTMS&&) = default; + ~MTMS() = default; + + enum + { + mtmSize = 8, + snSize = 12 + }; + + /** + * @brief Constructor + */ + MTMS(); + + /** + * @brief Constructor + * + * @param[in] typeModel - The machine type+model + * @param[in] serialNumber - The machine serial number + */ + MTMS(const std::string& typeModel, const std::string& serialNumber); + + /** + * @brief Constructor + * + * Fills in this class's data fields from the stream. + * + * @param[in] pel - the PEL data stream + */ + explicit MTMS(Stream& stream); + + /** + * @brief Returns the machine type/model value + * + * @return std::array<uint8_t, mtmSize>& - The TM value + */ + std::array<uint8_t, mtmSize>& machineTypeAndModel() + { + return _machineTypeAndModel; + } + + /** + * @brief Returns the machine serial number value + * + * @return std::array<uint8_t, snSize>& - The SN value + */ + std::array<uint8_t, snSize>& machineSerialNumber() + { + return _serialNumber; + } + + /** + * @brief Returns the size of the data when flattened + * + * @return size_t - The size of the data + */ + static constexpr size_t flattenedSize() + { + return mtmSize + snSize; + } + + private: + /** + * @brief The type+model value + * + * Of the form TTTT-MMM where: + * TTTT = machine type + * MMM = machine model + */ + std::array<uint8_t, mtmSize> _machineTypeAndModel; + + /** + * @brief Machine Serial Number + */ + std::array<uint8_t, snSize> _serialNumber; +}; + +/** + * @brief Stream extraction operator for MTMS + * + * @param[in] s - the stream + * @param[out] mtms - the MTMS object + * + * @return Stream& + */ +Stream& operator>>(Stream& s, MTMS& mtms); + +/** + * @brief Stream insertion operator for MTMS + * + * @param[out] s - the stream + * @param[in] mtms - the MTMS object + * + * @return Stream& + */ +Stream& operator<<(Stream& s, MTMS& mtms); + +} // namespace pels +} // namespace openpower diff --git a/extensions/openpower-pels/openpower-pels.mk b/extensions/openpower-pels/openpower-pels.mk index def28a1..6a58db8 100644 --- a/extensions/openpower-pels/openpower-pels.mk +++ b/extensions/openpower-pels/openpower-pels.mk @@ -3,6 +3,7 @@ phosphor_log_manager_SOURCES += \ extensions/openpower-pels/entry_points.cpp \ extensions/openpower-pels/log_id.cpp \ extensions/openpower-pels/manager.cpp \ + extensions/openpower-pels/mtms.cpp \ extensions/openpower-pels/paths.cpp \ extensions/openpower-pels/pel.cpp \ extensions/openpower-pels/private_header.cpp \ |