blob: 46497e3922ec0ccaec306b3041f8808e60954a6c [file] [log] [blame]
Patrick Venturec7ca2912018-11-02 11:38:33 -07001#pragma once
2
Patrick Venture1cde5f92018-11-07 08:26:47 -08003#include "data_handler.hpp"
Patrick Venturea78e39f2018-11-06 18:37:06 -08004#include "image_handler.hpp"
5
Patrick Venturec7ca2912018-11-02 11:38:33 -07006#include <blobs-ipmid/blobs.hpp>
Patrick Venture192d60f2018-11-06 11:11:59 -08007#include <cstdint>
Patrick Ventured9fb6132018-11-08 09:56:10 -08008#include <map>
Patrick Venture68cf64f2018-11-06 10:46:51 -08009#include <memory>
Patrick Venture148cd652018-11-06 10:59:47 -080010#include <string>
11#include <vector>
Patrick Venturec7ca2912018-11-02 11:38:33 -070012
13namespace blobs
14{
15
Patrick Venturec7ca2912018-11-02 11:38:33 -070016/**
Patrick Venture2d3a2542018-11-08 09:23:24 -080017 * Representation of a session, includes how to read/write data.
18 */
19struct Session
20{
21 /** Pointer to the correct Data handler interface. (nullptr on BT (or KCS))
22 */
23 DataInterface* dataHandler;
24
25 /** Pointer to the correct image handler interface. (nullptr on hash
26 * blob_id) */
27 ImageHandlerInterface* imageHandler;
Patrick Venture18235e62018-11-08 10:21:09 -080028
29 /** The flags used to open the session. */
30 std::uint16_t flags;
Patrick Venture32ba9dd2018-11-09 16:22:53 -080031
32 /** A sesion can be for an image (or tarball) or the hash. */
33 enum State
34 {
35 open = 0,
36 closed = 1,
37 };
38
39 /** The current state of this session. */
40 State state;
Patrick Venture2d3a2542018-11-08 09:23:24 -080041};
42
Patrick Venture18235e62018-11-08 10:21:09 -080043struct ExtChunkHdr
44{
45 std::uint32_t length; /* Length of the data queued (little endian). */
46} __attribute__((packed));
47
Patrick Venture2d3a2542018-11-08 09:23:24 -080048/**
Patrick Venturec7ca2912018-11-02 11:38:33 -070049 * Register only one firmware blob handler that will manage all sessions.
50 */
51class FirmwareBlobHandler : public GenericBlobInterface
52{
53 public:
Patrick Venture05abf7e2018-11-09 11:02:56 -080054 enum UpdateFlags : std::uint16_t
Patrick Venturefc3857b2018-11-07 08:14:55 -080055 {
Patrick Venture9158dcf2018-11-08 09:44:28 -080056 ipmi = (1 << 8), /* Expect to send contents over IPMI BlockTransfer. */
Patrick Venturefc3857b2018-11-07 08:14:55 -080057 p2a = (1 << 9), /* Expect to send contents over P2A bridge. */
58 lpc = (1 << 10), /* Expect to send contents over LPC bridge. */
59 };
60
Patrick Venture92106df2018-11-09 09:26:30 -080061 /** The state of the firmware update process. */
62 enum UpdateState
63 {
64 /** The initial state. */
65 notYetStarted = 0,
66 /**
67 * The upload process has started, but verification has not started.
68 */
69 uploadInProgress = 1,
70 /** The verification process has started, no more writes allowed. */
71 verificationStarted = 2,
72 /** The verification process has completed. */
73 verificationCompleted = 3,
74 };
75
Patrick Venture137ad2c2018-11-06 11:30:43 -080076 /**
77 * Create a FirmwareBlobHandler.
78 *
Patrick Venture4cceb8e2018-11-06 11:56:48 -080079 * @param[in] firmwares - list of firmware blob_ids to support.
Patrick Venture1cde5f92018-11-07 08:26:47 -080080 * @param[in] transports - list of transports to support.
Patrick Venture137ad2c2018-11-06 11:30:43 -080081 */
Patrick Venture1cde5f92018-11-07 08:26:47 -080082 static std::unique_ptr<GenericBlobInterface> CreateFirmwareBlobHandler(
83 const std::vector<HandlerPack>& firmwares,
84 const std::vector<DataHandlerPack>& transports);
Patrick Venture68cf64f2018-11-06 10:46:51 -080085
Patrick Venture137ad2c2018-11-06 11:30:43 -080086 /**
87 * Create a FirmwareBlobHandler.
88 *
Patrick Venture1cde5f92018-11-07 08:26:47 -080089 * @param[in] firmwares - list of firmware types and their handlers
90 * @param[in] blobs - list of blobs_ids to support
91 * @param[in] transports - list of transport types and their handlers
92 * @param[in] bitmask - bitmask of transports to support
Patrick Venture137ad2c2018-11-06 11:30:43 -080093 */
Patrick Venturea78e39f2018-11-06 18:37:06 -080094 FirmwareBlobHandler(const std::vector<HandlerPack>& firmwares,
95 const std::vector<std::string>& blobs,
Patrick Venture1cde5f92018-11-07 08:26:47 -080096 const std::vector<DataHandlerPack>& transports,
97 std::uint16_t bitmask) :
Patrick Venturea78e39f2018-11-06 18:37:06 -080098 handlers(firmwares),
Patrick Ventured9fb6132018-11-08 09:56:10 -080099 blobIDs(blobs), transports(transports), bitmask(bitmask), activeImage(),
Patrick Venture92106df2018-11-09 09:26:30 -0800100 activeHash(), lookup(), state(UpdateState::notYetStarted)
Patrick Venture148cd652018-11-06 10:59:47 -0800101 {
102 }
Patrick Venturec7ca2912018-11-02 11:38:33 -0700103 ~FirmwareBlobHandler() = default;
104 FirmwareBlobHandler(const FirmwareBlobHandler&) = default;
105 FirmwareBlobHandler& operator=(const FirmwareBlobHandler&) = default;
106 FirmwareBlobHandler(FirmwareBlobHandler&&) = default;
107 FirmwareBlobHandler& operator=(FirmwareBlobHandler&&) = default;
108
109 bool canHandleBlob(const std::string& path) override;
110 std::vector<std::string> getBlobIds() override;
111 bool deleteBlob(const std::string& path) override;
112 bool stat(const std::string& path, struct BlobMeta* meta) override;
113 bool open(uint16_t session, uint16_t flags,
114 const std::string& path) override;
115 std::vector<uint8_t> read(uint16_t session, uint32_t offset,
116 uint32_t requestedSize) override;
117 bool write(uint16_t session, uint32_t offset,
118 const std::vector<uint8_t>& data) override;
119 bool writeMeta(uint16_t session, uint32_t offset,
120 const std::vector<uint8_t>& data) override;
121 bool commit(uint16_t session, const std::vector<uint8_t>& data) override;
122 bool close(uint16_t session) override;
123 bool stat(uint16_t session, struct BlobMeta* meta) override;
124 bool expire(uint16_t session) override;
Patrick Venture148cd652018-11-06 10:59:47 -0800125
Patrick Venture21be45a2018-11-06 12:08:52 -0800126 static const std::string hashBlobID;
Patrick Venture7b9256f2018-11-06 15:06:04 -0800127 static const std::string activeImageBlobID;
128 static const std::string activeHashBlobID;
Patrick Venture21be45a2018-11-06 12:08:52 -0800129
Patrick Venture92106df2018-11-09 09:26:30 -0800130 /** Allow grabbing the current state. */
131 UpdateState getCurrentState() const
132 {
133 return state;
134 };
135
Patrick Venture148cd652018-11-06 10:59:47 -0800136 private:
Patrick Venturea78e39f2018-11-06 18:37:06 -0800137 /** List of handlers by type. */
138 std::vector<HandlerPack> handlers;
139
Patrick Venturec02849b2018-11-06 17:31:15 -0800140 /** Active list of blobIDs. */
Patrick Venture4cceb8e2018-11-06 11:56:48 -0800141 std::vector<std::string> blobIDs;
Patrick Venturec02849b2018-11-06 17:31:15 -0800142
Patrick Venture1cde5f92018-11-07 08:26:47 -0800143 /** List of handlers by transport type. */
144 std::vector<DataHandlerPack> transports;
145
Patrick Venturec02849b2018-11-06 17:31:15 -0800146 /** The bits set indicate what transport mechanisms are supported. */
Patrick Venture1cde5f92018-11-07 08:26:47 -0800147 std::uint16_t bitmask;
Patrick Venturec02849b2018-11-06 17:31:15 -0800148
Patrick Ventured9fb6132018-11-08 09:56:10 -0800149 /** Active image session. */
150 Session activeImage;
151
152 /** Active hash session. */
153 Session activeHash;
154
155 /** A quick method for looking up a session's mechanisms and details. */
156 std::map<std::uint16_t, Session*> lookup;
157
Patrick Venture92106df2018-11-09 09:26:30 -0800158 /** The firmware update state. */
159 UpdateState state;
160
Patrick Venturec02849b2018-11-06 17:31:15 -0800161 /** Temporary variable to track whether a blob is open. */
162 bool fileOpen = false;
Patrick Venturec7ca2912018-11-02 11:38:33 -0700163};
164
165} // namespace blobs