Received: by 2002:a05:7412:b995:b0:f9:9502:5bb8 with SMTP id it21csp6549766rdb; Tue, 2 Jan 2024 05:48:59 -0800 (PST) X-Google-Smtp-Source: AGHT+IE8Axs0jmZSvLyJjAO8S4MNtvTgZ8T0i3+7F5Y682ztdKH14IFZxmg7FltdYLfdpeRCV+Xx X-Received: by 2002:a17:906:2da:b0:a23:b8e:15c with SMTP id 26-20020a17090602da00b00a230b8e015cmr6372003ejk.25.1704203339723; Tue, 02 Jan 2024 05:48:59 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1704203339; cv=none; d=google.com; s=arc-20160816; b=M6KDaD32VD/bHtXEMqCvuTR2DQWsKQl71Qryyf8ZaepoDNNrtSkm98RXNM7+vEuv1C 09jlWqzTWPXLyurjnmNLWVbvigwaK7wZYtcRn4kKae45ZTlPT9qWrPZ3r9mar+bHsyrm 2MDrVxXLR+qVqXqiNCuptAFbjZzkq20YfU4zXQzwNSBv1gTJtMAjw+ZNBByKkGi+FwlJ 1Z59wwLYyepGlBlg6MXJerlvFcITzesHAstzpxj12eNydBa6vqBhsznMfCV6gZ/EvsMR Geeawk/hzuWDOex4Z61ZdMk9w9lNDYjSdGP93Vg8GcTh3vtZovgeHVYenA7LYspR8uaJ P/Ww== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:message-id:date:subject:cc:to :from:dkim-signature; bh=xJNhvlNEbhz6wkYNou1HHqLAU/bd7n4aZ11XtrXYphc=; fh=oC5agSExpC7i0UPka8s10VSYwlSZVWki/wwKTq0sciI=; b=TGhaIcMmFW7fLG7cTFs/Pqyw18V65t0HiAGvm5g3ooSctRgw8I6CgFd2MtX2uWV9RR SZpB1GWpzRPdKnz459OGZ2aGdxZ/7rndxcEzWdFRpTGR13E4LF3wJLb5XmGm7neRn2I0 54SJi1/RdQbL4PDEgKQaju8n934de0Uhw4mUark7R3nYkXKXSwpZVoCaO2P/puM0q4Gz K8zOyZirJtBcWA2SD3Koc/BoOAK1IsFHsXd0TVlalNBvtjNQ5QgAf5T7AniejCsU5l7Z X1q/GWY04t9SI5B8zAq7BPN5TZMP/LycePBg/V52uxDM5FkHYFAcKPKzS+yd4u48sRdX Usow== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@tuxedocomputers.com header.s=default header.b=IJ7RiyOs; spf=pass (google.com: domain of linux-kernel+bounces-14437-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:4601:e00::3 as permitted sender) smtp.mailfrom="linux-kernel+bounces-14437-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=tuxedocomputers.com Return-Path: Received: from am.mirrors.kernel.org (am.mirrors.kernel.org. [2604:1380:4601:e00::3]) by mx.google.com with ESMTPS id fc5-20020a1709073a4500b00a277335cec7si3960954ejc.570.2024.01.02.05.48.59 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 02 Jan 2024 05:48:59 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel+bounces-14437-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:4601:e00::3 as permitted sender) client-ip=2604:1380:4601:e00::3; Authentication-Results: mx.google.com; dkim=pass header.i=@tuxedocomputers.com header.s=default header.b=IJ7RiyOs; spf=pass (google.com: domain of linux-kernel+bounces-14437-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:4601:e00::3 as permitted sender) smtp.mailfrom="linux-kernel+bounces-14437-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=tuxedocomputers.com Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by am.mirrors.kernel.org (Postfix) with ESMTPS id 788681F22BD2 for ; Tue, 2 Jan 2024 13:48:59 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 7F8E7101C4; Tue, 2 Jan 2024 13:48:48 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=tuxedocomputers.com header.i=@tuxedocomputers.com header.b="IJ7RiyOs" X-Original-To: linux-kernel@vger.kernel.org Received: from mail.tuxedocomputers.com (mail.tuxedocomputers.com [157.90.84.7]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id D6EB8FBFC; Tue, 2 Jan 2024 13:48:43 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=tuxedocomputers.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=tuxedocomputers.com Received: from wse.fritz.box (p5de453e7.dip0.t-ipconnect.de [93.228.83.231]) (Authenticated sender: wse@tuxedocomputers.com) by mail.tuxedocomputers.com (Postfix) with ESMTPA id DA3822FC0048; Tue, 2 Jan 2024 14:48:35 +0100 (CET) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=tuxedocomputers.com; s=default; t=1704203315; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version: content-transfer-encoding:content-transfer-encoding; bh=xJNhvlNEbhz6wkYNou1HHqLAU/bd7n4aZ11XtrXYphc=; b=IJ7RiyOsDKx4+ZQOgaBao2511oVmSJCygE7sKa/jJ/hpl4zzO1sI7iynQXe7+6WXxweu0W SGj5cPtPvV/8FCZOdmyKGTT/l/PxVsEQJsZZqHlXKqZeajmxBewdvo9Sim/We0wEdYlPrw KAscv0mcqWQmEiv3rey+p8b612BlZu8= Authentication-Results: mail.tuxedocomputers.com; auth=pass smtp.auth=wse@tuxedocomputers.com smtp.mailfrom=wse@tuxedocomputers.com From: Werner Sembach To: Dmitry Torokhov Cc: Werner Sembach , linux-input@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH 1/2] i8042: Add forcenorestore quirk to leave controller untouched even on s3 Date: Tue, 2 Jan 2024 14:48:31 +0100 Message-Id: <20240102134833.68646-1-wse@tuxedocomputers.com> X-Mailer: git-send-email 2.34.1 Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit On s3 resume the i8042 driver tries to restore the controller to a known state by reinitializing things, however can this confuses the controller with different effects. Mostly occasionally unresponsive keyboards after resume. These issues do not rise on s0ix resume as here the controller is assumed to preserved its state from before suspend. This patch adds a quirk for devices where the reinitialization on s3 resume is not needed and might be harmful as described above. It does this by using the s0ix resume code path at selected locations. This new quirk goes beyond what the preexisting reset=never quirk does, which only skips some reinitialization steps. Signed-off-by: Werner Sembach Cc: stable@vger.kernel.org --- drivers/input/serio/i8042-acpipnpio.h | 10 +++++++--- drivers/input/serio/i8042.c | 10 +++++++--- 2 files changed, 14 insertions(+), 6 deletions(-) diff --git a/drivers/input/serio/i8042-acpipnpio.h b/drivers/input/serio/i8042-acpipnpio.h index b585b1dab870e..10ec4534e5e14 100644 --- a/drivers/input/serio/i8042-acpipnpio.h +++ b/drivers/input/serio/i8042-acpipnpio.h @@ -83,6 +83,7 @@ static inline void i8042_write_command(int val) #define SERIO_QUIRK_KBDRESET BIT(12) #define SERIO_QUIRK_DRITEK BIT(13) #define SERIO_QUIRK_NOPNP BIT(14) +#define SERIO_QUIRK_FORCENORESTORE BIT(15) /* Quirk table for different mainboards. Options similar or identical to i8042 * module parameters. @@ -1657,6 +1658,8 @@ static void __init i8042_check_quirks(void) if (quirks & SERIO_QUIRK_NOPNP) i8042_nopnp = true; #endif + if (quirks & SERIO_QUIRK_FORCENORESTORE) + i8042_forcenorestore = true; } #else static inline void i8042_check_quirks(void) {} @@ -1690,7 +1693,7 @@ static int __init i8042_platform_init(void) i8042_check_quirks(); - pr_debug("Active quirks (empty means none):%s%s%s%s%s%s%s%s%s%s%s%s%s\n", + pr_debug("Active quirks (empty means none):%s%s%s%s%s%s%s%s%s%s%s%s%s%s\n", i8042_nokbd ? " nokbd" : "", i8042_noaux ? " noaux" : "", i8042_nomux ? " nomux" : "", @@ -1710,10 +1713,11 @@ static int __init i8042_platform_init(void) "", #endif #ifdef CONFIG_PNP - i8042_nopnp ? " nopnp" : ""); + i8042_nopnp ? " nopnp" : "", #else - ""); + "", #endif + i8042_forcenorestore ? " forcenorestore" : ""); retval = i8042_pnp_init(); if (retval) diff --git a/drivers/input/serio/i8042.c b/drivers/input/serio/i8042.c index 9fbb8d31575ae..2233d93f90e81 100644 --- a/drivers/input/serio/i8042.c +++ b/drivers/input/serio/i8042.c @@ -115,6 +115,10 @@ module_param_named(nopnp, i8042_nopnp, bool, 0); MODULE_PARM_DESC(nopnp, "Do not use PNP to detect controller settings"); #endif +static bool i8042_forcenorestore; +module_param_named(forcenorestore, i8042_forcenorestore, bool, 0); +MODULE_PARM_DESC(forcenorestore, "Force no restore on s3 resume, copying s2idle behaviour"); + #define DEBUG #ifdef DEBUG static bool i8042_debug; @@ -1232,7 +1236,7 @@ static int i8042_pm_suspend(struct device *dev) { int i; - if (pm_suspend_via_firmware()) + if (!i8042_forcenorestore && pm_suspend_via_firmware()) i8042_controller_reset(true); /* Set up serio interrupts for system wakeup. */ @@ -1248,7 +1252,7 @@ static int i8042_pm_suspend(struct device *dev) static int i8042_pm_resume_noirq(struct device *dev) { - if (!pm_resume_via_firmware()) + if (i8042_forcenorestore || !pm_resume_via_firmware()) i8042_interrupt(0, NULL); return 0; @@ -1271,7 +1275,7 @@ static int i8042_pm_resume(struct device *dev) * not restore the controller state to whatever it had been at boot * time, so we do not need to do anything. */ - if (!pm_suspend_via_firmware()) + if (i8042_forcenorestore || !pm_suspend_via_firmware()) return 0; /* -- 2.34.1