/** @file | |
Copyright (c) 2006 - 2019, Intel Corporation. All rights reserved.<BR> | |
SPDX-License-Identifier: BSD-2-Clause-Patent | |
**/ | |
#ifndef _RESET_SYSTEM_H_ | |
#define _RESET_SYSTEM_H_ | |
#include <PiDxe.h> | |
#include <Protocol/Reset.h> | |
#include <Protocol/ResetNotification.h> | |
#include <Protocol/PlatformSpecificResetFilter.h> | |
#include <Protocol/PlatformSpecificResetHandler.h> | |
#include <Guid/CapsuleVendor.h> | |
#include <Library/BaseLib.h> | |
#include <Library/DebugLib.h> | |
#include <Library/UefiLib.h> | |
#include <Library/UefiDriverEntryPoint.h> | |
#include <Library/UefiBootServicesTableLib.h> | |
#include <Library/UefiRuntimeLib.h> | |
#include <Library/UefiRuntimeServicesTableLib.h> | |
#include <Library/ResetSystemLib.h> | |
#include <Library/ReportStatusCodeLib.h> | |
#include <Library/MemoryAllocationLib.h> | |
// | |
// The maximum recurstion depth to ResetSystem() by reset notification handlers | |
// | |
#define MAX_RESET_NOTIFY_DEPTH 10 | |
typedef struct { | |
UINT32 Signature; | |
LIST_ENTRY Link; | |
EFI_RESET_SYSTEM ResetNotify; | |
} RESET_NOTIFY_ENTRY; | |
#define RESET_NOTIFY_ENTRY_SIGNATURE SIGNATURE_32('r', 's', 't', 'n') | |
#define RESET_NOTIFY_ENTRY_FROM_LINK(a) CR (a, RESET_NOTIFY_ENTRY, Link, RESET_NOTIFY_ENTRY_SIGNATURE) | |
typedef struct { | |
UINT32 Signature; | |
EFI_RESET_NOTIFICATION_PROTOCOL ResetNotification; | |
LIST_ENTRY ResetNotifies; | |
} RESET_NOTIFICATION_INSTANCE; | |
#define RESET_NOTIFICATION_INSTANCE_SIGNATURE SIGNATURE_32('r', 's', 't', 'i') | |
#define RESET_NOTIFICATION_INSTANCE_FROM_THIS(a) \ | |
CR (a, RESET_NOTIFICATION_INSTANCE, ResetNotification, RESET_NOTIFICATION_INSTANCE_SIGNATURE) | |
/** | |
The driver's entry point. | |
It initializes the Reset Architectural Protocol. | |
@param[in] ImageHandle The firmware allocated handle for the EFI image. | |
@param[in] SystemTable A pointer to the EFI System Table. | |
@retval EFI_SUCCESS The entry point is executed successfully. | |
@retval other Cannot install ResetArch protocol. | |
**/ | |
EFI_STATUS | |
EFIAPI | |
InitializeResetSystem ( | |
IN EFI_HANDLE ImageHandle, | |
IN EFI_SYSTEM_TABLE *SystemTable | |
); | |
/** | |
Resets the entire platform. | |
@param[in] ResetType The type of reset to perform. | |
@param[in] ResetStatus The status code for the reset. | |
@param[in] DataSize The size, in bytes, of ResetData. | |
@param[in] ResetData For a ResetType of EfiResetCold, EfiResetWarm, or | |
EfiResetShutdown the data buffer starts with a Null-terminated | |
string, optionally followed by additional binary data. | |
The string is a description that the caller may use to further | |
indicate the reason for the system reset. | |
For a ResetType of EfiResetPlatformSpecific the data buffer | |
also starts with a Null-terminated string that is followed | |
by an EFI_GUID that describes the specific type of reset to perform. | |
**/ | |
VOID | |
EFIAPI | |
RuntimeServiceResetSystem ( | |
IN EFI_RESET_TYPE ResetType, | |
IN EFI_STATUS ResetStatus, | |
IN UINTN DataSize, | |
IN VOID *ResetData OPTIONAL | |
); | |
#endif |