xref: /rk3399_rockchip-uboot/make.sh (revision 851015326d0c4cdffc84d318f5f8e7bbdf40d437)
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 YanBOARD=$1
10b6255198SJoseph ChenSUBCMD=$1
1153ea5791SJoseph ChenFUNCADDR=$1
12dd590c93SJoseph ChenFILE=$2
1327a50c86SAndy YanJOB=`sed -n "N;/processor/p" /proc/cpuinfo|wc -l`
14b6255198SJoseph ChenSUPPORT_LIST=`ls configs/*[r,p][x,v,k][0-9][0-9]*_defconfig`
1527a50c86SAndy Yan
160583701dSJoseph Chen# @LOADER: map to $RKCHIP_LOADER for loader ini
170583701dSJoseph Chen# @TRUST:  map to $RKCHIP_TRUST for trust ini
180583701dSJoseph Chen# @LABEL:  map to $RKCHIP_LEBEL for verbose message
190583701dSJoseph Chen# @-:      default state/value
200583701dSJoseph ChenCHIP_TYPE_FIXUP_TABLE=(
210583701dSJoseph Chen	# CONFIG_XXX                         RKCHIP         LOADER       TRUST         LABEL
220583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK3368              RK3368H         -            -             -"
230583701dSJoseph Chen	"CONFIG_ROCKCHIP_RV1108              RV110X          -            -             -"
240583701dSJoseph Chen	"CONFIG_ROCKCHIP_PX3SE               PX3SE           -            -             -"
250583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK3126              RK3126          -            -             -"
260583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK3326              RK3326          -            -             -"
270583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK3128X             RK3128X         -            -             -"
280583701dSJoseph Chen	"CONFIG_ROCKCHIP_PX5                 PX5             -            -             -"
290583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK3399PRO           RK3399PRO       -            -             -"
300583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK1806              RK1806          -            -             -"
310583701dSJoseph Chen	"CONFIG_TARGET_GVA_RK3229            RK322X          RK322XAT     -             -"
320583701dSJoseph Chen	"CONFIG_COPROCESSOR_RK1808           RKNPU-LION      RKNPULION    RKNPULION     -"
330583701dSJoseph Chen)
340583701dSJoseph Chen
350583701dSJoseph Chen# <*> Fixup rsa/sha pack mode for platforms
360583701dSJoseph Chen#     RSA: RK3308/PX30/RK3326/RK1808 use RSA-PKCS1 V2.1, it's pack magic is "3", and others use default configure.
370583701dSJoseph Chen#     SHA: RK3368 use rk big endian SHA256, it's pack magic is "2", and others use default configure.
380583701dSJoseph Chen# <*> Fixup images size pack for platforms
390583701dSJoseph Chen# <*> Fixup verbose message about AARCH32
40de440615SJoseph Chen#
410583701dSJoseph Chen# @RSA:     rsa mode
420583701dSJoseph Chen# @SHA:     sha mode
430583701dSJoseph Chen# @A64-KB:  arm64 platform image size: [uboot,trust]
440583701dSJoseph Chen# @A64-NUM: arm64 platform image number of total: [uboot,trust]
450583701dSJoseph Chen# @A32-KB:  arm32 platform image size: [uboot,trust]
460583701dSJoseph Chen# @A32-NUM: arm32 platform image number of total: [uboot,trust]
470583701dSJoseph Chen# @LOADER:  map to $RKCHIP_LOADER for loader ini
480583701dSJoseph Chen# @TRUST:   map to $RKCHIP_TRUST for trust ini
490583701dSJoseph Chen# @-:       default state/value
500583701dSJoseph ChenCHIP_CFG_FIXUP_TABLE=(
510583701dSJoseph Chen	# CONFIG_XXX              RSA     SHA     A64-KB      A64-NUM     A32-KB       A32-NUM      LOAER        TRUST
520583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK3368    -       2       -,-          -,-        -,-          -,-           -           -"
530583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK3036    -       -       512,512      1,1        -,-          -,-           -           -"
540583701dSJoseph Chen	"CONFIG_ROCKCHIP_PX30      3       -       -,-          -,-        -,-          -,-           -           -"
550583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK3326    3       -       -,-          -,-        -,-          -,-           AARCH32     -"
560583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK3308    3       -       1024,1024    2,2        512,512      2,2           -           AARCH32"
570583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK1808    3       -       1024,1024    2,2        -,-          -,-           -           -"
58de440615SJoseph Chen)
59de440615SJoseph Chen
60fb90bd1dSJoseph Chen########################################### User can modify #############################################
61fb90bd1dSJoseph Chen# User's rkbin tool relative path
62bc98b3c8SJoseph ChenRKBIN_TOOLS=../rkbin/tools
63bc98b3c8SJoseph Chen
64fb90bd1dSJoseph Chen# User's GCC toolchain and relative path
6553ea5791SJoseph ChenADDR2LINE_ARM32=arm-linux-gnueabihf-addr2line
6653ea5791SJoseph ChenADDR2LINE_ARM64=aarch64-linux-gnu-addr2line
67fb90bd1dSJoseph ChenOBJ_ARM32=arm-linux-gnueabihf-objdump
68fb90bd1dSJoseph ChenOBJ_ARM64=aarch64-linux-gnu-objdump
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 #############################################
7523ba6841SJoseph ChenRKTOOLS=./tools
7623ba6841SJoseph Chen
77de440615SJoseph Chen# Declare global INI file searching index name for every chip, update in select_chip_info()
780583701dSJoseph ChenRKCHIP="-"
790583701dSJoseph ChenRKCHIP_LABEL="-"
800583701dSJoseph ChenRKCHIP_LOADER="-"
810583701dSJoseph ChenRKCHIP_TRUST="-"
82d443b7d5SJoseph Chen
8323ba6841SJoseph Chen# Declare rkbin repository path, updated in prepare()
84fb90bd1dSJoseph ChenRKBIN=
85fb90bd1dSJoseph Chen
86fb90bd1dSJoseph Chen# Declare global toolchain path for CROSS_COMPILE, updated in select_toolchain()
87fb90bd1dSJoseph ChenTOOLCHAIN_GCC=
88fb90bd1dSJoseph ChenTOOLCHAIN_OBJDUMP=
8953ea5791SJoseph ChenTOOLCHAIN_ADDR2LINE=
90fb90bd1dSJoseph Chen
91fb90bd1dSJoseph Chen# Declare global default output dir and cmd, update in prepare()
92622ccf34SJoseph ChenOPTION=
93bc98b3c8SJoseph Chen
9441cf5e5aSJoseph Chen# Declare global plaform configure, updated in fixup_platform_configure()
9541cf5e5aSJoseph ChenPLATFORM_RSA=
9641cf5e5aSJoseph ChenPLATFORM_SHA=
9741cf5e5aSJoseph ChenPLATFORM_UBOOT_IMG_SIZE=
9841cf5e5aSJoseph ChenPLATFORM_TRUST_IMG_SIZE=
99aa8ddc58SJoseph ChenPACK_FORMAT="rk"
1008f53a15cSJoseph ChenNOPACK="n"
101aa8ddc58SJoseph Chen
102fb90bd1dSJoseph Chen#########################################################################################################
1037c3ca500SJoseph Chenfunction help()
104b6255198SJoseph Chen{
105b6255198SJoseph Chen	echo
1066a764259SJoseph Chen	echo "Usage:"
107622ccf34SJoseph Chen	echo "	./make.sh [board|subcmd|EXT_DTB=<file>]"
1086a764259SJoseph Chen	echo
1096a764259SJoseph Chen	echo "	 - board:   board name of defconfig"
110622ccf34SJoseph Chen	echo "	 - subcmd:  |elf*|loader*|spl*|itb|trust*|uboot|map|sym|<addr>|EXT_DTB=*"
111f3d60245SJoseph Chen	echo "	 - ini:     assigned ini file to pack trust/loader"
112f3d60245SJoseph Chen	echo
113f3d60245SJoseph Chen	echo "Output:"
114f3d60245SJoseph Chen	echo "	 When board built okay, there are uboot/trust/loader images in current directory"
115b6255198SJoseph Chen	echo
116b6255198SJoseph Chen	echo "Example:"
117b6255198SJoseph Chen	echo
118d6821889SJoseph Chen	echo "1. Build:"
119fc99e044SJoseph Chen	echo "	./make.sh evb-rk3399               --- build for evb-rk3399_defconfig"
120fc99e044SJoseph Chen	echo "	./make.sh firefly-rk3288           --- build for firefly-rk3288_defconfig"
121622ccf34SJoseph Chen	echo "	./make.sh EXT_DTB=rk-kernel.dtb    --- build with exist .config and external dtb"
122fc99e044SJoseph Chen	echo "	./make.sh                          --- build with exist .config"
123398d3e80SJoseph Chen	echo "	./make.sh env                      --- build envtools"
124b6255198SJoseph Chen	echo
125d6821889SJoseph Chen	echo "2. Pack:"
1266a764259SJoseph Chen	echo "	./make.sh uboot                    --- pack uboot.img"
12769cce37bSJoseph Chen	echo "	./make.sh trust                    --- pack trust.img"
128f3d60245SJoseph Chen	echo "	./make.sh trust <ini>              --- pack trust img with assigned ini file"
1296a764259SJoseph Chen	echo "	./make.sh loader                   --- pack loader bin"
130f3d60245SJoseph Chen	echo "	./make.sh loader <ini>             --- pack loader img with assigned ini file"
131f3d60245SJoseph Chen	echo "	./make.sh spl                      --- pack loader with u-boot-spl.bin and u-boot-tpl.bin"
132f3d60245SJoseph Chen	echo "	./make.sh spl-s                    --- pack loader only replace miniloader with u-boot-spl.bin"
133f3d60245SJoseph Chen	echo "	./make.sh itb                      --- pack u-boot.itb(TODO: bl32 is not included for ARMv8)"
134b6255198SJoseph Chen	echo
135d6821889SJoseph Chen	echo "3. Debug:"
136b6255198SJoseph Chen	echo "	./make.sh elf                      --- dump elf file with -D(default)"
137b6255198SJoseph Chen	echo "	./make.sh elf-S                    --- dump elf file with -S"
1386a764259SJoseph Chen	echo "	./make.sh elf-d                    --- dump elf file with -d"
139f3d60245SJoseph Chen	echo "	./make.sh elf-*                    --- dump elf file with -*"
140fc99e044SJoseph Chen	echo "	./make.sh <no reloc_addr>          --- dump function symbol and code position of address(no relocated)"
141fc99e044SJoseph Chen	echo "	./make.sh <reloc_addr-reloc_off>   --- dump function symbol and code position of address(relocated)"
142b6255198SJoseph Chen	echo "	./make.sh map                      --- cat u-boot.map"
143b6255198SJoseph Chen	echo "	./make.sh sym                      --- cat u-boot.sym"
144b6255198SJoseph Chen}
14541cf5e5aSJoseph Chen
1467c3ca500SJoseph Chenfunction prepare()
147cd7ae718SJoseph Chen{
148b6255198SJoseph Chen	case $BOARD in
14953ea5791SJoseph Chen		# Parse from exit .config
1508f53a15cSJoseph Chen		''|elf*|loader*|spl*|itb|debug*|trust|uboot|map|sym|env|EXT_DTB=*|fit*|nopack)
151d6821889SJoseph Chen		if [ ! -f .config ]; then
152b6255198SJoseph Chen			echo
1537c3ca500SJoseph Chen			echo "ERROR: No .config"
154b6255198SJoseph Chen			help
155b6255198SJoseph Chen			exit 1
156b6255198SJoseph Chen		fi
157b6255198SJoseph Chen		;;
158b6255198SJoseph Chen	esac
159cd7ae718SJoseph Chen
160b6255198SJoseph Chen	# Parse help and make defconfig
161b6255198SJoseph Chen	case $BOARD in
16253ea5791SJoseph Chen		#Help
163b6255198SJoseph Chen		--help|-help|help|--h|-h)
164b6255198SJoseph Chen		help
165b6255198SJoseph Chen		exit 0
166b6255198SJoseph Chen		;;
16753ea5791SJoseph Chen
16853ea5791SJoseph Chen		#Subcmd
1698f53a15cSJoseph Chen		''|elf*|loader*|spl*|itb|debug*|trust*|uboot|map|sym|env|EXT_DTB=*|fit*|nopack)
170b6255198SJoseph Chen		;;
171b6255198SJoseph Chen
172b6255198SJoseph Chen		*)
17353ea5791SJoseph Chen		#Func address is valid ?
174fc99e044SJoseph Chen		if [ -z $(echo ${FUNCADDR} | sed 's/[0-9,a-f,A-F,x,X,-]//g') ]; then
17553ea5791SJoseph Chen			return
17653ea5791SJoseph Chen		elif [ ! -f configs/${BOARD}_defconfig ]; then
1777c3ca500SJoseph Chen			echo -e "\n${SUPPORT_LIST}\n"
1787c3ca500SJoseph Chen			echo "ERROR: No configs/${BOARD}_defconfig"
179cd7ae718SJoseph Chen			exit 1
180b6255198SJoseph Chen		else
181b6255198SJoseph Chen			echo "make for ${BOARD}_defconfig by -j${JOB}"
182622ccf34SJoseph Chen			make ${BOARD}_defconfig ${OPTION}
183cd7ae718SJoseph Chen		fi
184b6255198SJoseph Chen		;;
185b6255198SJoseph Chen	esac
186cd7ae718SJoseph Chen
18723ba6841SJoseph Chen	# Initialize RKBIN
188bc98b3c8SJoseph Chen	if [ -d ${RKBIN_TOOLS} ]; then
189bc98b3c8SJoseph Chen		absolute_path=$(cd `dirname ${RKBIN_TOOLS}`; pwd)
190bc98b3c8SJoseph Chen		RKBIN=${absolute_path}
191cd7ae718SJoseph Chen	else
192cd7ae718SJoseph Chen		echo
1937c3ca500SJoseph Chen		echo "No '../rkbin/' repository, please download it before pack image!"
194cd7ae718SJoseph Chen		echo "How to obtain? 3 ways:"
195fb90bd1dSJoseph Chen		echo "	1. Login your Rockchip gerrit account: \"Projects\" -> \"List\" -> search \"rk/rkbin\" repository"
196fb90bd1dSJoseph Chen		echo "	2. Github repository: https://github.com/rockchip-linux/rkbin"
197fb90bd1dSJoseph Chen		echo "	3. Download full release SDK repository"
198cd7ae718SJoseph Chen		exit 1
199cd7ae718SJoseph Chen	fi
20069b6e590SJoseph Chen
2017c3ca500SJoseph Chen	if grep -Eq ''^CONFIG_ARM64=y'|'^CONFIG_ARM64_BOOT_AARCH32=y'' .config ; then
2027c3ca500SJoseph Chen		ARM64_TRUSTZONE="y"
2037c3ca500SJoseph Chen	fi
2047c3ca500SJoseph Chen
20569b6e590SJoseph Chen	if grep  -q '^CONFIG_ROCKCHIP_FIT_IMAGE_PACK=y' .config ; then
20669b6e590SJoseph Chen		PACK_FORMAT="fit"
20769b6e590SJoseph Chen	fi
20830b04afcSJoseph Chen}
2097c2526e9SJoseph Chen
2107c3ca500SJoseph Chenfunction select_toolchain()
21127a50c86SAndy Yan{
212d6821889SJoseph Chen	if grep -q '^CONFIG_ARM64=y' .config ; then
213bc98b3c8SJoseph Chen		if [ -d ${TOOLCHAIN_ARM64} ]; then
214bc98b3c8SJoseph Chen			absolute_path=$(cd `dirname ${TOOLCHAIN_ARM64}`; pwd)
215bc98b3c8SJoseph Chen			TOOLCHAIN_GCC=${absolute_path}/bin/${GCC_ARM64}
2160ff0e214SJoseph Chen			TOOLCHAIN_OBJDUMP=${absolute_path}/bin/${OBJ_ARM64}
21753ea5791SJoseph Chen			TOOLCHAIN_ADDR2LINE=${absolute_path}/bin/${ADDR2LINE_ARM64}
218bc98b3c8SJoseph Chen		else
2197c3ca500SJoseph Chen			echo "ERROR: No toolchain: ${TOOLCHAIN_ARM64}"
220bc98b3c8SJoseph Chen			exit 1
22127a50c86SAndy Yan		fi
22227a50c86SAndy Yan	else
223bc98b3c8SJoseph Chen		if [ -d ${TOOLCHAIN_ARM32} ]; then
224bc98b3c8SJoseph Chen			absolute_path=$(cd `dirname ${TOOLCHAIN_ARM32}`; pwd)
225bc98b3c8SJoseph Chen			TOOLCHAIN_GCC=${absolute_path}/bin/${GCC_ARM32}
2260ff0e214SJoseph Chen			TOOLCHAIN_OBJDUMP=${absolute_path}/bin/${OBJ_ARM32}
22753ea5791SJoseph Chen			TOOLCHAIN_ADDR2LINE=${absolute_path}/bin/${ADDR2LINE_ARM32}
228bc98b3c8SJoseph Chen		else
2297c3ca500SJoseph Chen			echo "ERROR: No toolchain: ${TOOLCHAIN_ARM32}"
230bc98b3c8SJoseph Chen			exit 1
23127a50c86SAndy Yan		fi
23227a50c86SAndy Yan	fi
233bc98b3c8SJoseph Chen}
234bc98b3c8SJoseph Chen
2357c3ca500SJoseph Chenfunction sub_commands()
2360ff0e214SJoseph Chen{
2377c3ca500SJoseph Chen	cmd=${SUBCMD%-*}
2387c3ca500SJoseph Chen	opt=${SUBCMD#*-}
2397c3ca500SJoseph Chen	elf=u-boot
2407c3ca500SJoseph Chen	map=u-boot.map
2417c3ca500SJoseph Chen	sym=u-boot.sym
24234bdfea0SJoseph Chen
24334bdfea0SJoseph Chen	if [ "$FILE" == "tpl" -o "$FILE" == "spl" ]; then
24434bdfea0SJoseph Chen		elf=`find -name u-boot-${FILE}`
24534bdfea0SJoseph Chen		map=`find -name u-boot-${FILE}.map`
24634bdfea0SJoseph Chen		sym=`find -name u-boot-${FILE}.sym`
24734bdfea0SJoseph Chen	fi
2480ff0e214SJoseph Chen
249b6255198SJoseph Chen	case $cmd in
250b6255198SJoseph Chen		elf)
2517c3ca500SJoseph Chen		if [ ! -f ${elf} ]; then
2527c3ca500SJoseph Chen			echo "ERROR: No elf: ${elf}"
2530ff0e214SJoseph Chen			exit 1
2540ff0e214SJoseph Chen		else
255b6255198SJoseph Chen			# default 'cmd' without option, use '-D'
2565c75ab41SJoseph Chen			if [ "${cmd}" = 'elf' -a "${opt}" = 'elf' ]; then
2575c75ab41SJoseph Chen				opt=D
2580ff0e214SJoseph Chen			fi
25934bdfea0SJoseph Chen			${TOOLCHAIN_OBJDUMP} -${opt} ${elf} | less
26007de173aSJoseph Chen			exit 0
26107de173aSJoseph Chen		fi
262b6255198SJoseph Chen		;;
263b6255198SJoseph Chen
2641b6c85a0SJoseph Chen		debug)
265fcccd23aSJoseph Chen		./scripts/rkpatch.sh ${opt}
2661b6c85a0SJoseph Chen		exit 0
2671b6c85a0SJoseph Chen		;;
2681b6c85a0SJoseph Chen
26969b6e590SJoseph Chen		fit)
2706cf81e27SJoseph Chen		if [ "$opt" = "s" ]; then
2716cf81e27SJoseph Chen			./scripts/fit-vboot.sh
2726cf81e27SJoseph Chen		else
2736cf81e27SJoseph Chen			./scripts/fit-vboot.sh --no-vboot
2746cf81e27SJoseph Chen		fi
27569b6e590SJoseph Chen		exit 0
27669b6e590SJoseph Chen		;;
27769b6e590SJoseph Chen
278b6255198SJoseph Chen		map)
27934bdfea0SJoseph Chen		cat ${map} | less
280b6255198SJoseph Chen		exit 0
281b6255198SJoseph Chen		;;
282b6255198SJoseph Chen
283b6255198SJoseph Chen		sym)
28434bdfea0SJoseph Chen		cat ${sym} | less
285b6255198SJoseph Chen		exit 0
286b6255198SJoseph Chen		;;
287b6255198SJoseph Chen
288b6255198SJoseph Chen		trust)
289d6e1155eSJoseph Chen		pack_trust_image
290a43a18b2SJoseph Chen		exit 0
291b6255198SJoseph Chen		;;
292b6255198SJoseph Chen
293b6255198SJoseph Chen		loader)
294d6e1155eSJoseph Chen		pack_loader_image
295a43a18b2SJoseph Chen		exit 0
296b6255198SJoseph Chen		;;
297b6255198SJoseph Chen
298daa3bef5SJoseph Chen		spl)
299daa3bef5SJoseph Chen		pack_spl_loader_image ${opt}
300daa3bef5SJoseph Chen		exit 0
301daa3bef5SJoseph Chen		;;
302daa3bef5SJoseph Chen
303daa3bef5SJoseph Chen		itb)
304daa3bef5SJoseph Chen		pack_uboot_itb_image
305daa3bef5SJoseph Chen		exit 0
306daa3bef5SJoseph Chen		;;
307daa3bef5SJoseph Chen
308b6255198SJoseph Chen		uboot)
30969cce37bSJoseph Chen		pack_uboot_image ${opt}
310fb90bd1dSJoseph Chen		exit 0
311b6255198SJoseph Chen		;;
312b6255198SJoseph Chen
313398d3e80SJoseph Chen		env)
314398d3e80SJoseph Chen		make CROSS_COMPILE=${TOOLCHAIN_GCC} envtools
315398d3e80SJoseph Chen		exit 0
316398d3e80SJoseph Chen		;;
317398d3e80SJoseph Chen
318622ccf34SJoseph Chen		EXT_DTB=*)
319622ccf34SJoseph Chen		OPTION=${SUBCMD}
320622ccf34SJoseph Chen		;;
321622ccf34SJoseph Chen
3228f53a15cSJoseph Chen		nopack)
3238f53a15cSJoseph Chen		NOPACK="y"
3248f53a15cSJoseph Chen		;;
3258f53a15cSJoseph Chen
326b6255198SJoseph Chen		*)
32753ea5791SJoseph Chen		# Search function and code position of address
328fc99e044SJoseph Chen		RELOC_OFF=${FUNCADDR#*-}
329fc99e044SJoseph Chen		FUNCADDR=${FUNCADDR%-*}
330fc99e044SJoseph Chen		if [ -z $(echo ${FUNCADDR} | sed 's/[0-9,a-f,A-F,x,X,-]//g') ] && [ ${FUNCADDR} ]; then
3317070f875SJoseph Chen			# With prefix: '0x' or '0X'
3327070f875SJoseph Chen			if [ `echo ${FUNCADDR} | sed -n "/0[x,X]/p" | wc -l` -ne 0 ]; then
3337070f875SJoseph Chen				FUNCADDR=`echo $FUNCADDR | awk '{ print strtonum($0) }'`
3347070f875SJoseph Chen				FUNCADDR=`echo "obase=16;${FUNCADDR}"|bc |tr '[A-Z]' '[a-z]'`
3357070f875SJoseph Chen			fi
336fc99e044SJoseph Chen			if [ `echo ${RELOC_OFF} | sed -n "/0[x,X]/p" | wc -l` -ne 0 ] && [ ${RELOC_OFF} ]; then
337fc99e044SJoseph Chen				RELOC_OFF=`echo $RELOC_OFF | awk '{ print strtonum($0) }'`
338fc99e044SJoseph Chen				RELOC_OFF=`echo "obase=16;${RELOC_OFF}"|bc |tr '[A-Z]' '[a-z]'`
339fc99e044SJoseph Chen			fi
340fc99e044SJoseph Chen
341fc99e044SJoseph Chen			# If reloc address is assigned, do sub
342fc99e044SJoseph Chen			if [ "${FUNCADDR}" != "${RELOC_OFF}" ]; then
343fc99e044SJoseph Chen				# Hex -> Dec -> SUB -> Hex
344fc99e044SJoseph Chen				FUNCADDR=`echo $((16#${FUNCADDR}))`
345fc99e044SJoseph Chen				RELOC_OFF=`echo $((16#${RELOC_OFF}))`
346fc99e044SJoseph Chen				FUNCADDR=$((FUNCADDR-RELOC_OFF))
347fc99e044SJoseph Chen				FUNCADDR=$(echo "obase=16;${FUNCADDR}"|bc |tr '[A-Z]' '[a-z]')
348fc99e044SJoseph Chen			fi
3497070f875SJoseph Chen
35053ea5791SJoseph Chen			echo
35134bdfea0SJoseph Chen			sed -n "/${FUNCADDR}/p" ${sym}
35234bdfea0SJoseph Chen			${TOOLCHAIN_ADDR2LINE} -e ${elf} ${FUNCADDR}
35353ea5791SJoseph Chen			exit 0
35453ea5791SJoseph Chen		fi
355b6255198SJoseph Chen		;;
356b6255198SJoseph Chen	esac
3570ff0e214SJoseph Chen}
3580ff0e214SJoseph Chen
359de440615SJoseph Chen# We select chip info to do:
360de440615SJoseph Chen#	1. RKCHIP: fixup platform configure
361de440615SJoseph Chen#	2. RKCHIP_LOADER: search ini file to pack loader
362de440615SJoseph Chen#	3. RKCHIP_TRUST: search ini file to pack trust
363de440615SJoseph Chen#	4. RKCHIP_LABEL: show build message
364de440615SJoseph Chen#
365de440615SJoseph Chen# We read chip info from .config and 'RKCHIP_INI_DESC'
3667c3ca500SJoseph Chenfunction select_chip_info()
367bc98b3c8SJoseph Chen{
368de440615SJoseph Chen	# Read RKCHIP firstly from .config
369596700d7SShunqian Zheng	# The regular expression that matching:
370596700d7SShunqian Zheng	#  - PX30, PX3SE
371596700d7SShunqian Zheng	#  - RK????, RK????X
372596700d7SShunqian Zheng	#  - RV????
3737c3ca500SJoseph Chen	chip_pattern='^CONFIG_ROCKCHIP_[R,P][X,V,K][0-9ESX]{1,5}'
3747c3ca500SJoseph Chen	RKCHIP=`egrep -o ${chip_pattern} .config`
375d443b7d5SJoseph Chen
3760583701dSJoseph Chen	# default
377d443b7d5SJoseph Chen	RKCHIP=${RKCHIP##*_}
37841cf5e5aSJoseph Chen
3790583701dSJoseph Chen	# need fixup ?
3807c3ca500SJoseph Chen	for item in "${CHIP_TYPE_FIXUP_TABLE[@]}"
381de440615SJoseph Chen	do
3827c3ca500SJoseph Chen		config_xxx=`echo $item | awk '{ print $1 }'`
3837c3ca500SJoseph Chen		if grep  -q "^${config_xxx}=y" .config ; then
3847c3ca500SJoseph Chen			RKCHIP=`echo $item | awk '{ print $2 }'`
3857c3ca500SJoseph Chen			RKCHIP_LOADER=`echo $item | awk '{ print $3 }'`
3867c3ca500SJoseph Chen			RKCHIP_TRUST=`echo  $item | awk '{ print $4 }'`
3877c3ca500SJoseph Chen			RKCHIP_LABEL=`echo  $item | awk '{ print $5 }'`
388de440615SJoseph Chen		fi
3890583701dSJoseph Chen	done
3900583701dSJoseph Chen
3910583701dSJoseph Chen	if [ "$RKCHIP_LOADER" = "-" ]; then
3920583701dSJoseph Chen		RKCHIP_LOADER=${RKCHIP}
393de440615SJoseph Chen	fi
3940583701dSJoseph Chen	if [ "$RKCHIP_TRUST" = "-" ]; then
3950583701dSJoseph Chen		RKCHIP_TRUST=${RKCHIP}
3960583701dSJoseph Chen	fi
3970583701dSJoseph Chen	if [ "$RKCHIP_LABEL" = "-" ]; then
3980583701dSJoseph Chen		RKCHIP_LABEL=${RKCHIP}
3990583701dSJoseph Chen	fi
4000583701dSJoseph Chen
4010583701dSJoseph Chen	# echo "## $FUNCNAME: $RKCHIP, $RKCHIP_LOADER, $RKCHIP_TRUST, $RKCHIP_LABEL,"
4020583701dSJoseph Chen}
4030583701dSJoseph Chen
4040583701dSJoseph Chenfunction fixup_platform_configure()
4050583701dSJoseph Chen{
4067c3ca500SJoseph Chen	cfg_u_kb="-" cfg_u_num="-" cfg_t_kb="-" cfg_t_num="-"  cfg_sha="-" cfg_rsa="-"
4070583701dSJoseph Chen
4087c3ca500SJoseph Chen	for item in "${CHIP_CFG_FIXUP_TABLE[@]}"
4090583701dSJoseph Chen	do
4107c3ca500SJoseph Chen		config_xxx=`echo $item | awk '{ print $1 }'`
4117c3ca500SJoseph Chen		if grep  -q "^${config_xxx}=y" .config ; then
4120583701dSJoseph Chen			# <*> Fixup rsa/sha pack mode for platforms
4137c3ca500SJoseph Chen			cfg_rsa=`echo $item | awk '{ print $2 }'`
4147c3ca500SJoseph Chen			cfg_sha=`echo $item | awk '{ print $3 }'`
4150583701dSJoseph Chen
4160583701dSJoseph Chen			# <*> Fixup images size pack for platforms, and ini file
4170583701dSJoseph Chen			if grep -q '^CONFIG_ARM64_BOOT_AARCH32=y' .config ; then
4187c3ca500SJoseph Chen				cfg_u_kb=`echo  $item | awk '{ print $6 }' | awk -F "," '{ print $1 }'`
4197c3ca500SJoseph Chen				cfg_u_num=`echo $item | awk '{ print $7 }' | awk -F "," '{ print $1 }'`
4207c3ca500SJoseph Chen				cfg_t_kb=`echo  $item | awk '{ print $6 }' | awk -F "," '{ print $2 }'`
4217c3ca500SJoseph Chen				cfg_t_num=`echo $item | awk '{ print $7 }' | awk -F "," '{ print $2 }'`
4220583701dSJoseph Chen
4237c3ca500SJoseph Chen				PAD_LOADER=`echo $item | awk '{ print $8 }'`
4247c3ca500SJoseph Chen				PAD_TRUST=`echo  $item | awk '{ print $9 }'`
4250583701dSJoseph Chen				if [ "$PAD_LOADER" != "-" ]; then
4260583701dSJoseph Chen					RKCHIP_LOADER=${RKCHIP_LOADER}${PAD_LOADER}
4270583701dSJoseph Chen				fi
4280583701dSJoseph Chen				if [ "$PAD_TRUST" != "-" ]; then
4290583701dSJoseph Chen					RKCHIP_TRUST=${RKCHIP_TRUST}${PAD_TRUST}
4300583701dSJoseph Chen				fi
4310583701dSJoseph Chen				RKCHIP_LABEL=${RKCHIP_LABEL}"AARCH32"
4320583701dSJoseph Chen			else
4337c3ca500SJoseph Chen				cfg_u_kb=`echo  $item | awk '{ print $4 }' | awk -F "," '{ print $1 }'`
4347c3ca500SJoseph Chen				cfg_u_num=`echo $item | awk '{ print $5 }' | awk -F "," '{ print $1 }'`
4357c3ca500SJoseph Chen				cfg_t_kb=`echo  $item | awk '{ print $4 }' | awk -F "," '{ print $2 }'`
4367c3ca500SJoseph Chen				cfg_t_num=`echo $item | awk '{ print $5 }' | awk -F "," '{ print $2 }'`
437de440615SJoseph Chen			fi
438de440615SJoseph Chen		fi
439de440615SJoseph Chen	done
440de440615SJoseph Chen
4417c3ca500SJoseph Chen	if [ "$cfg_sha" != "-" ]; then
4427c3ca500SJoseph Chen		PLATFORM_SHA="--sha $cfg_sha"
4430583701dSJoseph Chen	fi
4447c3ca500SJoseph Chen	if [ "$cfg_rsa" != "-" ]; then
4457c3ca500SJoseph Chen		PLATFORM_RSA="--rsa $cfg_rsa"
4460583701dSJoseph Chen	fi
4477c3ca500SJoseph Chen	if [ "$cfg_u_kb" != "-" ]; then
4487c3ca500SJoseph Chen		PLATFORM_UBOOT_IMG_SIZE="--size $cfg_u_kb $cfg_u_num"
4490583701dSJoseph Chen	fi
4507c3ca500SJoseph Chen	if [ "$cfg_t_kb" != "-" ]; then
4517c3ca500SJoseph Chen		PLATFORM_TRUST_IMG_SIZE="--size $cfg_t_kb $cfg_t_num"
45241cf5e5aSJoseph Chen	fi
45341cf5e5aSJoseph Chen
4540583701dSJoseph Chen	# echo "## $FUNCNAME: $PLATFORM_RSA, $PLATFORM_SHA, $PLATFORM_TRUST_IMG_SIZE, $PLATFORM_UBOOT_IMG_SIZE"
4550583701dSJoseph Chen	# echo "## $FUNCNAME: $RKCHIP_LOADER, $RKCHIP_TRUST, $RKCHIP_LABEL"
45627a50c86SAndy Yan}
457de9a6cd2SJoseph Chen
4587c3ca500SJoseph Chenfunction pack_uboot_image()
459de9a6cd2SJoseph Chen{
4608f53a15cSJoseph Chen	if [ "$PACK_FORMAT" != "rk" ]; then
4618f53a15cSJoseph Chen		return
4628f53a15cSJoseph Chen	fi
4638f53a15cSJoseph Chen
464f089d907SJoseph Chen	# Check file size
4657c3ca500SJoseph Chen	head_kb=2
4667c3ca500SJoseph Chen	uboot_kb=`ls -l u-boot.bin | awk '{print $5}'`
467f089d907SJoseph Chen	if [ "$PLATFORM_UBOOT_IMG_SIZE" = "" ]; then
4687c3ca500SJoseph Chen		uboot_max_kb=1046528
469f089d907SJoseph Chen	else
4707c3ca500SJoseph Chen		uboot_max_kb=`echo $PLATFORM_UBOOT_IMG_SIZE | awk '{print strtonum($2)}'`
4717c3ca500SJoseph Chen		uboot_max_kb=$(((uboot_max_kb-head_kb)*1024))
472f089d907SJoseph Chen	fi
473f089d907SJoseph Chen
4747c3ca500SJoseph Chen	if [ $uboot_kb -gt $uboot_max_kb ]; then
475f089d907SJoseph Chen		echo
4767c3ca500SJoseph Chen		echo "ERROR: pack uboot failed! u-boot.bin actual: $uboot_kb bytes, max limit: $uboot_max_kb bytes"
477f089d907SJoseph Chen		exit 1
478f089d907SJoseph Chen	fi
479f089d907SJoseph Chen
4807c3ca500SJoseph Chen	# Pack
4817c3ca500SJoseph Chen	uboot_load_addr=`sed -n "/CONFIG_SYS_TEXT_BASE=/s/CONFIG_SYS_TEXT_BASE=//p" include/autoconf.mk|tr -d '\r'`
4827c3ca500SJoseph Chen	if [ -z $uboot_load_addr ]; then
4837c3ca500SJoseph Chen		echo "ERROR: No CONFIG_SYS_TEXT_BASE for u-boot";
4847c3ca500SJoseph Chen		exit 1
485daa679a7SKever Yang	fi
4867c3ca500SJoseph Chen	${RKTOOLS}/loaderimage --pack --uboot u-boot.bin uboot.img ${uboot_load_addr} ${PLATFORM_UBOOT_IMG_SIZE}
4877c3ca500SJoseph Chen	ls u-boot.img u-boot-dtb.img >/dev/null 2>&1 && rm u-boot.img u-boot-dtb.img -rf
48891205f1dSJoseph Chen	echo "pack uboot okay! Input: u-boot.bin"
489de9a6cd2SJoseph Chen}
490de9a6cd2SJoseph Chen
4917c3ca500SJoseph Chenfunction pack_uboot_itb_image()
492daa3bef5SJoseph Chen{
4937c3ca500SJoseph Chen	if [ "$ARM64_TRUSTZONE" = "y" ]; then
4940d0d4395SJoseph Chen		ini=${RKBIN}/RKTRUST/${RKCHIP_TRUST}${PLATFORM_AARCH32}TRUST.ini
4950d0d4395SJoseph Chen	else
4960d0d4395SJoseph Chen		ini=${RKBIN}/RKTRUST/${RKCHIP_TRUST}TOS.ini
4977c3ca500SJoseph Chen	fi
4987c3ca500SJoseph Chen
4997c3ca500SJoseph Chen	if [ ! -f $ini ]; then
5007c3ca500SJoseph Chen		echo "pack trust failed! Can't find: $ini"
5010d0d4395SJoseph Chen		return
5020d0d4395SJoseph Chen	fi
5030d0d4395SJoseph Chen
5047c3ca500SJoseph Chen	if [ "$ARM64_TRUSTZONE" = "y" ]; then
5057c3ca500SJoseph Chen		bl31=`sed -n '/_bl31_/s/PATH=//p' $ini |tr -d '\r'`
5067c3ca500SJoseph Chen		cp ${RKBIN}/${bl31} bl31.elf
5077c3ca500SJoseph Chen		make CROSS_COMPILE=${TOOLCHAIN_GCC} u-boot.itb
5087c3ca500SJoseph Chen		echo "pack u-boot.itb okay! Input: $ini"
5090d0d4395SJoseph Chen	else
5107c3ca500SJoseph Chen		tos_image=`sed -n "/TOS=/s/TOS=//p" $ini |tr -d '\r'`
5117c3ca500SJoseph Chen		tosta_image=`sed -n "/TOSTA=/s/TOSTA=//p" $ini |tr -d '\r'`
5127c3ca500SJoseph Chen		if [ $tosta_image ]; then
5137c3ca500SJoseph Chen			cp ${RKBIN}/${tosta_image} tee.bin
5147c3ca500SJoseph Chen		elif [ $tos_image ]; then
5157c3ca500SJoseph Chen			cp ${RKBIN}/${tos_image}   tee.bin
5167c3ca500SJoseph Chen		else
5177c3ca500SJoseph Chen			echo "ERROR: No any tee bin"
5180d0d4395SJoseph Chen			exit 1
5190d0d4395SJoseph Chen		fi
5200d0d4395SJoseph Chen
5217c3ca500SJoseph Chen		tee_offset=`sed -n "/ADDR=/s/ADDR=//p" $ini |tr -d '\r'`
5227c3ca500SJoseph Chen		if [ "$tee_offset" = "" ]; then
5237c3ca500SJoseph Chen			tee_offset=0x8400000
524d13b75e1SJoseph Chen		fi
525d13b75e1SJoseph Chen
526*85101532SJoseph Chen		mcu_enabled=`awk -F"," '/MCU=/ { printf $3 }' $ini | tr -d ' '`
527*85101532SJoseph Chen		if [ "$mcu_enabled" = "enabled" ]; then
528*85101532SJoseph Chen			mcu_image=`awk -F"," '/MCU=/ { printf $1 }' $ini | tr -d ' ' | cut -c 5-`
529*85101532SJoseph Chen			mcu_offset=`awk -F"," '/MCU=/ { printf $2 }' $ini | tr -d ' '`
530*85101532SJoseph Chen			cp ${RKBIN}/${mcu_image} mcu.bin
531*85101532SJoseph Chen		fi
532*85101532SJoseph Chen
533db3b6a92SJoseph Chen		SPL_FIT_SOURCE=`sed -n "/CONFIG_SPL_FIT_SOURCE=/s/CONFIG_SPL_FIT_SOURCE=//p" .config | tr -d '""'`
534db3b6a92SJoseph Chen		if [ ! -z $SPL_FIT_SOURCE ]; then
535db3b6a92SJoseph Chen			cp $SPL_FIT_SOURCE u-boot.its
536db3b6a92SJoseph Chen		else
537db3b6a92SJoseph Chen			SPL_FIT_GENERATOR=`sed -n "/CONFIG_SPL_FIT_GENERATOR=/s/CONFIG_SPL_FIT_GENERATOR=//p" .config | tr -d '""'`
538*85101532SJoseph Chen			$SPL_FIT_GENERATOR $tee_offset $mcu_offset > u-boot.its
539db3b6a92SJoseph Chen		fi
540d13b75e1SJoseph Chen		./tools/mkimage -f u-boot.its -E u-boot.itb
5417c3ca500SJoseph Chen		echo "pack u-boot.itb okay! Input: $ini"
5420d0d4395SJoseph Chen	fi
543daa3bef5SJoseph Chen}
544daa3bef5SJoseph Chen
5457c3ca500SJoseph Chenfunction pack_spl_loader_image()
546daa3bef5SJoseph Chen{
5477c3ca500SJoseph Chen	mode=$1
5487c3ca500SJoseph Chen	tmp_dir=${RKBIN}/tmp
5497c3ca500SJoseph Chen	tmp_ini=${tmp_dir}/${RKCHIP_LOADER}MINIALL.ini
550dd590c93SJoseph Chen	if [ "$FILE" != "" ]; then
551dd590c93SJoseph Chen		ini=$FILE;
5527c3ca500SJoseph Chen	else
5537c3ca500SJoseph Chen		ini=${RKBIN}/RKBOOT/${RKCHIP_LOADER}MINIALL.ini
554dd590c93SJoseph Chen	fi
5557c3ca500SJoseph Chen	if [ ! -f $ini ]; then
5567c3ca500SJoseph Chen		echo "pack TPL+SPL loader failed! Can't find: $ini"
557daa3bef5SJoseph Chen		return
558daa3bef5SJoseph Chen	fi
559daa3bef5SJoseph Chen
5607c3ca500SJoseph Chen	ls ${tmp_dir} >/dev/null 2>&1 && rm ${tmp_dir} -rf
5617c3ca500SJoseph Chen	mkdir ${tmp_dir} -p
5627c3ca500SJoseph Chen	cp spl/u-boot-spl.bin ${tmp_dir}/
5637c3ca500SJoseph Chen	cp $ini $tmp_ini
564daa3bef5SJoseph Chen	if [ "$mode" = 'spl' ]; then	# pack tpl+spl
565daa3bef5SJoseph Chen		label="TPL+SPL"
5667c3ca500SJoseph Chen		cp tpl/u-boot-tpl.bin ${tmp_dir}/
5677c3ca500SJoseph Chen		header=`sed -n '/NAME=/s/NAME=//p' ${ini}`
5687c3ca500SJoseph Chen		dd if=${tmp_dir}/u-boot-tpl.bin of=${tmp_dir}/tpl.bin bs=1 skip=4
5697c3ca500SJoseph Chen		sed -i "1s/^/${header:0:4}/" ${tmp_dir}/tpl.bin
5707c3ca500SJoseph Chen		sed -i "s/FlashData=.*$/FlashData=.\/tmp\/tpl.bin/" $tmp_ini
5717c3ca500SJoseph Chen	else
5727c3ca500SJoseph Chen		label="SPL"
573daa3bef5SJoseph Chen	fi
574daa3bef5SJoseph Chen
5757c3ca500SJoseph Chen	sed -i "s/FlashBoot=.*$/FlashBoot=.\/tmp\/u-boot-spl.bin/" $tmp_ini
5767c3ca500SJoseph Chen	cd ${RKBIN}
5777c3ca500SJoseph Chen	${RKTOOLS}/boot_merger $tmp_ini
5787c3ca500SJoseph Chen	rm ${tmp_dir} -rf
579daa3bef5SJoseph Chen	cd -
580daa3bef5SJoseph Chen	ls *_loader_*.bin >/dev/null 2>&1 && rm *_loader_*.bin
581b4e157ffSJoseph Chen	mv ${RKBIN}/*_loader_*.bin ./
5827c3ca500SJoseph Chen
583aa8ddc58SJoseph Chen	filename=`basename *_loader_*.bin`
584aa8ddc58SJoseph Chen	if [[ $filename != *spl* ]]; then
585b4e157ffSJoseph Chen		rename 's/loader_/spl_loader_/' *_loader_*.bin
586aa8ddc58SJoseph Chen	fi
5877c3ca500SJoseph Chen	echo "pack loader(${label}) okay! Input: $ini"
588daa3bef5SJoseph Chen}
589daa3bef5SJoseph Chen
5907c3ca500SJoseph Chenfunction pack_loader_image()
591cd7ae718SJoseph Chen{
5928f53a15cSJoseph Chen	if [ "$PACK_FORMAT" != "rk" ]; then
5938f53a15cSJoseph Chen		return
5948f53a15cSJoseph Chen	fi
5958f53a15cSJoseph Chen
596dd590c93SJoseph Chen	if [ "$FILE" != "" ]; then
597dd590c93SJoseph Chen		ini=$FILE;
5987c3ca500SJoseph Chen	else
5997c3ca500SJoseph Chen		ini=${RKBIN}/RKBOOT/${RKCHIP_LOADER}MINIALL.ini
600dd590c93SJoseph Chen	fi
601dd590c93SJoseph Chen
6020436a29dSJoseph Chen	if [ ! -f $ini ]; then
6030436a29dSJoseph Chen		echo "pack loader failed! Can't find: $ini"
60451441a28SJoseph Chen		return
60551441a28SJoseph Chen	fi
60651441a28SJoseph Chen
607224307feSJoseph Chen	ls *_loader_*.bin >/dev/null 2>&1 && rm *_loader_*.bin
608783f7f6eSJoseph Chen
609783f7f6eSJoseph Chen	numline=`cat $ini | wc -l`
610783f7f6eSJoseph Chen	if [ $numline -eq 1 ]; then
611783f7f6eSJoseph Chen		image=`sed -n "/PATH=/p" $ini | tr -d '\r' | cut -d '=' -f 2`
612783f7f6eSJoseph Chen		cp ${RKBIN}/${image} ./
6137c3ca500SJoseph Chen	else
614cd7ae718SJoseph Chen		cd ${RKBIN}
6157c3ca500SJoseph Chen		${RKTOOLS}/boot_merger $ini
616fb90bd1dSJoseph Chen		cd - && mv ${RKBIN}/*_loader_*.bin ./
6177c3ca500SJoseph Chen	fi
6187c3ca500SJoseph Chen
61969b6e590SJoseph Chen	file=`ls *loader*.bin`
62069b6e590SJoseph Chen	echo "pack $file okay! Input: $ini"
621cd7ae718SJoseph Chen}
622cd7ae718SJoseph Chen
6237c3ca500SJoseph Chenfunction pack_arm32_trust_image()
624cd7ae718SJoseph Chen{
6257c3ca500SJoseph Chen	ini=$1
6267c3ca500SJoseph Chen	tos_image=`sed -n "/TOS=/s/TOS=//p" $ini |tr -d '\r'`
6277c3ca500SJoseph Chen	tosta_image=`sed -n "/TOSTA=/s/TOSTA=//p" $ini |tr -d '\r'`
6287c3ca500SJoseph Chen	tee_output=`sed -n "/OUTPUT=/s/OUTPUT=//p" $ini |tr -d '\r'`
6297c3ca500SJoseph Chen	if [ "$tee_output" = "" ]; then
6307c3ca500SJoseph Chen		tee_output="./trust.img"
63151441a28SJoseph Chen	fi
6327c3ca500SJoseph Chen	tee_offset=`sed -n "/ADDR=/s/ADDR=//p" $ini |tr -d '\r'`
6337c3ca500SJoseph Chen	if [ "$tee_offset" = "" ]; then
6347c3ca500SJoseph Chen		tee_offset=0x8400000
63551441a28SJoseph Chen	fi
63651441a28SJoseph Chen
637cd7ae718SJoseph Chen	# OP-TEE is 132M(0x8400000) offset from DRAM base.
638eee9fb0aSJoseph Chen	dram_base=`sed -n "/CONFIG_SYS_SDRAM_BASE=/s/CONFIG_SYS_SDRAM_BASE=//p" include/autoconf.mk|tr -d '\r'`
6397c3ca500SJoseph Chen	tee_load_addr=$((dram_base+tee_offset))
6407c3ca500SJoseph Chen	tee_load_addr=$(echo "obase=16;${tee_load_addr}"|bc) # Convert Dec to Hex
6410e90839aSJoseph Chen
6427c3ca500SJoseph Chen	if [ $tosta_image ]; then
6437c3ca500SJoseph Chen		${RKTOOLS}/loaderimage --pack --trustos ${RKBIN}/${tosta_image} ${tee_output} ${tee_load_addr} ${PLATFORM_TRUST_IMG_SIZE}
6447c3ca500SJoseph Chen	elif [ $tos_image ]; then
6457c3ca500SJoseph Chen		${RKTOOLS}/loaderimage --pack --trustos ${RKBIN}/${tos_image}   ${tee_output} ${tee_load_addr} ${PLATFORM_TRUST_IMG_SIZE}
646cd7ae718SJoseph Chen	else
6477c3ca500SJoseph Chen		echo "ERROR: No any tee bin"
648a64486b5SJoseph Chen		exit 1
649cd7ae718SJoseph Chen	fi
6507c3ca500SJoseph Chen	echo "pack trust okay! Input: $ini"
65169cce37bSJoseph Chen}
65269cce37bSJoseph Chen
6537c3ca500SJoseph Chenfunction pack_arm64_trust_image()
65469cce37bSJoseph Chen{
6557c3ca500SJoseph Chen	ini=$1
65669cce37bSJoseph Chen	cd ${RKBIN}
6577c3ca500SJoseph Chen	${RKTOOLS}/trust_merger ${PLATFORM_SHA} ${PLATFORM_RSA} ${PLATFORM_TRUST_IMG_SIZE} $ini
65869cce37bSJoseph Chen	cd - && mv ${RKBIN}/trust*.img ./
6597c3ca500SJoseph Chen	echo "pack trust okay! Input: $ini"
66069cce37bSJoseph Chen}
66169cce37bSJoseph Chen
6627c3ca500SJoseph Chenfunction pack_trust_image()
66369cce37bSJoseph Chen{
6648f53a15cSJoseph Chen	if [ "$PACK_FORMAT" != "rk" ]; then
6658f53a15cSJoseph Chen		return
6668f53a15cSJoseph Chen	fi
6678f53a15cSJoseph Chen
668cd623926SJoseph Chen	ls trust*.img >/dev/null 2>&1 && rm trust*.img
669dd590c93SJoseph Chen	if [ "$FILE" != "" ]; then
670dd590c93SJoseph Chen		ini=$FILE;
6717c3ca500SJoseph Chen	else
6727c3ca500SJoseph Chen		if [ "$ARM64_TRUSTZONE" = "y" ]; then
6737c3ca500SJoseph Chen			ini=${RKBIN}/RKTRUST/${RKCHIP_TRUST}TRUST.ini
6747c3ca500SJoseph Chen		else
6757c3ca500SJoseph Chen			ini=${RKBIN}/RKTRUST/${RKCHIP_TRUST}TOS.ini
6767c3ca500SJoseph Chen		fi
6777c3ca500SJoseph Chen	fi
6787c3ca500SJoseph Chen	if [ ! -f $ini ]; then
6797c3ca500SJoseph Chen		echo "pack trust failed! Can't find: $ini"
6807c3ca500SJoseph Chen		return
681dd590c93SJoseph Chen	fi
682dd590c93SJoseph Chen
683783f7f6eSJoseph Chen	numline=`cat $ini | wc -l`
684783f7f6eSJoseph Chen	if [ $numline -eq 1 ]; then
685783f7f6eSJoseph Chen		image=`sed -n "/PATH=/p" $ini | tr -d '\r' | cut -d '=' -f 2`
686783f7f6eSJoseph Chen		cp ${RKBIN}/${image} ./trust.img
6877c3ca500SJoseph Chen		echo "pack trust okay! Input: $ini"
688783f7f6eSJoseph Chen		return;
68969cce37bSJoseph Chen	else
6907c3ca500SJoseph Chen		if [ "$ARM64_TRUSTZONE" = "y" ]; then
6917c3ca500SJoseph Chen			pack_arm64_trust_image $ini
6927c3ca500SJoseph Chen		else
6937c3ca500SJoseph Chen			pack_arm32_trust_image $ini
694dd590c93SJoseph Chen		fi
695cd7ae718SJoseph Chen	fi
696cd7ae718SJoseph Chen}
697cd7ae718SJoseph Chen
6988f53a15cSJoseph Chenfunction pack_fit_image()
6998f53a15cSJoseph Chen{
7008f53a15cSJoseph Chen	./scripts/fit-vboot-uboot.sh --no-vboot --no-rebuild
7018f53a15cSJoseph Chen	ls uboot.img trust*.img >/dev/null 2>&1 && rm uboot.img trust*.img -rf
7028f53a15cSJoseph Chen	echo "pack uboot.img (with uboot trust) okay! Input: $ini"
7038f53a15cSJoseph Chen}
7048f53a15cSJoseph Chen
7058f53a15cSJoseph Chenfunction pack_images()
7068f53a15cSJoseph Chen{
7078f53a15cSJoseph Chen	if [ "$NOPACK" != "y" ]; then
7088f53a15cSJoseph Chen		if [ "$PACK_FORMAT" = "rk" ]; then
7098f53a15cSJoseph Chen			pack_uboot_image
7108f53a15cSJoseph Chen			pack_trust_image
7118f53a15cSJoseph Chen			pack_loader_image
7128f53a15cSJoseph Chen		elif [ "$PACK_FORMAT" = "fit" ]; then
7138f53a15cSJoseph Chen			pack_fit_image
7148f53a15cSJoseph Chen		fi
7158f53a15cSJoseph Chen	fi
7168f53a15cSJoseph Chen}
7178f53a15cSJoseph Chen
7188f53a15cSJoseph Chenfunction clean_files()
7198f53a15cSJoseph Chen{
7208f53a15cSJoseph Chen	if [ -f spl/u-boot-spl.dtb ]; then
7218f53a15cSJoseph Chen		rm spl/u-boot-spl.dtb
7228f53a15cSJoseph Chen	fi
7238f53a15cSJoseph Chen	if [ -f tpl/u-boot-tpl.dtb ]; then
7248f53a15cSJoseph Chen		rm tpl/u-boot-tpl.dtb
7258f53a15cSJoseph Chen	fi
7268f53a15cSJoseph Chen	if [ -f u-boot.dtb ]; then
7278f53a15cSJoseph Chen		rm u-boot.dtb
7288f53a15cSJoseph Chen	fi
7298f53a15cSJoseph Chen}
7308f53a15cSJoseph Chen
7317c3ca500SJoseph Chenfunction finish()
73230b04afcSJoseph Chen{
73330b04afcSJoseph Chen	echo
734622ccf34SJoseph Chen	if [ ! -z "$OPTION" ]; then
735622ccf34SJoseph Chen		echo "Platform ${RKCHIP_LABEL} is build OK, with exist .config ($OPTION)"
736622ccf34SJoseph Chen	elif [ "$BOARD" = '' ]; then
7375202fe1fSJoseph Chen		echo "Platform ${RKCHIP_LABEL} is build OK, with exist .config"
73830b04afcSJoseph Chen	else
7395202fe1fSJoseph Chen		echo "Platform ${RKCHIP_LABEL} is build OK, with new .config(make ${BOARD}_defconfig)"
74030b04afcSJoseph Chen	fi
74130b04afcSJoseph Chen}
74230b04afcSJoseph Chen
743cd7ae718SJoseph Chenprepare
7447c2526e9SJoseph Chenselect_toolchain
745de440615SJoseph Chenselect_chip_info
74641cf5e5aSJoseph Chenfixup_platform_configure
7470ff0e214SJoseph Chensub_commands
7488f53a15cSJoseph Chenclean_files
749622ccf34SJoseph Chenmake CROSS_COMPILE=${TOOLCHAIN_GCC} ${OPTION} all --jobs=${JOB}
7508f53a15cSJoseph Chenpack_images
75130b04afcSJoseph Chenfinish
752