Add documentation on extending.

Change-Id: I1065519f4bb34885ec6b52a534bf4853f8573fdb
1 file changed
tree: 8bdcf75a3427aad7b70815656bf02d8b81ade7eb
  1. cli-app/
  2. docs/
  3. edk/
  4. generator/
  5. sections/
  6. specification/
  7. tests/
  8. .clang-format
  9. .gitignore
  10. CMakeLists.txt
  11. common-utils.c
  12. common-utils.h
  13. cper-parse.c
  14. cper-parse.h
  15. cper-parse.i
  16. cper-utils.c
  17. cper-utils.h
  18. ir-parse.c
  19. json-schema.c
  20. json-schema.h
  21. LICENSE
  22. README.md
README.md

CPER JSON Representation & Conversion Library

This repository specifies a structure for representing UEFI CPER records (as described in UEFI Specification Appendix N) in a human-readable JSON format, in addition to a library which can readily convert back and forth between the standard CPER binary format and the specified structured JSON.

Prerequisites

Before building this library and its associated tools, you must have CMake (>=3.10) and SWIG installed, with the following CMake modules available:

  • FetchContent
  • GoogleTest
  • FindSWIG
  • UseSWIG

If you are building the Python bindings, you should also have Python3 and associated libraries installed for the purposes of building the Python bindings.

Building

This project uses CMake (>=3.10). To build for native architecture, simply run:

cmake .
make

A static library file for the parsing library will be written to lib/, and test executables will be written to bin/. To build the Python bindings in addition to all C libraries, add the argument -DBUILD_PYTHON_LIBS to your cmake command.

Cross Compilation

To cross compile for ARM/AArch64 architecture from x86, instead use the below commands (ensure cmake clean . beforehand). You will need either the arm-linux-gnueabi or aarch64-linux-gnu toolchain installed.

cmake -DCMAKE_TOOLCHAIN_FILE="toolchains/arm-toolchain.cmake" -S. -Bbin # arm-linux-gnueabi
cmake -DCMAKE_TOOLCHAIN_FILE="toolchains/aarch64-toolchain.cmake" -S. -Bbin # aarch64-linux-gnu
make

Usage

This project comes with several binaries to help you deal with CPER binary and CPER-JSON. The first of these is cper-convert, which is a command line tool that can be found in bin/. With this, you can convert to and from CPER and CPER-JSON through the command line. An example usage scenario is below:

cper-convert to-cper samples/cper-json-test-arm.json --out cper.dump
cper-convert to-json cper.generated.dump

Another tool bundled with this repository is cper-generate, found in bin/. This allows you to generate pseudo-random valid CPER records with sections of specified types for testing purposes. An example use of the program is below:

cper-generate --out cper.generated.dump --sections generic ia32x64

Help for both of these tools can be accessed through using the --help flag in isolation.

Finally, a static library containing symbols for converting CPER and CPER-JSON between an intermediate JSON format can be found generated at lib/libcper-parse.a. This contains the following useful library symbols:

json_object* cper_to_ir(FILE* cper_file);
void ir_to_cper(json_object* ir, FILE* out);

This library also has Python bindings generated on build, which are placed at lib/cperparse.py. The static library _cperparse_pylib.a (as well as the C file cper-parsePYTHON_wrap.c) are generated specifically for the purpose of wrapping types for the Python library, and should not be used as a standard static C library.

Specification

The specification for this project's CPER-JSON format can be found in specification/, defined in both JSON Schema format and also as a LaTeX document. Specification for the CPER binary format can be found in UEFI Specification Appendix N (2021/03/18).

Usage Examples

This library is utilised in a proof of concept displaying CPER communication between a SatMC and OpenBMC board, including a conversion into CPER JSON for logging that utilises this library. You can find information on how to reproduce the prototype at the scripts repository, and example usage of the library itself at the pldm repository.