Received: by 2002:a05:6a10:2785:0:0:0:0 with SMTP id ia5csp133299pxb; Thu, 14 Jan 2021 22:00:28 -0800 (PST) X-Google-Smtp-Source: ABdhPJyoD3cvnUFBaDtMzHwIjkP80CnblhW93OrKmmRXX1f+jw8lTypAuphiTNGlarTINBqZQOaf X-Received: by 2002:a17:906:af89:: with SMTP id mj9mr6809824ejb.528.1610690427858; Thu, 14 Jan 2021 22:00:27 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1610690427; cv=none; d=google.com; s=arc-20160816; b=NQtsDW9gXQOcJXHEcZdYm6MQvTeZ53wa5Ly9AmK7YuACjH2krMjJU+u6UTqzuOEouE NuMDb6v7/F+j2Sy0dAoA4g87srvVh8bGK9I/8otnijV11P46eOO++y+43jse3E9Dy1yu De28Tq/LM2EqTVaCx3ZN2TnDrUvSn8idVgk57cXSFGx0aHC/6dYZe1QIBq3h3R5qIikG JPNijR+/lO02GEzX0Ekklt98ucEeE2fto5bDUh1r8u1Y36Ksji2E7vrcPbv0fZSrOyx+ vdBFEyqzVbRtv7WS0Lr5A9bL+aUjKs+ZUDhsvLXvi5Oi0RQ+1XLrVHaqekXbkYQguPNY a5KQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:user-agent:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date :dkim-signature; bh=J4IRduRh2lPDHoDnzAXwEKVdTwmGpK4GMKe23FN9dLk=; b=oFTmNgKTn1fzyw4MSv5rOrgP/qo09jY9Lv6E9vJc7u2Ud2xzg3d6c6PmrcQkfdjdqP /5No33nKUsLPE56+WG3E1KeYGsd0VeZvKMPzhvbHTOCZF7ZdYFPc8GPPeI2btYWENoz1 kForNB5gc8goJT1lvruHMzT8R1YY2ovXV6LSba94C2rMucw70oxR8IAimAJ/Xs0Kg06N YQDnAsIkYmRgWczV8SMjHZ1/8e5KHe+5ldl7ampSxyqCJ+JtrJ4XOIiXwsay0+Akvgga vdjbQ6YKT1xGFCQRteEmVRNltyno2ujnDaj2MQ1o/8pKur1c97RhnrM0zhiKnqU05Ayf dw1Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=rj8Z9+0l; 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=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id y9si4202891edm.482.2021.01.14.22.00.02; Thu, 14 Jan 2021 22:00:27 -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=@linaro.org header.s=google header.b=rj8Z9+0l; 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=NONE dis=NONE) header.from=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1732365AbhAOFpn (ORCPT + 99 others); Fri, 15 Jan 2021 00:45:43 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:36176 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1732162AbhAOFpf (ORCPT ); Fri, 15 Jan 2021 00:45:35 -0500 Received: from mail-pj1-x102d.google.com (mail-pj1-x102d.google.com [IPv6:2607:f8b0:4864:20::102d]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id EB36BC061757 for ; Thu, 14 Jan 2021 21:44:54 -0800 (PST) Received: by mail-pj1-x102d.google.com with SMTP id my11so4988632pjb.1 for ; Thu, 14 Jan 2021 21:44:54 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=date:from:to:cc:subject:message-id:references:mime-version :content-disposition:in-reply-to:user-agent; bh=J4IRduRh2lPDHoDnzAXwEKVdTwmGpK4GMKe23FN9dLk=; b=rj8Z9+0lMpn1ImzkWb0s2wW/9B+FKkZ4vtshtOtG9AJudfmkuebkIKixPLX+g0MxsH tGPn8ub+sFbLGac5dzHm0T6FHu7oNDIEjI87ShJQ4PlIMlZxHPo6KwWb5suAsPv2VjD3 TdyqZQS1cJomHP3xihTS9sOFskYLMMBYeXyHhi9VAl6GaGopIWjfsSt+QunfH8dtAMde XYe47DPafbGSWq3+o2nc4cKwvDA5XCOhDK3Xx8cDwcroXMrikc02XXhacQKBqkEY9xAa qYC/IUHplNM2HJ//AvioQC5TrRswqhZNwytBFdgKGf56N5h11ZRN4CcHHNtCXeyftwm3 mfXQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:in-reply-to:user-agent; bh=J4IRduRh2lPDHoDnzAXwEKVdTwmGpK4GMKe23FN9dLk=; b=HzVbvaDj8rj80EIUvZ6fhx0ZkU0vm0p/NBmynJ9lun+6DvgYP0OH6XcqmdAXDik+gH MO772gYq4O/mZcAD9nUWrLokBdnIPvn6sj4evdmBRj4D09l4f1G9mWt+qeb0VCd1yZXk EWQLlsf3nQZwOqmi5naT3lNXG7+C9JqI3FFFuN5dorPtigUMye0pO6W02UEtHtaJ2mLr c9Q0gWc/F0/g9QWjF0Fo75jS3pqWVVciiCnan4BhCoGwfxm6ebXEcHpXymCnJm4ugil0 2Lr703Hvtai+avRfaLmg81XUXX/QftOK6hSJMbHjDsXemCeuxuA+04P1fybcPzxgr5kJ +SMg== X-Gm-Message-State: AOAM5300/FOVzg6EniPTKqPdV/RP5Q1KB0slZWl6kbjZjSH4zHQO0THR ZZqk4vBBmM4x5d9b3XpD+WhdJQ== X-Received: by 2002:a17:90b:f08:: with SMTP id br8mr8737209pjb.134.1610689494482; Thu, 14 Jan 2021 21:44:54 -0800 (PST) Received: from localhost ([122.172.85.111]) by smtp.gmail.com with ESMTPSA id bk18sm3194628pjb.41.2021.01.14.21.44.52 (version=TLS1_2 cipher=ECDHE-ECDSA-AES128-GCM-SHA256 bits=128/128); Thu, 14 Jan 2021 21:44:53 -0800 (PST) Date: Fri, 15 Jan 2021 11:14:50 +0530 From: Viresh Kumar To: Rob Herring , David Gibson Cc: Pantelis Antoniou , Frank Rowand , devicetree@vger.kernel.org, "linux-kernel@vger.kernel.org" , Linux Kbuild mailing list , Vincent Guittot , Bill Mills , Anmar Oueja , Masahiro Yamada Subject: Re: [PATCH] of: unittest: Statically apply overlays using fdtoverlay Message-ID: <20210115054450.ab2xrohlxg7nnzpn@vireshk-i7> References: <1e42183ccafa1afba33b3e79a4e3efd3329fd133.1610095159.git.viresh.kumar@linaro.org> <20210114050309.wokrhw4o3cjxj5uo@vireshk-i7> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: User-Agent: NeoMutt/20180716-391-311a52 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org +David, On 14-01-21, 09:01, Rob Herring wrote: > On Wed, Jan 13, 2021 at 11:03 PM Viresh Kumar wrote: > > > > On 11-01-21, 09:46, Rob Herring wrote: > > > On Fri, Jan 8, 2021 at 2:41 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. > > > > > > Nice idea. > > > > > > > The file overlay_base.dtb have symbols of its own and we need to apply > > > > overlay.dtb to overlay_base.dtb alone first to make it work, which gives > > > > us intermediate-overlay.dtb file. > > > > > > Okay? If restructuring things helps we should do that. Frank? > > > > Frank, do we want to do something about it ? Maybe make overlay_base.dts an dtsi > > and include it from testcases.dts like the other ones ? > > No, because overlay_base.dts is an overlay dt. What property of a file makes it an overlay ? Just the presence of /plugin/; ? David, we are talking about the overlay base[1] file here. The fdtoverlay tool fails to apply it to testcases.dts file (in the same directory) because none of its nodes have the __overlay__ label and the dtc routine overlay_merge() [2] skips them intentionally. > I think we need an > empty, minimal base.dtb to apply overlay_base.dtbo to. One way out is adding an (almost-empty) testcase-data-2 in testcases.dtb, that will make it work. > And then fdtoverlay needs a fix to apply overlays to the root node? It isn't just root node I think, but any node for which the __overlay__ label isn't there. So this can make it all work if everyone is fine with it: diff --git a/drivers/of/unittest-data/overlay_base.dts b/drivers/of/unittest-data/overlay_base.dts index 99ab9d12d00b..59172c4c9e5a 100644 --- a/drivers/of/unittest-data/overlay_base.dts +++ b/drivers/of/unittest-data/overlay_base.dts @@ -11,8 +11,7 @@ * dtc will create nodes "/__symbols__" and "/__local_fixups__". */ -/ { - testcase-data-2 { + &overlay_base { #address-cells = <1>; #size-cells = <1>; @@ -89,5 +88,3 @@ retail_1: vending@50000 { }; }; -}; - diff --git a/drivers/of/unittest-data/testcases.dts b/drivers/of/unittest-data/testcases.dts index a85b5e1c381a..539dc7d9eddc 100644 --- a/drivers/of/unittest-data/testcases.dts +++ b/drivers/of/unittest-data/testcases.dts @@ -11,6 +11,11 @@ node-remove { }; }; }; + + overlay_base: testcase-data-2 { + #address-cells = <1>; + #size-cells = <1>; + }; -------------------------8<------------------------- And then we can do this to the Makefile over my changes. -------------------------8<------------------------- diff --git a/drivers/of/unittest-data/Makefile b/drivers/of/unittest-data/Makefile index 9f3eb30b78f1..8cc23311b778 100644 --- a/drivers/of/unittest-data/Makefile +++ b/drivers/of/unittest-data/Makefile @@ -41,7 +41,6 @@ DTC_FLAGS_testcases += -Wno-interrupts_property # Apply all overlays (except overlay_bad_* as they are not supposed to apply and # fail build) statically with fdtoverlay -intermediate-overlay := overlay.dtb master := 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 \ @@ -50,15 +49,12 @@ master := overlay_0.dtb overlay_1.dtb overlay_2.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 \ - intermediate-overlay.dtb + overlay_base.dtb overlay.dtb quiet_cmd_fdtoverlay = fdtoverlay $@ cmd_fdtoverlay = $(objtree)/scripts/dtc/fdtoverlay -o $@ -i $^ -$(obj)/intermediate-overlay.dtb: $(obj)/overlay_base.dtb $(addprefix $(obj)/,$(intermediate-overlay)) - $(call if_changed,fdtoverlay) - $(obj)/master.dtb: $(obj)/testcases.dtb $(addprefix $(obj)/,$(master)) $(call if_changed,fdtoverlay) -always-$(CONFIG_OF_OVERLAY) += intermediate-overlay.dtb master.dtb +always-$(CONFIG_OF_OVERLAY) += master.dtb -- viresh [1] https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/drivers/of/unittest-data/overlay_base.dts [2] https://git.kernel.org/pub/scm/utils/dtc/dtc.git/tree/libfdt/fdt_overlay.c#n628