blob: ce4539a46f13a702a011f7a2be63e9ccd2c5d23d [file] [log] [blame]
Heinrich Schuchardtb59ac9b2024-04-02 10:49:12 +02001.. SPDX-License-Identifier: GPL-2.0+
2
3Milk-V Mars
4===========
5
6U-Boot for the Milk-V Mars uses the same U-Boot binaries as the VisionFive 2
7board. In U-Boot SPL the actual board is detected and the device-tree patched
8accordingly.
9
10Building
Heinrich Schuchardt0c443d62025-04-24 14:13:13 +020011--------
Heinrich Schuchardtb59ac9b2024-04-02 10:49:12 +020012
131. Add the RISC-V toolchain to your PATH.
142. Setup ARCH & cross compilation environment variable:
15
16.. code-block:: none
17
18 export CROSS_COMPILE=<riscv64 toolchain prefix>
19
20The M-mode software OpenSBI provides the supervisor binary interface (SBI) and
21is responsible for the switch to S-Mode. It is a prerequisite to build U-Boot.
22Support for the JH7110 was introduced in OpenSBI 1.2. It is recommended to use
23a current release.
24
25.. code-block:: console
26
27 git clone https://github.com/riscv/opensbi.git
28 cd opensbi
29 make PLATFORM=generic FW_TEXT_START=0x40000000 FW_OPTIONS=0
30
31Now build the U-Boot SPL and U-Boot proper.
32
33.. code-block:: console
34
35 cd <U-Boot-dir>
36 make starfive_visionfive2_defconfig
37 make OPENSBI=$(opensbi_dir)/build/platform/generic/firmware/fw_dynamic.bin
38
39This will generate the U-Boot SPL image (spl/u-boot-spl.bin.normal.out) as well
40as the FIT image (u-boot.itb) with OpenSBI and U-Boot.
41
42Device-tree selection
Heinrich Schuchardt0c443d62025-04-24 14:13:13 +020043---------------------
Heinrich Schuchardtb59ac9b2024-04-02 10:49:12 +020044
45Depending on the board version U-Boot set variable $fdtfile to either
46starfive/jh7110-starfive-visionfive-2-v1.2a.dtb or
47starfive/jh7110-starfive-visionfive-2-v1.3b.dtb.
48
49To overrule this selection the variable can be set manually and saved in the
50environment
51
52::
53
54 setenv fdtfile my_device-tree.dtb
55 env save
56
57or the configuration variable CONFIG_DEFAULT_FDT_FILE can be used to set to
58provide a default value.
59
Heinrich Schuchardtb59ac9b2024-04-02 10:49:12 +020060Preparing the SD-Card
Heinrich Schuchardt0c443d62025-04-24 14:13:13 +020061---------------------
Heinrich Schuchardtb59ac9b2024-04-02 10:49:12 +020062
63The device firmware loads U-Boot SPL (u-boot-spl.bin.normal.out) from the
64partition with type GUID 2E54B353-1271-4842-806F-E436D6AF6985. You are free
65to choose any partition number.
66
67With the default configuration U-Boot SPL loads the U-Boot FIT image
68(u-boot.itb) from partition 2 (CONFIG_SYS_MMCSD_RAW_MODE_U_BOOT_PARTITION=0x2).
69When formatting it is recommended to use GUID
70BC13C2FF-59E6-4262-A352-B275FD6F7172 for this partition.
71
72The FIT image (u-boot.itb) is a combination of OpenSBI's fw_dynamic.bin,
73u-boot-nodtb.bin and the device tree blob.
74
75Format the SD card (make sure the disk has GPT, otherwise use gdisk to switch)
76
77.. code-block:: bash
78
79 sudo sgdisk --clear \
80 --set-alignment=2 \
81 --new=1:4096:8191 --change-name=1:spl --typecode=1:2E54B353-1271-4842-806F-E436D6AF6985\
82 --new=2:8192:16383 --change-name=2:uboot --typecode=2:BC13C2FF-59E6-4262-A352-B275FD6F7172 \
83 --new=3:16384:1654784 --change-name=3:system --typecode=3:EBD0A0A2-B9E5-4433-87C0-68B6B72699C7 \
84 /dev/sdb
85
86Copy U-Boot to the SD card
87
88.. code-block:: bash
89
90 sudo dd if=u-boot-spl.bin.normal.out of=/dev/sdb1
91 sudo dd if=u-boot.itb of=/dev/sdb2
92
93 sudo mount /dev/sdb3 /mnt/
94 sudo cp u-boot-spl.bin.normal.out /mnt/
95 sudo cp u-boot.itb /mnt/
96 sudo cp Image.gz /mnt/
97 sudo cp initramfs.cpio.gz /mnt/
98 sudo cp jh7110-starfive-visionfive-2.dtb /mnt/
99 sudo umount /mnt
100
Heinrich Schuchardt387cd002025-04-24 14:13:14 +0200101.. include:: jh7110_common.rst