https://svn.code.sf.net/p/edk2/code/trunk/edk2/, which are for MinnowBoard MAX open source project. Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: David Wei <david.wei@intel.com> Reviewed-by: Mike Wu <mike.wu@intel.com> Reviewed-by: Hot Tian <hot.tian@intel.com> git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@16599 6f19259b-4bc3-4df7-8a09-765794883524
		
			
				
	
	
		
			139 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			139 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/**
 | 
						|
**/
 | 
						|
/**
 | 
						|
 | 
						|
Copyright (c) 2012  - 2014, Intel Corporation. All rights reserved
 | 
						|
 | 
						|
  This program and the accompanying materials are licensed and made available under
 | 
						|
  the terms and conditions of the BSD License that accompanies this distribution.
 | 
						|
  The full text of the license may be found at
 | 
						|
  http://opensource.org/licenses/bsd-license.php.
 | 
						|
 | 
						|
  THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
 | 
						|
  WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
 | 
						|
 | 
						|
 | 
						|
 | 
						|
  @file
 | 
						|
  PchS3Support.h
 | 
						|
 | 
						|
  @brief
 | 
						|
  This file defines the PCH S3 support Protocol.
 | 
						|
 | 
						|
**/
 | 
						|
#ifndef _PCH_S3_SUPPORT_PROTOCOL_H_
 | 
						|
#define _PCH_S3_SUPPORT_PROTOCOL_H_
 | 
						|
 | 
						|
#ifndef ECP_FLAG
 | 
						|
#include <Pi/PiS3BootScript.h>
 | 
						|
#endif
 | 
						|
 | 
						|
#define EFI_PCH_S3_SUPPORT_PROTOCOL_GUID \
 | 
						|
  { \
 | 
						|
    0xe287d20b, 0xd897, 0x4e1e, 0xa5, 0xd9, 0x97, 0x77, 0x63, 0x93, 0x6a, 0x4 \
 | 
						|
  }
 | 
						|
 | 
						|
#include <Protocol/PchPlatformPolicy.h>
 | 
						|
 | 
						|
///
 | 
						|
/// Extern the GUID for protocol users.
 | 
						|
///
 | 
						|
extern EFI_GUID                             gEfiPchS3SupportProtocolGuid;
 | 
						|
 | 
						|
///
 | 
						|
/// Forward reference for ANSI C compatibility
 | 
						|
///
 | 
						|
typedef struct _EFI_PCH_S3_SUPPORT_PROTOCOL EFI_PCH_S3_SUPPORT_PROTOCOL;
 | 
						|
 | 
						|
typedef enum {
 | 
						|
  PchS3ItemTypeSendCodecCommand,
 | 
						|
  PchS3ItemTypePollStatus,
 | 
						|
  PchS3ItemTypeInitPcieRootPortDownstream,
 | 
						|
  PchS3ItemTypePcieSetPm,
 | 
						|
  PchS3ItemTypePmTimerStall,
 | 
						|
  PchS3ItemTypeMax
 | 
						|
} EFI_PCH_S3_DISPATCH_ITEM_TYPE;
 | 
						|
 | 
						|
///
 | 
						|
/// It's better not to use pointer here because the size of pointer in DXE is 8, but it's 4 in PEI
 | 
						|
/// plug 4 to ParameterSize in PEIM if you really need it
 | 
						|
///
 | 
						|
typedef struct {
 | 
						|
  UINT32                        HdaBar;
 | 
						|
  UINT32                        CodecCmdData;
 | 
						|
} EFI_PCH_S3_PARAMETER_SEND_CODEC_COMMAND;
 | 
						|
 | 
						|
typedef struct {
 | 
						|
  UINT64                        MmioAddress;
 | 
						|
  EFI_BOOT_SCRIPT_WIDTH         Width;
 | 
						|
  UINT64                        Mask;
 | 
						|
  UINT64                        Value;
 | 
						|
  UINT32                        Timeout;  // us
 | 
						|
} EFI_PCH_S3_PARAMETER_POLL_STATUS;
 | 
						|
 | 
						|
typedef struct {
 | 
						|
  UINT8                         RootPortBus;
 | 
						|
  UINT8                         RootPortDevice;
 | 
						|
  UINT8                         RootPortFunc;
 | 
						|
  UINT8                         TempBusNumberMin;
 | 
						|
  UINT8                         TempBusNumberMax;
 | 
						|
} EFI_PCH_S3_PARAMETER_INIT_PCIE_ROOT_PORT_DOWNSTREAM;
 | 
						|
 | 
						|
typedef struct {
 | 
						|
  UINT8                         RootPortBus;
 | 
						|
  UINT8                         RootPortDevice;
 | 
						|
  UINT8                         RootPortFunc;
 | 
						|
  PCH_PCI_EXPRESS_ASPM_CONTROL  RootPortAspm;
 | 
						|
  UINT8                         NumOfDevAspmOverride;
 | 
						|
  UINT32                        DevAspmOverrideAddr;
 | 
						|
  UINT8                         TempBusNumberMin;
 | 
						|
  UINT8                         TempBusNumberMax;
 | 
						|
  UINT8                         NumOfDevLtrOverride;
 | 
						|
  UINT32                        DevLtrOverrideAddr;
 | 
						|
} EFI_PCH_S3_PARAMETER_PCIE_SET_PM;
 | 
						|
 | 
						|
typedef struct {
 | 
						|
  UINT32                        DelayTime;  // us
 | 
						|
} EFI_PCH_S3_PARAMETER_PM_TIMER_STALL;
 | 
						|
 | 
						|
typedef struct {
 | 
						|
  EFI_PCH_S3_DISPATCH_ITEM_TYPE Type;
 | 
						|
  VOID                          *Parameter;
 | 
						|
} EFI_PCH_S3_DISPATCH_ITEM;
 | 
						|
 | 
						|
///
 | 
						|
/// Member functions
 | 
						|
///
 | 
						|
typedef
 | 
						|
EFI_STATUS
 | 
						|
(EFIAPI *EFI_PCH_S3_SUPPORT_SET_S3_DISPATCH_ITEM) (
 | 
						|
  IN     EFI_PCH_S3_SUPPORT_PROTOCOL   * This,
 | 
						|
  IN     EFI_PCH_S3_DISPATCH_ITEM      * DispatchItem,
 | 
						|
  OUT    EFI_PHYSICAL_ADDRESS          * S3DispatchEntryPoint
 | 
						|
  );
 | 
						|
 | 
						|
/**
 | 
						|
 | 
						|
  @brief
 | 
						|
  Set an item to be dispatched at S3 resume time. At the same time, the entry point
 | 
						|
  of the PCH S3 support image is returned to be used in subsequent boot script save
 | 
						|
  call
 | 
						|
 | 
						|
  @param[in] This                 Pointer to the protocol instance.
 | 
						|
  @param[in] DispatchItem         The item to be dispatched.
 | 
						|
  @param[in] S3DispatchEntryPoint The entry point of the PCH S3 support image.
 | 
						|
 | 
						|
  @retval EFI_STATUS              Successfully completed.
 | 
						|
  @retval EFI_OUT_OF_RESOURCES    Out of resources.
 | 
						|
 | 
						|
**/
 | 
						|
 | 
						|
///
 | 
						|
/// Protocol definition
 | 
						|
///
 | 
						|
struct _EFI_PCH_S3_SUPPORT_PROTOCOL {
 | 
						|
  EFI_PCH_S3_SUPPORT_SET_S3_DISPATCH_ITEM SetDispatchItem;
 | 
						|
};
 | 
						|
 | 
						|
#endif
 |