blob: 36faa05e3b506798604b72d9fdb3ee21c8411d97 [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{
Patrick Ventured6461d62018-11-09 17:30:25 -080021 /**
Patrick Ventureedd55b52018-11-15 11:05:13 -080022 * Built a session object.
23 *
24 * @param[in] the active path to which this corresponds.
25 */
26 explicit Session(const std::string& path) :
27 dataHandler(nullptr), imageHandler(nullptr), flags(0),
28 state(State::closed), activePath(path)
29 {
30 }
31
32 /**
Patrick Ventured6461d62018-11-09 17:30:25 -080033 * Pointer to the correct Data handler interface. (nullptr on BT (or KCS))
Patrick Venture2d3a2542018-11-08 09:23:24 -080034 */
35 DataInterface* dataHandler;
36
Patrick Ventured6461d62018-11-09 17:30:25 -080037 /**
38 * Pointer to the correct image handler interface. (nullptr on hash
39 * blob_id)
40 */
Patrick Venture2d3a2542018-11-08 09:23:24 -080041 ImageHandlerInterface* imageHandler;
Patrick Venture18235e62018-11-08 10:21:09 -080042
43 /** The flags used to open the session. */
44 std::uint16_t flags;
Patrick Venture32ba9dd2018-11-09 16:22:53 -080045
46 /** A sesion can be for an image (or tarball) or the hash. */
47 enum State
48 {
49 open = 0,
50 closed = 1,
51 };
52
53 /** The current state of this session. */
54 State state;
Patrick Ventureedd55b52018-11-15 11:05:13 -080055
56 /** The active path. */
57 std::string activePath;
Patrick Venture2d3a2542018-11-08 09:23:24 -080058};
59
Patrick Venture18235e62018-11-08 10:21:09 -080060struct ExtChunkHdr
61{
62 std::uint32_t length; /* Length of the data queued (little endian). */
63} __attribute__((packed));
64
Patrick Venture2d3a2542018-11-08 09:23:24 -080065/**
Patrick Venturec7ca2912018-11-02 11:38:33 -070066 * Register only one firmware blob handler that will manage all sessions.
67 */
68class FirmwareBlobHandler : public GenericBlobInterface
69{
70 public:
Patrick Venture05abf7e2018-11-09 11:02:56 -080071 enum UpdateFlags : std::uint16_t
Patrick Venturefc3857b2018-11-07 08:14:55 -080072 {
Patrick Venture9158dcf2018-11-08 09:44:28 -080073 ipmi = (1 << 8), /* Expect to send contents over IPMI BlockTransfer. */
Patrick Venturefc3857b2018-11-07 08:14:55 -080074 p2a = (1 << 9), /* Expect to send contents over P2A bridge. */
75 lpc = (1 << 10), /* Expect to send contents over LPC bridge. */
76 };
77
Patrick Ventureffcc5502018-11-16 12:32:38 -080078 /* TODO: All of the states may not be required - if we add abort() commands
79 * appropriately.
80 */
Patrick Venture92106df2018-11-09 09:26:30 -080081 /** The state of the firmware update process. */
82 enum UpdateState
83 {
84 /** The initial state. */
85 notYetStarted = 0,
86 /**
87 * The upload process has started, but verification has not started.
88 */
89 uploadInProgress = 1,
90 /** The verification process has started, no more writes allowed. */
91 verificationStarted = 2,
92 /** The verification process has completed. */
93 verificationCompleted = 3,
94 };
95
Patrick Venture79c08bf2018-11-09 15:33:54 -080096 /** The return values for verification. */
97 enum VerifyCheckResponses : std::uint8_t
98 {
99 running = 0,
100 success = 1,
101 failed = 2,
102 other = 3,
103 };
104
Patrick Venture137ad2c2018-11-06 11:30:43 -0800105 /**
106 * Create a FirmwareBlobHandler.
107 *
Patrick Venture4cceb8e2018-11-06 11:56:48 -0800108 * @param[in] firmwares - list of firmware blob_ids to support.
Patrick Venture1cde5f92018-11-07 08:26:47 -0800109 * @param[in] transports - list of transports to support.
Patrick Venture137ad2c2018-11-06 11:30:43 -0800110 */
Patrick Venture1cde5f92018-11-07 08:26:47 -0800111 static std::unique_ptr<GenericBlobInterface> CreateFirmwareBlobHandler(
112 const std::vector<HandlerPack>& firmwares,
113 const std::vector<DataHandlerPack>& transports);
Patrick Venture68cf64f2018-11-06 10:46:51 -0800114
Patrick Venture137ad2c2018-11-06 11:30:43 -0800115 /**
116 * Create a FirmwareBlobHandler.
117 *
Patrick Venture1cde5f92018-11-07 08:26:47 -0800118 * @param[in] firmwares - list of firmware types and their handlers
119 * @param[in] blobs - list of blobs_ids to support
120 * @param[in] transports - list of transport types and their handlers
121 * @param[in] bitmask - bitmask of transports to support
Patrick Venture137ad2c2018-11-06 11:30:43 -0800122 */
Patrick Venturea78e39f2018-11-06 18:37:06 -0800123 FirmwareBlobHandler(const std::vector<HandlerPack>& firmwares,
124 const std::vector<std::string>& blobs,
Patrick Venture1cde5f92018-11-07 08:26:47 -0800125 const std::vector<DataHandlerPack>& transports,
126 std::uint16_t bitmask) :
Patrick Venturea78e39f2018-11-06 18:37:06 -0800127 handlers(firmwares),
Patrick Ventureedd55b52018-11-15 11:05:13 -0800128 blobIDs(blobs), transports(transports), bitmask(bitmask),
Patrick Ventureffcc5502018-11-16 12:32:38 -0800129 activeImage(activeImageBlobID), activeHash(activeHashBlobID),
130 verifyImage(verifyBlobID), lookup(), state(UpdateState::notYetStarted)
Patrick Venture148cd652018-11-06 10:59:47 -0800131 {
132 }
Patrick Venturec7ca2912018-11-02 11:38:33 -0700133 ~FirmwareBlobHandler() = default;
134 FirmwareBlobHandler(const FirmwareBlobHandler&) = default;
135 FirmwareBlobHandler& operator=(const FirmwareBlobHandler&) = default;
136 FirmwareBlobHandler(FirmwareBlobHandler&&) = default;
137 FirmwareBlobHandler& operator=(FirmwareBlobHandler&&) = default;
138
139 bool canHandleBlob(const std::string& path) override;
140 std::vector<std::string> getBlobIds() override;
141 bool deleteBlob(const std::string& path) override;
142 bool stat(const std::string& path, struct BlobMeta* meta) override;
143 bool open(uint16_t session, uint16_t flags,
144 const std::string& path) override;
145 std::vector<uint8_t> read(uint16_t session, uint32_t offset,
146 uint32_t requestedSize) override;
147 bool write(uint16_t session, uint32_t offset,
148 const std::vector<uint8_t>& data) override;
149 bool writeMeta(uint16_t session, uint32_t offset,
150 const std::vector<uint8_t>& data) override;
151 bool commit(uint16_t session, const std::vector<uint8_t>& data) override;
152 bool close(uint16_t session) override;
153 bool stat(uint16_t session, struct BlobMeta* meta) override;
154 bool expire(uint16_t session) override;
Patrick Venture148cd652018-11-06 10:59:47 -0800155
Patrick Ventureffcc5502018-11-16 12:32:38 -0800156 bool triggerVerification();
157
158 static const std::string verifyBlobID;
Patrick Venture21be45a2018-11-06 12:08:52 -0800159 static const std::string hashBlobID;
Patrick Venture7b9256f2018-11-06 15:06:04 -0800160 static const std::string activeImageBlobID;
161 static const std::string activeHashBlobID;
Patrick Venture21be45a2018-11-06 12:08:52 -0800162
Patrick Venture92106df2018-11-09 09:26:30 -0800163 /** Allow grabbing the current state. */
164 UpdateState getCurrentState() const
165 {
166 return state;
167 };
168
Patrick Venture148cd652018-11-06 10:59:47 -0800169 private:
Patrick Venturea78e39f2018-11-06 18:37:06 -0800170 /** List of handlers by type. */
171 std::vector<HandlerPack> handlers;
172
Patrick Venturec02849b2018-11-06 17:31:15 -0800173 /** Active list of blobIDs. */
Patrick Venture4cceb8e2018-11-06 11:56:48 -0800174 std::vector<std::string> blobIDs;
Patrick Venturec02849b2018-11-06 17:31:15 -0800175
Patrick Venture1cde5f92018-11-07 08:26:47 -0800176 /** List of handlers by transport type. */
177 std::vector<DataHandlerPack> transports;
178
Patrick Venturec02849b2018-11-06 17:31:15 -0800179 /** The bits set indicate what transport mechanisms are supported. */
Patrick Venture1cde5f92018-11-07 08:26:47 -0800180 std::uint16_t bitmask;
Patrick Venturec02849b2018-11-06 17:31:15 -0800181
Patrick Ventured9fb6132018-11-08 09:56:10 -0800182 /** Active image session. */
183 Session activeImage;
184
185 /** Active hash session. */
186 Session activeHash;
187
Patrick Ventureffcc5502018-11-16 12:32:38 -0800188 /** Session for verification. */
189 Session verifyImage;
190
Patrick Ventured9fb6132018-11-08 09:56:10 -0800191 /** A quick method for looking up a session's mechanisms and details. */
192 std::map<std::uint16_t, Session*> lookup;
193
Patrick Venture92106df2018-11-09 09:26:30 -0800194 /** The firmware update state. */
195 UpdateState state;
196
Patrick Venturec02849b2018-11-06 17:31:15 -0800197 /** Temporary variable to track whether a blob is open. */
198 bool fileOpen = false;
Patrick Venturec7ca2912018-11-02 11:38:33 -0700199};
200
201} // namespace blobs