/** @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_