blob: ecbc2b41e883e9ef91f491d604df703d24a26646 [file] [log] [blame]
Vijay Khemkaa2d52f12019-03-27 14:54:00 -07001/*
2 * Copyright (c) 2018 Intel Corporation.
3 * Copyright (c) 2018-present Facebook.
4 *
5 * Licensed under the Apache License, Version 2.0 (the "License");
6 * you may not use this file except in compliance with the License.
7 * You may obtain a copy of the License at
8 *
9 * http://www.apache.org/licenses/LICENSE-2.0
10 *
11 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS,
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 * See the License for the specific language governing permissions and
15 * limitations under the License.
16 */
17
Vijay Khemkaa2d52f12019-03-27 14:54:00 -070018#include <fcntl.h>
Vijay Khemka63c99be2020-05-27 19:14:35 -070019#include <ipmid/api.h>
20#include <sys/stat.h>
Vijay Khemkaa2d52f12019-03-27 14:54:00 -070021#include <unistd.h>
Vijay Khemka63c99be2020-05-27 19:14:35 -070022
23#include <appcommands.hpp>
Vijay Khemkaa2d52f12019-03-27 14:54:00 -070024#include <commandutils.hpp>
Patrick Williams2405ae92023-05-10 07:50:09 -050025#include <ipmid/api-types.hpp>
26#include <ipmid/api.hpp>
Vijay Khemka63c99be2020-05-27 19:14:35 -070027#include <nlohmann/json.hpp>
Vijay Khemkaa2d52f12019-03-27 14:54:00 -070028#include <phosphor-logging/log.hpp>
29#include <sdbusplus/message/types.hpp>
Vijay Khemka63c99be2020-05-27 19:14:35 -070030
31#include <fstream>
32#include <iomanip>
33#include <iostream>
34#include <sstream>
Vijay Khemkaa2d52f12019-03-27 14:54:00 -070035
36namespace ipmi
37{
38
39static void registerAPPFunctions() __attribute__((constructor));
40static constexpr size_t GUID_SIZE = 16;
41// TODO Make offset and location runtime configurable to ensure we
42// can make each define their own locations.
43static constexpr off_t OFFSET_SYS_GUID = 0x17F0;
Vijay Khemka63c99be2020-05-27 19:14:35 -070044static constexpr const char* FRU_EEPROM = "/sys/bus/i2c/devices/6-0054/eeprom";
Vijay Khemka666a4d92019-04-03 11:27:24 -070045
46// TODO: Need to store this info after identifying proper storage
Vijay Khemkaa2d52f12019-03-27 14:54:00 -070047static uint8_t globEna = 0x09;
Vijay Khemka666a4d92019-04-03 11:27:24 -070048static SysInfoParam sysInfoParams;
Vijay Khemka802ccb12019-08-27 15:03:44 -070049nlohmann::json appData __attribute__((init_priority(101)));
Vijay Khemkaa2d52f12019-03-27 14:54:00 -070050
Manikandan Elumalai5f8e3432020-12-02 03:46:55 +053051int sendBicCmd(uint8_t, uint8_t, uint8_t, std::vector<uint8_t>&,
52 std::vector<uint8_t>&);
53
Bonnie Loe9baaff2022-11-08 16:36:21 +080054static inline auto responseSystemInfoParamterNotSupportCommand()
55{
56 return response(IPMI_CC_SYSTEM_INFO_PARAMETER_NOT_SUPPORTED);
57}
58
Vijay Khemka63c99be2020-05-27 19:14:35 -070059void printGUID(uint8_t* guid, off_t offset)
Vijay Khemkaa2d52f12019-03-27 14:54:00 -070060{
61 std::cout << "Read GUID from offset : " << offset << " :\n";
Willy Tue39f9392022-06-15 13:24:20 -070062 for (size_t i = 0; i < GUID_SIZE; i++)
Vijay Khemkaa2d52f12019-03-27 14:54:00 -070063 {
64 int data = guid[i];
65 std::cout << std::hex << data << " ";
66 }
67 std::cout << std::endl;
68}
69
Vijay Khemka63c99be2020-05-27 19:14:35 -070070int getGUID(off_t offset, uint8_t* guid)
Vijay Khemkaa2d52f12019-03-27 14:54:00 -070071{
72 int fd = -1;
73 ssize_t bytes_rd;
74 int ret = 0;
cchouxb2ae88b2023-09-13 00:35:36 +080075 std::string eepromPath = FRU_EEPROM;
76
77 // find the eeprom path of MB FRU
78 auto device = getMbFruDevice();
79 if (device)
80 {
81 auto [bus, address] = *device;
82 std::stringstream ss;
83 ss << "/sys/bus/i2c/devices/" << static_cast<int>(bus) << "-"
84 << std::setw(4) << std::setfill('0') << std::hex
85 << static_cast<int>(address) << "/eeprom";
86 eepromPath = ss.str();
87 }
Vijay Khemkaa2d52f12019-03-27 14:54:00 -070088
89 errno = 0;
90
91 // Check if file is present
cchouxb2ae88b2023-09-13 00:35:36 +080092 if (access(eepromPath.c_str(), F_OK) == -1)
Vijay Khemkaa2d52f12019-03-27 14:54:00 -070093 {
cchouxb2ae88b2023-09-13 00:35:36 +080094 std::cerr << "Unable to access: " << eepromPath << std::endl;
Vijay Khemkaa2d52f12019-03-27 14:54:00 -070095 return errno;
96 }
97
98 // Open the file
cchouxb2ae88b2023-09-13 00:35:36 +080099 fd = open(eepromPath.c_str(), O_RDONLY);
Vijay Khemkaa2d52f12019-03-27 14:54:00 -0700100 if (fd == -1)
101 {
cchouxb2ae88b2023-09-13 00:35:36 +0800102 std::cerr << "Unable to open: " << eepromPath << std::endl;
Vijay Khemkaa2d52f12019-03-27 14:54:00 -0700103 return errno;
104 }
105
106 // seek to the offset
107 lseek(fd, offset, SEEK_SET);
108
109 // Read bytes from location
110 bytes_rd = read(fd, guid, GUID_SIZE);
111 if (bytes_rd != GUID_SIZE)
112 {
113 phosphor::logging::log<phosphor::logging::level::ERR>(
114 "GUID read data from EEPROM failed");
115 ret = errno;
116 }
117 else
118 {
119 printGUID(guid, offset);
120 }
121 close(fd);
122 return ret;
123}
124
Vijay Khemka63c99be2020-05-27 19:14:35 -0700125int getSystemGUID(uint8_t* guid)
Vijay Khemkaa2d52f12019-03-27 14:54:00 -0700126{
127 return getGUID(OFFSET_SYS_GUID, guid);
128}
129
Vijay Khemkaa2d52f12019-03-27 14:54:00 -0700130//----------------------------------------------------------------------
Vijay Khemka666a4d92019-04-03 11:27:24 -0700131// Get Self Test Results (IPMI/Section 20.4) (CMD_APP_GET_SELFTEST_RESULTS)
132//----------------------------------------------------------------------
Willy Tue39f9392022-06-15 13:24:20 -0700133ipmi_ret_t ipmiAppGetSTResults(ipmi_netfn_t, ipmi_cmd_t, ipmi_request_t,
134 ipmi_response_t response,
135 ipmi_data_len_t data_len, ipmi_context_t)
Vijay Khemka666a4d92019-04-03 11:27:24 -0700136{
Vijay Khemka63c99be2020-05-27 19:14:35 -0700137 uint8_t* res = reinterpret_cast<uint8_t*>(response);
Vijay Khemka666a4d92019-04-03 11:27:24 -0700138
139 // TODO: Following data needs to be updated based on self-test results
140 *res++ = 0x55; // Self-Test result
141 *res++ = 0x00; // Extra error info in case of failure
142
143 *data_len = 2;
144
145 return IPMI_CC_OK;
146}
147
148//----------------------------------------------------------------------
149// Manufacturing Test On (IPMI/Section 20.5) (CMD_APP_MFR_TEST_ON)
150//----------------------------------------------------------------------
Willy Tue39f9392022-06-15 13:24:20 -0700151ipmi_ret_t ipmiAppMfrTestOn(ipmi_netfn_t, ipmi_cmd_t, ipmi_request_t request,
152 ipmi_response_t, ipmi_data_len_t data_len,
153 ipmi_context_t)
Vijay Khemka666a4d92019-04-03 11:27:24 -0700154{
Vijay Khemka63c99be2020-05-27 19:14:35 -0700155 uint8_t* req = reinterpret_cast<uint8_t*>(request);
Vijay Khemka666a4d92019-04-03 11:27:24 -0700156 std::string mfrTest = "sled-cycle";
Patrick Williams35208452022-06-24 06:12:15 -0500157 ipmi_ret_t rc = IPMI_CC_OK;
Vijay Khemka666a4d92019-04-03 11:27:24 -0700158
159 if (!memcmp(req, mfrTest.data(), mfrTest.length()) &&
160 (*data_len == mfrTest.length()))
161 {
162 /* sled-cycle the BMC */
Patrick Williams35208452022-06-24 06:12:15 -0500163 auto ret = system("/usr/sbin/power-util sled-cycle");
164 if (ret)
165 {
166 rc = IPMI_CC_UNSPECIFIED_ERROR;
167 }
Vijay Khemka666a4d92019-04-03 11:27:24 -0700168 }
169 else
170 {
Patrick Williams35208452022-06-24 06:12:15 -0500171 rc = IPMI_CC_SYSTEM_INFO_PARAMETER_NOT_SUPPORTED;
Vijay Khemka666a4d92019-04-03 11:27:24 -0700172 }
173
174 *data_len = 0;
175
Patrick Williams35208452022-06-24 06:12:15 -0500176 return rc;
Vijay Khemka666a4d92019-04-03 11:27:24 -0700177}
178
179//----------------------------------------------------------------------
Vijay Khemkaa2d52f12019-03-27 14:54:00 -0700180// Set Global Enables (CMD_APP_SET_GLOBAL_ENABLES)
181//----------------------------------------------------------------------
Willy Tue39f9392022-06-15 13:24:20 -0700182ipmi_ret_t ipmiAppSetGlobalEnables(ipmi_netfn_t, ipmi_cmd_t,
183 ipmi_request_t request, ipmi_response_t,
184 ipmi_data_len_t data_len, ipmi_context_t)
Vijay Khemkaa2d52f12019-03-27 14:54:00 -0700185{
Vijay Khemka63c99be2020-05-27 19:14:35 -0700186 uint8_t* req = reinterpret_cast<uint8_t*>(request);
Vijay Khemkaa2d52f12019-03-27 14:54:00 -0700187
188 globEna = *req;
189 *data_len = 0;
190
191 return IPMI_CC_OK;
192}
193
194//----------------------------------------------------------------------
195// Get Global Enables (CMD_APP_GET_GLOBAL_ENABLES)
196//----------------------------------------------------------------------
Willy Tue39f9392022-06-15 13:24:20 -0700197ipmi_ret_t ipmiAppGetGlobalEnables(ipmi_netfn_t, ipmi_cmd_t, ipmi_request_t,
Vijay Khemkaa2d52f12019-03-27 14:54:00 -0700198 ipmi_response_t response,
Willy Tue39f9392022-06-15 13:24:20 -0700199 ipmi_data_len_t data_len, ipmi_context_t)
Vijay Khemkaa2d52f12019-03-27 14:54:00 -0700200{
Vijay Khemka63c99be2020-05-27 19:14:35 -0700201 uint8_t* res = reinterpret_cast<uint8_t*>(response);
Vijay Khemkaa2d52f12019-03-27 14:54:00 -0700202
203 *data_len = 1;
204 *res++ = globEna;
205
206 return IPMI_CC_OK;
207}
208
209//----------------------------------------------------------------------
Vijay Khemka666a4d92019-04-03 11:27:24 -0700210// Clear Message flags (IPMI/Section 22.3) (CMD_APP_CLEAR_MESSAGE_FLAGS)
211//----------------------------------------------------------------------
Willy Tue39f9392022-06-15 13:24:20 -0700212ipmi_ret_t ipmiAppClearMsgFlags(ipmi_netfn_t, ipmi_cmd_t, ipmi_request_t,
213 ipmi_response_t, ipmi_data_len_t data_len,
214 ipmi_context_t)
Vijay Khemka666a4d92019-04-03 11:27:24 -0700215{
216 // Do Nothing and just return success
217 *data_len = 0;
218
219 return IPMI_CC_OK;
220}
221
222//----------------------------------------------------------------------
Vijay Khemkaa2d52f12019-03-27 14:54:00 -0700223// Get System GUID (CMD_APP_GET_SYS_GUID)
224//----------------------------------------------------------------------
Manikandan Elumalai5f8e3432020-12-02 03:46:55 +0530225#if BIC_ENABLED
226ipmi::RspType<std::vector<uint8_t>>
227 ipmiAppGetSysGUID(ipmi::Context::ptr ctx, std::vector<uint8_t> reqData)
228
229{
230 std::vector<uint8_t> respData;
231
232 uint8_t bicAddr = (uint8_t)ctx->hostIdx << 2;
233
234 if (sendBicCmd(ctx->netFn, ctx->cmd, bicAddr, reqData, respData))
235 return ipmi::responseUnspecifiedError();
236
237 return ipmi::responseSuccess(respData);
238}
239
240#else
Willy Tue39f9392022-06-15 13:24:20 -0700241ipmi_ret_t ipmiAppGetSysGUID(ipmi_netfn_t, ipmi_cmd_t, ipmi_request_t,
242 ipmi_response_t response, ipmi_data_len_t data_len,
243 ipmi_context_t)
Vijay Khemkaa2d52f12019-03-27 14:54:00 -0700244{
Vijay Khemka63c99be2020-05-27 19:14:35 -0700245 uint8_t* res = reinterpret_cast<uint8_t*>(response);
Vijay Khemkaa2d52f12019-03-27 14:54:00 -0700246 if (getSystemGUID(res))
247 {
248 return IPMI_CC_UNSPECIFIED_ERROR;
249 }
250 *data_len = GUID_SIZE;
251 return IPMI_CC_OK;
252}
253
Manikandan Elumalai5f8e3432020-12-02 03:46:55 +0530254#endif
255
Vijay Khemka666a4d92019-04-03 11:27:24 -0700256//----------------------------------------------------------------------
257// Platform specific functions for storing app data
258//----------------------------------------------------------------------
259
260void flush_app_data()
261{
Vijay Khemka802ccb12019-08-27 15:03:44 -0700262 std::ofstream file(JSON_APP_DATA_FILE);
Vijay Khemka666a4d92019-04-03 11:27:24 -0700263 file << appData;
Vijay Khemka802ccb12019-08-27 15:03:44 -0700264 file.close();
Vijay Khemka666a4d92019-04-03 11:27:24 -0700265 return;
266}
267
Bonnie Loe9baaff2022-11-08 16:36:21 +0800268static int platSetSysFWVer(uint8_t* ver, const std::string key)
Vijay Khemka666a4d92019-04-03 11:27:24 -0700269{
270 std::stringstream ss;
271 int i;
272
273 /* TODO: implement byte 1: Set selector
274 * byte 2: encodeing, currently only supported
275 * ASCII which is value 0, UTF and unicode are
276 * not supported yet.
277 */
278 if (ver[1] & 0x0f)
279 return -1;
280
281 for (i = 3; i < 3 + ver[2]; i++)
282 {
283 ss << (char)ver[i];
284 }
285
Bonnie Loe9baaff2022-11-08 16:36:21 +0800286 appData[key] = ss.str();
Vijay Khemka666a4d92019-04-03 11:27:24 -0700287 flush_app_data();
288
289 return 0;
290}
291
Bonnie Loe9baaff2022-11-08 16:36:21 +0800292static int platGetSysFWVer(std::vector<uint8_t>& respData,
293 const std::string key)
Vijay Khemka666a4d92019-04-03 11:27:24 -0700294{
Bonnie Loe9baaff2022-11-08 16:36:21 +0800295 int len = -1;
Vijay Khemka666a4d92019-04-03 11:27:24 -0700296
Bonnie Loe9baaff2022-11-08 16:36:21 +0800297 if (!appData.contains(std::string(key)))
298 {
299 return -1;
300 }
301 std::string str = appData[key].get<std::string>();
302
303 respData.push_back(0); // byte 1: Set selector not supported
304 respData.push_back(0); // byte 2: Only ASCII supported
Vijay Khemka666a4d92019-04-03 11:27:24 -0700305
306 len = str.length();
Bonnie Loe9baaff2022-11-08 16:36:21 +0800307 respData.push_back(len); // byte 3: Size of version
308
309 for (auto c : str)
310 {
311 respData.push_back(c);
312 }
313
314 // Remaining byte fill to 0
315 for (int i = 0; i < SIZE_SYSFW_VER - (len + 3); i++)
316 {
317 respData.push_back(0);
318 }
Vijay Khemka666a4d92019-04-03 11:27:24 -0700319
320 return (len + 3);
321}
322
323//----------------------------------------------------------------------
324// Set Sys Info Params (IPMI/Sec 22.14a) (CMD_APP_SET_SYS_INFO_PARAMS)
325//----------------------------------------------------------------------
Bonnie Loe9baaff2022-11-08 16:36:21 +0800326ipmi::RspType<uint8_t> ipmiAppSetSysInfoParams(ipmi::Context::ptr ctx,
327 std::vector<uint8_t> req)
Vijay Khemka666a4d92019-04-03 11:27:24 -0700328{
Vijay Khemka666a4d92019-04-03 11:27:24 -0700329 uint8_t param = req[0];
Bonnie Loe9baaff2022-11-08 16:36:21 +0800330 uint8_t req_len = req.size();
331 std::optional<size_t> hostId = findHost(ctx->hostIdx);
Vijay Khemka666a4d92019-04-03 11:27:24 -0700332
Bonnie Loe9baaff2022-11-08 16:36:21 +0800333 if (!hostId)
334 {
335 phosphor::logging::log<phosphor::logging::level::ERR>(
336 "Invalid Host Id received");
337 return ipmi::responseInvalidCommand();
338 }
Vijay Khemka666a4d92019-04-03 11:27:24 -0700339
340 switch (param)
341 {
342 case SYS_INFO_PARAM_SET_IN_PROG:
343 sysInfoParams.set_in_prog = req[1];
344 break;
345 case SYS_INFO_PARAM_SYSFW_VER:
Bonnie Loe9baaff2022-11-08 16:36:21 +0800346 {
Vijay Khemka666a4d92019-04-03 11:27:24 -0700347 memcpy(sysInfoParams.sysfw_ver, &req[1], SIZE_SYSFW_VER);
Bonnie Loe9baaff2022-11-08 16:36:21 +0800348 std::string version_key = KEY_SYSFW_VER + std::to_string(*hostId);
349 if (platSetSysFWVer(sysInfoParams.sysfw_ver, version_key))
350 return ipmi::responseSystemInfoParamterNotSupportCommand();
Vijay Khemka666a4d92019-04-03 11:27:24 -0700351 break;
Bonnie Loe9baaff2022-11-08 16:36:21 +0800352 }
Vijay Khemka666a4d92019-04-03 11:27:24 -0700353 case SYS_INFO_PARAM_SYS_NAME:
354 memcpy(sysInfoParams.sys_name, &req[1], SIZE_SYS_NAME);
355 break;
356 case SYS_INFO_PARAM_PRI_OS_NAME:
357 memcpy(sysInfoParams.pri_os_name, &req[1], SIZE_OS_NAME);
358 break;
359 case SYS_INFO_PARAM_PRESENT_OS_NAME:
360 memcpy(sysInfoParams.present_os_name, &req[1], SIZE_OS_NAME);
361 break;
362 case SYS_INFO_PARAM_PRESENT_OS_VER:
363 memcpy(sysInfoParams.present_os_ver, &req[1], SIZE_OS_VER);
364 break;
365 case SYS_INFO_PARAM_BMC_URL:
366 memcpy(sysInfoParams.bmc_url, &req[1], SIZE_BMC_URL);
367 break;
368 case SYS_INFO_PARAM_OS_HV_URL:
369 memcpy(sysInfoParams.os_hv_url, &req[1], SIZE_OS_HV_URL);
370 break;
371 case SYS_INFO_PARAM_BIOS_CURRENT_BOOT_LIST:
372 memcpy(sysInfoParams.bios_current_boot_list, &req[1], req_len);
373 appData[KEY_BIOS_BOOT_LEN] = req_len;
374 flush_app_data();
375 break;
376 case SYS_INFO_PARAM_BIOS_FIXED_BOOT_DEVICE:
377 if (SIZE_BIOS_FIXED_BOOT_DEVICE != req_len)
378 break;
379 memcpy(sysInfoParams.bios_fixed_boot_device, &req[1],
380 SIZE_BIOS_FIXED_BOOT_DEVICE);
381 break;
382 case SYS_INFO_PARAM_BIOS_RSTR_DFLT_SETTING:
383 if (SIZE_BIOS_RSTR_DFLT_SETTING != req_len)
384 break;
385 memcpy(sysInfoParams.bios_rstr_dflt_setting, &req[1],
386 SIZE_BIOS_RSTR_DFLT_SETTING);
387 break;
388 case SYS_INFO_PARAM_LAST_BOOT_TIME:
389 if (SIZE_LAST_BOOT_TIME != req_len)
390 break;
391 memcpy(sysInfoParams.last_boot_time, &req[1], SIZE_LAST_BOOT_TIME);
392 break;
393 default:
Bonnie Loe9baaff2022-11-08 16:36:21 +0800394 return ipmi::responseSystemInfoParamterNotSupportCommand();
Vijay Khemka666a4d92019-04-03 11:27:24 -0700395 break;
396 }
397
Bonnie Loe9baaff2022-11-08 16:36:21 +0800398 return ipmi::responseSuccess();
Vijay Khemka666a4d92019-04-03 11:27:24 -0700399}
400
401//----------------------------------------------------------------------
402// Get Sys Info Params (IPMI/Sec 22.14b) (CMD_APP_GET_SYS_INFO_PARAMS)
403//----------------------------------------------------------------------
Bonnie Loe9baaff2022-11-08 16:36:21 +0800404ipmi::RspType<std::vector<uint8_t>>
405 ipmiAppGetSysInfoParams(ipmi::Context::ptr ctx, uint8_t, uint8_t param,
406 uint8_t, uint8_t)
Vijay Khemka666a4d92019-04-03 11:27:24 -0700407{
Willy Tue39f9392022-06-15 13:24:20 -0700408 int len;
Bonnie Loe9baaff2022-11-08 16:36:21 +0800409 std::vector<uint8_t> respData;
410 respData.push_back(1); // Parameter revision
Vijay Khemka666a4d92019-04-03 11:27:24 -0700411
Bonnie Loe9baaff2022-11-08 16:36:21 +0800412 std::optional<size_t> hostId = findHost(ctx->hostIdx);
413
414 if (!hostId)
415 {
416 phosphor::logging::log<phosphor::logging::level::ERR>(
417 "Invalid Host Id received");
418 return ipmi::responseInvalidCommand();
419 }
Vijay Khemka666a4d92019-04-03 11:27:24 -0700420
421 switch (param)
422 {
423 case SYS_INFO_PARAM_SET_IN_PROG:
Bonnie Loe9baaff2022-11-08 16:36:21 +0800424 respData.push_back(sysInfoParams.set_in_prog);
Vijay Khemka666a4d92019-04-03 11:27:24 -0700425 break;
426 case SYS_INFO_PARAM_SYSFW_VER:
Bonnie Loe9baaff2022-11-08 16:36:21 +0800427 {
428 std::string version_key = KEY_SYSFW_VER + std::to_string(*hostId);
429 if ((platGetSysFWVer(respData, version_key)) < 0)
430 return ipmi::responseSystemInfoParamterNotSupportCommand();
Vijay Khemka666a4d92019-04-03 11:27:24 -0700431 break;
Bonnie Loe9baaff2022-11-08 16:36:21 +0800432 }
Vijay Khemka666a4d92019-04-03 11:27:24 -0700433 case SYS_INFO_PARAM_SYS_NAME:
Bonnie Loe9baaff2022-11-08 16:36:21 +0800434 respData.insert(respData.end(), std::begin(sysInfoParams.sys_name),
435 std::end(sysInfoParams.sys_name));
Vijay Khemka666a4d92019-04-03 11:27:24 -0700436 break;
437 case SYS_INFO_PARAM_PRI_OS_NAME:
Bonnie Loe9baaff2022-11-08 16:36:21 +0800438 respData.insert(respData.end(),
439 std::begin(sysInfoParams.pri_os_name),
440 std::end(sysInfoParams.pri_os_name));
Vijay Khemka666a4d92019-04-03 11:27:24 -0700441 break;
442 case SYS_INFO_PARAM_PRESENT_OS_NAME:
Bonnie Loe9baaff2022-11-08 16:36:21 +0800443 respData.insert(respData.end(),
444 std::begin(sysInfoParams.present_os_name),
445 std::end(sysInfoParams.present_os_name));
Vijay Khemka666a4d92019-04-03 11:27:24 -0700446 break;
447 case SYS_INFO_PARAM_PRESENT_OS_VER:
Bonnie Loe9baaff2022-11-08 16:36:21 +0800448 respData.insert(respData.end(),
449 std::begin(sysInfoParams.present_os_ver),
450 std::end(sysInfoParams.present_os_ver));
Vijay Khemka666a4d92019-04-03 11:27:24 -0700451 break;
452 case SYS_INFO_PARAM_BMC_URL:
Bonnie Loe9baaff2022-11-08 16:36:21 +0800453 respData.insert(respData.end(), std::begin(sysInfoParams.bmc_url),
454 std::end(sysInfoParams.bmc_url));
Vijay Khemka666a4d92019-04-03 11:27:24 -0700455 break;
456 case SYS_INFO_PARAM_OS_HV_URL:
Bonnie Loe9baaff2022-11-08 16:36:21 +0800457 respData.insert(respData.end(), std::begin(sysInfoParams.os_hv_url),
458 std::end(sysInfoParams.os_hv_url));
Vijay Khemka666a4d92019-04-03 11:27:24 -0700459 break;
460 case SYS_INFO_PARAM_BIOS_CURRENT_BOOT_LIST:
461 len = appData[KEY_BIOS_BOOT_LEN].get<uint8_t>();
Bonnie Loe9baaff2022-11-08 16:36:21 +0800462 respData.insert(respData.end(),
463 std::begin(sysInfoParams.bios_current_boot_list),
464 std::begin(sysInfoParams.bios_current_boot_list) +
465 len);
Vijay Khemka666a4d92019-04-03 11:27:24 -0700466 break;
467 case SYS_INFO_PARAM_BIOS_FIXED_BOOT_DEVICE:
Bonnie Loe9baaff2022-11-08 16:36:21 +0800468 respData.insert(respData.end(),
469 std::begin(sysInfoParams.bios_fixed_boot_device),
470 std::end(sysInfoParams.bios_fixed_boot_device));
Vijay Khemka666a4d92019-04-03 11:27:24 -0700471 break;
472 case SYS_INFO_PARAM_BIOS_RSTR_DFLT_SETTING:
Bonnie Loe9baaff2022-11-08 16:36:21 +0800473 respData.insert(respData.end(),
474 std::begin(sysInfoParams.bios_rstr_dflt_setting),
475 std::end(sysInfoParams.bios_rstr_dflt_setting));
Vijay Khemka666a4d92019-04-03 11:27:24 -0700476 break;
477 case SYS_INFO_PARAM_LAST_BOOT_TIME:
Bonnie Loe9baaff2022-11-08 16:36:21 +0800478 respData.insert(respData.end(),
479 std::begin(sysInfoParams.last_boot_time),
480 std::end(sysInfoParams.last_boot_time));
Vijay Khemka666a4d92019-04-03 11:27:24 -0700481 break;
482 default:
Bonnie Loe9baaff2022-11-08 16:36:21 +0800483 return ipmi::responseSystemInfoParamterNotSupportCommand();
Vijay Khemka666a4d92019-04-03 11:27:24 -0700484 break;
485 }
Bonnie Loe9baaff2022-11-08 16:36:21 +0800486
487 return ipmi::responseSuccess(respData);
Vijay Khemka666a4d92019-04-03 11:27:24 -0700488}
489
Vijay Khemkaa2d52f12019-03-27 14:54:00 -0700490void registerAPPFunctions()
491{
Vijay Khemka666a4d92019-04-03 11:27:24 -0700492 /* Get App data stored in json file */
Vijay Khemka802ccb12019-08-27 15:03:44 -0700493 std::ifstream file(JSON_APP_DATA_FILE);
Vijay Khemka666a4d92019-04-03 11:27:24 -0700494 if (file)
Vijay Khemka802ccb12019-08-27 15:03:44 -0700495 {
Vijay Khemka666a4d92019-04-03 11:27:24 -0700496 file >> appData;
Vijay Khemka802ccb12019-08-27 15:03:44 -0700497 file.close();
498 }
Vijay Khemka666a4d92019-04-03 11:27:24 -0700499
500 ipmiPrintAndRegister(NETFUN_APP, CMD_APP_GET_SELFTEST_RESULTS, NULL,
501 ipmiAppGetSTResults,
502 PRIVILEGE_USER); // Get Self Test Results
503 ipmiPrintAndRegister(NETFUN_APP, CMD_APP_MFR_TEST_ON, NULL,
504 ipmiAppMfrTestOn,
505 PRIVILEGE_USER); // Manufacturing Test On
Vijay Khemkaa2d52f12019-03-27 14:54:00 -0700506 ipmiPrintAndRegister(NETFUN_APP, CMD_APP_SET_GLOBAL_ENABLES, NULL,
507 ipmiAppSetGlobalEnables,
Vijay Khemka666a4d92019-04-03 11:27:24 -0700508 PRIVILEGE_USER); // Set Global Enables
Vijay Khemkaa2d52f12019-03-27 14:54:00 -0700509 ipmiPrintAndRegister(NETFUN_APP, CMD_APP_GET_GLOBAL_ENABLES, NULL,
510 ipmiAppGetGlobalEnables,
511 PRIVILEGE_USER); // Get Global Enables
Vijay Khemka666a4d92019-04-03 11:27:24 -0700512 ipmiPrintAndRegister(NETFUN_APP, CMD_APP_CLEAR_MESSAGE_FLAGS, NULL,
513 ipmiAppClearMsgFlags,
514 PRIVILEGE_USER); // Clear Message flags
Manikandan Elumalai5f8e3432020-12-02 03:46:55 +0530515#if BIC_ENABLED
516 ipmi::registerHandler(ipmi::prioOpenBmcBase, ipmi::netFnApp,
517 ipmi::app::cmdGetSystemGuid, ipmi::Privilege::User,
518 ipmiAppGetSysGUID);
519#else
Vijay Khemkaa2d52f12019-03-27 14:54:00 -0700520 ipmiPrintAndRegister(NETFUN_APP, CMD_APP_GET_SYS_GUID, NULL,
521 ipmiAppGetSysGUID,
522 PRIVILEGE_USER); // Get System GUID
Manikandan Elumalai5f8e3432020-12-02 03:46:55 +0530523#endif
Bonnie Loe9baaff2022-11-08 16:36:21 +0800524 ipmi::registerHandler(ipmi::prioOpenBmcBase, ipmi::netFnApp,
525 ipmi::app::cmdSetSystemInfoParameters,
526 ipmi::Privilege::User, ipmiAppSetSysInfoParams);
527
528 ipmi::registerHandler(ipmi::prioOpenBmcBase, ipmi::netFnApp,
529 ipmi::app::cmdGetSystemInfoParameters,
530 ipmi::Privilege::User, ipmiAppGetSysInfoParams);
Vijay Khemkaa2d52f12019-03-27 14:54:00 -0700531 return;
532}
533
534} // namespace ipmi