diff options
Diffstat (limited to 'drivers/platform/x86/amd/pmc/pmc-quirks.c')
| -rw-r--r-- | drivers/platform/x86/amd/pmc/pmc-quirks.c | 54 | 
1 files changed, 34 insertions, 20 deletions
| diff --git a/drivers/platform/x86/amd/pmc/pmc-quirks.c b/drivers/platform/x86/amd/pmc/pmc-quirks.c index ded4c84f5ed1..7ffc659b2794 100644 --- a/drivers/platform/x86/amd/pmc/pmc-quirks.c +++ b/drivers/platform/x86/amd/pmc/pmc-quirks.c @@ -28,10 +28,15 @@ static struct quirk_entry quirk_spurious_8042 = {  	.spurious_8042 = true,  }; +static struct quirk_entry quirk_s2idle_spurious_8042 = { +	.s2idle_bug_mmio = FCH_PM_BASE + FCH_PM_SCRATCH, +	.spurious_8042 = true, +}; +  static const struct dmi_system_id fwbug_list[] = {  	{  		.ident = "L14 Gen2 AMD", -		.driver_data = &quirk_s2idle_bug, +		.driver_data = &quirk_s2idle_spurious_8042,  		.matches = {  			DMI_MATCH(DMI_BOARD_VENDOR, "LENOVO"),  			DMI_MATCH(DMI_PRODUCT_NAME, "20X5"), @@ -39,7 +44,7 @@ static const struct dmi_system_id fwbug_list[] = {  	},  	{  		.ident = "T14s Gen2 AMD", -		.driver_data = &quirk_s2idle_bug, +		.driver_data = &quirk_s2idle_spurious_8042,  		.matches = {  			DMI_MATCH(DMI_BOARD_VENDOR, "LENOVO"),  			DMI_MATCH(DMI_PRODUCT_NAME, "20XF"), @@ -47,7 +52,7 @@ static const struct dmi_system_id fwbug_list[] = {  	},  	{  		.ident = "X13 Gen2 AMD", -		.driver_data = &quirk_s2idle_bug, +		.driver_data = &quirk_s2idle_spurious_8042,  		.matches = {  			DMI_MATCH(DMI_BOARD_VENDOR, "LENOVO"),  			DMI_MATCH(DMI_PRODUCT_NAME, "20XH"), @@ -55,7 +60,7 @@ static const struct dmi_system_id fwbug_list[] = {  	},  	{  		.ident = "T14 Gen2 AMD", -		.driver_data = &quirk_s2idle_bug, +		.driver_data = &quirk_s2idle_spurious_8042,  		.matches = {  			DMI_MATCH(DMI_BOARD_VENDOR, "LENOVO"),  			DMI_MATCH(DMI_PRODUCT_NAME, "20XK"), @@ -63,7 +68,7 @@ static const struct dmi_system_id fwbug_list[] = {  	},  	{  		.ident = "T14 Gen1 AMD", -		.driver_data = &quirk_s2idle_bug, +		.driver_data = &quirk_s2idle_spurious_8042,  		.matches = {  			DMI_MATCH(DMI_BOARD_VENDOR, "LENOVO"),  			DMI_MATCH(DMI_PRODUCT_NAME, "20UD"), @@ -71,7 +76,7 @@ static const struct dmi_system_id fwbug_list[] = {  	},  	{  		.ident = "T14 Gen1 AMD", -		.driver_data = &quirk_s2idle_bug, +		.driver_data = &quirk_s2idle_spurious_8042,  		.matches = {  			DMI_MATCH(DMI_BOARD_VENDOR, "LENOVO"),  			DMI_MATCH(DMI_PRODUCT_NAME, "20UE"), @@ -79,7 +84,7 @@ static const struct dmi_system_id fwbug_list[] = {  	},  	{  		.ident = "T14s Gen1 AMD", -		.driver_data = &quirk_s2idle_bug, +		.driver_data = &quirk_s2idle_spurious_8042,  		.matches = {  			DMI_MATCH(DMI_BOARD_VENDOR, "LENOVO"),  			DMI_MATCH(DMI_PRODUCT_NAME, "20UH"), @@ -87,7 +92,7 @@ static const struct dmi_system_id fwbug_list[] = {  	},  	{  		.ident = "T14s Gen1 AMD", -		.driver_data = &quirk_s2idle_bug, +		.driver_data = &quirk_s2idle_spurious_8042,  		.matches = {  			DMI_MATCH(DMI_BOARD_VENDOR, "LENOVO"),  			DMI_MATCH(DMI_PRODUCT_NAME, "20UJ"), @@ -95,7 +100,7 @@ static const struct dmi_system_id fwbug_list[] = {  	},  	{  		.ident = "P14s Gen1 AMD", -		.driver_data = &quirk_s2idle_bug, +		.driver_data = &quirk_s2idle_spurious_8042,  		.matches = {  			DMI_MATCH(DMI_BOARD_VENDOR, "LENOVO"),  			DMI_MATCH(DMI_PRODUCT_NAME, "20Y1"), @@ -103,7 +108,7 @@ static const struct dmi_system_id fwbug_list[] = {  	},  	{  		.ident = "P14s Gen2 AMD", -		.driver_data = &quirk_s2idle_bug, +		.driver_data = &quirk_s2idle_spurious_8042,  		.matches = {  			DMI_MATCH(DMI_BOARD_VENDOR, "LENOVO"),  			DMI_MATCH(DMI_PRODUCT_NAME, "21A0"), @@ -111,7 +116,7 @@ static const struct dmi_system_id fwbug_list[] = {  	},  	{  		.ident = "P14s Gen2 AMD", -		.driver_data = &quirk_s2idle_bug, +		.driver_data = &quirk_s2idle_spurious_8042,  		.matches = {  			DMI_MATCH(DMI_BOARD_VENDOR, "LENOVO"),  			DMI_MATCH(DMI_PRODUCT_NAME, "21A1"), @@ -152,7 +157,7 @@ static const struct dmi_system_id fwbug_list[] = {  	},  	{  		.ident = "IdeaPad 1 14AMN7", -		.driver_data = &quirk_s2idle_bug, +		.driver_data = &quirk_s2idle_spurious_8042,  		.matches = {  			DMI_MATCH(DMI_BOARD_VENDOR, "LENOVO"),  			DMI_MATCH(DMI_PRODUCT_NAME, "82VF"), @@ -160,7 +165,7 @@ static const struct dmi_system_id fwbug_list[] = {  	},  	{  		.ident = "IdeaPad 1 15AMN7", -		.driver_data = &quirk_s2idle_bug, +		.driver_data = &quirk_s2idle_spurious_8042,  		.matches = {  			DMI_MATCH(DMI_BOARD_VENDOR, "LENOVO"),  			DMI_MATCH(DMI_PRODUCT_NAME, "82VG"), @@ -168,7 +173,7 @@ static const struct dmi_system_id fwbug_list[] = {  	},  	{  		.ident = "IdeaPad 1 15AMN7", -		.driver_data = &quirk_s2idle_bug, +		.driver_data = &quirk_s2idle_spurious_8042,  		.matches = {  			DMI_MATCH(DMI_BOARD_VENDOR, "LENOVO"),  			DMI_MATCH(DMI_PRODUCT_NAME, "82X5"), @@ -176,7 +181,7 @@ static const struct dmi_system_id fwbug_list[] = {  	},  	{  		.ident = "IdeaPad Slim 3 14AMN8", -		.driver_data = &quirk_s2idle_bug, +		.driver_data = &quirk_s2idle_spurious_8042,  		.matches = {  			DMI_MATCH(DMI_BOARD_VENDOR, "LENOVO"),  			DMI_MATCH(DMI_PRODUCT_NAME, "82XN"), @@ -184,7 +189,7 @@ static const struct dmi_system_id fwbug_list[] = {  	},  	{  		.ident = "IdeaPad Slim 3 15AMN8", -		.driver_data = &quirk_s2idle_bug, +		.driver_data = &quirk_s2idle_spurious_8042,  		.matches = {  			DMI_MATCH(DMI_BOARD_VENDOR, "LENOVO"),  			DMI_MATCH(DMI_PRODUCT_NAME, "82XQ"), @@ -193,7 +198,7 @@ static const struct dmi_system_id fwbug_list[] = {  	/* https://gitlab.freedesktop.org/drm/amd/-/issues/4434 */  	{  		.ident = "Lenovo Yoga 6 13ALC6", -		.driver_data = &quirk_s2idle_bug, +		.driver_data = &quirk_s2idle_spurious_8042,  		.matches = {  			DMI_MATCH(DMI_BOARD_VENDOR, "LENOVO"),  			DMI_MATCH(DMI_PRODUCT_NAME, "82ND"), @@ -202,7 +207,7 @@ static const struct dmi_system_id fwbug_list[] = {  	/* https://gitlab.freedesktop.org/drm/amd/-/issues/2684 */  	{  		.ident = "HP Laptop 15s-eq2xxx", -		.driver_data = &quirk_s2idle_bug, +		.driver_data = &quirk_s2idle_spurious_8042,  		.matches = {  			DMI_MATCH(DMI_SYS_VENDOR, "HP"),  			DMI_MATCH(DMI_PRODUCT_NAME, "HP Laptop 15s-eq2xxx"), @@ -285,6 +290,16 @@ void amd_pmc_quirks_init(struct amd_pmc_dev *dev)  {  	const struct dmi_system_id *dmi_id; +	/* +	 * IRQ1 may cause an interrupt during resume even without a keyboard +	 * press. +	 * +	 * Affects Renoir, Cezanne and Barcelo SoCs +	 * +	 * A solution is available in PMFW 64.66.0, but it must be activated by +	 * SBIOS. If SBIOS is known to have the fix a quirk can be added for +	 * a given system to avoid workaround. +	 */  	if (dev->cpu_id == AMD_CPU_ID_CZN)  		dev->disable_8042_wakeup = true; @@ -295,6 +310,5 @@ void amd_pmc_quirks_init(struct amd_pmc_dev *dev)  	if (dev->quirks->s2idle_bug_mmio)  		pr_info("Using s2idle quirk to avoid %s platform firmware bug\n",  			dmi_id->ident); -	if (dev->quirks->spurious_8042) -		dev->disable_8042_wakeup = true; +	dev->disable_8042_wakeup = dev->quirks->spurious_8042;  } | 
