2021-09-30 09:48:17 +02:00
|
|
|
/** @file
|
|
|
|
Configuration Manager Object parser.
|
|
|
|
|
|
|
|
Copyright (c) 2021, ARM Limited. All rights reserved.<BR>
|
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
#ifndef CONFIGURATION_MANAGER_OBJECT_PARSER_H_
|
|
|
|
#define CONFIGURATION_MANAGER_OBJECT_PARSER_H_
|
|
|
|
|
2021-12-05 23:53:55 +01:00
|
|
|
#define OUTPUT_FIELD_COLUMN_WIDTH 32
|
2021-09-30 09:48:17 +02:00
|
|
|
|
|
|
|
/** Function prototype to format a field print.
|
|
|
|
|
|
|
|
@param [in] Format Format string for tracing the data as specified by
|
|
|
|
the 'Format' member of ACPI_PARSER.
|
|
|
|
@param [in] Ptr Pointer to the start of the buffer.
|
|
|
|
**/
|
2021-12-05 23:53:55 +01:00
|
|
|
typedef VOID (EFIAPI *FNPTR_PRINT_FORMATTER)(CONST CHAR8 *Format, UINT8 *Ptr);
|
2021-09-30 09:48:17 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
The CM_OBJ_PARSER structure describes the fields of an CmObject and
|
|
|
|
provides means for the parser to interpret and trace appropriately.
|
|
|
|
|
|
|
|
ParseAcpi() uses the format string specified by 'Format' for tracing
|
|
|
|
the field data.
|
|
|
|
*/
|
|
|
|
typedef struct CmObjParser CM_OBJ_PARSER;
|
|
|
|
struct CmObjParser {
|
|
|
|
/// String describing the Cm Object
|
2021-12-05 23:53:55 +01:00
|
|
|
CONST CHAR8 *NameStr;
|
2021-09-30 09:48:17 +02:00
|
|
|
|
|
|
|
/// The length of the field.
|
2021-12-05 23:53:55 +01:00
|
|
|
UINT32 Length;
|
2021-09-30 09:48:17 +02:00
|
|
|
|
|
|
|
/// Optional Print() style format string for tracing the data. If not
|
|
|
|
/// used this must be set to NULL.
|
2021-12-05 23:53:55 +01:00
|
|
|
CONST CHAR8 *Format;
|
2021-09-30 09:48:17 +02:00
|
|
|
|
|
|
|
/// Optional pointer to a print formatter function which
|
|
|
|
/// is typically used to trace complex field information.
|
|
|
|
/// If not used this must be set to NULL.
|
|
|
|
/// The Format string is passed to the PrintFormatter function
|
|
|
|
/// but may be ignored by the implementation code.
|
2021-12-05 23:53:55 +01:00
|
|
|
FNPTR_PRINT_FORMATTER PrintFormatter;
|
2021-09-30 09:48:17 +02:00
|
|
|
|
|
|
|
/// Optional pointer to print the fields of another CM_OBJ_PARSER
|
|
|
|
/// structure. This is useful to print sub-structures.
|
2021-12-05 23:53:55 +01:00
|
|
|
CONST CM_OBJ_PARSER *SubObjParser;
|
2021-09-30 09:48:17 +02:00
|
|
|
|
|
|
|
/// Count of items in the SubObj.
|
2021-12-05 23:53:55 +01:00
|
|
|
UINTN SubObjItemCount;
|
2021-09-30 09:48:17 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
A structure mapping an array of Configuration Manager Object parsers
|
|
|
|
with their object names.
|
|
|
|
*/
|
|
|
|
typedef struct CmObjParserArray {
|
|
|
|
/// Object name
|
2021-12-05 23:53:55 +01:00
|
|
|
CONST CHAR8 *ObjectName;
|
2021-09-30 09:48:17 +02:00
|
|
|
|
|
|
|
/// Function pointer to the parser
|
2021-12-05 23:53:55 +01:00
|
|
|
CONST CM_OBJ_PARSER *Parser;
|
2021-09-30 09:48:17 +02:00
|
|
|
|
|
|
|
/// Count of items
|
2021-12-05 23:53:55 +01:00
|
|
|
UINTN ItemCount;
|
2021-09-30 09:48:17 +02:00
|
|
|
} CM_OBJ_PARSER_ARRAY;
|
|
|
|
|
|
|
|
#endif // CONFIGURATION_MANAGER_OBJECT_PARSER_H_
|