xref: /rk3399_rockchip-uboot/make.sh (revision 6cf81e2732591420adf8f9bc905a2103e7b8a603)
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 ChenBIN_PATH_FIXUP="--replace tools/rk_tools/ ./"
7623ba6841SJoseph ChenRKTOOLS=./tools
7723ba6841SJoseph Chen
78de440615SJoseph Chen# Declare global INI file searching index name for every chip, update in select_chip_info()
790583701dSJoseph ChenRKCHIP="-"
800583701dSJoseph ChenRKCHIP_LABEL="-"
810583701dSJoseph ChenRKCHIP_LOADER="-"
820583701dSJoseph ChenRKCHIP_TRUST="-"
83d443b7d5SJoseph 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=
89fb90bd1dSJoseph ChenTOOLCHAIN_OBJDUMP=
9053ea5791SJoseph ChenTOOLCHAIN_ADDR2LINE=
91fb90bd1dSJoseph Chen
92fb90bd1dSJoseph Chen# Declare global default output dir and cmd, update in prepare()
93622ccf34SJoseph ChenOPTION=
94bc98b3c8SJoseph Chen
9541cf5e5aSJoseph Chen# Declare global plaform configure, updated in fixup_platform_configure()
9641cf5e5aSJoseph ChenPLATFORM_RSA=
9741cf5e5aSJoseph ChenPLATFORM_SHA=
9841cf5e5aSJoseph ChenPLATFORM_UBOOT_IMG_SIZE=
9941cf5e5aSJoseph ChenPLATFORM_TRUST_IMG_SIZE=
1002ba1365eSJoseph Chen
101aa8ddc58SJoseph ChenPACK_FORMAT="rk"
102aa8ddc58SJoseph Chen
1032ba1365eSJoseph Chen# Out env param
1042ba1365eSJoseph ChenPACK_IGNORE_BL32=$TRUST_PACK_IGNORE_BL32	# Value only: "--ignore-bl32"
105fb90bd1dSJoseph Chen#########################################################################################################
106b6255198SJoseph Chenhelp()
107b6255198SJoseph Chen{
108b6255198SJoseph Chen	echo
1096a764259SJoseph Chen	echo "Usage:"
110622ccf34SJoseph Chen	echo "	./make.sh [board|subcmd|EXT_DTB=<file>]"
1116a764259SJoseph Chen	echo
1126a764259SJoseph Chen	echo "	 - board:   board name of defconfig"
113622ccf34SJoseph Chen	echo "	 - subcmd:  |elf*|loader*|spl*|itb|trust*|uboot|map|sym|<addr>|EXT_DTB=*"
114f3d60245SJoseph Chen	echo "	 - ini:     assigned ini file to pack trust/loader"
115f3d60245SJoseph Chen	echo
116f3d60245SJoseph Chen	echo "Output:"
117f3d60245SJoseph Chen	echo "	 When board built okay, there are uboot/trust/loader images in current directory"
118b6255198SJoseph Chen	echo
119b6255198SJoseph Chen	echo "Example:"
120b6255198SJoseph Chen	echo
121d6821889SJoseph Chen	echo "1. Build:"
122fc99e044SJoseph Chen	echo "	./make.sh evb-rk3399               --- build for evb-rk3399_defconfig"
123fc99e044SJoseph Chen	echo "	./make.sh firefly-rk3288           --- build for firefly-rk3288_defconfig"
124622ccf34SJoseph Chen	echo "	./make.sh EXT_DTB=rk-kernel.dtb    --- build with exist .config and external dtb"
125fc99e044SJoseph Chen	echo "	./make.sh                          --- build with exist .config"
126398d3e80SJoseph Chen	echo "	./make.sh env                      --- build envtools"
127b6255198SJoseph Chen	echo
128d6821889SJoseph Chen	echo "2. Pack:"
1296a764259SJoseph Chen	echo "	./make.sh uboot                    --- pack uboot.img"
13069cce37bSJoseph Chen	echo "	./make.sh trust                    --- pack trust.img"
131f3d60245SJoseph Chen	echo "	./make.sh trust <ini>              --- pack trust img with assigned ini file"
1326a764259SJoseph Chen	echo "	./make.sh loader                   --- pack loader bin"
133f3d60245SJoseph Chen	echo "	./make.sh loader <ini>             --- pack loader img with assigned ini file"
134f3d60245SJoseph Chen	echo "	./make.sh spl                      --- pack loader with u-boot-spl.bin and u-boot-tpl.bin"
135f3d60245SJoseph Chen	echo "	./make.sh spl-s                    --- pack loader only replace miniloader with u-boot-spl.bin"
136f3d60245SJoseph Chen	echo "	./make.sh itb                      --- pack u-boot.itb(TODO: bl32 is not included for ARMv8)"
137b6255198SJoseph Chen	echo
138d6821889SJoseph Chen	echo "3. Debug:"
139b6255198SJoseph Chen	echo "	./make.sh elf                      --- dump elf file with -D(default)"
140b6255198SJoseph Chen	echo "	./make.sh elf-S                    --- dump elf file with -S"
1416a764259SJoseph Chen	echo "	./make.sh elf-d                    --- dump elf file with -d"
142f3d60245SJoseph Chen	echo "	./make.sh elf-*                    --- dump elf file with -*"
143fc99e044SJoseph Chen	echo "	./make.sh <no reloc_addr>          --- dump function symbol and code position of address(no relocated)"
144fc99e044SJoseph Chen	echo "	./make.sh <reloc_addr-reloc_off>   --- dump function symbol and code position of address(relocated)"
145b6255198SJoseph Chen	echo "	./make.sh map                      --- cat u-boot.map"
146b6255198SJoseph Chen	echo "	./make.sh sym                      --- cat u-boot.sym"
147b6255198SJoseph Chen}
14841cf5e5aSJoseph Chen
149cd7ae718SJoseph Chenprepare()
150cd7ae718SJoseph Chen{
151b6255198SJoseph Chen	local absolute_path cmd dir count
15230b04afcSJoseph Chen
153b6255198SJoseph Chen	case $BOARD in
15453ea5791SJoseph Chen		# Parse from exit .config
15569b6e590SJoseph Chen		''|elf*|loader*|spl*|itb|debug*|trust|uboot|map|sym|env|EXT_DTB=*|fit*)
156d6821889SJoseph Chen		if [ ! -f .config ]; then
157b6255198SJoseph Chen			echo
158b6255198SJoseph Chen			echo "Build failed, Can't find .config"
159b6255198SJoseph Chen			help
160b6255198SJoseph Chen			exit 1
161b6255198SJoseph Chen		fi
162b6255198SJoseph Chen		;;
163b6255198SJoseph Chen	esac
164cd7ae718SJoseph Chen
165b6255198SJoseph Chen	# Parse help and make defconfig
166b6255198SJoseph Chen	case $BOARD in
16753ea5791SJoseph Chen		#Help
168b6255198SJoseph Chen		--help|-help|help|--h|-h)
169b6255198SJoseph Chen		help
170b6255198SJoseph Chen		exit 0
171b6255198SJoseph Chen		;;
17253ea5791SJoseph Chen
17353ea5791SJoseph Chen		#Subcmd
17469b6e590SJoseph Chen		''|elf*|loader*|spl*|itb|debug*|trust*|uboot|map|sym|env|EXT_DTB=*|fit*)
175b6255198SJoseph Chen		;;
176b6255198SJoseph Chen
177b6255198SJoseph Chen		*)
17853ea5791SJoseph Chen		#Func address is valid ?
179fc99e044SJoseph Chen		if [ -z $(echo ${FUNCADDR} | sed 's/[0-9,a-f,A-F,x,X,-]//g') ]; then
18053ea5791SJoseph Chen			return
18153ea5791SJoseph Chen		elif [ ! -f configs/${BOARD}_defconfig ]; then
18230b04afcSJoseph Chen			echo
183cd7ae718SJoseph Chen			echo "Can't find: configs/${BOARD}_defconfig"
1847c19369dSJoseph Chen			echo
18530b04afcSJoseph Chen			echo "******** Rockchip Support List *************"
18630b04afcSJoseph Chen			echo "${SUPPORT_LIST}"
1877c19369dSJoseph Chen			echo "********************************************"
1887c19369dSJoseph Chen			echo
189cd7ae718SJoseph Chen			exit 1
190b6255198SJoseph Chen		else
191b6255198SJoseph Chen			echo "make for ${BOARD}_defconfig by -j${JOB}"
192622ccf34SJoseph Chen			make ${BOARD}_defconfig ${OPTION}
193cd7ae718SJoseph Chen		fi
194b6255198SJoseph Chen		;;
195b6255198SJoseph Chen	esac
196cd7ae718SJoseph Chen
19723ba6841SJoseph Chen	# Initialize RKBIN
198bc98b3c8SJoseph Chen	if [ -d ${RKBIN_TOOLS} ]; then
199bc98b3c8SJoseph Chen		absolute_path=$(cd `dirname ${RKBIN_TOOLS}`; pwd)
200bc98b3c8SJoseph Chen		RKBIN=${absolute_path}
201cd7ae718SJoseph Chen	else
202cd7ae718SJoseph Chen		echo
203fb90bd1dSJoseph Chen		echo "Can't find '../rkbin/' repository, please download it before pack image!"
204cd7ae718SJoseph Chen		echo "How to obtain? 3 ways:"
205fb90bd1dSJoseph Chen		echo "	1. Login your Rockchip gerrit account: \"Projects\" -> \"List\" -> search \"rk/rkbin\" repository"
206fb90bd1dSJoseph Chen		echo "	2. Github repository: https://github.com/rockchip-linux/rkbin"
207fb90bd1dSJoseph Chen		echo "	3. Download full release SDK repository"
208cd7ae718SJoseph Chen		exit 1
209cd7ae718SJoseph Chen	fi
21069b6e590SJoseph Chen
21169b6e590SJoseph Chen	if grep  -q '^CONFIG_ROCKCHIP_FIT_IMAGE_PACK=y' .config ; then
21269b6e590SJoseph Chen		PACK_FORMAT="fit"
21369b6e590SJoseph Chen	fi
21430b04afcSJoseph Chen}
2157c2526e9SJoseph Chen
21627a50c86SAndy Yanselect_toolchain()
21727a50c86SAndy Yan{
218bc98b3c8SJoseph Chen	local absolute_path
219bc98b3c8SJoseph Chen
220d6821889SJoseph Chen	if grep  -q '^CONFIG_ARM64=y' .config ; then
221bc98b3c8SJoseph Chen		if [ -d ${TOOLCHAIN_ARM64} ]; then
222bc98b3c8SJoseph Chen			absolute_path=$(cd `dirname ${TOOLCHAIN_ARM64}`; pwd)
223bc98b3c8SJoseph Chen			TOOLCHAIN_GCC=${absolute_path}/bin/${GCC_ARM64}
2240ff0e214SJoseph Chen			TOOLCHAIN_OBJDUMP=${absolute_path}/bin/${OBJ_ARM64}
22553ea5791SJoseph Chen			TOOLCHAIN_ADDR2LINE=${absolute_path}/bin/${ADDR2LINE_ARM64}
226bc98b3c8SJoseph Chen		else
227366bd23fSJoseph Chen			echo "Can't find toolchain: ${TOOLCHAIN_ARM64}"
228bc98b3c8SJoseph Chen			exit 1
22927a50c86SAndy Yan		fi
23027a50c86SAndy Yan	else
231bc98b3c8SJoseph Chen		if [ -d ${TOOLCHAIN_ARM32} ]; then
232bc98b3c8SJoseph Chen			absolute_path=$(cd `dirname ${TOOLCHAIN_ARM32}`; pwd)
233bc98b3c8SJoseph Chen			TOOLCHAIN_GCC=${absolute_path}/bin/${GCC_ARM32}
2340ff0e214SJoseph Chen			TOOLCHAIN_OBJDUMP=${absolute_path}/bin/${OBJ_ARM32}
23553ea5791SJoseph Chen			TOOLCHAIN_ADDR2LINE=${absolute_path}/bin/${ADDR2LINE_ARM32}
236bc98b3c8SJoseph Chen		else
237366bd23fSJoseph Chen			echo "Can't find toolchain: ${TOOLCHAIN_ARM32}"
238bc98b3c8SJoseph Chen			exit 1
23927a50c86SAndy Yan		fi
24027a50c86SAndy Yan	fi
241bc98b3c8SJoseph Chen
24253ea5791SJoseph Chen	# echo "toolchain: ${TOOLCHAIN_GCC}"
243bc98b3c8SJoseph Chen}
244bc98b3c8SJoseph Chen
2450ff0e214SJoseph Chensub_commands()
2460ff0e214SJoseph Chen{
2475c75ab41SJoseph Chen	local cmd=${SUBCMD%-*} opt=${SUBCMD#*-}
248d6821889SJoseph Chen	local elf=u-boot map=u-boot.map sym=u-boot.sym
24934bdfea0SJoseph Chen
25034bdfea0SJoseph Chen	if [ "$FILE" == "tpl" -o "$FILE" == "spl" ]; then
25134bdfea0SJoseph Chen		elf=`find -name u-boot-${FILE}`
25234bdfea0SJoseph Chen		map=`find -name u-boot-${FILE}.map`
25334bdfea0SJoseph Chen		sym=`find -name u-boot-${FILE}.sym`
25434bdfea0SJoseph Chen	fi
2550ff0e214SJoseph Chen
256b6255198SJoseph Chen	case $cmd in
257b6255198SJoseph Chen		elf)
25834bdfea0SJoseph Chen		if [ -o ! -f ${elf} ]; then
25934bdfea0SJoseph Chen			echo "Can't find elf file: ${elf}"
2600ff0e214SJoseph Chen			exit 1
2610ff0e214SJoseph Chen		else
262b6255198SJoseph Chen			# default 'cmd' without option, use '-D'
2635c75ab41SJoseph Chen			if [ "${cmd}" = 'elf' -a "${opt}" = 'elf' ]; then
2645c75ab41SJoseph Chen				opt=D
2650ff0e214SJoseph Chen			fi
26634bdfea0SJoseph Chen			${TOOLCHAIN_OBJDUMP} -${opt} ${elf} | less
26707de173aSJoseph Chen			exit 0
26807de173aSJoseph Chen		fi
269b6255198SJoseph Chen		;;
270b6255198SJoseph Chen
2711b6c85a0SJoseph Chen		debug)
272fcccd23aSJoseph Chen		./scripts/rkpatch.sh ${opt}
2731b6c85a0SJoseph Chen		exit 0
2741b6c85a0SJoseph Chen		;;
2751b6c85a0SJoseph Chen
27669b6e590SJoseph Chen		fit)
277*6cf81e27SJoseph Chen		if [ "$opt" = "s" ]; then
278*6cf81e27SJoseph Chen			./scripts/fit-vboot.sh
279*6cf81e27SJoseph Chen		else
280*6cf81e27SJoseph Chen			./scripts/fit-vboot.sh --no-vboot
281*6cf81e27SJoseph Chen		fi
28269b6e590SJoseph Chen		exit 0
28369b6e590SJoseph Chen		;;
28469b6e590SJoseph Chen
285b6255198SJoseph Chen		map)
28634bdfea0SJoseph Chen		cat ${map} | less
287b6255198SJoseph Chen		exit 0
288b6255198SJoseph Chen		;;
289b6255198SJoseph Chen
290b6255198SJoseph Chen		sym)
29134bdfea0SJoseph Chen		cat ${sym} | less
292b6255198SJoseph Chen		exit 0
293b6255198SJoseph Chen		;;
294b6255198SJoseph Chen
295b6255198SJoseph Chen		trust)
296d6e1155eSJoseph Chen		pack_trust_image
297a43a18b2SJoseph Chen		exit 0
298b6255198SJoseph Chen		;;
299b6255198SJoseph Chen
300b6255198SJoseph Chen		loader)
301d6e1155eSJoseph Chen		pack_loader_image
302a43a18b2SJoseph Chen		exit 0
303b6255198SJoseph Chen		;;
304b6255198SJoseph Chen
305daa3bef5SJoseph Chen		spl)
306daa3bef5SJoseph Chen		pack_spl_loader_image ${opt}
307daa3bef5SJoseph Chen		exit 0
308daa3bef5SJoseph Chen		;;
309daa3bef5SJoseph Chen
310daa3bef5SJoseph Chen		itb)
311daa3bef5SJoseph Chen		pack_uboot_itb_image
312daa3bef5SJoseph Chen		exit 0
313daa3bef5SJoseph Chen		;;
314daa3bef5SJoseph Chen
315b6255198SJoseph Chen		uboot)
31669cce37bSJoseph Chen		pack_uboot_image ${opt}
317fb90bd1dSJoseph Chen		exit 0
318b6255198SJoseph Chen		;;
319b6255198SJoseph Chen
320398d3e80SJoseph Chen		env)
321398d3e80SJoseph Chen		make CROSS_COMPILE=${TOOLCHAIN_GCC} envtools
322398d3e80SJoseph Chen		exit 0
323398d3e80SJoseph Chen		;;
324398d3e80SJoseph Chen
325622ccf34SJoseph Chen		EXT_DTB=*)
326622ccf34SJoseph Chen		OPTION=${SUBCMD}
327622ccf34SJoseph Chen		;;
328622ccf34SJoseph Chen
329b6255198SJoseph Chen		*)
33053ea5791SJoseph Chen		# Search function and code position of address
331fc99e044SJoseph Chen		RELOC_OFF=${FUNCADDR#*-}
332fc99e044SJoseph Chen		FUNCADDR=${FUNCADDR%-*}
333fc99e044SJoseph Chen		if [ -z $(echo ${FUNCADDR} | sed 's/[0-9,a-f,A-F,x,X,-]//g') ] && [ ${FUNCADDR} ]; then
3347070f875SJoseph Chen			# With prefix: '0x' or '0X'
3357070f875SJoseph Chen			if [ `echo ${FUNCADDR} | sed -n "/0[x,X]/p" | wc -l` -ne 0 ]; then
3367070f875SJoseph Chen				FUNCADDR=`echo $FUNCADDR | awk '{ print strtonum($0) }'`
3377070f875SJoseph Chen				FUNCADDR=`echo "obase=16;${FUNCADDR}"|bc |tr '[A-Z]' '[a-z]'`
3387070f875SJoseph Chen			fi
339fc99e044SJoseph Chen			if [ `echo ${RELOC_OFF} | sed -n "/0[x,X]/p" | wc -l` -ne 0 ] && [ ${RELOC_OFF} ]; then
340fc99e044SJoseph Chen				RELOC_OFF=`echo $RELOC_OFF | awk '{ print strtonum($0) }'`
341fc99e044SJoseph Chen				RELOC_OFF=`echo "obase=16;${RELOC_OFF}"|bc |tr '[A-Z]' '[a-z]'`
342fc99e044SJoseph Chen			fi
343fc99e044SJoseph Chen
344fc99e044SJoseph Chen			# If reloc address is assigned, do sub
345fc99e044SJoseph Chen			if [ "${FUNCADDR}" != "${RELOC_OFF}" ]; then
346fc99e044SJoseph Chen				# Hex -> Dec -> SUB -> Hex
347fc99e044SJoseph Chen				FUNCADDR=`echo $((16#${FUNCADDR}))`
348fc99e044SJoseph Chen				RELOC_OFF=`echo $((16#${RELOC_OFF}))`
349fc99e044SJoseph Chen				FUNCADDR=$((FUNCADDR-RELOC_OFF))
350fc99e044SJoseph Chen				FUNCADDR=$(echo "obase=16;${FUNCADDR}"|bc |tr '[A-Z]' '[a-z]')
351fc99e044SJoseph Chen			fi
3527070f875SJoseph Chen
35353ea5791SJoseph Chen			echo
35434bdfea0SJoseph Chen			sed -n "/${FUNCADDR}/p" ${sym}
35534bdfea0SJoseph Chen			${TOOLCHAIN_ADDR2LINE} -e ${elf} ${FUNCADDR}
35653ea5791SJoseph Chen			exit 0
35753ea5791SJoseph Chen		fi
358b6255198SJoseph Chen		;;
359b6255198SJoseph Chen	esac
3600ff0e214SJoseph Chen}
3610ff0e214SJoseph Chen
362de440615SJoseph Chen# We select chip info to do:
363de440615SJoseph Chen#	1. RKCHIP: fixup platform configure
364de440615SJoseph Chen#	2. RKCHIP_LOADER: search ini file to pack loader
365de440615SJoseph Chen#	3. RKCHIP_TRUST: search ini file to pack trust
366de440615SJoseph Chen#	4. RKCHIP_LABEL: show build message
367de440615SJoseph Chen#
368de440615SJoseph Chen# We read chip info from .config and 'RKCHIP_INI_DESC'
369de440615SJoseph Chenselect_chip_info()
370bc98b3c8SJoseph Chen{
371de440615SJoseph Chen	# Read RKCHIP firstly from .config
372596700d7SShunqian Zheng	# The regular expression that matching:
373596700d7SShunqian Zheng	#  - PX30, PX3SE
374596700d7SShunqian Zheng	#  - RK????, RK????X
375596700d7SShunqian Zheng	#  - RV????
3760583701dSJoseph Chen	CHIP_PATTERN='^CONFIG_ROCKCHIP_[R,P][X,V,K][0-9ESX]{1,5}'
3770583701dSJoseph Chen	RKCHIP=`egrep -o ${CHIP_PATTERN} .config`
378d443b7d5SJoseph Chen
3790583701dSJoseph Chen	# default
380d443b7d5SJoseph Chen	RKCHIP=${RKCHIP##*_}
38141cf5e5aSJoseph Chen
3820583701dSJoseph Chen	# need fixup ?
3830583701dSJoseph Chen	for ITEM in "${CHIP_TYPE_FIXUP_TABLE[@]}"
384de440615SJoseph Chen	do
3850583701dSJoseph Chen		CONFIG_XXX=`echo $ITEM | awk '{ print $1 }'`
3860583701dSJoseph Chen		if grep  -q "^${CONFIG_XXX}=y" .config ; then
3870583701dSJoseph Chen			RKCHIP=`echo $ITEM | awk '{ print $2 }'`
3880583701dSJoseph Chen			RKCHIP_LOADER=`echo $ITEM | awk '{ print $3 }'`
3890583701dSJoseph Chen			RKCHIP_TRUST=`echo  $ITEM | awk '{ print $4 }'`
3900583701dSJoseph Chen			RKCHIP_LABEL=`echo  $ITEM | awk '{ print $5 }'`
391de440615SJoseph Chen		fi
3920583701dSJoseph Chen	done
3930583701dSJoseph Chen
3940583701dSJoseph Chen	if [ "$RKCHIP_LOADER" = "-" ]; then
3950583701dSJoseph Chen		RKCHIP_LOADER=${RKCHIP}
396de440615SJoseph Chen	fi
3970583701dSJoseph Chen	if [ "$RKCHIP_TRUST" = "-" ]; then
3980583701dSJoseph Chen		RKCHIP_TRUST=${RKCHIP}
3990583701dSJoseph Chen	fi
4000583701dSJoseph Chen	if [ "$RKCHIP_LABEL" = "-" ]; then
4010583701dSJoseph Chen		RKCHIP_LABEL=${RKCHIP}
4020583701dSJoseph Chen	fi
4030583701dSJoseph Chen
4040583701dSJoseph Chen	# echo "## $FUNCNAME: $RKCHIP, $RKCHIP_LOADER, $RKCHIP_TRUST, $RKCHIP_LABEL,"
4050583701dSJoseph Chen}
4060583701dSJoseph Chen
4070583701dSJoseph Chenfunction fixup_platform_configure()
4080583701dSJoseph Chen{
4090583701dSJoseph Chen	CFG_U_KB="-" CFG_U_NUM="-" CFG_T_KB="-" CFG_T_NUM="-"  CFG_SHA="-" CFG_RSA="-"
4100583701dSJoseph Chen
4110583701dSJoseph Chen	for ITEM in "${CHIP_CFG_FIXUP_TABLE[@]}"
4120583701dSJoseph Chen	do
4130583701dSJoseph Chen		CONFIG_XXX=`echo $ITEM | awk '{ print $1 }'`
4140583701dSJoseph Chen		if grep  -q "^${CONFIG_XXX}=y" .config ; then
4150583701dSJoseph Chen			# <*> Fixup rsa/sha pack mode for platforms
4160583701dSJoseph Chen			CFG_RSA=`echo $ITEM | awk '{ print $2 }'`
4170583701dSJoseph Chen			CFG_SHA=`echo $ITEM | awk '{ print $3 }'`
4180583701dSJoseph Chen
4190583701dSJoseph Chen			# <*> Fixup images size pack for platforms, and ini file
4200583701dSJoseph Chen			if grep -q '^CONFIG_ARM64_BOOT_AARCH32=y' .config ; then
4210583701dSJoseph Chen				CFG_U_KB=`echo  $ITEM | awk '{ print $6 }' | awk -F "," '{ print $1 }'`
4220583701dSJoseph Chen				CFG_U_NUM=`echo $ITEM | awk '{ print $7 }' | awk -F "," '{ print $1 }'`
4230583701dSJoseph Chen				CFG_T_KB=`echo  $ITEM | awk '{ print $6 }' | awk -F "," '{ print $2 }'`
4240583701dSJoseph Chen				CFG_T_NUM=`echo $ITEM | awk '{ print $7 }' | awk -F "," '{ print $2 }'`
4250583701dSJoseph Chen
4260583701dSJoseph Chen				PAD_LOADER=`echo $ITEM | awk '{ print $8 }'`
4270583701dSJoseph Chen				PAD_TRUST=`echo  $ITEM | awk '{ print $9 }'`
4280583701dSJoseph Chen				if [ "$PAD_LOADER" != "-" ]; then
4290583701dSJoseph Chen					RKCHIP_LOADER=${RKCHIP_LOADER}${PAD_LOADER}
4300583701dSJoseph Chen				fi
4310583701dSJoseph Chen				if [ "$PAD_TRUST" != "-" ]; then
4320583701dSJoseph Chen					RKCHIP_TRUST=${RKCHIP_TRUST}${PAD_TRUST}
4330583701dSJoseph Chen				fi
4340583701dSJoseph Chen				RKCHIP_LABEL=${RKCHIP_LABEL}"AARCH32"
4350583701dSJoseph Chen			else
4360583701dSJoseph Chen				CFG_U_KB=`echo  $ITEM | awk '{ print $4 }' | awk -F "," '{ print $1 }'`
4370583701dSJoseph Chen				CFG_U_NUM=`echo $ITEM | awk '{ print $5 }' | awk -F "," '{ print $1 }'`
4380583701dSJoseph Chen				CFG_T_KB=`echo  $ITEM | awk '{ print $4 }' | awk -F "," '{ print $2 }'`
4390583701dSJoseph Chen				CFG_T_NUM=`echo $ITEM | awk '{ print $5 }' | awk -F "," '{ print $2 }'`
440de440615SJoseph Chen			fi
441de440615SJoseph Chen		fi
442de440615SJoseph Chen	done
443de440615SJoseph Chen
4440583701dSJoseph Chen	if [ "$CFG_SHA" != "-" ]; then
4450583701dSJoseph Chen		PLATFORM_SHA="--sha $CFG_SHA"
4460583701dSJoseph Chen	fi
4470583701dSJoseph Chen	if [ "$CFG_RSA" != "-" ]; then
4480583701dSJoseph Chen		PLATFORM_RSA="--rsa $CFG_RSA"
4490583701dSJoseph Chen	fi
4500583701dSJoseph Chen	if [ "$CFG_U_KB" != "-" ]; then
4510583701dSJoseph Chen		PLATFORM_UBOOT_IMG_SIZE="--size $CFG_U_KB $CFG_U_NUM"
4520583701dSJoseph Chen	fi
4530583701dSJoseph Chen	if [ "$CFG_T_KB" != "-" ]; then
4540583701dSJoseph Chen		PLATFORM_TRUST_IMG_SIZE="--size $CFG_T_KB $CFG_T_NUM"
45541cf5e5aSJoseph Chen	fi
45641cf5e5aSJoseph Chen
4570583701dSJoseph Chen	# echo "## $FUNCNAME: $PLATFORM_RSA, $PLATFORM_SHA, $PLATFORM_TRUST_IMG_SIZE, $PLATFORM_UBOOT_IMG_SIZE"
4580583701dSJoseph Chen	# echo "## $FUNCNAME: $RKCHIP_LOADER, $RKCHIP_TRUST, $RKCHIP_LABEL"
45927a50c86SAndy Yan}
460de9a6cd2SJoseph Chen
461cd7ae718SJoseph Chenpack_uboot_image()
462de9a6cd2SJoseph Chen{
463f089d907SJoseph Chen	local UBOOT_LOAD_ADDR UBOOT_MAX_KB UBOOT_KB HEAD_KB=2
464de9a6cd2SJoseph Chen
465f089d907SJoseph Chen	# Check file size
466f089d907SJoseph Chen	UBOOT_KB=`ls -l u-boot.bin | awk '{print $5}'`
467f089d907SJoseph Chen	if [ "$PLATFORM_UBOOT_IMG_SIZE" = "" ]; then
468f089d907SJoseph Chen		UBOOT_MAX_KB=1046528
469f089d907SJoseph Chen	else
470f089d907SJoseph Chen		UBOOT_MAX_KB=`echo $PLATFORM_UBOOT_IMG_SIZE | awk '{print strtonum($2)}'`
471f089d907SJoseph Chen		UBOOT_MAX_KB=$(((UBOOT_MAX_KB-HEAD_KB)*1024))
472f089d907SJoseph Chen	fi
473f089d907SJoseph Chen
474f089d907SJoseph Chen	if [ $UBOOT_KB -gt $UBOOT_MAX_KB ]; then
475f089d907SJoseph Chen		echo
476f089d907SJoseph 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
480aa8ddc58SJoseph Chen	if [ "$PACK_FORMAT" = "rk" ]; then
481f089d907SJoseph Chen		# Pack image
482d6821889SJoseph Chen		UBOOT_LOAD_ADDR=`sed -n "/CONFIG_SYS_TEXT_BASE=/s/CONFIG_SYS_TEXT_BASE=//p" include/autoconf.mk|tr -d '\r'`
483daa679a7SKever Yang		if [ ! $UBOOT_LOAD_ADDR ]; then
484d6821889SJoseph Chen			UBOOT_LOAD_ADDR=`sed -n "/CONFIG_SYS_TEXT_BASE=/s/CONFIG_SYS_TEXT_BASE=//p" .config|tr -d '\r'`
485daa679a7SKever Yang		fi
486daa679a7SKever Yang
487d6821889SJoseph Chen		${RKTOOLS}/loaderimage --pack --uboot u-boot.bin uboot.img ${UBOOT_LOAD_ADDR} ${PLATFORM_UBOOT_IMG_SIZE}
488fb90bd1dSJoseph Chen		# Delete u-boot.img and u-boot-dtb.img, which makes users not be confused with final uboot.img
489d6e1155eSJoseph Chen		ls u-boot.img >/dev/null 2>&1 && rm u-boot.img -rf
490d6e1155eSJoseph Chen		ls u-boot-dtb.img >/dev/null 2>&1 && rm u-boot-dtb.img -rf
49191205f1dSJoseph Chen		echo "pack uboot okay! Input: u-boot.bin"
49291205f1dSJoseph Chen	fi
493de9a6cd2SJoseph Chen}
494de9a6cd2SJoseph Chen
495daa3bef5SJoseph Chenpack_uboot_itb_image()
496daa3bef5SJoseph Chen{
497d13b75e1SJoseph Chen	local ini TEE_OFFSET
498daa3bef5SJoseph Chen
4990d0d4395SJoseph Chen	# ARM64
500d6821889SJoseph Chen	if grep -Eq ''^CONFIG_ARM64=y'|'^CONFIG_ARM64_BOOT_AARCH32=y'' .config ; then
5010d0d4395SJoseph Chen		ini=${RKBIN}/RKTRUST/${RKCHIP_TRUST}${PLATFORM_AARCH32}TRUST.ini
502daa3bef5SJoseph Chen		if [ ! -f ${ini} ]; then
503daa3bef5SJoseph Chen			echo "pack trust failed! Can't find: ${ini}"
504daa3bef5SJoseph Chen			return
505daa3bef5SJoseph Chen		fi
506daa3bef5SJoseph Chen
507daa3bef5SJoseph Chen		bl31=`sed -n '/_bl31_/s/PATH=//p' ${ini} |tr -d '\r'`
508daa3bef5SJoseph Chen
509daa3bef5SJoseph Chen		cp ${RKBIN}/${bl31} bl31.elf
510daa3bef5SJoseph Chen		make CROSS_COMPILE=${TOOLCHAIN_GCC} u-boot.itb
511daa3bef5SJoseph Chen		echo "pack u-boot.itb okay! Input: ${ini}"
5120d0d4395SJoseph Chen	else
5130d0d4395SJoseph Chen		ini=${RKBIN}/RKTRUST/${RKCHIP_TRUST}TOS.ini
5140d0d4395SJoseph Chen		if [ ! -f ${ini} ]; then
5150d0d4395SJoseph Chen			echo "pack trust failed! Can't find: ${ini}"
5160d0d4395SJoseph Chen			return
5170d0d4395SJoseph Chen		fi
5180d0d4395SJoseph Chen
5190d0d4395SJoseph Chen		TOS=`sed -n "/TOS=/s/TOS=//p" ${ini} |tr -d '\r'`
5200d0d4395SJoseph Chen		TOS_TA=`sed -n "/TOSTA=/s/TOSTA=//p" ${ini} |tr -d '\r'`
5210d0d4395SJoseph Chen
5220d0d4395SJoseph Chen		if [ $TOS_TA ]; then
5230d0d4395SJoseph Chen			cp ${RKBIN}/${TOS_TA} tee.bin
5240d0d4395SJoseph Chen		elif [ $TOS ]; then
5250d0d4395SJoseph Chen			cp ${RKBIN}/${TOS} tee.bin
5260d0d4395SJoseph Chen		else
5270d0d4395SJoseph Chen			echo "Can't find any tee bin"
5280d0d4395SJoseph Chen			exit 1
5290d0d4395SJoseph Chen		fi
5300d0d4395SJoseph Chen
531d13b75e1SJoseph Chen		TEE_OFFSET=`sed -n "/ADDR=/s/ADDR=//p" ${ini} |tr -d '\r'`
532d13b75e1SJoseph Chen		if [ "$TEE_OFFSET" = "" ]; then
533d13b75e1SJoseph Chen			TEE_OFFSET=0x8400000
534d13b75e1SJoseph Chen		fi
535d13b75e1SJoseph Chen
536db3b6a92SJoseph Chen		SPL_FIT_SOURCE=`sed -n "/CONFIG_SPL_FIT_SOURCE=/s/CONFIG_SPL_FIT_SOURCE=//p" .config | tr -d '""'`
537db3b6a92SJoseph Chen		if [ ! -z $SPL_FIT_SOURCE ]; then
538db3b6a92SJoseph Chen			cp $SPL_FIT_SOURCE u-boot.its
539db3b6a92SJoseph Chen		else
540db3b6a92SJoseph Chen			SPL_FIT_GENERATOR=`sed -n "/CONFIG_SPL_FIT_GENERATOR=/s/CONFIG_SPL_FIT_GENERATOR=//p" .config | tr -d '""'`
541db3b6a92SJoseph Chen			$SPL_FIT_GENERATOR $TEE_OFFSET > u-boot.its
542db3b6a92SJoseph Chen		fi
543db3b6a92SJoseph Chen
544d13b75e1SJoseph Chen		./tools/mkimage -f u-boot.its -E u-boot.itb
5450d0d4395SJoseph Chen		echo "pack u-boot.itb okay! Input: ${ini}"
5460d0d4395SJoseph Chen	fi
547daa3bef5SJoseph Chen}
548daa3bef5SJoseph Chen
549daa3bef5SJoseph Chenpack_spl_loader_image()
550daa3bef5SJoseph Chen{
551daa3bef5SJoseph Chen	local header label="SPL" mode=$1
552daa3bef5SJoseph Chen	local ini=${RKBIN}/RKBOOT/${RKCHIP_LOADER}MINIALL.ini
553daa3bef5SJoseph Chen	local temp_ini=${RKBIN}/.temp/${RKCHIP_LOADER}MINIALL.ini
554daa3bef5SJoseph Chen
555dd590c93SJoseph Chen	if [ "$FILE" != "" ]; then
556dd590c93SJoseph Chen		ini=$FILE;
557dd590c93SJoseph Chen	fi
558dd590c93SJoseph Chen
559daa3bef5SJoseph Chen	if [ ! -f ${ini} ]; then
560daa3bef5SJoseph Chen		echo "pack TPL+SPL loader failed! Can't find: ${ini}"
561daa3bef5SJoseph Chen		return
562daa3bef5SJoseph Chen	fi
563daa3bef5SJoseph Chen
564d6e1155eSJoseph Chen	ls ${RKBIN}/.temp >/dev/null 2>&1 && rm ${RKBIN}/.temp -rf
565ca69da84SJoseph Chen	mkdir ${RKBIN}/.temp
566ca69da84SJoseph Chen
567d6e1155eSJoseph Chen	# Copy to .temp folder
568d6821889SJoseph Chen	cp spl/u-boot-spl.bin ${RKBIN}/.temp/
569dd590c93SJoseph Chen	cp ${ini} ${RKBIN}/.temp/${RKCHIP_LOADER}MINIALL.ini -f
570daa3bef5SJoseph Chen
571daa3bef5SJoseph Chen	cd ${RKBIN}
572daa3bef5SJoseph Chen	if [ "$mode" = 'spl' ]; then	# pack tpl+spl
573708c86adSJason Zhu		cp tpl/u-boot-tpl.bin ${RKBIN}/.temp/
574daa3bef5SJoseph Chen		# Update ini
575daa3bef5SJoseph Chen		label="TPL+SPL"
576daa3bef5SJoseph Chen		header=`sed -n '/NAME=/s/NAME=//p' ${RKBIN}/RKBOOT/${RKCHIP_LOADER}MINIALL.ini`
577daa3bef5SJoseph Chen		dd if=${RKBIN}/.temp/u-boot-tpl.bin of=${RKBIN}/.temp/tpl.bin bs=1 skip=4
578daa3bef5SJoseph Chen		sed -i "1s/^/${header:0:4}/" ${RKBIN}/.temp/tpl.bin
579daa3bef5SJoseph Chen		sed -i "s/FlashData=.*$/FlashData=.\/.temp\/tpl.bin/"     ${temp_ini}
580daa3bef5SJoseph Chen	fi
581daa3bef5SJoseph Chen
582daa3bef5SJoseph Chen	sed -i "s/FlashBoot=.*$/FlashBoot=.\/.temp\/u-boot-spl.bin/"  ${temp_ini}
583daa3bef5SJoseph Chen
584daa3bef5SJoseph Chen	${RKTOOLS}/boot_merger ${BIN_PATH_FIXUP} ${temp_ini}
585daa3bef5SJoseph Chen	rm ${RKBIN}/.temp -rf
586daa3bef5SJoseph Chen	cd -
587daa3bef5SJoseph Chen	ls *_loader_*.bin >/dev/null 2>&1 && rm *_loader_*.bin
588b4e157ffSJoseph Chen	mv ${RKBIN}/*_loader_*.bin ./
589aa8ddc58SJoseph Chen	filename=`basename *_loader_*.bin`
590aa8ddc58SJoseph Chen	if [[ $filename != *spl* ]]; then
591b4e157ffSJoseph Chen		rename 's/loader_/spl_loader_/' *_loader_*.bin
592aa8ddc58SJoseph Chen	fi
593daa3bef5SJoseph Chen	echo "pack loader(${label}) okay! Input: ${ini}"
594b4e157ffSJoseph Chen	ls ./*_loader_*.bin
595daa3bef5SJoseph Chen}
596daa3bef5SJoseph Chen
597cd7ae718SJoseph Chenpack_loader_image()
598cd7ae718SJoseph Chen{
599d6e1155eSJoseph Chen	local ini=${RKBIN}/RKBOOT/${RKCHIP_LOADER}MINIALL.ini
600d9d90a73SJoseph Chen
601dd590c93SJoseph Chen	if [ "$FILE" != "" ]; then
602dd590c93SJoseph Chen		ini=$FILE;
603dd590c93SJoseph Chen	fi
604dd590c93SJoseph Chen
6050436a29dSJoseph Chen	if [ ! -f $ini ]; then
6060436a29dSJoseph Chen		echo "pack loader failed! Can't find: $ini"
60751441a28SJoseph Chen		return
60851441a28SJoseph Chen	fi
60951441a28SJoseph Chen
610224307feSJoseph Chen	ls *_loader_*.bin >/dev/null 2>&1 && rm *_loader_*.bin
611783f7f6eSJoseph Chen
612783f7f6eSJoseph Chen	numline=`cat $ini | wc -l`
613783f7f6eSJoseph Chen	if [ $numline -eq 1 ]; then
614783f7f6eSJoseph Chen		image=`sed -n "/PATH=/p" $ini | tr -d '\r' | cut -d '=' -f 2`
615783f7f6eSJoseph Chen		cp ${RKBIN}/${image} ./
6165b7cca2eSJoseph Chen		echo "pack loader okay! Input: ${ini}"
617783f7f6eSJoseph Chen		return;
618783f7f6eSJoseph Chen	fi
619783f7f6eSJoseph Chen
62069b6e590SJoseph Chen	if [ "$PACK_FORMAT" = "rk" ]; then
621cd7ae718SJoseph Chen		cd ${RKBIN}
62223ba6841SJoseph Chen		${RKTOOLS}/boot_merger ${BIN_PATH_FIXUP} $ini
623fb90bd1dSJoseph Chen		cd - && mv ${RKBIN}/*_loader_*.bin ./
62469b6e590SJoseph Chen		echo "pack loader okay! Input: $ini"
62569b6e590SJoseph Chen	else
62669b6e590SJoseph Chen		./scripts/fit-vboot-uboot.sh --no-vboot --no-rebuild >/dev/null
62769b6e590SJoseph Chen		file=`ls *loader*.bin`
62869b6e590SJoseph Chen		echo "pack $file okay! Input: $ini"
62969b6e590SJoseph Chen	fi
630cd7ae718SJoseph Chen}
631cd7ae718SJoseph Chen
632d6e1155eSJoseph Chenpack_32bit_trust_image()
633cd7ae718SJoseph Chen{
634162cc77eSJoseph Chen	local ini=$1 TOS TOS_TA DARM_BASE TEE_LOAD_ADDR TEE_OUTPUT TEE_OFFSET FORMAT
635cd7ae718SJoseph Chen
63669cce37bSJoseph Chen	if [ ! -f ${ini} ]; then
63769cce37bSJoseph Chen		echo "pack trust failed! Can't find: ${ini}"
63851441a28SJoseph Chen		return
63951441a28SJoseph Chen	fi
64051441a28SJoseph Chen
64169cce37bSJoseph Chen	# Parse orignal path
64269cce37bSJoseph Chen	TOS=`sed -n "/TOS=/s/TOS=//p" ${ini} |tr -d '\r'`
64369cce37bSJoseph Chen	TOS_TA=`sed -n "/TOSTA=/s/TOSTA=//p" ${ini} |tr -d '\r'`
644e5e978b3SJoseph Chen
64569cce37bSJoseph Chen	# Parse address and output name
64669cce37bSJoseph Chen	TEE_OUTPUT=`sed -n "/OUTPUT=/s/OUTPUT=//p" ${ini} |tr -d '\r'`
64769cce37bSJoseph Chen	if [ "$TEE_OUTPUT" = "" ]; then
64869cce37bSJoseph Chen		TEE_OUTPUT="./trust.img"
64969cce37bSJoseph Chen	fi
65069cce37bSJoseph Chen	TEE_OFFSET=`sed -n "/ADDR=/s/ADDR=//p" ${ini} |tr -d '\r'`
65169cce37bSJoseph Chen	if [ "$TEE_OFFSET" = "" ]; then
65269cce37bSJoseph Chen		TEE_OFFSET=0x8400000
65351441a28SJoseph Chen	fi
65451441a28SJoseph Chen
655cd7ae718SJoseph Chen	# OP-TEE is 132M(0x8400000) offset from DRAM base.
656d6821889SJoseph Chen	DARM_BASE=`sed -n "/CONFIG_SYS_SDRAM_BASE=/s/CONFIG_SYS_SDRAM_BASE=//p" include/autoconf.mk|tr -d '\r'`
657cd7ae718SJoseph Chen	TEE_LOAD_ADDR=$((DARM_BASE+TEE_OFFSET))
658cd7ae718SJoseph Chen
659cd7ae718SJoseph Chen	# Convert Dec to Hex
660cd7ae718SJoseph Chen	TEE_LOAD_ADDR=$(echo "obase=16;${TEE_LOAD_ADDR}"|bc)
661cd7ae718SJoseph Chen
66269cce37bSJoseph Chen	# Replace "./tools/rk_tools/" with "./" to compatible legacy ini content of rkdevelop branch
6630e90839aSJoseph Chen	TOS=$(echo ${TOS} | sed "s/tools\/rk_tools\//\.\//g")
6640e90839aSJoseph Chen	TOS_TA=$(echo ${TOS_TA} | sed "s/tools\/rk_tools\//\.\//g")
6650e90839aSJoseph Chen
66669b6e590SJoseph Chen	if [ "$PACK_FORMAT" = "rk" ]; then
667623d03d6SJoseph Chen		if [ $TOS_TA ]; then
66869cce37bSJoseph Chen			${RKTOOLS}/loaderimage --pack --trustos ${RKBIN}/${TOS_TA} ${TEE_OUTPUT} ${TEE_LOAD_ADDR} ${PLATFORM_TRUST_IMG_SIZE}
669cd7ae718SJoseph Chen		elif [ $TOS ]; then
67069cce37bSJoseph Chen			${RKTOOLS}/loaderimage --pack --trustos ${RKBIN}/${TOS}    ${TEE_OUTPUT} ${TEE_LOAD_ADDR} ${PLATFORM_TRUST_IMG_SIZE}
671cd7ae718SJoseph Chen		else
672a64486b5SJoseph Chen			echo "Can't find any tee bin"
673a64486b5SJoseph Chen			exit 1
674cd7ae718SJoseph Chen		fi
67551441a28SJoseph Chen
67669cce37bSJoseph Chen		echo "pack trust okay! Input: ${ini}"
67769b6e590SJoseph Chen	else
67869b6e590SJoseph Chen		./scripts/fit-vboot-uboot.sh --no-vboot --no-rebuild >/dev/null
67969b6e590SJoseph Chen		ls uboot.img >/dev/null 2>&1 && rm uboot.img -rf
68069b6e590SJoseph Chen		ls trust.img >/dev/null 2>&1 && rm trust.img -rf
68169b6e590SJoseph Chen		echo "pack uboot.fit (with uboot trust) okay! Input: ${ini}"
682162cc77eSJoseph Chen	fi
683162cc77eSJoseph Chen
68469cce37bSJoseph Chen	echo
68569cce37bSJoseph Chen}
68669cce37bSJoseph Chen
687d6e1155eSJoseph Chenpack_64bit_trust_image()
68869cce37bSJoseph Chen{
68969cce37bSJoseph Chen	local ini=$1
69069cce37bSJoseph Chen
69169cce37bSJoseph Chen	if [ ! -f ${ini} ]; then
69269cce37bSJoseph Chen		echo "pack trust failed! Can't find: ${ini}"
69369cce37bSJoseph Chen		return
69469cce37bSJoseph Chen	fi
69569cce37bSJoseph Chen
69669cce37bSJoseph Chen	cd ${RKBIN}
69769cce37bSJoseph Chen	${RKTOOLS}/trust_merger ${PLATFORM_SHA} ${PLATFORM_RSA} ${PLATFORM_TRUST_IMG_SIZE} ${BIN_PATH_FIXUP} \
69869cce37bSJoseph Chen				${PACK_IGNORE_BL32} ${ini}
69969cce37bSJoseph Chen
70069cce37bSJoseph Chen	cd - && mv ${RKBIN}/trust*.img ./
70169cce37bSJoseph Chen	echo "pack trust okay! Input: ${ini}"
70269cce37bSJoseph Chen	echo
70369cce37bSJoseph Chen}
70469cce37bSJoseph Chen
70569cce37bSJoseph Chenpack_trust_image()
70669cce37bSJoseph Chen{
707d6e1155eSJoseph Chen	local ini
70869cce37bSJoseph Chen
709cd623926SJoseph Chen	ls trust*.img >/dev/null 2>&1 && rm trust*.img
710783f7f6eSJoseph Chen
71169cce37bSJoseph Chen	# ARM64 uses trust_merger
712d6821889SJoseph Chen	if grep -Eq ''^CONFIG_ARM64=y'|'^CONFIG_ARM64_BOOT_AARCH32=y'' .config ; then
7135202fe1fSJoseph Chen		ini=${RKBIN}/RKTRUST/${RKCHIP_TRUST}TRUST.ini
714dd590c93SJoseph Chen		if [ "$FILE" != "" ]; then
715dd590c93SJoseph Chen			ini=$FILE;
716dd590c93SJoseph Chen		fi
717dd590c93SJoseph Chen
718783f7f6eSJoseph Chen		numline=`cat $ini | wc -l`
719783f7f6eSJoseph Chen		if [ $numline -eq 1 ]; then
720783f7f6eSJoseph Chen			image=`sed -n "/PATH=/p" $ini | tr -d '\r' | cut -d '=' -f 2`
721783f7f6eSJoseph Chen			cp ${RKBIN}/${image} ./trust.img
722783f7f6eSJoseph Chen			echo "pack trust okay! Input: ${ini}"
723783f7f6eSJoseph Chen			return;
724783f7f6eSJoseph Chen		fi
725d6e1155eSJoseph Chen		pack_64bit_trust_image ${ini}
72669cce37bSJoseph Chen	# ARM uses loaderimage
72769cce37bSJoseph Chen	else
72869cce37bSJoseph Chen		ini=${RKBIN}/RKTRUST/${RKCHIP_TRUST}TOS.ini
729dd590c93SJoseph Chen		if [ "$FILE" != "" ]; then
730dd590c93SJoseph Chen			ini=$FILE;
731dd590c93SJoseph Chen		fi
732d6e1155eSJoseph Chen		pack_32bit_trust_image ${ini}
733cd7ae718SJoseph Chen	fi
734cd7ae718SJoseph Chen}
735cd7ae718SJoseph Chen
73630b04afcSJoseph Chenfinish()
73730b04afcSJoseph Chen{
73830b04afcSJoseph Chen	echo
739622ccf34SJoseph Chen	if [ ! -z "$OPTION" ]; then
740622ccf34SJoseph Chen		echo "Platform ${RKCHIP_LABEL} is build OK, with exist .config ($OPTION)"
741622ccf34SJoseph Chen	elif [ "$BOARD" = '' ]; then
7425202fe1fSJoseph Chen		echo "Platform ${RKCHIP_LABEL} is build OK, with exist .config"
74330b04afcSJoseph Chen	else
7445202fe1fSJoseph Chen		echo "Platform ${RKCHIP_LABEL} is build OK, with new .config(make ${BOARD}_defconfig)"
74530b04afcSJoseph Chen	fi
74630b04afcSJoseph Chen}
74730b04afcSJoseph Chen
748cd7ae718SJoseph Chenprepare
7497c2526e9SJoseph Chenselect_toolchain
750de440615SJoseph Chenselect_chip_info
75141cf5e5aSJoseph Chenfixup_platform_configure
7520ff0e214SJoseph Chensub_commands
753622ccf34SJoseph Chenmake CROSS_COMPILE=${TOOLCHAIN_GCC} ${OPTION} all --jobs=${JOB}
75491205f1dSJoseph Chenpack_uboot_image
755d93242f2SJoseph Chenpack_loader_image
756cd7ae718SJoseph Chenpack_trust_image
75730b04afcSJoseph Chenfinish
758