Received: by 2002:a05:6358:3188:b0:123:57c1:9b43 with SMTP id q8csp27920115rwd; Tue, 4 Jul 2023 09:41:50 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ5l+Iny8B1flaCkqw+UwXyMaO5iJtWsJ+CScklr+xwrYaLMyLLP6rBSebDk0hztCfXsxmv8 X-Received: by 2002:a05:6808:b05:b0:3a1:c6ed:b902 with SMTP id s5-20020a0568080b0500b003a1c6edb902mr13086075oij.37.1688488910525; Tue, 04 Jul 2023 09:41:50 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1688488910; cv=none; d=google.com; s=arc-20160816; b=SqMl1aRsQ3LOpvPZMkA3iy5TOqu40dtx0neJ1H2bFVIHIkZUsCTR/22W7n7waval1k UE2Leh/Wao/9Tgo5mXdoMxS6hkxMvrR8ILI60hHcaGPUegrFzUWmr/qfHOjv7oDzuo0K zeqeZMp6J0AK5KTO3fBjUa/TQTNfXu/F/mwcAU+CdRozh5SfwCTN0sagbr7krNSQHK5p DEVLfrTXy7mn52/e3pApZmXHukgyRM0Tnt07Gkze4yCuBUQDpdLhRiEixEvkF9AjFB4B ILnRjr6CZr5xjoQdv8kV8tM42i0XiQMEBVniaYBRuxrdIRtIr/tqt9/tpTC4Aj05McTD V4VA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from; bh=MDs84LcvO/Try269w4U/9jeNnOTeXExyNjPqkyGL3Lc=; fh=SuP74hXNUeXSKDbyiktRyGAybUUFTbQpVwmlk5yCyls=; b=tISBOvYIB7nXTX1+kmmIGoYR7Hcx03YBRTKt6vsIhIpcZ0nozqJ7ljzUXbRg9cRTPk s8ILWFh/qxJL6afHokDgAoRTQce5HNQaePLg7POFn6Kj2QE6AO65nGYBLdgubLGNo3w7 o7PXi7htObUrs0qGlQ5c2FXnYitJa0tEXJK78x6deEbTh+LsvIQO2+ZtPf12yuWgX49f 306NqvD5U7LZie4OKUWRJz5TZMPLgbLuQgxGMfN48p3vnDW011/suFyLqeSFEELywY0q NV1+nz+lxrX85MCCpCTBHpt5uh650UPqrVTC4RFv0/XPbJS1xw7z1v3zmTHzGk+xCPKP AOqQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id n124-20020a632782000000b0054ffc2d9fc3si22641663pgn.38.2023.07.04.09.41.35; Tue, 04 Jul 2023 09:41:50 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231486AbjGDQaV (ORCPT + 99 others); Tue, 4 Jul 2023 12:30:21 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:40774 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231154AbjGDQaV (ORCPT ); Tue, 4 Jul 2023 12:30:21 -0400 Received: from unicorn.mansr.com (unicorn.mansr.com [81.2.72.234]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 0603EE3; Tue, 4 Jul 2023 09:30:20 -0700 (PDT) Received: from raven.mansr.com (raven.mansr.com [81.2.72.235]) by unicorn.mansr.com (Postfix) with ESMTPS id ACE5315360; Tue, 4 Jul 2023 17:30:16 +0100 (BST) Received: by raven.mansr.com (Postfix, from userid 51770) id 9E919219FC1; Tue, 4 Jul 2023 17:30:16 +0100 (BST) From: Mans Rullgard To: Lee Jones , Daniel Thompson , Jingoo Han Cc: Helge Deller , dri-devel@lists.freedesktop.org, linux-fbdev@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH v2] backlight: led_bl: fix initial power state Date: Tue, 4 Jul 2023 17:19:52 +0100 Message-ID: <20230704163013.21097-1-mans@mansr.com> X-Mailer: git-send-email 2.41.0 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00,SPF_HELO_PASS, SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The condition for the initial power state based on the default brightness value is reversed. Fix it. Furthermore, use the actual state of the LEDs rather than the default brightness specified in the devicetree as the latter should not cause the backlight to be automatically turned on. If the backlight device is not linked to any display, set the initial power to on unconditionally. Fixes: ae232e45acf9 ("backlight: add led-backlight driver") Signed-off-by: Mans Rullgard --- Changes in v2: - Use the reported LED state to set initial power state - Always power on if no phandle in DT --- drivers/video/backlight/led_bl.c | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/drivers/video/backlight/led_bl.c b/drivers/video/backlight/led_bl.c index 3259292fda76..bbf1673b1fb0 100644 --- a/drivers/video/backlight/led_bl.c +++ b/drivers/video/backlight/led_bl.c @@ -176,6 +176,7 @@ static int led_bl_probe(struct platform_device *pdev) { struct backlight_properties props; struct led_bl_data *priv; + int init_brightness; int ret, i; priv = devm_kzalloc(&pdev->dev, sizeof(*priv), GFP_KERNEL); @@ -190,6 +191,8 @@ static int led_bl_probe(struct platform_device *pdev) if (ret) return ret; + init_brightness = priv->default_brightness; + ret = led_bl_parse_levels(&pdev->dev, priv); if (ret < 0) { dev_err(&pdev->dev, "Failed to parse DT data\n"); @@ -200,8 +203,8 @@ static int led_bl_probe(struct platform_device *pdev) props.type = BACKLIGHT_RAW; props.max_brightness = priv->max_brightness; props.brightness = priv->default_brightness; - props.power = (priv->default_brightness > 0) ? FB_BLANK_POWERDOWN : - FB_BLANK_UNBLANK; + props.power = (init_brightness || !pdev->dev.of_node->phandle) ? + FB_BLANK_UNBLANK : FB_BLANK_POWERDOWN; priv->bl_dev = backlight_device_register(dev_name(&pdev->dev), &pdev->dev, priv, &led_bl_ops, &props); if (IS_ERR(priv->bl_dev)) { -- 2.41.0