Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp375794imu; Thu, 8 Nov 2018 22:10:20 -0800 (PST) X-Google-Smtp-Source: AJdET5ckVx+fnBkhHpErrd6V83AsH8Ep+cdNXJX3tGUdBxZdRXRvtSXt/+/rRBPiWyzcctge+KrW X-Received: by 2002:a17:902:6b88:: with SMTP id p8-v6mr7347797plk.19.1541743820399; Thu, 08 Nov 2018 22:10:20 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1541743820; cv=none; d=google.com; s=arc-20160816; b=UEDTsEIK4KyJfTRynoa9p1Z93HXOS3W9bheZCiaiLy3HThdPFK/gRacB1+negy2a1I fCYFNB6dyJ/M6q+o21YuU8kU1FZrsG/saJlxdauA2uhrtX9Fun80fNm9WmExG2+XHGHF fqIGi6nMTToRCjWWhSlj24mxE3pBkv7SXYxIHGbHVGkscV/9aD0T1rl9eu5QLx+RKumr J99c0Mhl5rCW0FJZYvQYUjFk8Y4MFL+2trNTYikJQ4NMyvUc3McbLSqkmWqCOI03c+Xh 2VlkBXgTfynGv0Dxh9ohzALJmpxg7nX0m9q1v5i719zo11vYn7yFv7nDVhjDe13zehtc DF4A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dkim-signature; bh=5upJeVS2/PUxAj2eWycRTvspVro5k0eON4BnhkKqWZI=; b=eDpqhsr/hxUbGSQWvEZ+BSMI601BRPqYWT/gOLhfWWPo4AnYI7kTzcpcFoNZ47bxTo cx9chwxTEJkwpSb0zbBiogD8veAvUBTJ2u8ddgE0977NDA6R722Qh4GfQj0dN8k7cqqq g1VtqZi5tq70NZWQD4ZauKHp9U7RWAfkBgfQ4rLraUkg7zCNOHltB53L16mqpQZsqWJY Z5FkFjyoJIANEdAcoF0rKSRUjobaQbe+36i8kVD/GHw6ibL7xiAjuOGdEPcScCKYhqlH JyuDPCD77DzhdNXwLFqPNUKKh1u3VT98wixegUU7yYiSALO6/pnlOumL6sHJ0APtN9Hr FxLw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=nNWnZXcz; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id v8-v6si7173392pfk.264.2018.11.08.22.10.05; Thu, 08 Nov 2018 22:10:20 -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=@gmail.com header.s=20161025 header.b=nNWnZXcz; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727843AbeKIPqs (ORCPT + 99 others); Fri, 9 Nov 2018 10:46:48 -0500 Received: from mail-pl1-f196.google.com ([209.85.214.196]:41680 "EHLO mail-pl1-f196.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727797AbeKIPqr (ORCPT ); Fri, 9 Nov 2018 10:46:47 -0500 Received: by mail-pl1-f196.google.com with SMTP id p16-v6so445478plr.8; Thu, 08 Nov 2018 22:07:47 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=5upJeVS2/PUxAj2eWycRTvspVro5k0eON4BnhkKqWZI=; b=nNWnZXcz7MTRqI9xbo9WBu+JIvTnd0frUv9VxjoVm8JYjGGgoH+hOLUAVZnxogp8ve EKfvVl5mLVpQ2WmiatSONYLheJQfimzxocWGP01zvxGzlBy7wFwFDFBz7Y+nntSN4fWw 9+GfRykPShjkbNALgOliIZ8HG7fSLw5vwMIej2PXGN0d6ss/WzbRMAgtisSxNZpjQmUP +AS8fVXrkZISjiQvzPnVq3tfFRZvjQYM6kX7uURdnOZrXVAMlRW+64Ar5+OB4deIncpv IJze0ezhZd/0G+fH2pRFWifhvTkRMeVYjpguoLNFlOA8jVJnWXonH4k87tJfSb2aLRzu pKXA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references; bh=5upJeVS2/PUxAj2eWycRTvspVro5k0eON4BnhkKqWZI=; b=jCA8IdNjIVQJtcZQYGgSrfdv1nQU9SVgwYum9QfHMYtYxHAIPNj+2QRSpnYOzsdg/D oP3MqklLo7hVZItDHa0i4Zc84+ikyvnuXj82m3Yz6NTZun7vFreoeDSM9tH8JPLHGADD w3FUSN27SkedCEZ2AkL8eup/DEriKkBTwKaf3GOX6dpzkG8ueLqGZKeVixFlcErCIUmk O0stJUDfYlngBnW13ZD2F/+RdmAzF7H79MyVeuDu7lYUKbEWdUer/+cDvb29rV7y51yh FoHao1YH2uE7KSo9kT6T8LCFnBUlMN7PLcgUgtLcVEniHXQW+I01F2GWp645/tKCr8N2 XX/g== X-Gm-Message-State: AGRZ1gJp3H2dx52UvVKsGzkgPbjGGW7s9+ajv9ocE2H02B4xHSBCW1G6 05yosF1J1SyixsY2lirEv/U= X-Received: by 2002:a17:902:c01:: with SMTP id 1-v6mr7647154pls.15.1541743667013; Thu, 08 Nov 2018 22:07:47 -0800 (PST) Received: from localhost.localdomain (c-24-6-192-50.hsd1.ca.comcast.net. [24.6.192.50]) by smtp.gmail.com with ESMTPSA id c70-v6sm6620722pfg.97.2018.11.08.22.07.45 (version=TLS1_2 cipher=ECDHE-RSA-AES128-SHA bits=128/128); Thu, 08 Nov 2018 22:07:46 -0800 (PST) From: frowand.list@gmail.com To: Rob Herring , Pantelis Antoniou , Michael Ellerman , Benjamin Herrenschmidt , Paul Mackerras , Alan Tull , Moritz Fischer Cc: linux-kernel@vger.kernel.org, linuxppc-dev@lists.ozlabs.org, devicetree@vger.kernel.org, linux-fpga@vger.kernel.org Subject: [PATCH v7 02/17] of: overlay: add missing of_node_put() after add new node to changeset Date: Thu, 8 Nov 2018 22:05:50 -0800 Message-Id: <1541743565-23163-3-git-send-email-frowand.list@gmail.com> X-Mailer: git-send-email 1.9.1 In-Reply-To: <1541743565-23163-1-git-send-email-frowand.list@gmail.com> References: <1541743565-23163-1-git-send-email-frowand.list@gmail.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Frank Rowand The refcount of a newly added overlay node decrements to one (instead of zero) when the overlay changeset is destroyed. This change will cause the final decrement be to zero. After applying this patch, new validation warnings will be reported from the devicetree unittest during boot due to a pre-existing devicetree bug. The warnings will be similar to: OF: ERROR: memory leak before free overlay changeset, /testcase-data/overlay-node/test-bus/test-unittest4 This pre-existing devicetree bug will also trigger a WARN_ONCE() from refcount_sub_and_test_checked() when an overlay changeset is destroyed without having first been applied. This scenario occurs when an error in the overlay is detected during the overlay changeset creation: WARNING: CPU: 0 PID: 1 at lib/refcount.c:187 refcount_sub_and_test_checked+0xa8/0xbc refcount_t: underflow; use-after-free. (unwind_backtrace) from (show_stack+0x10/0x14) (show_stack) from (dump_stack+0x6c/0x8c) (dump_stack) from (__warn+0xdc/0x104) (__warn) from (warn_slowpath_fmt+0x44/0x6c) (warn_slowpath_fmt) from (refcount_sub_and_test_checked+0xa8/0xbc) (refcount_sub_and_test_checked) from (kobject_put+0x24/0x208) (kobject_put) from (of_changeset_destroy+0x2c/0xb4) (of_changeset_destroy) from (free_overlay_changeset+0x1c/0x9c) (free_overlay_changeset) from (of_overlay_remove+0x284/0x2cc) (of_overlay_remove) from (of_unittest_apply_revert_overlay_check.constprop.4+0xf8/0x1e8) (of_unittest_apply_revert_overlay_check.constprop.4) from (of_unittest_overlay+0x960/0xed8) (of_unittest_overlay) from (of_unittest+0x1cc4/0x2138) (of_unittest) from (do_one_initcall+0x4c/0x28c) (do_one_initcall) from (kernel_init_freeable+0x29c/0x378) (kernel_init_freeable) from (kernel_init+0x8/0x110) (kernel_init) from (ret_from_fork+0x14/0x2c) Tested-by: Alan Tull Signed-off-by: Frank Rowand --- drivers/of/overlay.c | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/drivers/of/overlay.c b/drivers/of/overlay.c index f5fc8859a7ee..7613f7d680c7 100644 --- a/drivers/of/overlay.c +++ b/drivers/of/overlay.c @@ -379,7 +379,9 @@ static int add_changeset_node(struct overlay_changeset *ovcs, if (ret) return ret; - return build_changeset_next_level(ovcs, tchild, node); + ret = build_changeset_next_level(ovcs, tchild, node); + of_node_put(tchild); + return ret; } if (node->phandle && tchild->phandle) -- Frank Rowand