blob: e14ae9a15316bdfaf438f72bd795c7e4c174334c [file] [log] [blame]
Alex Deymo40d86b22015-09-03 22:27:10 -07001//
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//
16
Alex Deymo1b03f9f2015-12-09 00:38:36 -080017#ifndef UPDATE_ENGINE_HARDWARE_CHROMEOS_H_
18#define UPDATE_ENGINE_HARDWARE_CHROMEOS_H_
Alex Deymo40d86b22015-09-03 22:27:10 -070019
Zentaro Kavanaghbaacb982018-02-20 17:48:39 -080020#include <memory>
Alex Deymo40d86b22015-09-03 22:27:10 -070021#include <string>
22#include <vector>
23
24#include <base/macros.h>
25#include <base/time/time.h>
Sen Jiange67bb5b2016-06-20 15:53:56 -070026#include <debugd/dbus-proxies.h>
Alex Deymo40d86b22015-09-03 22:27:10 -070027
Alex Deymo39910dc2015-11-09 17:04:30 -080028#include "update_engine/common/hardware_interface.h"
Alex Deymo40d86b22015-09-03 22:27:10 -070029
30namespace chromeos_update_engine {
31
32// Implements the real interface with Chrome OS verified boot and recovery
33// process.
34class HardwareChromeOS final : public HardwareInterface {
35 public:
36 HardwareChromeOS() = default;
37 ~HardwareChromeOS() override = default;
38
Alex Deymo46a9aae2016-05-04 20:20:11 -070039 void Init();
40
Alex Deymo40d86b22015-09-03 22:27:10 -070041 // HardwareInterface methods.
42 bool IsOfficialBuild() const override;
43 bool IsNormalBootMode() const override;
Sen Jiange67bb5b2016-06-20 15:53:56 -070044 bool AreDevFeaturesEnabled() const override;
Alex Deymo46a9aae2016-05-04 20:20:11 -070045 bool IsOOBEEnabled() const override;
Alex Deymo40d86b22015-09-03 22:27:10 -070046 bool IsOOBEComplete(base::Time* out_time_of_oobe) const override;
47 std::string GetHardwareClass() const override;
48 std::string GetFirmwareVersion() const override;
49 std::string GetECVersion() const override;
Matt Ziegelbaumaa8e1a42019-05-09 21:41:58 -040050 std::string GetDeviceRequisition() const override;
Zentaro Kavanaghbaacb982018-02-20 17:48:39 -080051 int GetMinKernelKeyVersion() const override;
Marton Hunyady99ced782018-05-08 12:59:50 +020052 int GetMinFirmwareKeyVersion() const override;
Zentaro Kavanagh8f6f2432018-05-16 13:48:12 -070053 int GetMaxFirmwareKeyRollforward() const override;
54 bool SetMaxFirmwareKeyRollforward(int firmware_max_rollforward) override;
Zentaro Kavanagh5d956152018-05-15 09:40:33 -070055 bool SetMaxKernelKeyRollforward(int kernel_max_rollforward) override;
Alex Deymo40d86b22015-09-03 22:27:10 -070056 int GetPowerwashCount() const override;
Zentaro Kavanagh28def4f2019-01-15 17:15:01 -080057 bool SchedulePowerwash(bool save_rollback_data) override;
Alex Deymofb905d92016-06-03 19:26:58 -070058 bool CancelPowerwash() override;
Alex Deymodd132f32015-09-14 19:12:07 -070059 bool GetNonVolatileDirectory(base::FilePath* path) const override;
60 bool GetPowerwashSafeDirectory(base::FilePath* path) const override;
Sen Jiang5011df62017-06-28 17:13:19 -070061 int64_t GetBuildTimestamp() const override;
Tianjie Xu4ad3af62019-10-30 11:59:45 -070062 bool AllowDowngrade() const override { return false; }
Amin Hassani1677e812017-06-21 13:36:36 -070063 bool GetFirstActiveOmahaPingSent() const override;
Amin Hassani80f4d4c2018-05-16 13:34:00 -070064 bool SetFirstActiveOmahaPingSent() override;
Tianjie Xud6aa91f2019-11-14 11:55:10 -080065 void SetWarmReset(bool warm_reset) override;
Alex Deymo40d86b22015-09-03 22:27:10 -070066
67 private:
Alex Deymo46a9aae2016-05-04 20:20:11 -070068 friend class HardwareChromeOSTest;
69
70 // Load the update manager config flags (is_oobe_enabled flag) from the
71 // appropriate location based on whether we are in a normal mode boot (as
72 // passed in |normal_mode|) prefixing the paths with |root_prefix|.
73 void LoadConfig(const std::string& root_prefix, bool normal_mode);
74
75 bool is_oobe_enabled_;
76
Sen Jiange67bb5b2016-06-20 15:53:56 -070077 std::unique_ptr<org::chromium::debugdProxyInterface> debugd_proxy_;
78
Alex Deymo40d86b22015-09-03 22:27:10 -070079 DISALLOW_COPY_AND_ASSIGN(HardwareChromeOS);
80};
81
82} // namespace chromeos_update_engine
83
Alex Deymo1b03f9f2015-12-09 00:38:36 -080084#endif // UPDATE_ENGINE_HARDWARE_CHROMEOS_H_