mirror of
				https://source.denx.de/u-boot/u-boot.git
				synced 2025-10-25 14:31:21 +02:00 
			
		
		
		
	Raspberry firmware used to pass a FDT blob at a fixed address (0x100),
but this is not true anymore. The address now depends on both the
memory size and the blob size [1].
If one wants to passthrough this FDT blob to the kernel, the most
reliable way is to save its address from the r2/x0 register in the
U-Boot entry point and expose it in a environment variable for
further processing.
This patch just does this:
- save the provided address in the global variable fw_dtb_pointer
- expose it in ${fdt_addr} if it points to a a valid FDT blob
There are many different ways to use it. One can, for example, use
the following script which will extract from the tree the command
line built by the firmware, then hand over the blob to a previously
loaded kernel:
fdt addr ${fdt_addr}
fdt get value bootargs /chosen bootargs
bootz ${kernel_addr_r} - ${fdt_addr}
Alternatively, users relying on sysboot/pxe can simply omit any FDT
statement in their extlinux.conf file, U-Boot will automagically pick
${fdt_addr} and pass it to the kernel.
[1] https://www.raspberrypi.org/forums//viewtopic.php?f=107&t=134018
Signed-off-by: Cédric Schieli <cschieli@gmail.com>
Acked-by: Stephen Warren <swarren@nvidia.com>
		
	
			
		
			
				
	
	
		
			37 lines
		
	
	
		
			630 B
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
			
		
		
	
	
			37 lines
		
	
	
		
			630 B
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
| /*
 | |
|  * (C) Copyright 2016
 | |
|  * Cédric Schieli <cschieli@gmail.com>
 | |
|  *
 | |
|  * SPDX-License-Identifier:	GPL-2.0+
 | |
|  */
 | |
| 
 | |
| #include <config.h>
 | |
| 
 | |
| .align 8
 | |
| .global fw_dtb_pointer
 | |
| fw_dtb_pointer:
 | |
| #ifdef CONFIG_ARM64
 | |
| 	.dword 0x0
 | |
| #else
 | |
| 	.word 0x0
 | |
| #endif
 | |
| 
 | |
| /*
 | |
|  * Routine: save_boot_params (called after reset from start.S)
 | |
|  * Description: save ATAG/FDT address provided by the firmware at boot time
 | |
|  */
 | |
| 
 | |
| .global save_boot_params
 | |
| save_boot_params:
 | |
| 
 | |
| 	/* The firmware provided ATAG/FDT address can be found in r2/x0 */
 | |
| #ifdef CONFIG_ARM64
 | |
| 	adr	x8, fw_dtb_pointer
 | |
| 	str	x0, [x8]
 | |
| #else
 | |
| 	str	r2, fw_dtb_pointer
 | |
| #endif
 | |
| 
 | |
| 	/* Returns */
 | |
| 	b	save_boot_params_ret
 |