Skip to content
Snippets Groups Projects
Select Git revision
  • 02077a8caed12d662a268f15604f5a38f5f6b05c
  • devel default protected
  • fix_crash_at_transport
  • wenpeng-1007
  • asterisk_rdkb
  • lk_debug_dialogs
  • lk_forking_revert
  • wenpeng-jul8
  • gyang-devel
  • gyang-devel1
  • wenpeng-jul9
  • asterisk_rdkb_ipv6
  • 16916_rdkb_merge
  • lk_disable_registrar
  • wenpeng-100rel-ippbx
  • fix_multiple_dns_lookup
  • dev_fxs_no_wb
  • fix_fallback
  • 14666_fxs_no_wideband_codec
  • fix_srv_records
  • fix_deadlock_in_bridge_peer_functions
  • 22.0.0-pre1
  • 21.4.2
  • 20.9.2
  • 18.24.2
  • certified-20.7-cert2
  • certified-18.9-cert11
  • 21.4.1
  • 20.9.1
  • 18.24.1
  • 21.4.0
  • 20.9.0
  • 18.24.0
  • certified-20.7-cert1
  • certified-18.9-cert10
  • 21.4.0-rc1
  • 20.9.0-rc1
  • 18.24.0-rc1
  • 21.3.1
  • 20.8.1
  • 18.23.1
41 results

astman.c

Blame
  • README.mediatek 6.14 KiB
    # 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