soc/intel/skylake: Set xtal bypass on low power idle
When using Wake On Voice &/or DCI, it requires xtal to be active during low power idle. With xtal being active in S0ix state power impact is 1-2 mW. Hence set xtal bypass bit in CIR31C for low power idle entry. TEST= Build with s0ix enable for Poppy. Boot to OS & verify that bit 22 of CIR31C register is set. s0ix works. Change-Id: Ide2d01536f652cd1b0ac32eede89ec410c5101cf Signed-off-by: Naresh G Solanki <naresh.solanki@intel.com> Reviewed-on: https://review.coreboot.org/19442 Tested-by: build bot (Jenkins) Reviewed-by: Aaron Durbin <adurbin@chromium.org> Reviewed-by: Furquan Shaikh <furquan@google.com>
This commit is contained in:
parent
7f2c29b6d6
commit
c261c4b426
2 changed files with 9 additions and 1 deletions
|
@ -143,6 +143,13 @@ static void pch_finalize_script(void)
|
|||
write8(pmcbase + PCH_PWRM_ACPI_TMR_CTL, reg8);
|
||||
}
|
||||
|
||||
/* Disable XTAL shutdown qualification for low power idle. */
|
||||
if (config->s0ix_enable) {
|
||||
reg32 = read32(pmcbase + CIR31C);
|
||||
reg32 |= XTALSDQDIS;
|
||||
write32(pmcbase + CIR31C, reg32);
|
||||
}
|
||||
|
||||
/* we should disable Heci1 based on the devicetree policy */
|
||||
if (config->HeciEnabled == 0)
|
||||
pch_disable_heci();
|
||||
|
|
|
@ -98,5 +98,6 @@
|
|||
#define GPE0_DW2_SHIFT 8
|
||||
#define GBLRST_CAUSE0 0x124
|
||||
#define GBLRST_CAUSE1 0x128
|
||||
|
||||
#define CIR31C 0x31c
|
||||
#define XTALSDQDIS (1 << 22)
|
||||
#endif
|
||||
|
|
Loading…
Reference in a new issue