/** @file Copyright (c) 2017, Intel Corporation. All rights reserved.
SPDX-License-Identifier: BSD-2-Clause-Patent **/ #ifndef _SMM_TEST_POINT_DXE_H_ #define _SMM_TEST_POINT_DXE_H_ #include #include #include #include #include #include #include #include #include #include #define TEST_POINT_AIP_PRIVATE_SIGNATURE SIGNATURE_32('T', 'S', 'P', 'T') typedef struct { UINT32 Signature; EFI_ADAPTER_INFORMATION_PROTOCOL Aip; VOID *TestPoint; UINTN TestPointSize; UINTN TestPointMaxSize; } TEST_POINT_AIP_PRIVATE_DATA; #define TEST_POINT_AIP_PRIVATE_DATA_FROM_THIS(a) \ CR (a, \ TEST_POINT_AIP_PRIVATE_DATA, \ Aip, \ TEST_POINT_AIP_PRIVATE_SIGNATURE \ ) extern EFI_ADAPTER_INFORMATION_PROTOCOL mSmmAdapterInformationProtocol; /** Return if input TestPoint data is valid. @param TestPointData TestPoint data @param TestPointSize TestPoint size @retval TRUE TestPoint data is valid. @retval FALSE TestPoint data is not valid. **/ BOOLEAN InternalTestPointIsValidTable ( IN VOID *TestPointData, IN UINTN TestPointSize ); /** Register SMM TestPoint handler. **/ VOID RegisterSmmTestPointSmiHandler ( VOID ); #endif