blob: a1be5a67eb04e14ded6948dac9a3bcbadd16cbd9 [file] [log] [blame]
Kumar Thangavel41ad4ff2020-06-11 10:31:07 +05301/*
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
18#include <ipmid/api.hpp>
19#include <ipmid/api-types.hpp>
20
21#include <commandutils.hpp>
22#include <biccommands.hpp>
23#include <phosphor-logging/log.hpp>
24
25#include <vector>
Kumar Thangavelad049242020-08-31 22:27:33 +053026#include <variant>
Kumar Thangavel41ad4ff2020-06-11 10:31:07 +053027#include <iostream>
28
29namespace ipmi
30{
31
32using namespace phosphor::logging;
33
Patrick Williams58c1ca22021-04-22 12:29:35 -050034#ifdef BIC_ENABLED
Kumar Thangavel41ad4ff2020-06-11 10:31:07 +053035static void registerBICFunctions() __attribute__((constructor));
Patrick Williams58c1ca22021-04-22 12:29:35 -050036#endif
Kumar Thangavel41ad4ff2020-06-11 10:31:07 +053037
38extern message::Response::ptr executeIpmiCommand(message::Request::ptr);
39
40//----------------------------------------------------------------------
41// ipmiOemBicHandler (IPMI/Section - ) (CMD_OEM_BIC_INFO)
42// This Function will handle BIC request for netfn=0x38 and cmd=1
43// send the response back to the sender.
44//----------------------------------------------------------------------
45
46ipmi::RspType<std::array<uint8_t, 3>, uint8_t, uint2_t, uint6_t, uint8_t,
47 uint8_t, ipmi::message::Payload>
48 ipmiOemBicHandler(ipmi::Context::ptr ctx, std::array<uint8_t, 3> iana,
49 uint8_t interface, uint2_t lun, uint6_t netFnReq,
Patrick Williams485f9b32021-09-03 16:14:47 -050050 uint8_t cmdReq, SecureBuffer data)
Kumar Thangavel41ad4ff2020-06-11 10:31:07 +053051{
52
53 ipmi::message::Response::ptr res;
54
55 // Updating the correct netfn and cmd in the ipmi Context
56 ctx->netFn = ((uint8_t)netFnReq);
57 ctx->cmd = cmdReq;
58
59 // creating ipmi message request for calling executeIpmiCommand function
Patrick Williams485f9b32021-09-03 16:14:47 -050060 auto req = std::make_shared<ipmi::message::Request>(ctx, std::move(data));
Kumar Thangavel41ad4ff2020-06-11 10:31:07 +053061
62 // Calling executeIpmiCommand request function
63 res = ipmi::executeIpmiCommand(req);
64
65 // sending the response with headers and payload
66 return ipmi::responseSuccess(iana, interface, lun, ++netFnReq, cmdReq,
67 res->cc, res->payload);
68}
69
Kumar Thangavelad049242020-08-31 22:27:33 +053070//----------------------------------------------------------------------
71// ipmiOemPostCodeHandler (CMD_OEM_BIC_POST_BUFFER_INFO)
72// This Function will handle BIC incomming postcode from multi-host for
73// netfn=0x38 and cmd=0x08 send the response back to the sender.
74//----------------------------------------------------------------------
75
76ipmi::RspType<std::array<uint8_t, 3>, uint8_t>
77 ipmiOemPostCodeHandler(ipmi::Context::ptr ctx, std::array<uint8_t, 3> iana,
78 uint8_t interface, uint8_t data)
79{
80 // creating bus connection
81 auto conn = getSdBus();
82
83 try
84 {
Manojkiran Edac723d6a2021-03-11 14:53:32 +053085 using postcode_t = std::tuple<uint64_t, std::vector<uint8_t>>;
86
87 uint64_t primaryPostCode = static_cast<uint64_t>(data);
Kumar Thangavel0fcfbee2021-04-16 12:38:20 +053088 auto postCode = postcode_t(primaryPostCode, {});
Kumar Thangavelad049242020-08-31 22:27:33 +053089
90 // creating dbus objects for 1 to N process
91 std::string dbusObjStr = dbusObj + std::to_string((ctx->hostIdx + 1));
92
93 // creating method call to update postd value
94 auto method = conn->new_method_call(
95 "xyz.openbmc_project.State.Boot.Raw", dbusObjStr.c_str(),
96 "org.freedesktop.DBus.Properties", "Set");
97
98 // Adding paramters to method call
Kumar Thangavel0fcfbee2021-04-16 12:38:20 +053099 method.append(dbusService, "Value", std::variant<postcode_t>(postCode));
Kumar Thangavelad049242020-08-31 22:27:33 +0530100
101 // Invoke method call function
102 auto reply = conn->call(method);
103
104 // sending the success response with headers
105 return ipmi::responseSuccess(iana, interface);
106 }
107 catch (std::exception& e)
108 {
109 phosphor::logging::log<phosphor::logging::level::ERR>(
110 "post code handler error\n");
111
112 // sending the Error response
113 return ipmi::responseResponseError();
114 }
115}
116
Willy Tue39f9392022-06-15 13:24:20 -0700117[[maybe_unused]] static void registerBICFunctions(void)
Kumar Thangavel41ad4ff2020-06-11 10:31:07 +0530118{
119
120 phosphor::logging::log<phosphor::logging::level::INFO>(
121 "Registering BIC commands");
122
123 ipmi::registerHandler(ipmi::prioOpenBmcBase, ipmi::netFnOemFive,
124 cmdOemBicInfo, ipmi::Privilege::User,
125 ipmiOemBicHandler);
Kumar Thangavelad049242020-08-31 22:27:33 +0530126 ipmi::registerHandler(ipmi::prioOpenBmcBase, ipmi::netFnOemFive,
127 cmdOemSendPostBufferToBMC, ipmi::Privilege::User,
128 ipmiOemPostCodeHandler);
Kumar Thangavel41ad4ff2020-06-11 10:31:07 +0530129 return;
130}
131
132} // namespace ipmi