commit | 5ace9fb733e0757f105c3f6d00128fd9f5dc7df3 | [log] [tgz] |
---|---|---|
author | Faisal Awada <faisal@us.ibm.com> | Tue Jan 07 13:26:25 2025 -0600 |
committer | Faisal Awada <faisal@us.ibm.com> | Tue Jan 21 15:20:02 2025 -0600 |
tree | ec6a4e00b38a3c9de959c895f782c04c67abe45d | |
parent | 757ad6a91c0d18c750e83ffc4683df78be693f7b [diff] |
psutils: Add necessary firmware update functions doUpdate: Adds the main logic for orchestrating the PSU firmware update process, including ISP setup, firmware download, and verification. performI2cWriteReadWithRetries: Introduces functionality to perform I2C write-read operations with configurable retries, and error handling for robustness. performI2cReadWrite: Provides the implementation for direct I2C write-read operations with a customizable delay to ensure timing requirements are met. downloadPsuFirmware: Implements the functionality to read and process PSU firmware in blocks, ensuring data integrity during transfer. verifyDownloadFwStatus: Adds a mechanism to validate the success of firmware downloads by checking the PSU's checksum status register. getClassInstance: Add logic to dynamically instantiate updater class based on PSU model. Test: Placed latest firmware and MANIFEST files in "/usr/share/obmc/51E9" then retrieved the current PSU FW level. Ran "psutils" on the command line as follow: /usr/bin/psutils --update /xyz/openbmc_project/inventory/system/chassis/motherboard/powersupply1 /usr/share/obmc/51E9 Retrieved the FW level and verified the PSU FW was updated as expected. Signed-off-by: Faisal Awada <faisal@us.ibm.com> Change-Id: I65d0c015eab0322110e85b954a38590332aaa67a Signed-off-by: Faisal Awada <faisal@us.ibm.com>
This repository contains applications for configuring and monitoring devices that deliver power to the system.
Actively-maintained applications:
Legacy applications:
To build all applications in this repository:
meson setup build ninja -C build
To clean the repository and remove all build output:
rm -rf build
You can specify meson options to customize the build process. For example, you can specify:
Several applications in this repository require a PSU JSON config to run. The JSON config file provides information for:
There is an example psu.json to describe the necessary configurations.
inventoryPMBusAccessType
defines the pmbus access type, which tells the service which sysfs type to use to read the attributes. The possible values are:
/sys/bus/i2c/devices/3-0069/
/sys/bus/i2c/devices/3-0069/hwmon/hwmonX/
/sys/kernel/debug/pmbus/hwmonX/
/sys/kernel/debug/<driver>.<instance>/
/sys/kernel/debug/pmbus/hwmonX/cffps1/
fruConfigs
defines the mapping between the attribute file and the FRU inventory interface and property. The configuration example below indicates that the service will read part_number
attribute file from a directory specified by the above pmbus access type, and assign to PartNumber
property in xyz.openbmc_project.Inventory.Decorator.Asset
interface.
"fruConfigs": [ { "propertyName": "PartNumber", "fileName": "part_number", "interface": "xyz.openbmc_project.Inventory.Decorator.Asset" } ]
psuDevices
defines the kernel device dir for each PSU in inventory. The configuration example below indicates that powersupply0
's device is located in /sys/bus/i2c/devices/3-0069
.
"psuDevices": { "/xyz/openbmc_project/inventory/system/chassis/motherboard/powersupply0" : "/sys/bus/i2c/devices/3-0069", }