cper-generator
With OEM SectionsMuch like cper-parse
, cper-generator
supports the addition of arbitrary OEM sections as extensions. This document details how an OEM section generator could be added to the cper-generate
project from a stock version.
The first step is to create the generator itself. To do this, you should create a function predefinition inside sections/gen-section.h
as shown below, and then create a C file within sections/
to house your generation code. For the sake of example, we will create a generator for a fake OEM section "myVendorSection".
sections/gen-section.h:
//Section generator function predefinitions. ... size_t generate_section_cxl_protocol(void** location); size_t generate_section_cxl_component(void** location); size_t generate_section_myvendor(void** location);
sections/gen-myvendor.c:
/** * Functions for generating pseudo-random MyVendor error sections. * * Author: author@example.com **/ #include <stdlib.h> size_t generate_section_myvendor(void** location) { //... }
To identify our section for parsing, we must define a section GUID within edk/Cper.h
and edk/Cper.c
respectively. This is the same step taken when adding an OEM extension to cper-parse
, so if you've already done this, you do not need to repeat it again.
edk/Cper.h:
... extern EFI_GUID gEfiCxlVirtualSwitchErrorSectionGuid; extern EFI_GUID gEfiCxlMldPortErrorSectionGuid; extern EFI_GUID gMyVendorSectionGuid;
edk/Cper.c:
... EFI_GUID gEfiCxlVirtualSwitchErrorSectionGuid = { 0x40d26425, 0x3396, 0x4c4d, { 0xa5, 0xda, 0x3d, 0x47, 0x26, 0x3a, 0xf4, 0x25 }}; EFI_GUID gEfiCxlMldPortErrorSectionGuid = { 0x8dc44363, 0x0c96, 0x4710, { 0xb7, 0xbf, 0x04, 0xbb, 0x99, 0x53, 0x4c, 0x3f }}; EFI_GUID gMyVendorSectionGuid = { 0x40d26425, 0x3396, 0x4c4d, { 0xa5, 0xda, 0x3d, 0x47, 0x26, 0x3a, 0xf4, 0x25 }};
Now that a GUID and generation function are created for our section, we can finally add it to the generator definitions for cper-generate
. To do this, edit sections/gen-section.c
and add your generator definition to the generator_definitions
array. The second string parameter here is the shortcode used for generating your section, and must contain no spaces (this is also asserted via. GTest).
/** * Describes available section generators to the CPER generator. * * Author: Lawrence.Tang@arm.com **/ #include "gen-section.h" CPER_GENERATOR_DEFINITION generator_definitions[] = { ... {&gEfiCxlVirtualSwitchErrorSectionGuid, "cxlcomponent-vswitch", generate_section_cxl_component}, {&gEfiCxlMldPortErrorSectionGuid, "cxlcomponent-mld", generate_section_cxl_component}, {&gMyVendorSectionGuid, "myvendor", generate_section_myvendor}, };
Once this is complete, after a cmake .
and make
, your section should be available to generate through cper-generate
and libcper-generate
.