Received: by 2002:ac0:946b:0:0:0:0:0 with SMTP id j40csp1467580imj; Sun, 10 Feb 2019 02:59:30 -0800 (PST) X-Google-Smtp-Source: AHgI3IZT9UWQ0tgh3Ip/lSvAcqhXyuOghJ8/Z3LuON6kS5V4/4GbZEtu4ZOMxyaM3nH6DKMsInuY X-Received: by 2002:a63:6184:: with SMTP id v126mr1049037pgb.277.1549796370500; Sun, 10 Feb 2019 02:59:30 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1549796370; cv=none; d=google.com; s=arc-20160816; b=nbxCVLRd3sawEN4/jjOadYtJi9EBsFkeXZqgMPBCunqXuziehlLyrk9/388oTzNkLv X8GKJnwDOnJs2cCCatwYUKn73yb9DBQ0AUurlFYZj6Kx84fb1MPNTwwpOJqVASYAqtx9 trMMNpGRCZH5xXNX15PRrLf9tGrEbwwFcGMhXIxSp78qmXD3m9+LGHRZGNEaS/gJkTfT sN6e7U/M7HGBbGkQ9YEI+JBEjQKv1xgzZAkS+R7oBU3Tvccjg54z0CS5auo+sb7oGNYV kdg9fFk2wXbOKiYDkYBO1RzQ7tE4bINQ5t9AQ8nbvXG/HHf2fxtnwQCHDuJDP65k9d3O 4X5w== 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 :references:subject:cc:to:mime-version:user-agent:from:date :message-id:dkim-signature; bh=bL53ccFYg2o18JIG+H4Z3TItp8QKfCnm04mqw0DTumM=; b=iUherC2plHBM6yRW3o8F1JDKyoXY7521FuvK2NxX6M7Yugy1e228U1t1P/HuzvBlM/ Y49lse97XXVLqIfVKzeFuIBK6fSdooJCyeRxLY5xeu07QAV8+/Ls5r7YetsqvGwifpGf c5buY5CgT14ae4v/XOc+XPIDiKpAIx3Hqq7kqhW66QZge4ZmSu235E4ge5C5kg5T8C+6 GDeuevQmml28j9+W0tsEY8UF2/2J4JQ+1sV26nBVIWOHtxhf3bkBdoZpv+rH1wrK5Ps4 q3OJtl+/y0Dl0jp8W0j+HU0xi+rSBcZCIJDYe4LkNCRTr/cyNjy9hCunXIhRI2t4FSOo 1Aag== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@baylibre-com.20150623.gappssmtp.com header.s=20150623 header.b="U8m/duy0"; 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 l2si6771224pgq.163.2019.02.10.02.58.38; Sun, 10 Feb 2019 02:59:30 -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; dkim=pass header.i=@baylibre-com.20150623.gappssmtp.com header.s=20150623 header.b="U8m/duy0"; 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 S1726168AbfBJK5n (ORCPT + 99 others); Sun, 10 Feb 2019 05:57:43 -0500 Received: from mail-wm1-f68.google.com ([209.85.128.68]:52090 "EHLO mail-wm1-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726127AbfBJK5m (ORCPT ); Sun, 10 Feb 2019 05:57:42 -0500 Received: by mail-wm1-f68.google.com with SMTP id b11so11783444wmj.1 for ; Sun, 10 Feb 2019 02:57:41 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=baylibre-com.20150623.gappssmtp.com; s=20150623; h=message-id:date:from:user-agent:mime-version:to:cc:subject :references:in-reply-to:content-transfer-encoding; bh=bL53ccFYg2o18JIG+H4Z3TItp8QKfCnm04mqw0DTumM=; b=U8m/duy06hjnME/XCippTTlf0nljfERLpKebyze+sgKrwWJ4oGJ59C8lDG+3HtERH+ ko3NVWHS1HUsRkeak3Wwk+WpysX4ITHIVPkqvg/DAC4iiKTYV+26br9lRVj9/F1rJ+3W lEe9fcPcige3WU+bd2aHlpcbSTtnZJ3jxy5fvWn1zRZeE9NjPlA2lSmGWUPD2xLBpV4K KtbfRwWJBoBYcNNEAYxO9vnzUY03FvgwlNKgHREq/qrtgrx931MSEOYuU0qzEhbbFW5L s6gS1R8NjDlE7S8vjwf9/Nr1Kh1FlPW+nMXxk6g379HqYWvkqoF2y9czcpKkaQuTkcwN O7AQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:message-id:date:from:user-agent:mime-version:to :cc:subject:references:in-reply-to:content-transfer-encoding; bh=bL53ccFYg2o18JIG+H4Z3TItp8QKfCnm04mqw0DTumM=; b=tf6Tc2nI+mamx2qPGGEhnmVxbWbNLGfFHmte3LC6Gzt5LpKzunDBOxMTNeq+UpMblr CCZEo7jG0/Vxx6+/DfrTQsWdRUV1t3Bi7oVt+5I4/9Bv2LaVF52ejQS7ce1H6pNn155y i7FWLlEMOMb84mu5sRC7IBNHHqZYwH6dd9QsjSCcJWc7pmD9VXvxRKK8gDmLkYcu4YW5 PwmuIfQDH+ltgLt10XzXTRwzQa49dlMzb7fDODliIgmpo1oKrG9J8lBSdVyJpkxu7W/0 m+J0v/k3GYwk7KGGGMZRq1QI8cQbtW9fZVCqzvnN58ibIQArXJ4oH0rFJ0iCV30hLuwO HACA== X-Gm-Message-State: AHQUAubeP8r95RMQgy5OQMhzSepPQpLBBr/v96Q8YaNASaocFXDSqJ1l jF4fAdVkHJpBjbO2JTtcBcATJQ== X-Received: by 2002:a05:6000:8b:: with SMTP id m11mr1384922wrx.243.1549796260348; Sun, 10 Feb 2019 02:57:40 -0800 (PST) Received: from Armstrongs-MacBook-Pro.local (176-150-251-154.abo.bbox.fr. [176.150.251.154]) by smtp.gmail.com with ESMTPSA id s3sm7595606wmj.23.2019.02.10.02.57.39 (version=TLS1 cipher=ECDHE-RSA-AES128-SHA bits=128/128); Sun, 10 Feb 2019 02:57:39 -0800 (PST) Message-ID: <5C6003A2.1000301@baylibre.com> Date: Sun, 10 Feb 2019 11:57:38 +0100 From: Neil Armstrong User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.13; rv:24.0) Gecko/20100101 Thunderbird/24.6.0 MIME-Version: 1.0 To: Wen Yang , Mauro Carvalho Chehab , Kevin Hilman CC: "linux-media@lists.freedesktop.org" , "linux-amlogic@lists.infradead.org" , "linux-media@vger.kernel.org" , "linux-arm-kernel@lists.infradead.org" , "linux-kernel@vger.kernel.org" Subject: Re: [PATCH 2/4] media: platform: meson-ao-cec: fix possible object reference leak References: In-Reply-To: Content-Type: text/plain; charset=ISO-8859-1 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Le 09/02/2019 03:52, Wen Yang a ?crit : > The call to of_parse_phandle() returns a node pointer with refcount > incremented thus it must be explicitly decremented here after the last > usage. > The of_find_device_by_node() takes a reference to the underlying device > structure, we also should release that reference. > This patch fixes those two issues. > > Fixes: 7ec2c0f72cb1 ("media: platform: Add Amlogic Meson AO CEC Controller driver") > Signed-off-by: Wen Yang > --- > drivers/media/platform/meson/ao-cec.c | 13 ++++++++++--- > 1 file changed, 10 insertions(+), 3 deletions(-) > > diff --git a/drivers/media/platform/meson/ao-cec.c b/drivers/media/platform/meson/ao-cec.c > index cd4be38..8ba8b46 100644 > --- a/drivers/media/platform/meson/ao-cec.c > +++ b/drivers/media/platform/meson/ao-cec.c > @@ -613,18 +613,25 @@ static int meson_ao_cec_probe(struct platform_device *pdev) > } > > hdmi_dev = of_find_device_by_node(np); > - if (hdmi_dev == NULL) > + if (hdmi_dev == NULL) { > + of_node_put(np); > return -EPROBE_DEFER; > + } > > + of_node_put(np); > ao_cec = devm_kzalloc(&pdev->dev, sizeof(*ao_cec), GFP_KERNEL); > - if (!ao_cec) > + if (!ao_cec) { > + put_device(&hdmi_dev->dev); > return -ENOMEM; > + } > > spin_lock_init(&ao_cec->cec_reg_lock); > > ao_cec->notify = cec_notifier_get(&hdmi_dev->dev); > - if (!ao_cec->notify) > + if (!ao_cec->notify) { > + put_device(&hdmi_dev->dev); > return -ENOMEM; > + } > > ao_cec->adap = cec_allocate_adapter(&meson_ao_cec_ops, ao_cec, > "meson_ao_cec", > Acked-by: Neil Armstrong Thanks for the fix ! Neil