blob: a383d02b778587233c5cbe7b9c990813bfe64808 [file] [log] [blame]
Patrick Venture22e38752018-11-21 08:52:49 -08001/*
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
Patrick Venture148cd652018-11-06 10:59:47 -080017#include "config.h"
18
Patrick Venture64919ec2018-11-15 11:52:07 -080019#include "file_handler.hpp"
Patrick Venturec7ca2912018-11-02 11:38:33 -070020#include "firmware_handler.hpp"
Jason Lingc893f432020-10-24 19:31:44 -070021#include "firmware_handlers_builder.hpp"
Patrick Venture84778b82019-06-26 20:11:09 -070022#include "flags.hpp"
Patrick Venturecf066ac2019-08-06 09:03:47 -070023#include "general_systemd.hpp"
Patrick Venturea78e39f2018-11-06 18:37:06 -080024#include "image_handler.hpp"
Patrick Ventureefce8f92018-12-14 16:39:00 -080025#include "lpc_aspeed.hpp"
Patrick Venture1cde5f92018-11-07 08:26:47 -080026#include "lpc_handler.hpp"
Patrick Ventureefce8f92018-12-14 16:39:00 -080027#include "lpc_nuvoton.hpp"
Benjamin Fair545f5652019-10-09 14:18:54 -070028#include "net_handler.hpp"
Patrick Venture1cde5f92018-11-07 08:26:47 -080029#include "pci_handler.hpp"
Patrick Venture1d66fe62019-06-03 14:57:27 -070030#include "status.hpp"
Patrick Venture7dad86f2019-05-17 08:52:20 -070031#include "util.hpp"
Patrick Venturec7ca2912018-11-02 11:38:33 -070032
Patrick Venture4eb55952018-11-16 15:36:24 -080033#include <sdbusplus/bus.hpp>
Patrick Venture9b37b092020-05-28 20:58:57 -070034
35#include <cstdint>
36#include <memory>
Patrick Venturea6b4abd2019-07-19 10:58:55 -070037#include <string>
Patrick Venturefa06a5f2019-07-01 09:22:38 -070038#include <unordered_map>
Patrick Venturea6b4abd2019-07-19 10:58:55 -070039#include <vector>
Patrick Venturec7ca2912018-11-02 11:38:33 -070040
Patrick Venture1d5a31c2019-05-20 11:38:22 -070041namespace ipmi_flash
Patrick Venturec7ca2912018-11-02 11:38:33 -070042{
Patrick Venturea6b4abd2019-07-19 10:58:55 -070043
Patrick Venturea78e39f2018-11-06 18:37:06 -080044namespace
45{
Patrick Venture48e309c2019-06-29 07:51:19 -070046
Patrick Venturef32a4532019-07-19 10:15:40 -070047/**
48 * Given a name and path, create a HandlerPack.
49 *
50 * @param[in] name - the blob id path for this
51 * @param[in] path - the file path to write the contents.
52 * @return the HandlerPack.
53 */
54HandlerPack CreateFileHandlerPack(const std::string& name,
55 const std::string& path)
56{
57 return HandlerPack(name, std::make_unique<FileHandler>(path));
58}
59
Patrick Venturef62ec6b2020-09-24 09:07:10 -070060#ifdef NUVOTON_P2A_MBOX
Patrick Venture43a2d162020-09-24 15:55:41 -070061static constexpr std::size_t memoryRegionSize = 16 * 1024UL;
Patrick Venturef62ec6b2020-09-24 09:07:10 -070062#elif defined NUVOTON_P2A_VGA
Patrick Venture43a2d162020-09-24 15:55:41 -070063static constexpr std::size_t memoryRegionSize = 4 * 1024 * 1024UL;
Patrick Venturef62ec6b2020-09-24 09:07:10 -070064#else
Patrick Venture43a2d162020-09-24 15:55:41 -070065/* The maximum external buffer size we expect is 64KB. */
66static constexpr std::size_t memoryRegionSize = 64 * 1024UL;
Patrick Venturef62ec6b2020-09-24 09:07:10 -070067#endif
68
Patrick Venturea78e39f2018-11-06 18:37:06 -080069} // namespace
Patrick Venture1d5a31c2019-05-20 11:38:22 -070070} // namespace ipmi_flash
Patrick Venturec7ca2912018-11-02 11:38:33 -070071
Patrick Venture9b37b092020-05-28 20:58:57 -070072extern "C"
73{
74 std::unique_ptr<blobs::GenericBlobInterface> createHandler();
Patrick Venture5b451e62018-11-14 14:20:08 -080075}
Patrick Venture5b451e62018-11-14 14:20:08 -080076
77std::unique_ptr<blobs::GenericBlobInterface> createHandler()
Patrick Venturec7ca2912018-11-02 11:38:33 -070078{
Patrick Venturee7402692020-09-22 16:26:22 -070079 using namespace ipmi_flash;
Patrick Venture7c2a00e2019-07-01 17:33:03 -070080
Patrick Venture4934daa2020-09-22 16:37:44 -070081 std::vector<DataHandlerPack> supportedTransports;
82
83 supportedTransports.emplace_back(FirmwareFlags::UpdateFlags::ipmi, nullptr);
84
Patrick Venture12b76c92020-09-22 16:31:39 -070085#ifdef ENABLE_PCI_BRIDGE
Patrick Venture4934daa2020-09-22 16:37:44 -070086 supportedTransports.emplace_back(
87 FirmwareFlags::UpdateFlags::p2a,
Patrick Venture43a2d162020-09-24 15:55:41 -070088 std::make_unique<PciDataHandler>(MAPPED_ADDRESS, memoryRegionSize));
Patrick Venture12b76c92020-09-22 16:31:39 -070089#endif
Patrick Venture4934daa2020-09-22 16:37:44 -070090
Patrick Venture12b76c92020-09-22 16:31:39 -070091#ifdef ENABLE_LPC_BRIDGE
Patrick Venture4934daa2020-09-22 16:37:44 -070092#if defined(ASPEED_LPC)
93 supportedTransports.emplace_back(
94 FirmwareFlags::UpdateFlags::lpc,
95 std::make_unique<LpcDataHandler>(LpcMapperAspeed::createAspeedMapper(
Patrick Venture43a2d162020-09-24 15:55:41 -070096 MAPPED_ADDRESS, memoryRegionSize)));
Patrick Venture4934daa2020-09-22 16:37:44 -070097#elif defined(NUVOTON_LPC)
98 supportedTransports.emplace_back(
99 FirmwareFlags::UpdateFlags::lpc,
100 std::make_unique<LpcDataHandler>(LpcMapperNuvoton::createNuvotonMapper(
Patrick Venture43a2d162020-09-24 15:55:41 -0700101 MAPPED_ADDRESS, memoryRegionSize)));
Patrick Venture4934daa2020-09-22 16:37:44 -0700102#else
103#error "You must specify a hardware implementation."
Patrick Venture12b76c92020-09-22 16:31:39 -0700104#endif
Patrick Venture4934daa2020-09-22 16:37:44 -0700105#endif
106
Patrick Venture12b76c92020-09-22 16:31:39 -0700107#ifdef ENABLE_NET_BRIDGE
Patrick Venture4934daa2020-09-22 16:37:44 -0700108 supportedTransports.emplace_back(FirmwareFlags::UpdateFlags::net,
109 std::make_unique<NetDataHandler>());
Patrick Venture12b76c92020-09-22 16:31:39 -0700110#endif
Patrick Venture12b76c92020-09-22 16:31:39 -0700111
Patrick Venturee7402692020-09-22 16:26:22 -0700112 ActionMap actionPacks = {};
Jason Lingc893f432020-10-24 19:31:44 -0700113 FirmwareHandlersBuilder builder;
Patrick Venture7c2a00e2019-07-01 17:33:03 -0700114
William A. Kennington IIId0dc7232021-01-28 21:25:04 -0800115 auto configsFromJson = builder.buildHandlerConfigsFromDefaultPaths();
Patrick Ventured4e20de2019-07-18 12:48:05 -0700116
Patrick Venturee7402692020-09-22 16:26:22 -0700117 std::vector<HandlerPack> supportedFirmware;
118
119 supportedFirmware.push_back(
120 std::move(CreateFileHandlerPack(hashBlobId, HASH_FILENAME)));
Patrick Ventured4e20de2019-07-18 12:48:05 -0700121
Patrick Venture1871fe92019-07-19 14:46:08 -0700122 for (auto& config : configsFromJson)
123 {
Patrick Venturec6ba8ff2020-09-23 12:42:57 -0700124 supportedFirmware.emplace_back(config.blobId,
125 std::move(config.handler));
Patrick Venture1871fe92019-07-19 14:46:08 -0700126 actionPacks[config.blobId] = std::move(config.actions);
127
128 std::fprintf(stderr, "config loaded: %s\n", config.blobId.c_str());
129 }
Patrick Ventured4e20de2019-07-18 12:48:05 -0700130
Patrick Venturee7402692020-09-22 16:26:22 -0700131 auto handler = FirmwareBlobHandler::CreateFirmwareBlobHandler(
132 std::move(supportedFirmware), std::move(supportedTransports),
133 std::move(actionPacks));
Patrick Venture52854622018-11-06 12:30:00 -0800134
135 if (!handler)
136 {
Patrick Venture1ab824a2020-05-26 19:29:57 -0700137 std::fprintf(stderr, "Firmware Handler has an invalid configuration");
Patrick Venture5b451e62018-11-14 14:20:08 -0800138 return nullptr;
Patrick Venture52854622018-11-06 12:30:00 -0800139 }
140
Patrick Venturee1118bc2019-06-19 07:32:48 -0700141 return handler;
Patrick Venturec7ca2912018-11-02 11:38:33 -0700142}