From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from smtp.kernel.org (aws-us-west-2-korg-mail-1.web.codeaurora.org [10.30.226.201]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 9902B19E810; Tue, 9 Jul 2024 16:20:15 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=10.30.226.201 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1720542015; cv=none; b=SV2no+BgdmJ/ZwqBcFDylSr80W77eKvgMiCH9ZLppuODB/CwKNe4R1HwCTjaoNtJlt0Y/mWjL3vnB04PV3T/EXsaq1n01prNU9TGc+x8ZbpHBEYws3XVzGznZDrX/UruXIlATB1lD5xHqnxJCt0fMVCQvPt6TpOdVZrMGya/aX4= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1720542015; c=relaxed/simple; bh=FAAQ7hUngIYfV+m+yhEiNqSqomtGq42oNGZTyjozpxk=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=RC1Tp+LAKrCF4B+6XHVcvU7rsDFymmYLBK3cBNy/fKe891fCfX/HbVRBqiJzJnMVZQtB5/bVXMRMKmn6gY6cytUrPB6DHfV4WJDb2s/N7eo5c+/gX0agYbft5S4KfE7CcDCbhIdYB6/Kvt4WYwgcAFOwpM3mc5fEdLw7jWd+Bhg= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b=m9Dsn8bV; arc=none smtp.client-ip=10.30.226.201 Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b="m9Dsn8bV" Received: by smtp.kernel.org (Postfix) with ESMTPSA id 275F2C3277B; Tue, 9 Jul 2024 16:20:14 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1720542015; bh=FAAQ7hUngIYfV+m+yhEiNqSqomtGq42oNGZTyjozpxk=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=m9Dsn8bVrioXbWBfyF/LcM2h+g0/smSWgC1nsJ36atJg42rLU5iFxSipOoVHCsXcc E0RdYB6nve8cdcFKI/HMPJ5Het6lGFfdpBtiA17bnQNb+V0r2vCoB9RGcAhBRV4YKQ 1JTlrz793gPhFq//6gA48MAzRlBE5mrTmhC8F//+TTjAcHXqoCrFgYAFJwr3TIAiqV K1zvu5FivpGnnY8p5/Vee7pYcEuLSBIFgDDw8VDR2uFuYd+Q2btgQfvVvNRU7DPEFw Jth7GLLBq+fx65+srzeetIEYI9frKc4ywsL8B0MsvQYmmSTTXvhn39bTP92WKFAdAa o+i2NJGCac82g== From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: Tobias Jakobi , Dmitry Torokhov , Sasha Levin , wse@tuxedocomputers.com, szfabian@bluemarch.art, eshimanovich@chromium.org, linux-input@vger.kernel.org Subject: [PATCH AUTOSEL 6.9 03/40] Input: i8042 - add Ayaneo Kun to i8042 quirk table Date: Tue, 9 Jul 2024 12:18:43 -0400 Message-ID: <20240709162007.30160-3-sashal@kernel.org> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20240709162007.30160-1-sashal@kernel.org> References: <20240709162007.30160-1-sashal@kernel.org> Precedence: bulk X-Mailing-List: stable@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-stable: review X-Patchwork-Hint: Ignore X-stable-base: Linux 6.9.8 Content-Transfer-Encoding: 8bit From: Tobias Jakobi [ Upstream commit 955af6355ddfe35140f9706a635838212a32513b ] See the added comment for details. Also fix a typo in the quirk's define. Signed-off-by: Tobias Jakobi Link: https://lore.kernel.org/r/20240531190100.3874731-1-tjakobi@math.uni-bielefeld.de Signed-off-by: Dmitry Torokhov Signed-off-by: Sasha Levin --- drivers/input/serio/i8042-acpipnpio.h | 18 ++++++++++++++++-- 1 file changed, 16 insertions(+), 2 deletions(-) diff --git a/drivers/input/serio/i8042-acpipnpio.h b/drivers/input/serio/i8042-acpipnpio.h index dfc6c581873b7..5b50475ec4140 100644 --- a/drivers/input/serio/i8042-acpipnpio.h +++ b/drivers/input/serio/i8042-acpipnpio.h @@ -76,7 +76,7 @@ static inline void i8042_write_command(int val) #define SERIO_QUIRK_PROBE_DEFER BIT(5) #define SERIO_QUIRK_RESET_ALWAYS BIT(6) #define SERIO_QUIRK_RESET_NEVER BIT(7) -#define SERIO_QUIRK_DIECT BIT(8) +#define SERIO_QUIRK_DIRECT BIT(8) #define SERIO_QUIRK_DUMBKBD BIT(9) #define SERIO_QUIRK_NOLOOP BIT(10) #define SERIO_QUIRK_NOTIMEOUT BIT(11) @@ -1332,6 +1332,20 @@ static const struct dmi_system_id i8042_dmi_quirk_table[] __initconst = { .driver_data = (void *)(SERIO_QUIRK_NOMUX | SERIO_QUIRK_RESET_ALWAYS | SERIO_QUIRK_NOLOOP | SERIO_QUIRK_NOPNP) }, + { + /* + * The Ayaneo Kun is a handheld device where some the buttons + * are handled by an AT keyboard. The keyboard is usually + * detected as raw, but sometimes, usually after a cold boot, + * it is detected as translated. Make sure that the keyboard + * is always in raw mode. + */ + .matches = { + DMI_EXACT_MATCH(DMI_BOARD_VENDOR, "AYANEO"), + DMI_MATCH(DMI_BOARD_NAME, "KUN"), + }, + .driver_data = (void *)(SERIO_QUIRK_DIRECT) + }, { } }; @@ -1655,7 +1669,7 @@ static void __init i8042_check_quirks(void) if (quirks & SERIO_QUIRK_RESET_NEVER) i8042_reset = I8042_RESET_NEVER; } - if (quirks & SERIO_QUIRK_DIECT) + if (quirks & SERIO_QUIRK_DIRECT) i8042_direct = true; if (quirks & SERIO_QUIRK_DUMBKBD) i8042_dumbkbd = true; -- 2.43.0