Received: by 2002:a89:413:0:b0:1fd:dba5:e537 with SMTP id m19csp1582387lqs; Sat, 15 Jun 2024 16:15:52 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCUZan/l/JT1+X+zT15VvObozg/AgEdo/bjFgDjgZXf2c/KdX8mF4iVRGjzUoY91UQvCyr7K3ynp0mh74e2H1cJjT8cYFBBzgweAxqVrwg== X-Google-Smtp-Source: AGHT+IE7Tmt3GHsxkHwJX6gAz1Yr33pbQ61GKKT3gJcoD7lr5u7B5jp1lomdRCjCuXXD2NXl/ZeZ X-Received: by 2002:aa7:c3cf:0:b0:57c:46f7:a49c with SMTP id 4fb4d7f45d1cf-57cb4bb0d64mr6509264a12.7.1718493352798; Sat, 15 Jun 2024 16:15:52 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1718493352; cv=pass; d=google.com; s=arc-20160816; b=ssdojXPH8cbIx0A6B+qsJB6ExBO2oob+P3m+ouATvcvmJAEK/umzId2ijRDfpl+7GP Bf0gJl3W90FEDsf6au2sqI8ndkAnCuTAGfEtR2/vdzoHkj8YJrVauuQ7l0nyzXUUUzDd TNMKnYc3a9bOK2vTD1YmFL1uXlPKDUS79mhX8wS69XcK76pXSoFEc4VEhAhN8WUMFzVr n212YGaRvjELdQnnQrbfG8XJ2ZghK81SMxk+0rOOYeJSB7PF53sjNH8oDnlXOevUwHhL rQyA2DDwhkv/f69254dk9fJ8wVBGsIXEf4Om1QXG1mXmYm89sMRXvBllzSboIbqojegx T50Q== 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:references:in-reply-to:message-id :date:subject:cc:to:from:dkim-signature; bh=TJT+GSRKfcK8dGlTgwx48L15a3Q2jtdAFK5lJ52goD4=; fh=alQFt5C14qyaq+Q7FW7UhvZ1PwoC8EJDL4AsYqk6hUs=; b=c1eWtWuMtlpxOnTvrC64Of0/rngfKvSkjCZH1xchd/aRtEvVU5w1/EZA+Ry+5TijVU QRjW0chCwM8hq6Fe7gZeS5JY4ZENe2Ol0F/puZu4qCgz88Nd4QuMzxS8F2n5/yTG2k6D C4m0zG0zVlFohEqCgcAV9K/DGCMvpkDPCxfH8xRP4Jm9STCeEW6Cq22kjnP9b6Z3JIfi WSBaW3WQ9ixYX0jNhk9/+6oBq4T+r7urZtXbXmD4M9xC9OsTe3GEVme4Y5jnk+GY/ind zJ8vLAe/4AbodqVQOljnpqVV/B4Ut2MxgQFqa1jDrYu8Qac9tMUOq+A2aEWEf2pyA0M9 fxvg==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@gmail.com header.s=20230601 header.b="CiQz/KFH"; arc=pass (i=1 spf=pass spfdomain=gmail.com dkim=pass dkdomain=gmail.com dmarc=pass fromdomain=gmail.com); spf=pass (google.com: domain of linux-kernel+bounces-216052-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:4601:e00::3 as permitted sender) smtp.mailfrom="linux-kernel+bounces-216052-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from am.mirrors.kernel.org (am.mirrors.kernel.org. [2604:1380:4601:e00::3]) by mx.google.com with ESMTPS id 4fb4d7f45d1cf-57cb74410eesi3069478a12.367.2024.06.15.16.15.52 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 15 Jun 2024 16:15:52 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-216052-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:4601:e00::3 as permitted sender) client-ip=2604:1380:4601:e00::3; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20230601 header.b="CiQz/KFH"; arc=pass (i=1 spf=pass spfdomain=gmail.com dkim=pass dkdomain=gmail.com dmarc=pass fromdomain=gmail.com); spf=pass (google.com: domain of linux-kernel+bounces-216052-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:4601:e00::3 as permitted sender) smtp.mailfrom="linux-kernel+bounces-216052-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.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 57FC71F21BFC for ; Sat, 15 Jun 2024 23:15:52 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id C2AEC6BFD2; Sat, 15 Jun 2024 23:13:06 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="CiQz/KFH" Received: from mail-wr1-f46.google.com (mail-wr1-f46.google.com [209.85.221.46]) (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 DA533139D05; Sat, 15 Jun 2024 23:13:03 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.221.46 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1718493185; cv=none; b=rEdLL0WSptWZxb+Q8GjEJjBvkRFpJwVP3CEu8SKM01oWmWyau5Y0pj9CnQ1TK7iCVklbiU9i5l8cPtUDOnHNiwujd8TuGZM1QqasEed05dCO3oDs/aWYN/oHoSxbiH4TESH4MKI/Vhf/feQZFvaxhywVPGPklk9wAhApoF109xM= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1718493185; c=relaxed/simple; bh=jrUwrkPYp4hCHlkd6P6OYbxXe4swsLYG9zbBf4AA20s=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=mph8baFKeIAKqbGwob6OWlUZjKneh4Jjyd9XXCJ/obmRovCk/i2K/gEPyqM8nAiv2ez3uY9/J0Fsxop0up/UK7C5+QDJpMTTT1m/lHgdRim3cCpvmJUtIMzrLS5PdSDT2Qc3rpIDR2jyi1PFy+q3BCcbThbdXl9Xl2Ts7urt/4o= 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=CiQz/KFH; arc=none smtp.client-ip=209.85.221.46 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 Received: by mail-wr1-f46.google.com with SMTP id ffacd0b85a97d-35f2c0b7701so1878081f8f.0; Sat, 15 Jun 2024 16:13:03 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1718493182; x=1719097982; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=TJT+GSRKfcK8dGlTgwx48L15a3Q2jtdAFK5lJ52goD4=; b=CiQz/KFHpvhE2kjEiJcNdSKXlqAS3l1iMWdfX+9t0k00luF3bC2Bu3BhBeBJ78JBdo F+g4BIgnGNuBXe41B6VaIOG7tsB69DImW+gjoJWB7x/eBnhr9Jt6BcfRgJnNOqtDMEYF Jg7GntwciGaCAD1Tey9n8W/KYa+gLY12aNM1hZ0noavzWb8zgPfUXnAx16B9G+7g1wt9 5lA93yJ1yQdLrdF/J19N9TuWdddZWH6/EFqpFIp8PO+yYpCHCpZYWDI4ydXWbEQ7/Hbb MtNVgP8HBdu0Gdg1I96WMEG/tEnAB22NHe2iMnoE2+HyzOASL4HnkGk7HgAzcYL/WtVl GYTQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1718493182; x=1719097982; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=TJT+GSRKfcK8dGlTgwx48L15a3Q2jtdAFK5lJ52goD4=; b=aikZR5yWcCXls/BfvpQnVyQnRzjdaRHdeLEs/R4f1F/DljJpCqOs7ctI2VS0qB7C0H KKshST/FMSPwqDt2jDxYwAQGwERGYv7hHKVavFfNjsIVEh5lJAIeBoMVQ2DTWUYee3wa gski0yk8rA/gjO1NWVotAOOYQtyjnxgBX1z+IL9aNVWjxIZn8RizfF9WdmJW24MaAMwr IZqj76pq71KX/dGECJ7Geobajl2Ixm9vxRZbjNVOgAlX2LIeZCWFUx+ewoQIqK+9E6Mp xOIhzJzWu7PePv+t6wXlxM7Ms7foqfCmVacGeFSt6nwy1K9qMSWabgg6nZcmvPvXO/gu dTMA== X-Forwarded-Encrypted: i=1; AJvYcCWe1bcSUzIOTIKsGV1DMDrA6r86D5a61Oy19dwLP/CM39gy2Q3581tL9IsafJNa4VZvD4G2szYHigqTYfsH9CNX0CFdjAcaMTi83AiEq5q0JS+kt/PeiD3scpPXXbTwQOc5a32P5+QqrydeA1O9dYN6TBwoFiDLKJ+Z/fjEKPn0xhXqa14= X-Gm-Message-State: AOJu0YyR/He5xf6rmfZyzooGOXl608EGzQuWU+F4Y5ajjWYnQ4eB/vTR oOJFBEnsrXu6A8LL1X0PkL73yI/ev3MzY92k91zqqUFISd+9QQy1 X-Received: by 2002:adf:f14a:0:b0:360:8d70:d368 with SMTP id ffacd0b85a97d-3608d70d391mr2482228f8f.29.1718493182241; Sat, 15 Jun 2024 16:13:02 -0700 (PDT) Received: from localhost.localdomain (93-34-90-105.ip49.fastwebnet.it. [93.34.90.105]) by smtp.googlemail.com with ESMTPSA id ffacd0b85a97d-3607509355dsm8145532f8f.13.2024.06.15.16.13.01 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 15 Jun 2024 16:13:01 -0700 (PDT) From: Christian Marangi To: Pavel Machek , Lee Jones , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Jacek Anaszewski , linux-leds@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org Cc: Christian Marangi Subject: [PATCH v5 13/20] leds: leds-lp55xx: generalize turn_off_channels function Date: Sun, 16 Jun 2024 01:11:43 +0200 Message-ID: <20240615231152.28201-14-ansuelsmth@gmail.com> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20240615231152.28201-1-ansuelsmth@gmail.com> References: <20240615231152.28201-1-ansuelsmth@gmail.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 Generalize turn_off_channels function as the implementation is the same for most of the lp55xx based LED driver. Signed-off-by: Christian Marangi --- drivers/leds/leds-lp5523.c | 10 +--------- drivers/leds/leds-lp55xx-common.c | 10 ++++++++++ drivers/leds/leds-lp55xx-common.h | 1 + drivers/leds/leds-lp8501.c | 10 +--------- 4 files changed, 13 insertions(+), 18 deletions(-) diff --git a/drivers/leds/leds-lp5523.c b/drivers/leds/leds-lp5523.c index 3030a4495808..4a4463cb44a4 100644 --- a/drivers/leds/leds-lp5523.c +++ b/drivers/leds/leds-lp5523.c @@ -167,20 +167,12 @@ static void lp5523_stop_engine(struct lp55xx_chip *chip) lp5523_wait_opmode_done(); } -static void lp5523_turn_off_channels(struct lp55xx_chip *chip) -{ - int i; - - for (i = 0; i < LP5523_MAX_LEDS; i++) - lp55xx_write(chip, LP5523_REG_LED_PWM_BASE + i, 0); -} - static void lp5523_run_engine(struct lp55xx_chip *chip, bool start) { /* stop engine */ if (!start) { lp5523_stop_engine(chip); - lp5523_turn_off_channels(chip); + lp55xx_turn_off_channels(chip); return; } diff --git a/drivers/leds/leds-lp55xx-common.c b/drivers/leds/leds-lp55xx-common.c index 0d9c2990c335..028a485d3561 100644 --- a/drivers/leds/leds-lp55xx-common.c +++ b/drivers/leds/leds-lp55xx-common.c @@ -288,6 +288,16 @@ void lp55xx_set_led_current(struct lp55xx_led *led, u8 led_current) } EXPORT_SYMBOL_GPL(lp55xx_set_led_current); +void lp55xx_turn_off_channels(struct lp55xx_chip *chip) +{ + const struct lp55xx_device_config *cfg = chip->cfg; + int i; + + for (i = 0; i < cfg->max_channel; i++) + lp55xx_write(chip, cfg->reg_led_pwm_base.addr + i, 0); +} +EXPORT_SYMBOL_GPL(lp55xx_turn_off_channels); + static void lp55xx_reset_device(struct lp55xx_chip *chip) { const struct lp55xx_device_config *cfg = chip->cfg; diff --git a/drivers/leds/leds-lp55xx-common.h b/drivers/leds/leds-lp55xx-common.h index e638049d9297..531fbb0acb2e 100644 --- a/drivers/leds/leds-lp55xx-common.h +++ b/drivers/leds/leds-lp55xx-common.h @@ -220,6 +220,7 @@ extern void lp55xx_firmware_loaded_cb(struct lp55xx_chip *chip); extern int lp55xx_led_brightness(struct lp55xx_led *led); extern int lp55xx_multicolor_brightness(struct lp55xx_led *led); extern void lp55xx_set_led_current(struct lp55xx_led *led, u8 led_current); +extern void lp55xx_turn_off_channels(struct lp55xx_chip *chip); /* common probe/remove function */ extern int lp55xx_probe(struct i2c_client *client); diff --git a/drivers/leds/leds-lp8501.c b/drivers/leds/leds-lp8501.c index d924572e4533..1fb876f64cb7 100644 --- a/drivers/leds/leds-lp8501.c +++ b/drivers/leds/leds-lp8501.c @@ -110,20 +110,12 @@ static int lp8501_post_init_device(struct lp55xx_chip *chip) LP8501_PWR_CONFIG_M, chip->pdata->pwr_sel); } -static void lp8501_turn_off_channels(struct lp55xx_chip *chip) -{ - int i; - - for (i = 0; i < LP8501_MAX_LEDS; i++) - lp55xx_write(chip, LP8501_REG_LED_PWM_BASE + i, 0); -} - static void lp8501_run_engine(struct lp55xx_chip *chip, bool start) { /* stop engine */ if (!start) { lp55xx_stop_all_engine(chip); - lp8501_turn_off_channels(chip); + lp55xx_turn_off_channels(chip); return; } -- 2.43.0