# SPDX-License-Identifier: GPL-2.0+ # # Copyright (C) 2018 MediaTek Inc. # Ryder Lee <ryder.lee@kernel.org> This document describes how to compile the U-Boot and how to change U-Boot configuration about the MediaTek SoCs. Build Procedure =============== -Set the cross compiler: # export CROSS_COMPILE=/path/to/toolchain/arm-linux-gnueabi- -Clean-up old residuals: # make mrproper -Configure the U-Boot: # make <defconfig_file> # make - For the MT7623n bananapi R2 board use "mt7623n_bpir2_defconfig" - For the MT7629 reference board use "mt7629_rfb_defconfig" Boot sequence ============= -Bootrom -> MTK preloader -> U-Boot - MT7623n This version of U-Boot doesn't implement SPL. So, MTK preloader binary is needed to boot up: https://github.com/BPI-SINOVOIP/BPI-R2-bsp/tree/master/mt-pack/mtk/bpi-r2/bin -Bootrom -> SPL -> U-Boot - MT7629 Configuration update ==================== To update the U-Boot configuration, please refer to doc/README.kconfig MediaTek image header ===================== Currently there are two image headers used for MediaTek chips: - BootROM image header. This header is used by the first stage bootloader. It records the desired compatible boot device, integrity information and its load address. The on-chip BootROM will firstly verify integrity and compatibility of the bootloader. If verification passed, the BootROM will then load the bootloader into on-chip SRAM, and pass control to it. Note that this header is actually a combination of three independent headers: Device header, BRLYT header and GFH header. Used by U-Boot SPL of MT7629 and preloader of MT7623. - MediaTek legacy image header. This header was originally used by the legacy image. It basically records the load address, image size and image name. After all low level initializations passed, the preloader will locate the LK image and load it into DRAM, and pass control to it. Now this header is used by U-Boot of MT7623. To generate these two headers with mkimage: # mkimage -T mtk_image -a <load_addr> -n <option_string> -d <input_file> <image_file> - mtk_image means using MediaTek's header generation method. - load_addr is the load address of this image. For first stage bootloader like U-Boot SPL or preloader, it usually points to the on-chip SRAM. For second stage bootloader like U-Boot, it usually points to the DRAM. - option_string contains options to generate the header. The option string is using the follow format: key1=value1;key2=value2;... The following key names are valid: lk: If lk=1, LK image header is used. Otherwise BootROM image header is used. lkname: The name of the LK image header. The maximum length is 32. The default value is "U-Boot". media: Desired boot device. The valid values are: nand : Parallel NAND snand: Serial NAND nor : Serial NOR emmc : eMMC sdmmc: SD nandinfo: Desired NAND device type, a combination of page size, oob size and optional device capacity. Valid types are: 2k+64 : for Serial NAND, 2KiB page size + 64B oob size 2k+120 : for Serial NAND, 2KiB page size + 120B oob size 2k+128 : for Serial NAND, 2KiB page size + 128B oob size 4k+256 : for Serial NAND, 4KiB page size + 256B oob size 1g:2k+64 : for Parallel NAND, 2KiB page size + 64B oob size, total 1Gbit size 2g:2k+64 : for Parallel NAND, 2KiB page size + 64B oob size, total 2Gbit size 4g:2k+64 : for Parallel NAND, 2KiB page size + 64B oob size, total 4Gbit size 2g:2k+128: for Parallel NAND, 2KiB page size + 128B oob size, total 2Gbit size 4g:2k+128: for Parallel NAND, 2KiB page size + 128B oob size, total 4Gbit size MT7629 partitions on Serial NOR =============================== Start End Size Description 00000000 - 0000ffff: 64KiB U-Boot SPL 00010000 - 0005ffff: 320KiB U-Boot 00060000 - 0006ffff: 64KiB U-Boot env / MediaTek NVRAM 00070000 - 000affff: 256KiB RF calibration data 000b0000 - xxxxxxxx: all left Firmware image BPi-R2 (MT7623N) partitions on SD ================================= Please note that the last two partitions can vary from different Linux distributions depending on the MBR partition table. Start End Size Description 00000000 - 000001ff: 512B Device header (with MBR partition table) 00000200 - 000007ff: 1536B BRLYT header 00000800 - 0004ffff: 318KiB Preloader (with GFH header) 00050000 - 000fffff: 704KiB U-Boot 00100000 - 063fffff: 99MiB Reserved 06400000 - 163fffff: 256MiB Partition 1 (FAT32) 16400000 - xxxxxxxx: all left Partition 2 (ext4) Upgrading notice on Serial NOR ============================== Example: MT7629 The command sf is used to operate the Serial NOR device: - To probe current NOR flash: # sf probe - To erase a region: # sf erase <offset> <len> - To write data to an offset: # sf write <data_addr> <offset> <len> - To boot kernel: # bootm 0x300b0000 The memory address range 0x30000000 - 0x3fffffff is mapped to the NOR flash. The DRAM starts at 0x40000000. Please note that the output binary u-boot-mtk.bin is a combination of SPL and U-Boot, and it should be write to beginning of the flash. Otherwise you should use standalone files: spl/u-boot-spl-mtk.bin for SPL, u-boot.img for U-Boot. Upgrading notice on SD / eMMC ============================= Example: MT7623 Normally only Preloader and U-Boot can be upgraded within U-Boot, and other partitions should be written in PC. - To probe current SD card / eMMC: # mmc dev 0 for eMMC # mmc dev 1 for SD - To erase a region: # mmc erase <blk_offset> <blk_num> - To write data to a block offset: # mmc write <data_addr> <blk_offset> <blk_num> - To load kernel image from partition 1: # fatload mmc 0:1 <load_address> <path_to_kernel_uImage> for eMMC # fatload mmc 1:1 <load_address> <path_to_kernel_uImage> for SD - To boot kernel: # bootm <load_address> The DRAM starts at 0x80000000. Please note that we use block offset and block count for SD card, not the byte offset. The block size is always 512 bytes for SD card. Documentation ============= http://wiki.banana-pi.org/Banana_Pi_BPI-R2