REF: https://bugzilla.tianocore.org/show_bug.cgi?id=3737 Apply uncrustify changes to .c/.h files in the UefiPayloadPkg package Cc: Andrew Fish <afish@apple.com> Cc: Leif Lindholm <leif@nuviainc.com> Cc: Michael D Kinney <michael.d.kinney@intel.com> Signed-off-by: Michael Kubacki <michael.kubacki@microsoft.com> Reviewed-by: Ray Ni <ray.ni@intel.com>
		
			
				
	
	
		
			55 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			55 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /** @file
 | |
|   This file defines the SMM S3 communication hob structure.
 | |
| 
 | |
|   Copyright (c) 2021, Intel Corporation. All rights reserved.<BR>
 | |
|   SPDX-License-Identifier: BSD-2-Clause-Patent
 | |
| 
 | |
| **/
 | |
| 
 | |
| #ifndef PAYLOAD_S3_COMMUNICATION_GUID_H_
 | |
| #define PAYLOAD_S3_COMMUNICATION_GUID_H_
 | |
| 
 | |
| extern EFI_GUID  gS3CommunicationGuid;
 | |
| 
 | |
| #pragma pack(1)
 | |
| 
 | |
| typedef struct {
 | |
|   EFI_SMRAM_DESCRIPTOR    CommBuffer;
 | |
|   BOOLEAN                 PldAcpiS3Enable;
 | |
| } PLD_S3_COMMUNICATION;
 | |
| 
 | |
| ///
 | |
| /// The information below is used for communication between bootloader and payload.
 | |
| /// It is used to save/store some registers in S3 path
 | |
| ///
 | |
| /// This region exists only when gEfiAcpiVariableGuid HOB exist.
 | |
| /// when PLD_S3_INFO.PldAcpiS3Enable is false, the communication buffer is defined as below.
 | |
| ///
 | |
| 
 | |
| typedef struct {
 | |
|   UINT32    ApicId;
 | |
|   UINT32    SmmBase;
 | |
| } CPU_SMMBASE;
 | |
| 
 | |
| typedef struct {
 | |
|   UINT8          SwSmiData;
 | |
|   UINT8          SwSmiTriggerValue;
 | |
|   UINT16         Reserved;
 | |
|   UINT32         CpuCount;
 | |
|   CPU_SMMBASE    SmmBase[0];
 | |
| } SMM_S3_INFO;
 | |
| 
 | |
| //
 | |
| // Payload would save this structure to S3 communication area in normal boot.
 | |
| // In S3 path, bootloader need restore SMM base and writie IO port 0xB2 with SwSmiTriggerValue
 | |
| // to trigger SMI to let payload to restore S3.
 | |
| //
 | |
| typedef struct {
 | |
|   EFI_HOB_GUID_TYPE    Header;
 | |
|   SMM_S3_INFO          S3Info;
 | |
| } PLD_TO_BL_SMM_INFO;
 | |
| 
 | |
| #pragma pack()
 | |
| 
 | |
| #endif
 |