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 4F0E62ED143; Thu, 3 Jul 2025 15:11:58 +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=1751555519; cv=none; b=RvXaJXs1I8+Ev7R/zyjWrfgQRByJsweVjDoBxQIlvjfjbj8fmstDeY6dHs9Kk0CUIbkuIT/jxldI1Yi6BRcpHB2fRhtJf+QQGfg/o/vk1KT2LKeE1jZ+38yabhzDeUVX8Z5vpRgKLGJacY6jyqT7Uh1tk2ZOH7wHDsEziSFiopI= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1751555519; c=relaxed/simple; bh=Ht/soyYABQ6mZ+el/MHH5Gqz1RiRjbtxZTCzZ+b5XbQ=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=BKuA26NQDddGA7ZmZz9aMwFjc8IXe2ruizL7kVwhHXFtnm5iZbymHJkX55O/F/gd9luzWVR7TkDGWkt2mHZ9m2SZE676I2h97W2+KG9GHd0ZUEKgcPGZdQdjXwl0nNgd+ql/0yWagqjBTOX2AZOhgk8PskcyeA268xg5VnD3Qgw= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=linuxfoundation.org header.i=@linuxfoundation.org header.b=gc+sRvLU; arc=none smtp.client-ip=10.30.226.201 Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=linuxfoundation.org header.i=@linuxfoundation.org header.b="gc+sRvLU" Received: by smtp.kernel.org (Postfix) with ESMTPSA id 0D9D4C4CEE3; Thu, 3 Jul 2025 15:11:57 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1751555518; bh=Ht/soyYABQ6mZ+el/MHH5Gqz1RiRjbtxZTCzZ+b5XbQ=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=gc+sRvLUtSjCJn4qNA/DYShecr3k28aQCb0jerg59Lv/ae8arauhntyMY9WEYllO3 qv09dNeNylaJqzInYxVruu3xi35igbjpriWXb8X+tzUmXcVx+CZC5knO5o4Jpcv7Xp dOhsBeEuYdxk6o+jIHmUsJHf5f+IQBQjhurZ5dks= From: Greg Kroah-Hartman To: stable@vger.kernel.org Cc: Greg Kroah-Hartman , patches@lists.linux.dev, Jacek Anaszewski , Pavel Machek , Tobias Deiminger , Sven Schuchmann , Sven Schwermer , Lee Jones , Sasha Levin Subject: [PATCH 6.6 009/139] leds: multicolor: Fix intensity setting while SW blinking Date: Thu, 3 Jul 2025 16:41:12 +0200 Message-ID: <20250703143941.541453630@linuxfoundation.org> X-Mailer: git-send-email 2.50.0 In-Reply-To: <20250703143941.182414597@linuxfoundation.org> References: <20250703143941.182414597@linuxfoundation.org> User-Agent: quilt/0.68 X-stable: review X-Patchwork-Hint: ignore Precedence: bulk X-Mailing-List: patches@lists.linux.dev List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit 6.6-stable review patch. If anyone has any objections, please let me know. ------------------ From: Sven Schwermer [ Upstream commit e35ca991a777ef513040cbb36bc8245a031a2633 ] When writing to the multi_intensity file, don't unconditionally call led_set_brightness. By only doing this if blinking is inactive we prevent blinking from stopping if the blinking is in its off phase while the file is written. Instead, if blinking is active, the changed intensity values are applied upon the next blink. This is consistent with changing the brightness on monochrome LEDs with active blinking. Suggested-by: Jacek Anaszewski Acked-by: Jacek Anaszewski Acked-by: Pavel Machek Reviewed-by: Tobias Deiminger Tested-by: Sven Schuchmann Signed-off-by: Sven Schwermer Link: https://lore.kernel.org/r/20250404184043.227116-1-sven@svenschwermer.de Signed-off-by: Lee Jones Signed-off-by: Sasha Levin --- drivers/leds/led-class-multicolor.c | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/drivers/leds/led-class-multicolor.c b/drivers/leds/led-class-multicolor.c index ec62a48116135..e0785935f4ba6 100644 --- a/drivers/leds/led-class-multicolor.c +++ b/drivers/leds/led-class-multicolor.c @@ -61,7 +61,8 @@ static ssize_t multi_intensity_store(struct device *dev, for (i = 0; i < mcled_cdev->num_colors; i++) mcled_cdev->subled_info[i].intensity = intensity_value[i]; - led_set_brightness(led_cdev, led_cdev->brightness); + if (!test_bit(LED_BLINK_SW, &led_cdev->work_flags)) + led_set_brightness(led_cdev, led_cdev->brightness); ret = size; err_out: mutex_unlock(&led_cdev->led_access); -- 2.39.5