blob: 58157d0961dbee6888e8cce59e0fa0611c916528 [file] [log] [blame]
Alex Deymo42432912013-07-12 20:21:15 -07001// Copyright (c) 2013 The Chromium OS Authors. All rights reserved.
2// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
5#ifndef CHROMEOS_PLATFORM_UPDATE_ENGINE_HARDWARE_INTERFACE_H__
6#define CHROMEOS_PLATFORM_UPDATE_ENGINE_HARDWARE_INTERFACE_H__
7
8#include <string>
Alex Vakulenko59e253e2014-02-24 10:40:21 -08009#include <vector>
Alex Deymo42432912013-07-12 20:21:15 -070010
11namespace chromeos_update_engine {
12
13// The hardware interface allows access to the following parts of the system,
14// closely related to the hardware:
15// * crossystem exposed properties: firmware, hwid, etc.
16// * Physical disk: partition booted from and partition name conversions.
17// These stateless functions are tied together in this interface to facilitate
18// unit testing.
19class HardwareInterface {
20 public:
Don Garrett83692e42013-11-08 10:11:30 -080021 // Returns the currently booted kernel partition. "/dev/sda2", for example.
22 virtual const std::string BootKernelDevice() = 0;
23
24 // Returns the currently booted rootfs partition. "/dev/sda3", for example.
Alex Deymo42432912013-07-12 20:21:15 -070025 virtual const std::string BootDevice() = 0;
26
Alex Vakulenko59e253e2014-02-24 10:40:21 -080027 // Returns a list of all kernel partitions available (whether bootable or not)
28 virtual std::vector<std::string> GetKernelDevices() = 0;
29
Don Garrett83692e42013-11-08 10:11:30 -080030 // Is the specified kernel partition currently bootable, based on GPT flags?
31 // Returns success.
32 virtual bool IsKernelBootable(const std::string& kernel_device,
33 bool* bootable) = 0;
34
35 // Mark the specified kernel partition unbootable in GPT flags. We mark
36 // the other kernel as bootable inside postinst, not inside the UE.
37 // Returns success.
38 virtual bool MarkKernelUnbootable(const std::string& kernel_device) = 0;
39
J. Richard Barnette056b0ab2013-10-29 15:24:56 -070040 // Returns true if this is an official Chrome OS build, false otherwise.
41 virtual bool IsOfficialBuild() = 0;
42
43 // Returns true if the boot mode is normal or if it's unable to
44 // determine the boot mode. Returns false if the boot mode is
45 // developer.
46 virtual bool IsNormalBootMode() = 0;
J. Richard Barnette522d36f2013-10-28 17:22:12 -070047
48 // Returns the HWID or an empty string on error.
49 virtual std::string GetHardwareClass() = 0;
50
51 // Returns the firmware version or an empty string if the system is
52 // not running chrome os firmware.
53 virtual std::string GetFirmwareVersion() = 0;
54
55 // Returns the ec version or an empty string if the system is not
56 // running a custom chrome os ec.
57 virtual std::string GetECVersion() = 0;
Alex Deymo42432912013-07-12 20:21:15 -070058
59 virtual ~HardwareInterface() {}
60};
61
62} // namespace chromeos_update_engine
63
64#endif // CHROMEOS_PLATFORM_UPDATE_ENGINE_HARDWARE_INTERFACE_H__