2021-09-30 09:48:12 +02:00
|
|
|
/** @file
|
|
|
|
|
|
|
|
Copyright (c) 2017 - 2021, Arm Limited. All rights reserved.<BR>
|
|
|
|
|
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
|
|
|
**/
|
|
|
|
|
|
|
|
#ifndef ACPI_HELPER_LIB_H_
|
|
|
|
#define ACPI_HELPER_LIB_H_
|
|
|
|
|
|
|
|
/** Is a character upper case
|
|
|
|
*/
|
2021-12-05 23:53:55 +01:00
|
|
|
#define IS_UPPER_CHAR(x) ((x >= 'A') && (x <= 'Z'))
|
2021-09-30 09:48:12 +02:00
|
|
|
|
|
|
|
/** Is a character a decimal digit
|
|
|
|
*/
|
2021-12-05 23:53:55 +01:00
|
|
|
#define IS_DIGIT(x) ((x >= '0') && (x <= '9'))
|
2021-09-30 09:48:12 +02:00
|
|
|
|
|
|
|
/** Is a character an upper case hexadecimal digit
|
|
|
|
*/
|
2021-12-05 23:53:55 +01:00
|
|
|
#define IS_UPPER_HEX(x) (((x >= 'A') && (x <= 'F')) || IS_DIGIT (x))
|
2021-09-30 09:48:12 +02:00
|
|
|
|
|
|
|
/** Convert a hex number to its ASCII code.
|
|
|
|
|
2021-09-30 09:48:14 +02:00
|
|
|
@param [in] Hex Hex number to convert.
|
|
|
|
Must be 0 <= x < 16.
|
2021-09-30 09:48:12 +02:00
|
|
|
|
|
|
|
@return The ASCII code corresponding to x.
|
2021-09-30 09:48:14 +02:00
|
|
|
-1 if error.
|
2021-09-30 09:48:12 +02:00
|
|
|
**/
|
|
|
|
UINT8
|
|
|
|
EFIAPI
|
|
|
|
AsciiFromHex (
|
2021-12-05 23:53:55 +01:00
|
|
|
IN UINT8 Hex
|
2021-09-30 09:48:12 +02:00
|
|
|
);
|
|
|
|
|
2021-09-30 09:48:15 +02:00
|
|
|
/** Convert an ASCII char representing an hexadecimal number
|
|
|
|
to its integer value.
|
|
|
|
|
|
|
|
@param [in] Char Char to convert.
|
|
|
|
Must be between '0'-'9' or 'A'-'F' or 'a'-'f'.
|
|
|
|
|
|
|
|
@return The corresponding integer (between 0-16).
|
|
|
|
-1 if error.
|
|
|
|
**/
|
|
|
|
UINT8
|
|
|
|
EFIAPI
|
|
|
|
HexFromAscii (
|
2021-12-05 23:53:55 +01:00
|
|
|
IN CHAR8 Char
|
2021-09-30 09:48:15 +02:00
|
|
|
);
|
|
|
|
|
2021-09-30 09:48:12 +02:00
|
|
|
/** Check if a HID is a valid PNP ID.
|
|
|
|
|
|
|
|
@param [in] Hid The Hid to validate.
|
|
|
|
|
|
|
|
@retval TRUE The Hid is a valid PNP ID.
|
|
|
|
@retval FALSE The Hid is not a valid PNP ID.
|
|
|
|
**/
|
|
|
|
BOOLEAN
|
|
|
|
IsValidPnpId (
|
2021-12-05 23:53:55 +01:00
|
|
|
IN CONST CHAR8 *Hid
|
2021-09-30 09:48:12 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
/** Check if a HID is a valid ACPI ID.
|
|
|
|
|
|
|
|
@param [in] Hid The Hid to validate.
|
|
|
|
|
|
|
|
@retval TRUE The Hid is a valid ACPI ID.
|
|
|
|
@retval FALSE The Hid is not a valid ACPI ID.
|
|
|
|
**/
|
|
|
|
BOOLEAN
|
|
|
|
IsValidAcpiId (
|
2021-12-05 23:53:55 +01:00
|
|
|
IN CONST CHAR8 *Hid
|
2021-09-30 09:48:12 +02:00
|
|
|
);
|
|
|
|
|
2021-09-30 09:48:16 +02:00
|
|
|
/** Convert a EisaId string to its compressed UINT32 equivalent.
|
|
|
|
|
|
|
|
Cf. ACPI 6.4 specification, s19.3.4 "ASL Macros": "Eisaid"
|
|
|
|
|
|
|
|
@param [in] EisaIdStr Input EisaId string.
|
|
|
|
@param [out] EisaIdInt Output EisaId UINT32 (compressed).
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS The function completed successfully.
|
|
|
|
@retval EFI_INVALID_PARAMETER Invalid parameter.
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
AmlGetEisaIdFromString (
|
2021-12-05 23:53:55 +01:00
|
|
|
IN CONST CHAR8 *EisaIdStr,
|
|
|
|
OUT UINT32 *EisaIdInt
|
2021-09-30 09:48:16 +02:00
|
|
|
);
|
|
|
|
|
2021-09-30 09:48:12 +02:00
|
|
|
#endif // ACPI_HELPER_LIB_H_
|