blob: 4a1d575705e95b5942fdb4b357e24a5e8c25ffd9 [file] [log] [blame]
Josh Kingd7d237b2016-11-24 14:54:35 -06001description: >
Patrick Williams8da396c2022-03-14 14:21:02 -05002 Implementation of BMC state management. When rebooting we are in
3 transition. When Ready all services required are running
Patrick Williamsa1347412022-12-06 10:56:22 -06004 successfully. When we are Not Ready this implies not all services have
5 started that are required to be.
Josh Kingd7d237b2016-11-24 14:54:35 -06006
7properties:
Patrick Williams8da396c2022-03-14 14:21:02 -05008 - name: RequestedBMCTransition
9 type: enum[self.Transition]
10 default: "None"
11 description: >
12 The desired BMC transition
Josh Kingd7d237b2016-11-24 14:54:35 -060013
Patrick Williams8da396c2022-03-14 14:21:02 -050014 - name: CurrentBMCState
15 type: enum[self.BMCState]
16 description: >
17 The current state of the BMC and is a read-only property.
Josh Kingd7d237b2016-11-24 14:54:35 -060018
Patrick Williams8da396c2022-03-14 14:21:02 -050019 - name: LastRebootTime
20 type: uint64
21 description: >
Patrick Williamsa1347412022-12-06 10:56:22 -060022 The last time at which the BMC came out of a reboot as determined by
23 its uptime, in epoch time, in milliseconds.
Matt Spinler7b1c2212018-07-11 10:27:47 -050024
Patrick Williams8da396c2022-03-14 14:21:02 -050025 - name: LastRebootCause
26 type: enum[self.RebootCause]
27 default: "Unknown"
28 description: >
29 The last BMC reboot cause
Tim Lee2a4da802021-08-04 09:52:47 +080030
Josh Kingd7d237b2016-11-24 14:54:35 -060031enumerations:
Patrick Williams8da396c2022-03-14 14:21:02 -050032 - name: Transition
33 description: >
34 The desired transition for the BMC firmware
35 values:
36 - name: "Reboot"
37 description: >
38 BMC system should be rebooted
39 - name: "HardReboot"
40 description: >
41 BMC system should be non-gracefully rebooted.
42 - name: "None"
43 description: >
44 No transition is in progress
Josh Kingd7d237b2016-11-24 14:54:35 -060045
Patrick Williams8da396c2022-03-14 14:21:02 -050046 - name: BMCState
47 description: >
48 The current state of the BMC firmware
49 values:
50 - name: "Ready"
51 description: >
52 Ready implies all services started and are running successfully
53 - name: "NotReady"
54 description: >
Patrick Williamsa1347412022-12-06 10:56:22 -060055 Not ready implies not all services have started or are not
56 running successfully
Patrick Williams8da396c2022-03-14 14:21:02 -050057 - name: "UpdateInProgress"
58 description: >
Patrick Williamsa1347412022-12-06 10:56:22 -060059 UpdateInProgress implies BMC is in firmware update mode.
60 CurrentBMCState will be set to "UpdateInProgress" while starting
61 image download and reset to Ready, once activation is done or
62 error case during update process.
Patrick Williams8da396c2022-03-14 14:21:02 -050063 - name: "Quiesced"
64 description: >
65 BMC firmware is quiesced. The BMC firmware is enabled but either
Patrick Williamsa1347412022-12-06 10:56:22 -060066 unresponsive or only processing a restricted set of commands.
67 This state may be the result of a service within the BMC going
68 into a failed state.
Tim Lee2a4da802021-08-04 09:52:47 +080069
Patrick Williams8da396c2022-03-14 14:21:02 -050070 - name: RebootCause
71 description: >
72 The recorded reboot cause of the BMC
73 values:
74 - name: "POR"
75 description: >
76 Last reboot is caused by Power-On-Reset
77 - name: "PinholeReset"
78 description: >
79 Last reboot is caused by pinhole reset
80 - name: "Watchdog"
81 description: >
82 Last reboot is caused by Watchdog
83 - name: "Unknown"
84 description: >
85 Last reboot is caused by Unknown