blob: 432856790958780d0664fec72da189918f6fee1e [file] [log] [blame]
Patrick Ventureef3aead2018-09-12 08:53:29 -07001/*
2 * Copyright 2018 Google Inc.
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#include "config.h"
18
19#include "ipmi.hpp"
20#include "process.hpp"
Patrick Venture5100a382018-09-27 10:40:50 -070021#include "utils.hpp"
Patrick Ventureef3aead2018-09-12 08:53:29 -070022
23#include <host-ipmid/ipmid-api.h>
24
25#include <cstdio>
26#include <host-ipmid/iana.hpp>
27#include <host-ipmid/oemrouter.hpp>
28#include <memory>
Benjamin Fair1c4d3d32018-10-19 17:22:53 -070029#include <phosphor-logging/log.hpp>
Patrick Ventureef3aead2018-09-12 08:53:29 -070030
31/* TODO: Swap out once https://gerrit.openbmc-project.xyz/12743 is merged */
32namespace oem
33{
34constexpr auto blobTransferCmd = 128;
35} // namespace oem
36
37namespace blobs
38{
39
Benjamin Fair1c4d3d32018-10-19 17:22:53 -070040using namespace phosphor::logging;
41
Patrick Ventureef3aead2018-09-12 08:53:29 -070042static ipmi_ret_t handleBlobCommand(ipmi_cmd_t cmd, const uint8_t* reqBuf,
43 uint8_t* replyCmdBuf, size_t* dataLen)
44{
45 /* It's holding at least a sub-command. The OEN is trimmed from the bytes
46 * before this is called.
47 */
48 if ((*dataLen) < 1)
49 {
Patrick Venture41258802018-11-12 10:46:30 -080050 return IPMI_CC_REQ_DATA_LEN_INVALID;
Patrick Ventureef3aead2018-09-12 08:53:29 -070051 }
52
Patrick Venture41258802018-11-12 10:46:30 -080053 /* on failure rc is set to the corresponding IPMI error. */
54 ipmi_ret_t rc = IPMI_CC_OK;
Patrick Ventureef3aead2018-09-12 08:53:29 -070055 Crc16 crc;
56 IpmiBlobHandler command =
Patrick Venture41258802018-11-12 10:46:30 -080057 validateBlobCommand(&crc, reqBuf, replyCmdBuf, dataLen, &rc);
Patrick Ventureef3aead2018-09-12 08:53:29 -070058 if (command == nullptr)
59 {
Patrick Venture41258802018-11-12 10:46:30 -080060 return rc;
Patrick Ventureef3aead2018-09-12 08:53:29 -070061 }
62
Patrick Venture73eb6872018-10-01 18:37:34 -070063 return processBlobCommand(command, getBlobManager(), &crc, reqBuf,
64 replyCmdBuf, dataLen);
Patrick Ventureef3aead2018-09-12 08:53:29 -070065}
66
Patrick Venture5100a382018-09-27 10:40:50 -070067/* TODO: this should come from the makefile or recipe... */
Patrick Venturedf53de12018-11-08 10:29:50 -080068constexpr auto expectedHandlerPath = "/usr/lib/blob-ipmid";
Patrick Venture5100a382018-09-27 10:40:50 -070069
Patrick Ventureef3aead2018-09-12 08:53:29 -070070void setupBlobGlobalHandler() __attribute__((constructor));
71
72void setupBlobGlobalHandler()
73{
74 oem::Router* oemRouter = oem::mutableRouter();
75 std::fprintf(stderr,
76 "Registering OEM:[%#08X], Cmd:[%#04X] for Blob Commands\n",
77 oem::obmcOemNumber, oem::blobTransferCmd);
78
79 oemRouter->registerHandler(oem::obmcOemNumber, oem::blobTransferCmd,
80 handleBlobCommand);
81
Patrick Venture5100a382018-09-27 10:40:50 -070082 /* Install handlers. */
Benjamin Fair1c4d3d32018-10-19 17:22:53 -070083 try
84 {
85 loadLibraries(expectedHandlerPath);
86 }
87 catch (const std::exception& e)
88 {
89 log<level::ERR>("ERROR loading blob handlers",
90 entry("ERROR=%s", e.what()));
91 }
Patrick Ventureef3aead2018-09-12 08:53:29 -070092}
93} // namespace blobs