| 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_ |