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