From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mail-wm0-f67.google.com ([74.125.82.67]:43382 "EHLO mail-wm0-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751087AbdKTLeA (ORCPT ); Mon, 20 Nov 2017 06:34:00 -0500 Received: by mail-wm0-f67.google.com with SMTP id x63so18086424wmf.2 for ; Mon, 20 Nov 2017 03:34:00 -0800 (PST) Subject: Re: [PATCH v2 2/4] backlight: max8925_bl: fix device-tree node lookup To: Johan Hovold , Lee Jones Cc: Jingoo Han , Bartlomiej Zolnierkiewicz , dri-devel@lists.freedesktop.org, linux-fbdev@vger.kernel.org, linux-kernel@vger.kernel.org, stable , Qing Xu , Haojian Zhuang References: <20171120104547.2639-1-johan@kernel.org> <20171120104547.2639-3-johan@kernel.org> From: Daniel Thompson Message-ID: <3ebb4003-bc12-2da2-5b04-caeb3bcceafb@linaro.org> Date: Mon, 20 Nov 2017 11:33:52 +0000 MIME-Version: 1.0 In-Reply-To: <20171120104547.2639-3-johan@kernel.org> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: stable-owner@vger.kernel.org List-ID: On 20/11/17 10:45, Johan Hovold wrote: > Fix child-node lookup during probe, which ended up searching the whole > device tree depth-first starting at the parent rather than just matching > on its children. > > To make things worse, the parent mfd node was also prematurely freed, > while the child backlight node was leaked. > > Fixes: 47ec340cb8e2 ("mfd: max8925: Support dt for backlight") > Cc: stable # 3.9 > Cc: Qing Xu > Cc: Haojian Zhuang > Signed-off-by: Johan Hovold Didn't I already ack this one? Acked-by: Daniel Thompson > --- > drivers/video/backlight/max8925_bl.c | 4 +++- > 1 file changed, 3 insertions(+), 1 deletion(-) > > diff --git a/drivers/video/backlight/max8925_bl.c b/drivers/video/backlight/max8925_bl.c > index 7b738d60ecc2..f3aa6088f1d9 100644 > --- a/drivers/video/backlight/max8925_bl.c > +++ b/drivers/video/backlight/max8925_bl.c > @@ -116,7 +116,7 @@ static void max8925_backlight_dt_init(struct platform_device *pdev) > if (!pdata) > return; > > - np = of_find_node_by_name(nproot, "backlight"); > + np = of_get_child_by_name(nproot, "backlight"); > if (!np) { > dev_err(&pdev->dev, "failed to find backlight node\n"); > return; > @@ -125,6 +125,8 @@ static void max8925_backlight_dt_init(struct platform_device *pdev) > if (!of_property_read_u32(np, "maxim,max8925-dual-string", &val)) > pdata->dual_string = val; > > + of_node_put(np); > + > pdev->dev.platform_data = pdata; > } > >