Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752809Ab3JRAoT (ORCPT ); Thu, 17 Oct 2013 20:44:19 -0400 Received: from mail.active-venture.com ([67.228.131.205]:61468 "EHLO mail.active-venture.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751085Ab3JRAoR (ORCPT ); Thu, 17 Oct 2013 20:44:17 -0400 X-Originating-IP: 108.223.40.66 Message-ID: <52608457.5040609@roeck-us.net> Date: Thu, 17 Oct 2013 17:44:07 -0700 From: Guenter Roeck User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:24.0) Gecko/20100101 Thunderbird/24.0 MIME-Version: 1.0 To: Michael Bohan CC: David Daney , David Gibson , linux-kernel@vger.kernel.org, grant.likely@secretlab.ca, rob.herring@calxeda.com, ralf@linux-mips.org, "devicetree@vger.kernel.org" , david.daney@cavium.com, linux-arm-msm@vger.kernel.org, Pantelis Antoniou Subject: Re: [PATCH] of/lib: Export fdt routines to modules References: <1381966065-16854-1-git-send-email-mbohan@codeaurora.org> <525F2397.40203@caviumnetworks.com> <20131017002731.GA22830@codeaurora.org> <525F6D83.1050808@roeck-us.net> <20131017235132.GA6241@codeaurora.org> In-Reply-To: <20131017235132.GA6241@codeaurora.org> Content-Type: text/plain; charset=ISO-8859-1; format=flowed Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2751 Lines: 64 On 10/17/2013 04:51 PM, Michael Bohan wrote: > On Wed, Oct 16, 2013 at 09:54:27PM -0700, Guenter Roeck wrote: >> On 10/16/2013 05:27 PM, Michael Bohan wrote: >>> My motivation is actually to use the fdt format as a firmware. >>> I have a requirement to express driver metadata that's loadable >> >from the filesystem. This data is not reasonable to place in the >>> system Device Tree, since it's application specific and does not >>> actually describe hardware. The fact that the format chosen is >>> 'flattened device tree' is merely just a coincidence. >>> >> Still, what prevents you from unflattening it and just using the >> normal device tree functions as David suggested ? > > I'm assuming you're suggesting to use of_fdt_unflatten_tree()? Yes, that was the idea. > That's an interesting thought. I was planning to scan the fdt > only once and populate my own structures, but I suppose I could > use the of_* APIs equivalently. > > It seems there are some problems though. of_fdt_unflatten_tree() > does not return errors, and so for the purposes of my driver it > would not be sufficient to detect an invalid firmware image. > It does so, at least partially. If there is an error, it won't set the nodes pointer. Granted, that is not perfect, but it is at least a start. Ultimately, I considered it 'good enough' for my purpose (for devicetree overlays - see [1] below), as any missing mandatory properties or nodes are detected later when trying to actually read the properties. In my case, I also have a couple of validation properties to ensure that the overlay is acceptable (specifically I use 'compatible' and 'assembly-ids', but that is really a detail). > Would people entertain changing this API > (and implicitly __unflatten_device_tree) to return errors? I'm > guessing the reason it's coded that way is because the normal > usecase is 'system boot', at which time errors aren't that > meaningful. > > Also, there's no way to free the memory that was allocated from > the unflatten process. May I add one? > The patchset submitted by Pantelis Antoniou to add support for devicetree overlays adds this and other related functionality. See [1], specifically the patch titled "OF: Introduce utility helper functions". Not sure where that is going, though. It may need some cleanup to be accepted upstream. Copying Pantelis for comments. I also updated the devicetree discussion list address to get comments from the experts. Thanks, Guenter [1] https://lkml.org/lkml/2013/1/4/276 -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/