mirror of
				https://xff.cz/git/u-boot/
				synced 2025-10-22 10:31:56 +02:00 
			
		
		
		
	The ARMv8-R64 architecture introduces optional VMSA (paging based MMU) support in the EL1/0 translation regime, which makes that part mostly compatible to ARMv8-A. Add a new board variant to describe the "BASE-R64" FVP model, which inherits a lot from the existing v8-A FVP support. One major difference is that the memory map in "inverted": DRAM starts at 0x0, MMIO is at 2GB [1]. * Create new TARGET_VEXPRESS64_BASER_FVP target, sharing most of the exising configuration. * Implement inverted memory map in vexpress_aemv8.h * Create vexpress_aemv8r defconfig * Provide an MMU memory map for the BASER_FVP * Update vexpress64 documentation At the moment the boot-wrapper is the only supported secure firmware. As there is no official DT for the board yet, we rely on it being supplied by the boot-wrapper into U-Boot, so use OF_HAS_PRIOR_STAGE, and go with a dummy DT for now. [1] https://developer.arm.com/documentation/100964/1114/Base-Platform/Base---memory/BaseR-Platform-memory-map Signed-off-by: Peter Hoyes <Peter.Hoyes@arm.com> [Andre: rebase and add Linux kernel header] Signed-off-by: Andre Przywara <andre.przywara@arm.com> [trini: Add MAINTAINERS entry for Peter]
		
			
				
	
	
		
			61 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
			
		
		
	
	
			61 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
| .. SPDX-License-Identifier: GPL-2.0+
 | |
| 
 | |
| ARM64
 | |
| =====
 | |
| 
 | |
| Summary
 | |
| -------
 | |
| The initial arm64 U-Boot port was developed before hardware was available,
 | |
| so the first supported platforms were the Foundation and Fast Model for ARMv8.
 | |
| These days U-Boot runs on a variety of 64-bit capable ARM hardware, from
 | |
| embedded development boards to servers.
 | |
| 
 | |
| Notes
 | |
| -----
 | |
| 
 | |
| 1. U-Boot can run at any exception level it is entered in, it is
 | |
|    recommened to enter it in EL3 if U-Boot takes some responsibilities of a
 | |
|    classical firmware (like initial hardware setup, CPU errata workarounds
 | |
|    or SMP bringup). U-Boot can be entered in EL2 when its main purpose is
 | |
|    that of a boot loader. It can drop to lower exception levels before
 | |
|    entering the OS. For ARMv8-R it is recommened to enter at S-EL1, as for this
 | |
|    architecture there is no S-EL3.
 | |
| 
 | |
| 2. U-Boot for arm64 is compiled with AArch64-gcc. AArch64-gcc
 | |
|    use rela relocation format, a tool(tools/relocate-rela) by Scott Wood
 | |
|    is used to encode the initial addend of rela to u-boot.bin. After running,
 | |
|    the U-Boot will be relocated to destination again.
 | |
| 
 | |
| 3. Earlier Linux kernel versions required the FDT to be placed at a
 | |
|    2 MB boundary and within the same 512 MB section as the kernel image,
 | |
|    resulting in fdt_high to be defined specially.
 | |
|    Since kernel version 4.2 Linux is more relaxed about the DT location, so it
 | |
|    can be placed anywhere in memory.
 | |
|    Please reference linux/Documentation/arm64/booting.txt for detail.
 | |
| 
 | |
| 4. Spin-table is used to wake up secondary processors. One location
 | |
|    (or per processor location) is defined to hold the kernel entry point
 | |
|    for secondary processors. It must be ensured that the location is
 | |
|    accessible and zero immediately after secondary processor
 | |
|    enter slave_cpu branch execution in start.S. The location address
 | |
|    is encoded in cpu node of DTS. Linux kernel store the entry point
 | |
|    of secondary processors to it and send event to wakeup secondary
 | |
|    processors.
 | |
|    Please reference linux/Documentation/arm64/booting.txt for detail.
 | |
| 
 | |
| 5. Generic board is supported.
 | |
| 
 | |
| 6. CONFIG_ARM64 instead of CONFIG_ARMV8 is used to distinguish aarch64 and
 | |
|    aarch32 specific codes.
 | |
| 
 | |
| 
 | |
| Contributors
 | |
| ------------
 | |
|    * Tom Rini            <trini@ti.com>
 | |
|    * Scott Wood          <scottwood@freescale.com>
 | |
|    * York Sun            <yorksun@freescale.com>
 | |
|    * Simon Glass         <sjg@chromium.org>
 | |
|    * Sharma Bhupesh      <bhupesh.sharma@freescale.com>
 | |
|    * Rob Herring         <robherring2@gmail.com>
 | |
|    * Sergey Temerkhanov  <s.temerkhanov@gmail.com>
 |