From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from mail-dy1-f169.google.com (mail-dy1-f169.google.com [74.125.82.169]) (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 2809CEED8 for ; Sat, 24 Jan 2026 01:49:13 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=74.125.82.169 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1769219354; cv=none; b=l0/CGs4jV2wqrB80D7eW9v2Sy/6jbDuf8jeWcpSTjfM53iTMbsR/LHn2f7krWzG96iGRs3m+c9+N1vTQWVzPNG8FB8tGZMwPGSktISd1zkFM89VEMEg1PWUzWcGihDEfpWN/sQpQ1xgGTCBLm+UtiXAyUVeJrANOKQGuS4NwrEo= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1769219354; c=relaxed/simple; bh=Iz/O24RRXRopA/iYdltADd1JWiRCy/cbu+LwfrkUwAw=; h=From:To:Cc:Subject:Date:Message-ID:MIME-Version; b=hAxsYKwjwTc34E6Qb5Sa6yczgDE1bTM+fdPCXhrxk1pSOqh76MF0MWza3uisFbSVEhvS6MatZD/0Z2Man0p4uWqgjU7rBQoRCdLr8gaq/1sBHXbm3+rV+tYU5ZbsoUYCzHbNWQpHUWSJtB4n2+PRKHoHwQgzWyLcX+aYHp9gntw= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com; spf=pass smtp.mailfrom=gmail.com; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b=cGaagszN; arc=none smtp.client-ip=74.125.82.169 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="cGaagszN" Received: by mail-dy1-f169.google.com with SMTP id 5a478bee46e88-2b4520f6b32so4540709eec.0 for ; Fri, 23 Jan 2026 17:49:13 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1769219352; x=1769824152; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:from:to:cc:subject:date:message-id:reply-to; bh=Uo6jHEB3ezzd+BlMZazV0yjnUEyUOn6k4aOM+PmOEkM=; b=cGaagszNxVMFiSgF8MuB2EjFKKMtEHfjVJl99s2cLFrSGV66ItGwhAckoHwVN7phN4 8P/L8wQ/b0U9LyAuNsdxRCG+w74g4frGfaSmkxMAzhIZk5wtN8tGpas89w83mrYitUdZ IomeE41Xs3KXNVq89guZFaRm7iWi3Cyzh6Pf+3rWG6/a4BvQ8chA17cIc8AH/zadEG+0 Ahy7o88W4Cmxbs+2lugORLbHr2N2euOWExT4mh4xNwKvGtobDbR8eFCUaZGBWfezo5Vr MYO8f2ExIIcgbvyCwROHhk77GIKyQ3Xpzrn6bi5iyE7iCBLqHJ4AKV6QULkNtRX210q/ To4A== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1769219352; x=1769824152; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:x-gm-gg:x-gm-message-state:from:to:cc:subject:date :message-id:reply-to; bh=Uo6jHEB3ezzd+BlMZazV0yjnUEyUOn6k4aOM+PmOEkM=; b=nTLjdABpR1yeEhNz+faPV1BJt7AXzDkkJaIqoZol8fPf7FOUDjRRsG6p5hMquQyjk5 CV+cLK16D84DFIrtxBIx5WLUNRCJwtQp1r9lHIKMzNbXg4vIre2QSpZdhWwJ/tJFUI1u L50og8tSlzb3+b3iEb8CUwKuPz8yGYli/b/NGB6rCtRiXoj1xaRSHwWpZ0n8tFb2ftj4 JcVtvfi7jgx+ydwKGvsA945Iqn7Cnp7Xl7RMCex/r/HDEWZbf9Sgi7HJq356DMbHXwdV a2nsnXKpXto6HlQvrQjQLPQMAyhxKa9BfeLF7wbUSk1AcuLFoVmKM6EqMfAHowZB9QrA Fh0A== X-Forwarded-Encrypted: i=1; AJvYcCUnwBHCaD9OSjK0YYXGLBEQVLizIhs8Lc3eP233F2v+Mcx9CvQmJWoSzigh9nYy6P0aP+yxS+MPTaA9+A==@vger.kernel.org X-Gm-Message-State: AOJu0YwDaT61PNQGWUzIpYX3GcBZgTyKBCdqCoZagU6f7uDWzaYXAOwc /dXLg+AYdpMNL9UgCM8zhd7PGxs2/iTu/V59AE9GOOLwR/MZIlEFlPPf X-Gm-Gg: AZuq6aJ/dDtj/Z0XrULz4r2SsxNa1BjijL5diWkj8KKwA1uWh97LYtxtUZD1Z1Dky8q z757+484J4OiuqLYV7fnQTirmjkrG5nVXR4CfwhF/F458GVIP9sCCcpC/6m6CeyhzCs2PsFKHNu FfTMHwT0sMM6d8Dhc3uVzhQrWjLQ6NrqRwJkUdQ2qbeEX89Rdbz5sOtR77JXUCsrs4KQu+s5z2i JoNt38tspgJT59ca2jCQPmnyd6r6t55R2vMZYhCFU8nSFUuDO/zSXRpVek9pZI4gaeXZvADoaPF n8Kr5iqbfKKQ0jHkohq2p1LeR2IS24sY+9fr9fXu/ubvq5Zl6cAD9TOG/TOXAqu9uk4EUGbBKts vKwNCc0y+E/gwM1XhAxAOafrNsHhgoTVCcOOOj95x10/weapRHxO5iZ29YBf2wgm6nR+7dcVUdz SOyITV8ZTWsJ95DXgpQjfVGTNxShrEEVgd04BtnlGEccCQBtyRcLfhGGuuO/lIxgE= X-Received: by 2002:a05:7300:8183:b0:2b6:b23b:d488 with SMTP id 5a478bee46e88-2b739b71186mr3129087eec.25.1769219352182; Fri, 23 Jan 2026 17:49:12 -0800 (PST) Received: from lappy (108-228-232-20.lightspeed.sndgca.sbcglobal.net. [108.228.232.20]) by smtp.gmail.com with ESMTPSA id 5a478bee46e88-2b73aa22707sm5160014eec.29.2026.01.23.17.49.11 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 23 Jan 2026 17:49:11 -0800 (PST) From: "Derek J. Clark" To: Jiri Kosina , Benjamin Tissoires Cc: Mario Limonciello , Zhixin Zhang , Mia Shao , Mark Pearson , "Pierre-Loup A . Griffais" , "Derek J . Clark" , linux-input@vger.kernel.org, linux-doc@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH v3 00/16] HID: Add Legion Go and Go S Drivers Date: Sat, 24 Jan 2026 01:48:51 +0000 Message-ID: <20260124014907.991265-1-derekjohn.clark@gmail.com> X-Mailer: git-send-email 2.52.0 Precedence: bulk X-Mailing-List: linux-input@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit This series adds configuration driver support for the Legion Go S, Legion Go, and Legion Go 2 built-in controller HID interfaces. This allows for configuring hardware specific attributes such as the auso sleep timeout, rumble intensity, etc. non-configuration reports are forwarded to the HID subsystem to ensure no loss of functionality in userspace. Basic gamepad functionality is provided through xpad, while advanced features are currently only implemented in userspace daemons such as InputPlumber[1]. I plan to move this functionality into the kernel in a later patch series. Three new device.h macros are added that solve a fairly specific problem. Many of the attributes need to have the same name as other attributes when they are in separate attribute subdirectories. The previous version of this series, along with the upcoming his-asus-ally driver[2] use this macro to simplify the sysfs by removing redundancy. An upcoming out of tree driver for the Zotac Zone [3] also found this macro to be useful. This greatly reduces the path length and term redundancy of file paths in the sysfs, while also allowing for cleaner subdirectories that are grouped by functionality. Rather than carry the same macro in four drivers, it seems beneficial to me that we include the macro with the other device macros. A new HID uevent property is also added, HID_FIRMWARE_VERSION, so as to permit fwupd to read the firmware version of the Go S HID interface without detaching the kernel driver. Finally, there are some checkpatch warnings that will need to be supressed: WARNING: ENOSYS means 'invalid syscall nr' and nothing else 1292: FILE: drivers/hid/lenovo-legos-hid/lenovo-legos-hid-config.c:1085: + case -ENOSYS: /* during rmmod -ENOSYS is expected */ This error handling case was added as it is experienced in the real world when the driver is rmmod. The LED subsystem produces this error code in its legacy code and this is not a new novel use of -ENOSYS, we are simply catching the case to avoid spurious errors in dmesg when the drivers are removed. [1]: https://github.com/ShadowBlip/InputPlumber/tree/main/src/drivers/lego [2]: https://lore.kernel.org/all/20240806081212.56860-1-luke@ljones.dev/ [3]: https://github.com/flukejones/linux/tree/wip/zotac-zone-6.15/drivers/hid/zotac-zone-hid Signed-off-by: Derek J. Clark --- Change Log V3: - Fix Documentation formatting by removing extra + characters - Fix bugs in hid-lenovo-go-s IMU & TP RO attributes being tied to the wrong _show function. - Rename enume os_mode_index to os_mode_types_index to fix collision with os_mode_index attribute. - Remove accidental rename for enabled->enable attributes in patch 4 - Add SOB for Mario in patch 10 as Co-Developer V2: https://lore.kernel.org/linux-input/20251229031753.581664-1-derekjohn.clark@gmail.com/ - Break up adding the Go S driver into feature specific patches - Rename Go S driver from lenovo-legos-hid to hid-lenovo-go-s - Drop the arbitrary uevent properties patch - Add Go serires driver - Move DEVICE_ATTR_NAMED macros to device.h V1: https://lore.kernel.org/linux-input/20250703004943.515919-1-derekjohn.clark@gmail.com/ Derek J. Clark (15): include: device.h: Add named device attributes HID: hid-lenovo-go: Add Lenovo Legion Go Series HID Driver HID: hid-lenovo-go: Add Feature Status Attributes HID: hid-lenovo-go: Add Rumble and Haptic Settings HID: hid-lenovo-go: Add FPS Mode DPI settings HID: hid-lenovo-go: Add RGB LED control interface HID: hid-lenovo-go: Add Calibration Settings HID: hid-lenovo-go: Add OS Mode Toggle HID: hid-lenovo-go-s: Add Lenovo Legion Go S Series HID Driver HID: hid-lenovo-go-s: Add MCU ID Attribute HID: hid-lenovo-go-s: Add Feature Status Attributes HID: hid-lenovo-go-s: Add Touchpad Mode Attributes HID: hid-lenovo-go-s: Add RGB LED control interface HID: hid-lenovo-go-s: Add IMU and Touchpad RO Attributes HID: Add documentation for Lenovo Legion Go drivers Mario Limonciello (1): HID: Include firmware version in the uevent .../ABI/testing/sysfs-driver-hid-lenovo-go | 724 +++++ .../ABI/testing/sysfs-driver-hid-lenovo-go-s | 304 +++ MAINTAINERS | 11 + drivers/hid/Kconfig | 24 + drivers/hid/Makefile | 2 + drivers/hid/hid-core.c | 5 + drivers/hid/hid-ids.h | 7 + drivers/hid/hid-lenovo-go-s.c | 1577 +++++++++++ drivers/hid/hid-lenovo-go.c | 2399 +++++++++++++++++ include/linux/device.h | 46 + include/linux/hid.h | 1 + 11 files changed, 5100 insertions(+) create mode 100644 Documentation/ABI/testing/sysfs-driver-hid-lenovo-go create mode 100644 Documentation/ABI/testing/sysfs-driver-hid-lenovo-go-s create mode 100644 drivers/hid/hid-lenovo-go-s.c create mode 100644 drivers/hid/hid-lenovo-go.c -- 2.52.0