From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from mail-ed1-f48.google.com (mail-ed1-f48.google.com [209.85.208.48]) (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 2BCEC36C592 for ; Sat, 2 May 2026 12:41:16 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.208.48 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1777725679; cv=none; b=JRnXnH94mRVlu06zUcmLLe5oi5GEyiSGEWZSZjt+4CzuJVJj2NzUztHJxCVr5l9zEcKvUoVBb7ZZk/rlHNiOUHMvCpaU8jjvsq4aUUp8IjaTNDYpl8G92o0ZVe2Nh5Hli2UpgeUUSIo+3X1OdncMsiq1CRgq4rCqTXa6/rVw63s= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1777725679; c=relaxed/simple; bh=bzK7TuhI7iXeChjCRE/yKbFe3uEBIwi8ReixnO3VzD0=; h=From:To:Cc:Subject:Date:Message-ID:MIME-Version:Content-Type; b=ewFD+OLB9zYjC/HfMNs3MjBT6ju9XjCNvrofgBAhIQJ0EUeF/nulSh7w6eVBQ+dPXMlnZePKzB7DOB4Hn/1WEW/IepRQmr3zdIdIglhvrMNI2ngWhVWcmE7mK5q6SeOCZznZGEW5gJS3zpDoYuM2WOciwS7m1tqA4ykr4MKAUpc= 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=szC/F6aa; arc=none smtp.client-ip=209.85.208.48 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="szC/F6aa" Received: by mail-ed1-f48.google.com with SMTP id 4fb4d7f45d1cf-67c2d57a5ceso351942a12.3 for ; Sat, 02 May 2026 05:41:15 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20251104; t=1777725674; x=1778330474; 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=HBPNRk7v8mm7QEjJvKG3bZ2ji7O0ntCyzGjvZOc47Jg=; b=szC/F6aaQSGgS0XWpir9o5lO6cfT0oCt/xvdG5zbZfgRpZRZRei1DER181TJBgW3kZ HG2LQMX5Wh0nqXLmesIugpj+EaiV8Z8LkjgHgMonkEl+f8c84+dc8A+K4WNaaNPfFTPz 2z5bnoHs8lDj0Xpg7hKi9GpAYaypNrUNNiNZ8oIwv6M2l8icQTeM9XGorcwjHzVL85n0 S5W1N77C0pkKYzK6FUHO092IDvVSJw4AyT6aFFkq3GGXHkOD1RaPEgOX8vXNoxSE4QGy fx4oq0Vb1MVgIAs9zLRBMUobAs5IcXvdDRiyKiXAqsQSi2oTpViCsOKceO0LYYPD1xgR T7xw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20251104; t=1777725674; x=1778330474; 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=HBPNRk7v8mm7QEjJvKG3bZ2ji7O0ntCyzGjvZOc47Jg=; b=ef7mnBoQHFFpZV/DIQo/awli530faYvDyR0MTU97Avvk9JF1f6owqpGx5Z1Rn3mdL2 SQz/ffJYxoNUkj2uCygpkdn3iENA0d3bQr6tSXiHcfVd2smNUUxd608fPppaIoDnuv6Q 5lZRn9fZ7AxSPg3YqqS8WoB0pT3MUD5tesztn3Ta9ly0Cdn6jbrTAuAMM5SI9fulKAO0 75tVZwmxGwE9hwKE+AIRt2t4A4mhBvZ6p3fSZN6KMQ775mQetV8f4DqneVvtdR82DzIl /s7zbE5yxHM4TyExvwD4012hEwxYnOLaowqgx3ljNIOfXLGCnLRD3Sb8oMK0Ki1wVWDb p8fA== X-Forwarded-Encrypted: i=1; AFNElJ9bKqFrK88DP0NqCpL9E5t9nkUjqgh5NHbi2b2JclnvOoPP5A5OZAVx/9++EOxObqsgmKG5Fy8Dv6ih4Vg=@vger.kernel.org X-Gm-Message-State: AOJu0YwlPWj7AF80vgPevm1p2GEYY2ZnEqxyGkHB5LURTIk20HPMEL26 V0LmJITMrPqy5aEfPgxHM4+92/EN3Koqagu34+adFAj/l0Fz8/zCBrBF X-Gm-Gg: AeBDietHwfCXpBaB1IPtuycE8ZRQF+l8g0aPgY/qf3Z/GvmOYxLRplmmIplXaK9pQbq tHQ0kc/gUtB4j1+wXBixIWpNlFTWrzuCJ0C8LIk/NU5h0hYIw5BE+RELU4jnW2VOffMK6jieG00 7V8sS2rc6kdKL5hL2pqI9QCYGWzu5nhXJtGRCvu2uBPTjPjF74UreBkI9Z41wfhdWhNk00KQS+M 7VTpNI+h5AtxxYx8l5HXMHFYcVJzoY1lCwY7kRxvKRW3ef2VgmgbpawGrrBouwb8lRDzk4QGfxk GWOPOKbvOzvaD1GYCqNYxAQ1a+XZn8AT0rY+LVXKzFOT0jGZ5nElazazVJq86goiY9JiFTXxpKg rW+QA784OF/oIg5uKHqHRre1XI7gLsETow2dytzgXTyouJ8o0DgGHqVD5BcYY2I7xJ8IQnrTry4 +WY0ZDclBi8AnZmW8EiG68KDM= X-Received: by 2002:a05:6402:1209:b0:665:3d68:c46c with SMTP id 4fb4d7f45d1cf-67c1ada368fmr865771a12.14.1777725674231; Sat, 02 May 2026 05:41:14 -0700 (PDT) Received: from xeon ([188.163.112.56]) by smtp.gmail.com with ESMTPSA id 4fb4d7f45d1cf-67b85e281cdsm1649649a12.3.2026.05.02.05.41.12 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 02 May 2026 05:41:13 -0700 (PDT) From: Svyatoslav Ryhel To: Rob Herring , Krzysztof Kozlowski , Conor Dooley , Dmitry Torokhov , Lee Jones , Pavel Machek , Sebastian Reichel , Svyatoslav Ryhel , Ion Agorria , =?UTF-8?q?Micha=C5=82=20Miros=C5=82aw?= Cc: devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-input@vger.kernel.org, linux-leds@vger.kernel.org, linux-pm@vger.kernel.org Subject: [PATCH v6 0/7] mfd: Add support for Asus Transformer embedded controller Date: Sat, 2 May 2026 15:40:48 +0300 Message-ID: <20260502124055.22475-1-clamor95@gmail.com> X-Mailer: git-send-email 2.51.0 Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Add support for embedded controller used in Asus Transformers for managing power and input functions. --- Changes in v2: - converted sysfs debug exports into debugfs - added kernel-doc comments for exposed functions - fixed minor typos and inconsistencies Changes in v3: - dropped DockRAM commits (both schema and driver) - integrated DockRAM functionality directly into the controller driver - EC schema moved to embedded controllers folder - removed all cell descriptions from the schema - removed all compatibles from the cell drivers - adjusted naming conventions to better align with the ASUS Transformers - defined EC variant sets to provide coverage for all known devices Changes in v4: - grouped known programming models of EC chronologically (both schema and driver) - call debugfs init only if CONFIG_DEBUG_FS is enabled Changes in v5: - added asus,tf600t-ec-dock compatible to schema - rebased on top of v7.0 - kzalloc > kzalloc_obj in keys and kbc Changes in v6: - removed asus_ec_handle_smi casting - asus_dockram_access_ctl > asus_ec_get_ctl in control_reg_* - fixed battery Kconfig description --- Michał Mirosław (6): mfd: Add driver for ASUS Transformer embedded controller input: serio: Add driver for ASUS Transformer dock keyboard and touchpad input: keyboard: Add driver for ASUS Transformer dock multimedia keys leds: Add driver for ASUS Transformer LEDs power: supply: Add driver for ASUS Transformer battery power: supply: Add charger driver for Asus Transformers Svyatoslav Ryhel (1): dt-bindings: embedded-controller: document ASUS Transformer EC .../asus,tf201-ec-pad.yaml | 119 +++ drivers/input/keyboard/Kconfig | 10 + drivers/input/keyboard/Makefile | 1 + .../input/keyboard/asus-transformer-ec-keys.c | 272 +++++++ drivers/input/serio/Kconfig | 15 + drivers/input/serio/Makefile | 1 + drivers/input/serio/asus-transformer-ec-kbc.c | 147 ++++ drivers/leds/Kconfig | 11 + drivers/leds/Makefile | 1 + drivers/leds/leds-asus-transformer-ec.c | 79 ++ drivers/mfd/Kconfig | 14 + drivers/mfd/Makefile | 1 + drivers/mfd/asus-transformer-ec.c | 762 ++++++++++++++++++ drivers/power/supply/Kconfig | 22 + drivers/power/supply/Makefile | 2 + .../supply/asus-transformer-ec-battery.c | 272 +++++++ .../supply/asus-transformer-ec-charger.c | 193 +++++ include/linux/mfd/asus-transformer-ec.h | 162 ++++ 18 files changed, 2084 insertions(+) create mode 100644 Documentation/devicetree/bindings/embedded-controller/asus,tf201-ec-pad.yaml create mode 100644 drivers/input/keyboard/asus-transformer-ec-keys.c create mode 100644 drivers/input/serio/asus-transformer-ec-kbc.c create mode 100644 drivers/leds/leds-asus-transformer-ec.c create mode 100644 drivers/mfd/asus-transformer-ec.c create mode 100644 drivers/power/supply/asus-transformer-ec-battery.c create mode 100644 drivers/power/supply/asus-transformer-ec-charger.c create mode 100644 include/linux/mfd/asus-transformer-ec.h -- 2.51.0