Received: by 10.223.164.202 with SMTP id h10csp5050593wrb; Tue, 21 Nov 2017 04:03:04 -0800 (PST) X-Google-Smtp-Source: AGs4zMaMMBsrq7H5nmLn/Lx7ICU7C8SNWp9bf2VDynwJpIcqWI7n3wqD5nujf8j400kXLNGUF4/s X-Received: by 10.84.235.137 with SMTP id p9mr16537567plk.291.1511265784068; Tue, 21 Nov 2017 04:03:04 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1511265784; cv=none; d=google.com; s=arc-20160816; b=VipIXlxvKAKwKVmV9sDoLTJCguTOwuGKg9D2H3RJa88mXHjELZ1IbeF67RRlYUVhWr R43WdWdNONCs3WXS2EHiQqbCpiV9UGihiB89868pMk3QO0tzveVgQBMRhEQnB3pSDcnK tfDpAaaBurSFXEsAGj7u356O5WB+wGUe/e2mRyxKd3yFFAVu0+Fu+pybwS1JYGyG9VNE Ex/mUe8Oj6YQMSC8/FGeha6j4+gw0vPUMQdLAQSkwksVkQo4VlJbw4k3XNmuvTNFTCmm z/Gxst/zgAy0AlBCnPY4LYMsN/DhmeU3SSv520jHP8MCsjejMynp/zdYwCbF+giBtWDQ fttQ== 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:organization:references:to:from:subject:reply-to :arc-authentication-results; bh=FA9dONPjyLWcxlgCXMF/0AuTgyeE1B5FsvYJKb8tBQw=; b=iW6nGMbC3OE3zQMWXcNOiJNuPzYZi5ZcLwxj4U4Y/BMRX8ofasNqFdDG2iYsPGXp/C i0dceyG19mRIAgrkwoe6yj4d5J4IRHoc8/7zGvP+el1TdGnKkMS8dk19rSk+T1Tx7vqC 8h+Xq6ggqcbujtVKb7INewK3ig+TP5SNfAxbs5F9MH6qcHH14siQT7EpaKNu4DEoC6Gl 5DVXV0/0z6v1lZVDFRpQ1aA7NmIuFLJoueoulSRHnWwCSSUJvq5FPwOmVjSpq6lEiODo Ueh4rmRRvLJ3Joi0V8PI6R8r0q3Vhh+IHyrP9XyWUttwcA3PD2tlHnBFkUx41JBUXymx /21w== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id a8si4175943ple.537.2017.11.21.04.02.52; Tue, 21 Nov 2017 04:03:04 -0800 (PST) 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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752018AbdKUMCM (ORCPT + 75 others); Tue, 21 Nov 2017 07:02:12 -0500 Received: from v-smtpout2.han.skanova.net ([81.236.60.155]:44180 "EHLO v-smtpout2.han.skanova.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751918AbdKUMCK (ORCPT ); Tue, 21 Nov 2017 07:02:10 -0500 Received: from [10.175.196.237] ([37.123.169.62]) by cmsmtp with SMTP id H7FfeInqOAXuLH7FfeFRPG; Tue, 21 Nov 2017 13:02:08 +0100 Reply-To: linux-kernel@emagii.com Subject: Re: RFC: Copying Device Tree File into reserved area of VMLINUX before deployment From: Ulf Samuelsson To: Frank Rowand , LKML , "devicetree@vger.kernel.org" , Rob Herring References: <0b31e22b-202f-6fca-28f2-e16e6af6c6b7@emagii.com> <0e54f9f0-1226-7f2e-3143-ea4e450058e6@gmail.com> <872e81dc-82ba-f838-c4f8-88d2208d23d2@emagii.com> <4d2f0bf4-d49a-27bc-75aa-11c78bc074fa@emagii.com> Organization: eMagii Message-ID: Date: Tue, 21 Nov 2017 13:02:07 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.4.0 MIME-Version: 1.0 In-Reply-To: <4d2f0bf4-d49a-27bc-75aa-11c78bc074fa@emagii.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 8bit X-CMAE-Envelope: MS4wfAroav6Rxy8jwojouGqpfOgJiXufqBapJOVPQmp6lFfhoFEQe7RWaoNOfhKej+uNjkxZ9z87XQmOBwXIDMKhHkLRMXz+URRG25uTHw74sA0JRa47A5Sa 6ePxmc8g5bhS4ZpFWF9R3oIlSF4g9lrNmvgEXGy5cDjrstyNk/sNCUXSN8lPLnmIWBqiYFJAFEv8Gg6azq/xlvQkA/dhbk6HHv5F9bZaPDp7x18EPA5uQvoj FDOOru3EyekKqMPbnvMp99SsQwAf/ODvebLaBY63qgdVoL4YcEzgs8gSMsGHMlsG Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2017-11-21 07:19, Ulf Samuelsson wrote: > > > On 2017-11-21 00:09, Ulf Samuelsson wrote: >> >> >> On 2017-11-20 22:39, Frank Rowand wrote: >>> Hi Ulf, Rob, >>> >>> On 11/20/17 15:19, Ulf Samuelsson wrote: >>>> >>>> >>>> On 2017-11-20 05:32, Frank Rowand wrote: >>>>> Hi Ulf, >>>>> >>>>> >>>>> On 11/19/17 23:23, Frank Rowand wrote: >>>>>> adding devicetree list, devicetree maintainers >>>>>> >>>>>> On 11/18/17 12:59, Ulf Samuelsson wrote: >>>>>>> I noticed when checking out the OpenWRT support for the board >>>>>>> that they have a method to avoid having to pass the device tree >>>>>>> address to the kernel, and can thus boot device tree based >>>>>>> kernels with U-boots that >>>>>>> does not support device trees. >>>>>>> >>>>>>> Is this something that would be considered useful for including >>>>>>> in mainstream: >>>>>>> >>>>>>> BACKGROUND: >>>>>>> Trying to load a yocto kernel into a MIPS target (MT7620A based), >>>>>>> and the U-Boot is more than stupid. >>>>>>> Does not support the "run" command as an example. >>>>>>> They modified the U-Boot MAGIC Word to complicate things. >>>>>>> The U-Boot is not configured to use device tree files. >>>>>>> The board runs a 2.6 kernel right now. >>>>>>> >>>>>>> Several attempts by me a and others to rebuild U-Boot according to >>>>>>> the H/W vendors source code and build instructions results in a >>>>>>> bricked unit. Bricked units cannot be recovered. >>>>> >>>>> Hopefully you have brought this to the attention of the vendor. >>>>> U-Boot >>>>> is GPL v2 (or in some ways possibly GPL v2 or later), so if you can >>>>> not >>>>> build U-Boot that is equivalent to the binary U-Boot they shipped, the >>>>> vendor may want to ensure that they are shipping the proper source and >>>>> build instructions. >>>>> >>>> >>>> I am not the one in contact with the H/W vendor. >>>> The U-boot is pretty old, and from comments from those >>>> in contact with them, the U-Boot knowledge at the H/W vendor >>>> is minimal at best. >>>> It might even be that they program an U-boot where the upgrade of >>>> the U-boot is broken... >>>> >>>> >>>>> >>>>>>> Not my choice of H/W, so I cannot change it. >>>>>>> >>>>>>> >>>>>>> =================================================================== >>>>>>> OPENWRT: >>>>>>> I noticed when checking out the OpenWRT support for the board that >>>>>>> they have a method to avoid having to pass the device tree address >>>>>>> to the kernel, and can thus boot device tree based kernels with >>>>>>> U-boots that does not support device trees. >>>>>>> >>>>>>> What they do is to reserve 16 kB of kernel space, and tag it with >>>>>>> an ASCII string "OWRTDTB:". After the kernel and dtb is built, a >>>>>>> utility "patch-dtb" will update the vmlinux binary, copying in the >>>>>>> device tree file. >>>>>>> >>>>>>> =================================================================== >>>>>>> It would be useful to me, and I could of course patch the >>>>>>> mainstream kernel, but first I would like to check if this is of >>>>>>> interest for mainstream. >>>>> >>>>> Not in this form.  Hard coding a fixed size area in the boot image >>>>> to contain the FDT (aka DTB) is a non-starter. >>>> >>>> OK, Is it the fixed size, which is a problem? >>> >>> Yes, it is the fixed size which is a problem. >> >> The size can of course be changed, by setting the size configuration >> option (DTB_SIZE). >> OpenWRT does not support that, but I think it needs to be there for a >> generic option (but You have to recompile the kernel to increase the >> size). >> >> One problem is that you normally compile and link the kernel before you >> compile the dtbs, so you do not know what size is until afterwards. >> > Found this link:    https://csl.name/post/embedding-binary-data/ > > ======================================= > ... > Let's say you have an image target.dtb and want to embed it into your > application. You can create an object file with > > > image_dtb.o:    >     mv    image_dtb >     ld -r -b binary image_dtb -o image_dtb.o > > The object file will have three symbols in it, > > $ nm cat.o > 0000000000000512 D _binary_image_dtb_end > 0000000000000512 A _binary_image_dtb_size > 0000000000000000 D _binary_image_dtb_start > ======================================= > > This assumes that the dtbs are built before the kernel is linked. > The copy step is neccessary, since the generated names are > taken from the name of the "in file". > (Would have been better, if they used the "out file") > > Otherwise you can create an assembler file which "incbin's" the dtb file. > Just checked the kernel source, and it appears that the discussion is somewhat redundant, since the support is already in the linux kernel for some MIPS boards arch/mips/Kconfig: config MIPS_ELF_APPENDED_DTB bool "vmlinux" help With this option, the boot code will look for a device tree binary DTB) included in the vmlinux ELF section .appended_dtb. By default it is empty and the DTB can be appended using binutils command objcopy: objcopy --update-section .appended_dtb=.dtb vmlinux This is meant as a backward compatiblity convenience for those systems with a bootloader that can't be upgraded to accommodate the documented boot protocol using a device tree. arch/mips/kernel/setup.c: #ifdef CONFIG_MIPS_ELF_APPENDED_DTB const char __section(.appended_dtb) __appended_dtb[0x100000]; #endif /* CONFIG_MIPS_ELF_APPENDED_DTB */ arch/mips/bmips/setup.c #ifdef CONFIG_MIPS_ELF_APPENDED_DTB if (!fdt_check_header(&__appended_dtb)) dtb = (void *)&__appended_dtb; else #endif > > > >> >>> >>>> Is generally combining an image with a DTB into a single file also a >>>> non-starter? >>> >>> Can you jump in here Rob?  My understanding is that >>> CONFIG_ARM_APPENDED_DTB, >>> which is the ARM based solution that Mark mentioned, was envisioned as a >>> temporary stop gap until boot loaders could add devicetree support. >>> I don't >>> know if there is a desire to limit this approach or to remove it in the >>> future. >>> >>> I'm not sure why this feature should not be permanently supported. >>> I'm being >>> cautious, just in case I'm overlooking or missing an important issue, >>> thus >>> asking for Rob's input.  I do know that this feature does not advance >>> the >>> desires of people who want a single kernel (single boot image?) that >>> runs on >>> many different systems, instead of a boot image that is unique to each >>> target platform.  But I don't see why that desire precludes also having >>> an option to have a target specific boot image. >> The main reason to keep it is when you are really constrained for memory. >> The U-Boot on the board is 96 kB, which is just a fraction of a more >> normal U-Boot. >> Also, the u-boot is old. >> >> >>> >>> -Frank >>> >>> >>>>> >>>>> And again, I would first approach the H/W vendor before trying to >>>>> come up with a work around like this. >>>>> >>>>> >>>>>>> I envisage the support would look something like: >>>>>>> >>>>>>> ============ >>>>>>> Kconfig. >>>>>>> config MIPS >>>>>>>       select    HAVE_IMAGE_DTB >>>>>>> >>>>>>> config    HAVE_IMAGE_DTB >>>>>>>       bool >>>>>>> >>>>>>> if HAVE_IMAGE_DTB >>>>>>> config     IMAGE_DTB >>>>>>>       bool    "Allocated space for DTB within image >>>>>>> >>>>>>> config    DTB_SIZE >>>>>>>       int    "DTB space (kB) >>>>>>> >>>>>>> config    DTB_TAG >>>>>>>       string    "DTB space tag" >>>>>>>       default    "OWRTDTB:" >>>>>>> endif >>>>>>> >>>>>>> ============ >>>>>>> Some Makefile >>>>>>> obj-$(CONFIG_INCLUDE_DTB) += image_dtb.o >>>>>>> >>>>>>> ============ >>>>>>> image_dtb.S: >>>>>>>       .text >>>>>>>       .align    5 >>>>>>>       .ascii    CONFIG_DTB_TAG >>>>>>>       EXPORT(__image_dtb) >>>>>>>       .fill    DTB_SIZE * 1024 >>>>>>> >>>>>>> =================== >>>>>>> arch/mips/xxx/of.c: >>>>>>> >>>>>>> #if    defined(CONFIG_IMAGE_DTB) >>>>>>>       if () >>>>>>>           __dt_setup_arch(__dtb_start); >>>>>>>       else >>>>>>>           __dt_setup_arch(&__image_dtb); >>>>>>> #else >>>>>>>       __dt_setup_arch(__dtb_start); >>>>>>> #endif >>>>>>> >>>>>>> I imagine that if the support is enabled for a target, it should >>>>>>> be possible to override it with a CMDLINE argument >>>>>>>            They do something similar for the CMDLINE; copying it >>>>>>> into the vmlinux, to allow a smaller boot >>>> >>> >> > -- Best Regards Ulf Samuelsson From 1584655463678912452@xxx Tue Nov 21 06:20:16 +0000 2017 X-GM-THRID: 1584466498009191251 X-Gmail-Labels: Inbox,Category Forums,HistoricalUnread