Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp1988426yba; Fri, 17 May 2019 08:36:42 -0700 (PDT) X-Google-Smtp-Source: APXvYqwAlttji9QtB96UWvxn4iKrZDKJS+yz1woulq+/RwkqUDWRx7jS3aQ1qbie5I2GeQAnN0u1 X-Received: by 2002:a17:902:b28b:: with SMTP id u11mr11129146plr.311.1558107402099; Fri, 17 May 2019 08:36:42 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1558107402; cv=none; d=google.com; s=arc-20160816; b=y7AF73uVxVsKq2m1wsbnP8GLKyE4d5pSMM8LtJjyIAEtlIwjPRCg3AUJRla86J/uR4 vdJbTj+f7nCjEY23YE+6K5iMNJG0WrMJGRDQ1gVzHhCi3Ns6Et/ur+T7/3yYyPDTUmOE kMd6LJZ/9FfF/OinrHnNpw5XaBkS3ALxAONpYr1nrLdIeW3P6q8Bh36toVLQzqSIZB/x 9N11/+VPVWnRE9Vicq6VZMu5nfwo60TMVFAFoWxw0k+X7Mu126eBNyKypAL3OKZGurNB JI3gvcdgoeE8lX4xFeLIT7xbbcAolhBSWtC2ltgb454S/wsleafuUVPS/1b4CYYWqFk3 Rnrg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from; bh=YI1GRZoajZtVpUWhn3rFJzUsOExNQH+kUT7/paB1/Mc=; b=v3PuXogGXl/g+GQwLF2Qlf93loGwKm7le1UDw02QDxGN1NWYEkhcYgLyqTxeXwbQb7 91lBYykwHn3GExxnDALnH3hRfCRhGfKi/mHiIdvOxXA3pzF+MaYi6MBCEv4qepBHGZvb dmGDWK4ihWh4OZvyMX9xi1pN4B756nH1eYDsfUqiBVPW7kur4rn2IzVkUAhePCRX+AD0 hQ87vAdJm14Z/lwgUMRT5JHU4xrl+FXK/13jHWyZFxKmHdEnSZa3UGzfhVn1xRYmDBeG J+/uuNXyEAw0E2Z5r3DmHEwnRlcO/NlZGTwZkftaaKWKpOcH1kwA7DVCEuraYXzqZvgv WC8g== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id h4si8006450pgc.298.2019.05.17.08.36.26; Fri, 17 May 2019 08:36:42 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729179AbfEQPGE (ORCPT + 99 others); Fri, 17 May 2019 11:06:04 -0400 Received: from relay1-d.mail.gandi.net ([217.70.183.193]:39315 "EHLO relay1-d.mail.gandi.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728935AbfEQPGE (ORCPT ); Fri, 17 May 2019 11:06:04 -0400 X-Originating-IP: 90.88.22.185 Received: from localhost.localdomain (aaubervilliers-681-1-80-185.w90-88.abo.wanadoo.fr [90.88.22.185]) (Authenticated sender: paul.kocialkowski@bootlin.com) by relay1-d.mail.gandi.net (Postfix) with ESMTPSA id 17FCF24000F; Fri, 17 May 2019 15:05:57 +0000 (UTC) From: Paul Kocialkowski To: dri-devel@lists.freedesktop.org, linux-fbdev@vger.kernel.org, linux-kernel@vger.kernel.org Cc: Lee Jones , Daniel Thompson , Jingoo Han , Bartlomiej Zolnierkiewicz , Thomas Petazzoni , Laurent Pinchart , Paul Kocialkowski Subject: [PATCH] backlight: gpio-backlight: Set power state instead of brightness at probe Date: Fri, 17 May 2019 17:05:46 +0200 Message-Id: <20190517150546.4508-1-paul.kocialkowski@bootlin.com> X-Mailer: git-send-email 2.21.0 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On a trivial gpio-backlight setup with a panel using the backlight but no boot software to enable it beforehand, we fall in a case where the backlight is disabled (not just blanked) and thus remains disabled when the panel gets enabled. Setting gbl->def_value via the device-tree prop allows enabling the backlight in this situation, but it will be unblanked straight away, in compliance with the binding. This does not work well when there was no boot software to display something before, since we really need to unblank by the time the panel is enabled, not before. Resolve the situation by setting the brightness to 1 at probe and managing the power state accordingly, a bit like it's done in pwm-backlight. Fixes: 8b770e3c9824 ("backlight: Add GPIO-based backlight driver") Signed-off-by: Paul Kocialkowski --- drivers/video/backlight/gpio_backlight.c | 19 ++++++++++++++++++- 1 file changed, 18 insertions(+), 1 deletion(-) diff --git a/drivers/video/backlight/gpio_backlight.c b/drivers/video/backlight/gpio_backlight.c index e470da95d806..c9cb97fa13d0 100644 --- a/drivers/video/backlight/gpio_backlight.c +++ b/drivers/video/backlight/gpio_backlight.c @@ -57,6 +57,21 @@ static const struct backlight_ops gpio_backlight_ops = { .check_fb = gpio_backlight_check_fb, }; +static int gpio_backlight_initial_power_state(struct gpio_backlight *gbl) +{ + struct device_node *node = gbl->dev->of_node; + + /* If we absolutely want the backlight enabled at boot. */ + if (gbl->def_value) + return FB_BLANK_UNBLANK; + + /* If there's no panel to unblank the backlight later. */ + if (!node || !node->phandle) + return FB_BLANK_UNBLANK; + + return FB_BLANK_POWERDOWN; +} + static int gpio_backlight_probe_dt(struct platform_device *pdev, struct gpio_backlight *gbl) { @@ -142,7 +157,9 @@ static int gpio_backlight_probe(struct platform_device *pdev) return PTR_ERR(bl); } - bl->props.brightness = gbl->def_value; + bl->props.brightness = 1; + bl->props.power = gpio_backlight_initial_power_state(gbl); + backlight_update_status(bl); platform_set_drvdata(pdev, bl); -- 2.21.0