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