/** @file Serial IRQ policy Copyright (c) 2017, Intel Corporation. All rights reserved.
SPDX-License-Identifier: BSD-2-Clause-Patent **/ #ifndef _SERIAL_IRQ_CONFIG_H_ #define _SERIAL_IRQ_CONFIG_H_ #define SERIAL_IRQ_CONFIG_REVISION 1 extern EFI_GUID gSerialIrqConfigGuid; #pragma pack (push,1) typedef enum { PchQuietMode, PchContinuousMode } PCH_SIRQ_MODE; /// /// Refer to PCH EDS for the details of Start Frame Pulse Width in Continuous and Quiet mode /// typedef enum { PchSfpw4Clk, PchSfpw6Clk, PchSfpw8Clk } PCH_START_FRAME_PULSE; /// /// The PCH_LPC_SIRQ_CONFIG block describes the expected configuration of the PCH for Serial IRQ. /// typedef struct { CONFIG_BLOCK_HEADER Header; ///< Config Block Header UINT32 SirqEnable : 1; ///< Determines if enable Serial IRQ. 0: Disable; 1: Enable. UINT32 SirqMode : 2; ///< Serial IRQ Mode Select. Refer to PCH_SIRQ_MODE for each value. 0: quiet mode 1: continuous mode. UINT32 StartFramePulse : 3; ///< Start Frame Pulse Width. Refer to PCH_START_FRAME_PULSE for each value. Default is PchSfpw4Clk. UINT32 RsvdBits0 : 26; ///< Reserved bits } PCH_LPC_SIRQ_CONFIG; #pragma pack (pop) #endif // _SERIAL_IRQ_CONFIG_H_