Bin Meng | a187559 | 2016-02-05 19:30:11 -0800 | [diff] [blame] | 1 | U-Boot for arm64 |
David Feng | 0ae7653 | 2013-12-14 11:47:35 +0800 | [diff] [blame] | 2 | |
| 3 | Summary |
| 4 | ======= |
Andre Przywara | 8add679 | 2016-11-03 01:01:50 +0000 | [diff] [blame] | 5 | The initial arm64 U-Boot port was developed before hardware was available, |
| 6 | so the first supported platforms were the Foundation and Fast Model for ARMv8. |
| 7 | These days U-Boot runs on a variety of 64-bit capable ARM hardware, from |
| 8 | embedded development boards to servers. |
David Feng | 0ae7653 | 2013-12-14 11:47:35 +0800 | [diff] [blame] | 9 | |
| 10 | Notes |
| 11 | ===== |
| 12 | |
Andre Przywara | 8add679 | 2016-11-03 01:01:50 +0000 | [diff] [blame] | 13 | 1. U-Boot can run at any exception level it is entered in, it is |
| 14 | recommened to enter it in EL3 if U-Boot takes some responsibilities of a |
| 15 | classical firmware (like initial hardware setup, CPU errata workarounds |
| 16 | or SMP bringup). U-Boot can be entered in EL2 when its main purpose is |
| 17 | that of a boot loader. It can drop to lower exception levels before |
| 18 | entering the OS. |
David Feng | 0ae7653 | 2013-12-14 11:47:35 +0800 | [diff] [blame] | 19 | |
Bin Meng | a187559 | 2016-02-05 19:30:11 -0800 | [diff] [blame] | 20 | 2. U-Boot for arm64 is compiled with AArch64-gcc. AArch64-gcc |
David Feng | 0ae7653 | 2013-12-14 11:47:35 +0800 | [diff] [blame] | 21 | use rela relocation format, a tool(tools/relocate-rela) by Scott Wood |
| 22 | is used to encode the initial addend of rela to u-boot.bin. After running, |
Bin Meng | a187559 | 2016-02-05 19:30:11 -0800 | [diff] [blame] | 23 | the U-Boot will be relocated to destination again. |
David Feng | 0ae7653 | 2013-12-14 11:47:35 +0800 | [diff] [blame] | 24 | |
Andre Przywara | 8add679 | 2016-11-03 01:01:50 +0000 | [diff] [blame] | 25 | 3. Earlier Linux kernel versions required the FDT to be placed at a |
| 26 | 2 MB boundary and within the same 512 MB section as the kernel image, |
| 27 | resulting in fdt_high to be defined specially. |
| 28 | Since kernel version 4.2 Linux is more relaxed about the DT location, so it |
| 29 | can be placed anywhere in memory. |
David Feng | 0ae7653 | 2013-12-14 11:47:35 +0800 | [diff] [blame] | 30 | Please reference linux/Documentation/arm64/booting.txt for detail. |
| 31 | |
| 32 | 4. Spin-table is used to wake up secondary processors. One location |
| 33 | (or per processor location) is defined to hold the kernel entry point |
| 34 | for secondary processors. It must be ensured that the location is |
| 35 | accessible and zero immediately after secondary processor |
| 36 | enter slave_cpu branch execution in start.S. The location address |
| 37 | is encoded in cpu node of DTS. Linux kernel store the entry point |
| 38 | of secondary processors to it and send event to wakeup secondary |
| 39 | processors. |
| 40 | Please reference linux/Documentation/arm64/booting.txt for detail. |
| 41 | |
| 42 | 5. Generic board is supported. |
| 43 | |
| 44 | 6. CONFIG_ARM64 instead of CONFIG_ARMV8 is used to distinguish aarch64 and |
| 45 | aarch32 specific codes. |
| 46 | |
Sergey Temerkhanov | 94f7ff3 | 2015-10-14 09:55:45 -0700 | [diff] [blame] | 47 | |
Andre Przywara | 8add679 | 2016-11-03 01:01:50 +0000 | [diff] [blame] | 48 | Contributors |
| 49 | ============ |
Sergey Temerkhanov | 94f7ff3 | 2015-10-14 09:55:45 -0700 | [diff] [blame] | 50 | Tom Rini <trini@ti.com> |
| 51 | Scott Wood <scottwood@freescale.com> |
| 52 | York Sun <yorksun@freescale.com> |
| 53 | Simon Glass <sjg@chromium.org> |
| 54 | Sharma Bhupesh <bhupesh.sharma@freescale.com> |
| 55 | Rob Herring <robherring2@gmail.com> |
| 56 | Sergey Temerkhanov <s.temerkhanov@gmail.com> |