# 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