blob: 5f16ff60014ceb45d66140510820d6ab927a7ddb [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"
Patrick Venture84778b82019-06-26 20:11:09 -070021#include "flags.hpp"
Patrick Venturea78e39f2018-11-06 18:37:06 -080022#include "image_handler.hpp"
Patrick Ventureefce8f92018-12-14 16:39:00 -080023#include "lpc_aspeed.hpp"
Patrick Venture1cde5f92018-11-07 08:26:47 -080024#include "lpc_handler.hpp"
Patrick Ventureefce8f92018-12-14 16:39:00 -080025#include "lpc_nuvoton.hpp"
Patrick Venture1cde5f92018-11-07 08:26:47 -080026#include "pci_handler.hpp"
Patrick Venture6d7735d2019-06-21 10:03:19 -070027#include "prepare_systemd.hpp"
Patrick Venture1d66fe62019-06-03 14:57:27 -070028#include "status.hpp"
Patrick Venture6f81b162019-05-20 14:02:59 -070029#include "update_systemd.hpp"
Patrick Venture7dad86f2019-05-17 08:52:20 -070030#include "util.hpp"
Patrick Venture26a17262019-05-20 11:03:35 -070031#include "verify_systemd.hpp"
Patrick Venturec7ca2912018-11-02 11:38:33 -070032
Patrick Venture192d60f2018-11-06 11:11:59 -080033#include <cstdint>
Patrick Venturec7ca2912018-11-02 11:38:33 -070034#include <memory>
35#include <phosphor-logging/log.hpp>
Patrick Venture4eb55952018-11-16 15:36:24 -080036#include <sdbusplus/bus.hpp>
Patrick Venturefa06a5f2019-07-01 09:22:38 -070037#include <unordered_map>
Patrick Venturec7ca2912018-11-02 11:38:33 -070038
Patrick Venture1d5a31c2019-05-20 11:38:22 -070039namespace ipmi_flash
Patrick Venturec7ca2912018-11-02 11:38:33 -070040{
Patrick Venturea78e39f2018-11-06 18:37:06 -080041namespace
42{
Patrick Venture48e309c2019-06-29 07:51:19 -070043
Patrick Venture7b91cbc2018-11-28 14:24:41 -080044/* The maximum external buffer size we expect is 64KB. */
Patrick Venture28abae72018-12-14 09:44:02 -080045static constexpr std::size_t memoryRegionSize = 64 * 1024UL;
Patrick Venture7b91cbc2018-11-28 14:24:41 -080046
Patrick Venturee7728422018-11-14 20:16:33 -080047#ifdef ENABLE_LPC_BRIDGE
48#if defined(ASPEED_LPC)
Patrick Venture78b1a662019-01-17 12:38:26 -080049LpcDataHandler lpcDataHandler(
50 LpcMapperAspeed::createAspeedMapper(MAPPED_ADDRESS, memoryRegionSize));
Patrick Venturee7728422018-11-14 20:16:33 -080051#elif defined(NUVOTON_LPC)
Patrick Venture36bffb42019-06-24 10:47:47 -070052LpcDataHandler lpcDataHandler(
53 LpcMapperNuvoton::createNuvotonMapper(MAPPED_ADDRESS, memoryRegionSize));
Patrick Venturee7728422018-11-14 20:16:33 -080054#else
55#error "You must specify a hardware implementation."
56#endif
57#endif
58
Patrick Venture102ecbb2019-04-30 16:08:49 -070059#ifdef ENABLE_PCI_BRIDGE
60#if defined(ASPEED_P2A)
Patrick Venture4289e712019-04-30 17:08:50 -070061PciDataHandler pciDataHandler(MAPPED_ADDRESS, memoryRegionSize);
Patrick Venture102ecbb2019-04-30 16:08:49 -070062#else
63#error "You must specify a hardware implementation."
64#endif
65#endif
Patrick Venturea78e39f2018-11-06 18:37:06 -080066
Patrick Venture1cde5f92018-11-07 08:26:47 -080067std::vector<DataHandlerPack> supportedTransports = {
Patrick Venture84778b82019-06-26 20:11:09 -070068 {FirmwareFlags::UpdateFlags::ipmi, nullptr},
Patrick Venture1cde5f92018-11-07 08:26:47 -080069#ifdef ENABLE_PCI_BRIDGE
Patrick Venture84778b82019-06-26 20:11:09 -070070 {FirmwareFlags::UpdateFlags::p2a, &pciDataHandler},
Patrick Venture1cde5f92018-11-07 08:26:47 -080071#endif
72#ifdef ENABLE_LPC_BRIDGE
Patrick Venture84778b82019-06-26 20:11:09 -070073 {FirmwareFlags::UpdateFlags::lpc, &lpcDataHandler},
Patrick Venture1cde5f92018-11-07 08:26:47 -080074#endif
75};
76
Patrick Venturea78e39f2018-11-06 18:37:06 -080077} // namespace
Patrick Venture1d5a31c2019-05-20 11:38:22 -070078} // namespace ipmi_flash
Patrick Venturec7ca2912018-11-02 11:38:33 -070079
Patrick Venture5b451e62018-11-14 14:20:08 -080080extern "C" {
Patrick Venture5b451e62018-11-14 14:20:08 -080081std::unique_ptr<blobs::GenericBlobInterface> createHandler();
Patrick Venture5b451e62018-11-14 14:20:08 -080082}
Patrick Venture5b451e62018-11-14 14:20:08 -080083
84std::unique_ptr<blobs::GenericBlobInterface> createHandler()
Patrick Venturec7ca2912018-11-02 11:38:33 -070085{
Patrick Venture7c2a00e2019-07-01 17:33:03 -070086 ipmi_flash::ActionMap actionPacks = {};
87
Patrick Venture6f81b162019-05-20 14:02:59 -070088#ifdef ENABLE_REBOOT_UPDATE
89 static constexpr auto rebootTarget = "reboot.target";
90 static constexpr auto rebootMode = "replace-irreversibly";
91
92 auto updater = ipmi_flash::SystemdUpdateMechanism::CreateSystemdUpdate(
93 sdbusplus::bus::new_default(), rebootTarget, rebootMode);
94#else
95 auto updater = ipmi_flash::SystemdUpdateMechanism::CreateSystemdUpdate(
96 sdbusplus::bus::new_default(), UPDATE_DBUS_SERVICE);
97#endif
98
Patrick Venture48e309c2019-06-29 07:51:19 -070099 auto prepare = ipmi_flash::SystemdPreparation::CreatePreparation(
100 sdbusplus::bus::new_default(), PREPARATION_DBUS_SERVICE);
101
102 auto verifier = ipmi_flash::SystemdVerification::CreateVerification(
103 sdbusplus::bus::new_default(), VERIFY_STATUS_FILENAME,
104 VERIFY_DBUS_SERVICE);
105
Patrick Venturefa06a5f2019-07-01 09:22:38 -0700106 /* TODO: for bios should the name be, bios or /flash/bios?, these are
107 * /flash/... and it simplifies a few other things later (open/etc)
108 */
109 std::string bmcName;
110#ifdef ENABLE_STATIC_LAYOUT
111 bmcName = ipmi_flash::staticLayoutBlobId;
112#endif
113#ifdef ENABLE_TARBALL_UBI
114 bmcName = ipmi_flash::ubiTarballBlobId;
115#endif
116
117 auto bmcPack = std::make_unique<ipmi_flash::ActionPack>();
118 bmcPack->preparation = std::move(prepare);
119 bmcPack->verification = std::move(verifier);
120 bmcPack->update = std::move(updater);
121 actionPacks[bmcName] = std::move(bmcPack);
122
Patrick Venture7c2a00e2019-07-01 17:33:03 -0700123#ifdef ENABLE_HOST_BIOS
124 {
125 auto biosPack = std::make_unique<ipmi_flash::ActionPack>();
126
127 biosPack->preparation =
128 ipmi_flash::SystemdPreparation::CreatePreparation(
129 sdbusplus::bus::new_default(), PREPARATION_BIOS_TARGET);
130
131 biosPack->verification =
132 ipmi_flash::SystemdVerification::CreateVerification(
133 sdbusplus::bus::new_default(), BIOS_VERIFY_STATUS_FILENAME,
134 VERIFY_BIOS_TARGET);
135
136 biosPack->update =
137 ipmi_flash::SystemdUpdateMechanism::CreateSystemdUpdate(
138 sdbusplus::bus::new_default(), UPDATE_BIOS_TARGET);
139
140 actionPacks[ipmi_flash::biosBlobId] = std::move(biosPack);
141 }
142#endif
143
Patrick Ventured4e20de2019-07-18 12:48:05 -0700144 std::vector<ipmi_flash::HandlerPack> supportedFirmware;
145
146 supportedFirmware.push_back(std::move(ipmi_flash::HandlerPack(
147 ipmi_flash::hashBlobId,
148 std::make_unique<ipmi_flash::FileHandler>(HASH_FILENAME))));
149
150#ifdef ENABLE_STATIC_LAYOUT
151 supportedFirmware.push_back(std::move(
152 ipmi_flash::HandlerPack(ipmi_flash::staticLayoutBlobId,
153 std::make_unique<ipmi_flash::FileHandler>(
154 STATIC_HANDLER_STAGED_NAME))));
155#endif
156#ifdef ENABLE_TARBALL_UBI
157 supportedFirmware.push_back(std::move(ipmi_flash::HandlerPack(
158 ipmi_flash::ubiTarballBlobId,
159 std::make_unique<ipmi_flash::FileHandler>(TARBALL_STAGED_NAME))));
160#endif
161#ifdef ENABLE_HOST_BIOS
162 supportedFirmware.push_back(std::move(ipmi_flash::HandlerPack(
163 ipmi_flash::biosBlobId,
164 std::make_unique<ipmi_flash::FileHandler>(BIOS_STAGED_NAME))));
165#endif
166
Patrick Venture1d5a31c2019-05-20 11:38:22 -0700167 auto handler = ipmi_flash::FirmwareBlobHandler::CreateFirmwareBlobHandler(
Patrick Ventured4e20de2019-07-18 12:48:05 -0700168 std::move(supportedFirmware), ipmi_flash::supportedTransports,
Patrick Venturefa06a5f2019-07-01 09:22:38 -0700169 std::move(actionPacks));
Patrick Venture52854622018-11-06 12:30:00 -0800170
171 if (!handler)
172 {
Patrick Venture48e309c2019-06-29 07:51:19 -0700173 using namespace phosphor::logging;
174
Patrick Venture52854622018-11-06 12:30:00 -0800175 log<level::ERR>("Firmware Handler has invalid configuration");
Patrick Venture5b451e62018-11-14 14:20:08 -0800176 return nullptr;
Patrick Venture52854622018-11-06 12:30:00 -0800177 }
178
Patrick Venturee1118bc2019-06-19 07:32:48 -0700179 return handler;
Patrick Venturec7ca2912018-11-02 11:38:33 -0700180}