Received: by 10.223.176.46 with SMTP id f43csp2075470wra; Sun, 21 Jan 2018 10:39:49 -0800 (PST) X-Google-Smtp-Source: AH8x225fHqmWsNVmC2p59un6cUWg6WNaXiEn5ooyMzGTjnqmgUUVDFryvFYULDjOghvtrlbK4Nrt X-Received: by 10.99.1.151 with SMTP id 145mr5167170pgb.229.1516559989098; Sun, 21 Jan 2018 10:39:49 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1516559989; cv=none; d=google.com; s=arc-20160816; b=BvFFTEjFNR7Jc6hf/B8wt17/oh9XqdJ2HXMCf6h1X5G8Dbj/YueCmlcRt/iNa5rfxt LLWWWt1RHA6TbL1Vy08jZkSDOMI23E3Vdgvd7VLJa21DP7ilwYX+b2gcsRL9Wh2aFcm8 DJxBH3K5aWgE4hFgqbq/1Cv7f9MFgL5QU+nfmrFZLToKztdYd9kHzeFOdWTrsa5tb3LE fpm/1oLVWsExS8h321A9C4gJrRCXHiUMKkkgkYRIUqXqlnbPRsOHNX497iBWxkv6vlQt JI71u/Dhe6JQYUQXKAYzO0oVKT2TezHbtywGhamSdqCDJ+1Ne9lt2oE2I+Y3IPpa5hJU AFOQ== 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:in-reply-to :mime-version:user-agent:date:message-id:from:references:to:subject :arc-authentication-results; bh=N+tS4S8mk6sdwJbRkCZUE+IOipfpCOKTsl4t/hky4dY=; b=Z7DptjAFr0MC+KNzT475THDlmz9sXP8vjnJXBefAE13ggE1evxdb9HrXE2bhheqhTV 1oHX1/awnOdDICDhWuaRFTquCQ/84AFxu8aB7P/jBCxr98U/PWXEgZUKQ5jggRxbgQjN Nz0v6rbgvSg/gOq/8g926iWKDIgFSbmROn0UQ9i1B8xlUuL/o10twj8KWSO91124H9/K qSr0GOm22VFFUV5eWlF52TwpSqp/k6za5F6+X0IC0o7YmeN308VhAqJOnvyoaiVRQ/75 ObNgj0iKqL2f45rfMIf65LvOO45tf7kog5INYRbUdVy9K0i6PfMf/4qtgWRgNnU35T2S K3pQ== 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 bg3-v6si2702997plb.28.2018.01.21.10.39.34; Sun, 21 Jan 2018 10:39:49 -0800 (PST) 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 S1751346AbeAUSjM (ORCPT + 99 others); Sun, 21 Jan 2018 13:39:12 -0500 Received: from smtp.domeneshop.no ([194.63.252.55]:58441 "EHLO smtp.domeneshop.no" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750925AbeAUSjL (ORCPT ); Sun, 21 Jan 2018 13:39:11 -0500 Received: from 211.81-166-168.customer.lyse.net ([81.166.168.211]:56883 helo=[192.168.10.157]) by smtp.domeneshop.no with esmtpsa (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.84_2) (envelope-from ) id 1edKWL-0008Ov-Kt; Sun, 21 Jan 2018 19:39:09 +0100 Subject: Re: [PATCH v17 09/10] drm/panel: Use of_find_backlight helper To: Meghana Madhyastha , Lee Jones , Daniel Thompson , Jingoo Han , Thierry Reding , Tomi Valkeinen , Daniel Vetter , Sean Paul , dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org References: <9be21221c098e5e6f27621047ba62a51bff02f18.1516358037.git.meghana.madhyastha@gmail.com> From: =?UTF-8?Q?Noralf_Tr=c3=b8nnes?= Message-ID: <4e3f3cbd-b5a9-fb58-e245-f374709e38d7@tronnes.org> Date: Sun, 21 Jan 2018 19:39:07 +0100 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:52.0) Gecko/20100101 Thunderbird/52.5.2 MIME-Version: 1.0 In-Reply-To: <9be21221c098e5e6f27621047ba62a51bff02f18.1516358037.git.meghana.madhyastha@gmail.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Den 19.01.2018 11.47, skrev Meghana Madhyastha: > Replace of_find_backlight_by_node and of the code around it > with of_find_backlight helper to avoid repetition of code. > > Signed-off-by: Meghana Madhyastha > --- > changes in v17: > -remove put_device() to avoid double put > as we are using the devm version > > drivers/gpu/drm/panel/panel-innolux-p079zca.c | 23 ++++------------------- > drivers/gpu/drm/panel/panel-sharp-lq101r1sx01.c | 25 ++++--------------------- > drivers/gpu/drm/panel/panel-sharp-ls043t1le01.c | 25 ++++--------------------- > 3 files changed, 12 insertions(+), 61 deletions(-) > > diff --git a/drivers/gpu/drm/panel/panel-innolux-p079zca.c b/drivers/gpu/drm/panel/panel-innolux-p079zca.c > index 4c1b29eec..059f4af1a 100644 > --- a/drivers/gpu/drm/panel/panel-innolux-p079zca.c > +++ b/drivers/gpu/drm/panel/panel-innolux-p079zca.c > @@ -230,37 +230,22 @@ static int innolux_panel_add(struct innolux_panel *innolux) > innolux->enable_gpio = NULL; > } > > - np = of_parse_phandle(dev->of_node, "backlight", 0); > - if (np) { > - innolux->backlight = of_find_backlight_by_node(np); > - of_node_put(np); > + innolux->backlight = devm_of_find_backlight(np); There are several errors in these two last patches, like this one: /home/pi/dim-build/workdirs/drm-misc/linux-linus/drivers/gpu/drm/panel/panel-innolux-p079zca.c: In function 'innolux_panel_add': /home/pi/dim-build/workdirs/drm-misc/linux-linus/drivers/gpu/drm/panel/panel-innolux-p079zca.c:233:46: warning: passing argument 1 of 'devm_of_find_backlight' from incompatible pointer type   innolux->backlight = devm_of_find_backlight(np); Instead of tracking down the build dependencies to get this driver built, you can instead use these defconfigs and all DRM drivers should be built: https://cgit.freedesktop.org/drm/drm-tip/tree/?h=rerere-cache But not all drivers are built on every architecture. Noralf. > > - if (!innolux->backlight) > - return -EPROBE_DEFER; > - } > + if (IS_ERR(innolux->backlight)) > + return PTR_ERR(innolux->backlight); > > drm_panel_init(&innolux->base); > innolux->base.funcs = &innolux_panel_funcs; > innolux->base.dev = &innolux->link->dev; > > - err = drm_panel_add(&innolux->base); > - if (err < 0) > - goto put_backlight; > - > - return 0; > - > -put_backlight: > - put_device(&innolux->backlight->dev); > - > - return err; > + return drm_panel_add(&innolux->base); > } > > static void innolux_panel_del(struct innolux_panel *innolux) > { > if (innolux->base.dev) > drm_panel_remove(&innolux->base); > - > - put_device(&innolux->backlight->dev); > } > > static int innolux_panel_probe(struct mipi_dsi_device *dsi) > diff --git a/drivers/gpu/drm/panel/panel-sharp-lq101r1sx01.c b/drivers/gpu/drm/panel/panel-sharp-lq101r1sx01.c > index 072c0fc79..85279d224 100644 > --- a/drivers/gpu/drm/panel/panel-sharp-lq101r1sx01.c > +++ b/drivers/gpu/drm/panel/panel-sharp-lq101r1sx01.c > @@ -327,30 +327,16 @@ static int sharp_panel_add(struct sharp_panel *sharp) > if (IS_ERR(sharp->supply)) > return PTR_ERR(sharp->supply); > > - np = of_parse_phandle(sharp->link1->dev.of_node, "backlight", 0); > - if (np) { > - sharp->backlight = of_find_backlight_by_node(np); > - of_node_put(np); > + sharp->backlight = devm_of_find_backlight(np); > > - if (!sharp->backlight) > - return -EPROBE_DEFER; > - } > + if (IS_ERR(sharp->backlight)) > + return PTR_ERR(sharp->backlight); > > drm_panel_init(&sharp->base); > sharp->base.funcs = &sharp_panel_funcs; > sharp->base.dev = &sharp->link1->dev; > > - err = drm_panel_add(&sharp->base); > - if (err < 0) > - goto put_backlight; > - > - return 0; > - > -put_backlight: > - if (sharp->backlight) > - put_device(&sharp->backlight->dev); > - > - return err; > + return drm_panel_add(&sharp->base); > } > > static void sharp_panel_del(struct sharp_panel *sharp) > @@ -358,9 +344,6 @@ static void sharp_panel_del(struct sharp_panel *sharp) > if (sharp->base.dev) > drm_panel_remove(&sharp->base); > > - if (sharp->backlight) > - put_device(&sharp->backlight->dev); > - > if (sharp->link2) > put_device(&sharp->link2->dev); > } > diff --git a/drivers/gpu/drm/panel/panel-sharp-ls043t1le01.c b/drivers/gpu/drm/panel/panel-sharp-ls043t1le01.c > index 8a5137963..b634ec887 100644 > --- a/drivers/gpu/drm/panel/panel-sharp-ls043t1le01.c > +++ b/drivers/gpu/drm/panel/panel-sharp-ls043t1le01.c > @@ -271,39 +271,22 @@ static int sharp_nt_panel_add(struct sharp_nt_panel *sharp_nt) > gpiod_set_value(sharp_nt->reset_gpio, 0); > } > > - np = of_parse_phandle(dev->of_node, "backlight", 0); > - if (np) { > - sharp_nt->backlight = of_find_backlight_by_node(np); > - of_node_put(np); > + sharp_nt->backlight = devm_of_find_backlight(np); > > - if (!sharp_nt->backlight) > - return -EPROBE_DEFER; > - } > + if (IS_ERR(sharp_nt->backlight)) > + return PTR_ERR(sharp_nt->backlight); > > drm_panel_init(&sharp_nt->base); > sharp_nt->base.funcs = &sharp_nt_panel_funcs; > sharp_nt->base.dev = &sharp_nt->dsi->dev; > > - ret = drm_panel_add(&sharp_nt->base); > - if (ret < 0) > - goto put_backlight; > - > - return 0; > - > -put_backlight: > - if (sharp_nt->backlight) > - put_device(&sharp_nt->backlight->dev); > - > - return ret; > + return drm_panel_add(&sharp_nt->base); > } > > static void sharp_nt_panel_del(struct sharp_nt_panel *sharp_nt) > { > if (sharp_nt->base.dev) > drm_panel_remove(&sharp_nt->base); > - > - if (sharp_nt->backlight) > - put_device(&sharp_nt->backlight->dev); > } > > static int sharp_nt_panel_probe(struct mipi_dsi_device *dsi)