2015-12-15 20:22:23 +01:00
|
|
|
/** @file
|
|
|
|
Header file for QNC S3 Support driver
|
|
|
|
|
|
|
|
This file includes package header files, library classes and protocol, PPI & GUID definitions.
|
|
|
|
|
|
|
|
Copyright (c) 2013-2015 Intel Corporation.
|
|
|
|
|
2019-04-04 01:06:47 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2015-12-15 20:22:23 +01:00
|
|
|
**/
|
|
|
|
|
|
|
|
#ifndef _QNC_S3_SUPPORT_H_
|
|
|
|
#define _QNC_S3_SUPPORT_H_
|
|
|
|
|
|
|
|
//
|
|
|
|
// External include files do NOT need to be explicitly specified in real EDKII
|
|
|
|
// environment
|
|
|
|
//
|
|
|
|
//
|
|
|
|
// Driver Consumed Protocol Prototypes
|
|
|
|
//
|
|
|
|
#include <Protocol/FirmwareVolume2.h>
|
|
|
|
#include <Library/UefiLib.h>
|
|
|
|
#include <Library/IoLib.h>
|
|
|
|
#include <Library/DebugLib.h>
|
|
|
|
#include <Library/DxeServicesLib.h>
|
|
|
|
#include <Library/S3BootScriptLib.h>
|
|
|
|
#include <Library/BaseMemoryLib.h>
|
|
|
|
#include <Library/PeCoffLib.h>
|
|
|
|
#include <Library/LockBoxLib.h>
|
|
|
|
#include <Library/UefiDriverEntryPoint.h>
|
|
|
|
#include <Library/UefiBootServicesTableLib.h>
|
|
|
|
#include <Library/UefiRuntimeServicesTableLib.h>
|
|
|
|
//
|
|
|
|
// Driver Produced Protocol Prototypes
|
|
|
|
//
|
|
|
|
#include <Protocol/LoadedImage.h>
|
|
|
|
#include <Protocol/QncS3Support.h>
|
|
|
|
|
|
|
|
#include <Library/CacheMaintenanceLib.h>
|
|
|
|
#include <Library/IntelQNCLib.h>
|
|
|
|
//
|
|
|
|
// Define the header of the context region.
|
|
|
|
//
|
|
|
|
typedef struct {
|
|
|
|
UINT32 MaxContexts;
|
|
|
|
UINT32 StorePosition;
|
|
|
|
EFI_DISPATCH_CONTEXT_UNION Contexts[1];
|
|
|
|
} QNC_S3_PARAMETER_HEADER;
|
|
|
|
//
|
|
|
|
// Function prototypes
|
|
|
|
//
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
QncS3SetDispatchItem (
|
|
|
|
IN EFI_QNC_S3_SUPPORT_PROTOCOL *This,
|
|
|
|
IN EFI_QNC_S3_DISPATCH_ITEM *DispatchItem,
|
|
|
|
OUT VOID **S3DispatchEntryPoint,
|
|
|
|
OUT VOID **Context
|
|
|
|
)
|
|
|
|
/*++
|
|
|
|
|
|
|
|
Routine Description:
|
|
|
|
|
|
|
|
Set an item to be dispatched at S3 resume time. At the same time, the entry point
|
|
|
|
of the QNC S3 support image is returned to be used in subsequent boot script save
|
|
|
|
call
|
|
|
|
|
|
|
|
Arguments:
|
|
|
|
|
|
|
|
This - Pointer to the protocol instance.
|
|
|
|
DispatchItem - The item to be dispatched.
|
|
|
|
S3DispatchEntryPoint - The entry point of the QNC S3 support image.
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
|
|
|
|
EFI_STATUS - Successfully completed.
|
|
|
|
EFI_OUT_OF_RESOURCES - Out of resources.
|
|
|
|
|
|
|
|
--*/
|
|
|
|
;
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
LoadQncS3Image (
|
|
|
|
IN EFI_SYSTEM_TABLE *SystemTable
|
|
|
|
)
|
|
|
|
/*++
|
|
|
|
|
|
|
|
Routine Description:
|
|
|
|
|
|
|
|
Load the QNC S3 Image into Efi Reserved Memory below 4G.
|
|
|
|
|
|
|
|
Arguments:
|
|
|
|
|
|
|
|
ImageEntryPoint the ImageEntryPoint after success loading
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
|
|
|
|
--*/
|
|
|
|
;
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
QncS3InitPcieRootPortDownstream (
|
|
|
|
IN EFI_HANDLE ImageHandle,
|
|
|
|
IN VOID *Context
|
|
|
|
);
|
|
|
|
|
|
|
|
VOID
|
|
|
|
EFIAPI
|
|
|
|
QncS3BootEvent (
|
|
|
|
IN EFI_EVENT Event,
|
|
|
|
IN VOID *Context
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
#endif
|