blob: 6e858886e21e87aeaab3b511f398d9176e825e54 [file] [log] [blame]
PriyangaRamasamy1f0b1e62020-02-20 20:48:25 +05301#include "config.h"
2
PriyangaRamasamyc0a534f2020-08-24 21:29:18 +05303#include "editor_impl.hpp"
Sunny Srivastava6c71c9d2021-04-15 04:43:54 -05004#include "ibm_vpd_utils.hpp"
PriyangaRamasamy1f0b1e62020-02-20 20:48:25 +05305#include "types.hpp"
6
7#include <nlohmann/json.hpp>
PriyangaRamasamy887a42a2020-09-03 00:33:57 +05308#include <string>
PriyangaRamasamy1f0b1e62020-02-20 20:48:25 +05309
10using json = nlohmann::json;
11
Priyanga Ramasamy43ffcf72022-06-08 14:10:11 -050012// <S.no, Record, Keyword, D-Bus value, HW value, Data mismatch>
13using SystemCriticalData =
14 std::vector<std::tuple<int, std::string, std::string, std::string,
15 std::string, std::string>>;
16
PriyangaRamasamy1f0b1e62020-02-20 20:48:25 +053017class VpdTool
18{
19 private:
20 const std::string fruPath;
PriyangaRamasamy02d4d4e2020-02-24 14:54:45 +053021 const std::string recordName;
22 const std::string keyword;
PriyangaRamasamyd09d2ec2020-03-12 14:11:50 +053023 const std::string value;
PriyangaRamasamy8cc5b152021-06-03 13:05:17 -050024 bool objFound = true;
Priyanga Ramasamy43ffcf72022-06-08 14:10:11 -050025 SystemCriticalData recKwData;
PriyangaRamasamy1f0b1e62020-02-20 20:48:25 +053026
Alpana Kumarib6965f12020-06-01 00:32:21 -050027 // Store Type of FRU
28 std::string fruType;
29
PriyangaRamasamy1f0b1e62020-02-20 20:48:25 +053030 /**
31 * @brief Debugger
32 * Displays the output in JSON.
33 *
34 * @param[in] output - json output to be displayed
35 */
36 void debugger(json output);
37
38 /**
39 * @brief make Dbus Call
40 *
41 * @param[in] objectName - dbus Object
42 * @param[in] interface - dbus Interface
43 * @param[in] kw - keyword under the interface
44 *
45 * @return dbus call response
46 */
47 auto makeDBusCall(const std::string& objectName,
48 const std::string& interface, const std::string& kw);
49
50 /**
PriyangaRamasamy1f0b1e62020-02-20 20:48:25 +053051 * @brief Get VINI properties
52 * Making a dbus call for properties [SN, PN, CC, FN, DR]
53 * under VINI interface.
54 *
55 * @param[in] invPath - Value of inventory Path
PriyangaRamasamy1f0b1e62020-02-20 20:48:25 +053056 *
57 * @return json output which gives the properties under invPath's VINI
58 * interface
59 */
PriyangaRamasamy8cc5b152021-06-03 13:05:17 -050060 json getVINIProperties(std::string invPath);
PriyangaRamasamy1f0b1e62020-02-20 20:48:25 +053061
62 /**
63 * @brief Get ExtraInterface Properties
64 * Making a dbus call for those properties under extraInterfaces.
65 *
66 * @param[in] invPath - Value of inventory path
67 * @param[in] extraInterface - One of the invPath's extraInterfaces whose
68 * value is not null
69 * @param[in] prop - All properties of the extraInterface.
PriyangaRamasamy8cc5b152021-06-03 13:05:17 -050070 * @param[out] output - output json which has the properties under invPath's
71 * extra interface.
PriyangaRamasamy1f0b1e62020-02-20 20:48:25 +053072 */
Priyanga Ramasamye0084322022-09-27 06:28:33 -050073 void getExtraInterfaceProperties(const std::string& invPath,
74 const std::string& extraInterface,
PriyangaRamasamy8cc5b152021-06-03 13:05:17 -050075 const json& prop, json& output);
PriyangaRamasamy1f0b1e62020-02-20 20:48:25 +053076
77 /**
78 * @brief Interface Decider
79 * Decides whether to make the dbus call for
80 * getting properites from extraInterface or from
81 * VINI interface, depending on the value of
82 * extraInterfaces object in the inventory json.
83 *
84 * @param[in] itemEEPROM - holds the reference of one of the EEPROM objects.
85 *
86 * @return json output for one of the EEPROM objects.
87 */
88 json interfaceDecider(json& itemEEPROM);
89
90 /**
91 * @brief Parse Inventory JSON
92 * Parses the complete inventory json and depending upon
93 * the user option makes the dbuscall for the frus
94 * via interfaceDecider function.
95 *
96 * @param[in] jsObject - Inventory json object
97 * @param[in] flag - flag which tells about the user option(either
98 * dumpInventory or dumpObject)
99 * @param[in] fruPath - fruPath is empty for dumpInventory option and holds
100 * valid fruPath for dumpObject option.
101 *
102 * @return output json
103 */
104 json parseInvJson(const json& jsObject, char flag, std::string fruPath);
105
PriyangaRamasamycdf943c2020-03-18 02:25:30 +0530106 /**
PriyangaRamasamycdf943c2020-03-18 02:25:30 +0530107 * @brief eraseInventoryPath
108 * Remove the INVENTORY_PATH - "/xyz/openbmc_project/inventory"
109 * for code convenience.
110 *
111 * @param[out] fru - Reference to the fru path whose INVENTORY_PATH is
112 * stripped off.
113 */
114 void eraseInventoryPath(std::string& fru);
115
PriyangaRamasamyc0a534f2020-08-24 21:29:18 +0530116 /**
117 * @brief printReturnCode
118 * Prints the return code of the program in console output, whenever
119 * the program fails to exit successfully.
120 *
121 * @param[in] returnCode - return code of the program.
122 */
PriyangaRamasamy6ee637a2021-02-12 04:49:02 -0600123 void printReturnCode(int returnCode);
124
PriyangaRamasamyc0a534f2020-08-24 21:29:18 +0530125 /**
126 * @brief Convert hex/ascii values to Binary
127 * @param[in] - value in hex/ascii.
128 * @param[out] - value in binary.
129 */
130 openpower::vpd::Binary toBinary(const std::string& value);
131
Priyanga Ramasamy0086dd12021-09-28 10:31:50 -0500132 /**
133 * @brief Get the json which has Present property value of the given fru.
134 * @param[in] invPath - inventory path of the fru.
135 * @param[out] parentPresence - Update the parent fru's present property.
136 * @return output json which has the Present property value.
137 */
138 json getPresentPropJson(const std::string& invPath,
139 std::string& parentPresence);
140
Priyanga Ramasamy43ffcf72022-06-08 14:10:11 -0500141 /**
142 * @brief Parse through the options to fix system VPD
143 *
144 * @param[in] json - Inventory JSON
145 */
146 void parseSVPDOptions(const nlohmann::json& json);
147
148 /**
149 * @brief List of user options that can be used to fix system VPD keywords.
150 */
151 enum UserOption
152 {
153 EXIT = 0,
154 BMC_DATA_FOR_ALL = 1,
155 SYSTEM_BACKPLANE_DATA_FOR_ALL = 2,
156 MORE_OPTIONS = 3,
157 BMC_DATA_FOR_CURRENT = 4,
158 SYSTEM_BACKPLANE_DATA_FOR_CURRENT = 5,
159 NEW_VALUE_ON_BOTH = 6,
160 SKIP_CURRENT = 7
161 };
162
163 /**
164 * @brief Print options to fix system VPD.
165 * @param[in] option - Option to use.
166 */
167 void printFixSystemVPDOption(UserOption option);
168
PriyangaRamasamy1f0b1e62020-02-20 20:48:25 +0530169 public:
170 /**
171 * @brief Dump the complete inventory in JSON format
172 *
173 * @param[in] jsObject - Inventory JSON specified in configure file.
174 */
175 void dumpInventory(const nlohmann::basic_json<>& jsObject);
176
177 /**
178 * @brief Dump the given inventory object in JSON format
179 *
180 * @param[in] jsObject - Inventory JSON specified in configure file.
181 */
182 void dumpObject(const nlohmann::basic_json<>& jsObject);
183
184 /**
PriyangaRamasamy02d4d4e2020-02-24 14:54:45 +0530185 * @brief Read keyword
186 * Read the given object path, record name and keyword
187 * from the inventory and display the value of the keyword
188 * in JSON format.
189 */
190 void readKeyword();
191
192 /**
PriyangaRamasamyd09d2ec2020-03-12 14:11:50 +0530193 * @brief Update Keyword
194 * Update the given keyword with the given value.
195 *
196 * @return return code (Success(0)/Failure(-1))
197 */
198 int updateKeyword();
199
200 /**
PriyangaRamasamy0407b172020-03-31 13:57:18 +0530201 * @brief Force Reset
202 * Clearing the inventory cache data and restarting the
203 * phosphor inventory manager and also retriggering all the
204 * udev events.
205 *
206 * @param[in] jsObject - Inventory JSON specified in configure file.
207 */
208 void forceReset(const nlohmann::basic_json<>& jsObject);
209
210 /**
PriyangaRamasamyc0a534f2020-08-24 21:29:18 +0530211 * @brief Update Hardware
Priyanga Ramasamyc99a0b02022-06-08 14:53:39 -0500212 * The given data is updated only on the given hardware path and not on dbus
213 * for the given record-keyword pair. The user can now update record-keyword
214 * value for any hardware path irrespective of whether its present or not in
215 * VPD JSON, by providing a valid offset. By default offset takes 0.
216 *
217 * @param[in] offset - VPD offset.
PriyangaRamasamyc0a534f2020-08-24 21:29:18 +0530218 * @return returncode (success/failure).
219 */
Priyanga Ramasamyc99a0b02022-06-08 14:53:39 -0500220 int updateHardware(const uint32_t offset);
PriyangaRamasamy887a42a2020-09-03 00:33:57 +0530221
222 /**
Priyanga Ramasamy38031312021-10-07 16:39:13 -0500223 * @brief Read Keyword from Hardware
224 * This api is to read a keyword directly from the hardware. The hardware
225 * path, record name and keyword name are received at the time of
226 * initialising the constructor.
Priyanga Ramasamyc99a0b02022-06-08 14:53:39 -0500227 * The user can now read keyword from any hardware path irrespective of
228 * whether its present or not in VPD JSON, by providing a valid offset. By
229 * default offset takes 0.
230 *
231 * @param[in] startOffset - VPD offset.
Priyanga Ramasamy38031312021-10-07 16:39:13 -0500232 */
Priyanga Ramasamyc99a0b02022-06-08 14:53:39 -0500233 void readKwFromHw(const uint32_t& startOffset);
Priyanga Ramasamy38031312021-10-07 16:39:13 -0500234
235 /**
Priyanga Ramasamy43ffcf72022-06-08 14:10:11 -0500236 * @brief Fix System VPD keyword.
237 * This API provides an interactive way to fix system VPD keywords that are
238 * part of restorable record-keyword pairs. The user can use this option to
239 * restore the restorable keywords in cache or in hardware or in both cache
240 * and hardware.
241 * @return returncode (success/failure).
242 */
243 int fixSystemVPD();
244
245 /**
PriyangaRamasamycdf943c2020-03-18 02:25:30 +0530246 * @brief Constructor
PriyangaRamasamy1f0b1e62020-02-20 20:48:25 +0530247 * Constructor is called during the
PriyangaRamasamy0407b172020-03-31 13:57:18 +0530248 * object instantiation for dumpInventory option and
249 * forceReset option.
PriyangaRamasamy1f0b1e62020-02-20 20:48:25 +0530250 */
251 VpdTool()
252 {
253 }
254
255 /**
256 * @brief Constructor
257 * Constructor is called during the
258 * object instantiation for dumpObject option.
259 */
260 VpdTool(const std::string&& fru) : fruPath(std::move(fru))
261 {
262 }
PriyangaRamasamy02d4d4e2020-02-24 14:54:45 +0530263
264 /**
265 * @brief Constructor
266 * Constructor is called during the
267 * object instantiation for readKeyword option.
268 */
269 VpdTool(const std::string&& fru, const std::string&& recName,
270 const std::string&& kw) :
271 fruPath(std::move(fru)),
272 recordName(std::move(recName)), keyword(std::move(kw))
273 {
274 }
PriyangaRamasamyd09d2ec2020-03-12 14:11:50 +0530275
276 /**
277 * @brief Constructor
278 * Constructor is called during the
279 * object instantiation for updateKeyword option.
280 */
281
282 VpdTool(const std::string&& fru, const std::string&& recName,
283 const std::string&& kw, const std::string&& val) :
284 fruPath(std::move(fru)),
285 recordName(std::move(recName)), keyword(std::move(kw)),
286 value(std::move(val))
287 {
288 }
PriyangaRamasamy1f0b1e62020-02-20 20:48:25 +0530289};