blob: 16313de9ff3a0abf70564335e512659720dd6953 [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>
Patrick Venturee08863e2018-11-15 14:39:44 -080027#include <host-ipmid/oemopenbmc.hpp>
Patrick Ventureef3aead2018-09-12 08:53:29 -070028#include <host-ipmid/oemrouter.hpp>
29#include <memory>
Benjamin Fair1c4d3d32018-10-19 17:22:53 -070030#include <phosphor-logging/log.hpp>
Patrick Ventureef3aead2018-09-12 08:53:29 -070031
Patrick Ventureef3aead2018-09-12 08:53:29 -070032namespace blobs
33{
34
Benjamin Fair1c4d3d32018-10-19 17:22:53 -070035using namespace phosphor::logging;
36
Patrick Ventureef3aead2018-09-12 08:53:29 -070037static ipmi_ret_t handleBlobCommand(ipmi_cmd_t cmd, const uint8_t* reqBuf,
38 uint8_t* replyCmdBuf, size_t* dataLen)
39{
40 /* It's holding at least a sub-command. The OEN is trimmed from the bytes
41 * before this is called.
42 */
43 if ((*dataLen) < 1)
44 {
Patrick Venture41258802018-11-12 10:46:30 -080045 return IPMI_CC_REQ_DATA_LEN_INVALID;
Patrick Ventureef3aead2018-09-12 08:53:29 -070046 }
47
Patrick Venture41258802018-11-12 10:46:30 -080048 /* on failure rc is set to the corresponding IPMI error. */
49 ipmi_ret_t rc = IPMI_CC_OK;
Patrick Ventureef3aead2018-09-12 08:53:29 -070050 Crc16 crc;
51 IpmiBlobHandler command =
Patrick Venture41258802018-11-12 10:46:30 -080052 validateBlobCommand(&crc, reqBuf, replyCmdBuf, dataLen, &rc);
Patrick Ventureef3aead2018-09-12 08:53:29 -070053 if (command == nullptr)
54 {
Patrick Venture41258802018-11-12 10:46:30 -080055 return rc;
Patrick Ventureef3aead2018-09-12 08:53:29 -070056 }
57
Patrick Venture73eb6872018-10-01 18:37:34 -070058 return processBlobCommand(command, getBlobManager(), &crc, reqBuf,
59 replyCmdBuf, dataLen);
Patrick Ventureef3aead2018-09-12 08:53:29 -070060}
61
Patrick Venture5100a382018-09-27 10:40:50 -070062/* TODO: this should come from the makefile or recipe... */
Patrick Venturedf53de12018-11-08 10:29:50 -080063constexpr auto expectedHandlerPath = "/usr/lib/blob-ipmid";
Patrick Venture5100a382018-09-27 10:40:50 -070064
Patrick Ventureef3aead2018-09-12 08:53:29 -070065void setupBlobGlobalHandler() __attribute__((constructor));
66
67void setupBlobGlobalHandler()
68{
69 oem::Router* oemRouter = oem::mutableRouter();
70 std::fprintf(stderr,
71 "Registering OEM:[%#08X], Cmd:[%#04X] for Blob Commands\n",
Patrick Venturee08863e2018-11-15 14:39:44 -080072 oem::obmcOemNumber, oem::Cmd::blobTransferCmd);
Patrick Ventureef3aead2018-09-12 08:53:29 -070073
Patrick Venturee08863e2018-11-15 14:39:44 -080074 oemRouter->registerHandler(oem::obmcOemNumber, oem::Cmd::blobTransferCmd,
Patrick Ventureef3aead2018-09-12 08:53:29 -070075 handleBlobCommand);
76
Patrick Venture5100a382018-09-27 10:40:50 -070077 /* Install handlers. */
Benjamin Fair1c4d3d32018-10-19 17:22:53 -070078 try
79 {
80 loadLibraries(expectedHandlerPath);
81 }
82 catch (const std::exception& e)
83 {
84 log<level::ERR>("ERROR loading blob handlers",
85 entry("ERROR=%s", e.what()));
86 }
Patrick Ventureef3aead2018-09-12 08:53:29 -070087}
88} // namespace blobs