82 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
			
		
		
	
	
			82 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
| .. SPDX-License-Identifier: GPL-2.0+
 | |
| .. Copyright (C) 2023, Yu Chien Peter Lin <peterlin@andestech.com>
 | |
| 
 | |
| RISC-V
 | |
| ======
 | |
| 
 | |
| Overview
 | |
| --------
 | |
| 
 | |
| This document outlines the U-Boot boot process for the RISC-V architecture.
 | |
| RISC-V is an open-source instruction set architecture (ISA) based on the
 | |
| principles of reduced instruction set computing (RISC). It has been designed
 | |
| to be flexible and customizable, allowing it to be adapted to different use
 | |
| cases, from embedded systems to high performance servers.
 | |
| 
 | |
| Typical Boot Process
 | |
| --------------------
 | |
| 
 | |
| U-Boot can run in either M-mode or S-mode, depending on whether it runs before
 | |
| the initialization of the firmware providing SBI (Supervisor Binary Interface).
 | |
| The firmware is necessary in the RISC-V boot process as it serves as a SEE
 | |
| (Supervisor Execution Environment) to handle exceptions for the S-mode U-Boot
 | |
| or Operating System.
 | |
| 
 | |
| In between the boot phases, the hartid is passed through the a0 register, and
 | |
| the start address of the devicetree is passed through the a1 register.
 | |
| 
 | |
| As a reference, OpenSBI is an SBI implementation that can be used with U-Boot
 | |
| in different modes, see the
 | |
| `OpenSBI firmware document <https://github.com/riscv-software-src/opensbi/tree/master/docs/firmware>`_
 | |
| for more details.
 | |
| 
 | |
| M-mode U-Boot
 | |
| ^^^^^^^^^^^^^
 | |
| 
 | |
| When running in M-mode U-Boot, it will load the payload image (e.g.
 | |
| `fw_payload <https://github.com/riscv-software-src/opensbi/blob/master/docs/firmware/fw_payload.md>`_)
 | |
| which contains the firmware and the S-mode Operating System; in this case, you
 | |
| can use mkimage to package the payload image into an uImage format, and boot it
 | |
| using the bootm command.
 | |
| 
 | |
| The following diagram illustrates the boot process::
 | |
| 
 | |
| 	<-----------( M-mode )----------><--( S-mode )-->
 | |
| 	+----------+   +--------------+    +------------+
 | |
| 	|  U-Boot  |-->| SBI firmware |--->|     OS     |
 | |
| 	+----------+   +--------------+    +------------+
 | |
| 
 | |
| To examine the boot process with the QEMU virt machine, you can follow the
 | |
| steps in the "Building U-Boot" section of the following document:
 | |
| :doc:`../board/emulation/qemu-riscv`.
 | |
| 
 | |
| S-mode U-Boot
 | |
| ^^^^^^^^^^^^^
 | |
| 
 | |
| RISC-V production boot images may include a U-Boot SPL for platform-specific
 | |
| initialization. The U-Boot SPL then loads a FIT image (u-boot.itb), which
 | |
| contains a firmware (e.g.
 | |
| `fw_dynamic <https://github.com/riscv-software-src/opensbi/blob/master/docs/firmware/fw_dynamic.md>`_)
 | |
| providing the SBI, as well as a regular U-Boot (or U-Boot proper) running in
 | |
| S-mode. Finally, the S-mode Operating
 | |
| System is loaded.
 | |
| 
 | |
| The following diagram illustrates the boot process::
 | |
| 
 | |
| 	<-------------( M-mode )----------><----------( S-mode )------->
 | |
| 	+------------+   +--------------+    +----------+   +----------+
 | |
| 	| U-Boot SPL |-->| SBI firmware |--->|  U-Boot  |-->|    OS    |
 | |
| 	+------------+   +--------------+    +----------+   +----------+
 | |
| 
 | |
| To examine the boot process with the QEMU virt machine, you can follow the
 | |
| steps in the "Running U-Boot SPL" section of the following document:
 | |
| :doc:`../board/emulation/qemu-riscv`.
 | |
| 
 | |
| Toolchain
 | |
| ---------
 | |
| 
 | |
| You can build the
 | |
| `RISC-V GNU toolchain <https://github.com/riscv-collab/riscv-gnu-toolchain>`_
 | |
| from scratch, or download a pre-built toolchain from the
 | |
| `releases page <https://github.com/riscv-collab/riscv-gnu-toolchain/releases>`_.
 |