blob: 6932b6f3c7c3aa2e73b98691b107f14edc279a8a [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,
50 uint8_t cmdReq, std::vector<uint8_t> data)
51{
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
60 auto req = std::make_shared<ipmi::message::Request>(
61 ctx, std::forward<std::vector<uint8_t>>(data));
62
63 // Calling executeIpmiCommand request function
64 res = ipmi::executeIpmiCommand(req);
65
66 // sending the response with headers and payload
67 return ipmi::responseSuccess(iana, interface, lun, ++netFnReq, cmdReq,
68 res->cc, res->payload);
69}
70
Kumar Thangavelad049242020-08-31 22:27:33 +053071//----------------------------------------------------------------------
72// ipmiOemPostCodeHandler (CMD_OEM_BIC_POST_BUFFER_INFO)
73// This Function will handle BIC incomming postcode from multi-host for
74// netfn=0x38 and cmd=0x08 send the response back to the sender.
75//----------------------------------------------------------------------
76
77ipmi::RspType<std::array<uint8_t, 3>, uint8_t>
78 ipmiOemPostCodeHandler(ipmi::Context::ptr ctx, std::array<uint8_t, 3> iana,
79 uint8_t interface, uint8_t data)
80{
81 // creating bus connection
82 auto conn = getSdBus();
83
84 try
85 {
Manojkiran Edac723d6a2021-03-11 14:53:32 +053086 using postcode_t = std::tuple<uint64_t, std::vector<uint8_t>>;
87
88 uint64_t primaryPostCode = static_cast<uint64_t>(data);
Kumar Thangavel0fcfbee2021-04-16 12:38:20 +053089 auto postCode = postcode_t(primaryPostCode, {});
Kumar Thangavelad049242020-08-31 22:27:33 +053090
91 // creating dbus objects for 1 to N process
92 std::string dbusObjStr = dbusObj + std::to_string((ctx->hostIdx + 1));
93
94 // creating method call to update postd value
95 auto method = conn->new_method_call(
96 "xyz.openbmc_project.State.Boot.Raw", dbusObjStr.c_str(),
97 "org.freedesktop.DBus.Properties", "Set");
98
99 // Adding paramters to method call
Kumar Thangavel0fcfbee2021-04-16 12:38:20 +0530100 method.append(dbusService, "Value", std::variant<postcode_t>(postCode));
Kumar Thangavelad049242020-08-31 22:27:33 +0530101
102 // Invoke method call function
103 auto reply = conn->call(method);
104
105 // sending the success response with headers
106 return ipmi::responseSuccess(iana, interface);
107 }
108 catch (std::exception& e)
109 {
110 phosphor::logging::log<phosphor::logging::level::ERR>(
111 "post code handler error\n");
112
113 // sending the Error response
114 return ipmi::responseResponseError();
115 }
116}
117
Kumar Thangavel41ad4ff2020-06-11 10:31:07 +0530118static void registerBICFunctions(void)
119{
120
121 phosphor::logging::log<phosphor::logging::level::INFO>(
122 "Registering BIC commands");
123
124 ipmi::registerHandler(ipmi::prioOpenBmcBase, ipmi::netFnOemFive,
125 cmdOemBicInfo, ipmi::Privilege::User,
126 ipmiOemBicHandler);
Kumar Thangavelad049242020-08-31 22:27:33 +0530127 ipmi::registerHandler(ipmi::prioOpenBmcBase, ipmi::netFnOemFive,
128 cmdOemSendPostBufferToBMC, ipmi::Privilege::User,
129 ipmiOemPostCodeHandler);
Kumar Thangavel41ad4ff2020-06-11 10:31:07 +0530130 return;
131}
132
133} // namespace ipmi