Author: Christopher Sides (citysides)
Other contributors:
Created: September 14, 2023
BMC needs a process to identify and handle HPE GXP baseboards that provide HW ID data via non-I2C channels and in a proprietary format that is not covered by Entity-Manager's 'fru-device' daemon that most platforms rely on.
This proposal describes a method of handling for hardware where HW ID data is gathered from device tree file paths for Entity-Manager consumption.
Typical platforms provide HW ID data - often referred to as 'vital product data' (VPD) - for the baseboard as a FRU storage blob held in a physical EEPROM.
As described in Entity-Manager documentation, this blob is discovered and read over I2C, then is decoded before the data is copied to D-Bus as properties of the xyz.openbmc_project.FruDevice
interface by Entity-Manager's fru-device daemon. The current FRU-device daemon is able to decode IPMI-FRU storage formatted blobs, as well as the Tyan data format.
Additionally, a separate daemon for handling OpenPower format VPD is hosted in the 'openpower-vpd-parser' subproject. This daemon is relied on for the identification of certain IBM-supported hardware.
HPE hardware uses different channels and data formats from the above, relying on modifications to the device-tree to output properties as one file handle per attribute.
Once VPD is made available on D-Bus, it can be referenced by the Entity-Manager configuration 'probe' statements that are used as hardware/configuration detection triggers.
HPE platforms provide the following properties for baseboard VPD:
HPE platforms in Gen 10 and earlier provided VPD through a standard I2C-accessible EEPROM (but still in a proprietary data format). That avenue is no longer available on newer HPE systems.
For GXP-based Gen 11 HPE platforms, proprietary HPE-controlled bootblock firmware communicates with a secure element to provide necessary VPD. This process uses a driver whose implementation is strictly license-controlled and cannot be publicly released. The open source portions of the boot chain must adapt to the bootblock's reserved memory application binary interface (ABI) for providing VPD from the secure element.
Early in the boot process, an HPE-proprietary bootblock is validated, then an HPE-specific bootloader in the block fetches the VPD blob from the secure element via third party driver. From here, the data blob is copied to a predetermined location in RAM, where it is retrieved and parsed by HPE-specific code in u-Boot (open-sourced, and available at https://github.com/HewlettPackard/gxp-uboot). In the future, we'll be aiming to upstream as much 'HPE-critical' u-boot code as needed so that an HPE-specific u-boot fork will not be needed to boot HPE hardware.
Additionally, code in u-Boot gathers MAC addresses for the BMC's network interfaces, along with retrieving a 'server_id' value from an embedded CPLD-based memory device. This value is unique to each model of HPE platform, and will be used for platform-wide identification. In comparison, the data in the aforementioned blob may be used for recognizing finer details like specific board revisions for a given platform.
The HPE process described above relies on shared memory instead of u-boot env variables because the HPE bootloader does not know that u-boot will run next, and does not know where the u-boot variable store is, if it exists at all -- since a customer could decide to use something other than u-boot, or to store their environmental variables in a different place or format.
After that, u-Boot makes relevant data available to Linux via modifications to the flattened device tree, setting the values for '/model' and '/serial-number,' which both have well-known paths in the device tree root, along with 'local-mac-address,' a property provided by the network binding.
From there, the GXP product data must be published to D-Bus, or there will be no way for Entity-Manager to reference it during the probe evaluations used in detecting supported hardware configurations. The contents of 'device-tree/model' being made available on D-Bus will be enough to enable basic Entity-Manager identification of HPE baseboard hardware.
In the future, HPE's behind-the-scenes reliance on u-Boot for this process may be reduced or removed entirely, but but those implementation details should not affect how a service would collect data from the device-tree passed to the kernel from u-Boot. One alternative to modifying the flat device-tree would be to have values like 'model' set in the platform's device-tree source at image build time.
This document discusses leveraging a 'device-tree -> D-Bus' daemon in Entity-Manager to enable BMC detection and handling of HPE Gen 11 hardware (and potentially for other hardware as well).
Vital product data must be parsed and published to D-Bus
D-Bus properties for interface(s) at path xyz/openbmc_project/Inventory/MachineContext
may be populated using retrieved VPD values as appropriate to offer a D-Bus path for common specific model identifying details.
Vital product data properties should be referenced in Entity-Manager config 'probe' statement(s) in order to key configuration enablement off them.
High Level Flow:
At boot, a proprietary HPE bootblock is validated, then HPE GXP-bootloader code (proprietary) included in the block retrieves data from a secure element. Specific hardware identifying information is transferred into a pre-determined memory location in RAM for pickup.
u-Boot code (via an open source, but HPE-specific process) gathers MAC addresses and moves product data from the RAM location, plus a CPLD-based memory device, and exposes it in Linux under /proc/device-tree/
A daemon in DeviceTree-VPD-Parser retrieves product data from known device tree paths, then parses and publishes to D-Bus
Entity-Manager probes that reference properties from the xyz.openbmc_project.Inventory.Decorator.Asset
(.Model & .SerialNumber properties) interface on D-Bus can key off GXP hardware data and react accordingly.
Current repo maintainer feels the service doesn't fit this repo because the purpose is explicitly to deal with manipulation of u-boot env variables, which this service is not involved with.
https://gerrit.openbmc.org/c/openbmc/phosphor-u-boot-env-mgr/+/71512
Proposal: xyz.openbmc_project.Decorator.*
Rejection: "doesn't represent anything about the physical board" -Ed Tanous
Followup: Phosphor-dbus-interfaces maintenance (Patrick Williams) has rejected hosting an interface with properties like 'Model' and 'SerialNumber' that already exist as part of other interfaces, and has specifically suggested relying on xyz.openbmc_project.Inventory.Decorator.Asset (for .model and .serialnumber properties) along with xyz.openbmc_project.Inventory.Item.NetworkInterface (for .MACAddress property).
Discussion @ https://gerrit.openbmc.org/c/openbmc/phosphor-dbus-interfaces/+/73260/comment/e0226ae4_d7e514dd/
Follow-up 2: Sticking with Inventory.Decorator.Asset, but removing MAC address properties to reduce unneeded complexity.
Proposal: xyz.openbmc_project.FRUDevice
Rejection: The data is not coming from a FRU device
Proposal: xyz.openbmc_project.DeviceTree
Proposal: xyz.openbmc_project.uBootHWID
Proposal: xyz.openbmc_project.GXPFRU
Rejection: Above interfaces do not reflect underlying hardware
Proposal: xyz.openbmc_project.BMCPrebootContext
Rejection: Arguably doesn't represent a hardware concept.
Proposal: xyz.openbmc_project.UbootDeviceModel
Rejection: There are ongoing efforts to enable dynamic device-tree modifications post-u-boot. The nodes this daemon reads are unlikely to be affected, but there's no guarantee of that.
Proposal: xyz.openbmc_project.Platform
Rejection: Some attributes like serial-number or MAC don't apply across a given platform
Proposal: xyz.openbmc_project.Machine
Rejection: Promising, but the name seems vague re: its purpose. xyz.openbmc_project.MachineContext has been offered as an alternative.
Proposal: xyz.openbmc_project.MachineContext
Rejection: "We have all this stuff [.Model, .SerialNumber, ect. properties] defined already. I'm not going to accept a new "bunch of random properties HPe thinks are important [today] globbed into a new interface" interface"
Counter-proposal: "Reuse the existing dbus interfaces and put them at a well-defined location? Inventory.Decorator.[Asset] = Model Inventory.Decorator.Asset = SerialNumber Inventory.Item.NetworkInterace = MACAddress.." - Patrick Williams
Discussion @ https://gerrit.openbmc.org/c/openbmc/phosphor-dbus-interfaces/+/73260/comment/e0226ae4_d7e514dd/
Follow-up: Landed on interface: xyz.openbmc_project.Inventory.Decorator.Asset @ path xyz/openbmc_project/Inventory/MachineContext
The above-described process is only intended to scan selected paths -if they exist- once during initial service startup.
If the path(s) in question do not exist (device-tree/model or device-tree/serial-number), no further work will be done, so there is expected to be no noticeable performance or functional impact to platforms that don't rely on this service for Entity-Manager HW/config detection.
Yes. At this time, each of the [Channel] VPD -> D-Bus services (other than Fru_Device hosted in the Entity-Manager repo) has its own dedicated repository, so it would make sense to follow that pattern by creating a repo dedicated to hosting this service.
Christopher Sides
&Ian Woloschin
from HPE will be maintainers, with early oversight from an experienced member of the OBMC community.
Entity-Manager will have configuration files added for HPE hardware that make use of the new interface properties via probe statements.
Any platform that has a device-tree 'model' or 'serial-number' node populated in Device-Tree (this can be done by hardcoding a value into the DTS file before building an image, if desired) can be checked by confirming the contents of the device-tree/model and/or serial-number node matches the contents of 'model' and 'serial-number' properties of D-Bus interface at D-Bus path 'xyz/openbmc_project/MachineContext'
Practically, the whole of the service stack (including Entity-Manager probe validation) of the new D-Bus path can be validated on an HPE system by setting an Entity-Manager config's probe to trigger on match with a known HPE-HW identifying property, then by confirming busctl tree xyz.openbmc_project.EntityManager
shows a listing of objects that matches what's described in the modified EM config file.
At this time, HPE hardware requires forked (publicly available) OBMC components to fully boot, so automated testing of HPE hardware against 'mainstream' OBMC images is not yet a viable option. Enabling this type of testing is a longer term goal.