blob: b1d1c633668c852578a3281b4f5f45654dca775a [file] [log] [blame]
Gunnar Millsec1b41c2017-05-02 12:20:36 -05001#pragma once
2
Gunnar Millsec1b41c2017-05-02 12:20:36 -05003#include "activation.hpp"
Lei YU56aaf452018-06-21 16:09:44 +08004#include "item_updater_helper.hpp"
Saqib Khan705f1bf2017-06-09 23:58:38 -05005#include "version.hpp"
Gunnar Millsb0ce9962018-09-07 13:39:10 -05006#include "xyz/openbmc_project/Collection/DeleteAll/server.hpp"
7
8#include <sdbusplus/server.hpp>
John Wang85c356f2019-09-11 16:20:13 +08009#include <xyz/openbmc_project/Association/Definitions/server.hpp>
Michael Tritz37a59042017-07-12 13:44:53 -050010#include <xyz/openbmc_project/Common/FactoryReset/server.hpp>
Michael Tritz0129d922017-08-10 19:33:46 -050011#include <xyz/openbmc_project/Control/FieldMode/server.hpp>
Gunnar Millsec1b41c2017-05-02 12:20:36 -050012
Adriana Kobylak58aa7502020-06-08 11:12:11 -050013#include <string>
14
Gunnar Millsec1b41c2017-05-02 12:20:36 -050015namespace phosphor
16{
17namespace software
18{
19namespace updater
20{
21
Michael Tritz37a59042017-07-12 13:44:53 -050022using ItemUpdaterInherit = sdbusplus::server::object::object<
Adriana Kobylak2285fe02018-02-27 15:36:59 -060023 sdbusplus::xyz::openbmc_project::Common::server::FactoryReset,
24 sdbusplus::xyz::openbmc_project::Control::server::FieldMode,
John Wang85c356f2019-09-11 16:20:13 +080025 sdbusplus::xyz::openbmc_project::Association::server::Definitions,
Adriana Kobylak2285fe02018-02-27 15:36:59 -060026 sdbusplus::xyz::openbmc_project::Collection::server::DeleteAll>;
Michael Tritz37a59042017-07-12 13:44:53 -050027
Patrick Williamse75d10f2017-05-30 16:56:32 -050028namespace MatchRules = sdbusplus::bus::match::rules;
Gunnar Mills48442912017-10-06 13:34:07 -050029using VersionClass = phosphor::software::manager::Version;
Gunnar Millsded875d2017-08-28 16:44:52 -050030using AssociationList =
Adriana Kobylak2285fe02018-02-27 15:36:59 -060031 std::vector<std::tuple<std::string, std::string, std::string>>;
Gunnar Millsded875d2017-08-28 16:44:52 -050032
Gunnar Millsec1b41c2017-05-02 12:20:36 -050033/** @class ItemUpdater
34 * @brief Manages the activation of the BMC version items.
35 */
Michael Tritz37a59042017-07-12 13:44:53 -050036class ItemUpdater : public ItemUpdaterInherit
Gunnar Millsec1b41c2017-05-02 12:20:36 -050037{
Adriana Kobylak2285fe02018-02-27 15:36:59 -060038 public:
39 /*
40 * @brief Types of Activation status for image validation.
41 */
42 enum class ActivationStatus
43 {
44 ready,
45 invalid,
46 active
47 };
Saqib Khan35e83f32017-05-22 11:37:32 -050048
Adriana Kobylak2285fe02018-02-27 15:36:59 -060049 /** @brief Constructs ItemUpdater
50 *
51 * @param[in] bus - The D-Bus bus object
52 */
53 ItemUpdater(sdbusplus::bus::bus& bus, const std::string& path) :
Lei YU56aaf452018-06-21 16:09:44 +080054 ItemUpdaterInherit(bus, path.c_str(), false), bus(bus), helper(bus),
Adriana Kobylak2285fe02018-02-27 15:36:59 -060055 versionMatch(bus,
56 MatchRules::interfacesAdded() +
57 MatchRules::path("/xyz/openbmc_project/software"),
58 std::bind(std::mem_fn(&ItemUpdater::createActivation),
59 this, std::placeholders::_1))
60 {
61 setBMCInventoryPath();
62 processBMCImage();
63 restoreFieldModeStatus();
64 emit_object_added();
65 };
Gunnar Millsec1b41c2017-05-02 12:20:36 -050066
Adriana Kobylakbbcb7be2018-07-17 15:47:34 -050067 /** @brief Save priority value to persistent storage (flash and optionally
68 * a U-Boot environment variable)
69 *
70 * @param[in] versionId - The Id of the version
71 * @param[in] value - The priority value
72 * @return None
73 */
74 void savePriority(const std::string& versionId, uint8_t value);
75
Adriana Kobylak2285fe02018-02-27 15:36:59 -060076 /** @brief Sets the given priority free by incrementing
77 * any existing priority with the same value by 1
78 *
79 * @param[in] value - The priority that needs to be set free.
80 * @param[in] versionId - The Id of the version for which we
81 * are trying to free up the priority.
82 * @return None
83 */
84 void freePriority(uint8_t value, const std::string& versionId);
Saqib Khan4c1aec02017-07-06 11:46:13 -050085
Adriana Kobylak2285fe02018-02-27 15:36:59 -060086 /**
87 * @brief Create and populate the active BMC Version.
88 */
89 void processBMCImage();
Saqib Khanba239882017-05-26 08:41:54 -050090
Adriana Kobylak2285fe02018-02-27 15:36:59 -060091 /**
92 * @brief Erase specified entry D-Bus object
93 * if Action property is not set to Active
94 *
95 * @param[in] entryId - unique identifier of the entry
96 */
97 void erase(std::string entryId);
Leonel Gonzalez3526ef72017-07-07 14:38:25 -050098
Adriana Kobylak2285fe02018-02-27 15:36:59 -060099 /**
100 * @brief Deletes all versions except for the current one
101 */
102 void deleteAll();
Gunnar Millsded875d2017-08-28 16:44:52 -0500103
Adriana Kobylak2285fe02018-02-27 15:36:59 -0600104 /** @brief Creates an active association to the
105 * newly active software image
106 *
107 * @param[in] path - The path to create the association to.
108 */
109 void createActiveAssociation(const std::string& path);
Gunnar Millsded875d2017-08-28 16:44:52 -0500110
Adriana Kobylak991af7e2018-12-10 13:08:38 -0600111 /** @brief Removes the associations from the provided software image path
Adriana Kobylak2285fe02018-02-27 15:36:59 -0600112 *
Adriana Kobylak991af7e2018-12-10 13:08:38 -0600113 * @param[in] path - The path to remove the associations from.
Adriana Kobylak2285fe02018-02-27 15:36:59 -0600114 */
Adriana Kobylak991af7e2018-12-10 13:08:38 -0600115 void removeAssociations(const std::string& path);
Gunnar Millsded875d2017-08-28 16:44:52 -0500116
Adriana Kobylak2285fe02018-02-27 15:36:59 -0600117 /** @brief Determine if the given priority is the lowest
118 *
119 * @param[in] value - The priority that needs to be checked.
120 *
121 * @return boolean corresponding to whether the given
122 * priority is lowest.
123 */
124 bool isLowestPriority(uint8_t value);
Saqib Khanb9da6632017-09-13 09:48:37 -0500125
Adriana Kobylak2285fe02018-02-27 15:36:59 -0600126 /**
127 * @brief Updates the U-Boot variables to point to the requested
128 * versionId, so that the systems boots from this version on
129 * the next reboot.
130 *
131 * @param[in] versionId - The version to point the system to boot from.
132 */
133 void updateUbootEnvVars(const std::string& versionId);
Adriana Kobylakb77551c2017-10-27 12:46:23 -0500134
Adriana Kobylak2285fe02018-02-27 15:36:59 -0600135 /**
136 * @brief Updates the uboot variables to point to BMC version with lowest
137 * priority, so that the system boots from this version on the
138 * next boot.
139 */
140 void resetUbootEnvVars();
Saqib Khan49446ae2017-10-02 10:54:20 -0500141
Adriana Kobylak2285fe02018-02-27 15:36:59 -0600142 /** @brief Brings the total number of active BMC versions to
143 * ACTIVE_BMC_MAX_ALLOWED -1. This function is intended to be
144 * run before activating a new BMC version. If this function
145 * needs to delete any BMC version(s) it will delete the
146 * version(s) with the highest priority, skipping the
147 * functional BMC version.
Adriana Kobylaka6963592018-09-07 14:13:29 -0500148 *
149 * @param[in] caller - The Activation object that called this function.
Adriana Kobylak2285fe02018-02-27 15:36:59 -0600150 */
Adriana Kobylaka6963592018-09-07 14:13:29 -0500151 void freeSpace(Activation& caller);
Adriana Kobylak204e1e72018-01-24 16:00:05 -0600152
AppaRao Puli1bb6dcb2020-03-27 20:51:57 +0530153 /** @brief Creates a updateable association to the
154 * "running" BMC software image
155 *
156 * @param[in] path - The path to create the association.
157 */
158 void createUpdateableAssociation(const std::string& path);
159
Adriana Kobylakec4eec32019-11-13 14:28:35 -0600160 /** @brief Persistent map of Version D-Bus objects and their
161 * version id */
162 std::map<std::string, std::unique_ptr<VersionClass>> versions;
163
Adriana Kobylak2285fe02018-02-27 15:36:59 -0600164 private:
165 /** @brief Callback function for Software.Version match.
166 * @details Creates an Activation D-Bus object.
167 *
168 * @param[in] msg - Data associated with subscribed signal
169 */
170 void createActivation(sdbusplus::message::message& msg);
Gunnar Millsec1b41c2017-05-02 12:20:36 -0500171
Adriana Kobylak2285fe02018-02-27 15:36:59 -0600172 /**
173 * @brief Validates the presence of SquashFS image in the image dir.
174 *
175 * @param[in] filePath - The path to the image dir.
176 * @param[out] result - ActivationStatus Enum.
177 * ready if validation was successful.
178 * invalid if validation fail.
179 * active if image is the current version.
180 *
181 */
182 ActivationStatus validateSquashFSImage(const std::string& filePath);
Saqib Khan35e83f32017-05-22 11:37:32 -0500183
Adriana Kobylak2285fe02018-02-27 15:36:59 -0600184 /** @brief BMC factory reset - marks the read-write partition for
185 * recreation upon reboot. */
186 void reset() override;
Michael Tritz37a59042017-07-12 13:44:53 -0500187
Adriana Kobylak2285fe02018-02-27 15:36:59 -0600188 /**
189 * @brief Enables field mode, if value=true.
190 *
191 * @param[in] value - If true, enables field mode.
192 * @param[out] result - Returns the current state of field mode.
193 *
194 */
195 bool fieldModeEnabled(bool value) override;
Michael Tritz0129d922017-08-10 19:33:46 -0500196
Adriana Kobylak2285fe02018-02-27 15:36:59 -0600197 /** @brief Sets the BMC inventory item path under
198 * /xyz/openbmc_project/inventory/system/chassis/. */
199 void setBMCInventoryPath();
Gunnar Millsb60add12017-08-24 16:41:42 -0500200
Adriana Kobylak2285fe02018-02-27 15:36:59 -0600201 /** @brief The path to the BMC inventory item. */
202 std::string bmcInventoryPath;
Gunnar Millsb60add12017-08-24 16:41:42 -0500203
Adriana Kobylak2285fe02018-02-27 15:36:59 -0600204 /** @brief Restores field mode status on reboot. */
205 void restoreFieldModeStatus();
Michael Tritz0129d922017-08-10 19:33:46 -0500206
Adriana Kobylak2285fe02018-02-27 15:36:59 -0600207 /** @brief Creates a functional association to the
208 * "running" BMC software image
209 *
210 * @param[in] path - The path to create the association to.
211 */
212 void createFunctionalAssociation(const std::string& path);
Gunnar Mills88e8a322017-09-13 11:09:28 -0500213
Adriana Kobylak2285fe02018-02-27 15:36:59 -0600214 /** @brief Persistent sdbusplus D-Bus bus connection. */
215 sdbusplus::bus::bus& bus;
Gunnar Millsec1b41c2017-05-02 12:20:36 -0500216
Lei YU56aaf452018-06-21 16:09:44 +0800217 /** @brief The helper of image updater. */
218 Helper helper;
219
Adriana Kobylak2285fe02018-02-27 15:36:59 -0600220 /** @brief Persistent map of Activation D-Bus objects and their
221 * version id */
222 std::map<std::string, std::unique_ptr<Activation>> activations;
Gunnar Millsec1b41c2017-05-02 12:20:36 -0500223
Adriana Kobylak2285fe02018-02-27 15:36:59 -0600224 /** @brief sdbusplus signal match for Software.Version */
225 sdbusplus::bus::match_t versionMatch;
Gunnar Millsec1b41c2017-05-02 12:20:36 -0500226
Adriana Kobylak2285fe02018-02-27 15:36:59 -0600227 /** @brief This entry's associations */
228 AssociationList assocs = {};
Gunnar Millsded875d2017-08-28 16:44:52 -0500229
Adriana Kobylak2285fe02018-02-27 15:36:59 -0600230 /** @brief Clears read only partition for
231 * given Activation D-Bus object.
232 *
233 * @param[in] versionId - The version id.
234 */
235 void removeReadOnlyPartition(std::string versionId);
Eddie Jameseaa1ee02018-03-01 10:09:10 -0600236
237 /** @brief Copies U-Boot from the currently booted BMC chip to the
238 * alternate chip.
239 */
240 void mirrorUbootToAlt();
Gunnar Millsec1b41c2017-05-02 12:20:36 -0500241};
242
Gunnar Millsec1b41c2017-05-02 12:20:36 -0500243} // namespace updater
244} // namespace software
245} // namespace phosphor