xref: /openbmc/openpower-vpd-parser/vpd-manager/include/types.hpp (revision 315488401d4eaf1ba7dd0d82772a7be5652e13ee)
1 #pragma once
2 
3 #include <phosphor-logging/elog-errors.hpp>
4 #include <sdbusplus/asio/property.hpp>
5 #include <sdbusplus/server.hpp>
6 #include <xyz/openbmc_project/Common/Device/error.hpp>
7 #include <xyz/openbmc_project/Common/error.hpp>
8 
9 #include <tuple>
10 #include <unordered_map>
11 #include <variant>
12 
13 namespace vpd
14 {
15 namespace types
16 {
17 
18 using BiosProperty = std::tuple<
19     std::string, bool, std::string, std::string, std::string,
20     std::variant<int64_t, std::string>, std::variant<int64_t, std::string>,
21     std::vector<std::tuple<std::string, std::variant<int64_t, std::string>,
22                            std::string>>>;
23 using BiosBaseTable =
24     std::variant<std::monostate, std::map<std::string, BiosProperty>>;
25 using BiosBaseTableType = std::map<std::string, BiosBaseTable>;
26 using BiosAttributeCurrentValue =
27     std::variant<std::monostate, int64_t, std::string>;
28 using BiosAttributePendingValue = std::variant<int64_t, std::string>;
29 using BiosGetAttrRetType = std::tuple<std::string, BiosAttributeCurrentValue,
30                                       BiosAttributePendingValue>;
31 using PendingBIOSAttrItem =
32     std::pair<std::string, std::tuple<std::string, BiosAttributePendingValue>>;
33 using PendingBIOSAttrs = std::vector<PendingBIOSAttrItem>;
34 
35 using BinaryVector = std::vector<uint8_t>;
36 
37 // This covers mostly all the data type supported over Dbus for a property.
38 // clang-format off
39 using DbusVariantType = std::variant<
40     std::vector<std::tuple<std::string, std::string, std::string>>,
41     std::vector<std::string>,
42     std::vector<double>,
43     std::string,
44     int64_t,
45     uint64_t,
46     double,
47     int32_t,
48     uint32_t,
49     int16_t,
50     uint16_t,
51     uint8_t,
52     bool,
53     BinaryVector,
54     std::vector<uint32_t>,
55     std::vector<uint16_t>,
56     sdbusplus::message::object_path,
57     std::tuple<uint64_t, std::vector<std::tuple<std::string, std::string, double, uint64_t>>>,
58     std::vector<std::tuple<std::string, std::string>>,
59     std::vector<std::tuple<uint32_t, std::vector<uint32_t>>>,
60     std::vector<std::tuple<uint32_t, size_t>>,
61     std::vector<std::tuple<sdbusplus::message::object_path, std::string,
62                            std::string, std::string>>,
63     PendingBIOSAttrs
64  >;
65 
66 using MapperGetObject =
67     std::vector<std::pair<std::string, std::vector<std::string>>>;
68 using MapperGetSubTree = std::map<std::string, std::map<std::string, std::vector<std::string>>>;
69 
70 /* A type for holding the innermost map of property::value.*/
71 using IPZKwdValueMap = std::unordered_map<std::string, std::string>;
72 /*IPZ VPD Map of format <Record name, <keyword, value>>*/
73 using IPZVpdMap = std::unordered_map<std::string, IPZKwdValueMap>;
74 
75 /*Value types supported by Keyword VPD*/
76 using KWdVPDValueType = std::variant<BinaryVector,std::string, size_t>;
77 /* This hold map of parsed data of keyword VPD type*/
78 using KeywordVpdMap = std::unordered_map<std::string, KWdVPDValueType>;
79 
80 /**
81  * Both Keyword VPD parser and DDIMM parser stores the
82  * parsed VPD in the same format.
83  * To have better readability, two types are defined for underneath data structure.
84 */
85 using DdimmVpdMap = KeywordVpdMap;
86 
87 /**
88  * Both Keyword VPD parser and ISDIMM parser stores the
89  * parsed SPD in the same format.
90 */
91 using JedecSpdMap = KeywordVpdMap;
92 
93 /**
94  * Type to hold keyword::value map of a VPD.
95  * Variant can be extended to support additional type.
96 */
97 using VPDKWdValueMap = std::variant<IPZKwdValueMap, KeywordVpdMap>;
98 
99 /* Map<Property, Value>*/
100 using PropertyMap = std::map<std::string, DbusVariantType>;
101 /* Map<Interface<Property, Value>>*/
102 using InterfaceMap = std::map<std::string, PropertyMap>;
103 using ObjectMap = std::map<sdbusplus::message::object_path, InterfaceMap>;
104 
105 using KwSize = uint8_t;
106 using RecordId = uint8_t;
107 using RecordSize = uint16_t;
108 using RecordType = uint16_t;
109 using RecordOffset = uint16_t;
110 using RecordLength = uint16_t;
111 using ECCOffset = uint16_t;
112 using ECCLength = uint16_t;
113 using PoundKwSize = uint16_t;
114 
115 using RecordOffsetList = std::vector<uint32_t>;
116 
117 using VPDMapVariant = std::variant<std::monostate, IPZVpdMap, KeywordVpdMap>;
118 
119 using HWVerList = std::vector<std::pair<std::string, std::string>>;
120 /**
121  * Map of <systemIM, pair<Default version, vector<HW version, JSON suffix>>>
122 */
123 using SystemTypeMap =
124     std::unordered_map<std::string, std::pair<std::string, HWVerList>>;
125 
126 using Path = std::string;
127 using Record = std::string;
128 using Keyword = std::string;
129 
130 using IpzData = std::tuple<Record, Keyword, BinaryVector>;
131 using KwData = std::tuple<Keyword, BinaryVector>;
132 using VpdData = std::variant<IpzData, KwData>;
133 
134 using IpzType = std::tuple<Record, Keyword>;
135 using ReadVpdParams = std::variant<IpzType, Keyword>;
136 using WriteVpdParams = std::variant<IpzData, KwData>;
137 
138 using ListOfPaths = std::vector<sdbusplus::message::object_path>;
139 using RecordData = std::tuple<RecordOffset, RecordLength, ECCOffset, ECCLength>;
140 
141 using DbusInvalidArgument =
142     sdbusplus::xyz::openbmc_project::Common::Error::InvalidArgument;
143 using DbusNotAllowed = sdbusplus::xyz::openbmc_project::Common::Error::NotAllowed;
144 
145 using InvalidArgument = phosphor::logging::xyz::openbmc_project::Common::InvalidArgument;
146 
147 namespace DeviceError = sdbusplus::xyz::openbmc_project::Common::Device::Error;
148 
149 /* PEL Severity enum as defined in [xyz.openbmc_project.Logging.Entry.Level]log.hpp from 'phosphor-logging' repo. */
150 enum SeverityType
151 {
152     Notice,
153     Informational,
154     Debug,
155     Warning,
156     Critical,
157     Emergency,
158     Alert,
159     Error
160 };
161 
162 /* PEL callout priority from 'phosphor-logging' pel_types.hpp. If any change in 'phosphor-logging', it needs update here as well. */
163 enum CalloutPriority
164 {
165     High,
166     Medium,
167     MediumGroupA,
168     MediumGroupB,
169     MediumGroupC,
170     Low
171 };
172 
173 /* The Message property of the event entry for creating PEL, to introduce new message needs to be added in 'phosphor-logging' message_registry.json as well. */
174 enum ErrorType
175 {
176     DefaultValue,
177     InvalidVpdMessage,
178     VpdMismatch,
179     InvalidEeprom,
180     EccCheckFailed,
181     JsonFailure,
182     DbusFailure,
183     InvalidSystem,
184     EssentialFru,
185     GpioError,
186     InternalFailure, /* Should be used for any generic firmware failure */
187     FruMissing, /* Should be used in case of presence failure */
188     SystemTypeMismatch,
189     UndefinedError,
190     UnknownSystemSettings,
191     FirmwareError,
192     VpdParseError /* Should be used in case of any generic VPD parsing error. */
193 };
194 
195 /**
196  * @brief Enum which defines VPD collection modes
197  */
198 enum class VpdCollectionMode : uint8_t
199 {
200     HARDWARE_MODE,
201     MIXED_MODE,
202     FILE_MODE,
203     DEFAULT_MODE = HARDWARE_MODE
204 };
205 
206 using InventoryCalloutData = std::tuple<std::string, CalloutPriority>;
207 using DeviceCalloutData = std::tuple<std::string, std::string>;
208 using I2cBusCalloutData = std::tuple<std::string, std::string, std::string>;
209 
210 using ExceptionInfoVariant = std::variant<std::monostate, ErrorType, std::string>;
211 /* Error info map of format <Error format, Value> */
212 using ExceptionDataMap = std::map<std::string, ExceptionInfoVariant>;
213 
214 /* Pair of invalid record name and error encountered while parsing the record*/
215 using InvalidRecordEntry = std::pair<Record,ErrorType>;
216 /* List of invalid record entries*/
217 using InvalidRecordList = std::vector<InvalidRecordEntry>;
218 /* Map of inventory path -> Present property match object */
219 using FruPresenceMatchObjectMap = std::map<Path, std::shared_ptr<sdbusplus::bus::match_t>>;
220 /* A map of interface to match object*/
221 using MatchObjectInterfaceMap = std::map<std::string,std::shared_ptr<sdbusplus::bus::match_t>>;
222 /* A map of service name to match object interface map*/
223 using MatchObjectMap = std::map<std::string,MatchObjectInterfaceMap>;
224 
225 /*
226 * Tuple of Error type, severity, internal rc, userdata1, userdata2, symFru, Procedure
227 */
228 using PelInfoTuple =
229     std::tuple<types::ErrorType, std::optional<types::SeverityType>, uint8_t, std::optional<std::string>,
230                std::optional<std::string>, std::optional<std::string>,
231                std::optional<std::string>>;
232 /* A tuple of Dbus object path, interface and property*/
233 using DbusPropertyEntry = std::tuple<std::string, std::string, std::string>;
234 /* A list of Dbus property entries */
235 using DbusPropertyList = std::vector<DbusPropertyEntry>;
236 } // namespace types
237 } // namespace vpd
238