PLDM (Platform Level Data Model) is a key component of the OpenBMC project, providing a standardized data model and message formats for various platform management functionalities. It defines a method to manage, monitor, and control the firmware and hardware of a system.
The OpenBMC PLDM project aims to implement the specifications defined by the Distributed Management Task Force (DMTF), allowing for interoperable management interfaces across different hardware and firmware components.
- Standardized Messaging: Adheres to the DMTF's PLDM specifications, enabling consistent and interoperable communication between different components.
- Modularity: Supports multiple PLDM types, including base, FRU,Firmware update, Platform Monitoring and Control, and BIOS Control and Configuration.
- Extensibility: Easily extendable to support new PLDM types and custom OEM commands.
- Integration: Seamlessly integrates with other OpenBMC components for comprehensive system management.
To build and run PLDM, you need the following dependencies:
MesonNinja
Alternatively, source an OpenBMC ARM/x86 SDK.
To build the PLDM project, follow these steps:
meson setup build && meson compile -C buildThe simplest way of running the tests is as described by the meson man page:
meson test -C buildAlternatively, tests can be run in the OpenBMC CI docker container using these steps.
Use Meson/Ninja coverage targets with coverage instrumentation enabled:
# 1) Configure with tests and coverage CC=gcc-13 CXX=g++-13 meson setup --wipe build -Dtests=enabled -Db_coverage=true # 2) Run tests to generate .gcda data meson test -C build --print-errorlogs # 3) Generate HTML coverage report (Meson/Ninja target) GCOV=gcov-13 ninja -C build coverage-htmlThe HTML report is generated at:
build/meson-logs/coveragereport/index.html Optional text report:
GCOV=gcov-13 ninja -C build coverage-textText report path:
build/meson-logs/coverage.txt pldm daemon accepts a command line argument --verbose or --v or -v to enable the daemon to run in verbose mode. It can be done via adding this option to the environment file that pldm service consumes.
echo 'PLDMD_ARGS="--verbose"' > /etc/default/pldmd systemctl restart pldmdrm /etc/default/pldmd systemctl restart pldmd--fw-debug is not enabled by default. You can turn it on at runtime via the service environment file and a service restart:
# Enable fw-update debug logging sudo sh -c 'echo "FWDEBUG=--fw-debug" >> /etc/default/pldm_verbosity' sudo systemctl restart pldmdTo disable it again:
sudo sed -i '/^FWDEBUG=/d' /etc/default/pldm_verbosity # Or set it empty: sudo sh -c 'echo "FWDEBUG=" >> /etc/default/pldm_verbosity' sudo systemctl restart pldmdFor complete documentation on the functionality and usage of this repository, please refer to the docs folder.