utils: add pldm_fwup_pkg_parser.py It is a script generated by Gemini to reverse the pack process done by pldm_fwup_pkg_creator.py. It's helpful to extract the meta data out from a PLDM firmware package from vendor and perform modification and repackage if necessary. Tested: extract the metadata.json and component bin, repack with pldm_fwup_pkg_creator.py, tested PLDM type5 download with the re-packed firmware package. Usage: ./pldm_fwup_pkg_parser.py pldm-fw-package.fwpkg -o extract Found 1 components. Header parsed successfully. Final Offset: 161 Extracting 1 component images... Extracted: extract/component_0_1.bin (Size: 9395200 bytes) Metadata written to: extract/metadata.json Change-Id: Ibb05cbe351d428ee30353578ff495257f36a371e Signed-off-by: Jinliang Wang <jinliangw@google.com>
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.
To build and run PLDM, you need the following dependencies:
MesonNinjaAlternatively, source an OpenBMC ARM/x86 SDK.
To build the PLDM project, follow these steps:
meson setup build && meson compile -C build
The simplest way of running the tests is as described by the meson man page:
meson test -C build
Alternatively, tests can be run in the OpenBMC CI docker container using these steps.
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 pldmd
rm /etc/default/pldmd systemctl restart pldmd
For complete documentation on the functionality and usage of this repository, please refer to the docs folder.