2015-11-23 10:34:55 +01:00
|
|
|
/** @file
|
|
|
|
Utility routines used by boot maintenance modules.
|
|
|
|
|
2018-06-27 15:08:52 +02:00
|
|
|
Copyright (c) 2004 - 2018, Intel Corporation. All rights reserved.<BR>
|
2019-04-04 01:05:13 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2015-11-23 10:34:55 +01:00
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
#include "BootMaintenanceManager.h"
|
|
|
|
|
|
|
|
/**
|
|
|
|
Function deletes the variable specified by VarName and VarGuid.
|
|
|
|
|
|
|
|
@param VarName A Null-terminated Unicode string that is
|
|
|
|
the name of the vendor's variable.
|
|
|
|
|
|
|
|
@param VarGuid A unique identifier for the vendor.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS The variable was found and removed
|
|
|
|
@retval EFI_UNSUPPORTED The variable store was inaccessible
|
|
|
|
@retval EFI_NOT_FOUND The variable was not found
|
|
|
|
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
EfiLibDeleteVariable (
|
|
|
|
IN CHAR16 *VarName,
|
|
|
|
IN EFI_GUID *VarGuid
|
|
|
|
)
|
|
|
|
{
|
|
|
|
return gRT->SetVariable (
|
|
|
|
VarName,
|
|
|
|
VarGuid,
|
|
|
|
0,
|
|
|
|
0,
|
|
|
|
NULL
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Function is used to determine the number of device path instances
|
|
|
|
that exist in a device path.
|
|
|
|
|
|
|
|
|
|
|
|
@param DevicePath A pointer to a device path data structure.
|
|
|
|
|
|
|
|
@return This function counts and returns the number of device path instances
|
|
|
|
in DevicePath.
|
|
|
|
|
|
|
|
**/
|
|
|
|
UINTN
|
|
|
|
EfiDevicePathInstanceCount (
|
|
|
|
IN EFI_DEVICE_PATH_PROTOCOL *DevicePath
|
|
|
|
)
|
|
|
|
{
|
|
|
|
UINTN Count;
|
|
|
|
UINTN Size;
|
|
|
|
|
|
|
|
Count = 0;
|
|
|
|
while (GetNextDevicePathInstance (&DevicePath, &Size) != NULL) {
|
|
|
|
Count += 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
return Count;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2018-06-27 15:08:52 +02:00
|
|
|
Get a string from the Data Hub record based on
|
2015-11-23 10:34:55 +01:00
|
|
|
a device path.
|
|
|
|
|
|
|
|
@param DevPath The device Path.
|
|
|
|
|
|
|
|
@return A string located from the Data Hub records based on
|
|
|
|
the device path.
|
|
|
|
@retval NULL If failed to get the String from Data Hub.
|
|
|
|
|
|
|
|
**/
|
|
|
|
UINT16 *
|
|
|
|
EfiLibStrFromDatahub (
|
|
|
|
IN EFI_DEVICE_PATH_PROTOCOL *DevPath
|
|
|
|
)
|
|
|
|
{
|
|
|
|
return NULL;
|
|
|
|
}
|