diff options
Diffstat (limited to 'drivers/platform/x86/intel/pmc/lnl.c')
| -rw-r--r-- | drivers/platform/x86/intel/pmc/lnl.c | 477 | 
1 files changed, 265 insertions, 212 deletions
diff --git a/drivers/platform/x86/intel/pmc/lnl.c b/drivers/platform/x86/intel/pmc/lnl.c index 068d72504683..e7a8077d1a3e 100644 --- a/drivers/platform/x86/intel/pmc/lnl.c +++ b/drivers/platform/x86/intel/pmc/lnl.c @@ -1,7 +1,7 @@  // SPDX-License-Identifier: GPL-2.0  /*   * This file contains platform specific structure definitions - * and init function used by Meteor Lake PCH. + * and init function used by Lunar Lake PCH.   *   * Copyright (c) 2022, Intel Corporation.   * All Rights Reserved. @@ -56,264 +56,296 @@ const struct pmc_bit_map lnl_ltr_show_map[] = {  };  const struct pmc_bit_map lnl_power_gating_status_0_map[] = { -	{"PMC_PGD0_PG_STS",			BIT(0)}, -	{"FUSE_OSSE_PGD0_PG_STS",		BIT(1)}, -	{"ESPISPI_PGD0_PG_STS",			BIT(2)}, -	{"XHCI_PGD0_PG_STS",			BIT(3)}, -	{"SPA_PGD0_PG_STS",			BIT(4)}, -	{"SPB_PGD0_PG_STS",			BIT(5)}, -	{"SPR16B0_PGD0_PG_STS",			BIT(6)}, -	{"GBE_PGD0_PG_STS",			BIT(7)}, -	{"SBR8B7_PGD0_PG_STS",			BIT(8)}, -	{"SBR8B6_PGD0_PG_STS",			BIT(9)}, -	{"SBR16B1_PGD0_PG_STS",			BIT(10)}, -	{"SBR8B8_PGD0_PG_STS",			BIT(11)}, -	{"ESE_PGD3_PG_STS",			BIT(12)}, -	{"D2D_DISP_PGD0_PG_STS",		BIT(13)}, -	{"LPSS_PGD0_PG_STS",			BIT(14)}, -	{"LPC_PGD0_PG_STS",			BIT(15)}, -	{"SMB_PGD0_PG_STS",			BIT(16)}, -	{"ISH_PGD0_PG_STS",			BIT(17)}, -	{"SBR8B2_PGD0_PG_STS",			BIT(18)}, -	{"NPK_PGD0_PG_STS",			BIT(19)}, -	{"D2D_NOC_PGD0_PG_STS",			BIT(20)}, -	{"SAFSS_PGD0_PG_STS",			BIT(21)}, -	{"FUSE_PGD0_PG_STS",			BIT(22)}, -	{"D2D_DISP_PGD1_PG_STS",		BIT(23)}, -	{"MPFPW1_PGD0_PG_STS",			BIT(24)}, -	{"XDCI_PGD0_PG_STS",			BIT(25)}, -	{"EXI_PGD0_PG_STS",			BIT(26)}, -	{"CSE_PGD0_PG_STS",			BIT(27)}, -	{"KVMCC_PGD0_PG_STS",			BIT(28)}, -	{"PMT_PGD0_PG_STS",			BIT(29)}, -	{"CLINK_PGD0_PG_STS",			BIT(30)}, -	{"PTIO_PGD0_PG_STS",			BIT(31)}, +	{"PMC_PGD0_PG_STS",			BIT(0),		0}, +	{"FUSE_OSSE_PGD0_PG_STS",		BIT(1),		0}, +	{"ESPISPI_PGD0_PG_STS",			BIT(2),		0}, +	{"XHCI_PGD0_PG_STS",			BIT(3),		1}, +	{"SPA_PGD0_PG_STS",			BIT(4),		1}, +	{"SPB_PGD0_PG_STS",			BIT(5),		1}, +	{"SPR16B0_PGD0_PG_STS",			BIT(6),		0}, +	{"GBE_PGD0_PG_STS",			BIT(7),		1}, +	{"SBR8B7_PGD0_PG_STS",			BIT(8),		0}, +	{"SBR8B6_PGD0_PG_STS",			BIT(9),		0}, +	{"SBR16B1_PGD0_PG_STS",			BIT(10),	0}, +	{"SBR8B8_PGD0_PG_STS",			BIT(11),	0}, +	{"ESE_PGD3_PG_STS",			BIT(12),	1}, +	{"D2D_DISP_PGD0_PG_STS",		BIT(13),	1}, +	{"LPSS_PGD0_PG_STS",			BIT(14),	1}, +	{"LPC_PGD0_PG_STS",			BIT(15),	0}, +	{"SMB_PGD0_PG_STS",			BIT(16),	0}, +	{"ISH_PGD0_PG_STS",			BIT(17),	0}, +	{"SBR8B2_PGD0_PG_STS",			BIT(18),	0}, +	{"NPK_PGD0_PG_STS",			BIT(19),	0}, +	{"D2D_NOC_PGD0_PG_STS",			BIT(20),	0}, +	{"SAFSS_PGD0_PG_STS",			BIT(21),	0}, +	{"FUSE_PGD0_PG_STS",			BIT(22),	0}, +	{"D2D_DISP_PGD1_PG_STS",		BIT(23),	1}, +	{"MPFPW1_PGD0_PG_STS",			BIT(24),	0}, +	{"XDCI_PGD0_PG_STS",			BIT(25),	1}, +	{"EXI_PGD0_PG_STS",			BIT(26),	0}, +	{"CSE_PGD0_PG_STS",			BIT(27),	1}, +	{"KVMCC_PGD0_PG_STS",			BIT(28),	1}, +	{"PMT_PGD0_PG_STS",			BIT(29),	1}, +	{"CLINK_PGD0_PG_STS",			BIT(30),	1}, +	{"PTIO_PGD0_PG_STS",			BIT(31),	1},  	{}  };  const struct pmc_bit_map lnl_power_gating_status_1_map[] = { -	{"USBR0_PGD0_PG_STS",			BIT(0)}, -	{"SUSRAM_PGD0_PG_STS",			BIT(1)}, -	{"SMT1_PGD0_PG_STS",			BIT(2)}, -	{"U3FPW1_PGD0_PG_STS",			BIT(3)}, -	{"SMS2_PGD0_PG_STS",			BIT(4)}, -	{"SMS1_PGD0_PG_STS",			BIT(5)}, -	{"CSMERTC_PGD0_PG_STS",			BIT(6)}, -	{"CSMEPSF_PGD0_PG_STS",			BIT(7)}, -	{"FIA_PG_PGD0_PG_STS",			BIT(8)}, -	{"SBR16B4_PGD0_PG_STS",			BIT(9)}, -	{"P2SB8B_PGD0_PG_STS",			BIT(10)}, -	{"DBG_SBR_PGD0_PG_STS",			BIT(11)}, -	{"SBR8B9_PGD0_PG_STS",			BIT(12)}, -	{"OSSE_SMT1_PGD0_PG_STS",		BIT(13)}, -	{"SBR8B10_PGD0_PG_STS",			BIT(14)}, -	{"SBR16B3_PGD0_PG_STS",			BIT(15)}, -	{"G5FPW1_PGD0_PG_STS",			BIT(16)}, -	{"SBRG_PGD0_PG_STS",			BIT(17)}, -	{"PSF4_PGD0_PG_STS",			BIT(18)}, -	{"CNVI_PGD0_PG_STS",			BIT(19)}, -	{"USFX2_PGD0_PG_STS",			BIT(20)}, -	{"ENDBG_PGD0_PG_STS",			BIT(21)}, -	{"FIACPCB_P5X4_PGD0_PG_STS",		BIT(22)}, -	{"SBR8B3_PGD0_PG_STS",			BIT(23)}, -	{"SBR8B0_PGD0_PG_STS",			BIT(24)}, -	{"NPK_PGD1_PG_STS",			BIT(25)}, -	{"OSSE_HOTHAM_PGD0_PG_STS",		BIT(26)}, -	{"D2D_NOC_PGD2_PG_STS",			BIT(27)}, -	{"SBR8B1_PGD0_PG_STS",			BIT(28)}, -	{"PSF6_PGD0_PG_STS",			BIT(29)}, -	{"PSF7_PGD0_PG_STS",			BIT(30)}, -	{"FIA_U_PGD0_PG_STS",			BIT(31)}, +	{"USBR0_PGD0_PG_STS",			BIT(0),		1}, +	{"SUSRAM_PGD0_PG_STS",			BIT(1),		1}, +	{"SMT1_PGD0_PG_STS",			BIT(2),		1}, +	{"U3FPW1_PGD0_PG_STS",			BIT(3),		0}, +	{"SMS2_PGD0_PG_STS",			BIT(4),		1}, +	{"SMS1_PGD0_PG_STS",			BIT(5),		1}, +	{"CSMERTC_PGD0_PG_STS",			BIT(6),		0}, +	{"CSMEPSF_PGD0_PG_STS",			BIT(7),		0}, +	{"FIA_PG_PGD0_PG_STS",			BIT(8),		0}, +	{"SBR16B4_PGD0_PG_STS",			BIT(9),		0}, +	{"P2SB8B_PGD0_PG_STS",			BIT(10),	1}, +	{"DBG_SBR_PGD0_PG_STS",			BIT(11),	0}, +	{"SBR8B9_PGD0_PG_STS",			BIT(12),	0}, +	{"OSSE_SMT1_PGD0_PG_STS",		BIT(13),	1}, +	{"SBR8B10_PGD0_PG_STS",			BIT(14),	0}, +	{"SBR16B3_PGD0_PG_STS",			BIT(15),	0}, +	{"G5FPW1_PGD0_PG_STS",			BIT(16),	0}, +	{"SBRG_PGD0_PG_STS",			BIT(17),	0}, +	{"PSF4_PGD0_PG_STS",			BIT(18),	0}, +	{"CNVI_PGD0_PG_STS",			BIT(19),	0}, +	{"USFX2_PGD0_PG_STS",			BIT(20),	1}, +	{"ENDBG_PGD0_PG_STS",			BIT(21),	0}, +	{"FIACPCB_P5X4_PGD0_PG_STS",		BIT(22),	0}, +	{"SBR8B3_PGD0_PG_STS",			BIT(23),	0}, +	{"SBR8B0_PGD0_PG_STS",			BIT(24),	0}, +	{"NPK_PGD1_PG_STS",			BIT(25),	0}, +	{"OSSE_HOTHAM_PGD0_PG_STS",		BIT(26),	1}, +	{"D2D_NOC_PGD2_PG_STS",			BIT(27),	1}, +	{"SBR8B1_PGD0_PG_STS",			BIT(28),	0}, +	{"PSF6_PGD0_PG_STS",			BIT(29),	0}, +	{"PSF7_PGD0_PG_STS",			BIT(30),	0}, +	{"FIA_U_PGD0_PG_STS",			BIT(31),	0},  	{}  };  const struct pmc_bit_map lnl_power_gating_status_2_map[] = { -	{"PSF8_PGD0_PG_STS",			BIT(0)}, -	{"SBR16B2_PGD0_PG_STS",			BIT(1)}, -	{"D2D_IPU_PGD0_PG_STS",			BIT(2)}, -	{"FIACPCB_U_PGD0_PG_STS",		BIT(3)}, -	{"TAM_PGD0_PG_STS",			BIT(4)}, -	{"D2D_NOC_PGD1_PG_STS",			BIT(5)}, -	{"TBTLSX_PGD0_PG_STS",			BIT(6)}, -	{"THC0_PGD0_PG_STS",			BIT(7)}, -	{"THC1_PGD0_PG_STS",			BIT(8)}, -	{"PMC_PGD0_PG_STS",			BIT(9)}, -	{"SBR8B5_PGD0_PG_STS",			BIT(10)}, -	{"UFSPW1_PGD0_PG_STS",			BIT(11)}, -	{"DBC_PGD0_PG_STS",			BIT(12)}, -	{"TCSS_PGD0_PG_STS",			BIT(13)}, -	{"FIA_P5X4_PGD0_PG_STS",		BIT(14)}, -	{"DISP_PGA_PGD0_PG_STS",		BIT(15)}, -	{"DISP_PSF_PGD0_PG_STS",		BIT(16)}, -	{"PSF0_PGD0_PG_STS",			BIT(17)}, -	{"P2SB16B_PGD0_PG_STS",			BIT(18)}, -	{"ACE_PGD0_PG_STS",			BIT(19)}, -	{"ACE_PGD1_PG_STS",			BIT(20)}, -	{"ACE_PGD2_PG_STS",			BIT(21)}, -	{"ACE_PGD3_PG_STS",			BIT(22)}, -	{"ACE_PGD4_PG_STS",			BIT(23)}, -	{"ACE_PGD5_PG_STS",			BIT(24)}, -	{"ACE_PGD6_PG_STS",			BIT(25)}, -	{"ACE_PGD7_PG_STS",			BIT(26)}, -	{"ACE_PGD8_PG_STS",			BIT(27)}, -	{"ACE_PGD9_PG_STS",			BIT(28)}, -	{"ACE_PGD10_PG_STS",			BIT(29)}, -	{"FIACPCB_PG_PGD0_PG_STS",		BIT(30)}, -	{"OSSE_PGD0_PG_STS",			BIT(31)}, +	{"PSF8_PGD0_PG_STS",			BIT(0),		0}, +	{"SBR16B2_PGD0_PG_STS",			BIT(1),		0}, +	{"D2D_IPU_PGD0_PG_STS",			BIT(2),		1}, +	{"FIACPCB_U_PGD0_PG_STS",		BIT(3),		0}, +	{"TAM_PGD0_PG_STS",			BIT(4),		1}, +	{"D2D_NOC_PGD1_PG_STS",			BIT(5),		1}, +	{"TBTLSX_PGD0_PG_STS",			BIT(6),		1}, +	{"THC0_PGD0_PG_STS",			BIT(7),		1}, +	{"THC1_PGD0_PG_STS",			BIT(8),		1}, +	{"PMC_PGD0_PG_STS",			BIT(9),		0}, +	{"SBR8B5_PGD0_PG_STS",			BIT(10),	0}, +	{"UFSPW1_PGD0_PG_STS",			BIT(11),	0}, +	{"DBC_PGD0_PG_STS",			BIT(12),	0}, +	{"TCSS_PGD0_PG_STS",			BIT(13),	0}, +	{"FIA_P5X4_PGD0_PG_STS",		BIT(14),	0}, +	{"DISP_PGA_PGD0_PG_STS",		BIT(15),	0}, +	{"DISP_PSF_PGD0_PG_STS",		BIT(16),	0}, +	{"PSF0_PGD0_PG_STS",			BIT(17),	0}, +	{"P2SB16B_PGD0_PG_STS",			BIT(18),	1}, +	{"ACE_PGD0_PG_STS",			BIT(19),	0}, +	{"ACE_PGD1_PG_STS",			BIT(20),	0}, +	{"ACE_PGD2_PG_STS",			BIT(21),	0}, +	{"ACE_PGD3_PG_STS",			BIT(22),	0}, +	{"ACE_PGD4_PG_STS",			BIT(23),	0}, +	{"ACE_PGD5_PG_STS",			BIT(24),	0}, +	{"ACE_PGD6_PG_STS",			BIT(25),	0}, +	{"ACE_PGD7_PG_STS",			BIT(26),	0}, +	{"ACE_PGD8_PG_STS",			BIT(27),	0}, +	{"ACE_PGD9_PG_STS",			BIT(28),	0}, +	{"ACE_PGD10_PG_STS",			BIT(29),	0}, +	{"FIACPCB_PG_PGD0_PG_STS",		BIT(30),	0}, +	{"OSSE_PGD0_PG_STS",			BIT(31),	1},  	{}  };  const struct pmc_bit_map lnl_d3_status_0_map[] = { -	{"LPSS_D3_STS",				BIT(3)}, -	{"XDCI_D3_STS",				BIT(4)}, -	{"XHCI_D3_STS",				BIT(5)}, -	{"SPA_D3_STS",				BIT(12)}, -	{"SPB_D3_STS",				BIT(13)}, -	{"OSSE_D3_STS",				BIT(15)}, -	{"ESPISPI_D3_STS",			BIT(18)}, -	{"PSTH_D3_STS",				BIT(21)}, +	{"LPSS_D3_STS",				BIT(3),		1}, +	{"XDCI_D3_STS",				BIT(4),		1}, +	{"XHCI_D3_STS",				BIT(5),		1}, +	{"SPA_D3_STS",				BIT(12),	0}, +	{"SPB_D3_STS",				BIT(13),	0}, +	{"OSSE_D3_STS",				BIT(15),	0}, +	{"ESPISPI_D3_STS",			BIT(18),	0}, +	{"PSTH_D3_STS",				BIT(21),	0},  	{}  };  const struct pmc_bit_map lnl_d3_status_1_map[] = { -	{"OSSE_SMT1_D3_STS",			BIT(7)}, -	{"GBE_D3_STS",				BIT(19)}, -	{"ITSS_D3_STS",				BIT(23)}, -	{"CNVI_D3_STS",				BIT(27)}, -	{"UFSX2_D3_STS",			BIT(28)}, -	{"OSSE_HOTHAM_D3_STS",			BIT(31)}, +	{"OSSE_SMT1_D3_STS",			BIT(7),		0}, +	{"GBE_D3_STS",				BIT(19),	0}, +	{"ITSS_D3_STS",				BIT(23),	0}, +	{"CNVI_D3_STS",				BIT(27),	0}, +	{"UFSX2_D3_STS",			BIT(28),	1}, +	{"OSSE_HOTHAM_D3_STS",			BIT(31),	0},  	{}  };  const struct pmc_bit_map lnl_d3_status_2_map[] = { -	{"ESE_D3_STS",				BIT(0)}, -	{"CSMERTC_D3_STS",			BIT(1)}, -	{"SUSRAM_D3_STS",			BIT(2)}, -	{"CSE_D3_STS",				BIT(4)}, -	{"KVMCC_D3_STS",			BIT(5)}, -	{"USBR0_D3_STS",			BIT(6)}, -	{"ISH_D3_STS",				BIT(7)}, -	{"SMT1_D3_STS",				BIT(8)}, -	{"SMT2_D3_STS",				BIT(9)}, -	{"SMT3_D3_STS",				BIT(10)}, -	{"OSSE_SMT2_D3_STS",			BIT(13)}, -	{"CLINK_D3_STS",			BIT(14)}, -	{"PTIO_D3_STS",				BIT(16)}, -	{"PMT_D3_STS",				BIT(17)}, -	{"SMS1_D3_STS",				BIT(18)}, -	{"SMS2_D3_STS",				BIT(19)}, +	{"ESE_D3_STS",				BIT(0),		0}, +	{"CSMERTC_D3_STS",			BIT(1),		0}, +	{"SUSRAM_D3_STS",			BIT(2),		0}, +	{"CSE_D3_STS",				BIT(4),		0}, +	{"KVMCC_D3_STS",			BIT(5),		0}, +	{"USBR0_D3_STS",			BIT(6),		0}, +	{"ISH_D3_STS",				BIT(7),		0}, +	{"SMT1_D3_STS",				BIT(8),		0}, +	{"SMT2_D3_STS",				BIT(9),		0}, +	{"SMT3_D3_STS",				BIT(10),	0}, +	{"OSSE_SMT2_D3_STS",			BIT(13),	0}, +	{"CLINK_D3_STS",			BIT(14),	0}, +	{"PTIO_D3_STS",				BIT(16),	0}, +	{"PMT_D3_STS",				BIT(17),	0}, +	{"SMS1_D3_STS",				BIT(18),	0}, +	{"SMS2_D3_STS",				BIT(19),	0},  	{}  };  const struct pmc_bit_map lnl_d3_status_3_map[] = { -	{"THC0_D3_STS",				BIT(14)}, -	{"THC1_D3_STS",				BIT(15)}, -	{"OSSE_SMT3_D3_STS",			BIT(21)}, -	{"ACE_D3_STS",				BIT(23)}, +	{"THC0_D3_STS",				BIT(14),	1}, +	{"THC1_D3_STS",				BIT(15),	1}, +	{"OSSE_SMT3_D3_STS",			BIT(21),	0}, +	{"ACE_D3_STS",				BIT(23),	0},  	{}  };  const struct pmc_bit_map lnl_vnn_req_status_0_map[] = { -	{"LPSS_VNN_REQ_STS",			BIT(3)}, -	{"OSSE_VNN_REQ_STS",			BIT(15)}, -	{"ESPISPI_VNN_REQ_STS",			BIT(18)}, +	{"LPSS_VNN_REQ_STS",			BIT(3),		1}, +	{"OSSE_VNN_REQ_STS",			BIT(15),	1}, +	{"ESPISPI_VNN_REQ_STS",			BIT(18),	1},  	{}  };  const struct pmc_bit_map lnl_vnn_req_status_1_map[] = { -	{"NPK_VNN_REQ_STS",			BIT(4)}, -	{"OSSE_SMT1_VNN_REQ_STS",		BIT(7)}, -	{"DFXAGG_VNN_REQ_STS",			BIT(8)}, -	{"EXI_VNN_REQ_STS",			BIT(9)}, -	{"P2D_VNN_REQ_STS",			BIT(18)}, -	{"GBE_VNN_REQ_STS",			BIT(19)}, -	{"SMB_VNN_REQ_STS",			BIT(25)}, -	{"LPC_VNN_REQ_STS",			BIT(26)}, +	{"NPK_VNN_REQ_STS",			BIT(4),		1}, +	{"OSSE_SMT1_VNN_REQ_STS",		BIT(7),		1}, +	{"DFXAGG_VNN_REQ_STS",			BIT(8),		0}, +	{"EXI_VNN_REQ_STS",			BIT(9),		1}, +	{"P2D_VNN_REQ_STS",			BIT(18),	1}, +	{"GBE_VNN_REQ_STS",			BIT(19),	1}, +	{"SMB_VNN_REQ_STS",			BIT(25),	1}, +	{"LPC_VNN_REQ_STS",			BIT(26),	0},  	{}  };  const struct pmc_bit_map lnl_vnn_req_status_2_map[] = { -	{"eSE_VNN_REQ_STS",			BIT(0)}, -	{"CSMERTC_VNN_REQ_STS",			BIT(1)}, -	{"CSE_VNN_REQ_STS",			BIT(4)}, -	{"ISH_VNN_REQ_STS",			BIT(7)}, -	{"SMT1_VNN_REQ_STS",			BIT(8)}, -	{"CLINK_VNN_REQ_STS",			BIT(14)}, -	{"SMS1_VNN_REQ_STS",			BIT(18)}, -	{"SMS2_VNN_REQ_STS",			BIT(19)}, -	{"GPIOCOM4_VNN_REQ_STS",		BIT(20)}, -	{"GPIOCOM3_VNN_REQ_STS",		BIT(21)}, -	{"GPIOCOM2_VNN_REQ_STS",		BIT(22)}, -	{"GPIOCOM1_VNN_REQ_STS",		BIT(23)}, -	{"GPIOCOM0_VNN_REQ_STS",		BIT(24)}, +	{"eSE_VNN_REQ_STS",			BIT(0),		1}, +	{"CSMERTC_VNN_REQ_STS",			BIT(1),		1}, +	{"CSE_VNN_REQ_STS",			BIT(4),		1}, +	{"ISH_VNN_REQ_STS",			BIT(7),		1}, +	{"SMT1_VNN_REQ_STS",			BIT(8),		1}, +	{"CLINK_VNN_REQ_STS",			BIT(14),	1}, +	{"SMS1_VNN_REQ_STS",			BIT(18),	1}, +	{"SMS2_VNN_REQ_STS",			BIT(19),	1}, +	{"GPIOCOM4_VNN_REQ_STS",		BIT(20),	1}, +	{"GPIOCOM3_VNN_REQ_STS",		BIT(21),	1}, +	{"GPIOCOM2_VNN_REQ_STS",		BIT(22),	0}, +	{"GPIOCOM1_VNN_REQ_STS",		BIT(23),	1}, +	{"GPIOCOM0_VNN_REQ_STS",		BIT(24),	1},  	{}  };  const struct pmc_bit_map lnl_vnn_req_status_3_map[] = { -	{"DISP_SHIM_VNN_REQ_STS",		BIT(2)}, -	{"DTS0_VNN_REQ_STS",			BIT(7)}, -	{"GPIOCOM5_VNN_REQ_STS",		BIT(11)}, +	{"DISP_SHIM_VNN_REQ_STS",		BIT(2),		0}, +	{"DTS0_VNN_REQ_STS",			BIT(7),		0}, +	{"GPIOCOM5_VNN_REQ_STS",		BIT(11),	2},  	{}  };  const struct pmc_bit_map lnl_vnn_misc_status_map[] = { -	{"CPU_C10_REQ_STS",			BIT(0)}, -	{"TS_OFF_REQ_STS",			BIT(1)}, -	{"PNDE_MET_REQ_STS",			BIT(2)}, -	{"PCIE_DEEP_PM_REQ_STS",		BIT(3)}, -	{"PMC_CLK_THROTTLE_EN_REQ_STS",		BIT(4)}, -	{"NPK_VNNAON_REQ_STS",			BIT(5)}, -	{"VNN_SOC_REQ_STS",			BIT(6)}, -	{"ISH_VNNAON_REQ_STS",			BIT(7)}, -	{"D2D_NOC_CFI_QACTIVE_REQ_STS",		BIT(8)}, -	{"D2D_NOC_GPSB_QACTIVE_REQ_STS",	BIT(9)}, -	{"D2D_NOC_IPU_QACTIVE_REQ_STS",		BIT(10)}, -	{"PLT_GREATER_REQ_STS",			BIT(11)}, -	{"PCIE_CLKREQ_REQ_STS",			BIT(12)}, -	{"PMC_IDLE_FB_OCP_REQ_STS",		BIT(13)}, -	{"PM_SYNC_STATES_REQ_STS",		BIT(14)}, -	{"EA_REQ_STS",				BIT(15)}, -	{"MPHY_CORE_OFF_REQ_STS",		BIT(16)}, -	{"BRK_EV_EN_REQ_STS",			BIT(17)}, -	{"AUTO_DEMO_EN_REQ_STS",		BIT(18)}, -	{"ITSS_CLK_SRC_REQ_STS",		BIT(19)}, -	{"LPC_CLK_SRC_REQ_STS",			BIT(20)}, -	{"ARC_IDLE_REQ_STS",			BIT(21)}, -	{"MPHY_SUS_REQ_STS",			BIT(22)}, -	{"FIA_DEEP_PM_REQ_STS",			BIT(23)}, -	{"UXD_CONNECTED_REQ_STS",		BIT(24)}, -	{"ARC_INTERRUPT_WAKE_REQ_STS",	BIT(25)}, -	{"D2D_NOC_DISP_DDI_QACTIVE_REQ_STS",	BIT(26)}, -	{"PRE_WAKE0_REQ_STS",			BIT(27)}, -	{"PRE_WAKE1_REQ_STS",			BIT(28)}, -	{"PRE_WAKE2_EN_REQ_STS",		BIT(29)}, -	{"WOV_REQ_STS",				BIT(30)}, -	{"D2D_NOC_DISP_EDP_QACTIVE_REQ_STS_31",	BIT(31)}, +	{"CPU_C10_REQ_STS",			BIT(0),		0}, +	{"TS_OFF_REQ_STS",			BIT(1),		0}, +	{"PNDE_MET_REQ_STS",			BIT(2),		1}, +	{"PCIE_DEEP_PM_REQ_STS",		BIT(3),		0}, +	{"PMC_CLK_THROTTLE_EN_REQ_STS",		BIT(4),		0}, +	{"NPK_VNNAON_REQ_STS",			BIT(5),		0}, +	{"VNN_SOC_REQ_STS",			BIT(6),		1}, +	{"ISH_VNNAON_REQ_STS",			BIT(7),		0}, +	{"D2D_NOC_CFI_QACTIVE_REQ_STS",		BIT(8),		1}, +	{"D2D_NOC_GPSB_QACTIVE_REQ_STS",	BIT(9),		1}, +	{"D2D_NOC_IPU_QACTIVE_REQ_STS",		BIT(10),	1}, +	{"PLT_GREATER_REQ_STS",			BIT(11),	1}, +	{"PCIE_CLKREQ_REQ_STS",			BIT(12),	0}, +	{"PMC_IDLE_FB_OCP_REQ_STS",		BIT(13),	0}, +	{"PM_SYNC_STATES_REQ_STS",		BIT(14),	0}, +	{"EA_REQ_STS",				BIT(15),	0}, +	{"MPHY_CORE_OFF_REQ_STS",		BIT(16),	0}, +	{"BRK_EV_EN_REQ_STS",			BIT(17),	0}, +	{"AUTO_DEMO_EN_REQ_STS",		BIT(18),	0}, +	{"ITSS_CLK_SRC_REQ_STS",		BIT(19),	1}, +	{"LPC_CLK_SRC_REQ_STS",			BIT(20),	0}, +	{"ARC_IDLE_REQ_STS",			BIT(21),	0}, +	{"MPHY_SUS_REQ_STS",			BIT(22),	0}, +	{"FIA_DEEP_PM_REQ_STS",			BIT(23),	0}, +	{"UXD_CONNECTED_REQ_STS",		BIT(24),	1}, +	{"ARC_INTERRUPT_WAKE_REQ_STS",		BIT(25),	0}, +	{"D2D_NOC_DISP_DDI_QACTIVE_REQ_STS",	BIT(26),	1}, +	{"PRE_WAKE0_REQ_STS",			BIT(27),	1}, +	{"PRE_WAKE1_REQ_STS",			BIT(28),	1}, +	{"PRE_WAKE2_EN_REQ_STS",		BIT(29),	1}, +	{"WOV_REQ_STS",				BIT(30),	0}, +	{"D2D_NOC_DISP_EDP_QACTIVE_REQ_STS_31",	BIT(31),	1},  	{}  };  const struct pmc_bit_map lnl_clocksource_status_map[] = { -	{"AON2_OFF_STS",			BIT(0)}, -	{"AON3_OFF_STS",			BIT(1)}, -	{"AON4_OFF_STS",			BIT(2)}, -	{"AON5_OFF_STS",			BIT(3)}, -	{"AON1_OFF_STS",			BIT(4)}, -	{"MPFPW1_0_PLL_OFF_STS",		BIT(6)}, -	{"USB3_PLL_OFF_STS",			BIT(8)}, -	{"AON3_SPL_OFF_STS",			BIT(9)}, -	{"G5FPW1_PLL_OFF_STS",			BIT(15)}, -	{"XTAL_AGGR_OFF_STS",			BIT(17)}, -	{"USB2_PLL_OFF_STS",			BIT(18)}, -	{"SAF_PLL_OFF_STS",			BIT(19)}, -	{"SE_TCSS_PLL_OFF_STS",			BIT(20)}, -	{"DDI_PLL_OFF_STS",			BIT(21)}, -	{"FILTER_PLL_OFF_STS",			BIT(22)}, -	{"ACE_PLL_OFF_STS",			BIT(24)}, -	{"FABRIC_PLL_OFF_STS",			BIT(25)}, -	{"SOC_PLL_OFF_STS",			BIT(26)}, -	{"REF_OFF_STS",				BIT(28)}, -	{"IMG_OFF_STS",				BIT(29)}, -	{"RTC_PLL_OFF_STS",			BIT(31)}, +	{"AON2_OFF_STS",			BIT(0),		0}, +	{"AON3_OFF_STS",			BIT(1),		1}, +	{"AON4_OFF_STS",			BIT(2),		1}, +	{"AON5_OFF_STS",			BIT(3),		1}, +	{"AON1_OFF_STS",			BIT(4),		0}, +	{"MPFPW1_0_PLL_OFF_STS",		BIT(6),		1}, +	{"USB3_PLL_OFF_STS",			BIT(8),		1}, +	{"AON3_SPL_OFF_STS",			BIT(9),		1}, +	{"G5FPW1_PLL_OFF_STS",			BIT(15),	1}, +	{"XTAL_AGGR_OFF_STS",			BIT(17),	1}, +	{"USB2_PLL_OFF_STS",			BIT(18),	0}, +	{"SAF_PLL_OFF_STS",			BIT(19),	1}, +	{"SE_TCSS_PLL_OFF_STS",			BIT(20),	1}, +	{"DDI_PLL_OFF_STS",			BIT(21),	1}, +	{"FILTER_PLL_OFF_STS",			BIT(22),	1}, +	{"ACE_PLL_OFF_STS",			BIT(24),	0}, +	{"FABRIC_PLL_OFF_STS",			BIT(25),	1}, +	{"SOC_PLL_OFF_STS",			BIT(26),	1}, +	{"REF_OFF_STS",				BIT(28),	1}, +	{"IMG_OFF_STS",				BIT(29),	1}, +	{"RTC_PLL_OFF_STS",			BIT(31),	0}, +	{} +}; + +const struct pmc_bit_map lnl_signal_status_map[] = { +	{"LSX_Wake0_STS",			BIT(0),		0}, +	{"LSX_Wake1_STS",			BIT(1),		0}, +	{"LSX_Wake2_STS",			BIT(2),		0}, +	{"LSX_Wake3_STS",			BIT(3),		0}, +	{"LSX_Wake4_STS",			BIT(4),		0}, +	{"LSX_Wake5_STS",			BIT(5),		0}, +	{"LSX_Wake6_STS",			BIT(6),		0}, +	{"LSX_Wake7_STS",			BIT(7),		0}, +	{"LPSS_Wake0_STS",			BIT(8),		1}, +	{"LPSS_Wake1_STS",			BIT(9),		1}, +	{"Int_Timer_SS_Wake0_STS",		BIT(10),	1}, +	{"Int_Timer_SS_Wake1_STS",		BIT(11),	1}, +	{"Int_Timer_SS_Wake2_STS",		BIT(12),	1}, +	{"Int_Timer_SS_Wake3_STS",		BIT(13),	1}, +	{"Int_Timer_SS_Wake4_STS",		BIT(14),	1}, +	{"Int_Timer_SS_Wake5_STS",		BIT(15),	1}, +	{} +}; + +const struct pmc_bit_map lnl_rsc_status_map[] = { +	{"Memory",				0,		1}, +	{"PSF0",				0,		1}, +	{"PSF4",				0,		1}, +	{"PSF6",				0,		1}, +	{"PSF7",				0,		1}, +	{"PSF8",				0,		1}, +	{"SAF_CFI_LINK",			0,		1}, +	{"SBR",					0,		1},  	{}  }; @@ -331,7 +363,26 @@ const struct pmc_bit_map *lnl_lpm_maps[] = {  	lnl_vnn_req_status_2_map,  	lnl_vnn_req_status_3_map,  	lnl_vnn_misc_status_map, -	mtl_socm_signal_status_map, +	lnl_signal_status_map, +	NULL +}; + +const struct pmc_bit_map *lnl_blk_maps[] = { +	lnl_power_gating_status_0_map, +	lnl_power_gating_status_1_map, +	lnl_power_gating_status_2_map, +	lnl_rsc_status_map, +	lnl_vnn_req_status_0_map, +	lnl_vnn_req_status_1_map, +	lnl_vnn_req_status_2_map, +	lnl_vnn_req_status_3_map, +	lnl_d3_status_0_map, +	lnl_d3_status_1_map, +	lnl_d3_status_2_map, +	lnl_d3_status_3_map, +	lnl_clocksource_status_map, +	lnl_vnn_misc_status_map, +	lnl_signal_status_map,  	NULL  }; @@ -475,6 +526,8 @@ const struct pmc_reg_map lnl_socm_reg_map = {  	.lpm_sts = lnl_lpm_maps,  	.lpm_status_offset = MTL_LPM_STATUS_OFFSET,  	.lpm_live_status_offset = MTL_LPM_LIVE_STATUS_OFFSET, +	.s0ix_blocker_maps = lnl_blk_maps, +	.s0ix_blocker_offset = LNL_S0IX_BLOCKER_OFFSET,  };  #define LNL_NPU_PCI_DEV		0x643e  |