/** @file
This file declares Graphics PPI.
This PPI is the main interface exposed by the Graphics PEIM to be used by the
other firmware modules.
Copyright (c) 2015, Intel Corporation. All rights reserved.
SPDX-License-Identifier: BSD-2-Clause-Patent
@par Revision Reference:
This PPI is introduced in PI Version 1.4.
**/
#ifndef __PEI_GRAPHICS_PPI_H__
#define __PEI_GRAPHICS_PPI_H__
#include
#define EFI_PEI_GRAPHICS_PPI_GUID \
{ \
0x6ecd1463, 0x4a4a, 0x461b, { 0xaf, 0x5f, 0x5a, 0x33, 0xe3, 0xb2, 0x16, 0x2b } \
}
typedef struct _EFI_PEI_GRAPHICS_PPI EFI_PEI_GRAPHICS_PPI;
/**
The GraphicsPpiInit initializes the graphics subsystem in phases.
@param[in] GraphicsPolicyPtr GraphicsPolicyPtr points to a configuration data
block of policy settings required by Graphics PEIM.
@retval EFI_SUCCESS The invocation was successful.
@retval EFI_INVALID_PARAMETER The phase parameter is not valid.
@retval EFI_NOT_ABORTED The stages was not called in the proper order.
@retval EFI_NOT_FOUND The PeiGraphicsPlatformPolicyPpi is not located.
@retval EFI_DEVICE_ERROR The initialization failed due to device error.
@retval EFI_NOT_READY The previous init stage is still in progress and not
ready for the current initialization phase yet. The
platform code should call this again sometime later.
**/
typedef
EFI_STATUS
(EFIAPI *EFI_PEI_GRAPHICS_INIT)(
IN VOID *GraphicsPolicyPtr
);
/**
The GraphicsPpiGetMode returns the mode information supported by the Graphics PEI
Module.
@param[in, out] Mode Pointer to EFI_GRAPHICS_OUTPUT_PROTOCOL_MODE data.
@retval EFI_SUCCESS Valid mode information was returned.
@retval EFI_INVALID_PARAMETER The Mode parameter is not valid.
@retval EFI_DEVICE_ERROR A hardware error occurred trying to retrieve the video
mode.
@retval EFI_NOT_READY The Graphics Initialization is not competed and Mode
information is not yet available.The platform code
should call this again after the Graphics
initialization is done.
**/
typedef
EFI_STATUS
(EFIAPI *EFI_PEI_GRAPHICS_GET_MODE)(
IN OUT EFI_GRAPHICS_OUTPUT_PROTOCOL_MODE *Mode
);
///
/// This PPI is the main interface exposed by the Graphics PEIM to be used by the other
/// firmware modules.
///
struct _EFI_PEI_GRAPHICS_PPI {
EFI_PEI_GRAPHICS_INIT GraphicsPpiInit;
EFI_PEI_GRAPHICS_GET_MODE GraphicsPpiGetMode;
};
extern EFI_GUID gEfiPeiGraphicsPpiGuid;
#endif