/** @file
Header file for private PmcLib.
Copyright (c) 2019 Intel Corporation. All rights reserved.
SPDX-License-Identifier: BSD-2-Clause-Patent
**/
#ifndef _PMC_PRIVATE_LIB_H_
#define _PMC_PRIVATE_LIB_H_
#include
#include
/**
Send PMC IPC1 Normal Read/Write command
@param[in] Command Command to be issued to PMC IPC 1 interface
@param[in] SubCmdId SUB_CMD_ID for provided Command
@param[in] CmdSize Total size in byte to be sent via PMC IPC 1 interface
@param[in] WriteBufPtr Pointer to Structure of 4 DWORDs to be issued to PMC IPC 1 interface
@param[out] ReadBufPtr Pointer to Structure of 4 DWORDs to be filled by PMC IPC 1 interface
@retval EFI_SUCCESS Command was executed successfully
@retval EFI_INVALID_PARAMETER Invalid command size
@retval EFI_DEVICE_ERROR IPC command failed with an error
@retval EFI_TIMEOUT IPC command did not complete after 1s
**/
EFI_STATUS
PmcSendCommand (
IN UINT8 Command,
IN UINT8 SubCmdId,
IN UINT8 CmdSize,
IN PMC_IPC_COMMAND_BUFFER *WriteBufPtr,
OUT PMC_IPC_COMMAND_BUFFER *ReadBufPtr
);
/**
Set PCH ACPI base address.
The Address should not be 0 and should be 256 bytes alignment, and it is IO space, so must not exceed 0xFFFF.
@param[in] Address Address for ACPI base address.
@retval EFI_SUCCESS Successfully completed.
@retval EFI_INVALID_PARAMETER Invalid base address passed.
**/
EFI_STATUS
PmcSetAcpiBase (
IN UINT16 Address
);
/**
Set PCH PWRM base address.
Only 0xFE000000 (PCH_PWRM_BASE_ADDRESS) is the acceptable value for PWRMBASE
@param[in] Address Address for PWRM base address.
@retval EFI_SUCCESS Successfully completed.
@retval EFI_UNSUPPORTED DMIC.SRL is set.
**/
EFI_STATUS
PmcSetPwrmBase (
IN UINT32 Address
);
/**
This function checks if function disable (static and non-static power gating)
configuration is locked
@retval lock state
**/
BOOLEAN
PmcIsFunctionDisableConfigLocked (
VOID
);
/**
This function locks static power gating configuration with S3 Boot Script programming
**/
VOID
PmcLockFunctionDisableConfigWithS3BootScript (
VOID
);
/**
This function checks if ISH is function disabled
by static power gating
@retval ISH device state
**/
BOOLEAN
PmcIsIshFunctionDisabled (
VOID
);
/**
This function checks if ISH device is supported (not disabled by fuse)
@retval ISH support state
**/
BOOLEAN
PmcIsIshSupported (
VOID
);
/**
This function disables ISH device by static power gating
For static power gating to take place Global Reset, G3 or DeepSx transition must happen.
**/
VOID
PmcStaticDisableIsh (
VOID
);
/**
This function enables ISH device by disabling static power gating
**/
VOID
PmcEnableIsh (
VOID
);
/**
This function enables GBE ModPHY SPD gating.
**/
VOID
PmcGbeModPhyPowerGating (
VOID
);
/**
This function checks if GbE is function disabled
by static power gating
@retval GbE device state
**/
BOOLEAN
PmcIsGbeFunctionDisabled (
VOID
);
/**
This function disables GbE device by static power gating
For static power gating to take place Global Reset, G3 or DeepSx transition must happen.
**/
VOID
PmcStaticDisableGbe (
VOID
);
/**
This function enables GbE device by disabling static power gating
Static power gating disabling takes place after Global Reset, G3 or DeepSx transition.
**/
VOID
PmcEnableGbe (
VOID
);
/**
This function checks if GbE device is supported (not disabled by fuse)
@retval GbE support state
**/
BOOLEAN
PmcIsGbeSupported (
VOID
);
/**
This function enables all SerailIo devices
Static power gating disabling takes place after Global Reset, G3 or DeepSx transition.
**/
VOID
PmcEnableSerialIo (
VOID
);
/**
This function disables (static power gating) all SerailIo devices.
For SerialIo controllers they can be power gated only if all of them are to be disabled.
They cannot be statically power gated separately.
For static power gating to take place Global Reset, G3 or DeepSx transition must happen.
**/
VOID
PmcStaticDisableSerialIo (
VOID
);
/**
This function checks if all SerialIo devices are statically disabled (static power gating)
@retval SerialIo disable state
**/
BOOLEAN
PmcIsSerialIoStaticallyDisabled (
VOID
);
/**
This function checks if SerialIo device is supported (not disabled by fuse)
@retval SerialIo support state
**/
BOOLEAN
PmcIsSerialIoSupported (
VOID
);
/**
This function disables (non-static power gating) HDA device
**/
VOID
PmcDisableHda (
VOID
);
/**
This function checks if Cnvi device is supported (not disabled by fuse)
@retval Cnvi support state
**/
BOOLEAN
PmcIsCnviSupported (
VOID
);
/**
This function checks if CNVi is function disabled
by static power gating
@retval GbE device state
**/
BOOLEAN
PmcIsCnviFunctionDisabled (
VOID
);
/**
This function enables CNVi device by disabling static power gating.
Static power gating disabling takes place after Global Reset, G3 or DeepSx transition.
**/
VOID
PmcEnableCnvi (
VOID
);
/**
This function disables CNVi device by static power gating
For static power gating to take place Global Reset, G3 or DeepSx transition must happen.
**/
VOID
PmcStaticDisableCnvi (
VOID
);
/**
This function disables (non-static power gating) PCIe Root Port
@param[in] RpIndex PCIe Root Port Index (0 based)
**/
VOID
PmcDisablePcieRootPort (
IN UINT32 RpIndex
);
/**
This function disables (non-static power gating) SATA
@param[in] SataCtrlIndex SATA controller index
**/
VOID
PmcDisableSata (
IN UINT32 SataCtrlIndex
);
/**
This function checks if SATA device is supported (not disabled by fuse)
@param[in] SataCtrlIndex SATA controller index
@retval SATA support state
**/
BOOLEAN
PmcIsSataSupported (
IN UINT32 SataCtrlIndex
);
/**
This function gets NMI regsiter.
@retval NMI register setting
**/
UINT32
PmcGetNmiControl (
VOID
);
/**
This function sets the NMI register
@param[in] NmiRegister The whole NMI register
**/
VOID
PmcSetNmiControl (
UINT32 NmiRegister
);
/**
This function disables (non-static power gating) xHCI
**/
VOID
PmcDisableXhci (
VOID
);
/**
This function disables (non-static power gating) XDCI
**/
VOID
PmcDisableXdci (
VOID
);
/**
This function checks if XDCI device is supported (not disabled by fuse)
@retval XDCI support state
**/
BOOLEAN
PmcIsXdciSupported (
VOID
);
/**
This function disables (non-static power gating) SCS eMMC controller and enables ModPHY SPD gating (PCH-LP only).
**/
VOID
PmcDisableScsEmmc (
VOID
);
/**
This function disables (non-static power gating) SCS SD Card controller and enables ModPHY SPD gating (PCH-LP only).
**/
VOID
PmcDisableScsSdCard (
VOID
);
/**
This function disables (non-static power gating) SCS UFS controller and enables ModPHY SPD gating (PCH-LP only).
@param[in] UfsNum SCS UFS Device
**/
VOID
PmcDisableScsUfs (
IN UINT32 UfsNum
);
/**
This function checks if SCS eMMC device is supported (not disabled by fuse)
@retval SCS device support state
**/
BOOLEAN
PmcIsScsEmmcSupported (
VOID
);
/**
This function checks if SCS SD Card device is supported (not disabled by fuse)
@retval SCS device support state
**/
BOOLEAN
PmcIsScsSdCardSupported (
VOID
);
/**
This function checks if SCS UFS device is supported (not disabled by fuse)
@param[in] UfsNum SCS UFS Device
@retval SCS device support state
**/
BOOLEAN
PmcIsScsUfsSupported (
IN UINT32 UfsNum
);
/**
This function locks HOST SW power gating control
**/
VOID
PmcLockHostSwPgCtrl (
VOID
);
/**
This function checks if HOST SW Power Gating Control is locked
@retval lock state
**/
BOOLEAN
PmcIsHostSwPgCtrlLocked (
VOID
);
/**
This function disables Trace Hub by enabling power gating
**/
VOID
PmcDisableTraceHub (
VOID
);
/**
This function enables Trace Hub by disabling power gating
**/
VOID
PmcEnableTraceHub (
VOID
);
/**
This function checks if LAN wake from DeepSx is enabled
@retval Lan Wake state
**/
BOOLEAN
PmcIsLanDeepSxWakeEnabled (
VOID
);
/**
This function locks down PMC (DebugModeLock)
**/
VOID
PmcLockWithS3BootScript (
VOID
);
/**
Checks if conditions for proper USB2 PHY AFE programming are met
**/
VOID
PmcUsb2CorePhyPowerGatingDisable (
VOID
);
/**
This function reads CPU Early Power-on Configuration (EPOC)
@retval CPU EPOC value
**/
UINT32
PmcGetCpuEpoc (
VOID
);
/**
This function sets CPU Early Power-on Configuration (EPOC)
@param[in] CpuEpocValue CPU EPOC value
**/
VOID
PmcSetCpuEpoc (
IN UINT32 CpuEpocValue
);
/**
This function sets DRAM_RESET# Control Pin value
@param[in] DramResetVal 0: Pin output is low
1: Pin output is tri-stated
**/
VOID
PmcSetDramResetCtlState (
IN UINT32 DramResetVal
);
/**
This function enables triggering Global Reset of both
the Host and the ME partitions after CF9h write of 6h or Eh
**/
VOID
PmcEnableCf9GlobalReset (
VOID
);
/**
This function disables triggering Global Reset of both
the Host and the ME partitions after CF9h write of 6h or Eh.
**/
VOID
PmcDisableCf9GlobalReset (
VOID
);
/**
This function disables triggering Global Reset of both
the Host and the ME partitions after CF9h write of 6h or Eh.
Global Reset configuration is locked after programming
**/
VOID
PmcDisableCf9GlobalResetWithLock (
VOID
);
/**
This S3 BootScript only function disables triggering Global Reset of both
the Host and the ME partitions after CF9h write of 6h or Eh.
**/
VOID
PmcDisableCf9GlobalResetInS3BootScript (
VOID
);
/**
This S3 BootScript only function disables triggering Global Reset of both
the Host and the ME partitions after CF9h write of 6h or Eh.
Global Reset configuration is locked after programming
**/
VOID
PmcDisableCf9GlobalResetWithLockInS3BootScript (
VOID
);
/**
This function disables CF9 reset without Resume Well reset.
Cf9 0x6/0xE reset will also reset resume well logic.
**/
VOID
PmcDisableCf9ResetWithoutResumeWell (
VOID
);
/**
This function locks PMC Set Strap Message interface with S3 Boot Script programming
**/
VOID
PmcLockSetStrapMsgInterfaceWithS3BootScript (
VOID
);
/**
This function clears RTC Power Failure status (RTC_PWR_FLR)
**/
VOID
PmcClearRtcPowerFailureStatus (
VOID
);
/**
This function enables PCI Express* PME events
**/
VOID
PmcEnablePciExpressPmeEvents (
VOID
);
/**
This function sets SLP_SX Stretching Policy and adds
lock setting to S3 Boot Script
**/
VOID
PmcLockSlpSxStretchingPolicyWithS3BootScript (
VOID
);
/**
This function sets SMI Lock with S3 Boot Script programming
**/
VOID
PmcLockSmiWithS3BootScript (
VOID
);
/**
This function sets eSPI SMI Lock
**/
VOID
PmcLockEspiSmi (
VOID
);
/**
This function checks if eSPI SMI Lock is set
@retval eSPI SMI Lock state
**/
BOOLEAN
PmcIsEspiSmiLockSet (
VOID
);
typedef enum {
PmcSwSmiRate1p5ms = 0,
PmcSwSmiRate16ms,
PmcSwSmiRate32ms,
PmcSwSmiRate64ms
} PMC_SWSMI_RATE;
/**
This function sets SW SMI Rate.
@param[in] SwSmiRate Refer to PMC_SWSMI_RATE for possible values
**/
VOID
PmcSetSwSmiRate (
IN PMC_SWSMI_RATE SwSmiRate
);
typedef enum {
PmcPeriodicSmiRate8s = 0,
PmcPeriodicSmiRate16s,
PmcPeriodicSmiRate32s,
PmcPeriodicSmiRate64s
} PMC_PERIODIC_SMI_RATE;
/**
This function sets Periodic SMI Rate.
@param[in] PeriodicSmiRate Refer to PMC_PERIODIC_SMI_RATE for possible values
**/
VOID
PmcSetPeriodicSmiRate (
IN PMC_PERIODIC_SMI_RATE PeriodicSmiRate
);
/**
This function reads Power Button Level
@retval State of PWRBTN# signal (0: Low, 1: High)
**/
UINT8
PmcGetPwrBtnLevel (
VOID
);
/**
This function gets Group to GPE0 configuration
@param[out] GpeDw0Value GPIO Group to GPE_DW0 assignment
@param[out] GpeDw1Value GPIO Group to GPE_DW1 assignment
@param[out] GpeDw2Value GPIO Group to GPE_DW2 assignment
**/
VOID
PmcGetGpioGpe (
OUT UINT32 *GpeDw0Value,
OUT UINT32 *GpeDw1Value,
OUT UINT32 *GpeDw2Value
);
/**
This function sets Group to GPE0 configuration
@param[out] GpeDw0Value GPIO Group to GPE_DW0 assignment
@param[out] GpeDw1Value GPIO Group to GPE_DW1 assignment
@param[out] GpeDw2Value GPIO Group to GPE_DW2 assignment
**/
VOID
PmcSetGpioGpe (
IN UINT32 GpeDw0Value,
IN UINT32 GpeDw1Value,
IN UINT32 GpeDw2Value
);
/**
This function checks if SCI interrupt is enabled
@retval SCI Enable state
**/
BOOLEAN
PmcIsSciEnabled (
VOID
);
/**
This function triggers Software GPE
**/
VOID
PmcTriggerSwGpe (
VOID
);
/**
Disable SLP_S0# assertion when system is in debug mode
**/
VOID
PmcDisableSlpS0AssertionInDebugMode (
VOID
);
/**
Enable SLP_S0# assertion even when system is in debug mode
**/
VOID
PmcEnableSlpS0AssertionInDebugMode (
VOID
);
#endif // _PMC_PRIVATE_LIB_H_