xref: /rk3399_rockchip-uboot/make.sh (revision 2a0b9372577646701ccd8873bdf4de4fc935cee3)
1de440615SJoseph Chen#!/bin/bash
2f7bec228SJoseph Chen#
3f7bec228SJoseph Chen# Copyright (c) 2019 Fuzhou Rockchip Electronics Co., Ltd
4f7bec228SJoseph Chen#
5f7bec228SJoseph Chen# SPDX-License-Identifier: GPL-2.0
6f7bec228SJoseph Chen#
7f7bec228SJoseph Chen
8cd7ae718SJoseph Chenset -e
927a50c86SAndy YanJOB=`sed -n "N;/processor/p" /proc/cpuinfo|wc -l`
10b6255198SJoseph ChenSUPPORT_LIST=`ls configs/*[r,p][x,v,k][0-9][0-9]*_defconfig`
11b42d2103SJoseph ChenCMD_ARGS=$1
1227a50c86SAndy Yan
130583701dSJoseph Chen# @LOADER: map to $RKCHIP_LOADER for loader ini
140583701dSJoseph Chen# @TRUST:  map to $RKCHIP_TRUST for trust ini
150583701dSJoseph Chen# @LABEL:  map to $RKCHIP_LEBEL for verbose message
160583701dSJoseph Chen# @-:      default state/value
170583701dSJoseph ChenCHIP_TYPE_FIXUP_TABLE=(
180583701dSJoseph Chen	# CONFIG_XXX                         RKCHIP         LOADER       TRUST         LABEL
190583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK3368              RK3368H         -            -             -"
200583701dSJoseph Chen	"CONFIG_ROCKCHIP_RV1108              RV110X          -            -             -"
210583701dSJoseph Chen	"CONFIG_ROCKCHIP_PX3SE               PX3SE           -            -             -"
220583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK3126              RK3126          -            -             -"
230583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK3326              RK3326          -            -             -"
240583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK3128X             RK3128X         -            -             -"
250583701dSJoseph Chen	"CONFIG_ROCKCHIP_PX5                 PX5             -            -             -"
260583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK3399PRO           RK3399PRO       -            -             -"
270583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK1806              RK1806          -            -             -"
280583701dSJoseph Chen	"CONFIG_TARGET_GVA_RK3229            RK322X          RK322XAT     -             -"
290583701dSJoseph Chen	"CONFIG_COPROCESSOR_RK1808           RKNPU-LION      RKNPULION    RKNPULION     -"
300583701dSJoseph Chen)
310583701dSJoseph Chen
320583701dSJoseph Chen# <*> Fixup rsa/sha pack mode for platforms
330583701dSJoseph Chen#     RSA: RK3308/PX30/RK3326/RK1808 use RSA-PKCS1 V2.1, it's pack magic is "3", and others use default configure.
340583701dSJoseph Chen#     SHA: RK3368 use rk big endian SHA256, it's pack magic is "2", and others use default configure.
350583701dSJoseph Chen# <*> Fixup images size pack for platforms
360583701dSJoseph Chen# <*> Fixup verbose message about AARCH32
37de440615SJoseph Chen#
380583701dSJoseph Chen# @RSA:     rsa mode
390583701dSJoseph Chen# @SHA:     sha mode
400583701dSJoseph Chen# @A64-KB:  arm64 platform image size: [uboot,trust]
410583701dSJoseph Chen# @A64-NUM: arm64 platform image number of total: [uboot,trust]
420583701dSJoseph Chen# @A32-KB:  arm32 platform image size: [uboot,trust]
430583701dSJoseph Chen# @A32-NUM: arm32 platform image number of total: [uboot,trust]
440583701dSJoseph Chen# @LOADER:  map to $RKCHIP_LOADER for loader ini
450583701dSJoseph Chen# @TRUST:   map to $RKCHIP_TRUST for trust ini
460583701dSJoseph Chen# @-:       default state/value
470583701dSJoseph ChenCHIP_CFG_FIXUP_TABLE=(
480583701dSJoseph Chen	# CONFIG_XXX              RSA     SHA     A64-KB      A64-NUM     A32-KB       A32-NUM      LOAER        TRUST
490583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK3368    -       2       -,-          -,-        -,-          -,-           -           -"
500583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK3036    -       -       512,512      1,1        -,-          -,-           -           -"
510583701dSJoseph Chen	"CONFIG_ROCKCHIP_PX30      3       -       -,-          -,-        -,-          -,-           -           -"
520583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK3326    3       -       -,-          -,-        -,-          -,-           AARCH32     -"
530583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK3308    3       -       1024,1024    2,2        512,512      2,2           -           AARCH32"
540583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK1808    3       -       1024,1024    2,2        -,-          -,-           -           -"
552e566761SJoseph Chen	"CONFIG_ROCKCHIP_RV1126    3       -       -,-          -,-        -,-          -,-           -           -"
56de440615SJoseph Chen)
57de440615SJoseph Chen
58fb90bd1dSJoseph Chen########################################### User can modify #############################################
59fb90bd1dSJoseph Chen# User's rkbin tool relative path
60bc98b3c8SJoseph ChenRKBIN_TOOLS=../rkbin/tools
61bc98b3c8SJoseph Chen
62fb90bd1dSJoseph Chen# User's GCC toolchain and relative path
6353ea5791SJoseph ChenADDR2LINE_ARM32=arm-linux-gnueabihf-addr2line
6453ea5791SJoseph ChenADDR2LINE_ARM64=aarch64-linux-gnu-addr2line
65fb90bd1dSJoseph ChenOBJ_ARM32=arm-linux-gnueabihf-objdump
66fb90bd1dSJoseph ChenOBJ_ARM64=aarch64-linux-gnu-objdump
67b42d2103SJoseph ChenNM_ARM32=arm-linux-gnueabihf-nm
68b42d2103SJoseph ChenNM_ARM64=aarch64-linux-gnu-nm
69d8540eacSJoseph ChenGCC_ARM32=arm-linux-gnueabihf-
70d8540eacSJoseph ChenGCC_ARM64=aarch64-linux-gnu-
71d8540eacSJoseph ChenTOOLCHAIN_ARM32=../prebuilts/gcc/linux-x86/arm/gcc-linaro-6.3.1-2017.05-x86_64_arm-linux-gnueabihf/bin
72d8540eacSJoseph ChenTOOLCHAIN_ARM64=../prebuilts/gcc/linux-x86/aarch64/gcc-linaro-6.3.1-2017.05-x86_64_aarch64-linux-gnu/bin
73fb90bd1dSJoseph Chen
74fb90bd1dSJoseph Chen########################################### User not touch #############################################
75de440615SJoseph Chen# Declare global INI file searching index name for every chip, update in select_chip_info()
760583701dSJoseph ChenRKCHIP="-"
770583701dSJoseph ChenRKCHIP_LABEL="-"
780583701dSJoseph ChenRKCHIP_LOADER="-"
790583701dSJoseph ChenRKCHIP_TRUST="-"
80d443b7d5SJoseph Chen
81b768b915SJoseph ChenINI_TRUST=
82b768b915SJoseph ChenINI_LOADER=
83b768b915SJoseph Chen
8423ba6841SJoseph Chen# Declare rkbin repository path, updated in prepare()
85fb90bd1dSJoseph ChenRKBIN=
86fb90bd1dSJoseph Chen
87fb90bd1dSJoseph Chen# Declare global toolchain path for CROSS_COMPILE, updated in select_toolchain()
88fb90bd1dSJoseph ChenTOOLCHAIN_GCC=
89b42d2103SJoseph ChenTOOLCHAIN_NM=
90fb90bd1dSJoseph ChenTOOLCHAIN_OBJDUMP=
9153ea5791SJoseph ChenTOOLCHAIN_ADDR2LINE=
92fb90bd1dSJoseph Chen
9341cf5e5aSJoseph Chen# Declare global plaform configure, updated in fixup_platform_configure()
94b42d2103SJoseph ChenPLAT_RSA=
95b42d2103SJoseph ChenPLAT_SHA=
96b42d2103SJoseph ChenPLAT_UBOOT_SIZE=
97b42d2103SJoseph ChenPLAT_TRUST_SIZE=
98b42d2103SJoseph ChenPLAT_TYPE="RKFW" # default
99b42d2103SJoseph Chen
100b42d2103SJoseph ChenSRCTREE=`pwd`
101ae33e311SJoseph ChenSCRIPT_FIT="${SRCTREE}/scripts/fit.sh"
102b42d2103SJoseph ChenSCRIPT_ATF="${SRCTREE}/scripts/atf.sh"
103b42d2103SJoseph ChenSCRIPT_TOS="${SRCTREE}/scripts/tos.sh"
104b42d2103SJoseph ChenSCRIPT_SPL="${SRCTREE}/scripts/spl.sh"
105b42d2103SJoseph ChenSCRIPT_UBOOT="${SRCTREE}/scripts/uboot.sh"
106b42d2103SJoseph ChenSCRIPT_LOADER="${SRCTREE}/scripts/loader.sh"
107aa8ddc58SJoseph Chen
108173e789eSJoseph ChenREP_DIR="./rep"
109fb90bd1dSJoseph Chen#########################################################################################################
1107c3ca500SJoseph Chenfunction help()
111b6255198SJoseph Chen{
112b6255198SJoseph Chen	echo
1136a764259SJoseph Chen	echo "Usage:"
114b768b915SJoseph Chen	echo "	./make.sh [board|sub-command]"
1156a764259SJoseph Chen	echo
1166a764259SJoseph Chen	echo "	 - board:        board name of defconfig"
117b42d2103SJoseph Chen	echo "	 - sub-command:  elf*|loader|trust|uboot|--spl|--tpl|itb|map|sym|<addr>"
118b42d2103SJoseph Chen	echo "	 - ini:          ini file to pack trust/loader"
119f3d60245SJoseph Chen	echo
120f3d60245SJoseph Chen	echo "Output:"
121f3d60245SJoseph Chen	echo "	 When board built okay, there are uboot/trust/loader images in current directory"
122b6255198SJoseph Chen	echo
123b6255198SJoseph Chen	echo "Example:"
124b6255198SJoseph Chen	echo
125d6821889SJoseph Chen	echo "1. Build:"
126fc99e044SJoseph Chen	echo "	./make.sh evb-rk3399               --- build for evb-rk3399_defconfig"
127fc99e044SJoseph Chen	echo "	./make.sh firefly-rk3288           --- build for firefly-rk3288_defconfig"
128622ccf34SJoseph Chen	echo "	./make.sh EXT_DTB=rk-kernel.dtb    --- build with exist .config and external dtb"
129fc99e044SJoseph Chen	echo "	./make.sh                          --- build with exist .config"
130398d3e80SJoseph Chen	echo "	./make.sh env                      --- build envtools"
131b6255198SJoseph Chen	echo
132d6821889SJoseph Chen	echo "2. Pack:"
1336a764259SJoseph Chen	echo "	./make.sh uboot                    --- pack uboot.img"
13469cce37bSJoseph Chen	echo "	./make.sh trust                    --- pack trust.img"
135f3d60245SJoseph Chen	echo "	./make.sh trust <ini>              --- pack trust img with assigned ini file"
1366a764259SJoseph Chen	echo "	./make.sh loader                   --- pack loader bin"
137f3d60245SJoseph Chen	echo "	./make.sh loader <ini>             --- pack loader img with assigned ini file"
138b42d2103SJoseph Chen	echo "	./make.sh --spl                    --- pack loader with u-boot-spl.bin"
139b42d2103SJoseph Chen	echo "	./make.sh --tpl                    --- pack loader with u-boot-tpl.bin"
140b42d2103SJoseph Chen	echo "	./make.sh --tpl --spl              --- pack loader with u-boot-tpl.bin and u-boot-spl.bin"
141b6255198SJoseph Chen	echo
142d6821889SJoseph Chen	echo "3. Debug:"
143b6255198SJoseph Chen	echo "	./make.sh elf                      --- dump elf file with -D(default)"
144b6255198SJoseph Chen	echo "	./make.sh elf-S                    --- dump elf file with -S"
1456a764259SJoseph Chen	echo "	./make.sh elf-d                    --- dump elf file with -d"
146f3d60245SJoseph Chen	echo "	./make.sh elf-*                    --- dump elf file with -*"
147b42d2103SJoseph Chen	echo "	./make.sh <no reloc_addr>          --- unwind address(no relocated)"
148b42d2103SJoseph Chen	echo "	./make.sh <reloc_addr-reloc_off>   --- unwind address(relocated)"
149b6255198SJoseph Chen	echo "	./make.sh map                      --- cat u-boot.map"
150b6255198SJoseph Chen	echo "	./make.sh sym                      --- cat u-boot.sym"
151b6255198SJoseph Chen}
15241cf5e5aSJoseph Chen
1537c3ca500SJoseph Chenfunction prepare()
154cd7ae718SJoseph Chen{
155bc98b3c8SJoseph Chen	if [ -d ${RKBIN_TOOLS} ]; then
156bc98b3c8SJoseph Chen		absolute_path=$(cd `dirname ${RKBIN_TOOLS}`; pwd)
157bc98b3c8SJoseph Chen		RKBIN=${absolute_path}
158cd7ae718SJoseph Chen	else
159b768b915SJoseph Chen		echo "ERROR: No ../rkbin repository"
160cd7ae718SJoseph Chen		exit 1
161cd7ae718SJoseph Chen	fi
16269b6e590SJoseph Chen
1637c3ca500SJoseph Chen	if grep -Eq ''^CONFIG_ARM64=y'|'^CONFIG_ARM64_BOOT_AARCH32=y'' .config ; then
1647c3ca500SJoseph Chen		ARM64_TRUSTZONE="y"
1657c3ca500SJoseph Chen	fi
1667c3ca500SJoseph Chen
16769b6e590SJoseph Chen	if grep  -q '^CONFIG_ROCKCHIP_FIT_IMAGE_PACK=y' .config ; then
168b42d2103SJoseph Chen		PLAT_TYPE="FIT"
169b768b915SJoseph Chen	fi
170b768b915SJoseph Chen}
171b768b915SJoseph Chen
172b768b915SJoseph Chenfunction process_args()
173b768b915SJoseph Chen{
174b768b915SJoseph Chen	while [ $# -gt 0 ]; do
175b768b915SJoseph Chen		case $1 in
176b42d2103SJoseph Chen			*help|--h|-h)
177b768b915SJoseph Chen				help
178b768b915SJoseph Chen				exit 0
179b768b915SJoseph Chen				;;
180b42d2103SJoseph Chen			# '': build with exist .config
181b42d2103SJoseph Chen			# loader|trust|uboot: pack image
182b42d2103SJoseph Chen			# debug*|map|sym|elf*|nm: debug command
183b42d2103SJoseph Chen			# env: build env tool
184b42d2103SJoseph Chen			# itb: pack itb image
185b42d2103SJoseph Chen			# fit: pack non-secure uboot.img && boot.img
186b42d2103SJoseph Chen			''|loader|trust|uboot|debug*|itb|env|fit|map|sym|elf*|nm)
187b42b4e11SJoseph Chen				if [ "$2" == "spl" -o "$2" == "tpl" ]; then
188b42d2103SJoseph Chen					ARG_TSPL=$2
189b768b915SJoseph Chen					shift 1
190b768b915SJoseph Chen				fi
191b768b915SJoseph Chen				shift 1
192b768b915SJoseph Chen				;;
193b42d2103SJoseph Chen			# trust/loader ini files for packing trust.img/loader.img
194b42d2103SJoseph Chen			*.ini|*.INI)
195b768b915SJoseph Chen				if [ ! -f $1 ]; then
196b768b915SJoseph Chen					echo "ERROR: No $1"
197b768b915SJoseph Chen				fi
198b768b915SJoseph Chen				if grep -q 'CODE471_OPTION' $1 ; then
199b768b915SJoseph Chen					ARG_INI_LOADER=$1
200b768b915SJoseph Chen				elif grep -Eq ''BL31_OPTION'|'TOS'' $1 ; then
201b768b915SJoseph Chen					ARG_INI_TRUST=$1
202b768b915SJoseph Chen				fi
203b768b915SJoseph Chen				shift 1
204b768b915SJoseph Chen				;;
205b42d2103SJoseph Chen			--sz-trust) # set trust size
206b42d2103SJoseph Chen				ARG_TRUST_SIZE="--size $2 $3"
207b42d2103SJoseph Chen				shift 3
208b42d2103SJoseph Chen				;;
209b42d2103SJoseph Chen			--sz-uboot) # set uboot size
210b42d2103SJoseph Chen				ARG_UBOOT_SIZE="--size $2 $3"
211b42d2103SJoseph Chen				shift 3
212b42d2103SJoseph Chen				;;
2132d11b868SJoseph Chen			--raw-compile)  # FIT: build but not pack image
2142d11b868SJoseph Chen				ARG_RAW_COMPILE="y"
215b42d2103SJoseph Chen				shift 1
216b42d2103SJoseph Chen				;;
217b42d2103SJoseph Chen			--no-uboot) # FIT: pack uboot.img without u-boot
218b42d2103SJoseph Chen				ARG_NO_UBOOT="y"
219b42d2103SJoseph Chen				shift 1
220b42d2103SJoseph Chen				;;
221a505e63bSJoseph Chen			--idblock)  # pack idblock.bin
222a505e63bSJoseph Chen				shift 1
223a505e63bSJoseph Chen				;;
224b42d2103SJoseph Chen			--tpl|tpl)  # use tpl file
225b42d2103SJoseph Chen				ARG_TPL_BIN="tpl/u-boot-tpl.bin"
226b42d2103SJoseph Chen				shift 1
227b42d2103SJoseph Chen				;;
228b42d2103SJoseph Chen			--spl|spl*) # use spl file
229b42d2103SJoseph Chen				ARG_SPL_BIN="spl/u-boot-spl.bin"
230b42d2103SJoseph Chen				shift 1
231b42d2103SJoseph Chen				;;
232173e789eSJoseph Chen			--uboot|--fdt|--optee|--mcu|--bl31) # uboot.img components
233173e789eSJoseph Chen				mkdir -p ${REP_DIR}
234173e789eSJoseph Chen				if [ ! -f $2 ]; then
235173e789eSJoseph Chen					echo "ERROR: No $2"
236173e789eSJoseph Chen					exit 1
237173e789eSJoseph Chen				fi
238173e789eSJoseph Chen				if [ "$1" == "--uboot" ]; then
239173e789eSJoseph Chen					cp $2 ${REP_DIR}/u-boot-nodtb.bin
240173e789eSJoseph Chen				elif [ "$1" == "--fdt" ]; then
241173e789eSJoseph Chen					cp $2 ${REP_DIR}/u-boot.dtb
242173e789eSJoseph Chen				elif [ "$1" == "--optee" ]; then
243173e789eSJoseph Chen					cp $2 ${REP_DIR}/tee.bin
244173e789eSJoseph Chen				elif [ "$1" == "--mcu" ]; then
245173e789eSJoseph Chen					cp $2 ${REP_DIR}/mcu.bin
246173e789eSJoseph Chen				elif [ "$1" == "--bl31" ]; then
247173e789eSJoseph Chen					if ! file $2 | grep 'ELF ' >/dev/null 2>&1 ; then
248173e789eSJoseph Chen						echo "ERROR: $2 is not a bl31.elf file"
249173e789eSJoseph Chen						exit 1
250173e789eSJoseph Chen					fi
251173e789eSJoseph Chen					cp $2 ${REP_DIR}/bl31.elf
252173e789eSJoseph Chen				fi
253173e789eSJoseph Chen				shift 2
254173e789eSJoseph Chen				;;
255b768b915SJoseph Chen			*)
256b42d2103SJoseph Chen				#1. FIT scripts args
2572d11b868SJoseph Chen				NUM=$(${SCRIPT_FIT} --args $1)
258b42b4e11SJoseph Chen				if  [ ${NUM} -ne 0 ]; then
259b42b4e11SJoseph Chen					[ ${NUM} -eq 1 ] && ARG_LIST_FIT="${ARG_LIST_FIT} $1"
260b42b4e11SJoseph Chen					[ ${NUM} -eq 2 ] && ARG_LIST_FIT="${ARG_LIST_FIT} $1 $2"
2611ff581bbSJoseph Chen					shift ${NUM}
2621ff581bbSJoseph Chen					continue
263b42d2103SJoseph Chen				#2. unwind function address
2641ff581bbSJoseph Chen				elif [ -z $(echo $1 | sed 's/[0-9,a-f,A-F,x,X,-]//g') ]; then
265b768b915SJoseph Chen					ARG_FUNCADDR=$1
266b42d2103SJoseph Chen				#3. make defconfig
267b768b915SJoseph Chen				else
268b768b915SJoseph Chen					ARG_BOARD=$1
269124e8c09SJoseph Chen					if [ ! -f configs/${ARG_BOARD}_defconfig -a ! -f configs/${ARG_BOARD}.config ]; then
270b768b915SJoseph Chen						echo -e "\n${SUPPORT_LIST}\n"
271b768b915SJoseph Chen						echo "ERROR: No configs/${ARG_BOARD}_defconfig"
272b768b915SJoseph Chen						exit 1
273124e8c09SJoseph Chen					elif [ -f configs/${ARG_BOARD}.config ]; then
2741df865f3SJoseph Chen						BASE1_DEFCONFIG=`sed -n "/CONFIG_BASE_DEFCONFIG=/s/CONFIG_BASE_DEFCONFIG=//p" configs/${ARG_BOARD}.config |tr -d '\r' | tr -d '"'`
2751df865f3SJoseph Chen						BASE0_DEFCONFIG=`sed -n "/CONFIG_BASE_DEFCONFIG=/s/CONFIG_BASE_DEFCONFIG=//p" configs/${BASE1_DEFCONFIG} |tr -d '\r' | tr -d '"'`
2761df865f3SJoseph Chen						MAKE_CMD="make ${BASE0_DEFCONFIG} ${BASE1_DEFCONFIG} ${ARG_BOARD}.config -j${JOB}"
277124e8c09SJoseph Chen						echo "## ${MAKE_CMD}"
2781df865f3SJoseph Chen						make ${BASE0_DEFCONFIG} ${BASE1_DEFCONFIG} ${ARG_BOARD}.config ${OPTION}
279b768b915SJoseph Chen					else
280124e8c09SJoseph Chen						MAKE_CMD="make ${ARG_BOARD}_defconfig -j${JOB}"
281124e8c09SJoseph Chen						echo "## ${MAKE_CMD}"
282124e8c09SJoseph Chen						make ${ARG_BOARD}_defconfig ${OPTION}
283b768b915SJoseph Chen					fi
284b768b915SJoseph Chen				fi
285b768b915SJoseph Chen				shift 1
286b768b915SJoseph Chen				;;
287b768b915SJoseph Chen		esac
288b768b915SJoseph Chen	done
289b768b915SJoseph Chen
290b768b915SJoseph Chen	if [ ! -f .config ]; then
291b768b915SJoseph Chen		echo
292b768b915SJoseph Chen		echo "ERROR: No .config"
293b768b915SJoseph Chen		help
294b768b915SJoseph Chen		exit 1
29569b6e590SJoseph Chen	fi
29630b04afcSJoseph Chen}
2977c2526e9SJoseph Chen
2987c3ca500SJoseph Chenfunction select_toolchain()
29927a50c86SAndy Yan{
300d6821889SJoseph Chen	if grep -q '^CONFIG_ARM64=y' .config ; then
301bc98b3c8SJoseph Chen		if [ -d ${TOOLCHAIN_ARM64} ]; then
302bc98b3c8SJoseph Chen			absolute_path=$(cd `dirname ${TOOLCHAIN_ARM64}`; pwd)
303b42d2103SJoseph Chen			TOOLCHAIN_NM=${absolute_path}/bin/${NM_ARM64}
304bc98b3c8SJoseph Chen			TOOLCHAIN_GCC=${absolute_path}/bin/${GCC_ARM64}
3050ff0e214SJoseph Chen			TOOLCHAIN_OBJDUMP=${absolute_path}/bin/${OBJ_ARM64}
30653ea5791SJoseph Chen			TOOLCHAIN_ADDR2LINE=${absolute_path}/bin/${ADDR2LINE_ARM64}
307bc98b3c8SJoseph Chen		else
3087c3ca500SJoseph Chen			echo "ERROR: No toolchain: ${TOOLCHAIN_ARM64}"
309bc98b3c8SJoseph Chen			exit 1
31027a50c86SAndy Yan		fi
31127a50c86SAndy Yan	else
312bc98b3c8SJoseph Chen		if [ -d ${TOOLCHAIN_ARM32} ]; then
313bc98b3c8SJoseph Chen			absolute_path=$(cd `dirname ${TOOLCHAIN_ARM32}`; pwd)
314b42d2103SJoseph Chen			TOOLCHAIN_NM=${absolute_path}/bin/${NM_ARM32}
315bc98b3c8SJoseph Chen			TOOLCHAIN_GCC=${absolute_path}/bin/${GCC_ARM32}
3160ff0e214SJoseph Chen			TOOLCHAIN_OBJDUMP=${absolute_path}/bin/${OBJ_ARM32}
31753ea5791SJoseph Chen			TOOLCHAIN_ADDR2LINE=${absolute_path}/bin/${ADDR2LINE_ARM32}
318bc98b3c8SJoseph Chen		else
3197c3ca500SJoseph Chen			echo "ERROR: No toolchain: ${TOOLCHAIN_ARM32}"
320bc98b3c8SJoseph Chen			exit 1
32127a50c86SAndy Yan		fi
32227a50c86SAndy Yan	fi
323bc98b3c8SJoseph Chen}
324bc98b3c8SJoseph Chen
325b42b4e11SJoseph Chen#
326de440615SJoseph Chen# We select chip info to do:
327de440615SJoseph Chen#	1. RKCHIP:        fixup platform configure
328de440615SJoseph Chen#	2. RKCHIP_LOADER: search ini file to pack loader
329de440615SJoseph Chen#	3. RKCHIP_TRUST:  search ini file to pack trust
330de440615SJoseph Chen#	4. RKCHIP_LABEL:  show build message
331de440615SJoseph Chen#
3327c3ca500SJoseph Chenfunction select_chip_info()
333bc98b3c8SJoseph Chen{
334de440615SJoseph Chen	# Read RKCHIP firstly from .config
335596700d7SShunqian Zheng	# The regular expression that matching:
336596700d7SShunqian Zheng	#  - PX30, PX3SE
337596700d7SShunqian Zheng	#  - RK????, RK????X
338596700d7SShunqian Zheng	#  - RV????
339b42d2103SJoseph Chen	CHIP_PATTERN='^CONFIG_ROCKCHIP_[R,P][X,V,K][0-9ESX]{1,5}'
340b42d2103SJoseph Chen	RKCHIP=`egrep -o ${CHIP_PATTERN} .config`
341d443b7d5SJoseph Chen
3420583701dSJoseph Chen	# default
343d443b7d5SJoseph Chen	RKCHIP=${RKCHIP##*_}
344b42b4e11SJoseph Chen	# fixup ?
3457c3ca500SJoseph Chen	for item in "${CHIP_TYPE_FIXUP_TABLE[@]}"
346de440615SJoseph Chen	do
347b42d2103SJoseph Chen		CONFIG_ROCKCHIP_XXX=`echo ${item} | awk '{ print $1 }'`
348b42d2103SJoseph Chen		if grep  -q "^${CONFIG_ROCKCHIP_XXX}=y" .config ; then
349b42b4e11SJoseph Chen			RKCHIP=`echo ${item} | awk '{ print $2 }'`
350b42b4e11SJoseph Chen			RKCHIP_LOADER=`echo ${item} | awk '{ print $3 }'`
351b42b4e11SJoseph Chen			RKCHIP_TRUST=`echo  ${item} | awk '{ print $4 }'`
352b42b4e11SJoseph Chen			RKCHIP_LABEL=`echo  ${item} | awk '{ print $5 }'`
353de440615SJoseph Chen		fi
3540583701dSJoseph Chen	done
3550583701dSJoseph Chen
356b42b4e11SJoseph Chen	if [ "${RKCHIP_LOADER}" == "-" ]; then
3570583701dSJoseph Chen		RKCHIP_LOADER=${RKCHIP}
358de440615SJoseph Chen	fi
359b42b4e11SJoseph Chen	if [ "${RKCHIP_TRUST}" == "-" ]; then
3600583701dSJoseph Chen		RKCHIP_TRUST=${RKCHIP}
3610583701dSJoseph Chen	fi
362b42b4e11SJoseph Chen	if [ "${RKCHIP_LABEL}" == "-" ]; then
3630583701dSJoseph Chen		RKCHIP_LABEL=${RKCHIP}
3640583701dSJoseph Chen	fi
3650583701dSJoseph Chen}
3660583701dSJoseph Chen
36707d90e77SJoseph Chen# Priority: default < CHIP_CFG_FIXUP_TABLE() < make.sh args
3680583701dSJoseph Chenfunction fixup_platform_configure()
3690583701dSJoseph Chen{
370b42d2103SJoseph Chen	U_KB="-" U_NUM="-" T_KB="-" T_NUM="-"  SHA="-" RSA="-"
3710583701dSJoseph Chen
3727c3ca500SJoseph Chen	for item in "${CHIP_CFG_FIXUP_TABLE[@]}"
3730583701dSJoseph Chen	do
374b42b4e11SJoseph Chen		config_xxx=`echo ${item} | awk '{ print $1 }'`
3757c3ca500SJoseph Chen		if grep  -q "^${config_xxx}=y" .config ; then
3760583701dSJoseph Chen			# <*> Fixup rsa/sha pack mode for platforms
377b42d2103SJoseph Chen			RSA=`echo ${item} | awk '{ print $2 }'`
378b42d2103SJoseph Chen			SHA=`echo ${item} | awk '{ print $3 }'`
3790583701dSJoseph Chen
3800583701dSJoseph Chen			# <*> Fixup images size pack for platforms, and ini file
38189d0489dSJoseph Chen			if grep -q '^CONFIG_ARM64=y' .config ; then
382b42d2103SJoseph Chen				U_KB=`echo  ${item} | awk '{ print $4 }' | awk -F "," '{ print $1 }'`
383b42d2103SJoseph Chen				T_KB=`echo  ${item} | awk '{ print $4 }' | awk -F "," '{ print $2 }'`
384b42d2103SJoseph Chen				U_NUM=`echo ${item} | awk '{ print $5 }' | awk -F "," '{ print $1 }'`
385b42d2103SJoseph Chen				T_NUM=`echo ${item} | awk '{ print $5 }' | awk -F "," '{ print $2 }'`
38689d0489dSJoseph Chen			else
387b42d2103SJoseph Chen				U_KB=`echo  ${item} | awk '{ print $6 }' | awk -F "," '{ print $1 }'`
388b42d2103SJoseph Chen				T_KB=`echo  ${item} | awk '{ print $6 }' | awk -F "," '{ print $2 }'`
389b42d2103SJoseph Chen				U_NUM=`echo ${item} | awk '{ print $7 }' | awk -F "," '{ print $1 }'`
390b42d2103SJoseph Chen				T_NUM=`echo ${item} | awk '{ print $7 }' | awk -F "," '{ print $2 }'`
39189d0489dSJoseph Chen				# AArch32
39289d0489dSJoseph Chen				if grep -q '^CONFIG_ARM64_BOOT_AARCH32=y' .config ; then
393b42b4e11SJoseph Chen					PADDING=`echo ${item} | awk '{ print $8 }'`
394b42b4e11SJoseph Chen					if [ "${PADDING}" != "-" ]; then
395b42b4e11SJoseph Chen						RKCHIP_LOADER=${RKCHIP_LOADER}${PADDING}
3960583701dSJoseph Chen					fi
397b42b4e11SJoseph Chen					PADDING=`echo  ${item} | awk '{ print $9 }'`
398b42b4e11SJoseph Chen					if [ "${PADDING}" != "-" ]; then
399b42b4e11SJoseph Chen						RKCHIP_TRUST=${RKCHIP_TRUST}${PADDING}
4000583701dSJoseph Chen					fi
4010583701dSJoseph Chen					RKCHIP_LABEL=${RKCHIP_LABEL}"AARCH32"
40289d0489dSJoseph Chen				fi
403de440615SJoseph Chen			fi
404de440615SJoseph Chen		fi
405de440615SJoseph Chen	done
406de440615SJoseph Chen
407b42d2103SJoseph Chen	if [ "${SHA}" != "-" ]; then
408b42d2103SJoseph Chen		PLAT_SHA="--sha ${SHA}"
4090583701dSJoseph Chen	fi
410b42d2103SJoseph Chen	if [ "${RSA}" != "-" ]; then
411b42d2103SJoseph Chen		PLAT_RSA="--rsa ${RSA}"
4120583701dSJoseph Chen	fi
413b42d2103SJoseph Chen	if [ "${U_KB}" != "-" ]; then
414b42d2103SJoseph Chen		PLAT_UBOOT_SIZE="--size ${U_KB} ${U_NUM}"
4150583701dSJoseph Chen	fi
416b42d2103SJoseph Chen	if [ "${T_KB}" != "-" ]; then
417b42d2103SJoseph Chen		PLAT_TRUST_SIZE="--size ${T_KB} ${T_NUM}"
418b768b915SJoseph Chen	fi
41907d90e77SJoseph Chen
42007d90e77SJoseph Chen	# args
42107d90e77SJoseph Chen	if [ ! -z "${ARG_UBOOT_SIZE}" ]; then
422b42d2103SJoseph Chen		PLAT_UBOOT_SIZE=${ARG_UBOOT_SIZE}
42307d90e77SJoseph Chen	fi
42407d90e77SJoseph Chen
42507d90e77SJoseph Chen	if [ ! -z "${ARG_TRUST_SIZE}" ]; then
426b42d2103SJoseph Chen		PLAT_TRUST_SIZE=${ARG_TRUST_SIZE}
42707d90e77SJoseph Chen	fi
428b768b915SJoseph Chen}
429b768b915SJoseph Chen
430496a6e1eSJoseph Chen# Priority: default < CHIP_TYPE_FIXUP_TABLE() < defconfig < make.sh args
431b768b915SJoseph Chenfunction select_ini_file()
432b768b915SJoseph Chen{
433b768b915SJoseph Chen	# default
434b768b915SJoseph Chen	INI_LOADER=${RKBIN}/RKBOOT/${RKCHIP_LOADER}MINIALL.ini
435b42b4e11SJoseph Chen	if [ "${ARM64_TRUSTZONE}" == "y" ]; then
436b768b915SJoseph Chen		INI_TRUST=${RKBIN}/RKTRUST/${RKCHIP_TRUST}TRUST.ini
437b768b915SJoseph Chen	else
438b768b915SJoseph Chen		INI_TRUST=${RKBIN}/RKTRUST/${RKCHIP_TRUST}TOS.ini
43941cf5e5aSJoseph Chen	fi
44041cf5e5aSJoseph Chen
441496a6e1eSJoseph Chen	# defconfig
442496a6e1eSJoseph Chen	NAME=`sed -n "/CONFIG_LOADER_INI=/s/CONFIG_LOADER_INI=//p" .config |tr -d '\r' | tr -d '"'`
443496a6e1eSJoseph Chen	if [ ! -z "${NAME}" ]; then
444496a6e1eSJoseph Chen		INI_LOADER=${RKBIN}/RKBOOT/${NAME}
445496a6e1eSJoseph Chen	fi
446496a6e1eSJoseph Chen	NAME=`sed -n "/CONFIG_TRUST_INI=/s/CONFIG_TRUST_INI=//p" .config |tr -d '\r' | tr -d '"'`
447496a6e1eSJoseph Chen	if [ ! -z "${NAME}" ]; then
448496a6e1eSJoseph Chen		INI_TRUST=${RKBIN}/RKTRUST/${NAME}
449496a6e1eSJoseph Chen	fi
450496a6e1eSJoseph Chen
451b768b915SJoseph Chen	# args
452b42d2103SJoseph Chen	if [ ! -z "${ARG_INI_TRUST}" ]; then
453b42b4e11SJoseph Chen		INI_TRUST=${ARG_INI_TRUST}
454b768b915SJoseph Chen	fi
455b42d2103SJoseph Chen	if [ ! -z "${ARG_INI_LOADER}" ]; then
456b42b4e11SJoseph Chen		INI_LOADER=${ARG_INI_LOADER}
457b768b915SJoseph Chen	fi
45827a50c86SAndy Yan}
459de9a6cd2SJoseph Chen
460b42d2103SJoseph Chenfunction sub_commands()
461b42d2103SJoseph Chen{
462b42d2103SJoseph Chen	# skip "--" parameter, such as "--rollback-index-..."
463b42d2103SJoseph Chen	if [[ ${CMD_ARGS} != --* ]]; then
464b42d2103SJoseph Chen		CMD=${CMD_ARGS%-*}
465b42d2103SJoseph Chen		ARG=${CMD_ARGS#*-}
466b42d2103SJoseph Chen	else
467b42d2103SJoseph Chen		CMD=${CMD_ARGS}
468b42d2103SJoseph Chen	fi
469b42d2103SJoseph Chen
470b42d2103SJoseph Chen	if [ "${ARG_TSPL}" == "tpl" -o "${ARG_TSPL}" == "spl" ]; then
471b42d2103SJoseph Chen		ELF=`find -name u-boot-${ARG_TSPL}`
472b42d2103SJoseph Chen		MAP=`find -name u-boot-${ARG_TSPL}.map`
473b42d2103SJoseph Chen		SYM=`find -name u-boot-${ARG_TSPL}.sym`
474b42d2103SJoseph Chen	else
475b42d2103SJoseph Chen		ELF=u-boot
476b42d2103SJoseph Chen		MAP=u-boot.map
477b42d2103SJoseph Chen		SYM=u-boot.sym
478b42d2103SJoseph Chen	fi
479b42d2103SJoseph Chen
480b42d2103SJoseph Chen	case ${CMD} in
481b42d2103SJoseph Chen		elf|nm)
482b42d2103SJoseph Chen			if [ "${CMD}" == "nm" ]; then
4839b6b8f53SJoseph Chen				echo -e "\n${ELF}:     file format elf\n"
484b42d2103SJoseph Chen				${TOOLCHAIN_NM} -r --size ${ELF} | less
485b42d2103SJoseph Chen			else
486b42d2103SJoseph Chen				if [ "${CMD}" == "elf" -a "${ARG}" == "elf" ]; then
487b42d2103SJoseph Chen					ARG=D # default
488b42d2103SJoseph Chen				fi
489b42d2103SJoseph Chen				${TOOLCHAIN_OBJDUMP} -${ARG} ${ELF} | less
490b42d2103SJoseph Chen			fi
491b42d2103SJoseph Chen			exit 0
492b42d2103SJoseph Chen			;;
493b42d2103SJoseph Chen		map|sym)
494b42d2103SJoseph Chen			if [ ${CMD} == "map" ]; then
495b42d2103SJoseph Chen				cat ${MAP} | less
496b42d2103SJoseph Chen			else
497b42d2103SJoseph Chen				cat ${SYM} | less
498b42d2103SJoseph Chen			fi
499b42d2103SJoseph Chen			exit 0
500b42d2103SJoseph Chen			;;
501b42d2103SJoseph Chen		debug)
502b42d2103SJoseph Chen			./scripts/rkpatch.sh ${ARG}
503b42d2103SJoseph Chen			exit 0
504b42d2103SJoseph Chen			;;
505b42d2103SJoseph Chen		fit)
506b42d2103SJoseph Chen			# Non-secure
5072d11b868SJoseph Chen			${SCRIPT_FIT} --boot_img_dir images/ ${ARG_LIST_FIT}
508b42d2103SJoseph Chen			exit 0
509b42d2103SJoseph Chen			;;
510b42d2103SJoseph Chen		uboot)
511b42d2103SJoseph Chen			pack_uboot_image
512b42d2103SJoseph Chen			exit 0
513b42d2103SJoseph Chen			;;
514b42d2103SJoseph Chen		trust)
515b42d2103SJoseph Chen			pack_trust_image
516b42d2103SJoseph Chen			exit 0
517b42d2103SJoseph Chen			;;
518b42d2103SJoseph Chen		loader)
519b42d2103SJoseph Chen			pack_loader_image
520b42d2103SJoseph Chen			exit 0
521b42d2103SJoseph Chen			;;
522b42d2103SJoseph Chen		itb)
523b42d2103SJoseph Chen			pack_uboot_itb_image
524b42d2103SJoseph Chen			exit 0
525b42d2103SJoseph Chen			;;
526b42d2103SJoseph Chen		env)
527b42d2103SJoseph Chen			make CROSS_COMPILE=${TOOLCHAIN_GCC} envtools
528b42d2103SJoseph Chen			exit 0
529b42d2103SJoseph Chen			;;
530a505e63bSJoseph Chen		--idblock)
531a505e63bSJoseph Chen			pack_idblock
532a505e63bSJoseph Chen			exit 0
533a505e63bSJoseph Chen			;;
534b42d2103SJoseph Chen		--tpl|--spl|tpl|spl)
535b42d2103SJoseph Chen			pack_spl_loader_image
536b42d2103SJoseph Chen			exit 0
537b42d2103SJoseph Chen			;;
538b42d2103SJoseph Chen		*)
539b42d2103SJoseph Chen			unwind_addr_or_continue
540b42d2103SJoseph Chen			;;
541b42d2103SJoseph Chen	esac
542b42d2103SJoseph Chen}
543b42d2103SJoseph Chen
544b42d2103SJoseph Chenfunction unwind_addr_or_continue()
545b42d2103SJoseph Chen{
546b42d2103SJoseph Chen	FUNCADDR=${ARG_FUNCADDR}
547b42d2103SJoseph Chen	RELOCOFF=${FUNCADDR#*-}
548b42d2103SJoseph Chen	FUNCADDR=${FUNCADDR%-*}
549b42d2103SJoseph Chen
550b42d2103SJoseph Chen	if [ -z $(echo ${FUNCADDR} | sed 's/[0-9,a-f,A-F,x,X,-]//g') ] && [ ${FUNCADDR} ]; then
551b42d2103SJoseph Chen		# With prefix: '0x' or '0X'
552b42d2103SJoseph Chen		if [ `echo ${FUNCADDR} | sed -n "/0[x,X]/p" | wc -l` -ne 0 ]; then
553b42d2103SJoseph Chen			FUNCADDR=`echo ${FUNCADDR} | awk '{ print strtonum($0) }'`
554b42d2103SJoseph Chen			FUNCADDR=`echo "obase=16;${FUNCADDR}"|bc | tr '[A-Z]' '[a-z]'`
555b42d2103SJoseph Chen		fi
556b42d2103SJoseph Chen		if [ `echo ${RELOCOFF} | sed -n "/0[x,X]/p" | wc -l` -ne 0 ] && [ ${RELOCOFF} ]; then
557b42d2103SJoseph Chen			RELOCOFF=`echo ${RELOCOFF} | awk '{ print strtonum($0) }'`
558b42d2103SJoseph Chen			RELOCOFF=`echo "obase=16;${RELOCOFF}"|bc | tr '[A-Z]' '[a-z]'`
559b42d2103SJoseph Chen		fi
560b42d2103SJoseph Chen
561b42d2103SJoseph Chen		# If reloc address is assigned, do sub
562b42d2103SJoseph Chen		if [ "${FUNCADDR}" != "${RELOCOFF}" ]; then
563b42d2103SJoseph Chen			# Hex -> Dec -> SUB -> Hex
564b42d2103SJoseph Chen			FUNCADDR=`echo $((16#${FUNCADDR}))`
565b42d2103SJoseph Chen			RELOCOFF=`echo $((16#${RELOCOFF}))`
566b42d2103SJoseph Chen			FUNCADDR=$((FUNCADDR-RELOCOFF))
567b42d2103SJoseph Chen			FUNCADDR=$(echo "obase=16;${FUNCADDR}"|bc | tr '[A-Z]' '[a-z]')
568b42d2103SJoseph Chen		fi
569b42d2103SJoseph Chen
570b42d2103SJoseph Chen		echo
571b42d2103SJoseph Chen		sed -n "/${FUNCADDR}/p" ${SYM}
572b42d2103SJoseph Chen		${TOOLCHAIN_ADDR2LINE} -e ${ELF} ${FUNCADDR}
573b42d2103SJoseph Chen		exit 0
574b42d2103SJoseph Chen	fi
575b42d2103SJoseph Chen}
576b42d2103SJoseph Chen
577a505e63bSJoseph Chenfunction pack_idblock()
578a505e63bSJoseph Chen{
579a505e63bSJoseph Chen	INI=${INI_LOADER}
580a505e63bSJoseph Chen	if [ ! -f ${INI} ]; then
581a505e63bSJoseph Chen		echo "ERROR: No ${INI}"
582a505e63bSJoseph Chen		exit 1
583a505e63bSJoseph Chen	fi
584a505e63bSJoseph Chen
585a505e63bSJoseph Chen	# chip
586a505e63bSJoseph Chen	COMMON_H=`grep "_common.h:" include/autoconf.mk.dep | awk -F "/" '{ printf $3 }'`
587a505e63bSJoseph Chen	PLAT=${COMMON_H%_*}
588a505e63bSJoseph Chen
589a505e63bSJoseph Chen	# file
590a505e63bSJoseph Chen	SPL_BIN=${RKBIN}/`sed -n "/FlashBoot=/s/FlashBoot=//p" ${INI} | tr -d '\r'`
591a505e63bSJoseph Chen	TPL_BIN=${RKBIN}/`sed -n "/FlashData=/s/FlashData=//p" ${INI} | tr -d '\r'`
592a505e63bSJoseph Chen	if [ ! -z "${ARG_SPL_BIN}" ]; then
593a505e63bSJoseph Chen		SPL_BIN=${ARG_SPL_BIN}
594a505e63bSJoseph Chen	fi
595a505e63bSJoseph Chen	if [ ! -z "${ARG_TPL_BIN}" ]; then
596a505e63bSJoseph Chen		TPL_BIN=${ARG_TPL_BIN}
597a505e63bSJoseph Chen	fi
598a505e63bSJoseph Chen
599a505e63bSJoseph Chen	# pack
600a505e63bSJoseph Chen	rm idblock.bin -f
601a505e63bSJoseph Chen	./tools/mkimage -n ${PLAT} -T rksd -d ${TPL_BIN}:${SPL_BIN} idblock.bin
602a505e63bSJoseph Chen	echo "Input:"
603a505e63bSJoseph Chen	echo "    ${INI}"
604a505e63bSJoseph Chen	echo "    ${TPL_BIN}"
605a505e63bSJoseph Chen	echo "    ${SPL_BIN}"
606a505e63bSJoseph Chen	echo
607a505e63bSJoseph Chen	echo "Pack ${PLAT} idblock.bin okay!"
608a505e63bSJoseph Chen	echo
609a505e63bSJoseph Chen}
610a505e63bSJoseph Chen
611b42d2103SJoseph Chenfunction pack_uboot_itb_image()
612b42d2103SJoseph Chen{
613b42d2103SJoseph Chen	INI=${INI_TRUST}
614b42d2103SJoseph Chen	if [ ! -f ${INI} ]; then
615b42d2103SJoseph Chen		echo "ERROR: No ${INI}"
616b42d2103SJoseph Chen		exit 1
617b42d2103SJoseph Chen	fi
618b42d2103SJoseph Chen
619b42d2103SJoseph Chen	if [ "${ARM64_TRUSTZONE}" == "y" ]; then
620b42d2103SJoseph Chen		BL31_ELF=`sed -n '/_bl31_/s/PATH=//p' ${INI} | tr -d '\r'`
621cb718016SJoseph Chen		BL32_BIN=`sed -n '/_bl32_/s/PATH=//p' ${INI} | tr -d '\r'`
622407bd0fbSJoseph Chen		rm bl31.elf tee.bin -rf
623b42d2103SJoseph Chen		cp ${RKBIN}/${BL31_ELF} bl31.elf
624cb718016SJoseph Chen		if grep BL32_OPTION -A 1 ${INI} | grep SEC=1 ; then
625cb718016SJoseph Chen			cp ${RKBIN}/${BL32_BIN} tee.bin
626cb718016SJoseph Chen			TEE_OFFSET=`grep BL32_OPTION -A 3 ${INI} | grep ADDR= | awk -F "=" '{ printf $2 }' | tr -d '\r'`
627cb718016SJoseph Chen			TEE_ARG="-t ${TEE_OFFSET}"
628cb718016SJoseph Chen		fi
629b42d2103SJoseph Chen	else
630b42d2103SJoseph Chen		# TOS
631b42d2103SJoseph Chen		TOS=`sed -n "/TOS=/s/TOS=//p" ${INI} | tr -d '\r'`
632b42d2103SJoseph Chen		TOSTA=`sed -n "/TOSTA=/s/TOSTA=//p" ${INI} | tr -d '\r'`
633b42d2103SJoseph Chen		if [ ! -z "${TOSTA}" ]; then
634b42d2103SJoseph Chen			cp ${RKBIN}/${TOSTA} tee.bin
635b42d2103SJoseph Chen		elif [ ! -z "${TOS}" ]; then
636b42d2103SJoseph Chen			cp ${RKBIN}/${TOS}   tee.bin
637b42d2103SJoseph Chen		else
638b42d2103SJoseph Chen			echo "ERROR: No tee bin"
639b42d2103SJoseph Chen			exit 1
640b42d2103SJoseph Chen		fi
641b42d2103SJoseph Chen
642b42d2103SJoseph Chen		TEE_OFFSET=`sed -n "/ADDR=/s/ADDR=//p" ${INI} | tr -d '\r'`
643b42d2103SJoseph Chen		if [ "${TEE_OFFSET}" == "" ]; then
644b42d2103SJoseph Chen			TEE_OFFSET=0x8400000
645b42d2103SJoseph Chen		fi
646cb718016SJoseph Chen		TEE_ARG="-t ${TEE_OFFSET}"
64733e46123SJoseph Chen	fi
648b42d2103SJoseph Chen
649b42d2103SJoseph Chen	# MCU
650b42d2103SJoseph Chen	MCU_ENABLED=`awk -F"," '/MCU=/ { printf $3 }' ${INI} | tr -d ' '`
651b42d2103SJoseph Chen	if [ "${MCU_ENABLED}" == "enabled" -o "${MCU_ENABLED}" == "okay" ]; then
652b42d2103SJoseph Chen		MCU=`awk -F"," '/MCU=/  { printf $1 }' ${INI} | tr -d ' ' | cut -c 5-`
653b42d2103SJoseph Chen		cp ${RKBIN}/${MCU} mcu.bin
654b42d2103SJoseph Chen		MCU_OFFSET=`awk -F"," '/MCU=/ { printf $2 }' ${INI} | tr -d ' '`
6553a711d9cSJoseph Chen		if [ -z ${MCU_OFFSET} ]; then
6563a711d9cSJoseph Chen			echo "ERROR: No mcu address in ${INI}"
6573a711d9cSJoseph Chen			exit 1
6583a711d9cSJoseph Chen		fi
659cb718016SJoseph Chen		MCU_ARG="-m ${MCU_OFFSET}"
660cb718016SJoseph Chen	fi
661b42d2103SJoseph Chen
66233e46123SJoseph Chen	# COMPRESSION
663b42d2103SJoseph Chen	COMPRESSION=`awk -F"," '/COMPRESSION=/  { printf $1 }' ${INI} | tr -d ' ' | cut -c 13-`
664cb718016SJoseph Chen	if [ ! -z "${COMPRESSION}" -a "${COMPRESSION}" != "none" ]; then
665cb718016SJoseph Chen		COMPRESSION_ARG="-c ${COMPRESSION}"
666b42d2103SJoseph Chen	fi
667b42d2103SJoseph Chen
668173e789eSJoseph Chen	if [ -d ${REP_DIR} ]; then
669173e789eSJoseph Chen		mv ${REP_DIR}/* ./
670173e789eSJoseph Chen	fi
671173e789eSJoseph Chen
672b42d2103SJoseph Chen	SPL_FIT_SOURCE=`sed -n "/CONFIG_SPL_FIT_SOURCE=/s/CONFIG_SPL_FIT_SOURCE=//p" .config | tr -d '""'`
673b42d2103SJoseph Chen	if [ ! -z ${SPL_FIT_SOURCE} ]; then
674b42d2103SJoseph Chen		cp ${SPL_FIT_SOURCE} u-boot.its
675b42d2103SJoseph Chen	else
676b42d2103SJoseph Chen		SPL_FIT_GENERATOR=`sed -n "/CONFIG_SPL_FIT_GENERATOR=/s/CONFIG_SPL_FIT_GENERATOR=//p" .config | tr -d '""'`
6773a711d9cSJoseph Chen		# *.py is the legacy one.
67846e7ba36SJoseph Chen		if [[ ${SPL_FIT_GENERATOR} == *.py ]]; then
67946e7ba36SJoseph Chen			${SPL_FIT_GENERATOR} u-boot.dtb > u-boot.its
68046e7ba36SJoseph Chen		else
681cb718016SJoseph Chen			${SPL_FIT_GENERATOR} ${TEE_ARG} ${COMPRESSION_ARG} ${MCU_ARG} > u-boot.its
682b42d2103SJoseph Chen		fi
68346e7ba36SJoseph Chen	fi
684b42d2103SJoseph Chen
685173a9307SJoseph Chen	./tools/mkimage -f u-boot.its -E u-boot.itb >/dev/null 2>&1
686b42d2103SJoseph Chen	echo "pack u-boot.itb okay! Input: ${INI}"
687b42d2103SJoseph Chen	echo
688b42d2103SJoseph Chen}
689b42d2103SJoseph Chen
690b42d2103SJoseph Chenfunction pack_spl_loader_image()
691b42d2103SJoseph Chen{
692b42d2103SJoseph Chen	rm *_loader_*.bin -f
693b42d2103SJoseph Chen	cd ${RKBIN}
694b42d2103SJoseph Chen	if [ ! -z "${ARG_SPL_BIN}" -a ! -z "${ARG_TPL_BIN}" ]; then
695b42d2103SJoseph Chen		${SCRIPT_SPL} --ini ${INI_LOADER} --tpl ${SRCTREE}/${ARG_TPL_BIN} --spl ${SRCTREE}/${ARG_SPL_BIN}
696b42d2103SJoseph Chen	elif [ ! -z "${ARG_TPL_BIN}" ]; then
697b42d2103SJoseph Chen		${SCRIPT_SPL} --ini ${INI_LOADER} --tpl ${SRCTREE}/${ARG_TPL_BIN}
698b42d2103SJoseph Chen	else
699b42d2103SJoseph Chen		${SCRIPT_SPL} --ini ${INI_LOADER} --spl ${SRCTREE}/${ARG_SPL_BIN}
700b42d2103SJoseph Chen	fi
701b42d2103SJoseph Chen	cd -
702b42d2103SJoseph Chen	if [ -f ${RKBIN}/*_loader_*.bin ]; then
703b42d2103SJoseph Chen		mv ${RKBIN}/*_loader_*.bin ./
704b42d2103SJoseph Chen	fi
705b42d2103SJoseph Chen}
706b42d2103SJoseph Chen
707b42d2103SJoseph Chenfunction pack_uboot_image()
708b42d2103SJoseph Chen{
709b42d2103SJoseph Chen	rm u-boot.img u-boot-dtb.img -f
710b42d2103SJoseph Chen	LOAD_ADDR=`sed -n "/CONFIG_SYS_TEXT_BASE=/s/CONFIG_SYS_TEXT_BASE=//p" include/autoconf.mk|tr -d '\r'`
711a524b379SJoseph Chen	if [ -z "${LOAD_ADDR}" ]; then
712a524b379SJoseph Chen		# upstream U-Boot
713a524b379SJoseph Chen		LOAD_ADDR=`grep CONFIG_SYS_TEXT_BASE include/generated/autoconf.h | awk '{ print $3 }' | tr -d '\r'`
714a524b379SJoseph Chen	fi
715a524b379SJoseph Chen
716a524b379SJoseph Chen	if [ -z "${LOAD_ADDR}" ]; then
717a524b379SJoseph Chen		echo "ERROR: No CONFIG_SYS_TEXT_BASE for u-boot";
718a524b379SJoseph Chen		exit 1
719a524b379SJoseph Chen	fi
720a524b379SJoseph Chen
721b42d2103SJoseph Chen	${SCRIPT_UBOOT} --load ${LOAD_ADDR} ${PLAT_UBOOT_SIZE}
722b42d2103SJoseph Chen}
723b42d2103SJoseph Chen
724b42d2103SJoseph Chenfunction pack_loader_image()
725b42d2103SJoseph Chen{
726b42d2103SJoseph Chen	rm *_loader_*.bin -f
727b42d2103SJoseph Chen	cd ${RKBIN}
728b42d2103SJoseph Chen	${SCRIPT_LOADER} --ini ${INI_LOADER}
729b42d2103SJoseph Chen	cd -
730b42d2103SJoseph Chen	if [ -f ${RKBIN}/*_loader_*.bin ]; then
731b42d2103SJoseph Chen		mv ${RKBIN}/*_loader_*.bin ./
732b42d2103SJoseph Chen	fi
733b42d2103SJoseph Chen}
734b42d2103SJoseph Chen
735b42d2103SJoseph Chenfunction pack_trust_image()
736b42d2103SJoseph Chen{
737b42d2103SJoseph Chen	DRAM_BASE=`sed -n "/CONFIG_SYS_SDRAM_BASE=/s/CONFIG_SYS_SDRAM_BASE=//p" include/autoconf.mk|tr -d '\r'`
738b42d2103SJoseph Chen
739b42d2103SJoseph Chen	rm trust*.img -f
740b42d2103SJoseph Chen	cd ${RKBIN}
741b42d2103SJoseph Chen	if [ "${ARM64_TRUSTZONE}" == "y" ]; then
742b42d2103SJoseph Chen		${SCRIPT_ATF} --ini ${INI_TRUST} ${PLAT_SHA} ${PLAT_RSA} ${PLAT_TRUST_SIZE}
743b42d2103SJoseph Chen	else
744b42d2103SJoseph Chen		${SCRIPT_TOS} --ini ${INI_TRUST} --base ${DRAM_BASE} ${PLAT_TRUST_SIZE}
745b42d2103SJoseph Chen	fi
746b42d2103SJoseph Chen	cd -
747b42d2103SJoseph Chen	if [ -f ${RKBIN}/trust*.img ]; then
748b42d2103SJoseph Chen		mv ${RKBIN}/trust*.img ./
749b42d2103SJoseph Chen	fi
750b42d2103SJoseph Chen}
751b42d2103SJoseph Chen
752b42d2103SJoseph Chenfunction pack_fit_image()
753b42d2103SJoseph Chen{
7543a711d9cSJoseph Chen	# check host tools
7553a711d9cSJoseph Chen	if ! which dtc >/dev/null 2>&1 ; then
7563a711d9cSJoseph Chen		echo "ERROR: No 'dtc', please: apt-get install device-tree-compiler"
7573a711d9cSJoseph Chen		exit 1
7583a711d9cSJoseph Chen	fi
7593a711d9cSJoseph Chen
7603a711d9cSJoseph Chen	if [ "${ARM64_TRUSTZONE}" == "y" ]; then
7613a711d9cSJoseph Chen		if ! python -c "import elftools" ; then
7623a711d9cSJoseph Chen			echo "ERROR: No python 'pyelftools', please: pip install pyelftools"
7633a711d9cSJoseph Chen			exit 1
7643a711d9cSJoseph Chen		fi
7653a711d9cSJoseph Chen	fi
7663a711d9cSJoseph Chen
767b42d2103SJoseph Chen	# If we don't plan to have uboot in uboot.img in case of: SPL => Trust => Kernel, creating empty files.
768b42d2103SJoseph Chen	if [ "${ARG_NO_UBOOT}" == "y" ]; then
769b42d2103SJoseph Chen		rm u-boot-nodtb.bin u-boot.dtb -f
770b42d2103SJoseph Chen		touch u-boot-nodtb.bin u-boot.dtb
771b42d2103SJoseph Chen	fi
772b42d2103SJoseph Chen
7732d11b868SJoseph Chen	rm uboot.img trust*.img -rf
774*2a0b9372SJoseph Chen	${SCRIPT_FIT} ${ARG_LIST_FIT} --chip ${RKCHIP_LABEL}
7752d11b868SJoseph Chen
7766b7fba58SJoseph Chen	if [ "${ARM64_TRUSTZONE}" == "y" ]; then
777cab35d60SJoseph Chen		if ! fdtget -l uboot.img /images/atf-1 >/dev/null 2>&1 ; then
7786b7fba58SJoseph Chen			echo -e "\nERROR: Invalid uboot.img, please install: \"pip install pyelftools\""
7796b7fba58SJoseph Chen			echo
7806b7fba58SJoseph Chen			exit 1
7816b7fba58SJoseph Chen		fi
7826b7fba58SJoseph Chen	fi
7836b7fba58SJoseph Chen
784173e789eSJoseph Chen	rm ${REP_DIR} -rf
785b42d2103SJoseph Chen	echo "pack uboot.img okay! Input: ${INI_TRUST}"
786b42d2103SJoseph Chen}
787b42d2103SJoseph Chen
788b6e67ca8SJoseph Chenfunction handle_args_late()
789b6e67ca8SJoseph Chen{
790b42b4e11SJoseph Chen	ARG_LIST_FIT="${ARG_LIST_FIT} --ini-trust ${INI_TRUST} --ini-loader ${INI_LOADER}"
791b6e67ca8SJoseph Chen}
792b6e67ca8SJoseph Chen
793b42d2103SJoseph Chenfunction clean_files()
794de9a6cd2SJoseph Chen{
795b42d2103SJoseph Chen	rm spl/u-boot-spl.dtb tpl/u-boot-tpl.dtb u-boot.dtb -f
796b42d2103SJoseph Chen	rm spl/u-boot-spl tpl/u-boot-tpl u-boot -f
7978f53a15cSJoseph Chen}
7988f53a15cSJoseph Chen
7998f53a15cSJoseph Chenfunction pack_images()
8008f53a15cSJoseph Chen{
8012d11b868SJoseph Chen	if [ "${ARG_RAW_COMPILE}" != "y" ]; then
8022d11b868SJoseph Chen		if [ "${PLAT_TYPE}" == "FIT" ]; then
8032d11b868SJoseph Chen			pack_fit_image ${ARG_LIST_FIT}
8042d11b868SJoseph Chen		else
8058f53a15cSJoseph Chen			pack_uboot_image
8068f53a15cSJoseph Chen			pack_trust_image
8078f53a15cSJoseph Chen			pack_loader_image
8082d11b868SJoseph Chen		fi
8098f53a15cSJoseph Chen	fi
8108f53a15cSJoseph Chen}
8118f53a15cSJoseph Chen
8127c3ca500SJoseph Chenfunction finish()
81330b04afcSJoseph Chen{
81430b04afcSJoseph Chen	echo
815b42b4e11SJoseph Chen	if [ "${ARG_BOARD}" == "" ]; then
8165202fe1fSJoseph Chen		echo "Platform ${RKCHIP_LABEL} is build OK, with exist .config"
81730b04afcSJoseph Chen	else
818124e8c09SJoseph Chen		echo "Platform ${RKCHIP_LABEL} is build OK, with new .config(${MAKE_CMD})"
81930b04afcSJoseph Chen	fi
82030b04afcSJoseph Chen}
82130b04afcSJoseph Chen
822b768b915SJoseph Chenprocess_args $*
823cd7ae718SJoseph Chenprepare
8247c2526e9SJoseph Chenselect_toolchain
825de440615SJoseph Chenselect_chip_info
82641cf5e5aSJoseph Chenfixup_platform_configure
827b768b915SJoseph Chenselect_ini_file
828b6e67ca8SJoseph Chenhandle_args_late
8290ff0e214SJoseph Chensub_commands
8308f53a15cSJoseph Chenclean_files
831df4d86e5SJoseph Chenmake PYTHON=python2 CROSS_COMPILE=${TOOLCHAIN_GCC} all --jobs=${JOB}
8328f53a15cSJoseph Chenpack_images
83330b04afcSJoseph Chenfinish
834