Patrick Williams | 8da396c | 2022-03-14 14:21:02 -0500 | [diff] [blame] | 1 | description: Implement to provide the chassis power management |
Andrew Geissler | 2477d9a | 2016-11-22 12:09:21 -0600 | [diff] [blame] | 2 | |
| 3 | properties: |
| 4 | - name: RequestedPowerTransition |
| 5 | type: enum[self.Transition] |
Patrick Williams | 8da396c | 2022-03-14 14:21:02 -0500 | [diff] [blame] | 6 | default: "Off" |
Andrew Geissler | 2477d9a | 2016-11-22 12:09:21 -0600 | [diff] [blame] | 7 | description: > |
Patrick Williams | a134741 | 2022-12-06 10:56:22 -0600 | [diff] [blame] | 8 | The desired power transition to start on this chassis. This will be |
| 9 | preserved across AC power cycles of the BMC. |
Andrew Geissler | abb61a0 | 2023-05-25 12:47:56 -0500 | [diff] [blame] | 10 | errors: |
| 11 | - xyz.openbmc_project.State.Chassis.Error.BMCNotReady |
Andrew Geissler | 2477d9a | 2016-11-22 12:09:21 -0600 | [diff] [blame] | 12 | |
| 13 | - name: CurrentPowerState |
| 14 | type: enum[self.PowerState] |
| 15 | description: > |
Patrick Williams | a134741 | 2022-12-06 10:56:22 -0600 | [diff] [blame] | 16 | A read-only property describing the current chassis power state. A |
| 17 | user can determine if a chassis is in transition by comparing the |
| 18 | CurrentPowerState and RequestedPowerTransition properties. |
Andrew Geissler | 2477d9a | 2016-11-22 12:09:21 -0600 | [diff] [blame] | 19 | |
Andrew Geissler | 9c91332 | 2021-11-08 16:09:45 -0600 | [diff] [blame] | 20 | - name: CurrentPowerStatus |
| 21 | type: enum[self.PowerStatus] |
| 22 | description: > |
Patrick Williams | a134741 | 2022-12-06 10:56:22 -0600 | [diff] [blame] | 23 | A read-only property describing the current chassis power status. This |
| 24 | property aggregates all available information about the status of the |
| 25 | power coming into the chassis. Note that this is different then the |
| 26 | CurrentPowerState in that it provides status of the power coming into |
| 27 | the chassis, not the actual state of the chassis power. |
Andrew Geissler | 9c91332 | 2021-11-08 16:09:45 -0600 | [diff] [blame] | 28 | |
Matt Spinler | e0c06d7 | 2018-07-09 11:15:21 -0500 | [diff] [blame] | 29 | - name: LastStateChangeTime |
| 30 | type: uint64 |
| 31 | description: > |
Patrick Williams | a134741 | 2022-12-06 10:56:22 -0600 | [diff] [blame] | 32 | The last time at which the chassis power changed state, as tracked by |
| 33 | the CurrentPowerState property, in epoch time, in milliseconds. This |
| 34 | can be used to tell when the chassis was last powered on or off. |
Matt Spinler | e0c06d7 | 2018-07-09 11:15:21 -0500 | [diff] [blame] | 35 | |
Andrew Geissler | 2477d9a | 2016-11-22 12:09:21 -0600 | [diff] [blame] | 36 | enumerations: |
| 37 | - name: Transition |
| 38 | description: > |
Patrick Williams | 8da396c | 2022-03-14 14:21:02 -0500 | [diff] [blame] | 39 | The desired power transition for the chassis |
Andrew Geissler | 2477d9a | 2016-11-22 12:09:21 -0600 | [diff] [blame] | 40 | values: |
Patrick Williams | 8da396c | 2022-03-14 14:21:02 -0500 | [diff] [blame] | 41 | - name: "Off" |
| 42 | description: > |
| 43 | Chassis power should be off |
| 44 | - name: "On" |
| 45 | description: > |
| 46 | Chassis power should be on |
| 47 | - name: "PowerCycle" |
| 48 | description: > |
| 49 | Chassis power should be cycled from off to on. There will be a 5 |
| 50 | second delay between the off and the on. |
Andrew Geissler | 2477d9a | 2016-11-22 12:09:21 -0600 | [diff] [blame] | 51 | |
| 52 | - name: PowerState |
| 53 | description: > |
Patrick Williams | 8da396c | 2022-03-14 14:21:02 -0500 | [diff] [blame] | 54 | The current state of the chassis power |
Andrew Geissler | 2477d9a | 2016-11-22 12:09:21 -0600 | [diff] [blame] | 55 | values: |
Patrick Williams | 8da396c | 2022-03-14 14:21:02 -0500 | [diff] [blame] | 56 | - name: "Off" |
| 57 | description: > |
| 58 | Chassis power is off |
| 59 | - name: "TransitioningToOff" |
| 60 | description: > |
| 61 | Firmware is transitioning the chassis to an Off state |
| 62 | - name: "On" |
| 63 | description: > |
| 64 | Chassis power is on |
| 65 | - name: "TransitioningToOn" |
| 66 | description: > |
| 67 | Firmware is transitioning the chassis to an On state |
Andrew Geissler | 9c91332 | 2021-11-08 16:09:45 -0600 | [diff] [blame] | 68 | |
| 69 | - name: PowerStatus |
| 70 | description: > |
Patrick Williams | 8da396c | 2022-03-14 14:21:02 -0500 | [diff] [blame] | 71 | The current status of the chassis power |
Andrew Geissler | 9c91332 | 2021-11-08 16:09:45 -0600 | [diff] [blame] | 72 | values: |
Patrick Williams | 8da396c | 2022-03-14 14:21:02 -0500 | [diff] [blame] | 73 | - name: "Undefined" |
| 74 | description: > |
| 75 | Chassis power status is unknown |
| 76 | - name: "BrownOut" |
| 77 | description: > |
| 78 | Chassis power status is in a brownout condition. |
| 79 | - name: "UninterruptiblePowerSupply" |
| 80 | description: > |
| 81 | Chassis power is being provided via an uninterruptible power |
Patrick Williams | a134741 | 2022-12-06 10:56:22 -0600 | [diff] [blame] | 82 | supply. Note that some systems may choose to continue to use |
| 83 | this status, even once power has returned to the system, to |
| 84 | indicate the uninterruptible power supply is charging or is |
| 85 | below a certain threshold of charged. This provides system |
| 86 | owners the flexibility on whether their system requires a |
| 87 | certain level of charged uninterruptible power supply to be in a |
| 88 | 'Good' state or not. |
Patrick Williams | 8da396c | 2022-03-14 14:21:02 -0500 | [diff] [blame] | 89 | - name: "Good" |
| 90 | description: > |
| 91 | Chassis power status is in a good condition |
Patrick Williams | 855b46f | 2024-01-15 16:21:40 -0600 | [diff] [blame] | 92 | |
| 93 | paths: |
| 94 | - namespace: /xyz/openbmc_project/state |
| 95 | segments: |
| 96 | - name: Chassis |
| 97 | value: chassis |