2020-12-17 23:35:38 +01:00
|
|
|
/** @file
|
|
|
|
Device Path services. The thing to remember is device paths are built out of
|
|
|
|
nodes. The device path is terminated by an end node that is length
|
|
|
|
sizeof(EFI_DEVICE_PATH_PROTOCOL). That would be why there is sizeof(EFI_DEVICE_PATH_PROTOCOL)
|
|
|
|
all over this file.
|
|
|
|
|
|
|
|
The only place where multi-instance device paths are supported is in
|
|
|
|
environment varibles. Multi-instance device paths should never be placed
|
|
|
|
on a Handle.
|
|
|
|
|
|
|
|
Copyright (c) 2006 - 2018, Intel Corporation. All rights reserved.<BR>
|
|
|
|
Copyright (c) Microsoft Corporation.
|
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
#include "UefiDevicePathLib.h"
|
|
|
|
|
|
|
|
/**
|
|
|
|
Retrieves the device path protocol from a handle.
|
|
|
|
|
|
|
|
This function returns the device path protocol from the handle specified by Handle.
|
|
|
|
If Handle is NULL or Handle does not contain a device path protocol, then NULL
|
|
|
|
is returned.
|
|
|
|
|
|
|
|
@param Handle The handle from which to retrieve the device
|
|
|
|
path protocol.
|
|
|
|
|
|
|
|
@return The device path protocol from the handle specified by Handle.
|
|
|
|
|
|
|
|
**/
|
|
|
|
EFI_DEVICE_PATH_PROTOCOL *
|
|
|
|
EFIAPI
|
|
|
|
DevicePathFromHandle (
|
2021-12-05 23:54:05 +01:00
|
|
|
IN EFI_HANDLE Handle
|
2020-12-17 23:35:38 +01:00
|
|
|
)
|
|
|
|
{
|
|
|
|
EFI_DEVICE_PATH_PROTOCOL *DevicePath;
|
|
|
|
EFI_STATUS Status;
|
|
|
|
|
|
|
|
Status = gBS->HandleProtocol (
|
|
|
|
Handle,
|
|
|
|
&gEfiDevicePathProtocolGuid,
|
2021-12-05 23:54:05 +01:00
|
|
|
(VOID *)&DevicePath
|
2020-12-17 23:35:38 +01:00
|
|
|
);
|
|
|
|
if (EFI_ERROR (Status)) {
|
|
|
|
DevicePath = NULL;
|
|
|
|
}
|
2021-12-05 23:54:05 +01:00
|
|
|
|
2020-12-17 23:35:38 +01:00
|
|
|
return DevicePath;
|
|
|
|
}
|