2008-03-19 10:01:03 +01:00
|
|
|
/** @file
|
2008-07-16 11:40:06 +02:00
|
|
|
Pei Core Reset System Support
|
2017-09-01 09:32:22 +02:00
|
|
|
|
2019-02-27 07:32:08 +01:00
|
|
|
Copyright (c) 2006 - 2019, Intel Corporation. All rights reserved.<BR>
|
2019-04-04 01:05:13 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2007-07-04 09:51:48 +02:00
|
|
|
|
2008-07-16 11:40:06 +02:00
|
|
|
**/
|
2007-07-04 09:51:48 +02:00
|
|
|
|
2008-10-31 05:35:02 +01:00
|
|
|
#include "PeiMain.h"
|
2007-07-04 09:51:48 +02:00
|
|
|
|
2008-07-16 11:40:06 +02:00
|
|
|
/**
|
2007-07-04 09:51:48 +02:00
|
|
|
|
2008-07-16 11:40:06 +02:00
|
|
|
Core version of the Reset System
|
2007-07-04 09:51:48 +02:00
|
|
|
|
|
|
|
|
2008-08-08 03:37:44 +02:00
|
|
|
@param PeiServices An indirect pointer to the EFI_PEI_SERVICES table published by the PEI Foundation.
|
2007-07-04 09:51:48 +02:00
|
|
|
|
2008-07-16 11:40:06 +02:00
|
|
|
@retval EFI_NOT_AVAILABLE_YET PPI not available yet.
|
|
|
|
@retval EFI_DEVICE_ERROR Did not reset system.
|
|
|
|
Otherwise, resets the system.
|
2007-07-04 09:51:48 +02:00
|
|
|
|
2008-07-16 11:40:06 +02:00
|
|
|
**/
|
2007-07-04 09:51:48 +02:00
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
PeiResetSystem (
|
2017-09-01 09:32:22 +02:00
|
|
|
IN CONST EFI_PEI_SERVICES **PeiServices
|
2007-07-04 09:51:48 +02:00
|
|
|
)
|
|
|
|
{
|
2017-09-01 09:32:22 +02:00
|
|
|
EFI_STATUS Status;
|
|
|
|
EFI_PEI_RESET_PPI *ResetPpi;
|
2007-07-04 09:51:48 +02:00
|
|
|
|
2017-09-01 09:31:03 +02:00
|
|
|
//
|
|
|
|
// Attempt to use newer ResetSystem2(). If this returns, then ResetSystem2()
|
|
|
|
// is not available.
|
|
|
|
//
|
|
|
|
PeiResetSystem2 (EfiResetCold, EFI_SUCCESS, 0, NULL);
|
2007-07-04 09:51:48 +02:00
|
|
|
|
|
|
|
//
|
2017-09-01 09:31:03 +02:00
|
|
|
// Look for PEI Reset System PPI
|
2007-07-04 09:51:48 +02:00
|
|
|
//
|
2017-09-01 09:31:03 +02:00
|
|
|
Status = PeiServicesLocatePpi (
|
|
|
|
&gEfiPeiResetPpiGuid,
|
|
|
|
0,
|
|
|
|
NULL,
|
|
|
|
(VOID **)&ResetPpi
|
|
|
|
);
|
2007-07-04 09:51:48 +02:00
|
|
|
if (!EFI_ERROR (Status)) {
|
|
|
|
return ResetPpi->ResetSystem (PeiServices);
|
2017-09-01 09:32:22 +02:00
|
|
|
}
|
|
|
|
|
2012-10-30 05:23:40 +01:00
|
|
|
//
|
2017-09-01 09:32:22 +02:00
|
|
|
// Report Status Code that Reset PPI is not available.
|
2012-10-30 05:23:40 +01:00
|
|
|
//
|
|
|
|
REPORT_STATUS_CODE (
|
|
|
|
EFI_ERROR_CODE | EFI_ERROR_MINOR,
|
|
|
|
(EFI_SOFTWARE_PEI_CORE | EFI_SW_PS_EC_RESET_NOT_AVAILABLE)
|
|
|
|
);
|
2017-09-01 09:31:03 +02:00
|
|
|
|
|
|
|
//
|
|
|
|
// No reset PPIs are available yet.
|
|
|
|
//
|
2007-07-04 09:51:48 +02:00
|
|
|
return EFI_NOT_AVAILABLE_YET;
|
|
|
|
}
|
|
|
|
|
2015-05-11 04:06:51 +02:00
|
|
|
/**
|
|
|
|
Resets the entire platform.
|
|
|
|
|
|
|
|
@param[in] ResetType The type of reset to perform.
|
|
|
|
@param[in] ResetStatus The status code for the reset.
|
2017-06-29 16:48:43 +02:00
|
|
|
@param[in] DataSize The size, in bytes, of ResetData.
|
2015-05-11 04:06:51 +02:00
|
|
|
@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
|
2019-02-27 07:32:08 +01:00
|
|
|
system reset.
|
2015-05-11 04:06:51 +02:00
|
|
|
|
|
|
|
**/
|
|
|
|
VOID
|
|
|
|
EFIAPI
|
|
|
|
PeiResetSystem2 (
|
2017-09-01 09:32:22 +02:00
|
|
|
IN EFI_RESET_TYPE ResetType,
|
|
|
|
IN EFI_STATUS ResetStatus,
|
|
|
|
IN UINTN DataSize,
|
|
|
|
IN VOID *ResetData OPTIONAL
|
2015-05-11 04:06:51 +02:00
|
|
|
)
|
|
|
|
{
|
2017-09-01 09:32:22 +02:00
|
|
|
EFI_STATUS Status;
|
|
|
|
EFI_PEI_RESET2_PPI *Reset2Ppi;
|
2015-05-11 04:06:51 +02:00
|
|
|
|
2017-09-01 09:31:03 +02:00
|
|
|
//
|
|
|
|
// Look for PEI Reset System 2 PPI
|
|
|
|
//
|
2015-05-11 04:06:51 +02:00
|
|
|
Status = PeiServicesLocatePpi (
|
|
|
|
&gEfiPeiReset2PpiGuid,
|
|
|
|
0,
|
|
|
|
NULL,
|
|
|
|
(VOID **)&Reset2Ppi
|
|
|
|
);
|
|
|
|
if (!EFI_ERROR (Status)) {
|
|
|
|
Reset2Ppi->ResetSystem (ResetType, ResetStatus, DataSize, ResetData);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
//
|
|
|
|
// Report Status Code that Reset2 PPI is not available.
|
|
|
|
//
|
|
|
|
REPORT_STATUS_CODE (
|
|
|
|
EFI_ERROR_CODE | EFI_ERROR_MINOR,
|
|
|
|
(EFI_SOFTWARE_PEI_CORE | EFI_SW_PS_EC_RESET_NOT_AVAILABLE)
|
|
|
|
);
|
|
|
|
}
|