blob: a056ce4a097f4c8efc18db9ab9061aa94622ccc9 [file] [log] [blame]
Matt Spinler711d51d2019-11-06 09:36:51 -06001/**
2 * Copyright © 2019 IBM Corporation
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
Matt Spinler09d64002019-09-11 14:29:46 -050016#include "failing_mtms.hpp"
17
Harisuddin Mohamed Isae2d1bf32020-02-06 17:32:38 +080018#include "json_utils.hpp"
Matt Spinler09d64002019-09-11 14:29:46 -050019#include "pel_types.hpp"
Harisuddin Mohamed Isabebeb942020-03-12 17:12:24 +080020#include "pel_values.hpp"
Matt Spinler09d64002019-09-11 14:29:46 -050021
Arya K Padman5bc26532024-04-10 06:19:25 -050022#include <phosphor-logging/lg2.hpp>
Matt Spinler09d64002019-09-11 14:29:46 -050023
Jayanth Othayoth1aa90d42023-09-13 04:25:45 -050024#include <format>
25
Matt Spinler09d64002019-09-11 14:29:46 -050026namespace openpower
27{
28namespace pels
29{
30
Harisuddin Mohamed Isabebeb942020-03-12 17:12:24 +080031namespace pv = openpower::pels::pel_values;
Arya K Padman5bc26532024-04-10 06:19:25 -050032
Matt Spinler09d64002019-09-11 14:29:46 -050033static constexpr uint8_t failingMTMSVersion = 0x01;
34
35FailingMTMS::FailingMTMS(const DataInterfaceBase& dataIface) :
36 _mtms(dataIface.getMachineTypeModel(), dataIface.getMachineSerialNumber())
37{
38 _header.id = static_cast<uint16_t>(SectionID::failingMTMS);
39 _header.size = FailingMTMS::flattenedSize();
40 _header.version = failingMTMSVersion;
41 _header.subType = 0;
42 _header.componentID = static_cast<uint16_t>(ComponentID::phosphorLogging);
Matt Spinleraa659472019-10-23 09:26:48 -050043
44 _valid = true;
Matt Spinler09d64002019-09-11 14:29:46 -050045}
46
47FailingMTMS::FailingMTMS(Stream& pel)
48{
49 try
50 {
51 unflatten(pel);
52 validate();
53 }
Patrick Williams66491c62021-10-06 12:23:37 -050054 catch (const std::exception& e)
Matt Spinler09d64002019-09-11 14:29:46 -050055 {
Arya K Padman5bc26532024-04-10 06:19:25 -050056 lg2::error("Cannot unflatten failing MTM section: {EXCEPTION}",
57 "EXCEPTION", e);
Matt Spinler09d64002019-09-11 14:29:46 -050058 _valid = false;
59 }
60}
61
62void FailingMTMS::validate()
63{
64 bool failed = false;
65
66 if (header().id != static_cast<uint16_t>(SectionID::failingMTMS))
67 {
Arya K Padman5bc26532024-04-10 06:19:25 -050068 lg2::error("Invalid failing MTMS section ID: {HEADER_ID}", "HEADER_ID",
69 lg2::hex, header().id);
Matt Spinler09d64002019-09-11 14:29:46 -050070 failed = true;
71 }
72
73 if (header().version != failingMTMSVersion)
74 {
Arya K Padman5bc26532024-04-10 06:19:25 -050075 lg2::error("Invalid failing MTMS version: {HEADER_VERSION}",
76 "HEADER_VERSION", lg2::hex, header().version);
Matt Spinler09d64002019-09-11 14:29:46 -050077 failed = true;
78 }
79
80 _valid = (failed) ? false : true;
81}
82
Matt Spinler06885452019-11-06 10:35:42 -060083void FailingMTMS::flatten(Stream& stream) const
Matt Spinler09d64002019-09-11 14:29:46 -050084{
85 stream << _header << _mtms;
86}
87
88void FailingMTMS::unflatten(Stream& stream)
89{
90 stream >> _header >> _mtms;
91}
92
Matt Spinlerb832aa52023-03-21 15:32:34 -050093std::optional<std::string> FailingMTMS::getJSON(uint8_t creatorID) const
Harisuddin Mohamed Isae2d1bf32020-02-06 17:32:38 +080094{
95 std::string json;
Harisuddin Mohamed Isabebeb942020-03-12 17:12:24 +080096 jsonInsert(json, pv::sectionVer, getNumberString("%d", _header.version), 1);
97 jsonInsert(json, pv::subSection, getNumberString("%d", _header.subType), 1);
98 jsonInsert(json, pv::createdBy,
Matt Spinlerb832aa52023-03-21 15:32:34 -050099 getComponentName(_header.componentID, creatorID), 1);
Harisuddin Mohamed Isae2d1bf32020-02-06 17:32:38 +0800100 jsonInsert(json, "Machine Type Model", _mtms.machineTypeAndModel(), 1);
101 jsonInsert(json, "Serial Number", trimEnd(_mtms.machineSerialNumber()), 1);
102 json.erase(json.size() - 2);
103 return json;
104}
Matt Spinler09d64002019-09-11 14:29:46 -0500105} // namespace pels
106} // namespace openpower