From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from mail-dy1-f175.google.com (mail-dy1-f175.google.com [74.125.82.175]) (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 CD2C4480972 for ; Tue, 5 May 2026 14:54:20 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=74.125.82.175 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1777992862; cv=none; b=KMNMN9Co0Jhz6CHqIXGoNMvitfiQGGtPt3OzW4YCUOJVyJnmvam8SBbpJXQAZbV1fnyUGdTs/V+xO0mrLTvfFpjsUwNlzZ6hX6TH3xSROh3GpAImXDSmW5GsQV4WseOnmuA/6x7uTUyp8AbeCVkCxBF70A8N86fv8kqz7jIUROE= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1777992862; c=relaxed/simple; bh=E8KHLC1Nbi3NBLgVxLEsG0ZdvPc4VF3KSVAQfL9DEHM=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=uaYQ6cC/FpeUi85+Ijt9MQHlkyTklQPEPiwutzI0SxVHPLOAWzC4GHwC0a+vNH9tmFXLdJ+zEXoZvu4vBJBINiFXQKcAqoyHcCwWcm6vYQCnIEfEv+fjGUFthfcUPQny75gHbNxM+ltNCd4EeNZUelLLgH+ZvRTwb7Sx6nRN4D0= 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=qYzHeq6W; arc=none smtp.client-ip=74.125.82.175 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="qYzHeq6W" Received: by mail-dy1-f175.google.com with SMTP id 5a478bee46e88-2bdcf5970cdso3954296eec.0 for ; Tue, 05 May 2026 07:54:20 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20251104; t=1777992860; x=1778597660; 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=8gO706adh8M0cH/PpFGt/u7nigSQIbFuK2LgSPVQ9R0=; b=qYzHeq6WNGys3BuA872VzgwybhvpPGYaROUhlO7m1IWe4dUrkdusnv8DT8rEvogWIZ 94aiz5G20Xz4Gwq+ucWmuHoS+XKssjKvVi43YWnWkqBgojNzckLO0mg8XJ5YDxJbbFIW 60T8IaxduT+dxGKeRxGOHC1EKHK+jyELnoM4Q/GLaYdrB+0RFBBGWsfjQ2Sv2DK0Lvwy XO71DB6aTjm6OFTC8qpSnG2ifXIuxmEpk2PtS6EoNuiJke0vEPs73mO9huu3wAFIe3Wa LguDHF5toSOK5Ry8kslPzLoghvw3vhhfqZCKSUz281Hwo2Dilxj7LzYYfFkNhD6WfGZc WJkQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20251104; t=1777992860; x=1778597660; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-gg:x-gm-message-state:from :to:cc:subject:date:message-id:reply-to; bh=8gO706adh8M0cH/PpFGt/u7nigSQIbFuK2LgSPVQ9R0=; b=WCfhCqgvRKpCs77HHfp7szR4lpYWB1rcp+ni6tRwDSeRAeVOVw3RIamH/U7dwLQ7vR ZyQZCPorSqv4DQmpL9ARGxT7TFG3yboA9qYjjaED1agetsAFOMwrBsgac/3eqHReg1aZ bTyjdoYn72hQz43ypCpiswB6vfiemzdeAev8CHGkAZ0Wp/oJ4km6iY0kAOJUcHIL0+L+ qxJOTp1mTGeRDAJR7OpeudcYihFfIZXPERSi5arnRZbcqMVn9/kzYU+hkdg5aCfrymCB 77BFfd3mt6W1Em8OyVW2YNthf3noi5PlNMDS38NvuHelzzfoxgAezQZLo+I8ta05w6UM kVUA== X-Forwarded-Encrypted: i=1; AFNElJ8zAwXnR4YMtgorq0NDwI/JLD35poNbiJ30VjXhYBaBf0zrABvUIDiJwN8sddOJc8EVlwb8nciZFMO2@vger.kernel.org X-Gm-Message-State: AOJu0Yx+MQ08YWYyr7Jj2r8WDpcN4zvKprdxPWtUc4OUV+bCJWFxVQea pitjIEMgIr9VCtemV5ygKViKfGqkvk8PaKS7K8qmXlBooINSqNGLPSja X-Gm-Gg: AeBDieu0Ynq4GclzXwc0UAB9BlwGdUauFWtu/Ql2jUcmRX50k4OOoyMDXfiTdsQgfmg SJCPUBPnLEdXB68R9rVKE7igdgqyFpAtRbuVuAcDTZxTLvAPTzgM6dQ99gBSptwB1VUE/YTyCtS tlWvGqJiDvZvV86NiTy+aujwvAcjfPfbyUPbAKCmrvGVXhMF1ebeXlOyDTDGH6oJ/2vbxtqkIUO tqAibRqNbehhkexjm9+STTbimtWY7USlq0nJIuwAzDw9yskejhfsDobiYckpIrBXx7CqpBbCZJQ EeEuO3ZSHlIDmiEvyXna3aV+Tw13zXvX0uzJjQ78KWpMvziE45gaxUAL4tNUYZW+fBjROfdBCuZ CBv22VlT9mhlmALQuMUZ6NnWH2HU37ycoSOpUhiTHtLNOd/gemI45JBCuY/2zws4Cbj7UMaJkex CxGE5zFJswymu/nfZKRqZj3KTkHa+35j8= X-Received: by 2002:a05:7300:bb08:b0:2de:e194:5fb1 with SMTP id 5a478bee46e88-2f3ce9f2e5dmr1644089eec.7.1777992859864; Tue, 05 May 2026 07:54:19 -0700 (PDT) Received: from arch.localdomain ([2409:8a28:a59:55d1::1002]) by smtp.gmail.com with ESMTPSA id 5a478bee46e88-2f3bf67cf8dsm5793545eec.6.2026.05.05.07.54.16 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 05 May 2026 07:54:19 -0700 (PDT) From: Jun Yan To: linux-kernel@vger.kernel.org, devicetree@vger.kernel.org, linux-leds@vger.kernel.org Cc: lee@kernel.org, robh@kernel.org, krzk+dt@kernel.org, conor+dt@kernel.org, luccafachinetti@gmail.com, pzalewski@thegoodpenguin.co.uk, daniel@zonque.org, Jun Yan Subject: [PATCH v4 4/5] leds: is31fl32xx: Add powerdown pin to exit hardware shutdown mode Date: Tue, 5 May 2026 22:53:53 +0800 Message-ID: <20260505145354.1267095-5-jerrysteve1101@gmail.com> X-Mailer: git-send-email 2.53.0 In-Reply-To: <20260505145354.1267095-1-jerrysteve1101@gmail.com> References: <20260505145354.1267095-1-jerrysteve1101@gmail.com> Precedence: bulk X-Mailing-List: linux-leds@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit The IS31FL32XX series features an SDB shutdown pin. Driving it low (active low) places the chip into hardware shutdown mode for power saving, while all register contents are preserved and registers are not reset. Drive the pin logic low during probe() to exit hardware shutdown mode. Signed-off-by: Jun Yan --- drivers/leds/leds-is31fl32xx.c | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/drivers/leds/leds-is31fl32xx.c b/drivers/leds/leds-is31fl32xx.c index fe07acbb103a..57d779e07a62 100644 --- a/drivers/leds/leds-is31fl32xx.c +++ b/drivers/leds/leds-is31fl32xx.c @@ -10,6 +10,7 @@ */ #include +#include #include #include #include @@ -60,6 +61,7 @@ struct is31fl32xx_led_data { struct is31fl32xx_priv { const struct is31fl32xx_chipdef *cdef; struct i2c_client *client; + struct gpio_desc *powerdown_gpio; unsigned int num_leds; struct is31fl32xx_led_data leds[]; }; @@ -421,6 +423,11 @@ static int is31fl32xx_parse_dt(struct device *dev, const struct is31fl32xx_chipdef *cdef = priv->cdef; int ret = 0; + priv->powerdown_gpio = devm_gpiod_get_optional(dev, "powerdown", GPIOD_OUT_LOW); + if (IS_ERR(priv->powerdown_gpio)) + return dev_err_probe(dev, PTR_ERR(priv->powerdown_gpio), + "Failed to get powerdown gpio\n"); + if ((cdef->output_frequency_setting_reg != IS31FL32XX_REG_NONE) && of_property_read_bool(dev_of_node(dev), "issi,22khz-pwm")) { -- 2.53.0