commit | 17c2c94eb9f6c789cba6e1495d88dfd7700b42fb | [log] [tgz] |
---|---|---|
author | Shawn McCarney <shawnmm@us.ibm.com> | Tue Dec 10 17:32:30 2024 -0600 |
committer | Shawn McCarney <shawnmm@us.ibm.com> | Wed Dec 11 13:00:36 2024 -0600 |
tree | c3928cf6121f5aaf0419f3f60982fdd017a26492 | |
parent | 46ea388c68bddfb13336ac182b74c75289ec8f78 [diff] |
Set ExtendedVersion property on Activations Activation objects are created by this application in three scenarios: 1. When an InterfacesAdded event notifies the application about a new PSU image that was uploaded to IMG_DIR (/tmp/images). 2. When getting the firmware version that is already running on a PSU in the system. 3. When a firmware version is found in the file system (IMG_DIR_BUILTIN or IMG_DIR_PERSIST). In scenario #2, there are two Activation properties that are not set: 1. Path: the file system path to the image directory. 2. ExtendedVersion: contains the manufacturer and model. In scenario #3, a firmware version may be found in the file system that is the same as the version running on a PSU. In this case, the Activation object has already been created. The Path property on the existing Activation is set to the file system path. However, the ExtendedVersion property of the existing Activation is not set. Due to this, the Activation has no manufacturer or model information. This means it cannot be used to update other PSUs. Solve this problem by setting the ExtendedVersion property of the existing Activation when a matching version is found in the file system. This will enable the Activation to obtain the manufacturer and model information. This in turn will allow the Activation to be used to update other PSUs that are not running the latest version. Tested: * Verified that extendedVersion, manufacturer, and model data members are set when the Activation constructor is called. * Verified that extendedVersion, manufacturer, and model data members are set when the new, overridden extendedVersion() method is called. * Verified that the ExtendedVersion property is set by scanDirectory() if an Activation already exists. * For the complete test plan see: https://gist.github.com/smccarney/2a3bf72c6faa436199a70968cd99e30e Change-Id: I7107b8c1d631ada5cd55648f92cf2c1e5cd90778 Signed-off-by: Shawn McCarney <shawnmm@us.ibm.com>
phosphor-psu-code-mgmt is a service to provide management for PSU code, including:
meson build/ && ninja -C build
Run it in OpenBMC CI, refer to local-ci-build.md
Run it in OE SDK, run below commands in a x86-64 SDK env:
meson -Doe-sdk=enabled -Dtests=enabled build/ ninja -C build/ test # Meson skips running the case due to it thinks it's cross compiling # Manually run the tests for t in `find build/test/ -maxdepth 1 -name "test_*"`; do ./$t || break ; done
This repo contains generic code to handle the PSU versions and updates. It depends on vendor-specific tools to provide the below functions on the real PSU hardware:
It provides configure options for vendor-specific tools for the above functions:
PSU_VERSION_UTIL
: It shall be defined as a command-line tool that accepts the PSU inventory path as input, and outputs the PSU version string to stdout.PSU_MODEL_UTIL
: It shall be defined as a command-line tool that accepts the PSU inventory path as input, and outputs the PSU model string to stdout.PSU_VERSION_COMPARE_UTIL
: It shall be defined as a command-line tool that accepts one or more PSU version strings, and outputs the latest version string to stdout.PSU_UPDATE_SERVICE
: It shall be defined as a systemd service that accepts two arguments:For example:
meson -Dtests=disabled \ '-DPSU_VERSION_UTIL=/usr/bin/psutils --raw --get-version' \ '-DPSU_MODEL_UTIL=/usr/bin/psutils --raw --get-model' \ '-DPSU_VERSION_COMPARE_UTIL=/usr/bin/psutils --raw --compare' \ '-DPSU_UPDATE_SERVICE=psu-update@.service' \ build
The above configures the vendor-specific tools to use psutils
from phosphor-power to get the PSU version and model, compare PSU versions, and use psu-update@.service
to perform the PSU firmware update, where internally it invokes psutils
as well.
When the service starts, it queries the inventory to get all the PSU inventory paths, invokes the vendor-specific tool to get the versions, and creates version objects under /xyz/openbmc_project/software
that are associated with the PSU inventory path. If multiple PSUs are using the same version, multiple PSU inventory paths are associated.
E.g.
Example of system with two PSUs that have different versions:
"/xyz/openbmc_project/software/02572429": { "Activation": "xyz.openbmc_project.Software.Activation.Activations.Active", "Associations": [ [ "inventory", "activation", "/xyz/openbmc_project/inventory/system/chassis/motherboard/powersupply1" ] ], "ExtendedVersion": "", "Path": "", "Purpose": "xyz.openbmc_project.Software.Version.VersionPurpose.PSU", "RequestedActivation": "xyz.openbmc_project.Software.Activation.RequestedActivations.None", "Version": "01120114" }, "/xyz/openbmc_project/software/7094f612": { "Activation": "xyz.openbmc_project.Software.Activation.Activations.Active", "Associations": [ [ "inventory", "activation", "/xyz/openbmc_project/inventory/system/chassis/motherboard/powersupply0" ] ], "ExtendedVersion": "", "Path": "", "Purpose": "xyz.openbmc_project.Software.Version.VersionPurpose.PSU", "RequestedActivation": "xyz.openbmc_project.Software.Activation.RequestedActivations.None", "Version": "00000110" },
Example of system with two PSUs that have the same version:
"/xyz/openbmc_project/software/9463c2ad": { "Activation": "xyz.openbmc_project.Software.Activation.Activations.Active", "Associations": [ [ "inventory", "activation", "/xyz/openbmc_project/inventory/system/chassis/motherboard/powersupply0" ], [ "inventory", "activation", "/xyz/openbmc_project/inventory/system/chassis/motherboard/powersupply1" ] ], "ExtendedVersion": "", "Path": "", "Purpose": "xyz.openbmc_project.Software.Version.VersionPurpose.PSU", "RequestedActivation": "xyz.openbmc_project.Software.Activation.RequestedActivations.None", "Version": "01100110" },
Generate a tarball of PSU firmware image by generate-psu-tar tool.
./generate-psu-tar --image <psu-image> --version <version> --model <model> --manufacturer \ <manufacturer> --machineName <machineName> --outfile <psu.tar> --sign
To update the PSU firmware, follow the same steps as described in code-update.md:
After a successful update, the PSU image and the manifest is stored in BMC's persistent storage defined by IMG_DIR_PERSIST
. When a PSU is replaced, the PSU's firmware version will be checked and updated if it's older than the one stored in BMC.
It is possible to put a PSU image and MANIFEST in the built-in OpenBMC image in BMC's read-only filesystem defined by IMG_DIR_BUILTIN
. When the service starts, it will compare the versions of the built-in image and the existing PSUs. If there is any PSU that has older firmware, it will be updated to the new firmware.