Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp3769219pxb; Tue, 26 Jan 2021 04:26:05 -0800 (PST) X-Google-Smtp-Source: ABdhPJzQLfSpPCZKvJtQLfzAUNdV3r2HfxDr4sbKU34mmDfpaWA+c+W06IO3vIb719aRV1rSTLSp X-Received: by 2002:a17:907:d25:: with SMTP id gn37mr3155832ejc.381.1611663965256; Tue, 26 Jan 2021 04:26:05 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1611663965; cv=none; d=google.com; s=arc-20160816; b=Muqh/ugEUI4AGhtChOhjtWQfRtxXIHZUN/6Kfs2DmeeEn3XN1EhJ/HpPGlwLPWS+Gx 78bVH37i/OuLG+f5S6K5SE5g/Xs1qDG/RWd+WuQ7ngUo/FFiPbtIatqjC1SJTgWvXaHP SL1ZsA9eHoOwKiQK08bAeD7i1lbt0r5d3zPjdcNxzoMmsrzdgxpOmOOMnHDWrFDUwCXQ KYDqdzA7IaUma+LfyurJPbM9DjgdY8Tu6ZFfU97QZ3CWDOeunYJnM5Ky/uie0FmStty0 gkNyoMmZcTsPMyVnxSh+a7QP4IGXuABhxbxLT8rD1Ds91DosjkYxKVIS+/lBmwjkKd02 PSXg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject:dkim-signature; bh=GlDwSv5vGV0NrH+Gyfq0mpa+FzrKZ7rYP/44E0uNm8E=; b=vhKvG8gubsi2DHwVoUxZaphUZzp6yjIJiB7+6fdiMY6TOKUDXQe0Uijn/omhZIXcMD KUHs90tuzHCievoXENnh4+BeTmZoOm5ytDVWF8m83/ejd08O8qiJciM/XF+tleCzrZ6W 4znwWNtcrR1X8iJ4sthAWgMoDAWimZiT/KHwiR+qV/j2BWGfJ8bSfCOWVpOGXmO2RtOf 9hEPLRAOgCvfVf6XRq469nSKVyWA0GpwQj0X+br4SQNqrBL2/JAt0VWY8MkVvGoTHeeq +eM+N/5ZPW5VX62DgVXijLtBbjVvBCAGxt4ZE5wnOAiWMXBf5tEs7Gq+2hxFKSdoL7R/ gcfA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=nE4OjwWq; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 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. [23.128.96.18]) by mx.google.com with ESMTP id s22si6089693edi.465.2021.01.26.04.25.40; Tue, 26 Jan 2021 04:26:05 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=nE4OjwWq; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 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 S2404622AbhAZKya (ORCPT + 99 others); Tue, 26 Jan 2021 05:54:30 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:41262 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726451AbhAZDP5 (ORCPT ); Mon, 25 Jan 2021 22:15:57 -0500 Received: from mail-qt1-x82d.google.com (mail-qt1-x82d.google.com [IPv6:2607:f8b0:4864:20::82d]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 54F9EC061573; Mon, 25 Jan 2021 19:15:17 -0800 (PST) Received: by mail-qt1-x82d.google.com with SMTP id z6so11401996qtn.0; Mon, 25 Jan 2021 19:15:17 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=subject:to:cc:references:from:message-id:date:user-agent :mime-version:in-reply-to:content-language:content-transfer-encoding; bh=GlDwSv5vGV0NrH+Gyfq0mpa+FzrKZ7rYP/44E0uNm8E=; b=nE4OjwWqEa9kjkCEW9mtf4C2Yhc1uRfT1jWrO1Xhh7Ef1tWeSv+LaedzncSPHCDAx+ aKOkJ+UzfoxeyBR3mnVjm566Ncnj4JQtf78rBNdVlegIwPihC7ld03rVTTswrvvqG3Ra Zh8PYkyxTCDjpP/DStHkhLa9zMoJ6TBbBuR7FUb4uommfJMoZ466NKYLAYRwHwY4hua5 S1zS8DSX6SLN8+uM/xspF6jfzXfg8HJexf9BE5KBq5kOu/qCuJQNWKptG9nxsIzWJtYc lbZCKcjRPQrx53Cyk5GyE2mM2GUXRbhnW9VtlunFnBDUPMP1BV+NkIIKUMiLU731znWM bY7g== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=GlDwSv5vGV0NrH+Gyfq0mpa+FzrKZ7rYP/44E0uNm8E=; b=oTcis8gJqskjZtToiHD46QJ/ZS6YCMiM4j4n/EbweC6Tuo92wGGghpiF58MwEoaaYN 67v97j2o599ZHQwPxY8E5N7JRTXXy8unXudQKtusrQrK1yxFpknlQvjYqlSSOk0BsIKw gW89bcJzVQzEiXsoz2YVtIfHJx1W13uDeTHQmsyOBvdKYAQRomsJetwEhxpO9ygaG8hV Ny5rqyjONnLIHQM0AELmlimOpXhohOgi0QzUc/h8hq9bwDUsXwRXSnkz4x2UbCIkoxJ1 VFtPNDNWw7xqpAKi8HksQskXiILgxqf8Q1lJE389sWDCVfESaZgkcjbNbyJk7wZSCLgh 0Ljw== X-Gm-Message-State: AOAM530Au6YiDjOrnzX8kAnAFA6PJ8LioeSfDtVQ+5ppdKxw3USzCLo+ sOe9Pz1dhfb/d/qEGAYWJnjqLNP6A4L2tA== X-Received: by 2002:ac8:6f07:: with SMTP id g7mr3523701qtv.54.1611630916512; Mon, 25 Jan 2021 19:15:16 -0800 (PST) Received: from [192.168.1.49] (c-67-187-90-124.hsd1.ky.comcast.net. [67.187.90.124]) by smtp.gmail.com with ESMTPSA id s23sm9818672qtq.56.2021.01.25.19.15.15 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Mon, 25 Jan 2021 19:15:16 -0800 (PST) Subject: Re: [PATCH V6 6/6] of: unittest: Statically apply overlays using fdtoverlay To: Viresh Kumar , Rob Herring , Pantelis Antoniou , Masahiro Yamada Cc: Vincent Guittot , linux-kernel@vger.kernel.org, anmar.oueja@linaro.org, Bill Mills , David Gibson , devicetree@vger.kernel.org, Michal Marek References: <58e8523e1489b70b76211fb94a9229ae12c33cad.1611312122.git.viresh.kumar@linaro.org> From: Frank Rowand Message-ID: <68370651-4706-308e-db18-fc3642116b8a@gmail.com> Date: Mon, 25 Jan 2021 21:15:14 -0600 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.10.0 MIME-Version: 1.0 In-Reply-To: <58e8523e1489b70b76211fb94a9229ae12c33cad.1611312122.git.viresh.kumar@linaro.org> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 1/22/21 4:50 AM, Viresh Kumar wrote: > Now that fdtoverlay is part of the kernel build, start using it to test > the unitest overlays we have by applying them statically. Create a new > base file static_base.dts which includes other .dtsi files. > > Some unittest overlays deliberately contain errors that unittest checks > for. These overlays will cause fdtoverlay to fail, and are thus not > included in the static_test.dtb. > > Signed-off-by: Viresh Kumar > --- > drivers/of/unittest-data/Makefile | 51 ++++++++++++++++++++++++ > drivers/of/unittest-data/static_base.dts | 5 +++ > 2 files changed, 56 insertions(+) > create mode 100644 drivers/of/unittest-data/static_base.dts > > diff --git a/drivers/of/unittest-data/Makefile b/drivers/of/unittest-data/Makefile > index 009f4045c8e4..586fa8cda916 100644 > --- a/drivers/of/unittest-data/Makefile > +++ b/drivers/of/unittest-data/Makefile > @@ -34,7 +34,58 @@ DTC_FLAGS_overlay += -@ > DTC_FLAGS_overlay_bad_phandle += -@ > DTC_FLAGS_overlay_bad_symbol += -@ > DTC_FLAGS_overlay_base += -@ > +DTC_FLAGS_static_base += -@ > DTC_FLAGS_testcases += -@ > > # suppress warnings about intentional errors > DTC_FLAGS_testcases += -Wno-interrupts_property > + > +# Apply overlays statically with fdtoverlay. This is a build time test that > +# the overlays can be applied successfully by fdtoverlay. This does not > +# guarantee that the overlays can be applied successfully at run time by > +# unittest, but it provides a bit of build time test coverage for those > +# who do not execute unittest. > +# > +# The overlays are applied on top of static_base.dtb to create static_test.dtb > +# If fdtoverlay detects an error than the kernel build will fail. > +# static_test.dtb is not consumed by unittest. > +# > +# Some unittest overlays deliberately contain errors that unittest checks for. > +# These overlays will cause fdtoverlay to fail, and are thus not included > +# in the static test: > +# overlay_bad_add_dup_node.dtb \ > +# overlay_bad_add_dup_prop.dtb \ > +# overlay_bad_phandle.dtb \ > +# overlay_bad_symbol.dtb \ > +# overlay_base.dtb \ > + > +apply_static_overlay := overlay.dtb \ rename apply_static_overlay to apply_static_overlay_2: apply_static_overlay_2 := overlay.dtb Then the remainder of apply_static_overlay becomes apply_static_overlay_1: apply_static_overlay_1 := > + overlay_0.dtb \ > + overlay_1.dtb \ > + overlay_2.dtb \ > + overlay_3.dtb \ > + overlay_4.dtb \ > + overlay_5.dtb \ > + overlay_6.dtb \ > + overlay_7.dtb \ > + overlay_8.dtb \ > + overlay_9.dtb \ > + overlay_10.dtb \ > + overlay_11.dtb \ > + overlay_12.dtb \ > + overlay_13.dtb \ > + overlay_15.dtb \ > + overlay_gpio_01.dtb \ > + overlay_gpio_02a.dtb \ > + overlay_gpio_02b.dtb \ > + overlay_gpio_03.dtb \ > + overlay_gpio_04a.dtb \ > + overlay_gpio_04b.dtb > + > +quiet_cmd_fdtoverlay = FDTOVERLAY $@ > + cmd_fdtoverlay = $(objtree)/scripts/dtc/fdtoverlay -o $@ -i $^ > + > +$(obj)/static_test.dtb: $(obj)/static_base.dtb $(addprefix $(obj)/,$(apply_static_overlay)) > + $(call if_changed,fdtoverlay) Split the static_test.dtb into _1 and _2: > +$(obj)/static_test_1.dtb: $(obj)/static_base_1.dtb $(addprefix $(obj)/,$(apply_static_overlay_1)) > + $(call if_changed,fdtoverlay) > +$(obj)/static_test_2.dtb: $(obj)/static_base_2.dtb $(addprefix $(obj)/,$(apply_static_overlay_2)) > + $(call if_changed,fdtoverlay) > + > +always-$(CONFIG_OF_OVERLAY) += static_test.dtb > diff --git a/drivers/of/unittest-data/static_base.dts b/drivers/of/unittest-data/static_base.dts > new file mode 100644 > index 000000000000..3c9af4aefb96 > --- /dev/null > +++ b/drivers/of/unittest-data/static_base.dt> @@ -0,0 +1,5 @@ > +// SPDX-License-Identifier: GPL-2.0 > +/dts-v1/; > + > +#include "overlay_common.dtsi" > +#include "testcases_common.dtsi" > Split static_base.dts into static_base_1.dts and static_base_2.dts: static_base_1.dts: > +// SPDX-License-Identifier: GPL-2.0 > +/dts-v1/; > + > +#include "testcases_common.dtsi" static_base_2.dts: > +// SPDX-License-Identifier: GPL-2.0 > +/dts-v1/; > + > +#include "overlay_common.dtsi"