blob: 2dd9531c23717b551661e0084ed837381cbe5ef3 [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 Venturea78e39f2018-11-06 18:37:06 -080021#include "image_handler.hpp"
Patrick Ventureefce8f92018-12-14 16:39:00 -080022#include "lpc_aspeed.hpp"
Patrick Venture1cde5f92018-11-07 08:26:47 -080023#include "lpc_handler.hpp"
Patrick Ventureefce8f92018-12-14 16:39:00 -080024#include "lpc_nuvoton.hpp"
Patrick Venture1cde5f92018-11-07 08:26:47 -080025#include "pci_handler.hpp"
Patrick Venture6d7735d2019-06-21 10:03:19 -070026#include "prepare_systemd.hpp"
Patrick Venture1d66fe62019-06-03 14:57:27 -070027#include "status.hpp"
Patrick Venture6f81b162019-05-20 14:02:59 -070028#include "update_systemd.hpp"
Patrick Venture7dad86f2019-05-17 08:52:20 -070029#include "util.hpp"
Patrick Venture26a17262019-05-20 11:03:35 -070030#include "verify_systemd.hpp"
Patrick Venturec7ca2912018-11-02 11:38:33 -070031
Patrick Venture192d60f2018-11-06 11:11:59 -080032#include <cstdint>
Patrick Venturec7ca2912018-11-02 11:38:33 -070033#include <memory>
34#include <phosphor-logging/log.hpp>
Patrick Venture4eb55952018-11-16 15:36:24 -080035#include <sdbusplus/bus.hpp>
Patrick Venturec7ca2912018-11-02 11:38:33 -070036
Patrick Venture1d5a31c2019-05-20 11:38:22 -070037namespace ipmi_flash
Patrick Venturec7ca2912018-11-02 11:38:33 -070038{
Patrick Venturea78e39f2018-11-06 18:37:06 -080039namespace
40{
Patrick Venture64919ec2018-11-15 11:52:07 -080041FileHandler hashHandler(HASH_FILENAME);
Patrick Venture2ba71302019-05-17 14:48:46 -070042#ifdef ENABLE_STATIC_LAYOUT
Patrick Venture7753d942018-11-15 13:15:36 -080043FileHandler staticLayoutHandler(STATIC_HANDLER_STAGED_NAME);
Patrick Venture2ba71302019-05-17 14:48:46 -070044#endif
45#ifdef ENABLE_TARBALL_UBI
Patrick Ventured46b8112018-11-15 13:38:55 -080046FileHandler ubitarballHandler(TARBALL_STAGED_NAME);
Patrick Venture2ba71302019-05-17 14:48:46 -070047#endif
Patrick Venturee7728422018-11-14 20:16:33 -080048
Patrick Venture7b91cbc2018-11-28 14:24:41 -080049/* The maximum external buffer size we expect is 64KB. */
Patrick Venture28abae72018-12-14 09:44:02 -080050static constexpr std::size_t memoryRegionSize = 64 * 1024UL;
Patrick Venture7b91cbc2018-11-28 14:24:41 -080051
Patrick Venturee7728422018-11-14 20:16:33 -080052#ifdef ENABLE_LPC_BRIDGE
53#if defined(ASPEED_LPC)
Patrick Venture78b1a662019-01-17 12:38:26 -080054LpcDataHandler lpcDataHandler(
55 LpcMapperAspeed::createAspeedMapper(MAPPED_ADDRESS, memoryRegionSize));
Patrick Venturee7728422018-11-14 20:16:33 -080056#elif defined(NUVOTON_LPC)
Patrick Venture36bffb42019-06-24 10:47:47 -070057LpcDataHandler lpcDataHandler(
58 LpcMapperNuvoton::createNuvotonMapper(MAPPED_ADDRESS, memoryRegionSize));
Patrick Venturee7728422018-11-14 20:16:33 -080059#else
60#error "You must specify a hardware implementation."
61#endif
62#endif
63
Patrick Venture102ecbb2019-04-30 16:08:49 -070064#ifdef ENABLE_PCI_BRIDGE
65#if defined(ASPEED_P2A)
Patrick Venture4289e712019-04-30 17:08:50 -070066PciDataHandler pciDataHandler(MAPPED_ADDRESS, memoryRegionSize);
Patrick Venture102ecbb2019-04-30 16:08:49 -070067#else
68#error "You must specify a hardware implementation."
69#endif
70#endif
Patrick Venturea78e39f2018-11-06 18:37:06 -080071
72std::vector<HandlerPack> supportedFirmware = {
Patrick Venture7dad86f2019-05-17 08:52:20 -070073 {hashBlobId, &hashHandler},
Patrick Venture148cd652018-11-06 10:59:47 -080074#ifdef ENABLE_STATIC_LAYOUT
Patrick Venture7dad86f2019-05-17 08:52:20 -070075 {staticLayoutBlobId, &staticLayoutHandler},
Patrick Venture148cd652018-11-06 10:59:47 -080076#endif
Patrick Ventured46b8112018-11-15 13:38:55 -080077#ifdef ENABLE_TARBALL_UBI
Patrick Venture7dad86f2019-05-17 08:52:20 -070078 {ubiTarballBlobId, &ubitarballHandler},
Patrick Ventured46b8112018-11-15 13:38:55 -080079#endif
Patrick Venture148cd652018-11-06 10:59:47 -080080};
81
Patrick Venture1cde5f92018-11-07 08:26:47 -080082std::vector<DataHandlerPack> supportedTransports = {
Patrick Venture05abf7e2018-11-09 11:02:56 -080083 {FirmwareBlobHandler::UpdateFlags::ipmi, nullptr},
Patrick Venture1cde5f92018-11-07 08:26:47 -080084#ifdef ENABLE_PCI_BRIDGE
Patrick Venture05abf7e2018-11-09 11:02:56 -080085 {FirmwareBlobHandler::UpdateFlags::p2a, &pciDataHandler},
Patrick Venture1cde5f92018-11-07 08:26:47 -080086#endif
87#ifdef ENABLE_LPC_BRIDGE
Patrick Venture05abf7e2018-11-09 11:02:56 -080088 {FirmwareBlobHandler::UpdateFlags::lpc, &lpcDataHandler},
Patrick Venture1cde5f92018-11-07 08:26:47 -080089#endif
90};
91
Patrick Venturea78e39f2018-11-06 18:37:06 -080092} // namespace
Patrick Venture192d60f2018-11-06 11:11:59 -080093
Patrick Venture1d5a31c2019-05-20 11:38:22 -070094} // namespace ipmi_flash
Patrick Venturec7ca2912018-11-02 11:38:33 -070095
Patrick Venture5b451e62018-11-14 14:20:08 -080096extern "C" {
Patrick Venture5b451e62018-11-14 14:20:08 -080097std::unique_ptr<blobs::GenericBlobInterface> createHandler();
Patrick Venture5b451e62018-11-14 14:20:08 -080098}
Patrick Venture5b451e62018-11-14 14:20:08 -080099
100std::unique_ptr<blobs::GenericBlobInterface> createHandler()
Patrick Venturec7ca2912018-11-02 11:38:33 -0700101{
Patrick Venture5b451e62018-11-14 14:20:08 -0800102 using namespace phosphor::logging;
103
Patrick Venture6f81b162019-05-20 14:02:59 -0700104#ifdef ENABLE_REBOOT_UPDATE
105 static constexpr auto rebootTarget = "reboot.target";
106 static constexpr auto rebootMode = "replace-irreversibly";
107
108 auto updater = ipmi_flash::SystemdUpdateMechanism::CreateSystemdUpdate(
109 sdbusplus::bus::new_default(), rebootTarget, rebootMode);
110#else
111 auto updater = ipmi_flash::SystemdUpdateMechanism::CreateSystemdUpdate(
112 sdbusplus::bus::new_default(), UPDATE_DBUS_SERVICE);
113#endif
114
Patrick Venture1d5a31c2019-05-20 11:38:22 -0700115 auto handler = ipmi_flash::FirmwareBlobHandler::CreateFirmwareBlobHandler(
116 ipmi_flash::supportedFirmware, ipmi_flash::supportedTransports,
Patrick Venture6d7735d2019-06-21 10:03:19 -0700117 ipmi_flash::SystemdPreparation::CreatePreparation(
118 sdbusplus::bus::new_default(), PREPARATION_DBUS_SERVICE),
Patrick Venture1d5a31c2019-05-20 11:38:22 -0700119 ipmi_flash::SystemdVerification::CreateVerification(
Patrick Venture3ecb3502019-05-17 11:03:51 -0700120 sdbusplus::bus::new_default(), VERIFY_STATUS_FILENAME,
Patrick Venture27ac5822019-05-20 17:39:31 -0700121 VERIFY_DBUS_SERVICE),
122 std::move(updater));
Patrick Venture52854622018-11-06 12:30:00 -0800123
124 if (!handler)
125 {
126 log<level::ERR>("Firmware Handler has invalid configuration");
Patrick Venture5b451e62018-11-14 14:20:08 -0800127 return nullptr;
Patrick Venture52854622018-11-06 12:30:00 -0800128 }
129
Patrick Venturee1118bc2019-06-19 07:32:48 -0700130 return handler;
Patrick Venturec7ca2912018-11-02 11:38:33 -0700131}