Received: by 2002:ab2:6857:0:b0:1ef:ffd0:ce49 with SMTP id l23csp2209055lqp; Sun, 24 Mar 2024 08:02:08 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCUto8oN3owH/fyHbw7kLhbF/P8aPxlFU887+/E1/DUSqSx7VFLLAcZdz2juTR9hhS/gEtyqb8wudWCzxOCaj3BeTZbYzF+Sd9kQUZew0A== X-Google-Smtp-Source: AGHT+IFvsW75hA7uGQCoO0pE0f2X7mIjxJxdNnV9VvQiLZakGrEaNCW1UUcrKKNqXYWGxstpLBKj X-Received: by 2002:a17:906:f6d8:b0:a46:f6f8:c96f with SMTP id jo24-20020a170906f6d800b00a46f6f8c96fmr3416717ejb.33.1711292528407; Sun, 24 Mar 2024 08:02:08 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1711292528; cv=pass; d=google.com; s=arc-20160816; b=y37DVamVR5gfnR5hcZYwAU8dgT+TUpF31c5NGmDlqebvBuBXK8QJp/cFBl1DSzrd3b 4wPkX9x9LmWTgQUXqjkH8gr20xOddkLZfOC/2KAzaxne7BON7qnCZJreGOmEBCizraBN 8JIgSmZKCtF3A92qspIhWRkkb4ghCt3nyud79SiYxqMMgY3rK/k3pPD2MPJg4ekTT3oJ txgiviM8X1y/WSdwKhpMNg4QzMLPs8xInet8cRY+Nlx9v5FSO55zheKnDxeBXsQjxMqL b7QebLJdBxZa5+dHJ8AWH2QbXkDHFDYmRCb/Hk++OwAwMmJgK8kYqhc+/ziX2fgw6DYg vc2w== ARC-Message-Signature: i=2; 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=NrnaIDGD9GLPzpqf9XIs73N3ICvGrhKs7eQKU2DgFLQ=; fh=hfu+pxMW6jJGnce6KP7/+i5TYWb3+Zng5eoqE5iJ1ZE=; b=sdqMNWtIoLNlTNANmeBEgoFjXSN+adJYKZox/yuEF7ymkUCtjxo1TxOWCvAPI0Cc1A Kg10DyT/v58NTKhym/GaSSC8sBPZfvwjln0GdP7v7/3g09Tgu76QDG3CTUMUFaTkjWHd nfmrAnXALWr9j5zR5WVE+jvicFfbbEo4nHhVZmxnxYquac42ests8ImLxLe4JN5iruip pVNnhiZNrEAtxA2uPffbIPRKRsSpad573gQpuWqtVVL2K5xbYtaQXLGNJ00uCzz26QOO gU3PY5rMmOoWXJwTWrDaBoWb0Jmi7cLyW5IS7yhhTS7dSi9Xj7eCfFZx0ova5lt6R6LE n61Q==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=Q+QkUvgm; arc=pass (i=1 spf=pass spfdomain=redhat.com dkim=pass dkdomain=redhat.com dmarc=pass fromdomain=redhat.com); spf=pass (google.com: domain of linux-kernel+bounces-112716-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.80.249 as permitted sender) smtp.mailfrom="linux-kernel+bounces-112716-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from am.mirrors.kernel.org (am.mirrors.kernel.org. [147.75.80.249]) by mx.google.com with ESMTPS id kn1-20020a170906aa4100b00a47340c3f59si1666219ejb.879.2024.03.24.08.02.08 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sun, 24 Mar 2024 08:02:08 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-112716-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.80.249 as permitted sender) client-ip=147.75.80.249; Authentication-Results: mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=Q+QkUvgm; arc=pass (i=1 spf=pass spfdomain=redhat.com dkim=pass dkdomain=redhat.com dmarc=pass fromdomain=redhat.com); spf=pass (google.com: domain of linux-kernel+bounces-112716-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.80.249 as permitted sender) smtp.mailfrom="linux-kernel+bounces-112716-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.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 26E171F2120D for ; Sun, 24 Mar 2024 15:02:08 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 5D6B918639; Sun, 24 Mar 2024 15:02:00 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=redhat.com header.i=@redhat.com header.b="Q+QkUvgm" Received: from us-smtp-delivery-124.mimecast.com (us-smtp-delivery-124.mimecast.com [170.10.129.124]) (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 08087182D4 for ; Sun, 24 Mar 2024 15:01:57 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=170.10.129.124 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1711292519; cv=none; b=LTepgswDsRB1VnatkdvWs4HAhfFWKBIrz9lbs52bbhTXY7RxmOtF4ta8/amJcbSjGuaDBGSVbJ6ZUq4nHdm0ozpkSlKAeaKYgyqqOUv5Uf1gpvwS7P8fBxE+c8ES9k1n1x5q+47fk63Fb+DHtwJ/Aml/8Vl09AR3huFsAW2206I= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1711292519; c=relaxed/simple; bh=9kD5mYuA0ixrmsz/Nc+tYzQ3aOX+CXGxr7IZ5BHCiyI=; h=From:To:Cc:Subject:Date:Message-ID:MIME-Version; b=fBRhiaWls42BBUwC8t+UBE4VOmNtTYvriyewxQoFN9EVr/glTa6qqn5bwHT6iyiYgae3wUOiJWFWGJuAsoc/OeiOK2pmLSDlJJqimB8SQIvDQBQolcjr4AvvXWAu3096Ons24OduZKShAOKnJpHRk9+Ibx9Jgfd4UgcmklHRwtU= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=redhat.com; spf=pass smtp.mailfrom=redhat.com; dkim=pass (1024-bit key) header.d=redhat.com header.i=@redhat.com header.b=Q+QkUvgm; arc=none smtp.client-ip=170.10.129.124 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=redhat.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=redhat.com DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1711292517; 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=NrnaIDGD9GLPzpqf9XIs73N3ICvGrhKs7eQKU2DgFLQ=; b=Q+QkUvgmQV6MhR+1FPygy8ljzUOjfhbq8PWb36e+vF4nwLr6mXSjhTrn+/eUujTW+MfY6p WY3TE21Y4GCh4kj6o0XTk6Z/eC9f1g7R4YvGD6QtsTYCYd4zyqs5W3X5pAITJpSfWhesMO D9dFaKIkaEHbv94Peq7+1DUI9ij4TqQ= Received: from mimecast-mx02.redhat.com (mimecast-mx02.redhat.com [66.187.233.88]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.3, cipher=TLS_AES_256_GCM_SHA384) id us-mta-533-MMq404_uPTOF9T5j7TRl4A-1; Sun, 24 Mar 2024 11:01:53 -0400 X-MC-Unique: MMq404_uPTOF9T5j7TRl4A-1 Received: from smtp.corp.redhat.com (int-mx02.intmail.prod.int.rdu2.redhat.com [10.11.54.2]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (2048 bits) server-digest SHA256) (No client certificate requested) by mimecast-mx02.redhat.com (Postfix) with ESMTPS id DBA1D85A58C; Sun, 24 Mar 2024 15:01:52 +0000 (UTC) Received: from fedora.redhat.com (unknown [10.39.192.75]) by smtp.corp.redhat.com (Postfix) with ESMTP id 0C5CE40C6DAE; Sun, 24 Mar 2024 15:01:46 +0000 (UTC) From: Kate Hsuan To: Pavel Machek , Lee Jones , linux-leds@vger.kernel.org, platform-driver-x86@vger.kernel.org, Hans de Goede , =?UTF-8?q?Ilpo=20J=C3=A4rvinen?= , =?UTF-8?q?Andr=C3=A9=20Apitzsch?= , linux-kernel@vger.kernel.org, Andy Shevchenko , Sebastian Reichel , linux-pm@vger.kernel.org Cc: Kate Hsuan Subject: [PATCH v5 RESEND 0/6] KTD2026 indicator LED for X86 Xiaomi Pad2 Date: Sun, 24 Mar 2024 23:01:01 +0800 Message-ID: <20240324150107.976025-1-hpa@redhat.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Scanned-By: MIMEDefang 3.4.1 on 10.11.54.2 This patch added the support for Xiaomi Pad2 indicator LED. This work included: 1. Added the KTD2026 swnode description to describe the LED controller. 2. Migrated the original driver to fwnode to support x86 platform. 3. Support for multi-color LED trigger event. 4. The LED will be red when charging and the LED will be green when the battery is full. Moreover, the LED trigger is set to the new trigger, called "bq27520-0-charging-red-full-green" for Xiaomi Pad2 so the LED will be red when charging and the LED will be green when the battery is full. The new LED API led_mc_trigger_event() can be found in the following URL. https://lore.kernel.org/linux-leds/f40a0b1a-ceac-e269-c2dd-0158c5b4a1ad@gmail.com/T/#t -- Changes in v5: 1. Fix swnode LED color settings. 2. Improve the driver based on the comments. 3. Introduce a LED new API- led_mc_trigger_event() to make the LED color can be changed according to the trigger. 4. Introduced a new trigger "charging-red-full-green". The LED will be red when charging and the the LED will be green when the battery is full. 5. Set the default trigger to "bq27520-0-charging-red-full-green" for Xiaomi Pad2. Changes in v4: 1. Fix double casting. 2. Since force casting a pointer value to int will trigger a compiler warning, the type of num_leds was changed to unsigned long. Changes in v3: 1. Drop the patch "leds-ktd202x: Skip regulator settings for Xiaomi pad2" Changes in v2: 1. Typo and style fixes. 2. The patch 0003 skips all the regulator setup for Xiaomi pad2 since KTD2026 on Xiaomi pad2 is already powered by BP25890RTWR. So, the sleep can be removed when removing the module. Hans de Goede (2): leds: core: Add led_mc_set_brightness() function leds: trigger: Add led_mc_trigger_event() function Kate Hsuan (4): platform: x86-android-tablets: other: Add swnode for Xiaomi pad2 indicator LED leds: rgb: leds-ktd202x: Get device properties through fwnode to support ACPI power: supply: power-supply-leds: Add charging_red_full_green trigger for RGB LED platform: x86-android-tablets: others: Set the LED trigger to charging_red_full_green for Xiaomi pad2 drivers/leds/led-class-multicolor.c | 1 + drivers/leds/led-core.c | 31 +++++++ drivers/leds/led-triggers.c | 20 +++++ drivers/leds/rgb/Kconfig | 1 - drivers/leds/rgb/leds-ktd202x.c | 75 ++++++++++------- .../platform/x86/x86-android-tablets/other.c | 82 +++++++++++++++++++ .../x86/x86-android-tablets/shared-psy-info.h | 2 + drivers/power/supply/power_supply_leds.c | 25 ++++++ include/linux/leds.h | 26 ++++++ include/linux/power_supply.h | 2 + 10 files changed, 235 insertions(+), 30 deletions(-) -- 2.44.0