commit | e0e1549e82c4691ad41703cfb6563c77b76cf2c4 | [log] [tgz] |
---|---|---|
author | Matt Spinler <spinler@us.ibm.com> | Mon Oct 28 04:17:48 2024 -0500 |
committer | Matt Spinler <spinler@us.ibm.com> | Thu Nov 07 14:09:26 2024 -0600 |
tree | af430d8b88fc3a4dbbed004204056f9595c755f9 | |
parent | f04c17494ce93764dd81fc8bbc2feda2196a2e7a [diff] |
Add Slot interface to all NVMe drives Assign a slot number to all drive paths so that the entity manager config file for IBM's drives can use that to give its objects unique names. Previously it used its own incrementing index but sometimes got confused and tried to put a duplicate interface on the same object path which would crash. This was already being done for IBM's cable card sensors. Because the NVMe temperature sensor names are being hardcoded in other places (fan control and HMC telemetry), the slots are being assigned to always start at 1 and sequentially increment to keep the names the same as before. Tested: Properties are on D-Bus: ``` busctl get-property xyz.openbmc_project.Inventory.Manager \ /xyz/openbmc_project/inventory/system/chassis/motherboard/disk_backplane0/nvme0/dp0_drive0 \ xyz.openbmc_project.Inventory.Decorator.Slot SlotNumber u 1 ``` Change-Id: Id83c5c4ea2aaae810bcd9c1120cef11fb0e7ba74 Signed-off-by: Matt Spinler <spinler@us.ibm.com>
This repository hosts code for OpenPower and IBM IPZ format VPD parsers. Both OpenPower VPD and IPZ VPD formats are structured binaries that consist of records and keywords. A record is a collection of multiple keywords. More information about the format can be found here.
The repository consists of two distinct applications, which are:
This is a build-time YAML driven application that parses the OpenPower VPD format and uses the YAML configuration (see extra-properties-example.yaml and writefru.yaml) to determine:
The application instance must be passed in the file path to the VPD (this can, for example, be a sysfs path exposed by the EEPROM device driver) and also the D-Bus object path(s) that EEPROM data needs to be published under.
This parser is can be built by passing in the --enable-ibm-parser
configure option. This parser differs from the OpenPower VPD parser in the following ways:
#
and are > 255 bytes in length).Making the application runtime JSON driven allows us to support multiple systems (with different FRU configurations) to be supported in a single code image as well as making the application more flexible for future improvements.