mirror of https://github.com/acidanthera/audk.git
85 lines
2.3 KiB
C
85 lines
2.3 KiB
C
|
/** @file -- VariablePolicyExtraInitRuntimeDxe.c
|
||
|
This file contains extra init and deinit routines that register and unregister
|
||
|
VariableAddressChange callbacks.
|
||
|
|
||
|
Copyright (c) Microsoft Corporation.
|
||
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
||
|
|
||
|
**/
|
||
|
|
||
|
#include <Library/UefiBootServicesTableLib.h>
|
||
|
#include <Library/UefiRuntimeServicesTableLib.h>
|
||
|
|
||
|
extern EFI_GET_VARIABLE mGetVariableHelper;
|
||
|
extern UINT8 *mPolicyTable;
|
||
|
STATIC BOOLEAN mIsVirtualAddrConverted;
|
||
|
STATIC EFI_EVENT mVariablePolicyLibVirtualAddressChangeEvent = NULL;
|
||
|
|
||
|
/**
|
||
|
For the RuntimeDxe version of this lib, convert internal pointer addresses to virtual addresses.
|
||
|
|
||
|
@param[in] Event Event whose notification function is being invoked.
|
||
|
@param[in] Context The pointer to the notification function's context, which
|
||
|
is implementation-dependent.
|
||
|
**/
|
||
|
STATIC
|
||
|
VOID
|
||
|
EFIAPI
|
||
|
VariablePolicyLibVirtualAddressCallback (
|
||
|
IN EFI_EVENT Event,
|
||
|
IN VOID *Context
|
||
|
)
|
||
|
{
|
||
|
gRT->ConvertPointer (0, (VOID **)&mPolicyTable);
|
||
|
gRT->ConvertPointer (0, (VOID **)&mGetVariableHelper);
|
||
|
mIsVirtualAddrConverted = TRUE;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
An extra init hook that enables the RuntimeDxe library instance to
|
||
|
register VirtualAddress change callbacks. Among other things.
|
||
|
|
||
|
@retval EFI_SUCCESS Everything is good. Continue with init.
|
||
|
@retval Others Uh... don't continue.
|
||
|
|
||
|
**/
|
||
|
EFI_STATUS
|
||
|
VariablePolicyExtraInit (
|
||
|
VOID
|
||
|
)
|
||
|
{
|
||
|
return gBS->CreateEventEx (
|
||
|
EVT_NOTIFY_SIGNAL,
|
||
|
TPL_NOTIFY,
|
||
|
VariablePolicyLibVirtualAddressCallback,
|
||
|
NULL,
|
||
|
&gEfiEventVirtualAddressChangeGuid,
|
||
|
&mVariablePolicyLibVirtualAddressChangeEvent
|
||
|
);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
An extra deinit hook that enables the RuntimeDxe library instance to
|
||
|
register VirtualAddress change callbacks. Among other things.
|
||
|
|
||
|
@retval EFI_SUCCESS Everything is good. Continue with deinit.
|
||
|
@retval Others Uh... don't continue.
|
||
|
|
||
|
**/
|
||
|
EFI_STATUS
|
||
|
VariablePolicyExtraDeinit (
|
||
|
VOID
|
||
|
)
|
||
|
{
|
||
|
EFI_STATUS Status;
|
||
|
|
||
|
Status = EFI_SUCCESS;
|
||
|
if (mIsVirtualAddrConverted) {
|
||
|
Status = gBS->CloseEvent (mVariablePolicyLibVirtualAddressChangeEvent);
|
||
|
} else {
|
||
|
Status = EFI_SUCCESS;
|
||
|
}
|
||
|
|
||
|
return Status;
|
||
|
}
|