commit | 31ce375e7e71ff6b3da460dc63c1ab4f16cf4df6 | [log] [tgz] |
---|---|---|
author | Rush Chen <rush.chen.wiwynn@gmail.com> | Fri Nov 08 14:57:27 2024 +0800 |
committer | Patrick Williams <patrick@stwcx.xyz> | Mon Nov 25 18:00:02 2024 -0500 |
tree | 220198ce30950a243c62a89be39dcb88f3a23023 | |
parent | 4c47d4c9a8ae5dd27f4c9e0b5557dd1e33e52a04 [diff] |
Support multi power buttons with multi behaviors For supporting more-than-one power buttons behaviors, add new matches and instances by following json config. This change is for multiple slots integrated on one chassis, and each slot has button to control power status. For example: /xyz/openbmc_project/Chassis/Buttons/Power01 for button on slot1 /xyz/openbmc_project/Chassis/Buttons/Power02 for button on slot2 Moreover, support multi-level power control by json config, chassis now can do action by corresponding pressing duration. Tested: Press buttons and check corresponding behaviors. Change-Id: I7789f0367d5e846dd9e68f966ba0755fc916217a Signed-off-by: Rush Chen <rush.chen.wiwynn@gmail.com>
Phosphor-buttons has a collection of IO event handler interfaces for physical inputs which are typically part of some sort of panel.
It defines an individual dbus interface object for each physical button/switch inputs such as power button, reset button etc. Each button interface monitors its associated IO for event changes and emits signals that the button-handler application listens for.
All events occur when the button is released.
If the power is off, power on the host.
If the power is on, it depends on how long the press was and which options are enabled:
The 'power-button-profile' meson option can be used to select custom power button profiles that have different behaviors.
Available profiles are:
See this section below.
When released:
When released, toggles the 'enclosure_identify' LED group provided by the phosphor-led-manager repository. The group name can be changed using the 'id-led-group' meson option.
In order to monitor a button/input interface the respective gpio config details should be mentioned in the gpio defs json file - /etc/default/obmc/gpio/gpio_defs.json
A gpio can be mapped using the "pin" or "num" keyword. The "pin" key uses alphanumerical references while the "num" key supports the integer pin number.
{ "gpio_definitions": [ { "name": "POWER_BUTTON", "gpio_config": [ { "pin": "D0", "direction": "both" } ] }, { "name": "RESET_BUTTON", "gpio_config": [ { "pin": "AB0", "direction": "both" } ] }, { "name": "HOST_SELECTOR", "group_gpio_config": [ { "pin": "AA4", "direction": "both" }, { "pin": "AA5", "direction": "both" }, { "pin": "AA6", "direction": "both" }, { "pin": "AA7", "direction": "both" } ] } ] }
This config is original config which can be used for configs with only single gpio such as power button,reset button, OCP debug card host select button.
{ "name": "POWER_BUTTON", "pin": "D0", "direction": "both" }
Note: this config is used by most of the other platforms so this format is kept as it is so that existing gpio configs do not get affected.
The following configs are related to multi-host bmc systems more info explained in the design: https://github.com/openbmc/docs/blob/master/designs/multihost-phosphor-buttons.md
The host selector has four gpios associated. So the related gpios are mentioned in a json array named group_gpio_config.
Example : The value of "7" derived from the 4 host select gpio lines are mapped to host position 1.
{ "name": "HOST_SELECTOR", "group_gpio_config": [ { "name": "host_select_0", "pin": "AA4", "direction": "both", "polarity": "active_high" }, { "name": "host_select_1", "pin": "AA5", "direction": "both", "polarity": "active_high" }, { "name": "host_select_2", "pin": "AA6", "direction": "both", "polarity": "active_high" }, { "name": "host_select_3", "pin": "AA7", "direction": "both", "polarity": "active_high" } ], "max_position": 4, "host_selector_map": { "6": 0, "7": 1, "8": 2, "9": 3, "10": 4, "11": 0, "12": 1, "13": 2, "14": 3, "15": 4 } }
There are also some systems that get the host selector selection from the CPLD, the configuration is provided below.
{ "cpld_definitions": [ { "name": "HOST_SELECTOR", "i2c_bus": 12, "i2c_address": 15, "register_name": "uart-selection-debug-card", "max_position": 4 } ] }
Similar to host selector there are multiple gpios associated with the serial uart mux. These gpio configs are specified as part of json array "group_gpio_config".
Here the serial uart mux output is accessed via OCP debug card. SO the OCP debug card present gpio is mentioned part of the group_gpio_config. The debug card present gpio is identified by its name "debug_card_present".
The other gpios part of the group gpio config is serial uart MUX gpio select lines and serial_uart_rx line.
{ "name": "SERIAL_UART_MUX", "group_gpio_config": [ { "name": "serial_uart_sel_0", "pin": "E0", "direction": "out", "polarity": "active_high" }, { "name": "serial_uart_sel_1", "pin": "E1", "direction": "out", "polarity": "active_high" }, { "name": "serial_uart_sel_2", "pin": "E2", "direction": "out", "polarity": "active_high" }, { "name": "serial_uart_sel_3", "pin": "E3", "direction": "out", "polarity": "active_high" }, { "name": "serial_uart_rx", "pin": "E4", "direction": "out", "polarity": "active_high" }, { "name": "debug_card_present", "pin": "R3", "direction": "both", "polarity": "active_high" } ], "serial_uart_mux_map": { "0": 4, "1": 0, "2": 1, "3": 2, "4": 3 } }
This config is used for configs with multiple power buttons on each slots and whole sled, or for which needs multi-level chassis power control behavior.
name - this is name of the specific gpio line, "POWER_BUTTON" + the index of chassis instance
{ "gpio_definitions": [ { "name": "POWER_BUTTON0", "pin": "I6", "direction": "both", "multi-action": [ { "duration": 4000, "action": "chassis cycle" } ] }, { "name": "POWER_BUTTON1", "pin": "V0", "direction": "both", "multi-action": [ { "duration": 0, "action": "chassis on" }, { "duration": 4000, "action": "chassis cycle" }, { "duration": 8000, "action": "chassis off" } ] } ] }