Alex Deymo | aea4c1c | 2015-08-19 20:24:43 -0700 | [diff] [blame] | 1 | // |
| 2 | // Copyright (C) 2013 The Android Open Source Project |
| 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 | // |
Alex Deymo | 4243291 | 2013-07-12 20:21:15 -0700 | [diff] [blame] | 16 | |
Alex Deymo | 39910dc | 2015-11-09 17:04:30 -0800 | [diff] [blame] | 17 | #ifndef UPDATE_ENGINE_COMMON_FAKE_HARDWARE_H_ |
| 18 | #define UPDATE_ENGINE_COMMON_FAKE_HARDWARE_H_ |
Alex Deymo | 4243291 | 2013-07-12 20:21:15 -0700 | [diff] [blame] | 19 | |
Don Garrett | 83692e4 | 2013-11-08 10:11:30 -0800 | [diff] [blame] | 20 | #include <map> |
Alex Deymo | df632d1 | 2014-04-29 20:04:36 -0700 | [diff] [blame] | 21 | #include <string> |
Kelvin Zhang | d719103 | 2020-08-11 10:48:16 -0400 | [diff] [blame] | 22 | #include <utility> |
Don Garrett | 83692e4 | 2013-11-08 10:11:30 -0800 | [diff] [blame] | 23 | |
Alex Deymo | bccbc38 | 2014-04-03 13:38:55 -0700 | [diff] [blame] | 24 | #include <base/time/time.h> |
| 25 | |
Yifan Hong | 8702933 | 2020-09-01 17:20:08 -0700 | [diff] [blame^] | 26 | #include "update_engine/common/error_code.h" |
Alex Deymo | 39910dc | 2015-11-09 17:04:30 -0800 | [diff] [blame] | 27 | #include "update_engine/common/hardware_interface.h" |
Kelvin Zhang | d719103 | 2020-08-11 10:48:16 -0400 | [diff] [blame] | 28 | #include "update_engine/common/utils.h" |
Alex Deymo | 4243291 | 2013-07-12 20:21:15 -0700 | [diff] [blame] | 29 | |
Alex Deymo | 4243291 | 2013-07-12 20:21:15 -0700 | [diff] [blame] | 30 | namespace chromeos_update_engine { |
| 31 | |
| 32 | // Implements a fake hardware interface used for testing. |
| 33 | class FakeHardware : public HardwareInterface { |
| 34 | public: |
Alex Deymo | ebbe7ef | 2014-10-30 13:02:49 -0700 | [diff] [blame] | 35 | // Value used to signal that the powerwash_count file is not present. When |
| 36 | // this value is used in SetPowerwashCount(), GetPowerwashCount() will return |
| 37 | // false. |
| 38 | static const int kPowerwashCountNotSet = -1; |
| 39 | |
Zentaro Kavanagh | baacb98 | 2018-02-20 17:48:39 -0800 | [diff] [blame] | 40 | // Default value for crossystem tpm_kernver. |
| 41 | static const int kMinKernelKeyVersion = 3; |
| 42 | |
Marton Hunyady | 99ced78 | 2018-05-08 12:59:50 +0200 | [diff] [blame] | 43 | // Default value for crossystem tpm_fwver. |
| 44 | static const int kMinFirmwareKeyVersion = 13; |
| 45 | |
Zentaro Kavanagh | 5d95615 | 2018-05-15 09:40:33 -0700 | [diff] [blame] | 46 | // Default value for crossystem kernel_max_rollforward. This value is the |
Zentaro Kavanagh | baacb98 | 2018-02-20 17:48:39 -0800 | [diff] [blame] | 47 | // default for consumer devices and effectively means "unlimited rollforward |
| 48 | // is allowed", which is the same as the behavior prior to implementing |
| 49 | // roll forward prevention. |
Zentaro Kavanagh | 8f6f243 | 2018-05-16 13:48:12 -0700 | [diff] [blame] | 50 | static const int kKernelMaxRollforward = 0xfffffffe; |
| 51 | |
| 52 | // Default value for crossystem firmware_max_rollforward. This value is the |
| 53 | // default for consumer devices and effectively means "unlimited rollforward |
| 54 | // is allowed", which is the same as the behavior prior to implementing |
| 55 | // roll forward prevention. |
| 56 | static const int kFirmwareMaxRollforward = 0xfffffffe; |
Zentaro Kavanagh | baacb98 | 2018-02-20 17:48:39 -0800 | [diff] [blame] | 57 | |
Alex Deymo | 46a9aae | 2016-05-04 20:20:11 -0700 | [diff] [blame] | 58 | FakeHardware() = default; |
Alex Deymo | 4243291 | 2013-07-12 20:21:15 -0700 | [diff] [blame] | 59 | |
| 60 | // HardwareInterface methods. |
Alex Vakulenko | 157fe30 | 2014-08-11 15:59:58 -0700 | [diff] [blame] | 61 | bool IsOfficialBuild() const override { return is_official_build_; } |
Alex Vakulenko | d0fdfb3 | 2014-02-21 15:26:26 -0800 | [diff] [blame] | 62 | |
Alex Vakulenko | 157fe30 | 2014-08-11 15:59:58 -0700 | [diff] [blame] | 63 | bool IsNormalBootMode() const override { return is_normal_boot_mode_; } |
Alex Vakulenko | d0fdfb3 | 2014-02-21 15:26:26 -0800 | [diff] [blame] | 64 | |
Sen Jiang | e67bb5b | 2016-06-20 15:53:56 -0700 | [diff] [blame] | 65 | bool AreDevFeaturesEnabled() const override { |
| 66 | return are_dev_features_enabled_; |
| 67 | } |
| 68 | |
Alex Deymo | 46a9aae | 2016-05-04 20:20:11 -0700 | [diff] [blame] | 69 | bool IsOOBEEnabled() const override { return is_oobe_enabled_; } |
| 70 | |
Alex Vakulenko | 157fe30 | 2014-08-11 15:59:58 -0700 | [diff] [blame] | 71 | bool IsOOBEComplete(base::Time* out_time_of_oobe) const override { |
Alex Deymo | bccbc38 | 2014-04-03 13:38:55 -0700 | [diff] [blame] | 72 | if (out_time_of_oobe != nullptr) |
| 73 | *out_time_of_oobe = oobe_timestamp_; |
| 74 | return is_oobe_complete_; |
| 75 | } |
| 76 | |
Alex Vakulenko | 157fe30 | 2014-08-11 15:59:58 -0700 | [diff] [blame] | 77 | std::string GetHardwareClass() const override { return hardware_class_; } |
Alex Vakulenko | d0fdfb3 | 2014-02-21 15:26:26 -0800 | [diff] [blame] | 78 | |
Alex Vakulenko | 157fe30 | 2014-08-11 15:59:58 -0700 | [diff] [blame] | 79 | std::string GetFirmwareVersion() const override { return firmware_version_; } |
Alex Vakulenko | d0fdfb3 | 2014-02-21 15:26:26 -0800 | [diff] [blame] | 80 | |
Alex Vakulenko | 157fe30 | 2014-08-11 15:59:58 -0700 | [diff] [blame] | 81 | std::string GetECVersion() const override { return ec_version_; } |
Alex Deymo | 4243291 | 2013-07-12 20:21:15 -0700 | [diff] [blame] | 82 | |
Matt Ziegelbaum | aa8e1a4 | 2019-05-09 21:41:58 -0400 | [diff] [blame] | 83 | std::string GetDeviceRequisition() const override { |
| 84 | return device_requisition_; |
| 85 | } |
| 86 | |
Zentaro Kavanagh | baacb98 | 2018-02-20 17:48:39 -0800 | [diff] [blame] | 87 | int GetMinKernelKeyVersion() const override { |
| 88 | return min_kernel_key_version_; |
| 89 | } |
| 90 | |
Marton Hunyady | 99ced78 | 2018-05-08 12:59:50 +0200 | [diff] [blame] | 91 | int GetMinFirmwareKeyVersion() const override { |
| 92 | return min_firmware_key_version_; |
| 93 | } |
| 94 | |
Zentaro Kavanagh | 8f6f243 | 2018-05-16 13:48:12 -0700 | [diff] [blame] | 95 | int GetMaxFirmwareKeyRollforward() const override { |
| 96 | return firmware_max_rollforward_; |
| 97 | } |
| 98 | |
| 99 | bool SetMaxFirmwareKeyRollforward(int firmware_max_rollforward) override { |
| 100 | if (GetMaxFirmwareKeyRollforward() == -1) |
| 101 | return false; |
| 102 | |
| 103 | firmware_max_rollforward_ = firmware_max_rollforward; |
| 104 | return true; |
| 105 | } |
| 106 | |
Zentaro Kavanagh | 5d95615 | 2018-05-15 09:40:33 -0700 | [diff] [blame] | 107 | bool SetMaxKernelKeyRollforward(int kernel_max_rollforward) override { |
| 108 | kernel_max_rollforward_ = kernel_max_rollforward; |
Zentaro Kavanagh | baacb98 | 2018-02-20 17:48:39 -0800 | [diff] [blame] | 109 | return true; |
| 110 | } |
| 111 | |
Alex Deymo | ebbe7ef | 2014-10-30 13:02:49 -0700 | [diff] [blame] | 112 | int GetPowerwashCount() const override { return powerwash_count_; } |
| 113 | |
Zentaro Kavanagh | 28def4f | 2019-01-15 17:15:01 -0800 | [diff] [blame] | 114 | bool SchedulePowerwash(bool save_rollback_data) override { |
Alex Deymo | fb905d9 | 2016-06-03 19:26:58 -0700 | [diff] [blame] | 115 | powerwash_scheduled_ = true; |
Zentaro Kavanagh | 28def4f | 2019-01-15 17:15:01 -0800 | [diff] [blame] | 116 | save_rollback_data_ = save_rollback_data; |
Alex Deymo | fb905d9 | 2016-06-03 19:26:58 -0700 | [diff] [blame] | 117 | return true; |
| 118 | } |
| 119 | |
| 120 | bool CancelPowerwash() override { |
| 121 | powerwash_scheduled_ = false; |
Zentaro Kavanagh | 28def4f | 2019-01-15 17:15:01 -0800 | [diff] [blame] | 122 | save_rollback_data_ = false; |
Alex Deymo | fb905d9 | 2016-06-03 19:26:58 -0700 | [diff] [blame] | 123 | return true; |
| 124 | } |
| 125 | |
| 126 | bool IsPowerwashScheduled() { return powerwash_scheduled_; } |
| 127 | |
Alex Deymo | dd132f3 | 2015-09-14 19:12:07 -0700 | [diff] [blame] | 128 | bool GetNonVolatileDirectory(base::FilePath* path) const override { |
| 129 | return false; |
| 130 | } |
| 131 | |
| 132 | bool GetPowerwashSafeDirectory(base::FilePath* path) const override { |
| 133 | return false; |
| 134 | } |
| 135 | |
Sen Jiang | 5011df6 | 2017-06-28 17:13:19 -0700 | [diff] [blame] | 136 | int64_t GetBuildTimestamp() const override { return build_timestamp_; } |
| 137 | |
Tianjie Xu | 4ad3af6 | 2019-10-30 11:59:45 -0700 | [diff] [blame] | 138 | bool AllowDowngrade() const override { return false; } |
| 139 | |
Amin Hassani | 1677e81 | 2017-06-21 13:36:36 -0700 | [diff] [blame] | 140 | bool GetFirstActiveOmahaPingSent() const override { |
| 141 | return first_active_omaha_ping_sent_; |
| 142 | } |
| 143 | |
Amin Hassani | 80f4d4c | 2018-05-16 13:34:00 -0700 | [diff] [blame] | 144 | bool SetFirstActiveOmahaPingSent() override { |
Amin Hassani | 1677e81 | 2017-06-21 13:36:36 -0700 | [diff] [blame] | 145 | first_active_omaha_ping_sent_ = true; |
Amin Hassani | 80f4d4c | 2018-05-16 13:34:00 -0700 | [diff] [blame] | 146 | return true; |
Amin Hassani | 1677e81 | 2017-06-21 13:36:36 -0700 | [diff] [blame] | 147 | } |
| 148 | |
Alex Deymo | 4243291 | 2013-07-12 20:21:15 -0700 | [diff] [blame] | 149 | // Setters |
J. Richard Barnette | 056b0ab | 2013-10-29 15:24:56 -0700 | [diff] [blame] | 150 | void SetIsOfficialBuild(bool is_official_build) { |
| 151 | is_official_build_ = is_official_build; |
| 152 | } |
| 153 | |
| 154 | void SetIsNormalBootMode(bool is_normal_boot_mode) { |
| 155 | is_normal_boot_mode_ = is_normal_boot_mode; |
| 156 | } |
| 157 | |
Sen Jiang | e67bb5b | 2016-06-20 15:53:56 -0700 | [diff] [blame] | 158 | void SetAreDevFeaturesEnabled(bool are_dev_features_enabled) { |
| 159 | are_dev_features_enabled_ = are_dev_features_enabled; |
| 160 | } |
| 161 | |
Alex Deymo | 46a9aae | 2016-05-04 20:20:11 -0700 | [diff] [blame] | 162 | // Sets the SetIsOOBEEnabled to |is_oobe_enabled|. |
| 163 | void SetIsOOBEEnabled(bool is_oobe_enabled) { |
| 164 | is_oobe_enabled_ = is_oobe_enabled; |
| 165 | } |
| 166 | |
Alex Deymo | bccbc38 | 2014-04-03 13:38:55 -0700 | [diff] [blame] | 167 | // Sets the IsOOBEComplete to True with the given timestamp. |
| 168 | void SetIsOOBEComplete(base::Time oobe_timestamp) { |
| 169 | is_oobe_complete_ = true; |
| 170 | oobe_timestamp_ = oobe_timestamp; |
| 171 | } |
| 172 | |
Amin Hassani | b268959 | 2019-01-13 17:04:28 -0800 | [diff] [blame] | 173 | void UnsetIsOOBEComplete() { is_oobe_complete_ = false; } |
Alex Deymo | bccbc38 | 2014-04-03 13:38:55 -0700 | [diff] [blame] | 174 | |
Chih-Hung Hsieh | 5c6bb1d | 2016-07-27 13:33:15 -0700 | [diff] [blame] | 175 | void SetHardwareClass(const std::string& hardware_class) { |
J. Richard Barnette | 522d36f | 2013-10-28 17:22:12 -0700 | [diff] [blame] | 176 | hardware_class_ = hardware_class; |
| 177 | } |
| 178 | |
Chih-Hung Hsieh | 5c6bb1d | 2016-07-27 13:33:15 -0700 | [diff] [blame] | 179 | void SetFirmwareVersion(const std::string& firmware_version) { |
J. Richard Barnette | 522d36f | 2013-10-28 17:22:12 -0700 | [diff] [blame] | 180 | firmware_version_ = firmware_version; |
| 181 | } |
| 182 | |
Amin Hassani | b268959 | 2019-01-13 17:04:28 -0800 | [diff] [blame] | 183 | void SetECVersion(const std::string& ec_version) { ec_version_ = ec_version; } |
J. Richard Barnette | 522d36f | 2013-10-28 17:22:12 -0700 | [diff] [blame] | 184 | |
Matt Ziegelbaum | aa8e1a4 | 2019-05-09 21:41:58 -0400 | [diff] [blame] | 185 | void SetDeviceRequisition(const std::string& requisition) { |
| 186 | device_requisition_ = requisition; |
| 187 | } |
| 188 | |
Zentaro Kavanagh | baacb98 | 2018-02-20 17:48:39 -0800 | [diff] [blame] | 189 | void SetMinKernelKeyVersion(int min_kernel_key_version) { |
| 190 | min_kernel_key_version_ = min_kernel_key_version; |
| 191 | } |
| 192 | |
Marton Hunyady | 99ced78 | 2018-05-08 12:59:50 +0200 | [diff] [blame] | 193 | void SetMinFirmwareKeyVersion(int min_firmware_key_version) { |
| 194 | min_firmware_key_version_ = min_firmware_key_version; |
| 195 | } |
| 196 | |
Alex Deymo | ebbe7ef | 2014-10-30 13:02:49 -0700 | [diff] [blame] | 197 | void SetPowerwashCount(int powerwash_count) { |
| 198 | powerwash_count_ = powerwash_count; |
| 199 | } |
| 200 | |
Sen Jiang | 5011df6 | 2017-06-28 17:13:19 -0700 | [diff] [blame] | 201 | void SetBuildTimestamp(int64_t build_timestamp) { |
| 202 | build_timestamp_ = build_timestamp; |
| 203 | } |
| 204 | |
Tianjie Xu | d6aa91f | 2019-11-14 11:55:10 -0800 | [diff] [blame] | 205 | void SetWarmReset(bool warm_reset) { warm_reset_ = warm_reset; } |
| 206 | |
Zentaro Kavanagh | baacb98 | 2018-02-20 17:48:39 -0800 | [diff] [blame] | 207 | // Getters to verify state. |
Zentaro Kavanagh | 5d95615 | 2018-05-15 09:40:33 -0700 | [diff] [blame] | 208 | int GetMaxKernelKeyRollforward() const { return kernel_max_rollforward_; } |
Zentaro Kavanagh | baacb98 | 2018-02-20 17:48:39 -0800 | [diff] [blame] | 209 | |
Zentaro Kavanagh | 0418de3 | 2019-01-15 10:29:35 -0800 | [diff] [blame] | 210 | bool GetIsRollbackPowerwashScheduled() const { |
Zentaro Kavanagh | 28def4f | 2019-01-15 17:15:01 -0800 | [diff] [blame] | 211 | return powerwash_scheduled_ && save_rollback_data_; |
Zentaro Kavanagh | 0418de3 | 2019-01-15 10:29:35 -0800 | [diff] [blame] | 212 | } |
Kelvin Zhang | d719103 | 2020-08-11 10:48:16 -0400 | [diff] [blame] | 213 | std::string GetVersionForLogging( |
| 214 | const std::string& partition_name) const override { |
| 215 | return partition_timestamps_[partition_name]; |
| 216 | } |
| 217 | void SetVersion(const std::string& partition_name, std::string timestamp) { |
| 218 | partition_timestamps_[partition_name] = std::move(timestamp); |
| 219 | } |
Yifan Hong | 8702933 | 2020-09-01 17:20:08 -0700 | [diff] [blame^] | 220 | ErrorCode IsPartitionUpdateValid( |
| 221 | const std::string& partition_name, |
| 222 | const std::string& new_version) const override { |
Kelvin Zhang | d719103 | 2020-08-11 10:48:16 -0400 | [diff] [blame] | 223 | const auto old_version = GetVersionForLogging(partition_name); |
| 224 | return utils::IsTimestampNewer(old_version, new_version); |
| 225 | } |
Zentaro Kavanagh | 0418de3 | 2019-01-15 10:29:35 -0800 | [diff] [blame] | 226 | |
Alex Deymo | 4243291 | 2013-07-12 20:21:15 -0700 | [diff] [blame] | 227 | private: |
Alex Deymo | 46a9aae | 2016-05-04 20:20:11 -0700 | [diff] [blame] | 228 | bool is_official_build_{true}; |
| 229 | bool is_normal_boot_mode_{true}; |
Sen Jiang | e67bb5b | 2016-06-20 15:53:56 -0700 | [diff] [blame] | 230 | bool are_dev_features_enabled_{false}; |
Alex Deymo | 46a9aae | 2016-05-04 20:20:11 -0700 | [diff] [blame] | 231 | bool is_oobe_enabled_{true}; |
| 232 | bool is_oobe_complete_{true}; |
Zentaro Kavanagh | baacb98 | 2018-02-20 17:48:39 -0800 | [diff] [blame] | 233 | // Jan 20, 2007 |
| 234 | base::Time oobe_timestamp_{base::Time::FromTimeT(1169280000)}; |
Alex Deymo | 46a9aae | 2016-05-04 20:20:11 -0700 | [diff] [blame] | 235 | std::string hardware_class_{"Fake HWID BLAH-1234"}; |
| 236 | std::string firmware_version_{"Fake Firmware v1.0.1"}; |
| 237 | std::string ec_version_{"Fake EC v1.0a"}; |
Matt Ziegelbaum | aa8e1a4 | 2019-05-09 21:41:58 -0400 | [diff] [blame] | 238 | std::string device_requisition_{"fake_requisition"}; |
Zentaro Kavanagh | baacb98 | 2018-02-20 17:48:39 -0800 | [diff] [blame] | 239 | int min_kernel_key_version_{kMinKernelKeyVersion}; |
Marton Hunyady | 99ced78 | 2018-05-08 12:59:50 +0200 | [diff] [blame] | 240 | int min_firmware_key_version_{kMinFirmwareKeyVersion}; |
Zentaro Kavanagh | 8f6f243 | 2018-05-16 13:48:12 -0700 | [diff] [blame] | 241 | int kernel_max_rollforward_{kKernelMaxRollforward}; |
| 242 | int firmware_max_rollforward_{kFirmwareMaxRollforward}; |
Alex Deymo | 46a9aae | 2016-05-04 20:20:11 -0700 | [diff] [blame] | 243 | int powerwash_count_{kPowerwashCountNotSet}; |
Alex Deymo | fb905d9 | 2016-06-03 19:26:58 -0700 | [diff] [blame] | 244 | bool powerwash_scheduled_{false}; |
Zentaro Kavanagh | 28def4f | 2019-01-15 17:15:01 -0800 | [diff] [blame] | 245 | bool save_rollback_data_{false}; |
Sen Jiang | 5011df6 | 2017-06-28 17:13:19 -0700 | [diff] [blame] | 246 | int64_t build_timestamp_{0}; |
Amin Hassani | 1677e81 | 2017-06-21 13:36:36 -0700 | [diff] [blame] | 247 | bool first_active_omaha_ping_sent_{false}; |
Tianjie Xu | d6aa91f | 2019-11-14 11:55:10 -0800 | [diff] [blame] | 248 | bool warm_reset_{false}; |
Kelvin Zhang | d719103 | 2020-08-11 10:48:16 -0400 | [diff] [blame] | 249 | mutable std::map<std::string, std::string> partition_timestamps_; |
Alex Deymo | 4243291 | 2013-07-12 20:21:15 -0700 | [diff] [blame] | 250 | |
| 251 | DISALLOW_COPY_AND_ASSIGN(FakeHardware); |
| 252 | }; |
| 253 | |
| 254 | } // namespace chromeos_update_engine |
| 255 | |
Alex Deymo | 39910dc | 2015-11-09 17:04:30 -0800 | [diff] [blame] | 256 | #endif // UPDATE_ENGINE_COMMON_FAKE_HARDWARE_H_ |