Received: by 2002:ac0:a582:0:0:0:0:0 with SMTP id m2-v6csp2503437imm; Thu, 18 Oct 2018 16:07:17 -0700 (PDT) X-Google-Smtp-Source: ACcGV61bJ7Fz6qp67L9AKL3I5h/nYnzw1nzaz4U3aksT5ZtjW30Tz/6/cTosU01PSLMm5qZz3pdh X-Received: by 2002:a62:6801:: with SMTP id d1-v6mr32221683pfc.7.1539904037110; Thu, 18 Oct 2018 16:07:17 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1539904037; cv=none; d=google.com; s=arc-20160816; b=srExLc4e+vNKkDwbBzh7UQEiYcVkx1BC8hNmboStHYw7LP6DNo2JGkCQIc0Nwb0rsk H8BF7CuCnLHKWzUtxsispxzw/81FiXPYdeVNYsWC5BfSIoNHTdN2GMHDx/zvdHDT2O2c uoHT9fZYPn/JByTuZWq9lfM8yFJ/K66fRsexqTqn0vMWMSTW9PGwqmYIMt3wJd/6zpjc 7b+kK7nRXEAVhIzxbiZNDDN9mFGT2fp0Qel8TxWMqE4aXGE+H1eVQPLuXIOFgf0xVENj Drt4FFUekMBwOoKHwuHmr1UjZ7JcLl0mgt/DNRKAsBn+KTVWdO1XwLBibbsWLBj96kbK ovNQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :dkim-signature; bh=RjThF0EvHGI6dWXNCVEiHTZA1JEA+VjGl4N3F03pIL4=; b=r6lCSCbe9SYZiJMDBfiJQY1TTu4liunwweBlqZlVhwpX1YMwemNze/xhmpvZM27ckb hoR9jjCkbS43BHuXMbMQp00yVZMF4Jl+YSe2MhmZdstMmcnW0irBEN5PE2VhxmIfWx8t 8VttsyJzO6DeCVvAQV6QGRq/8cJZfzbPMwifZffI1qrA7IVwBwK5dkNygjIyWqLrTtsp Hk1UauNJdXx0hTdPEFCPaBz/8Hicfai4TPhqqevYiLtprWc5cGulv/PXDjLnrdoikJbT 30h9tvnIrBsDfS5KdZUt9u9loKHYQVK0QnPTBmacj2W7lR1UtmLTs3xaWvPM07X8daeC B4mg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=cdx7lTKV; 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 y6-v6si22759956pge.215.2018.10.18.16.07.01; Thu, 18 Oct 2018 16:07:17 -0700 (PDT) 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=cdx7lTKV; 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 S1727139AbeJSGvO (ORCPT + 99 others); Fri, 19 Oct 2018 02:51:14 -0400 Received: from mail-pf1-f193.google.com ([209.85.210.193]:43753 "EHLO mail-pf1-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726245AbeJSGvO (ORCPT ); Fri, 19 Oct 2018 02:51:14 -0400 Received: by mail-pf1-f193.google.com with SMTP id p24-v6so15545633pff.10; Thu, 18 Oct 2018 15:48:04 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id; bh=RjThF0EvHGI6dWXNCVEiHTZA1JEA+VjGl4N3F03pIL4=; b=cdx7lTKV2/C6pIWAYbDnp2jfkD5EnegxH5gPCqh0f8HaL7eOGBtleFzoqWjOt2N+Ju Iw3Jiky64CNrQnCoxa9b1F/eGVQwVYzHkN0V1ieKtZ04wf7/uXSU6jjUfDaeOSwlNiET x6vDVzZvB3XUpb7Lh3T6SbNNqJDVTkCswQgXM37AprpZSciOpOdxbhfG8QKqsNiXf2kY T5veNJGtztD9Cq3KfIwcdDOKLuciGeXecY6Tn30sf4kjvZL+i5GryyNCPctaARN45+EI CrCcXuPQUi7esDG0cLoHK1XkkqhdaYLiEYuskoTN91panm3pobXAyzDyuxjrG8Hu8wDs QPzw== 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; bh=RjThF0EvHGI6dWXNCVEiHTZA1JEA+VjGl4N3F03pIL4=; b=acOnZQ+caAE7aClJfifocdeUzr/dDOQrTXLvP+LKQFV0zDx851dxs0qWiuv3mYQ0ir qN7Mts8uirdK/Cw1SVkx3ZKV5ysEfB+AWyzzc1DdJVTD1VvaZMB+S0GBMSKr6QF3wOIY ZuD+bVGANYVL4us+tyuaLAQvYtyfUaJlC065WOCZhYAteQsj9RnopgEZMh7hTcGgQH1D OffUOUlbUiUOy+iE4c2sy/i8cMb/LOa9thx0vMrAgAPxTuPbhuoKVRO0ZWiviYhgepbj 0GSb+uGOwec4SOevtTxD4MwzngR0q8sk1nB4scbUJLioB76+kfEaVA1lwYuzrGrIpwcy Xo9g== X-Gm-Message-State: ABuFfogg87AT6IVFxZQgnGbyCl6DvTuDIE4pVd2jYGg35jXfpKpBUA9K AOr01a+76RKFhEn6Kec6N6Y= X-Received: by 2002:a63:f553:: with SMTP id e19-v6mr29964602pgk.417.1539902884242; Thu, 18 Oct 2018 15:48:04 -0700 (PDT) Received: from localhost.localdomain (c-24-6-192-50.hsd1.ca.comcast.net. [24.6.192.50]) by smtp.gmail.com with ESMTPSA id v81-v6sm38129268pfj.25.2018.10.18.15.48.02 (version=TLS1_2 cipher=ECDHE-RSA-AES128-SHA bits=128/128); Thu, 18 Oct 2018 15:48:03 -0700 (PDT) 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 v5 00/18] of: overlay: validation checks, subsequent fixes Date: Thu, 18 Oct 2018 15:46:18 -0700 Message-Id: <1539902796-8382-1-git-send-email-frowand.list@gmail.com> X-Mailer: git-send-email 1.9.1 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Frank Rowand 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. ***** Powerpc folks: I was not able to test the patches that ***** directly impact Powerpc systems that use dynamic ***** devicetree. Please review that code carefully and ***** test. The specific patches are: 03/16, 04/16, 07/16 FPGA folks: I made the validation checks that should result in an invalid live devicetree report "ERROR" and cause the overlay apply to fail. I made the memory leak validation tests report "WARNING" and allow the overlay apply to complete successfully. Please let me know if you encounter the warnings. There are at least two paths forward to deal with the cases that trigger the warning: (1) change the warning to an error and fail the overlay apply, or (2) find a way to detect the potential memory leaks and free the memory appropriately. ALL people: The validations do _not_ address another major concern I have with releasing overlays, which is use after free errors. Changes since v4: - 01/18: make error message format consistent, error first, path last - 09/18: create of_prop_val_eq() and change open code to use it - 09/18: remove extra blank lines Changes since v3: - 01/18: Add expected value of refcount for destroy cset entry error. Also explain the cause of the error. - 09/18: for errors of an overlay changing the value of #size-cells or #address-cells, return -EINVAL so that overlay apply will fail - 09/18: for errors of an overlay changing the value of #size-cells or #address-cells, make the message more direct. Old message: OF: overlay: ERROR: overlay and/or live tree #size-cells invalid in node /soc/base_fpga_region New message: OF: overlay: ERROR: changing value of /soc/base_fpga_region/#size-cells not allowed - 13/18: Update patch comment header to state that this patch modifies the previous patch to not return immediately on fragment error and explain this is not a performance issue. - 13/18: remove redundant "overlay" from two error messages. "OF: overlay:" is already present in pr_fmt() Changes since v2: - 13/18: Use continue to reduce indentation in find_dup_cset_node_entry() and find_dup_cset_prop() Changes since v1: - move patch 16/16 to 17/18 - move patch 15/16 to 18/18 - new patch 15/18 - new patch 16/18 - 05/18: add_changeset_node() header comment: incorrect comment for @target - 18/18: add same fix for of_parse_phandle_with_args() - 18/18: add same fix for of_parse_phandle_with_args_map() *** BLURB HERE *** Frank Rowand (18): 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: dynamic: change type of of_{at,de}tach_node() to void 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 | 15 +- arch/powerpc/platforms/pseries/reconfig.c | 6 +- drivers/of/dynamic.c | 68 +++-- 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 | 25 +- 11 files changed, 439 insertions(+), 122 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 -- Frank Rowand