* bootloader support for DTB on x86 @ 2012-05-22 12:56 Thierry Reding [not found] ` <20120522125622.GA21187-RM9K5IK7kjIQXX3q8xo1gnVAuStQJXxyR5q1nwbD4aMs9pC9oP6+/A@public.gmane.org> 0 siblings, 1 reply; 6+ messages in thread From: Thierry Reding @ 2012-05-22 12:56 UTC (permalink / raw) To: devicetree-discuss-uLR06cmDAlY/bJ5BZ2RsiQ Cc: Sebastian Andrzej Siewior, x86-DgEjT+Ai2ygdnm+yROfE0A, Rob Herring, Ingo Molnar, H. Peter Anvin, Thomas Gleixner [-- Attachment #1.1: Type: text/plain, Size: 755 bytes --] Hi, I was looking at booting an x86-based platform using DT. However I wasn't able to find a bootloader that supports this. There also doesn't seem to be a method to append the DTB to the zImage (which I wouldn't want to use anyway). Does anybody know of a bootloader that supports this? I'm currently using syslinux (specifically extlinux) and was looking at perhaps adding the support myself based on the information given in Documentation/x86/boot.txt. However I'm not overly familiar with syslinux code and this could prove more difficult than I anticipate. The only x86 platforms that use DT seem to be OLPC and CE4100 and according to the web the OLPC has a complete OF implementation. Does anyone know which bootloader the CE4100 uses? Thierry [-- Attachment #1.2: Type: application/pgp-signature, Size: 198 bytes --] [-- Attachment #2: Type: text/plain, Size: 192 bytes --] _______________________________________________ devicetree-discuss mailing list devicetree-discuss-uLR06cmDAlY/bJ5BZ2RsiQ@public.gmane.org https://lists.ozlabs.org/listinfo/devicetree-discuss ^ permalink raw reply [flat|nested] 6+ messages in thread
[parent not found: <20120522125622.GA21187-RM9K5IK7kjIQXX3q8xo1gnVAuStQJXxyR5q1nwbD4aMs9pC9oP6+/A@public.gmane.org>]
* Re: bootloader support for DTB on x86 [not found] ` <20120522125622.GA21187-RM9K5IK7kjIQXX3q8xo1gnVAuStQJXxyR5q1nwbD4aMs9pC9oP6+/A@public.gmane.org> @ 2012-05-22 16:17 ` Dirk Brandewie 2012-05-22 19:51 ` Sebastian Andrzej Siewior 2012-07-10 12:27 ` Simon Glass 2 siblings, 0 replies; 6+ messages in thread From: Dirk Brandewie @ 2012-05-22 16:17 UTC (permalink / raw) To: Thierry Reding Cc: devicetree-discuss-uLR06cmDAlY/bJ5BZ2RsiQ, x86-DgEjT+Ai2ygdnm+yROfE0A, Rob Herring, Ingo Molnar, H. Peter Anvin, Thomas Gleixner, Sebastian Andrzej Siewior On 05/22/2012 05:56 AM, Thierry Reding wrote: > Hi, > > I was looking at booting an x86-based platform using DT. However I wasn't > able to find a bootloader that supports this. There also doesn't seem to be a > method to append the DTB to the zImage (which I wouldn't want to use anyway). > Does anybody know of a bootloader that supports this? > > I'm currently using syslinux (specifically extlinux) and was looking at > perhaps adding the support myself based on the information given in > Documentation/x86/boot.txt. However I'm not overly familiar with syslinux > code and this could prove more difficult than I anticipate. > > The only x86 platforms that use DT seem to be OLPC and CE4100 and according > to the web the OLPC has a complete OF implementation. Does anyone know which > bootloader the CE4100 uses? The falcon falls CE4100 based board we used to do the DT support uses redboot The code is available at git://gitorious.org/driver-work/redboot.git I never got to the point where the bootloader was loading the FDT from storage. I linked the FDT blobs(s) into the kernel and used a kernel command line option to specify the compat string for the blob the kernel should use. You can see a snapshot of what I was using at: https://gitorious.org/driver-work/linux/commits/base-ce4100.public The command line parameter stuff did not get merged linking the DTB(s) into the kernel did aab9433 of: Add support for linking device tree blobs into vmlinux > > Thierry > > > > _______________________________________________ > devicetree-discuss mailing list > devicetree-discuss-uLR06cmDAlY/bJ5BZ2RsiQ@public.gmane.org > https://lists.ozlabs.org/listinfo/devicetree-discuss ^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: bootloader support for DTB on x86 [not found] ` <20120522125622.GA21187-RM9K5IK7kjIQXX3q8xo1gnVAuStQJXxyR5q1nwbD4aMs9pC9oP6+/A@public.gmane.org> 2012-05-22 16:17 ` Dirk Brandewie @ 2012-05-22 19:51 ` Sebastian Andrzej Siewior [not found] ` <20120522195107.GA17501-hfZtesqFncYOwBW4kG4KsQ@public.gmane.org> 2012-07-10 12:27 ` Simon Glass 2 siblings, 1 reply; 6+ messages in thread From: Sebastian Andrzej Siewior @ 2012-05-22 19:51 UTC (permalink / raw) To: Thierry Reding Cc: devicetree-discuss-uLR06cmDAlY/bJ5BZ2RsiQ, x86-DgEjT+Ai2ygdnm+yROfE0A, Rob Herring, Ingo Molnar, H. Peter Anvin, Thomas Gleixner * Thierry Reding | 2012-05-22 14:56:22 [+0200]: >Hi, Hi, >I was looking at booting an x86-based platform using DT. However I wasn't >able to find a bootloader that supports this. There also doesn't seem to be a >method to append the DTB to the zImage (which I wouldn't want to use anyway). >Does anybody know of a bootloader that supports this? None that I am aware of. >I'm currently using syslinux (specifically extlinux) and was looking at >perhaps adding the support myself based on the information given in >Documentation/x86/boot.txt. However I'm not overly familiar with syslinux >code and this could prove more difficult than I anticipate. It should not be that difficult. - Look how the initrd is loaded. Use the same technique to load the dtb blob. - Allocate another memory block for setup_data. You need one entry of type SETUP_DTB pointing to the dtb. If I remember correctly, the setup_data is thrown away by kernel and the dtb blob itself is relocated to some place safe. - You may need to set hardware_subarch to some similar to X86_SUBARCH_CE4100. I mean you *may* need your own subarch value but you can most likely reuse most of the functions that ce4100 is using. The PCI bus and UART is broken is a special way, everything else is generic. Since we don't have ACPI/SFI,⊠we need something to find HPET, IO-APIC, irq routing,⊠>The only x86 platforms that use DT seem to be OLPC and CE4100 and according >to the web the OLPC has a complete OF implementation. Does anyone know which >bootloader the CE4100 uses? It jumps in the end to redboot which then loads the kernel. In the early days I had this patch make to sure the setup_data thingy works. So with this it should be easy to add the support to redboot/grub/isolinux/⊠From: Sebastian Andrzej Siewior <bigeasy-hfZtesqFncYOwBW4kG4KsQ@public.gmane.org> Subject: [PATCH ] x86/dtb: add bzImage support this adds two new targets: - arch/x86/boot/$dt.dtb a convience target which just calls dtc on the $dtb which lives in arch/x86/boot/dts/$dt.dts - bzImage.$dt embeds the device tree in the bzImage loader. The dtb will be passed to the kernel via setup_data if there is no dtb included. The memory location of the dtb will be before the initrd if one is available. If not it will placed at "memory size" or 128MiB depends which one is less. The upper limit is used a guess to ensure that it remains in lowmem. On a system with 1GiB the lowmem is around ~880MiB. The exact value depends on a few CONFIG_ swithes and is determined at run time. It can be additionaly increased or decreased via kernel parameters like memmap or vmalloc. So instead of parsing every piece of information we assume that nobody runs a kernel with only the first 100MiB mapped. Signed-off-by: Sebastian Andrzej Siewior <bigeasy-hfZtesqFncYOwBW4kG4KsQ@public.gmane.org> --- arch/x86/Makefile | 6 +++ arch/x86/boot/Makefile | 29 ++++++++++++++-- arch/x86/boot/compressed/Makefile | 25 ++++++++++++-- arch/x86/boot/compressed/misc.c | 60 +++++++++++++++++++++++++++++++- arch/x86/boot/compressed/vmlinux.lds.S | 7 ++++ 5 files changed, 120 insertions(+), 7 deletions(-) diff --git a/arch/x86/Makefile b/arch/x86/Makefile index e8c8881..50dffd8 100644 --- a/arch/x86/Makefile +++ b/arch/x86/Makefile @@ -161,6 +161,9 @@ endif $(Q)mkdir -p $(objtree)/arch/$(UTS_MACHINE)/boot $(Q)ln -fsn ../../x86/boot/bzImage $(objtree)/arch/$(UTS_MACHINE)/boot/$@ +bzImage.%: vmlinux + $(Q)$(MAKE) $(build)=$(boot) $(boot)/$@ + $(BOOT_TARGETS): vmlinux $(Q)$(MAKE) $(build)=$(boot) $@ @@ -177,6 +180,9 @@ archclean: $(Q)rm -rf $(objtree)/arch/x86_64 $(Q)$(MAKE) $(clean)=$(boot) +%.dtb: + $(Q)$(MAKE) $(build)=$(boot) $@ + define archhelp echo '* bzImage - Compressed kernel image (arch/x86/boot/bzImage)' echo ' install - Install kernel using' diff --git a/arch/x86/boot/Makefile b/arch/x86/boot/Makefile index f7cb086..a7651f2 100644 --- a/arch/x86/boot/Makefile +++ b/arch/x86/boot/Makefile @@ -72,20 +72,30 @@ KBUILD_CFLAGS += $(call cc-option, -m32) KBUILD_AFLAGS := $(KBUILD_CFLAGS) -D__ASSEMBLY__ GCOV_PROFILE := n -$(obj)/bzImage: asflags-y := $(SVGA_MODE) +$(obj)/bzImage $(obj)/bzImage.%: asflags-y := $(SVGA_MODE) quiet_cmd_image = BUILD $@ -cmd_image = $(obj)/tools/build $(obj)/setup.bin $(obj)/vmlinux.bin \ +cmd_image = $(obj)/tools/build $(obj)/setup.bin $2 \ $(ROOT_DEV) > $@ $(obj)/bzImage: $(obj)/setup.bin $(obj)/vmlinux.bin $(obj)/tools/build FORCE - $(call if_changed,image) + $(call if_changed,image, $(obj)/vmlinux.bin) + @echo 'Kernel: $@ is ready' ' (#'`cat .version`')' + +$(obj)/bzImage.%: $(obj)/setup.bin $(obj)/vmlinux.bin.% $(obj)/tools/build FORCE + $(call if_changed,image,$(obj)/vmlinux.bin.$*) @echo 'Kernel: $@ is ready' ' (#'`cat .version`')' OBJCOPYFLAGS_vmlinux.bin := -O binary -R .note -R .comment -S $(obj)/vmlinux.bin: $(obj)/compressed/vmlinux FORCE $(call if_changed,objcopy) +quiet_cmd_objcopybin = OBJCOPY $@ + cmd_objcopybin = $(OBJCOPY) $(OBJCOPYFLAGS) -O binary -R .note -R .comment -S $< $@ + +$(obj)/vmlinux.bin.%: $(obj)/compressed/vmlinux.dtb.% FORCE + $(call if_changed,objcopybin) + SETUP_OBJS = $(addprefix $(obj)/,$(setup-y)) sed-voffset := -e 's/^\([0-9a-fA-F]*\) . \(_text\|_end\)$$/\#define VO_\2 0x\1/p' @@ -121,6 +131,19 @@ $(obj)/setup.bin: $(obj)/setup.elf FORCE $(obj)/compressed/vmlinux: FORCE $(Q)$(MAKE) $(build)=$(obj)/compressed $@ +$(obj)/compressed/vmlinux.dtb.%: FORCE + $(Q)$(MAKE) $(build)=$(obj)/compressed $@ + +dtstree := $(srctree)/$(src)/dts +DTC = $(objtree)/scripts/dtc/dtc + +quiet_cmd_dtc = DTC $@ + cmd_dtc = $(DTC) -O dtb -o $(obj)/$*.dtb -b 0 -p 1024 $(dtstree)/$*.dts + +# Rule to build device tree blobs +$(obj)/%.dtb: $(dtstree)/%.dts FORCE + $(call if_changed,dtc) + # Set this if you want to pass append arguments to the # bzdisk/fdimage/isoimage kernel FDARGS = diff --git a/arch/x86/boot/compressed/Makefile b/arch/x86/boot/compressed/Makefile index 0c22955..4137939 100644 --- a/arch/x86/boot/compressed/Makefile +++ b/arch/x86/boot/compressed/Makefile @@ -18,15 +18,34 @@ KBUILD_CFLAGS += $(call cc-option,-fno-stack-protector) KBUILD_AFLAGS := $(KBUILD_CFLAGS) -D__ASSEMBLY__ GCOV_PROFILE := n -LDFLAGS := -m elf_$(UTS_MACHINE) -LDFLAGS_vmlinux := -T +LDFLAGS := -m elf_$(UTS_MACHINE) -T hostprogs-y := mkpiggy -$(obj)/vmlinux: $(obj)/vmlinux.lds $(obj)/head_$(BITS).o $(obj)/misc.o $(obj)/string.o $(obj)/cmdline.o $(obj)/early_serial_console.o $(obj)/piggy.o FORCE +VMLINUX_DEP := $(obj)/vmlinux.lds $(obj)/head_$(BITS).o $(obj)/misc.o $(obj)/string.o $(obj)/cmdline.o $(obj)/early_serial_console.o $(obj)/piggy.o + +$(obj)/vmlinux: $(VMLINUX_DEP) FORCE + $(call if_changed,ld) + @: + +dtstree := $(srctree)/arch/x86/boot/dts +DTC = $(objtree)/scripts/dtc/dtc + +quiet_cmd_dtc = DTC $@ + cmd_dtc = $(DTC) -O dtb -o $(obj)/$*.dtb -b 0 -p 1024 $(dtstree)/$*.dts + +$(obj)/%.dtb: $(dtstree)/%.dts + $(call if_changed,dtc) + +$(obj)/%.dtb.S: $(obj)/%.dtb + @echo '.section .data..dtb,"a"' > $@ + @echo '.incbin "$<" ' >> $@ + +$(obj)/vmlinux.dtb.%: $(VMLINUX_DEP) $(obj)/%.dtb.o FORCE $(call if_changed,ld) @: +targets += vmlinux.dtb.% OBJCOPYFLAGS_vmlinux.bin := -R .comment -S $(obj)/vmlinux.bin: vmlinux FORCE $(call if_changed,objcopy) diff --git a/arch/x86/boot/compressed/misc.c b/arch/x86/boot/compressed/misc.c index 8f7bef8..ebd6901 100644 --- a/arch/x86/boot/compressed/misc.c +++ b/arch/x86/boot/compressed/misc.c @@ -101,7 +101,8 @@ #undef memcpy #define memzero(s, n) memset((s), 0, (n)) - +extern char _dtb_end[]; +extern char _dtb_start[]; static void error(char *m); /* @@ -302,6 +303,40 @@ static void parse_elf(void *output) } } +static u64 attach_initdata(u64 old_sd, void *dest, void *data, unsigned int len, + unsigned int type) +{ + struct setup_data *sd = dest; + + sd->next = old_sd; + sd->type = type; + sd->len = len; + memcpy(&sd->data[0], data, len); + return (u64) (u32) sd; +} + +static u64 attach_dtb(u64 old_sd, void *dest, void *data, unsigned int len) +{ + return attach_initdata(old_sd, dest, data, len, SETUP_DTB); +} + +static int dtb_passed(u64 setup_data) +{ + int ret = 0; + + while (setup_data) { + struct setup_data *sdata; + + sdata = (void *)(u32)setup_data; + if (sdata->type == SETUP_DTB) { + ret = 1; + break; + } + setup_data = sdata->next; + } + return ret; +} + asmlinkage void decompress_kernel(void *rmode, memptr heap, unsigned char *input_data, unsigned long input_len, @@ -350,6 +385,29 @@ asmlinkage void decompress_kernel(void *rmode, memptr heap, putstr("\nDecompressing Linux... "); decompress(input_data, input_len, NULL, NULL, output, NULL, error); parse_elf(output); + if (_dtb_end > _dtb_start && !dtb_passed(real_mode->hdr.setup_data)) { + u32 k_dtb; + + if (real_mode->hdr.ramdisk_image) + k_dtb = real_mode->hdr.ramdisk_image; + else { + k_dtb = real_mode->alt_mem_k; + k_dtb++; + k_dtb *= 1024; + } + if (k_dtb > 128 * 1024 * 1024) + k_dtb = 128 * 1024 * 1024; + k_dtb -= (_dtb_end - _dtb_start); + if (!IS_ALIGNED(k_dtb, 4096)) { + /* align down */ + k_dtb = ALIGN(k_dtb, 4096); + k_dtb -= 4096; + } + real_mode->hdr.setup_data = + attach_dtb(real_mode->hdr.setup_data, (void *)k_dtb, + _dtb_start, _dtb_end - _dtb_start); + } + if (!quiet) putstr("done.\nBooting the kernel.\n"); return; diff --git a/arch/x86/boot/compressed/vmlinux.lds.S b/arch/x86/boot/compressed/vmlinux.lds.S index 34d047c..a4924f9 100644 --- a/arch/x86/boot/compressed/vmlinux.lds.S +++ b/arch/x86/boot/compressed/vmlinux.lds.S @@ -41,6 +41,13 @@ SECTIONS *(.rodata.*) _erodata = . ; } + + _dtb_start = .; + .data..dtb : { + *(.data..dtb) + } + _dtb_end = . ; + .got : { _got = .; KEEP(*(.got.plt)) -- 1.7.2.3 >Thierry Sebastian ^ permalink raw reply related [flat|nested] 6+ messages in thread
[parent not found: <20120522195107.GA17501-hfZtesqFncYOwBW4kG4KsQ@public.gmane.org>]
* Re: bootloader support for DTB on x86 [not found] ` <20120522195107.GA17501-hfZtesqFncYOwBW4kG4KsQ@public.gmane.org> @ 2012-05-22 21:53 ` H. Peter Anvin 0 siblings, 0 replies; 6+ messages in thread From: H. Peter Anvin @ 2012-05-22 21:53 UTC (permalink / raw) To: Sebastian Andrzej Siewior, Thomas Renninger Cc: x86-DgEjT+Ai2ygdnm+yROfE0A, devicetree-discuss-uLR06cmDAlY/bJ5BZ2RsiQ, Rob Herring, Ingo Molnar, Thomas Gleixner On 05/22/2012 12:51 PM, Sebastian Andrzej Siewior wrote: > > It should not be that difficult. > - Look how the initrd is loaded. Use the same technique to load the dtb > blob. > > - Allocate another memory block for setup_data. You need one entry of > type SETUP_DTB pointing to the dtb. If I remember correctly, the > setup_data is thrown away by kernel and the dtb blob itself is > relocated to some place safe. > > - You may need to set hardware_subarch to some similar to > X86_SUBARCH_CE4100. I mean you *may* need your own subarch value but > you can most likely reuse most of the functions that ce4100 is using. > The PCI bus and UART is broken is a special way, everything else is > generic. Since we don't have ACPI/SFI,⊠we need something to find > HPET, IO-APIC, irq routing,⊠> Careful here! We have just had a long discussion how we want to handle large data blobs which need bootloader support in x86 space. The consensus opinion ended up that they should be prepended to the initramfs, uncompressed, and using a cpio header with a file name beginning with "kernel/". Thus, it is logically part of initramfs but can be accessed earlier in the boot. This has a number of advantages for the bootloader, including a modicum of backward compatibility with legacy bootloaders. Intended users of this mechanism include microcode updates and ACPI table overrides. I really don't want to see more ad hockery of the CE4100 variety. The code for this is still not integrated; I wrote up some cpio parsing code for this: http://www.zytor.com/~hpa/kernel/findcpio.c ... but it hasn't been included in any kernel trees yet. I know Thomas Renninger said he was going to work on it, but I haven't seen anything. See the LKML thread "[PATCH] ACPI: Implement overriding of arbitrary ACPI tables via initrd": http://lkml.kernel.org/r/1332512984-79664-1-git-send-email-trenn@suse.de -hpa -- H. Peter Anvin, Intel Open Source Technology Center I work for Intel. I don't speak on their behalf. _______________________________________________ devicetree-discuss mailing list devicetree-discuss@lists.ozlabs.org https://lists.ozlabs.org/listinfo/devicetree-discuss ^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: bootloader support for DTB on x86 [not found] ` <20120522125622.GA21187-RM9K5IK7kjIQXX3q8xo1gnVAuStQJXxyR5q1nwbD4aMs9pC9oP6+/A@public.gmane.org> 2012-05-22 16:17 ` Dirk Brandewie 2012-05-22 19:51 ` Sebastian Andrzej Siewior @ 2012-07-10 12:27 ` Simon Glass [not found] ` <CAPnjgZ2OwarbF+=SZkXYgszhES94Y6=-9wq+BdNHuo+PrZsYWA-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org> 2 siblings, 1 reply; 6+ messages in thread From: Simon Glass @ 2012-07-10 12:27 UTC (permalink / raw) To: Thierry Reding Cc: devicetree-discuss-uLR06cmDAlY/bJ5BZ2RsiQ, x86-DgEjT+Ai2ygdnm+yROfE0A, Rob Herring, Ingo Molnar, H. Peter Anvin, Thomas Gleixner, Sebastian Andrzej Siewior [-- Attachment #1.1: Type: text/plain, Size: 1382 bytes --] Hi, On Tue, May 22, 2012 at 2:56 PM, Thierry Reding < thierry.reding-RM9K5IK7kjKj5M59NBduVrNAH6kLmebB@public.gmane.org> wrote: > Hi, > > I was looking at booting an x86-based platform using DT. However I wasn't > able to find a bootloader that supports this. There also doesn't seem to > be a > method to append the DTB to the zImage (which I wouldn't want to use > anyway). > Does anybody know of a bootloader that supports this? > Maybe U-Boot with a FIT image? Also, you should support having multiple device trees in the image and the boot loader selecting the correct one. I don't think we should rely on there being an initrd - what do we do if there isn't one? > > I'm currently using syslinux (specifically extlinux) and was looking at > perhaps adding the support myself based on the information given in > Documentation/x86/boot.txt. However I'm not overly familiar with syslinux > code and this could prove more difficult than I anticipate. > > The only x86 platforms that use DT seem to be OLPC and CE4100 and according > to the web the OLPC has a complete OF implementation. Does anyone know > which > bootloader the CE4100 uses? > > Thierry > > _______________________________________________ > devicetree-discuss mailing list > devicetree-discuss-uLR06cmDAlY/bJ5BZ2RsiQ@public.gmane.org > https://lists.ozlabs.org/listinfo/devicetree-discuss > > Regards, Simon [-- Attachment #1.2: Type: text/html, Size: 2140 bytes --] [-- Attachment #2: Type: text/plain, Size: 192 bytes --] _______________________________________________ devicetree-discuss mailing list devicetree-discuss-uLR06cmDAlY/bJ5BZ2RsiQ@public.gmane.org https://lists.ozlabs.org/listinfo/devicetree-discuss ^ permalink raw reply [flat|nested] 6+ messages in thread
[parent not found: <CAPnjgZ2OwarbF+=SZkXYgszhES94Y6=-9wq+BdNHuo+PrZsYWA-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>]
* Re: bootloader support for DTB on x86 [not found] ` <CAPnjgZ2OwarbF+=SZkXYgszhES94Y6=-9wq+BdNHuo+PrZsYWA-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org> @ 2012-07-10 12:35 ` Thierry Reding 0 siblings, 0 replies; 6+ messages in thread From: Thierry Reding @ 2012-07-10 12:35 UTC (permalink / raw) To: Simon Glass Cc: devicetree-discuss-uLR06cmDAlY/bJ5BZ2RsiQ, x86-DgEjT+Ai2ygdnm+yROfE0A, Rob Herring, Ingo Molnar, H. Peter Anvin, Thomas Gleixner, Sebastian Andrzej Siewior [-- Attachment #1.1: Type: text/plain, Size: 993 bytes --] On Tue, Jul 10, 2012 at 02:27:26PM +0200, Simon Glass wrote: > Hi, > > On Tue, May 22, 2012 at 2:56 PM, Thierry Reding < > thierry.reding-RM9K5IK7kjKj5M59NBduVrNAH6kLmebB@public.gmane.org> wrote: > > > Hi, > > > > I was looking at booting an x86-based platform using DT. However I wasn't > > able to find a bootloader that supports this. There also doesn't seem to > > be a > > method to append the DTB to the zImage (which I wouldn't want to use > > anyway). > > Does anybody know of a bootloader that supports this? > > > > Maybe U-Boot with a FIT image? Also, you should support having multiple > device trees in the image and the boot loader selecting the correct one. > > I don't think we should rely on there being an initrd - what do we do if > there isn't one? I'm not sure if I can get U-Boot to run on this platform. It's Atom- based and I don't think anybody's gotten that to work yet. syslinux 4.06 should support loading of DTBs on x86. Thierry [-- Attachment #1.2: Type: application/pgp-signature, Size: 836 bytes --] [-- Attachment #2: Type: text/plain, Size: 192 bytes --] _______________________________________________ devicetree-discuss mailing list devicetree-discuss-uLR06cmDAlY/bJ5BZ2RsiQ@public.gmane.org https://lists.ozlabs.org/listinfo/devicetree-discuss ^ permalink raw reply [flat|nested] 6+ messages in thread
end of thread, other threads:[~2012-07-10 12:35 UTC | newest] Thread overview: 6+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2012-05-22 12:56 bootloader support for DTB on x86 Thierry Reding [not found] ` <20120522125622.GA21187-RM9K5IK7kjIQXX3q8xo1gnVAuStQJXxyR5q1nwbD4aMs9pC9oP6+/A@public.gmane.org> 2012-05-22 16:17 ` Dirk Brandewie 2012-05-22 19:51 ` Sebastian Andrzej Siewior [not found] ` <20120522195107.GA17501-hfZtesqFncYOwBW4kG4KsQ@public.gmane.org> 2012-05-22 21:53 ` H. Peter Anvin 2012-07-10 12:27 ` Simon Glass [not found] ` <CAPnjgZ2OwarbF+=SZkXYgszhES94Y6=-9wq+BdNHuo+PrZsYWA-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org> 2012-07-10 12:35 ` Thierry Reding
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).