commit | 38cd74c88d7be550bb022572891f3037061460d5 | [log] [tgz] |
---|---|---|
author | Yang Chen <yang.chen@quantatw.com> | Thu Nov 07 14:42:24 2024 +0800 |
committer | Yang Chen <yang.chen@quantatw.com> | Fri Nov 08 09:49:47 2024 +0800 |
tree | bee5101cd9f07c19360c979a1acbb3083411c289 | |
parent | 8377d59c61c653a34df1c3c4ca72219eceb0b43b [diff] |
Continue on missing GPIOs in the monitor/presence In some cases, if a GPIO is not found, the function returns -1 to exit the process. To improve this, change the return value from -1 to continue so each object can be handled separately. This ensures the JSON file fully parses even if some GPIOs are missing. Change-Id: I83763d56963e3d2ec9981a95a1a0da17d0882910 Signed-off-by: Yang Chen <yang.chen@quantatw.com>
phosphor-gpio-monitor
This daemon accepts a command line parameter for monitoring single gpio line and take action if requested. This implementation uses GPIO keys and only supports monitoring single GPIO line, for multiple lines, user has to run this daemon seperately for each gpio line.
phosphor-multi-gpio-monitor
This daemon accepts command line parameter as a well-defined GPIO configuration file in json format to monitor list of gpios from config file and take action defined in config based on gpio state change. It uses libgpiod library.
New implementation (phosphor-multi-gpio-monitor) provides multiple gpio line monitoring in single instance of phosphor-multi-gpio-monitor running. It is very easy to add list of gpios into JSON config file and it also supports of GPIO line by name defined in kernel.
There is a phosphor-multi-gpio-monitor.json file that defines details of GPIOs which is required to be monitored. This file can be replaced with a platform specific configuration file via bbappend.
Following are fields in json file
[ { "Name": "PowerButton", "LineName": "POWER_BUTTON", "GpioNum": 34, "ChipId": "gpiochip0", "EventMon": "FALLING", "Target": "PowerButtonDown.service", "Continue": true }, { "Name": "PowerGood", "LineName": "PS_PWROK", "EventMon": "BOTH", "Targets": { "FALLING": ["PowerGoodFalling.service", "PowerOff.service"], "RISING": ["PowerGoodRising.service", "PowerOn.service"] }, "Continue": false }, { "Name": "SystemReset", "GpioNum": 46, "ChipId": "0" } ]
phosphor-multi-gpio-presence
This daemon accepts command line parameter as a well-defined GPIO configuration file in json format to monitor list of gpios from config file and sets inventory presence as defined in config based on gpio state change. It uses libgpiod library.
New implementation (phosphor-multi-gpio-presence) provides multiple gpio line monitoring in single instance of phosphor-multi-gpio-presence running. It is very easy to add list of gpios into JSON config file and it also supports of GPIO line by name defined in kernel.
There is a phosphor-multi-gpio-presence.json file that defines details of GPIOs which is required to be monitored. This file can be replaced with a platform specific configuration file via bbappend.
Following are fields in json file
[ { "Name": "DIMM A0", "LineName": "POWER_BUTTON", "Inventory": "/system/chassis/motherboard/dimm_a0" }, { "Name": "Powersupply 0", "ChipId": "0", "GpioNum": 14, "Inventory": "/system/chassis/motherboard/powersupply0", "ActiveLow": true, "Bias": "PULL_UP", "ExtraInterfaces": ["xyz.openbmc_project.Inventory.Item.PowerSupply"] } ]