Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp408605imu; Thu, 8 Nov 2018 22:56:53 -0800 (PST) X-Google-Smtp-Source: AJdET5dD18thI7p0JkcTmAlkyZSI1CauBfT2Uu3ur7iTJgZfYahLRbFRJdI/Vv1c3em14IStMRId X-Received: by 2002:a17:902:a984:: with SMTP id bh4-v6mr7765342plb.163.1541746613134; Thu, 08 Nov 2018 22:56:53 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1541746613; cv=none; d=google.com; s=arc-20160816; b=vm9VdYEuKkqfDtpc+rPqI0RL5esGFSZPSQm6zzWdl502NIfEHfuj5dnJJgVCwN8bm0 hxYaaalU2hMnDVyetK/J1HUg01hfBwZmT2te4lLl/7mRfq63JzweoGVg0mYypBVqUhX4 Gdb8dIC/F2gHWfEikk0dHow8gN4NUwaqwGyDHneQ8+dEWsDG/muaKLjNjdodpZgywpa+ +qmF9SEkEq+tZOzcmpaQUrwK0mAIo8FCXqVQ1N5cbFF8fHfpcaM4vtIxqvz8IupQk6y/ o9lJzkN1IfFvrHTrQOGaCaGHTMYvRn9asNPchAYR9S+Pf2M00XkGwEm6HUGkWiiig5Kr dGgg== 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 :content-language:mime-version:user-agent:date:message-id:subject :from:cc:to:dkim-signature; bh=ZfD90Hvp0FuovJUhMX05MqKYD8ZCEtw5w94uyNFI8Qo=; b=NX40ziniOB+YNjl+/ABXp57pU4QJYBcMTnPMajTlAI0dM2fURu9nsICzKt5LMdm8uH 4qOfv1jQbK1z/YCbfgErPluhHo3np2rI4IM4YmoKgiy6dlozFruJmKf9EKKjM20Z9cRv HzzGHIR6xs8VAlSy8CVuAezukR1dCMQfSPiDwUS1b40Eaikuu3mqQk1e/UHUg1JzrO9h 2wFk98hdsyljF91m/v55cWHV9oXAPKMxvZjvW2cVTZBO0qY90g5rw5H8E5yXEY/nnKMW RHKbXM7GnGl2bVFk4AsYq+YAl23BEJz0sgi9MGH51cS8n2uyUkBr7vLj99sjJ9fVhkVx T0GQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=oe5HHdak; 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 k21-v6si6077981pgj.381.2018.11.08.22.56.37; Thu, 08 Nov 2018 22:56:53 -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=oe5HHdak; 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 S1728019AbeKIQf1 (ORCPT + 99 others); Fri, 9 Nov 2018 11:35:27 -0500 Received: from mail-pg1-f194.google.com ([209.85.215.194]:41712 "EHLO mail-pg1-f194.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727693AbeKIQf1 (ORCPT ); Fri, 9 Nov 2018 11:35:27 -0500 Received: by mail-pg1-f194.google.com with SMTP id 70so452960pgh.8; Thu, 08 Nov 2018 22:56:16 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=to:cc:from:subject:message-id:date:user-agent:mime-version :content-language:content-transfer-encoding; bh=ZfD90Hvp0FuovJUhMX05MqKYD8ZCEtw5w94uyNFI8Qo=; b=oe5HHdakLh9BH1W8MU3AFu1RzNoBlN/4tVsxRE/UQYqJI8N4qTm8fx2e0OcSlKqlP5 O23wL4TRdei2KvgdoUFmb5KNYUk/KkkQmpYzkALD2XF6565COSai4DIhcKSmY+iCX5rg cSKz+Fi3+gDqQvJsPq7rYh8NYEaY5p1FBrYa4kZKDSD1vIq8nsQe0SmMLdTeofHGmPV+ YVPgnXcJSNFDuKN04oFZ4yRoKp27EVetYuSal8ZUbmJW1imjT2+tlpnxeRRJBKJr4xxA 8rNSnpT/ZSsWe1JVbb1j4O0kynwZevYWdKt+ZigJX9h0qWpFgya5lUuY5SLH8XrJ5kP8 bfgg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:to:cc:from:subject:message-id:date:user-agent :mime-version:content-language:content-transfer-encoding; bh=ZfD90Hvp0FuovJUhMX05MqKYD8ZCEtw5w94uyNFI8Qo=; b=rihPY1qgi9s4RnpmQk12d1o6o/C1Zt6Q1pTRrWMJxLwAs7BF9tO4sjmO3lmGwOhDys CQMmURm5IvdawxNTqWL3oEZtHrUSmvt9FBdqe2Kh0WAqnye91RvuETN5/uBAj2Ihfdf2 4ls5antgT3D+KkQzC7OHGnIWMN9fiN8lNqYYOVH/0V8NeonNjxGGgetAo3LRCFpRpoTt ppDSiGqDPmXmp6+14r4gLg9zd4XW8ZfQZyirBRDMh2TKENFgBcB6/Z3YfJmePjkeIEPm p+c57EWLHzf6yw/W0CRipf8P01owQZFnQWXGEVY42rNhHErz7X5hTGiqo5iapClkzrEL /MBw== X-Gm-Message-State: AGRZ1gK4OuSf8h10lwmBbYk4D56ZabwJKWs2C52RkkxN0q8qsbS+w80F 8Krq/cuYDd8OKOvYaAV7nP4= X-Received: by 2002:a62:160c:: with SMTP id 12-v6mr7776030pfw.45.1541746575691; Thu, 08 Nov 2018 22:56:15 -0800 (PST) Received: from [192.168.1.70] (c-24-6-192-50.hsd1.ca.comcast.net. [24.6.192.50]) by smtp.gmail.com with ESMTPSA id e65-v6sm7181502pfa.90.2018.11.08.22.56.14 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Thu, 08 Nov 2018 22:56:15 -0800 (PST) To: Rob Herring , Pantelis Antoniou , Michael Ellerman , Benjamin Herrenschmidt , Paul Mackerras , Alan Tull , Moritz Fischer Cc: "devicetree@vger.kernel.org" , "linux-kernel@vger.kernel.org" , linuxppc-dev , linux-fpga@vger.kernel.org From: Frank Rowand Subject: [GIT PULL] of: overlay: validation checks, subsequent fixes for v20 Message-ID: <262419e9-5c9f-1193-f119-33f373d81e43@gmail.com> Date: Thu, 8 Nov 2018 22:56:13 -0800 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.2.1 MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Rob, Please pull the changes to add the overlay validation checks. This is the v7 version of the patch series. -Frank The following changes since commit 651022382c7f8da46cb4872a545ee1da6d097d2a: Linux 4.20-rc1 (2018-11-04 15:37:52 -0800) are available in the git repository at: git://git.kernel.org/pub/scm/linux/kernel/git/frowand/linux.git tags/kfree_validate_v7-for-4.20 for you to fetch changes up to eeb07c573ec307c53fe2f6ac6d8d11c261f64006: of: unittest: initialize args before calling of_*parse_*() (2018-11-08 22:12:37 -0800) ---------------------------------------------------------------- Add checks to (1) overlay apply process and (2) memory freeing triggered by overlay release. The checks are intended to detect possible memory leaks and invalid overlays. The checks revealed bugs in existing code. Fixed the bugs. While fixing bugs, noted other issues, which are fixed in separate patches. ---------------------------------------------------------------- Frank Rowand (17): of: overlay: add tests to validate kfrees from overlay removal of: overlay: add missing of_node_put() after add new node to changeset of: overlay: add missing of_node_get() in __of_attach_node_sysfs powerpc/pseries: add of_node_put() in dlpar_detach_node() of: overlay: use prop add changeset entry for property in new nodes of: overlay: do not duplicate properties from overlay for new nodes of: overlay: reorder fields in struct fragment of: overlay: validate overlay properties #address-cells and #size-cells of: overlay: make all pr_debug() and pr_err() messages unique of: overlay: test case of two fragments adding same node of: overlay: check prevents multiple fragments add or delete same node of: overlay: check prevents multiple fragments touching same property of: unittest: remove unused of_unittest_apply_overlay() argument of: overlay: set node fields from properties when add new overlay node of: unittest: allow base devicetree to have symbol metadata of: unittest: find overlays[] entry by name instead of index of: unittest: initialize args before calling of_*parse_*() arch/powerpc/platforms/pseries/dlpar.c | 2 + drivers/of/dynamic.c | 59 ++++- drivers/of/kobj.c | 4 +- drivers/of/overlay.c | 292 ++++++++++++++++----- drivers/of/unittest-data/Makefile | 2 + .../of/unittest-data/overlay_bad_add_dup_node.dts | 28 ++ .../of/unittest-data/overlay_bad_add_dup_prop.dts | 24 ++ drivers/of/unittest-data/overlay_base.dts | 1 + drivers/of/unittest.c | 96 +++++-- include/linux/of.h | 21 +- 10 files changed, 432 insertions(+), 97 deletions(-) create mode 100644 drivers/of/unittest-data/overlay_bad_add_dup_node.dts create mode 100644 drivers/of/unittest-data/overlay_bad_add_dup_prop.dts