Skip to content

Latest commit

 

History

History
88 lines (60 loc) · 5.4 KB

README.md

File metadata and controls

88 lines (60 loc) · 5.4 KB

Contributing

This project welcomes contributions and suggestions. Most contributions require you to agree to a Contributor License Agreement (CLA) declaring that you have the right to, and actually do, grant us the rights to use your contribution. For details, visit https://cla.opensource.microsoft.com.

When you submit a pull request, a CLA bot will automatically determine whether you need to provide a CLA and decorate the PR appropriately (e.g., status check, comment). Simply follow the instructions provided by the bot. You will only need to do this once across all repos using our CLA.

This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact [email protected] with any additional questions or comments.

Trademarks

This project may contain trademarks or logos for projects, products, or services. Authorized use of Microsoft trademarks or logos is subject to and must follow Microsoft's Trademark & Brand Guidelines. Use of Microsoft trademarks or logos in modified versions of this project must not cause confusion or imply Microsoft sponsorship. Any use of third-party trademarks or logos are subject to those third-party's policies.

PLDM Firmware Packager

This tool provides provides means to unpack a PLDM bundle image into the respective component image (bin) files and the PLDM header file. The tool can also repack the components and the PLDM header file into a PLDM bundle file. In addition the tool supports corrupting the components and header images prior to packaging them into a PLDM bundle file.

The pldm_spec.json file acts as the spec reference. Any changes in spec will need this file to be respectively changed.

The code is sensitive to the following rules i) Every field has a "length" and "data_type" attribute that the code looks for. ii) You could have a repeated section by using the "count" field - means that the bytstream has to be repeat-decoded for everything underneath the "count" attribute (if found).
iii) The "count" and "length" fields can be indirect references of other fields or a calculation/expression of two fields with an operator inbetween. iv) The "data type" decode types are limited - check for supported data types - hex, int, string, bytes, timestamp, ASCII, utf-8, utf-16, utf-16le, utf-16be & finally special_decode. v) The "data type" could also have a variable decode, in which case the "decode" field needs to be added.

Refer the pldm_spec.json file for examples of these rules.

To build an executable using PyInstaller, run the below command line.

python -m pip install PyInstaller python -m PyInstaller --add-data "spec/pldm_spec.json;spec" --collect-submodules python --collect-submodules spec --collect-submodules invoker invoker/pldm.py

And then use the pldm.exe under dist/pldm folder to use the tool in the below ways. Alternatively you can replace pldm.exe with "python invoker\pldm.py" and run with the same options

Getting Started with the executable

  1. To unpack a firmware bundle (.fwpkg file) Copy the fwpkg file to any workspace folder and run

    pldm.exe -F workspace<name of bundle file>.fwpkg -N unpack

    If the package is PLDM compliant, this will create an "unpack" folder within the workspace folder and generate
    i) component image files (as ComponentIdentifier_ComponentVersionString.bin) ii) header.json file (PLDM Header file)

  2. To repack a firmware bundle If not available, point to the unpack folder which contains the component image files (.bin) and header.json file (populated) and run

    pldm.exe -F workspace\unpack -N repack

    If the components and header are PLDM compliant, then it would create a "repack" folder, with the PLDM bundle image (repacked_data.fwpkg)

  3. To inject error, point to the If not available, point to the unpack folder which contains the component image files and header.json files and run

    pldm.exe -F workspace\repack\repacked_data.fwpkg -E descriptor OR pldm.exe -F workspace\repack\repacked_data.fwpkg -E UUID OR pldm.exe -F workspace\repack\repacked_data.fwpkg -E image OR pldm.exe -F workspace\repack\repacked_data.fwpkg -E signkey OR pldm.exe -F workspace\repack\repacked_data.fwpkg -E largefile

    In each of the cases above, a new folder gets created inside workspace with the new set of unpacked and repacked fwpkg file.

  4. To unpack and repack a firmware bundle (.fwpkg file) - you might want to check if the two firmware packages are identical, Copy the fwpkg file to any workspace folder and run

    pldm.exe -F workspace<name of bundle file>.fwpkg

    If the package is PLDM compliant, this will create an "unpack" folder within the workspace folder and generate i) unpack folder - houses the component images and pldm header.json file. ii) repack folder - houses the rebuilt image from the unpack folder components.

TODO

  1. Error injection is very component specific (like a specific component can have its UUID corrupted). Need to make this random isntead.
  2. The original goal of this code was meant to be spec independent. Any spec should have been able to use the unpack code to decode the spec defined byte stream. However we have some hardcodings still. Check the code to find spec field names added.