xref: /rk3399_rockchip-uboot/make.sh (revision 24ea65e699e0a7aa3a33a35faaa6309ee52a17f3)
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
13fb90bd1dSJoseph Chen########################################### User can modify #############################################
14bc98b3c8SJoseph ChenRKBIN_TOOLS=../rkbin/tools
15c6439a46SJoseph ChenCROSS_COMPILE_ARM32=../prebuilts/gcc/linux-x86/arm/gcc-linaro-6.3.1-2017.05-x86_64_arm-linux-gnueabihf/bin/arm-linux-gnueabihf-
16c6439a46SJoseph ChenCROSS_COMPILE_ARM64=../prebuilts/gcc/linux-x86/aarch64/gcc-linaro-6.3.1-2017.05-x86_64_aarch64-linux-gnu/bin/aarch64-linux-gnu-
17fb90bd1dSJoseph Chen########################################### User not touch #############################################
18de440615SJoseph Chen# Declare global INI file searching index name for every chip, update in select_chip_info()
19bc3a22a7SJoseph ChenRKCHIP=
20bc3a22a7SJoseph ChenRKCHIP_LABEL=
21bc3a22a7SJoseph ChenRKCHIP_LOADER=
22bc3a22a7SJoseph ChenRKCHIP_TRUST=
23b768b915SJoseph ChenINI_TRUST=
24b768b915SJoseph ChenINI_LOADER=
25b768b915SJoseph Chen
2623ba6841SJoseph Chen# Declare rkbin repository path, updated in prepare()
27fb90bd1dSJoseph ChenRKBIN=
28fb90bd1dSJoseph Chen
29fb90bd1dSJoseph Chen# Declare global toolchain path for CROSS_COMPILE, updated in select_toolchain()
30c6439a46SJoseph ChenTOOLCHAIN=
31b42d2103SJoseph ChenTOOLCHAIN_NM=
32fb90bd1dSJoseph ChenTOOLCHAIN_OBJDUMP=
3353ea5791SJoseph ChenTOOLCHAIN_ADDR2LINE=
34fb90bd1dSJoseph Chen
3541cf5e5aSJoseph Chen# Declare global plaform configure, updated in fixup_platform_configure()
36b42d2103SJoseph ChenPLAT_RSA=
37b42d2103SJoseph ChenPLAT_SHA=
38b42d2103SJoseph ChenPLAT_UBOOT_SIZE=
39b42d2103SJoseph ChenPLAT_TRUST_SIZE=
40b42d2103SJoseph ChenPLAT_TYPE="RKFW" # default
41b42d2103SJoseph Chen
42b42d2103SJoseph ChenSRCTREE=`pwd`
43ae33e311SJoseph ChenSCRIPT_FIT="${SRCTREE}/scripts/fit.sh"
44b8043f48SJoseph Chen
45b42d2103SJoseph ChenSCRIPT_ATF="${SRCTREE}/scripts/atf.sh"
46b42d2103SJoseph ChenSCRIPT_TOS="${SRCTREE}/scripts/tos.sh"
47b42d2103SJoseph ChenSCRIPT_SPL="${SRCTREE}/scripts/spl.sh"
48b42d2103SJoseph ChenSCRIPT_UBOOT="${SRCTREE}/scripts/uboot.sh"
49b42d2103SJoseph ChenSCRIPT_LOADER="${SRCTREE}/scripts/loader.sh"
50b9fb3edaSJoseph ChenSCRIPT_DECOMP="${SRCTREE}/scripts/decomp.sh"
51942378a0SJoseph ChenSCRIPT_CHECKCONFIG="${SRCTREE}/scripts/check-rkconfig.sh"
52c6439a46SJoseph ChenCC_FILE=".cc"
53173e789eSJoseph ChenREP_DIR="./rep"
54fb90bd1dSJoseph Chen#########################################################################################################
557c3ca500SJoseph Chenfunction help()
56b6255198SJoseph Chen{
57b6255198SJoseph Chen	echo
586a764259SJoseph Chen	echo "Usage:"
59b768b915SJoseph Chen	echo "	./make.sh [board|sub-command]"
606a764259SJoseph Chen	echo
616a764259SJoseph Chen	echo "	 - board:        board name of defconfig"
62b42d2103SJoseph Chen	echo "	 - sub-command:  elf*|loader|trust|uboot|--spl|--tpl|itb|map|sym|<addr>"
63b42d2103SJoseph Chen	echo "	 - ini:          ini file to pack trust/loader"
64f3d60245SJoseph Chen	echo
65f3d60245SJoseph Chen	echo "Output:"
66f3d60245SJoseph Chen	echo "	 When board built okay, there are uboot/trust/loader images in current directory"
67b6255198SJoseph Chen	echo
68b6255198SJoseph Chen	echo "Example:"
69b6255198SJoseph Chen	echo
70d6821889SJoseph Chen	echo "1. Build:"
71fc99e044SJoseph Chen	echo "	./make.sh evb-rk3399               --- build for evb-rk3399_defconfig"
72fc99e044SJoseph Chen	echo "	./make.sh firefly-rk3288           --- build for firefly-rk3288_defconfig"
73622ccf34SJoseph Chen	echo "	./make.sh EXT_DTB=rk-kernel.dtb    --- build with exist .config and external dtb"
74fc99e044SJoseph Chen	echo "	./make.sh                          --- build with exist .config"
75398d3e80SJoseph Chen	echo "	./make.sh env                      --- build envtools"
76b6255198SJoseph Chen	echo
77d6821889SJoseph Chen	echo "2. Pack:"
786a764259SJoseph Chen	echo "	./make.sh uboot                    --- pack uboot.img"
7969cce37bSJoseph Chen	echo "	./make.sh trust                    --- pack trust.img"
80f3d60245SJoseph Chen	echo "	./make.sh trust <ini>              --- pack trust img with assigned ini file"
816a764259SJoseph Chen	echo "	./make.sh loader                   --- pack loader bin"
82f3d60245SJoseph Chen	echo "	./make.sh loader <ini>             --- pack loader img with assigned ini file"
83b42d2103SJoseph Chen	echo "	./make.sh --spl                    --- pack loader with u-boot-spl.bin"
84b42d2103SJoseph Chen	echo "	./make.sh --tpl                    --- pack loader with u-boot-tpl.bin"
85b42d2103SJoseph Chen	echo "	./make.sh --tpl --spl              --- pack loader with u-boot-tpl.bin and u-boot-spl.bin"
86b6255198SJoseph Chen	echo
87d6821889SJoseph Chen	echo "3. Debug:"
88b6255198SJoseph Chen	echo "	./make.sh elf                      --- dump elf file with -D(default)"
89b6255198SJoseph Chen	echo "	./make.sh elf-S                    --- dump elf file with -S"
906a764259SJoseph Chen	echo "	./make.sh elf-d                    --- dump elf file with -d"
91f3d60245SJoseph Chen	echo "	./make.sh elf-*                    --- dump elf file with -*"
92b42d2103SJoseph Chen	echo "	./make.sh <no reloc_addr>          --- unwind address(no relocated)"
93b42d2103SJoseph Chen	echo "	./make.sh <reloc_addr-reloc_off>   --- unwind address(relocated)"
94b6255198SJoseph Chen	echo "	./make.sh map                      --- cat u-boot.map"
95b6255198SJoseph Chen	echo "	./make.sh sym                      --- cat u-boot.sym"
96b6255198SJoseph Chen}
9741cf5e5aSJoseph Chen
98caaf32e4SJoseph Chenfunction filt_val()
99caaf32e4SJoseph Chen{
100caaf32e4SJoseph Chen	sed -n "/${1}=/s/${1}=//p" $2 | tr -d '\r' | tr -d '"'
101caaf32e4SJoseph Chen}
102caaf32e4SJoseph Chen
1037c3ca500SJoseph Chenfunction prepare()
104cd7ae718SJoseph Chen{
105bc98b3c8SJoseph Chen	if [ -d ${RKBIN_TOOLS} ]; then
106bc98b3c8SJoseph Chen		absolute_path=$(cd `dirname ${RKBIN_TOOLS}`; pwd)
107bc98b3c8SJoseph Chen		RKBIN=${absolute_path}
108cd7ae718SJoseph Chen	else
109b768b915SJoseph Chen		echo "ERROR: No ../rkbin repository"
110cd7ae718SJoseph Chen		exit 1
111cd7ae718SJoseph Chen	fi
11269b6e590SJoseph Chen
1137c3ca500SJoseph Chen	if grep -Eq ''^CONFIG_ARM64=y'|'^CONFIG_ARM64_BOOT_AARCH32=y'' .config ; then
1147c3ca500SJoseph Chen		ARM64_TRUSTZONE="y"
1157c3ca500SJoseph Chen	fi
1167c3ca500SJoseph Chen
11769b6e590SJoseph Chen	if grep  -q '^CONFIG_ROCKCHIP_FIT_IMAGE_PACK=y' .config ; then
118b42d2103SJoseph Chen		PLAT_TYPE="FIT"
119b9fb3edaSJoseph Chen	elif grep  -q '^CONFIG_SPL_DECOMP_HEADER=y' .config ; then
120b9fb3edaSJoseph Chen		PLAT_TYPE="DECOMP"
121b768b915SJoseph Chen	fi
122b768b915SJoseph Chen}
123b768b915SJoseph Chen
124b768b915SJoseph Chenfunction process_args()
125b768b915SJoseph Chen{
126b768b915SJoseph Chen	while [ $# -gt 0 ]; do
127b768b915SJoseph Chen		case $1 in
128b42d2103SJoseph Chen			*help|--h|-h)
129b768b915SJoseph Chen				help
130b768b915SJoseph Chen				exit 0
131b768b915SJoseph Chen				;;
132c6439a46SJoseph Chen			CROSS_COMPILE=*)  # set CROSS_COMPILE
133c6439a46SJoseph Chen				ARG_COMPILE="y"
134c6439a46SJoseph Chen				CROSS_COMPILE_ARM32=${1#*=}
135c6439a46SJoseph Chen				CROSS_COMPILE_ARM64=${1#*=}
136c6439a46SJoseph Chen				if [ ${CMD_ARGS} == $1 ]; then
137c6439a46SJoseph Chen					shift 1
138c6439a46SJoseph Chen					CMD_ARGS=$1
139c6439a46SJoseph Chen				else
140c6439a46SJoseph Chen					shift 1
141c6439a46SJoseph Chen				fi
142c6439a46SJoseph Chen				;;
143b42d2103SJoseph Chen			# '': build with exist .config
144b42d2103SJoseph Chen			# loader|trust|uboot: pack image
145b42d2103SJoseph Chen			# debug*|map|sym|elf*|nm: debug command
146b42d2103SJoseph Chen			# env: build env tool
147b42d2103SJoseph Chen			# itb: pack itb image
148b42d2103SJoseph Chen			# fit: pack non-secure uboot.img && boot.img
149b42d2103SJoseph Chen			''|loader|trust|uboot|debug*|itb|env|fit|map|sym|elf*|nm)
150b42b4e11SJoseph Chen				if [ "$2" == "spl" -o "$2" == "tpl" ]; then
151b42d2103SJoseph Chen					ARG_TSPL=$2
152b768b915SJoseph Chen					shift 1
153b768b915SJoseph Chen				fi
154b768b915SJoseph Chen				shift 1
155b768b915SJoseph Chen				;;
156b42d2103SJoseph Chen			# trust/loader ini files for packing trust.img/loader.img
157b42d2103SJoseph Chen			*.ini|*.INI)
158b768b915SJoseph Chen				if [ ! -f $1 ]; then
159b768b915SJoseph Chen					echo "ERROR: No $1"
160b768b915SJoseph Chen				fi
161b768b915SJoseph Chen				if grep -q 'CODE471_OPTION' $1 ; then
162b768b915SJoseph Chen					ARG_INI_LOADER=$1
163b768b915SJoseph Chen				elif grep -Eq ''BL31_OPTION'|'TOS'' $1 ; then
164b768b915SJoseph Chen					ARG_INI_TRUST=$1
165b768b915SJoseph Chen				fi
166b768b915SJoseph Chen				shift 1
167b768b915SJoseph Chen				;;
168b42d2103SJoseph Chen			--sz-trust) # set trust size
169b42d2103SJoseph Chen				ARG_TRUST_SIZE="--size $2 $3"
170b42d2103SJoseph Chen				shift 3
171b42d2103SJoseph Chen				;;
172b42d2103SJoseph Chen			--sz-uboot) # set uboot size
173b42d2103SJoseph Chen				ARG_UBOOT_SIZE="--size $2 $3"
174b42d2103SJoseph Chen				shift 3
175b42d2103SJoseph Chen				;;
1762d11b868SJoseph Chen			--raw-compile)  # FIT: build but not pack image
1772d11b868SJoseph Chen				ARG_RAW_COMPILE="y"
178b42d2103SJoseph Chen				shift 1
179b42d2103SJoseph Chen				;;
180b42d2103SJoseph Chen			--no-uboot) # FIT: pack uboot.img without u-boot
181b42d2103SJoseph Chen				ARG_NO_UBOOT="y"
182b42d2103SJoseph Chen				shift 1
183b42d2103SJoseph Chen				;;
184a505e63bSJoseph Chen			--idblock)  # pack idblock.bin
185a505e63bSJoseph Chen				shift 1
186a505e63bSJoseph Chen				;;
187b42d2103SJoseph Chen			--tpl|tpl)  # use tpl file
188b42d2103SJoseph Chen				ARG_TPL_BIN="tpl/u-boot-tpl.bin"
189b42d2103SJoseph Chen				shift 1
190b42d2103SJoseph Chen				;;
191b42d2103SJoseph Chen			--spl|spl*) # use spl file
192b42d2103SJoseph Chen				ARG_SPL_BIN="spl/u-boot-spl.bin"
193b42d2103SJoseph Chen				shift 1
194b42d2103SJoseph Chen				;;
195ed86ec4fSJoseph Chen			--spl-fwver)
1966af0d055SJoseph Chen				ARG_FIT_FWVER="${ARG_FIT_FWVER} --spl-fwver $2"
197ed86ec4fSJoseph Chen				ARG_SPL_FWVER="SPL_FWVER=$2"
198ed86ec4fSJoseph Chen				shift 2
199ed86ec4fSJoseph Chen				;;
200ed86ec4fSJoseph Chen			--fwver)
2016af0d055SJoseph Chen				ARG_FIT_FWVER="${ARG_FIT_FWVER} --fwver $2"
202ed86ec4fSJoseph Chen				ARG_FWVER="FWVER=$2"
203ed86ec4fSJoseph Chen				shift 2
204ed86ec4fSJoseph Chen				;;
205173e789eSJoseph Chen			--uboot|--fdt|--optee|--mcu|--bl31) # uboot.img components
206173e789eSJoseph Chen				mkdir -p ${REP_DIR}
207173e789eSJoseph Chen				if [ ! -f $2 ]; then
208173e789eSJoseph Chen					echo "ERROR: No $2"
209173e789eSJoseph Chen					exit 1
210173e789eSJoseph Chen				fi
211173e789eSJoseph Chen				if [ "$1" == "--uboot" ]; then
212173e789eSJoseph Chen					cp $2 ${REP_DIR}/u-boot-nodtb.bin
213173e789eSJoseph Chen				elif [ "$1" == "--fdt" ]; then
214173e789eSJoseph Chen					cp $2 ${REP_DIR}/u-boot.dtb
215173e789eSJoseph Chen				elif [ "$1" == "--optee" ]; then
216173e789eSJoseph Chen					cp $2 ${REP_DIR}/tee.bin
217173e789eSJoseph Chen				elif [ "$1" == "--mcu" ]; then
218173e789eSJoseph Chen					cp $2 ${REP_DIR}/mcu.bin
219173e789eSJoseph Chen				elif [ "$1" == "--bl31" ]; then
220173e789eSJoseph Chen					if ! file $2 | grep 'ELF ' >/dev/null 2>&1 ; then
221173e789eSJoseph Chen						echo "ERROR: $2 is not a bl31.elf file"
222173e789eSJoseph Chen						exit 1
223173e789eSJoseph Chen					fi
224173e789eSJoseph Chen					cp $2 ${REP_DIR}/bl31.elf
225173e789eSJoseph Chen				fi
226173e789eSJoseph Chen				shift 2
227173e789eSJoseph Chen				;;
228b768b915SJoseph Chen			*)
229b42d2103SJoseph Chen				#1. FIT scripts args
2302d11b868SJoseph Chen				NUM=$(${SCRIPT_FIT} --args $1)
231b42b4e11SJoseph Chen				if  [ ${NUM} -ne 0 ]; then
232b42b4e11SJoseph Chen					[ ${NUM} -eq 1 ] && ARG_LIST_FIT="${ARG_LIST_FIT} $1"
233b42b4e11SJoseph Chen					[ ${NUM} -eq 2 ] && ARG_LIST_FIT="${ARG_LIST_FIT} $1 $2"
2341ff581bbSJoseph Chen					shift ${NUM}
2351ff581bbSJoseph Chen					continue
236b42d2103SJoseph Chen				#2. unwind function address
2371ff581bbSJoseph Chen				elif [ -z $(echo $1 | sed 's/[0-9,a-f,A-F,x,X,-]//g') ]; then
238b768b915SJoseph Chen					ARG_FUNCADDR=$1
239b42d2103SJoseph Chen				#3. make defconfig
240b768b915SJoseph Chen				else
241b768b915SJoseph Chen					ARG_BOARD=$1
242124e8c09SJoseph Chen					if [ ! -f configs/${ARG_BOARD}_defconfig -a ! -f configs/${ARG_BOARD}.config ]; then
243b768b915SJoseph Chen						echo -e "\n${SUPPORT_LIST}\n"
244b768b915SJoseph Chen						echo "ERROR: No configs/${ARG_BOARD}_defconfig"
245b768b915SJoseph Chen						exit 1
246124e8c09SJoseph Chen					elif [ -f configs/${ARG_BOARD}.config ]; then
247caaf32e4SJoseph Chen						BASE1_DEFCONFIG=`filt_val "CONFIG_BASE_DEFCONFIG" configs/${ARG_BOARD}.config`
248caaf32e4SJoseph Chen						BASE0_DEFCONFIG=`filt_val "CONFIG_BASE_DEFCONFIG" configs/${BASE1_DEFCONFIG}`
2491df865f3SJoseph Chen						MAKE_CMD="make ${BASE0_DEFCONFIG} ${BASE1_DEFCONFIG} ${ARG_BOARD}.config -j${JOB}"
250124e8c09SJoseph Chen						echo "## ${MAKE_CMD}"
2511df865f3SJoseph Chen						make ${BASE0_DEFCONFIG} ${BASE1_DEFCONFIG} ${ARG_BOARD}.config ${OPTION}
252c6439a46SJoseph Chen						rm -f ${CC_FILE}
253b768b915SJoseph Chen					else
254124e8c09SJoseph Chen						MAKE_CMD="make ${ARG_BOARD}_defconfig -j${JOB}"
255124e8c09SJoseph Chen						echo "## ${MAKE_CMD}"
256124e8c09SJoseph Chen						make ${ARG_BOARD}_defconfig ${OPTION}
257c6439a46SJoseph Chen						rm -f ${CC_FILE}
258b768b915SJoseph Chen					fi
259b768b915SJoseph Chen				fi
260b768b915SJoseph Chen				shift 1
261b768b915SJoseph Chen				;;
262b768b915SJoseph Chen		esac
263b768b915SJoseph Chen	done
264b768b915SJoseph Chen
265b768b915SJoseph Chen	if [ ! -f .config ]; then
266b768b915SJoseph Chen		echo
267b768b915SJoseph Chen		echo "ERROR: No .config"
268b768b915SJoseph Chen		help
269b768b915SJoseph Chen		exit 1
27069b6e590SJoseph Chen	fi
27130b04afcSJoseph Chen}
2727c2526e9SJoseph Chen
2737c3ca500SJoseph Chenfunction select_toolchain()
27427a50c86SAndy Yan{
275c6439a46SJoseph Chen	# If no outer CROSS_COMPILE, look for it from CC_FILE.
276c6439a46SJoseph Chen	if [ "${ARG_COMPILE}" != "y" ]; then
277c6439a46SJoseph Chen		if [ -f ${CC_FILE} ]; then
278c6439a46SJoseph Chen			CROSS_COMPILE_ARM32=`cat ${CC_FILE}`
279c6439a46SJoseph Chen			CROSS_COMPILE_ARM64=`cat ${CC_FILE}`
280c6439a46SJoseph Chen		else
281d6821889SJoseph Chen			if grep -q '^CONFIG_ARM64=y' .config ; then
282c6439a46SJoseph Chen				CROSS_COMPILE_ARM64=$(cd `dirname ${CROSS_COMPILE_ARM64}`; pwd)"/aarch64-linux-gnu-"
283bc98b3c8SJoseph Chen			else
284c6439a46SJoseph Chen				CROSS_COMPILE_ARM32=$(cd `dirname ${CROSS_COMPILE_ARM32}`; pwd)"/arm-linux-gnueabihf-"
285c6439a46SJoseph Chen			fi
286c6439a46SJoseph Chen		fi
287c6439a46SJoseph Chen	fi
288c6439a46SJoseph Chen
289c6439a46SJoseph Chen	if grep -q '^CONFIG_ARM64=y' .config ; then
290c6439a46SJoseph Chen		TOOLCHAIN=${CROSS_COMPILE_ARM64}
291c6439a46SJoseph Chen		TOOLCHAIN_NM=${CROSS_COMPILE_ARM64}nm
292c6439a46SJoseph Chen		TOOLCHAIN_OBJDUMP=${CROSS_COMPILE_ARM64}objdump
293c6439a46SJoseph Chen		TOOLCHAIN_ADDR2LINE=${CROSS_COMPILE_ARM64}addr2line
294c6439a46SJoseph Chen	else
295c6439a46SJoseph Chen		TOOLCHAIN=${CROSS_COMPILE_ARM32}
296c6439a46SJoseph Chen		TOOLCHAIN_NM=${CROSS_COMPILE_ARM32}nm
297c6439a46SJoseph Chen		TOOLCHAIN_OBJDUMP=${CROSS_COMPILE_ARM32}objdump
298c6439a46SJoseph Chen		TOOLCHAIN_ADDR2LINE=${CROSS_COMPILE_ARM32}addr2line
299c6439a46SJoseph Chen	fi
300c6439a46SJoseph Chen
301b9cfcfe6SJoseph Chen	if [ ! `which ${TOOLCHAIN}gcc` ]; then
302c6439a46SJoseph Chen		echo "ERROR: No find ${TOOLCHAIN}gcc"
303bc98b3c8SJoseph Chen		exit 1
30427a50c86SAndy Yan	fi
305c6439a46SJoseph Chen
306c6439a46SJoseph Chen	# save to CC_FILE
307c6439a46SJoseph Chen	if [ "${ARG_COMPILE}" == "y" ]; then
308c6439a46SJoseph Chen		echo "${TOOLCHAIN}" > ${CC_FILE}
30927a50c86SAndy Yan	fi
310bc98b3c8SJoseph Chen}
311bc98b3c8SJoseph Chen
312b42b4e11SJoseph Chen#
313de440615SJoseph Chen# We select chip info to do:
314de440615SJoseph Chen#	1. RKCHIP:        fixup platform configure
315de440615SJoseph Chen#	2. RKCHIP_LOADER: search ini file to pack loader
316de440615SJoseph Chen#	3. RKCHIP_TRUST:  search ini file to pack trust
317de440615SJoseph Chen#	4. RKCHIP_LABEL:  show build message
318de440615SJoseph Chen#
3197c3ca500SJoseph Chenfunction select_chip_info()
320bc98b3c8SJoseph Chen{
321de440615SJoseph Chen	# Read RKCHIP firstly from .config
322596700d7SShunqian Zheng	# The regular expression that matching:
323596700d7SShunqian Zheng	#  - PX30, PX3SE
324596700d7SShunqian Zheng	#  - RK????, RK????X
325596700d7SShunqian Zheng	#  - RV????
3263a6d3179SXuhui Lin	CHIP_PATTERN='^CONFIG_ROCKCHIP_[R,P][X,V,K][0-9ESXB]{1,5}'
327b42d2103SJoseph Chen	RKCHIP=`egrep -o ${CHIP_PATTERN} .config`
328d443b7d5SJoseph Chen
3290583701dSJoseph Chen	# default
330d443b7d5SJoseph Chen	RKCHIP=${RKCHIP##*_}
3310583701dSJoseph Chen	RKCHIP_LOADER=${RKCHIP}
3320583701dSJoseph Chen	RKCHIP_TRUST=${RKCHIP}
333caaf32e4SJoseph Chen	RKCHIP_LABEL=`filt_val "CONFIG_CHIP_NAME" .config`
334bc3a22a7SJoseph Chen	if [ -z "${RKCHIP_LABEL}" ]; then
3350583701dSJoseph Chen		RKCHIP_LABEL=${RKCHIP}
3360583701dSJoseph Chen	fi
3370583701dSJoseph Chen}
3380583701dSJoseph Chen
33907d90e77SJoseph Chen# Priority: default < CHIP_CFG_FIXUP_TABLE() < make.sh args
3400583701dSJoseph Chenfunction fixup_platform_configure()
3410583701dSJoseph Chen{
342caaf32e4SJoseph Chen	U_KB=`filt_val "CONFIG_UBOOT_SIZE_KB" .config`
343caaf32e4SJoseph Chen	U_NUM=`filt_val "CONFIG_UBOOT_NUM" .config`
344caaf32e4SJoseph Chen	T_KB=`filt_val "CONFIG_TRUST_SIZE_KB" .config`
345caaf32e4SJoseph Chen	T_NUM=`filt_val "CONFIG_TRUST_NUM" .config`
346caaf32e4SJoseph Chen	SHA=`filt_val "CONFIG_TRUST_SHA_MODE" .config`
347caaf32e4SJoseph Chen	RSA=`filt_val "CONFIG_TRUST_RSA_MODE" .config`
3480583701dSJoseph Chen
349bc3a22a7SJoseph Chen	# .config
350b42d2103SJoseph Chen	PLAT_UBOOT_SIZE="--size ${U_KB} ${U_NUM}"
351b42d2103SJoseph Chen	PLAT_TRUST_SIZE="--size ${T_KB} ${T_NUM}"
352bc3a22a7SJoseph Chen	PLAT_SHA="--sha ${SHA}"
353bc3a22a7SJoseph Chen	PLAT_RSA="--rsa ${RSA}"
35407d90e77SJoseph Chen
355bc3a22a7SJoseph Chen	# ./make.sh args
35607d90e77SJoseph Chen	if [ ! -z "${ARG_UBOOT_SIZE}" ]; then
357b42d2103SJoseph Chen		PLAT_UBOOT_SIZE=${ARG_UBOOT_SIZE}
35807d90e77SJoseph Chen	fi
35907d90e77SJoseph Chen	if [ ! -z "${ARG_TRUST_SIZE}" ]; then
360b42d2103SJoseph Chen		PLAT_TRUST_SIZE=${ARG_TRUST_SIZE}
36107d90e77SJoseph Chen	fi
362b768b915SJoseph Chen}
363b768b915SJoseph Chen
364b768b915SJoseph Chenfunction select_ini_file()
365b768b915SJoseph Chen{
366b768b915SJoseph Chen	# default
367b768b915SJoseph Chen	INI_LOADER=${RKBIN}/RKBOOT/${RKCHIP_LOADER}MINIALL.ini
368b42b4e11SJoseph Chen	if [ "${ARM64_TRUSTZONE}" == "y" ]; then
369b768b915SJoseph Chen		INI_TRUST=${RKBIN}/RKTRUST/${RKCHIP_TRUST}TRUST.ini
370b768b915SJoseph Chen	else
371b768b915SJoseph Chen		INI_TRUST=${RKBIN}/RKTRUST/${RKCHIP_TRUST}TOS.ini
37241cf5e5aSJoseph Chen	fi
37341cf5e5aSJoseph Chen
374496a6e1eSJoseph Chen	# defconfig
375caaf32e4SJoseph Chen	NAME=`filt_val "CONFIG_LOADER_INI" .config`
376496a6e1eSJoseph Chen	if [ ! -z "${NAME}" ]; then
377496a6e1eSJoseph Chen		INI_LOADER=${RKBIN}/RKBOOT/${NAME}
378496a6e1eSJoseph Chen	fi
379caaf32e4SJoseph Chen	NAME=`filt_val "CONFIG_TRUST_INI" .config`
380496a6e1eSJoseph Chen	if [ ! -z "${NAME}" ]; then
381496a6e1eSJoseph Chen		INI_TRUST=${RKBIN}/RKTRUST/${NAME}
382496a6e1eSJoseph Chen	fi
383496a6e1eSJoseph Chen
384b768b915SJoseph Chen	# args
385b42d2103SJoseph Chen	if [ ! -z "${ARG_INI_TRUST}" ]; then
386b42b4e11SJoseph Chen		INI_TRUST=${ARG_INI_TRUST}
387b768b915SJoseph Chen	fi
388b42d2103SJoseph Chen	if [ ! -z "${ARG_INI_LOADER}" ]; then
389b42b4e11SJoseph Chen		INI_LOADER=${ARG_INI_LOADER}
390b768b915SJoseph Chen	fi
39127a50c86SAndy Yan}
392de9a6cd2SJoseph Chen
393b42d2103SJoseph Chenfunction sub_commands()
394b42d2103SJoseph Chen{
395b42d2103SJoseph Chen	# skip "--" parameter, such as "--rollback-index-..."
396b42d2103SJoseph Chen	if [[ ${CMD_ARGS} != --* ]]; then
397b42d2103SJoseph Chen		CMD=${CMD_ARGS%-*}
398b42d2103SJoseph Chen		ARG=${CMD_ARGS#*-}
399b42d2103SJoseph Chen	else
400b42d2103SJoseph Chen		CMD=${CMD_ARGS}
401b42d2103SJoseph Chen	fi
402b42d2103SJoseph Chen
403b42d2103SJoseph Chen	if [ "${ARG_TSPL}" == "tpl" -o "${ARG_TSPL}" == "spl" ]; then
404b42d2103SJoseph Chen		ELF=`find -name u-boot-${ARG_TSPL}`
405b42d2103SJoseph Chen		MAP=`find -name u-boot-${ARG_TSPL}.map`
406b42d2103SJoseph Chen		SYM=`find -name u-boot-${ARG_TSPL}.sym`
407b42d2103SJoseph Chen	else
408b42d2103SJoseph Chen		ELF=u-boot
409b42d2103SJoseph Chen		MAP=u-boot.map
410b42d2103SJoseph Chen		SYM=u-boot.sym
411b42d2103SJoseph Chen	fi
412b42d2103SJoseph Chen
413b42d2103SJoseph Chen	case ${CMD} in
414b42d2103SJoseph Chen		elf|nm)
415b42d2103SJoseph Chen			if [ "${CMD}" == "nm" ]; then
4169b6b8f53SJoseph Chen				echo -e "\n${ELF}:     file format elf\n"
417cdc0f037SJoseph Chen				${TOOLCHAIN_NM} -r --size ${ELF} | grep -iv 'b' | less
418b42d2103SJoseph Chen			else
419b42d2103SJoseph Chen				if [ "${CMD}" == "elf" -a "${ARG}" == "elf" ]; then
420b42d2103SJoseph Chen					ARG=D # default
421b42d2103SJoseph Chen				fi
422b42d2103SJoseph Chen				${TOOLCHAIN_OBJDUMP} -${ARG} ${ELF} | less
423b42d2103SJoseph Chen			fi
424b42d2103SJoseph Chen			exit 0
425b42d2103SJoseph Chen			;;
426b42d2103SJoseph Chen		map|sym)
427b42d2103SJoseph Chen			if [ ${CMD} == "map" ]; then
428b42d2103SJoseph Chen				cat ${MAP} | less
429b42d2103SJoseph Chen			else
430b42d2103SJoseph Chen				cat ${SYM} | less
431b42d2103SJoseph Chen			fi
432b42d2103SJoseph Chen			exit 0
433b42d2103SJoseph Chen			;;
434b42d2103SJoseph Chen		debug)
435b42d2103SJoseph Chen			./scripts/rkpatch.sh ${ARG}
436b42d2103SJoseph Chen			exit 0
437b42d2103SJoseph Chen			;;
438b42d2103SJoseph Chen		fit)
439b42d2103SJoseph Chen			# Non-secure
4402d11b868SJoseph Chen			${SCRIPT_FIT} --boot_img_dir images/ ${ARG_LIST_FIT}
441b42d2103SJoseph Chen			exit 0
442b42d2103SJoseph Chen			;;
443b42d2103SJoseph Chen		uboot)
444b42d2103SJoseph Chen			pack_uboot_image
445b42d2103SJoseph Chen			exit 0
446b42d2103SJoseph Chen			;;
447b42d2103SJoseph Chen		trust)
448b42d2103SJoseph Chen			pack_trust_image
449b42d2103SJoseph Chen			exit 0
450b42d2103SJoseph Chen			;;
451b42d2103SJoseph Chen		loader)
452b42d2103SJoseph Chen			pack_loader_image
453b42d2103SJoseph Chen			exit 0
454b42d2103SJoseph Chen			;;
455b42d2103SJoseph Chen		itb)
456b42d2103SJoseph Chen			pack_uboot_itb_image
457b42d2103SJoseph Chen			exit 0
458b42d2103SJoseph Chen			;;
459b42d2103SJoseph Chen		env)
460c6439a46SJoseph Chen			make CROSS_COMPILE=${TOOLCHAIN} envtools
461b42d2103SJoseph Chen			exit 0
462b42d2103SJoseph Chen			;;
463a505e63bSJoseph Chen		--idblock)
464a505e63bSJoseph Chen			pack_idblock
465a505e63bSJoseph Chen			exit 0
466a505e63bSJoseph Chen			;;
467b42d2103SJoseph Chen		--tpl|--spl|tpl|spl)
468b42d2103SJoseph Chen			pack_spl_loader_image
469b42d2103SJoseph Chen			exit 0
470b42d2103SJoseph Chen			;;
471b42d2103SJoseph Chen		*)
472b42d2103SJoseph Chen			unwind_addr_or_continue
473b42d2103SJoseph Chen			;;
474b42d2103SJoseph Chen	esac
475b42d2103SJoseph Chen}
476b42d2103SJoseph Chen
477b42d2103SJoseph Chenfunction unwind_addr_or_continue()
478b42d2103SJoseph Chen{
479b42d2103SJoseph Chen	FUNCADDR=${ARG_FUNCADDR}
480b42d2103SJoseph Chen	RELOCOFF=${FUNCADDR#*-}
481b42d2103SJoseph Chen	FUNCADDR=${FUNCADDR%-*}
482b42d2103SJoseph Chen
483b42d2103SJoseph Chen	if [ -z $(echo ${FUNCADDR} | sed 's/[0-9,a-f,A-F,x,X,-]//g') ] && [ ${FUNCADDR} ]; then
484b42d2103SJoseph Chen		# With prefix: '0x' or '0X'
485b42d2103SJoseph Chen		if [ `echo ${FUNCADDR} | sed -n "/0[x,X]/p" | wc -l` -ne 0 ]; then
486b42d2103SJoseph Chen			FUNCADDR=`echo ${FUNCADDR} | awk '{ print strtonum($0) }'`
487b42d2103SJoseph Chen			FUNCADDR=`echo "obase=16;${FUNCADDR}"|bc | tr '[A-Z]' '[a-z]'`
488b42d2103SJoseph Chen		fi
489b42d2103SJoseph Chen		if [ `echo ${RELOCOFF} | sed -n "/0[x,X]/p" | wc -l` -ne 0 ] && [ ${RELOCOFF} ]; then
490b42d2103SJoseph Chen			RELOCOFF=`echo ${RELOCOFF} | awk '{ print strtonum($0) }'`
491b42d2103SJoseph Chen			RELOCOFF=`echo "obase=16;${RELOCOFF}"|bc | tr '[A-Z]' '[a-z]'`
492b42d2103SJoseph Chen		fi
493b42d2103SJoseph Chen
494b42d2103SJoseph Chen		# If reloc address is assigned, do sub
495b42d2103SJoseph Chen		if [ "${FUNCADDR}" != "${RELOCOFF}" ]; then
496b42d2103SJoseph Chen			# Hex -> Dec -> SUB -> Hex
497b42d2103SJoseph Chen			FUNCADDR=`echo $((16#${FUNCADDR}))`
498b42d2103SJoseph Chen			RELOCOFF=`echo $((16#${RELOCOFF}))`
499b42d2103SJoseph Chen			FUNCADDR=$((FUNCADDR-RELOCOFF))
500b42d2103SJoseph Chen			FUNCADDR=$(echo "obase=16;${FUNCADDR}"|bc | tr '[A-Z]' '[a-z]')
501b42d2103SJoseph Chen		fi
502b42d2103SJoseph Chen
503b42d2103SJoseph Chen		echo
504b42d2103SJoseph Chen		sed -n "/${FUNCADDR}/p" ${SYM}
505b42d2103SJoseph Chen		${TOOLCHAIN_ADDR2LINE} -e ${ELF} ${FUNCADDR}
506b42d2103SJoseph Chen		exit 0
507b42d2103SJoseph Chen	fi
508b42d2103SJoseph Chen}
509b42d2103SJoseph Chen
510a505e63bSJoseph Chenfunction pack_idblock()
511a505e63bSJoseph Chen{
512a505e63bSJoseph Chen	INI=${INI_LOADER}
513a505e63bSJoseph Chen	if [ ! -f ${INI} ]; then
514a505e63bSJoseph Chen		echo "ERROR: No ${INI}"
515a505e63bSJoseph Chen		exit 1
516a505e63bSJoseph Chen	fi
517a505e63bSJoseph Chen
518a505e63bSJoseph Chen	# chip
519a505e63bSJoseph Chen	COMMON_H=`grep "_common.h:" include/autoconf.mk.dep | awk -F "/" '{ printf $3 }'`
520a505e63bSJoseph Chen	PLAT=${COMMON_H%_*}
521a505e63bSJoseph Chen
522a505e63bSJoseph Chen	# file
523caaf32e4SJoseph Chen	SPL_BIN=${RKBIN}/`filt_val "FlashBoot" ${INI}`
524caaf32e4SJoseph Chen	TPL_BIN=${RKBIN}/`filt_val "FlashData" ${INI}`
525a505e63bSJoseph Chen	if [ ! -z "${ARG_SPL_BIN}" ]; then
526a505e63bSJoseph Chen		SPL_BIN=${ARG_SPL_BIN}
527a505e63bSJoseph Chen	fi
528a505e63bSJoseph Chen	if [ ! -z "${ARG_TPL_BIN}" ]; then
529a505e63bSJoseph Chen		TPL_BIN=${ARG_TPL_BIN}
530a505e63bSJoseph Chen	fi
531a505e63bSJoseph Chen
532a505e63bSJoseph Chen	# pack
533a505e63bSJoseph Chen	rm idblock.bin -f
534a505e63bSJoseph Chen	./tools/mkimage -n ${PLAT} -T rksd -d ${TPL_BIN}:${SPL_BIN} idblock.bin
535a505e63bSJoseph Chen	echo "Input:"
536a505e63bSJoseph Chen	echo "    ${INI}"
537a505e63bSJoseph Chen	echo "    ${TPL_BIN}"
538a505e63bSJoseph Chen	echo "    ${SPL_BIN}"
539a505e63bSJoseph Chen	echo
540a505e63bSJoseph Chen	echo "Pack ${PLAT} idblock.bin okay!"
541a505e63bSJoseph Chen	echo
542a505e63bSJoseph Chen}
543a505e63bSJoseph Chen
544b42d2103SJoseph Chenfunction pack_uboot_itb_image()
545b42d2103SJoseph Chen{
546b42d2103SJoseph Chen	INI=${INI_TRUST}
547b42d2103SJoseph Chen	if [ ! -f ${INI} ]; then
548b42d2103SJoseph Chen		echo "ERROR: No ${INI}"
549b42d2103SJoseph Chen		exit 1
550b42d2103SJoseph Chen	fi
551b42d2103SJoseph Chen
552b42d2103SJoseph Chen	if [ "${ARM64_TRUSTZONE}" == "y" ]; then
553b42d2103SJoseph Chen		BL31_ELF=`sed -n '/_bl31_/s/PATH=//p' ${INI} | tr -d '\r'`
554cb718016SJoseph Chen		BL32_BIN=`sed -n '/_bl32_/s/PATH=//p' ${INI} | tr -d '\r'`
555407bd0fbSJoseph Chen		rm bl31.elf tee.bin -rf
556b42d2103SJoseph Chen		cp ${RKBIN}/${BL31_ELF} bl31.elf
557cb718016SJoseph Chen		if grep BL32_OPTION -A 1 ${INI} | grep SEC=1 ; then
558cb718016SJoseph Chen			cp ${RKBIN}/${BL32_BIN} tee.bin
559cb718016SJoseph Chen			TEE_OFFSET=`grep BL32_OPTION -A 3 ${INI} | grep ADDR= | awk -F "=" '{ printf $2 }' | tr -d '\r'`
560cb718016SJoseph Chen			TEE_ARG="-t ${TEE_OFFSET}"
561cb718016SJoseph Chen		fi
562b42d2103SJoseph Chen	else
563b42d2103SJoseph Chen		# TOS
564caaf32e4SJoseph Chen		TOS=`filt_val "TOS" ${INI}`
565caaf32e4SJoseph Chen		TOSTA=`filt_val "TOSTA" ${INI}`
566b42d2103SJoseph Chen		if [ ! -z "${TOSTA}" ]; then
567b42d2103SJoseph Chen			cp ${RKBIN}/${TOSTA} tee.bin
568b42d2103SJoseph Chen		elif [ ! -z "${TOS}" ]; then
569b42d2103SJoseph Chen			cp ${RKBIN}/${TOS}   tee.bin
570b42d2103SJoseph Chen		else
571083ae6f2SJoseph Chen			echo "WARN: No tee bin"
572b42d2103SJoseph Chen		fi
573d3d48da7SJoseph Chen		if [ ! -z "${TOSTA}" -o ! -z "${TOS}" ]; then
574caaf32e4SJoseph Chen			TEE_OFFSET=`filt_val "ADDR" ${INI}`
575b42d2103SJoseph Chen			if [ "${TEE_OFFSET}" == "" ]; then
576b42d2103SJoseph Chen				TEE_OFFSET=0x8400000
577b42d2103SJoseph Chen			fi
578cb718016SJoseph Chen			TEE_ARG="-t ${TEE_OFFSET}"
57933e46123SJoseph Chen		fi
580d3d48da7SJoseph Chen	fi
581b42d2103SJoseph Chen
582*24ea65e6SJoseph Chen	# Inits
583*24ea65e6SJoseph Chen	for ((i=0; i<5; i++))
584*24ea65e6SJoseph Chen	do
585*24ea65e6SJoseph Chen		INIT_BIN="init${i}.bin"
586*24ea65e6SJoseph Chen		INIT_IDX="INIT${i}"
587*24ea65e6SJoseph Chen		ENABLED=`awk -F "," '/'${INIT_IDX}'=/  { printf $3 }' ${INI} | tr -d ' '`
588*24ea65e6SJoseph Chen		if [ "${ENABLED}" == "enabled" -o "${ENABLED}" == "okay" ]; then
589*24ea65e6SJoseph Chen			NAME=`awk -F "," '/'${INIT_IDX}'=/ { printf $1 }' ${INI} | tr -d ' ' | awk -F "=" '{ print $2 }'`
590*24ea65e6SJoseph Chen			OFFS=`awk -F "," '/'${INIT_IDX}'=/ { printf $2 }' ${INI} | tr -d ' '`
591*24ea65e6SJoseph Chen			cp ${RKBIN}/${NAME} ${INIT_BIN}
592*24ea65e6SJoseph Chen			if [ -z ${OFFS} ]; then
593*24ea65e6SJoseph Chen				echo "ERROR: No ${INIT_BIN} address in ${INI}"
594*24ea65e6SJoseph Chen				exit 1
595*24ea65e6SJoseph Chen			fi
596*24ea65e6SJoseph Chen			INIT_ARG=${INIT_ARG}" -i${i} ${OFFS}"
597*24ea65e6SJoseph Chen		fi
598*24ea65e6SJoseph Chen	done
599*24ea65e6SJoseph Chen
600701318baSJoseph Chen	# MCUs
601701318baSJoseph Chen	for ((i=0; i<5; i++))
602701318baSJoseph Chen	do
603701318baSJoseph Chen		MCU_BIN="mcu${i}.bin"
604701318baSJoseph Chen		MCU_IDX="MCU${i}"
605701318baSJoseph Chen
606701318baSJoseph Chen		# compatible: use "MCU" to replace "MCU0" if "MCU" is present.
607701318baSJoseph Chen		ENABLED=`awk -F"," '/MCU=/  { printf $3 }' ${INI} | tr -d ' '`
608701318baSJoseph Chen		if [ ${i} -eq 0 ]; then
609701318baSJoseph Chen			ENABLED=`awk -F"," '/MCU=/  { printf $3 }' ${INI} | tr -d ' '`
610701318baSJoseph Chen			if [ ! -z ${ENABLED} ]; then
611701318baSJoseph Chen				MCU_IDX="MCU"
612701318baSJoseph Chen			fi
613701318baSJoseph Chen		fi
614701318baSJoseph Chen
615701318baSJoseph Chen		ENABLED=`awk -F "," '/'${MCU_IDX}'=/  { printf $3 }' ${INI} | tr -d ' '`
616701318baSJoseph Chen		if [ "${ENABLED}" == "enabled" -o "${ENABLED}" == "okay" ]; then
617701318baSJoseph Chen			NAME=`awk -F "," '/'${MCU_IDX}'=/ { printf $1 }' ${INI} | tr -d ' ' | awk -F "=" '{ print $2 }'`
618701318baSJoseph Chen			OFFS=`awk -F "," '/'${MCU_IDX}'=/ { printf $2 }' ${INI} | tr -d ' '`
619701318baSJoseph Chen			cp ${RKBIN}/${NAME} ${MCU_BIN}
620701318baSJoseph Chen			if [ -z ${OFFS} ]; then
621701318baSJoseph Chen				echo "ERROR: No ${MCU_BIN} address in ${INI}"
6223a711d9cSJoseph Chen				exit 1
6233a711d9cSJoseph Chen			fi
624701318baSJoseph Chen			MCU_ARG=${MCU_ARG}" -m${i} ${OFFS}"
625cb718016SJoseph Chen		fi
626701318baSJoseph Chen	done
627701318baSJoseph Chen
628701318baSJoseph Chen	# Loadables
629701318baSJoseph Chen	for ((i=0; i<5; i++))
630701318baSJoseph Chen	do
631701318baSJoseph Chen		LOAD_BIN="load${i}.bin"
632701318baSJoseph Chen		LOAD_IDX="LOAD${i}"
633701318baSJoseph Chen		ENABLED=`awk -F "," '/'${LOAD_IDX}'=/  { printf $3 }' ${INI} | tr -d ' '`
634701318baSJoseph Chen		if [ "${ENABLED}" == "enabled" -o "${ENABLED}" == "okay" ]; then
635701318baSJoseph Chen			NAME=`awk -F "," '/'${LOAD_IDX}'=/ { printf $1 }' ${INI} | tr -d ' ' | awk -F "=" '{ print $2 }'`
636701318baSJoseph Chen			OFFS=`awk -F "," '/'${LOAD_IDX}'=/ { printf $2 }' ${INI} | tr -d ' '`
637701318baSJoseph Chen			cp ${RKBIN}/${NAME} ${LOAD_BIN}
638701318baSJoseph Chen			if [ -z ${OFFS} ]; then
639701318baSJoseph Chen				echo "ERROR: No ${LOAD_BIN} address in ${INI}"
640701318baSJoseph Chen				exit 1
641701318baSJoseph Chen			fi
642701318baSJoseph Chen			LOAD_ARG=${LOAD_ARG}" -l${i} ${OFFS}"
643701318baSJoseph Chen		fi
644701318baSJoseph Chen	done
645b42d2103SJoseph Chen
64633e46123SJoseph Chen	# COMPRESSION
6478ec3b1c1SJoseph Chen	if grep -q '^CONFIG_IMAGE_GZIP=y' .config ; then
6488ec3b1c1SJoseph Chen		COMPRESSION_ARG="-c gzip"
6498ec3b1c1SJoseph Chen	else
650b42d2103SJoseph Chen		COMPRESSION=`awk -F"," '/COMPRESSION=/  { printf $1 }' ${INI} | tr -d ' ' | cut -c 13-`
651cb718016SJoseph Chen		if [ ! -z "${COMPRESSION}" -a "${COMPRESSION}" != "none" ]; then
652cb718016SJoseph Chen			COMPRESSION_ARG="-c ${COMPRESSION}"
653b42d2103SJoseph Chen		fi
6548ec3b1c1SJoseph Chen	fi
655b42d2103SJoseph Chen
656173e789eSJoseph Chen	if [ -d ${REP_DIR} ]; then
657173e789eSJoseph Chen		mv ${REP_DIR}/* ./
658173e789eSJoseph Chen	fi
659173e789eSJoseph Chen
660caaf32e4SJoseph Chen	SPL_FIT_SOURCE=`filt_val "CONFIG_SPL_FIT_SOURCE" .config`
661b42d2103SJoseph Chen	if [ ! -z ${SPL_FIT_SOURCE} ]; then
662b42d2103SJoseph Chen		cp ${SPL_FIT_SOURCE} u-boot.its
663b42d2103SJoseph Chen	else
664caaf32e4SJoseph Chen		SPL_FIT_GENERATOR=`filt_val "CONFIG_SPL_FIT_GENERATOR" .config`
6653a711d9cSJoseph Chen		# *.py is the legacy one.
66646e7ba36SJoseph Chen		if [[ ${SPL_FIT_GENERATOR} == *.py ]]; then
66746e7ba36SJoseph Chen			${SPL_FIT_GENERATOR} u-boot.dtb > u-boot.its
66846e7ba36SJoseph Chen		else
669*24ea65e6SJoseph Chen			${SPL_FIT_GENERATOR} ${TEE_ARG} ${COMPRESSION_ARG} ${INIT_ARG} ${MCU_ARG} ${LOAD_ARG} > u-boot.its
670b42d2103SJoseph Chen		fi
67146e7ba36SJoseph Chen	fi
672b42d2103SJoseph Chen
673173a9307SJoseph Chen	./tools/mkimage -f u-boot.its -E u-boot.itb >/dev/null 2>&1
674b42d2103SJoseph Chen	echo "pack u-boot.itb okay! Input: ${INI}"
675b42d2103SJoseph Chen	echo
676b42d2103SJoseph Chen}
677b42d2103SJoseph Chen
678b42d2103SJoseph Chenfunction pack_spl_loader_image()
679b42d2103SJoseph Chen{
6807e94e08eSJoseph Chen	rm -f *loader*.bin *download*.bin *idblock*.img
681b42d2103SJoseph Chen	cd ${RKBIN}
68289b86f57SJoseph Chen	DEF_PATH=${RKBIN}/`filt_val "^PATH" ${INI_LOADER}`
68389b86f57SJoseph Chen	IDB_PATH=${RKBIN}/`filt_val "IDB_PATH" ${INI_LOADER}`
684b42d2103SJoseph Chen	if [ ! -z "${ARG_SPL_BIN}" -a ! -z "${ARG_TPL_BIN}" ]; then
685b42d2103SJoseph Chen		${SCRIPT_SPL} --ini ${INI_LOADER} --tpl ${SRCTREE}/${ARG_TPL_BIN} --spl ${SRCTREE}/${ARG_SPL_BIN}
686b42d2103SJoseph Chen	elif [ ! -z "${ARG_TPL_BIN}" ]; then
687b42d2103SJoseph Chen		${SCRIPT_SPL} --ini ${INI_LOADER} --tpl ${SRCTREE}/${ARG_TPL_BIN}
688b42d2103SJoseph Chen	else
689b42d2103SJoseph Chen		${SCRIPT_SPL} --ini ${INI_LOADER} --spl ${SRCTREE}/${ARG_SPL_BIN}
690b42d2103SJoseph Chen	fi
691b42d2103SJoseph Chen	cd -
69289b86f57SJoseph Chen	if [ -f ${DEF_PATH} ]; then
69389b86f57SJoseph Chen		mv ${DEF_PATH} ./
69489b86f57SJoseph Chen	fi
69589b86f57SJoseph Chen	if [ -f ${IDB_PATH} ]; then
69689b86f57SJoseph Chen		mv ${IDB_PATH} ./
697b42d2103SJoseph Chen	fi
698b42d2103SJoseph Chen}
699b42d2103SJoseph Chen
700b42d2103SJoseph Chenfunction pack_uboot_image()
701b42d2103SJoseph Chen{
702b42d2103SJoseph Chen	rm u-boot.img u-boot-dtb.img -f
703b42d2103SJoseph Chen	LOAD_ADDR=`sed -n "/CONFIG_SYS_TEXT_BASE=/s/CONFIG_SYS_TEXT_BASE=//p" include/autoconf.mk|tr -d '\r'`
704a524b379SJoseph Chen	if [ -z "${LOAD_ADDR}" ]; then
705a524b379SJoseph Chen		# upstream U-Boot
706a524b379SJoseph Chen		LOAD_ADDR=`grep CONFIG_SYS_TEXT_BASE include/generated/autoconf.h | awk '{ print $3 }' | tr -d '\r'`
707a524b379SJoseph Chen	fi
708a524b379SJoseph Chen
709a524b379SJoseph Chen	if [ -z "${LOAD_ADDR}" ]; then
710a524b379SJoseph Chen		echo "ERROR: No CONFIG_SYS_TEXT_BASE for u-boot";
711a524b379SJoseph Chen		exit 1
712a524b379SJoseph Chen	fi
713a524b379SJoseph Chen
714b42d2103SJoseph Chen	${SCRIPT_UBOOT} --load ${LOAD_ADDR} ${PLAT_UBOOT_SIZE}
715b42d2103SJoseph Chen}
716b42d2103SJoseph Chen
717b42d2103SJoseph Chenfunction pack_loader_image()
718b42d2103SJoseph Chen{
7197e94e08eSJoseph Chen	rm -f *loader*.bin *download*.bin *idblock*.img
720b42d2103SJoseph Chen	cd ${RKBIN}
72189b86f57SJoseph Chen	DEF_PATH=${RKBIN}/`filt_val "^PATH" ${INI_LOADER}`
72289b86f57SJoseph Chen	IDB_PATH=${RKBIN}/`filt_val "IDB_PATH" ${INI_LOADER}`
723b42d2103SJoseph Chen	${SCRIPT_LOADER} --ini ${INI_LOADER}
724b42d2103SJoseph Chen	cd -
72589b86f57SJoseph Chen	if [ -f ${DEF_PATH} ]; then
72689b86f57SJoseph Chen		mv ${DEF_PATH} ./
72789b86f57SJoseph Chen	fi
72889b86f57SJoseph Chen	if [ -f ${IDB_PATH} ]; then
72989b86f57SJoseph Chen		mv ${IDB_PATH} ./
730b42d2103SJoseph Chen	fi
731b42d2103SJoseph Chen}
732b42d2103SJoseph Chen
733b42d2103SJoseph Chenfunction pack_trust_image()
734b42d2103SJoseph Chen{
735caaf32e4SJoseph Chen	DRAM_BASE=`filt_val "CONFIG_SYS_SDRAM_BASE" include/autoconf.mk`
736b42d2103SJoseph Chen
737b42d2103SJoseph Chen	rm trust*.img -f
738b42d2103SJoseph Chen	cd ${RKBIN}
739b42d2103SJoseph Chen	if [ "${ARM64_TRUSTZONE}" == "y" ]; then
740b42d2103SJoseph Chen		${SCRIPT_ATF} --ini ${INI_TRUST} ${PLAT_SHA} ${PLAT_RSA} ${PLAT_TRUST_SIZE}
741b42d2103SJoseph Chen	else
742b42d2103SJoseph Chen		${SCRIPT_TOS} --ini ${INI_TRUST} --base ${DRAM_BASE} ${PLAT_TRUST_SIZE}
743b42d2103SJoseph Chen	fi
744b42d2103SJoseph Chen	cd -
745b42d2103SJoseph Chen	if [ -f ${RKBIN}/trust*.img ]; then
746b42d2103SJoseph Chen		mv ${RKBIN}/trust*.img ./
747b42d2103SJoseph Chen	fi
748b42d2103SJoseph Chen}
749b42d2103SJoseph Chen
750b42d2103SJoseph Chenfunction pack_fit_image()
751b42d2103SJoseph Chen{
7523a711d9cSJoseph Chen	# check host tools
7533a711d9cSJoseph Chen	if ! which dtc >/dev/null 2>&1 ; then
7543a711d9cSJoseph Chen		echo "ERROR: No 'dtc', please: apt-get install device-tree-compiler"
7553a711d9cSJoseph Chen		exit 1
756b8043f48SJoseph Chen	elif [ "${ARM64_TRUSTZONE}" == "y" ]; then
757b8043f48SJoseph Chen		if ! which python2 >/dev/null 2>&1 ; then
758b8043f48SJoseph Chen			echo "ERROR: No python2"
759b8043f48SJoseph Chen			exit 1
760b8043f48SJoseph Chen		fi
7613a711d9cSJoseph Chen	fi
7623a711d9cSJoseph Chen
763b42d2103SJoseph Chen	# If we don't plan to have uboot in uboot.img in case of: SPL => Trust => Kernel, creating empty files.
764b42d2103SJoseph Chen	if [ "${ARG_NO_UBOOT}" == "y" ]; then
765b42d2103SJoseph Chen		rm u-boot-nodtb.bin u-boot.dtb -f
766b42d2103SJoseph Chen		touch u-boot-nodtb.bin u-boot.dtb
767b42d2103SJoseph Chen	fi
768b42d2103SJoseph Chen
7692d11b868SJoseph Chen	rm uboot.img trust*.img -rf
7702a0b9372SJoseph Chen	${SCRIPT_FIT} ${ARG_LIST_FIT} --chip ${RKCHIP_LABEL}
7712d11b868SJoseph Chen
772173e789eSJoseph Chen	rm ${REP_DIR} -rf
773b42d2103SJoseph Chen	echo "pack uboot.img okay! Input: ${INI_TRUST}"
774b42d2103SJoseph Chen}
775b42d2103SJoseph Chen
776b6e67ca8SJoseph Chenfunction handle_args_late()
777b6e67ca8SJoseph Chen{
7786af0d055SJoseph Chen	ARG_LIST_FIT="${ARG_LIST_FIT} --ini-trust ${INI_TRUST} --ini-loader ${INI_LOADER} ${ARG_FIT_FWVER}"
779b6e67ca8SJoseph Chen}
780b6e67ca8SJoseph Chen
781b42d2103SJoseph Chenfunction clean_files()
782de9a6cd2SJoseph Chen{
783b42d2103SJoseph Chen	rm spl/u-boot-spl.dtb tpl/u-boot-tpl.dtb u-boot.dtb -f
784b42d2103SJoseph Chen	rm spl/u-boot-spl tpl/u-boot-tpl u-boot -f
7858f53a15cSJoseph Chen}
7868f53a15cSJoseph Chen
7878f53a15cSJoseph Chenfunction pack_images()
7888f53a15cSJoseph Chen{
7892d11b868SJoseph Chen	if [ "${ARG_RAW_COMPILE}" != "y" ]; then
7902d11b868SJoseph Chen		if [ "${PLAT_TYPE}" == "FIT" ]; then
7912d11b868SJoseph Chen			pack_fit_image ${ARG_LIST_FIT}
792b9fb3edaSJoseph Chen		elif [ "${PLAT_TYPE}" == "DECOMP" ]; then
7935a46c4f4SJoseph Chen			${SCRIPT_DECOMP} ${ARG_LIST_FIT} --chip ${RKCHIP_LABEL}
7942d11b868SJoseph Chen		else
7958f53a15cSJoseph Chen			pack_uboot_image
7968f53a15cSJoseph Chen			pack_trust_image
7978f53a15cSJoseph Chen			pack_loader_image
7982d11b868SJoseph Chen		fi
7998f53a15cSJoseph Chen	fi
8008f53a15cSJoseph Chen}
8018f53a15cSJoseph Chen
8027c3ca500SJoseph Chenfunction finish()
80330b04afcSJoseph Chen{
804942378a0SJoseph Chen	# check special config
805942378a0SJoseph Chen	${SCRIPT_CHECKCONFIG}
806942378a0SJoseph Chen
80730b04afcSJoseph Chen	echo
808b42b4e11SJoseph Chen	if [ "${ARG_BOARD}" == "" ]; then
8095202fe1fSJoseph Chen		echo "Platform ${RKCHIP_LABEL} is build OK, with exist .config"
81030b04afcSJoseph Chen	else
811124e8c09SJoseph Chen		echo "Platform ${RKCHIP_LABEL} is build OK, with new .config(${MAKE_CMD})"
81230b04afcSJoseph Chen	fi
81330b04afcSJoseph Chen}
81430b04afcSJoseph Chen
815b768b915SJoseph Chenprocess_args $*
816cd7ae718SJoseph Chenprepare
8177c2526e9SJoseph Chenselect_toolchain
818de440615SJoseph Chenselect_chip_info
81941cf5e5aSJoseph Chenfixup_platform_configure
820b768b915SJoseph Chenselect_ini_file
821b6e67ca8SJoseph Chenhandle_args_late
8220ff0e214SJoseph Chensub_commands
8238f53a15cSJoseph Chenclean_files
824ed86ec4fSJoseph Chenmake PYTHON=python2 ${ARG_SPL_FWVER} ${ARG_FWVER} CROSS_COMPILE=${TOOLCHAIN} all --jobs=${JOB}
8258f53a15cSJoseph Chenpack_images
82630b04afcSJoseph Chenfinish
827b9cfcfe6SJoseph Chenecho ${TOOLCHAIN}
82841045696SJoseph Chendate
829