Received: by 10.213.65.68 with SMTP id h4csp2360463imn; Thu, 5 Apr 2018 13:36:31 -0700 (PDT) X-Google-Smtp-Source: AIpwx4/fO0y/XWH1ZmJwd0HmclQPgZuRr7+Vs7rl+Rq9vpNCBT11aptefyB9JC+HTkQMLzJll1DI X-Received: by 10.98.31.67 with SMTP id f64mr18404558pff.176.1522960590997; Thu, 05 Apr 2018 13:36:30 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1522960590; cv=none; d=google.com; s=arc-20160816; b=su/jcaBhQ6Kb1vdrZjG1gtAwu36uPohNgf7qaY3Q522yvNOMwHevL1uxWIjBLfClTj cplzpIkrj63z9VciMauDPOeH7d+jmfJEnGF85nLWI2xyePYur1R6K91S6+mmSe5wfs4q N94wwFTANd9VDNMtIhdbeOg6d5GH0O6uXqCNP6Dye1+liun0ta2ATw1JgWSab4jtrEnG JMg7G5x/buUm+9zaAd8aaqqePWOQx2yGdy90qQ/uDjOxUGyF/rUz6zHj4/Pbp4RJYOmp w1Sr28Qv6Wau67Q3NK9T5jhfyl2SXn+oHMBwHCKDjJ1iTi0YGec3pD7ncLAXyt50dGHk 956A== 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:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dkim-signature :arc-authentication-results; bh=s3Nyvy6JcJez5b73IRbEfjt29gYqUr4NtOXeC9wz0H4=; b=KaBuZ3eQOGJGi/+BCUzYuyia7rbeJGq9y+VyWE5c6gz0YYWNr758at50ImZIAeJt9K gKea5WEA3TeZwBfJyIMYhsiSPrYVcxOWwXJStSSvAFLit0OiXbnQeFymrnIGrxGPay7V l7zY8z/x8tTq0Xh0OxH19LyBw2Ek0aq4me9aw3+4pKub9VjXMmyUvdTWSZ23RCLXXIay gAh9e+L+kbiBxH8rweDn+x2fIZ/qTujhNyw9hIxlGG2JPH8UBn2DvddjLXCo+He+EGu0 H77r6yM5MbIBgH+xWBslQexHykdKIJR/fpk4hEKU9VpIRtRANZyPvqgvNJwewygEq0Vb 4eXg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=KcALS/ig; 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 e29-v6si9000653plj.8.2018.04.05.13.36.06; Thu, 05 Apr 2018 13:36:30 -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=KcALS/ig; 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 S1753711AbeDEUdU (ORCPT + 99 others); Thu, 5 Apr 2018 16:33:20 -0400 Received: from mail-pl0-f51.google.com ([209.85.160.51]:43356 "EHLO mail-pl0-f51.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753399AbeDEUdS (ORCPT ); Thu, 5 Apr 2018 16:33:18 -0400 Received: by mail-pl0-f51.google.com with SMTP id a39-v6so1539003pla.10; Thu, 05 Apr 2018 13:33:18 -0700 (PDT) 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=s3Nyvy6JcJez5b73IRbEfjt29gYqUr4NtOXeC9wz0H4=; b=KcALS/igmibAvmHbCCGOoMPWqoExpmdDwiLN1EYL+iopwWLDs0Dq+VjlnWC7NVe+y/ vnmzuLK1ue169klwir1xR72GDx/3MDmydSq0zosqX1viGiFPtxxMB6Upn5C4zNL0AWdT T4UA27AjHsJr9aiOTpPgYEMfKFaLpThAIYO7FIKNjqQAOOIBKtTKoDeKGySpavplwQaK pupubj4yquPyfqzzBsqTR5pnZgqn78Y2m/VAhcfB4lM7kgKMhCbURWFi7KZc99m49a4i yJwpiP9m55INzQarQUr7N+4akpsb+yDGLnvOOdE99ewTV9LYlprZxUZP0B3uk4ycVzYL sCvQ== 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=s3Nyvy6JcJez5b73IRbEfjt29gYqUr4NtOXeC9wz0H4=; b=Wr2hAIOaZCof7nNO9kcYeT+T+Ilo60Iaq2V3DMKZkleMgzq5R5EYboTp8ea5n2mUio CRXL7VZxkpicuuvdSE3X1iQCPPtkwgPTCXFdDyWoOzlY3bpjhx0Dm3xVAAQpVOcUgtag MXTYFA+pUkkjaKNZSf9ONzIYAkfRcILrMitS3D4Rk132KpBOD/agAams5VImo6S3bZJu 9rAMDHDY+f5DW9LU5zpd37S9tSaULubtaJlKyv+NQoNniTWm++817Va055BfxDK5sb24 9fbnqLJZjCwxHZh4DgyheGMK7ctsAoNKw1Oes0sQ/S/QIgI2OvgnpLg5ttynZ1t+PCo0 6GfA== X-Gm-Message-State: AElRT7Gu5AFYcZtdNh3SokgcOqIxiboUcOY6mf0dF3wSNB0kPM9Aiw7M j/DzNBT8m2rfA/LEoPKVHlw= X-Received: by 2002:a17:902:822:: with SMTP id 31-v6mr24910476plk.200.1522960397731; Thu, 05 Apr 2018 13:33:17 -0700 (PDT) Received: from [192.168.1.70] (c-73-93-215-6.hsd1.ca.comcast.net. [73.93.215.6]) by smtp.gmail.com with ESMTPSA id l74sm17265388pfi.138.2018.04.05.13.33.16 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Thu, 05 Apr 2018 13:33:17 -0700 (PDT) Subject: Re: [PATCH v7 2/5] of: change overlay apply input data from unflattened to FDT To: Jan Kiszka , Rob Herring , pantelis.antoniou@konsulko.com, Pantelis Antoniou Cc: devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, geert@linux-m68k.org, laurent.pinchart+renesas@ideasonboard.com, Jailhouse References: <1520122673-11003-1-git-send-email-frowand.list@gmail.com> <1520122673-11003-3-git-send-email-frowand.list@gmail.com> <09e3db63-cbf9-52a2-ee77-520979f17fea@web.de> <7bbf615b-3cdd-6bb4-6918-33e48de4225d@gmail.com> <255dffbd-4ff1-42a4-033b-311d49339102@web.de> From: Frank Rowand Message-ID: <70c766c9-aa4b-d67c-37a0-795fc5bc228f@gmail.com> Date: Thu, 5 Apr 2018 13:33:15 -0700 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.6.0 MIME-Version: 1.0 In-Reply-To: <255dffbd-4ff1-42a4-033b-311d49339102@web.de> 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 On 04/05/18 12:38, Jan Kiszka wrote: > On 2018-04-05 21:28, Frank Rowand wrote: >> On 04/05/18 12:13, Jan Kiszka wrote: >>> On 2018-04-05 20:59, Frank Rowand wrote: >>>> Hi Jan, >>>> >>>> On 04/04/18 15:35, Jan Kiszka wrote: >>>>> Hi Frank, >>>>> >>>>> On 2018-03-04 01:17, frowand.list@gmail.com wrote: >>>>>> From: Frank Rowand >>>>>> >>>>>> Move duplicating and unflattening of an overlay flattened devicetree >>>>>> (FDT) into the overlay application code. To accomplish this, >>>>>> of_overlay_apply() is replaced by of_overlay_fdt_apply(). >>>>>> >>>>>> The copy of the FDT (aka "duplicate FDT") now belongs to devicetree >>>>>> code, which is thus responsible for freeing the duplicate FDT. The >>>>>> caller of of_overlay_fdt_apply() remains responsible for freeing the >>>>>> original FDT. >>>>>> >>>>>> The unflattened devicetree now belongs to devicetree code, which is >>>>>> thus responsible for freeing the unflattened devicetree. >>>>>> >>>>>> These ownership changes prevent early freeing of the duplicated FDT >>>>>> or the unflattened devicetree, which could result in use after free >>>>>> errors. >>>>>> >>>>>> of_overlay_fdt_apply() is a private function for the anticipated >>>>>> overlay loader. >>>>> >>>>> We are using of_fdt_unflatten_tree + of_overlay_apply in the >>>>> (out-of-tree) Jailhouse loader driver in order to register a virtual >>>>> device during hypervisor activation with Linux. The DT overlay is >>>>> created from a a template but modified prior to application to account >>>>> for runtime-specific parameters. See [1] for the current implementation. >>>>> >>>>> I'm now wondering how to model that scenario best with the new API. >>>>> Given that the loader lost ownership of the unflattened tree but the >>>>> modification API exist only for the that DT state, I'm not yet seeing a >>>>> clear solution. Should we apply the template in disabled form (status = >>>>> "disabled"), modify it, and then activate it while it is already applied? >>>> >>>> Thank you for the pointer to the driver - that makes it much easier to >>>> understand the use case and consider solutions. >>>> >>>> If you can make the changes directly on the FDT instead of on the >>>> expanded devicetree, then you could move to the new API. >>> >>> Are there some examples/references on how to edit FDTs in-place in the >>> kernel? I'd like to avoid writing the n-th FDT parser/generator. >> >> I don't know of any existing in-kernel edits of the FDT (but they might >> exist). The functions to access an FDT are in libfdt, which is in >> scripts/dtc/libfdt/. >> > > Ah, libfdt is available for kernel drivers as well. That looks like a > viable path on first sight. I'll try that and come back in case it does > not solve all issues. > >> >>>> >>>> Looking at the driver, I see one potential issue with that approach. >>>> The property "interrupt-map" is added directly to the changeset >>>> instead of being an existing property in the overlay. Is it possible >>>> to have this property in the overlay when needed? >>> >>> Well, the size of that property has a runtime dependency on the gic's >>> #address-cells. If that is easy to account for depends a bit on the >>> available FDT manipulation services. Or it would take multiple templates >>> to handle the different cases (0, 1, or 2 IIRC). >> >> If I understand create_vpci_of_overlay() correctly, it is assuming a >> fixed size of 4 cells. Line 314 is: for (n = 0, cell = 0; n < 4; n++) { >> >> Off the top of my head, it is theoretically possible to create a property >> that can contain the largest possible size for the property, then shrink >> the size by inserting NOPs at the end of the property to shrink it. > > Well, I even find fdt_appendprop which sounds like we could keep adding > that property on the fly. > > How does memory management work with libfdt? Do I have to ensure that > the fdt is already backed by an area large enough also for it modified form? I have not looked at those functions, so I don't know. > > Thanks, > Jan >