blob: f8700b193fd2dbdc16e3f9a054e3170f011df984 [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 Venturec7ca2912018-11-02 11:38:33 -070026
27#include <blobs-ipmid/manager.hpp>
Patrick Venture192d60f2018-11-06 11:11:59 -080028#include <cstdint>
Patrick Venturec7ca2912018-11-02 11:38:33 -070029#include <memory>
30#include <phosphor-logging/log.hpp>
Patrick Venture4eb55952018-11-16 15:36:24 -080031#include <sdbusplus/bus.hpp>
Patrick Venturec7ca2912018-11-02 11:38:33 -070032
33namespace blobs
34{
Patrick Venturea78e39f2018-11-06 18:37:06 -080035namespace
36{
Patrick Venture64919ec2018-11-15 11:52:07 -080037FileHandler hashHandler(HASH_FILENAME);
Patrick Venture7753d942018-11-15 13:15:36 -080038FileHandler staticLayoutHandler(STATIC_HANDLER_STAGED_NAME);
Patrick Ventured46b8112018-11-15 13:38:55 -080039FileHandler ubitarballHandler(TARBALL_STAGED_NAME);
Patrick Venturee7728422018-11-14 20:16:33 -080040
Patrick Venture7b91cbc2018-11-28 14:24:41 -080041/* The maximum external buffer size we expect is 64KB. */
Patrick Venture28abae72018-12-14 09:44:02 -080042static constexpr std::size_t memoryRegionSize = 64 * 1024UL;
Patrick Venture7b91cbc2018-11-28 14:24:41 -080043
Patrick Venturee7728422018-11-14 20:16:33 -080044#ifdef ENABLE_LPC_BRIDGE
45#if defined(ASPEED_LPC)
Patrick Venture7b91cbc2018-11-28 14:24:41 -080046LpcDataHandler
47 lpcDataHandler(MAPPED_ADDRESS,
48 LpcMapperAspeed::createAspeedMapper(memoryRegionSize));
Patrick Venturee7728422018-11-14 20:16:33 -080049#elif defined(NUVOTON_LPC)
Patrick Venture002916a2018-11-15 10:38:07 -080050LpcDataHandler lpcDataHandler(MAPPED_ADDRESS,
51 LpcMapperNuvoton::createNuvotonMapper());
Patrick Venturee7728422018-11-14 20:16:33 -080052#else
53#error "You must specify a hardware implementation."
54#endif
55#endif
56
Patrick Venture002916a2018-11-15 10:38:07 -080057PciDataHandler pciDataHandler(MAPPED_ADDRESS);
Patrick Venturea78e39f2018-11-06 18:37:06 -080058
59std::vector<HandlerPack> supportedFirmware = {
Patrick Venture18235e62018-11-08 10:21:09 -080060 {FirmwareBlobHandler::hashBlobID, &hashHandler},
Patrick Venture148cd652018-11-06 10:59:47 -080061#ifdef ENABLE_STATIC_LAYOUT
Patrick Venturea78e39f2018-11-06 18:37:06 -080062 {"/flash/image", &staticLayoutHandler},
Patrick Venture148cd652018-11-06 10:59:47 -080063#endif
Patrick Ventured46b8112018-11-15 13:38:55 -080064#ifdef ENABLE_TARBALL_UBI
65 {"/flash/tarball", &ubitarballHandler},
66#endif
Patrick Venture148cd652018-11-06 10:59:47 -080067};
68
Patrick Venture1cde5f92018-11-07 08:26:47 -080069std::vector<DataHandlerPack> supportedTransports = {
Patrick Venture05abf7e2018-11-09 11:02:56 -080070 {FirmwareBlobHandler::UpdateFlags::ipmi, nullptr},
Patrick Venture1cde5f92018-11-07 08:26:47 -080071#ifdef ENABLE_PCI_BRIDGE
Patrick Venture05abf7e2018-11-09 11:02:56 -080072 {FirmwareBlobHandler::UpdateFlags::p2a, &pciDataHandler},
Patrick Venture1cde5f92018-11-07 08:26:47 -080073#endif
74#ifdef ENABLE_LPC_BRIDGE
Patrick Venture05abf7e2018-11-09 11:02:56 -080075 {FirmwareBlobHandler::UpdateFlags::lpc, &lpcDataHandler},
Patrick Venture1cde5f92018-11-07 08:26:47 -080076#endif
77};
78
Patrick Venturea78e39f2018-11-06 18:37:06 -080079} // namespace
Patrick Venture192d60f2018-11-06 11:11:59 -080080
Patrick Venture5b451e62018-11-14 14:20:08 -080081} // namespace blobs
Patrick Venturec7ca2912018-11-02 11:38:33 -070082
Patrick Venture5b451e62018-11-14 14:20:08 -080083extern "C" {
Patrick Venture5b451e62018-11-14 14:20:08 -080084std::unique_ptr<blobs::GenericBlobInterface> createHandler();
Patrick Venture5b451e62018-11-14 14:20:08 -080085}
Patrick Venture5b451e62018-11-14 14:20:08 -080086
87std::unique_ptr<blobs::GenericBlobInterface> createHandler()
Patrick Venturec7ca2912018-11-02 11:38:33 -070088{
Patrick Venture5b451e62018-11-14 14:20:08 -080089 using namespace phosphor::logging;
90
91 auto handler = blobs::FirmwareBlobHandler::CreateFirmwareBlobHandler(
Patrick Venture4eb55952018-11-16 15:36:24 -080092 sdbusplus::bus::new_default(), blobs::supportedFirmware,
93 blobs::supportedTransports);
Patrick Venture52854622018-11-06 12:30:00 -080094
95 if (!handler)
96 {
97 log<level::ERR>("Firmware Handler has invalid configuration");
Patrick Venture5b451e62018-11-14 14:20:08 -080098 return nullptr;
Patrick Venture52854622018-11-06 12:30:00 -080099 }
100
Patrick Venture5b451e62018-11-14 14:20:08 -0800101 return std::move(handler);
Patrick Venturec7ca2912018-11-02 11:38:33 -0700102}