blob: 017690cf551b902b6f5c2fe6fa23d109fb274d6c [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
34static void registerBICFunctions() __attribute__((constructor));
35
36extern message::Response::ptr executeIpmiCommand(message::Request::ptr);
37
38//----------------------------------------------------------------------
39// ipmiOemBicHandler (IPMI/Section - ) (CMD_OEM_BIC_INFO)
40// This Function will handle BIC request for netfn=0x38 and cmd=1
41// send the response back to the sender.
42//----------------------------------------------------------------------
43
44ipmi::RspType<std::array<uint8_t, 3>, uint8_t, uint2_t, uint6_t, uint8_t,
45 uint8_t, ipmi::message::Payload>
46 ipmiOemBicHandler(ipmi::Context::ptr ctx, std::array<uint8_t, 3> iana,
47 uint8_t interface, uint2_t lun, uint6_t netFnReq,
48 uint8_t cmdReq, std::vector<uint8_t> data)
49{
50
51 ipmi::message::Response::ptr res;
52
53 // Updating the correct netfn and cmd in the ipmi Context
54 ctx->netFn = ((uint8_t)netFnReq);
55 ctx->cmd = cmdReq;
56
57 // creating ipmi message request for calling executeIpmiCommand function
58 auto req = std::make_shared<ipmi::message::Request>(
59 ctx, std::forward<std::vector<uint8_t>>(data));
60
61 // Calling executeIpmiCommand request function
62 res = ipmi::executeIpmiCommand(req);
63
64 // sending the response with headers and payload
65 return ipmi::responseSuccess(iana, interface, lun, ++netFnReq, cmdReq,
66 res->cc, res->payload);
67}
68
Kumar Thangavelad049242020-08-31 22:27:33 +053069//----------------------------------------------------------------------
70// ipmiOemPostCodeHandler (CMD_OEM_BIC_POST_BUFFER_INFO)
71// This Function will handle BIC incomming postcode from multi-host for
72// netfn=0x38 and cmd=0x08 send the response back to the sender.
73//----------------------------------------------------------------------
74
75ipmi::RspType<std::array<uint8_t, 3>, uint8_t>
76 ipmiOemPostCodeHandler(ipmi::Context::ptr ctx, std::array<uint8_t, 3> iana,
77 uint8_t interface, uint8_t data)
78{
79 // creating bus connection
80 auto conn = getSdBus();
81
82 try
83 {
Manojkiran Edac723d6a2021-03-11 14:53:32 +053084 using postcode_t = std::tuple<uint64_t, std::vector<uint8_t>>;
85
86 uint64_t primaryPostCode = static_cast<uint64_t>(data);
Kumar Thangavel0fcfbee2021-04-16 12:38:20 +053087 auto postCode = postcode_t(primaryPostCode, {});
Kumar Thangavelad049242020-08-31 22:27:33 +053088
89 // creating dbus objects for 1 to N process
90 std::string dbusObjStr = dbusObj + std::to_string((ctx->hostIdx + 1));
91
92 // creating method call to update postd value
93 auto method = conn->new_method_call(
94 "xyz.openbmc_project.State.Boot.Raw", dbusObjStr.c_str(),
95 "org.freedesktop.DBus.Properties", "Set");
96
97 // Adding paramters to method call
Kumar Thangavel0fcfbee2021-04-16 12:38:20 +053098 method.append(dbusService, "Value", std::variant<postcode_t>(postCode));
Kumar Thangavelad049242020-08-31 22:27:33 +053099
100 // Invoke method call function
101 auto reply = conn->call(method);
102
103 // sending the success response with headers
104 return ipmi::responseSuccess(iana, interface);
105 }
106 catch (std::exception& e)
107 {
108 phosphor::logging::log<phosphor::logging::level::ERR>(
109 "post code handler error\n");
110
111 // sending the Error response
112 return ipmi::responseResponseError();
113 }
114}
115
Kumar Thangavel41ad4ff2020-06-11 10:31:07 +0530116static void registerBICFunctions(void)
117{
118
119 phosphor::logging::log<phosphor::logging::level::INFO>(
120 "Registering BIC commands");
121
122 ipmi::registerHandler(ipmi::prioOpenBmcBase, ipmi::netFnOemFive,
123 cmdOemBicInfo, ipmi::Privilege::User,
124 ipmiOemBicHandler);
Kumar Thangavelad049242020-08-31 22:27:33 +0530125 ipmi::registerHandler(ipmi::prioOpenBmcBase, ipmi::netFnOemFive,
126 cmdOemSendPostBufferToBMC, ipmi::Privilege::User,
127 ipmiOemPostCodeHandler);
Kumar Thangavel41ad4ff2020-06-11 10:31:07 +0530128 return;
129}
130
131} // namespace ipmi