Received: by 2002:ac0:b08d:0:0:0:0:0 with SMTP id l13csp4923886imc; Mon, 25 Feb 2019 13:44:37 -0800 (PST) X-Google-Smtp-Source: AHgI3Ib67zpWjKtODZxwn1pVS0dENemIlPeIsi3NtFKnDTAw1wVXgR3jRPhuYFzOcst0yzMW8erK X-Received: by 2002:a17:902:12e:: with SMTP id 43mr22583462plb.31.1551131077472; Mon, 25 Feb 2019 13:44:37 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1551131077; cv=none; d=google.com; s=arc-20160816; b=EPKGWwUXWF+9urVNP7V3bCfcGUJmzAf15QXW3bLzDHMoxC+vyPgBvOEbRMDOBcBfzm 5A5CQBXPKAh+KLBaJEmGdz0894McGW7VfqHu0F2eAjrQa6YJCPm6nANnZm12L/AJWWp+ euQKgpI3p+IhVwP+lTWiS8JLGLoCMKIKF/DKpvDGoa7e+ms2Fq/+uU4ouwBPlFF7RZsn PR3e7txdNSTmRux1ADilicEqwjEPFQk7X8qbMsXmpXh0UIsn0HpHs8sgRZrgEudu4hNJ 74Dynhr9ooWQ3kGN7sExTbGteFSBWT7uG3v5EwlshyTGGAji4dGJf6mxnnl58q2n7WeH y/uA== 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 :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=gLaN5BL3NFyEdQaQ3jY8uraxt1RQxyAUfzT/NJJlPf0=; b=LLboocAuDkQYWu299+dJ4JLqpPhSuqapQ2lsbjceefvqyhU5P/DJGJy8dOoBD2h13b WSTRLGSmAh+7wBGg/vhY85FZWrBAV/dYtpyY/b16Df+IT5Lf86yKhPeeqBIyXfzjYVBj brJoaWdFZCwt2wecQq34YXE0rEBsr6l8yY3h6KeL6VoCs8dq/keAnMpoy5NNmg71rEoD uFvCN3eBFIsN5UxMHgXVnIrMTZkF5hqklSPXMWzTS+atlk8YTu65BrbtcirZVBHGHD5n zOSgJoOK4Y8e4rYSIHaYi7yOTi/zU/OpOiLAiQ7JF8kIeihkA0FRkKLNAj1VnYb1gU9X KT3A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=K8RCgg5x; 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 x125si1579937pfd.30.2019.02.25.13.44.22; Mon, 25 Feb 2019 13:44:37 -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=@kernel.org header.s=default header.b=K8RCgg5x; 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 S1732535AbfBYVcm (ORCPT + 99 others); Mon, 25 Feb 2019 16:32:42 -0500 Received: from mail.kernel.org ([198.145.29.99]:38386 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1732521AbfBYVck (ORCPT ); Mon, 25 Feb 2019 16:32:40 -0500 Received: from localhost (5356596B.cm-6-7b.dynamic.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 152E821850; Mon, 25 Feb 2019 21:32:38 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1551130359; bh=1usEiyhDJE4Xg84lPkEz5PNMUE8G7mQ7/trWkhlNOMU=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=K8RCgg5x50Gfdd1/U1OfQX84P2JOaulP34AF/HbHCIMc8evbvAH0DwHHGaTsR8qwT yXoFyVA6OIMChyclVqdZY/lViwiHl6V3HH8P0OHrzJsPveZse5aYycWymhgqjd9xM8 n77zwnf/Xp913a44PdESU647deS82xQErKl6wUIs= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Julia Lawall , Maxime Ripard , Sasha Levin Subject: [PATCH 4.20 095/183] drm/sun4i: backend: add missing of_node_puts Date: Mon, 25 Feb 2019 22:11:08 +0100 Message-Id: <20190225195110.696644933@linuxfoundation.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20190225195054.748060397@linuxfoundation.org> References: <20190225195054.748060397@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review X-Patchwork-Hint: ignore MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 4.20-stable review patch. If anyone has any objections, please let me know. ------------------ [ Upstream commit 4bb0e6d7258213d4893c2c876712fbba40e712fe ] The device node iterators perform an of_node_get on each iteration, so a jump out of the loop requires an of_node_put. Remote and port also have augmented reference counts, so drop them on each iteration and at the end of the function, respectively. Remote is only used for the address it contains, not for the contents of that address, so the reference count can be dropped immediately. The semantic patch that fixes the first part of this problem is as follows (http://coccinelle.lip6.fr): // @@ expression root,e; local idexpression child; iterator name for_each_child_of_node; @@ for_each_available_child_of_node(root, child) { ... when != of_node_put(child) when != e = child + of_node_put(child); ? break; ... } ... when != child // Signed-off-by: Julia Lawall Signed-off-by: Maxime Ripard Link: https://patchwork.freedesktop.org/patch/msgid/1547369264-24831-5-git-send-email-Julia.Lawall@lip6.fr Signed-off-by: Sasha Levin --- drivers/gpu/drm/sun4i/sun4i_backend.c | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/drivers/gpu/drm/sun4i/sun4i_backend.c b/drivers/gpu/drm/sun4i/sun4i_backend.c index bf49c55b0f2c7..9f27d5464804b 100644 --- a/drivers/gpu/drm/sun4i/sun4i_backend.c +++ b/drivers/gpu/drm/sun4i/sun4i_backend.c @@ -704,17 +704,18 @@ static struct sun4i_frontend *sun4i_backend_find_frontend(struct sun4i_drv *drv, remote = of_graph_get_remote_port_parent(ep); if (!remote) continue; + of_node_put(remote); /* does this node match any registered engines? */ list_for_each_entry(frontend, &drv->frontend_list, list) { if (remote == frontend->node) { - of_node_put(remote); of_node_put(port); + of_node_put(ep); return frontend; } } } - + of_node_put(port); return ERR_PTR(-EINVAL); } -- 2.19.1