xref: /rk3399_rockchip-uboot/make.sh (revision a11e2c82253aabe4495a335a7d52afb18bd55e74)
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
13f9afd3dcSJoseph ChenARGS=$*
1427a50c86SAndy YanJOB=`sed -n "N;/processor/p" /proc/cpuinfo|wc -l`
15b6255198SJoseph ChenSUPPORT_LIST=`ls configs/*[r,p][x,v,k][0-9][0-9]*_defconfig`
1627a50c86SAndy Yan
170583701dSJoseph Chen# @LOADER: map to $RKCHIP_LOADER for loader ini
180583701dSJoseph Chen# @TRUST:  map to $RKCHIP_TRUST for trust ini
190583701dSJoseph Chen# @LABEL:  map to $RKCHIP_LEBEL for verbose message
200583701dSJoseph Chen# @-:      default state/value
210583701dSJoseph ChenCHIP_TYPE_FIXUP_TABLE=(
220583701dSJoseph Chen	# CONFIG_XXX                         RKCHIP         LOADER       TRUST         LABEL
230583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK3368              RK3368H         -            -             -"
240583701dSJoseph Chen	"CONFIG_ROCKCHIP_RV1108              RV110X          -            -             -"
250583701dSJoseph Chen	"CONFIG_ROCKCHIP_PX3SE               PX3SE           -            -             -"
260583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK3126              RK3126          -            -             -"
270583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK3326              RK3326          -            -             -"
280583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK3128X             RK3128X         -            -             -"
290583701dSJoseph Chen	"CONFIG_ROCKCHIP_PX5                 PX5             -            -             -"
300583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK3399PRO           RK3399PRO       -            -             -"
310583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK1806              RK1806          -            -             -"
320583701dSJoseph Chen	"CONFIG_TARGET_GVA_RK3229            RK322X          RK322XAT     -             -"
330583701dSJoseph Chen	"CONFIG_COPROCESSOR_RK1808           RKNPU-LION      RKNPULION    RKNPULION     -"
340583701dSJoseph Chen)
350583701dSJoseph Chen
360583701dSJoseph Chen# <*> Fixup rsa/sha pack mode for platforms
370583701dSJoseph Chen#     RSA: RK3308/PX30/RK3326/RK1808 use RSA-PKCS1 V2.1, it's pack magic is "3", and others use default configure.
380583701dSJoseph Chen#     SHA: RK3368 use rk big endian SHA256, it's pack magic is "2", and others use default configure.
390583701dSJoseph Chen# <*> Fixup images size pack for platforms
400583701dSJoseph Chen# <*> Fixup verbose message about AARCH32
41de440615SJoseph Chen#
420583701dSJoseph Chen# @RSA:     rsa mode
430583701dSJoseph Chen# @SHA:     sha mode
440583701dSJoseph Chen# @A64-KB:  arm64 platform image size: [uboot,trust]
450583701dSJoseph Chen# @A64-NUM: arm64 platform image number of total: [uboot,trust]
460583701dSJoseph Chen# @A32-KB:  arm32 platform image size: [uboot,trust]
470583701dSJoseph Chen# @A32-NUM: arm32 platform image number of total: [uboot,trust]
480583701dSJoseph Chen# @LOADER:  map to $RKCHIP_LOADER for loader ini
490583701dSJoseph Chen# @TRUST:   map to $RKCHIP_TRUST for trust ini
500583701dSJoseph Chen# @-:       default state/value
510583701dSJoseph ChenCHIP_CFG_FIXUP_TABLE=(
520583701dSJoseph Chen	# CONFIG_XXX              RSA     SHA     A64-KB      A64-NUM     A32-KB       A32-NUM      LOAER        TRUST
530583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK3368    -       2       -,-          -,-        -,-          -,-           -           -"
540583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK3036    -       -       512,512      1,1        -,-          -,-           -           -"
550583701dSJoseph Chen	"CONFIG_ROCKCHIP_PX30      3       -       -,-          -,-        -,-          -,-           -           -"
560583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK3326    3       -       -,-          -,-        -,-          -,-           AARCH32     -"
570583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK3308    3       -       1024,1024    2,2        512,512      2,2           -           AARCH32"
580583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK1808    3       -       1024,1024    2,2        -,-          -,-           -           -"
59de440615SJoseph Chen)
60de440615SJoseph Chen
61fb90bd1dSJoseph Chen########################################### User can modify #############################################
62fb90bd1dSJoseph Chen# User's rkbin tool relative path
63bc98b3c8SJoseph ChenRKBIN_TOOLS=../rkbin/tools
64bc98b3c8SJoseph Chen
65fb90bd1dSJoseph Chen# User's GCC toolchain and relative path
6653ea5791SJoseph ChenADDR2LINE_ARM32=arm-linux-gnueabihf-addr2line
6753ea5791SJoseph ChenADDR2LINE_ARM64=aarch64-linux-gnu-addr2line
68fb90bd1dSJoseph ChenOBJ_ARM32=arm-linux-gnueabihf-objdump
69fb90bd1dSJoseph ChenOBJ_ARM64=aarch64-linux-gnu-objdump
70d8540eacSJoseph ChenGCC_ARM32=arm-linux-gnueabihf-
71d8540eacSJoseph ChenGCC_ARM64=aarch64-linux-gnu-
72d8540eacSJoseph ChenTOOLCHAIN_ARM32=../prebuilts/gcc/linux-x86/arm/gcc-linaro-6.3.1-2017.05-x86_64_arm-linux-gnueabihf/bin
73d8540eacSJoseph ChenTOOLCHAIN_ARM64=../prebuilts/gcc/linux-x86/aarch64/gcc-linaro-6.3.1-2017.05-x86_64_aarch64-linux-gnu/bin
74fb90bd1dSJoseph Chen
75fb90bd1dSJoseph Chen########################################### User not touch #############################################
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=
100aa8ddc58SJoseph ChenPACK_FORMAT="rk"
1018f53a15cSJoseph ChenNOPACK="n"
102aa8ddc58SJoseph Chen
103fb90bd1dSJoseph Chen#########################################################################################################
1047c3ca500SJoseph Chenfunction help()
105b6255198SJoseph Chen{
106b6255198SJoseph Chen	echo
1076a764259SJoseph Chen	echo "Usage:"
108622ccf34SJoseph Chen	echo "	./make.sh [board|subcmd|EXT_DTB=<file>]"
1096a764259SJoseph Chen	echo
1106a764259SJoseph Chen	echo "	 - board:   board name of defconfig"
111622ccf34SJoseph Chen	echo "	 - subcmd:  |elf*|loader*|spl*|itb|trust*|uboot|map|sym|<addr>|EXT_DTB=*"
112f3d60245SJoseph Chen	echo "	 - ini:     assigned ini file to pack trust/loader"
113f3d60245SJoseph Chen	echo
114f3d60245SJoseph Chen	echo "Output:"
115f3d60245SJoseph Chen	echo "	 When board built okay, there are uboot/trust/loader images in current directory"
116b6255198SJoseph Chen	echo
117b6255198SJoseph Chen	echo "Example:"
118b6255198SJoseph Chen	echo
119d6821889SJoseph Chen	echo "1. Build:"
120fc99e044SJoseph Chen	echo "	./make.sh evb-rk3399               --- build for evb-rk3399_defconfig"
121fc99e044SJoseph Chen	echo "	./make.sh firefly-rk3288           --- build for firefly-rk3288_defconfig"
122622ccf34SJoseph Chen	echo "	./make.sh EXT_DTB=rk-kernel.dtb    --- build with exist .config and external dtb"
123fc99e044SJoseph Chen	echo "	./make.sh                          --- build with exist .config"
124398d3e80SJoseph Chen	echo "	./make.sh env                      --- build envtools"
125b6255198SJoseph Chen	echo
126d6821889SJoseph Chen	echo "2. Pack:"
1276a764259SJoseph Chen	echo "	./make.sh uboot                    --- pack uboot.img"
12869cce37bSJoseph Chen	echo "	./make.sh trust                    --- pack trust.img"
129f3d60245SJoseph Chen	echo "	./make.sh trust <ini>              --- pack trust img with assigned ini file"
1306a764259SJoseph Chen	echo "	./make.sh loader                   --- pack loader bin"
131f3d60245SJoseph Chen	echo "	./make.sh loader <ini>             --- pack loader img with assigned ini file"
132f3d60245SJoseph Chen	echo "	./make.sh spl                      --- pack loader with u-boot-spl.bin and u-boot-tpl.bin"
133f3d60245SJoseph Chen	echo "	./make.sh spl-s                    --- pack loader only replace miniloader with u-boot-spl.bin"
134f3d60245SJoseph Chen	echo "	./make.sh itb                      --- pack u-boot.itb(TODO: bl32 is not included for ARMv8)"
135b6255198SJoseph Chen	echo
136d6821889SJoseph Chen	echo "3. Debug:"
137b6255198SJoseph Chen	echo "	./make.sh elf                      --- dump elf file with -D(default)"
138b6255198SJoseph Chen	echo "	./make.sh elf-S                    --- dump elf file with -S"
1396a764259SJoseph Chen	echo "	./make.sh elf-d                    --- dump elf file with -d"
140f3d60245SJoseph Chen	echo "	./make.sh elf-*                    --- dump elf file with -*"
141fc99e044SJoseph Chen	echo "	./make.sh <no reloc_addr>          --- dump function symbol and code position of address(no relocated)"
142fc99e044SJoseph Chen	echo "	./make.sh <reloc_addr-reloc_off>   --- dump function symbol and code position of address(relocated)"
143b6255198SJoseph Chen	echo "	./make.sh map                      --- cat u-boot.map"
144b6255198SJoseph Chen	echo "	./make.sh sym                      --- cat u-boot.sym"
145b6255198SJoseph Chen}
14641cf5e5aSJoseph Chen
1477c3ca500SJoseph Chenfunction prepare()
148cd7ae718SJoseph Chen{
149b6255198SJoseph Chen	case $BOARD in
15053ea5791SJoseph Chen		# Parse from exit .config
151f9afd3dcSJoseph Chen		''|elf*|loader*|spl*|itb|debug*|trust|uboot|map|sym|env|EXT_DTB=*|fit*|nopack|--rollback-index*)
152d6821889SJoseph Chen		if [ ! -f .config ]; then
153b6255198SJoseph Chen			echo
1547c3ca500SJoseph Chen			echo "ERROR: No .config"
155b6255198SJoseph Chen			help
156b6255198SJoseph Chen			exit 1
157b6255198SJoseph Chen		fi
158b6255198SJoseph Chen		;;
159b6255198SJoseph Chen	esac
160cd7ae718SJoseph Chen
161b6255198SJoseph Chen	# Parse help and make defconfig
162b6255198SJoseph Chen	case $BOARD in
16353ea5791SJoseph Chen		#Help
164b6255198SJoseph Chen		--help|-help|help|--h|-h)
165b6255198SJoseph Chen		help
166b6255198SJoseph Chen		exit 0
167b6255198SJoseph Chen		;;
16853ea5791SJoseph Chen
16953ea5791SJoseph Chen		#Subcmd
170f9afd3dcSJoseph Chen		''|elf*|loader*|spl*|itb|debug*|trust*|uboot|map|sym|env|EXT_DTB=*|fit*|nopack|--rollback-index*)
171b6255198SJoseph Chen		;;
172b6255198SJoseph Chen
173b6255198SJoseph Chen		*)
17453ea5791SJoseph Chen		#Func address is valid ?
175fc99e044SJoseph Chen		if [ -z $(echo ${FUNCADDR} | sed 's/[0-9,a-f,A-F,x,X,-]//g') ]; then
17653ea5791SJoseph Chen			return
17753ea5791SJoseph Chen		elif [ ! -f configs/${BOARD}_defconfig ]; then
1787c3ca500SJoseph Chen			echo -e "\n${SUPPORT_LIST}\n"
1797c3ca500SJoseph Chen			echo "ERROR: No configs/${BOARD}_defconfig"
180cd7ae718SJoseph Chen			exit 1
181b6255198SJoseph Chen		else
182b6255198SJoseph Chen			echo "make for ${BOARD}_defconfig by -j${JOB}"
183622ccf34SJoseph Chen			make ${BOARD}_defconfig ${OPTION}
184f9afd3dcSJoseph Chen			# Skip 1st args
185f9afd3dcSJoseph Chen			ARGS=`echo $ARGS | awk '{ $1=""; print $0 }'`
186cd7ae718SJoseph Chen		fi
187b6255198SJoseph Chen		;;
188b6255198SJoseph Chen	esac
189cd7ae718SJoseph Chen
19023ba6841SJoseph Chen	# Initialize RKBIN
191bc98b3c8SJoseph Chen	if [ -d ${RKBIN_TOOLS} ]; then
192bc98b3c8SJoseph Chen		absolute_path=$(cd `dirname ${RKBIN_TOOLS}`; pwd)
193bc98b3c8SJoseph Chen		RKBIN=${absolute_path}
194cd7ae718SJoseph Chen	else
195cd7ae718SJoseph Chen		echo
1967c3ca500SJoseph Chen		echo "No '../rkbin/' repository, please download it before pack image!"
197cd7ae718SJoseph Chen		echo "How to obtain? 3 ways:"
198fb90bd1dSJoseph Chen		echo "	1. Login your Rockchip gerrit account: \"Projects\" -> \"List\" -> search \"rk/rkbin\" repository"
199fb90bd1dSJoseph Chen		echo "	2. Github repository: https://github.com/rockchip-linux/rkbin"
200fb90bd1dSJoseph Chen		echo "	3. Download full release SDK repository"
201cd7ae718SJoseph Chen		exit 1
202cd7ae718SJoseph Chen	fi
20369b6e590SJoseph Chen
2047c3ca500SJoseph Chen	if grep -Eq ''^CONFIG_ARM64=y'|'^CONFIG_ARM64_BOOT_AARCH32=y'' .config ; then
2057c3ca500SJoseph Chen		ARM64_TRUSTZONE="y"
2067c3ca500SJoseph Chen	fi
2077c3ca500SJoseph Chen
20869b6e590SJoseph Chen	if grep  -q '^CONFIG_ROCKCHIP_FIT_IMAGE_PACK=y' .config ; then
20969b6e590SJoseph Chen		PACK_FORMAT="fit"
21069b6e590SJoseph Chen	fi
21130b04afcSJoseph Chen}
2127c2526e9SJoseph Chen
2137c3ca500SJoseph Chenfunction select_toolchain()
21427a50c86SAndy Yan{
215d6821889SJoseph Chen	if grep -q '^CONFIG_ARM64=y' .config ; then
216bc98b3c8SJoseph Chen		if [ -d ${TOOLCHAIN_ARM64} ]; then
217bc98b3c8SJoseph Chen			absolute_path=$(cd `dirname ${TOOLCHAIN_ARM64}`; pwd)
218bc98b3c8SJoseph Chen			TOOLCHAIN_GCC=${absolute_path}/bin/${GCC_ARM64}
2190ff0e214SJoseph Chen			TOOLCHAIN_OBJDUMP=${absolute_path}/bin/${OBJ_ARM64}
22053ea5791SJoseph Chen			TOOLCHAIN_ADDR2LINE=${absolute_path}/bin/${ADDR2LINE_ARM64}
221bc98b3c8SJoseph Chen		else
2227c3ca500SJoseph Chen			echo "ERROR: No toolchain: ${TOOLCHAIN_ARM64}"
223bc98b3c8SJoseph Chen			exit 1
22427a50c86SAndy Yan		fi
22527a50c86SAndy Yan	else
226bc98b3c8SJoseph Chen		if [ -d ${TOOLCHAIN_ARM32} ]; then
227bc98b3c8SJoseph Chen			absolute_path=$(cd `dirname ${TOOLCHAIN_ARM32}`; pwd)
228bc98b3c8SJoseph Chen			TOOLCHAIN_GCC=${absolute_path}/bin/${GCC_ARM32}
2290ff0e214SJoseph Chen			TOOLCHAIN_OBJDUMP=${absolute_path}/bin/${OBJ_ARM32}
23053ea5791SJoseph Chen			TOOLCHAIN_ADDR2LINE=${absolute_path}/bin/${ADDR2LINE_ARM32}
231bc98b3c8SJoseph Chen		else
2327c3ca500SJoseph Chen			echo "ERROR: No toolchain: ${TOOLCHAIN_ARM32}"
233bc98b3c8SJoseph Chen			exit 1
23427a50c86SAndy Yan		fi
23527a50c86SAndy Yan	fi
236bc98b3c8SJoseph Chen}
237bc98b3c8SJoseph Chen
2387c3ca500SJoseph Chenfunction sub_commands()
2390ff0e214SJoseph Chen{
240f9afd3dcSJoseph Chen	# skip "--" parameter, such as "--rollback-index-..."
241f9afd3dcSJoseph Chen	if [[ "$SUBCMD" != "--*" ]]; then
2427c3ca500SJoseph Chen		cmd=${SUBCMD%-*}
2437c3ca500SJoseph Chen		opt=${SUBCMD#*-}
244f9afd3dcSJoseph Chen	else
245f9afd3dcSJoseph Chen		cmd=$SUBCMD
246f9afd3dcSJoseph Chen	fi
247f9afd3dcSJoseph Chen
2487c3ca500SJoseph Chen	elf=u-boot
2497c3ca500SJoseph Chen	map=u-boot.map
2507c3ca500SJoseph Chen	sym=u-boot.sym
25134bdfea0SJoseph Chen
25234bdfea0SJoseph Chen	if [ "$FILE" == "tpl" -o "$FILE" == "spl" ]; then
25334bdfea0SJoseph Chen		elf=`find -name u-boot-${FILE}`
25434bdfea0SJoseph Chen		map=`find -name u-boot-${FILE}.map`
25534bdfea0SJoseph Chen		sym=`find -name u-boot-${FILE}.sym`
25634bdfea0SJoseph Chen	fi
2570ff0e214SJoseph Chen
258b6255198SJoseph Chen	case $cmd in
259b6255198SJoseph Chen		elf)
2607c3ca500SJoseph Chen		if [ ! -f ${elf} ]; then
2617c3ca500SJoseph Chen			echo "ERROR: No elf: ${elf}"
2620ff0e214SJoseph Chen			exit 1
2630ff0e214SJoseph Chen		else
264b6255198SJoseph Chen			# default 'cmd' without option, use '-D'
2655c75ab41SJoseph Chen			if [ "${cmd}" = 'elf' -a "${opt}" = 'elf' ]; then
2665c75ab41SJoseph Chen				opt=D
2670ff0e214SJoseph Chen			fi
26834bdfea0SJoseph Chen			${TOOLCHAIN_OBJDUMP} -${opt} ${elf} | less
26907de173aSJoseph Chen			exit 0
27007de173aSJoseph Chen		fi
271b6255198SJoseph Chen		;;
272b6255198SJoseph Chen
2731b6c85a0SJoseph Chen		debug)
274fcccd23aSJoseph Chen		./scripts/rkpatch.sh ${opt}
2751b6c85a0SJoseph Chen		exit 0
2761b6c85a0SJoseph Chen		;;
2771b6c85a0SJoseph Chen
27869b6e590SJoseph Chen		fit)
2794b4c6841SJoseph Chen		if [ "$opt" = "ns" ]; then
2806cf81e27SJoseph Chen			./scripts/fit-vboot.sh --no-vboot
2816cf81e27SJoseph 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
325f9afd3dcSJoseph Chen		--rollback-index*)
326f9afd3dcSJoseph Chen		pack_fit_image $ARGS
327f9afd3dcSJoseph Chen		exit 0
328f9afd3dcSJoseph Chen		;;
329f9afd3dcSJoseph Chen
330622ccf34SJoseph Chen		EXT_DTB=*)
331622ccf34SJoseph Chen		OPTION=${SUBCMD}
332622ccf34SJoseph Chen		;;
333622ccf34SJoseph Chen
3348f53a15cSJoseph Chen		nopack)
3358f53a15cSJoseph Chen		NOPACK="y"
3368f53a15cSJoseph Chen		;;
3378f53a15cSJoseph Chen
338b6255198SJoseph Chen		*)
33953ea5791SJoseph Chen		# Search function and code position of address
340fc99e044SJoseph Chen		RELOC_OFF=${FUNCADDR#*-}
341fc99e044SJoseph Chen		FUNCADDR=${FUNCADDR%-*}
342fc99e044SJoseph Chen		if [ -z $(echo ${FUNCADDR} | sed 's/[0-9,a-f,A-F,x,X,-]//g') ] && [ ${FUNCADDR} ]; then
3437070f875SJoseph Chen			# With prefix: '0x' or '0X'
3447070f875SJoseph Chen			if [ `echo ${FUNCADDR} | sed -n "/0[x,X]/p" | wc -l` -ne 0 ]; then
3457070f875SJoseph Chen				FUNCADDR=`echo $FUNCADDR | awk '{ print strtonum($0) }'`
3467070f875SJoseph Chen				FUNCADDR=`echo "obase=16;${FUNCADDR}"|bc |tr '[A-Z]' '[a-z]'`
3477070f875SJoseph Chen			fi
348fc99e044SJoseph Chen			if [ `echo ${RELOC_OFF} | sed -n "/0[x,X]/p" | wc -l` -ne 0 ] && [ ${RELOC_OFF} ]; then
349fc99e044SJoseph Chen				RELOC_OFF=`echo $RELOC_OFF | awk '{ print strtonum($0) }'`
350fc99e044SJoseph Chen				RELOC_OFF=`echo "obase=16;${RELOC_OFF}"|bc |tr '[A-Z]' '[a-z]'`
351fc99e044SJoseph Chen			fi
352fc99e044SJoseph Chen
353fc99e044SJoseph Chen			# If reloc address is assigned, do sub
354fc99e044SJoseph Chen			if [ "${FUNCADDR}" != "${RELOC_OFF}" ]; then
355fc99e044SJoseph Chen				# Hex -> Dec -> SUB -> Hex
356fc99e044SJoseph Chen				FUNCADDR=`echo $((16#${FUNCADDR}))`
357fc99e044SJoseph Chen				RELOC_OFF=`echo $((16#${RELOC_OFF}))`
358fc99e044SJoseph Chen				FUNCADDR=$((FUNCADDR-RELOC_OFF))
359fc99e044SJoseph Chen				FUNCADDR=$(echo "obase=16;${FUNCADDR}"|bc |tr '[A-Z]' '[a-z]')
360fc99e044SJoseph Chen			fi
3617070f875SJoseph Chen
36253ea5791SJoseph Chen			echo
36334bdfea0SJoseph Chen			sed -n "/${FUNCADDR}/p" ${sym}
36434bdfea0SJoseph Chen			${TOOLCHAIN_ADDR2LINE} -e ${elf} ${FUNCADDR}
36553ea5791SJoseph Chen			exit 0
36653ea5791SJoseph Chen		fi
367b6255198SJoseph Chen		;;
368b6255198SJoseph Chen	esac
3690ff0e214SJoseph Chen}
3700ff0e214SJoseph Chen
371de440615SJoseph Chen# We select chip info to do:
372de440615SJoseph Chen#	1. RKCHIP: fixup platform configure
373de440615SJoseph Chen#	2. RKCHIP_LOADER: search ini file to pack loader
374de440615SJoseph Chen#	3. RKCHIP_TRUST: search ini file to pack trust
375de440615SJoseph Chen#	4. RKCHIP_LABEL: show build message
376de440615SJoseph Chen#
377de440615SJoseph Chen# We read chip info from .config and 'RKCHIP_INI_DESC'
3787c3ca500SJoseph Chenfunction select_chip_info()
379bc98b3c8SJoseph Chen{
380de440615SJoseph Chen	# Read RKCHIP firstly from .config
381596700d7SShunqian Zheng	# The regular expression that matching:
382596700d7SShunqian Zheng	#  - PX30, PX3SE
383596700d7SShunqian Zheng	#  - RK????, RK????X
384596700d7SShunqian Zheng	#  - RV????
3857c3ca500SJoseph Chen	chip_pattern='^CONFIG_ROCKCHIP_[R,P][X,V,K][0-9ESX]{1,5}'
3867c3ca500SJoseph Chen	RKCHIP=`egrep -o ${chip_pattern} .config`
387d443b7d5SJoseph Chen
3880583701dSJoseph Chen	# default
389d443b7d5SJoseph Chen	RKCHIP=${RKCHIP##*_}
39041cf5e5aSJoseph Chen
3910583701dSJoseph Chen	# need fixup ?
3927c3ca500SJoseph Chen	for item in "${CHIP_TYPE_FIXUP_TABLE[@]}"
393de440615SJoseph Chen	do
3947c3ca500SJoseph Chen		config_xxx=`echo $item | awk '{ print $1 }'`
3957c3ca500SJoseph Chen		if grep  -q "^${config_xxx}=y" .config ; then
3967c3ca500SJoseph Chen			RKCHIP=`echo $item | awk '{ print $2 }'`
3977c3ca500SJoseph Chen			RKCHIP_LOADER=`echo $item | awk '{ print $3 }'`
3987c3ca500SJoseph Chen			RKCHIP_TRUST=`echo  $item | awk '{ print $4 }'`
3997c3ca500SJoseph Chen			RKCHIP_LABEL=`echo  $item | awk '{ print $5 }'`
400de440615SJoseph Chen		fi
4010583701dSJoseph Chen	done
4020583701dSJoseph Chen
4030583701dSJoseph Chen	if [ "$RKCHIP_LOADER" = "-" ]; then
4040583701dSJoseph Chen		RKCHIP_LOADER=${RKCHIP}
405de440615SJoseph Chen	fi
4060583701dSJoseph Chen	if [ "$RKCHIP_TRUST" = "-" ]; then
4070583701dSJoseph Chen		RKCHIP_TRUST=${RKCHIP}
4080583701dSJoseph Chen	fi
4090583701dSJoseph Chen	if [ "$RKCHIP_LABEL" = "-" ]; then
4100583701dSJoseph Chen		RKCHIP_LABEL=${RKCHIP}
4110583701dSJoseph Chen	fi
4120583701dSJoseph Chen
4130583701dSJoseph Chen	# echo "## $FUNCNAME: $RKCHIP, $RKCHIP_LOADER, $RKCHIP_TRUST, $RKCHIP_LABEL,"
4140583701dSJoseph Chen}
4150583701dSJoseph Chen
4160583701dSJoseph Chenfunction fixup_platform_configure()
4170583701dSJoseph Chen{
4187c3ca500SJoseph Chen	cfg_u_kb="-" cfg_u_num="-" cfg_t_kb="-" cfg_t_num="-"  cfg_sha="-" cfg_rsa="-"
4190583701dSJoseph Chen
4207c3ca500SJoseph Chen	for item in "${CHIP_CFG_FIXUP_TABLE[@]}"
4210583701dSJoseph Chen	do
4227c3ca500SJoseph Chen		config_xxx=`echo $item | awk '{ print $1 }'`
4237c3ca500SJoseph Chen		if grep  -q "^${config_xxx}=y" .config ; then
4240583701dSJoseph Chen			# <*> Fixup rsa/sha pack mode for platforms
4257c3ca500SJoseph Chen			cfg_rsa=`echo $item | awk '{ print $2 }'`
4267c3ca500SJoseph Chen			cfg_sha=`echo $item | awk '{ print $3 }'`
4270583701dSJoseph Chen
4280583701dSJoseph Chen			# <*> Fixup images size pack for platforms, and ini file
4290583701dSJoseph Chen			if grep -q '^CONFIG_ARM64_BOOT_AARCH32=y' .config ; then
4307c3ca500SJoseph Chen				cfg_u_kb=`echo  $item | awk '{ print $6 }' | awk -F "," '{ print $1 }'`
4317c3ca500SJoseph Chen				cfg_u_num=`echo $item | awk '{ print $7 }' | awk -F "," '{ print $1 }'`
4327c3ca500SJoseph Chen				cfg_t_kb=`echo  $item | awk '{ print $6 }' | awk -F "," '{ print $2 }'`
4337c3ca500SJoseph Chen				cfg_t_num=`echo $item | awk '{ print $7 }' | awk -F "," '{ print $2 }'`
4340583701dSJoseph Chen
4357c3ca500SJoseph Chen				PAD_LOADER=`echo $item | awk '{ print $8 }'`
4367c3ca500SJoseph Chen				PAD_TRUST=`echo  $item | awk '{ print $9 }'`
4370583701dSJoseph Chen				if [ "$PAD_LOADER" != "-" ]; then
4380583701dSJoseph Chen					RKCHIP_LOADER=${RKCHIP_LOADER}${PAD_LOADER}
4390583701dSJoseph Chen				fi
4400583701dSJoseph Chen				if [ "$PAD_TRUST" != "-" ]; then
4410583701dSJoseph Chen					RKCHIP_TRUST=${RKCHIP_TRUST}${PAD_TRUST}
4420583701dSJoseph Chen				fi
4430583701dSJoseph Chen				RKCHIP_LABEL=${RKCHIP_LABEL}"AARCH32"
4440583701dSJoseph Chen			else
4457c3ca500SJoseph Chen				cfg_u_kb=`echo  $item | awk '{ print $4 }' | awk -F "," '{ print $1 }'`
4467c3ca500SJoseph Chen				cfg_u_num=`echo $item | awk '{ print $5 }' | awk -F "," '{ print $1 }'`
4477c3ca500SJoseph Chen				cfg_t_kb=`echo  $item | awk '{ print $4 }' | awk -F "," '{ print $2 }'`
4487c3ca500SJoseph Chen				cfg_t_num=`echo $item | awk '{ print $5 }' | awk -F "," '{ print $2 }'`
449de440615SJoseph Chen			fi
450de440615SJoseph Chen		fi
451de440615SJoseph Chen	done
452de440615SJoseph Chen
4537c3ca500SJoseph Chen	if [ "$cfg_sha" != "-" ]; then
4547c3ca500SJoseph Chen		PLATFORM_SHA="--sha $cfg_sha"
4550583701dSJoseph Chen	fi
4567c3ca500SJoseph Chen	if [ "$cfg_rsa" != "-" ]; then
4577c3ca500SJoseph Chen		PLATFORM_RSA="--rsa $cfg_rsa"
4580583701dSJoseph Chen	fi
4597c3ca500SJoseph Chen	if [ "$cfg_u_kb" != "-" ]; then
4607c3ca500SJoseph Chen		PLATFORM_UBOOT_IMG_SIZE="--size $cfg_u_kb $cfg_u_num"
4610583701dSJoseph Chen	fi
4627c3ca500SJoseph Chen	if [ "$cfg_t_kb" != "-" ]; then
4637c3ca500SJoseph Chen		PLATFORM_TRUST_IMG_SIZE="--size $cfg_t_kb $cfg_t_num"
46441cf5e5aSJoseph Chen	fi
46541cf5e5aSJoseph Chen
4660583701dSJoseph Chen	# echo "## $FUNCNAME: $PLATFORM_RSA, $PLATFORM_SHA, $PLATFORM_TRUST_IMG_SIZE, $PLATFORM_UBOOT_IMG_SIZE"
4670583701dSJoseph Chen	# echo "## $FUNCNAME: $RKCHIP_LOADER, $RKCHIP_TRUST, $RKCHIP_LABEL"
46827a50c86SAndy Yan}
469de9a6cd2SJoseph Chen
4707c3ca500SJoseph Chenfunction pack_uboot_image()
471de9a6cd2SJoseph Chen{
4728f53a15cSJoseph Chen	if [ "$PACK_FORMAT" != "rk" ]; then
4738f53a15cSJoseph Chen		return
4748f53a15cSJoseph Chen	fi
4758f53a15cSJoseph Chen
476f089d907SJoseph Chen	# Check file size
4777c3ca500SJoseph Chen	head_kb=2
4787c3ca500SJoseph Chen	uboot_kb=`ls -l u-boot.bin | awk '{print $5}'`
479f089d907SJoseph Chen	if [ "$PLATFORM_UBOOT_IMG_SIZE" = "" ]; then
4807c3ca500SJoseph Chen		uboot_max_kb=1046528
481f089d907SJoseph Chen	else
4827c3ca500SJoseph Chen		uboot_max_kb=`echo $PLATFORM_UBOOT_IMG_SIZE | awk '{print strtonum($2)}'`
4837c3ca500SJoseph Chen		uboot_max_kb=$(((uboot_max_kb-head_kb)*1024))
484f089d907SJoseph Chen	fi
485f089d907SJoseph Chen
4867c3ca500SJoseph Chen	if [ $uboot_kb -gt $uboot_max_kb ]; then
487f089d907SJoseph Chen		echo
4887c3ca500SJoseph Chen		echo "ERROR: pack uboot failed! u-boot.bin actual: $uboot_kb bytes, max limit: $uboot_max_kb bytes"
489f089d907SJoseph Chen		exit 1
490f089d907SJoseph Chen	fi
491f089d907SJoseph Chen
4927c3ca500SJoseph Chen	# Pack
4937c3ca500SJoseph Chen	uboot_load_addr=`sed -n "/CONFIG_SYS_TEXT_BASE=/s/CONFIG_SYS_TEXT_BASE=//p" include/autoconf.mk|tr -d '\r'`
4947c3ca500SJoseph Chen	if [ -z $uboot_load_addr ]; then
4957c3ca500SJoseph Chen		echo "ERROR: No CONFIG_SYS_TEXT_BASE for u-boot";
4967c3ca500SJoseph Chen		exit 1
497daa679a7SKever Yang	fi
4987c3ca500SJoseph Chen	${RKTOOLS}/loaderimage --pack --uboot u-boot.bin uboot.img ${uboot_load_addr} ${PLATFORM_UBOOT_IMG_SIZE}
499*a11e2c82SJoseph Chen	rm u-boot.img u-boot-dtb.img -rf
50091205f1dSJoseph Chen	echo "pack uboot okay! Input: u-boot.bin"
501de9a6cd2SJoseph Chen}
502de9a6cd2SJoseph Chen
5037c3ca500SJoseph Chenfunction pack_uboot_itb_image()
504daa3bef5SJoseph Chen{
5057c3ca500SJoseph Chen	if [ "$ARM64_TRUSTZONE" = "y" ]; then
5060d0d4395SJoseph Chen		ini=${RKBIN}/RKTRUST/${RKCHIP_TRUST}${PLATFORM_AARCH32}TRUST.ini
5070d0d4395SJoseph Chen	else
5080d0d4395SJoseph Chen		ini=${RKBIN}/RKTRUST/${RKCHIP_TRUST}TOS.ini
5097c3ca500SJoseph Chen	fi
5107c3ca500SJoseph Chen
5117c3ca500SJoseph Chen	if [ ! -f $ini ]; then
5127c3ca500SJoseph Chen		echo "pack trust failed! Can't find: $ini"
5130d0d4395SJoseph Chen		return
5140d0d4395SJoseph Chen	fi
5150d0d4395SJoseph Chen
5167c3ca500SJoseph Chen	if [ "$ARM64_TRUSTZONE" = "y" ]; then
5177c3ca500SJoseph Chen		bl31=`sed -n '/_bl31_/s/PATH=//p' $ini |tr -d '\r'`
5187c3ca500SJoseph Chen		cp ${RKBIN}/${bl31} bl31.elf
5197c3ca500SJoseph Chen		make CROSS_COMPILE=${TOOLCHAIN_GCC} u-boot.itb
5207c3ca500SJoseph Chen		echo "pack u-boot.itb okay! Input: $ini"
5210d0d4395SJoseph Chen	else
5227c3ca500SJoseph Chen		tos_image=`sed -n "/TOS=/s/TOS=//p" $ini |tr -d '\r'`
5237c3ca500SJoseph Chen		tosta_image=`sed -n "/TOSTA=/s/TOSTA=//p" $ini |tr -d '\r'`
5247c3ca500SJoseph Chen		if [ $tosta_image ]; then
5257c3ca500SJoseph Chen			cp ${RKBIN}/${tosta_image} tee.bin
5267c3ca500SJoseph Chen		elif [ $tos_image ]; then
5277c3ca500SJoseph Chen			cp ${RKBIN}/${tos_image}   tee.bin
5287c3ca500SJoseph Chen		else
5297c3ca500SJoseph Chen			echo "ERROR: No any tee bin"
5300d0d4395SJoseph Chen			exit 1
5310d0d4395SJoseph Chen		fi
5320d0d4395SJoseph Chen
5337c3ca500SJoseph Chen		tee_offset=`sed -n "/ADDR=/s/ADDR=//p" $ini |tr -d '\r'`
5347c3ca500SJoseph Chen		if [ "$tee_offset" = "" ]; then
5357c3ca500SJoseph Chen			tee_offset=0x8400000
536d13b75e1SJoseph Chen		fi
537d13b75e1SJoseph Chen
53885101532SJoseph Chen		mcu_enabled=`awk -F"," '/MCU=/ { printf $3 }' $ini | tr -d ' '`
53985101532SJoseph Chen		if [ "$mcu_enabled" = "enabled" ]; then
54085101532SJoseph Chen			mcu_image=`awk -F"," '/MCU=/ { printf $1 }' $ini | tr -d ' ' | cut -c 5-`
54185101532SJoseph Chen			mcu_offset=`awk -F"," '/MCU=/ { printf $2 }' $ini | tr -d ' '`
54285101532SJoseph Chen			cp ${RKBIN}/${mcu_image} mcu.bin
54385101532SJoseph Chen		fi
54485101532SJoseph Chen
545db3b6a92SJoseph Chen		SPL_FIT_SOURCE=`sed -n "/CONFIG_SPL_FIT_SOURCE=/s/CONFIG_SPL_FIT_SOURCE=//p" .config | tr -d '""'`
546db3b6a92SJoseph Chen		if [ ! -z $SPL_FIT_SOURCE ]; then
547db3b6a92SJoseph Chen			cp $SPL_FIT_SOURCE u-boot.its
548db3b6a92SJoseph Chen		else
549db3b6a92SJoseph Chen			SPL_FIT_GENERATOR=`sed -n "/CONFIG_SPL_FIT_GENERATOR=/s/CONFIG_SPL_FIT_GENERATOR=//p" .config | tr -d '""'`
55085101532SJoseph Chen			$SPL_FIT_GENERATOR $tee_offset $mcu_offset > u-boot.its
551db3b6a92SJoseph Chen		fi
552d13b75e1SJoseph Chen		./tools/mkimage -f u-boot.its -E u-boot.itb
5537c3ca500SJoseph Chen		echo "pack u-boot.itb okay! Input: $ini"
5540d0d4395SJoseph Chen	fi
555daa3bef5SJoseph Chen}
556daa3bef5SJoseph Chen
5577c3ca500SJoseph Chenfunction pack_spl_loader_image()
558daa3bef5SJoseph Chen{
5597c3ca500SJoseph Chen	mode=$1
5607c3ca500SJoseph Chen	tmp_dir=${RKBIN}/tmp
5617c3ca500SJoseph Chen	tmp_ini=${tmp_dir}/${RKCHIP_LOADER}MINIALL.ini
562dd590c93SJoseph Chen	if [ "$FILE" != "" ]; then
563dd590c93SJoseph Chen		ini=$FILE;
5647c3ca500SJoseph Chen	else
5657c3ca500SJoseph Chen		ini=${RKBIN}/RKBOOT/${RKCHIP_LOADER}MINIALL.ini
566dd590c93SJoseph Chen	fi
5677c3ca500SJoseph Chen	if [ ! -f $ini ]; then
5687c3ca500SJoseph Chen		echo "pack TPL+SPL loader failed! Can't find: $ini"
569daa3bef5SJoseph Chen		return
570daa3bef5SJoseph Chen	fi
571daa3bef5SJoseph Chen
572*a11e2c82SJoseph Chen	rm ${tmp_dir} -rf
5737c3ca500SJoseph Chen	mkdir ${tmp_dir} -p
5747c3ca500SJoseph Chen	cp spl/u-boot-spl.bin ${tmp_dir}/
5757c3ca500SJoseph Chen	cp $ini $tmp_ini
576daa3bef5SJoseph Chen	if [ "$mode" = 'spl' ]; then	# pack tpl+spl
577daa3bef5SJoseph Chen		label="TPL+SPL"
5787c3ca500SJoseph Chen		cp tpl/u-boot-tpl.bin ${tmp_dir}/
5797c3ca500SJoseph Chen		header=`sed -n '/NAME=/s/NAME=//p' ${ini}`
5807c3ca500SJoseph Chen		dd if=${tmp_dir}/u-boot-tpl.bin of=${tmp_dir}/tpl.bin bs=1 skip=4
5817c3ca500SJoseph Chen		sed -i "1s/^/${header:0:4}/" ${tmp_dir}/tpl.bin
5827c3ca500SJoseph Chen		sed -i "s/FlashData=.*$/FlashData=.\/tmp\/tpl.bin/" $tmp_ini
5837c3ca500SJoseph Chen	else
5847c3ca500SJoseph Chen		label="SPL"
585daa3bef5SJoseph Chen	fi
586daa3bef5SJoseph Chen
5877c3ca500SJoseph Chen	sed -i "s/FlashBoot=.*$/FlashBoot=.\/tmp\/u-boot-spl.bin/" $tmp_ini
5887c3ca500SJoseph Chen	cd ${RKBIN}
5897c3ca500SJoseph Chen	${RKTOOLS}/boot_merger $tmp_ini
5907c3ca500SJoseph Chen	rm ${tmp_dir} -rf
591daa3bef5SJoseph Chen	cd -
592*a11e2c82SJoseph Chen	rm *_loader_*.bin -rf
593b4e157ffSJoseph Chen	mv ${RKBIN}/*_loader_*.bin ./
5947c3ca500SJoseph Chen
595aa8ddc58SJoseph Chen	filename=`basename *_loader_*.bin`
596aa8ddc58SJoseph Chen	if [[ $filename != *spl* ]]; then
597b4e157ffSJoseph Chen		rename 's/loader_/spl_loader_/' *_loader_*.bin
598aa8ddc58SJoseph Chen	fi
5997c3ca500SJoseph Chen	echo "pack loader(${label}) okay! Input: $ini"
600daa3bef5SJoseph Chen}
601daa3bef5SJoseph Chen
6027c3ca500SJoseph Chenfunction pack_loader_image()
603cd7ae718SJoseph Chen{
6048f53a15cSJoseph Chen	if [ "$PACK_FORMAT" != "rk" ]; then
6058f53a15cSJoseph Chen		return
6068f53a15cSJoseph Chen	fi
6078f53a15cSJoseph Chen
608dd590c93SJoseph Chen	if [ "$FILE" != "" ]; then
609dd590c93SJoseph Chen		ini=$FILE;
6107c3ca500SJoseph Chen	else
6117c3ca500SJoseph Chen		ini=${RKBIN}/RKBOOT/${RKCHIP_LOADER}MINIALL.ini
612dd590c93SJoseph Chen	fi
613dd590c93SJoseph Chen
6140436a29dSJoseph Chen	if [ ! -f $ini ]; then
6150436a29dSJoseph Chen		echo "pack loader failed! Can't find: $ini"
61651441a28SJoseph Chen		return
61751441a28SJoseph Chen	fi
61851441a28SJoseph Chen
619*a11e2c82SJoseph Chen	rm *_loader_*.bin -rf
620783f7f6eSJoseph Chen	numline=`cat $ini | wc -l`
621783f7f6eSJoseph Chen	if [ $numline -eq 1 ]; then
622783f7f6eSJoseph Chen		image=`sed -n "/PATH=/p" $ini | tr -d '\r' | cut -d '=' -f 2`
623783f7f6eSJoseph Chen		cp ${RKBIN}/${image} ./
6247c3ca500SJoseph Chen	else
625cd7ae718SJoseph Chen		cd ${RKBIN}
6267c3ca500SJoseph Chen		${RKTOOLS}/boot_merger $ini
627fb90bd1dSJoseph Chen		cd - && mv ${RKBIN}/*_loader_*.bin ./
6287c3ca500SJoseph Chen	fi
6297c3ca500SJoseph Chen
63069b6e590SJoseph Chen	file=`ls *loader*.bin`
63169b6e590SJoseph Chen	echo "pack $file okay! Input: $ini"
632cd7ae718SJoseph Chen}
633cd7ae718SJoseph Chen
6347c3ca500SJoseph Chenfunction pack_arm32_trust_image()
635cd7ae718SJoseph Chen{
6367c3ca500SJoseph Chen	ini=$1
6377c3ca500SJoseph Chen	tos_image=`sed -n "/TOS=/s/TOS=//p" $ini |tr -d '\r'`
6387c3ca500SJoseph Chen	tosta_image=`sed -n "/TOSTA=/s/TOSTA=//p" $ini |tr -d '\r'`
6397c3ca500SJoseph Chen	tee_output=`sed -n "/OUTPUT=/s/OUTPUT=//p" $ini |tr -d '\r'`
6407c3ca500SJoseph Chen	if [ "$tee_output" = "" ]; then
6417c3ca500SJoseph Chen		tee_output="./trust.img"
64251441a28SJoseph Chen	fi
6437c3ca500SJoseph Chen	tee_offset=`sed -n "/ADDR=/s/ADDR=//p" $ini |tr -d '\r'`
6447c3ca500SJoseph Chen	if [ "$tee_offset" = "" ]; then
6457c3ca500SJoseph Chen		tee_offset=0x8400000
64651441a28SJoseph Chen	fi
64751441a28SJoseph Chen
648cd7ae718SJoseph Chen	# OP-TEE is 132M(0x8400000) offset from DRAM base.
649eee9fb0aSJoseph Chen	dram_base=`sed -n "/CONFIG_SYS_SDRAM_BASE=/s/CONFIG_SYS_SDRAM_BASE=//p" include/autoconf.mk|tr -d '\r'`
6507c3ca500SJoseph Chen	tee_load_addr=$((dram_base+tee_offset))
6517c3ca500SJoseph Chen	tee_load_addr=$(echo "obase=16;${tee_load_addr}"|bc) # Convert Dec to Hex
6520e90839aSJoseph Chen
6537c3ca500SJoseph Chen	if [ $tosta_image ]; then
6547c3ca500SJoseph Chen		${RKTOOLS}/loaderimage --pack --trustos ${RKBIN}/${tosta_image} ${tee_output} ${tee_load_addr} ${PLATFORM_TRUST_IMG_SIZE}
6557c3ca500SJoseph Chen	elif [ $tos_image ]; then
6567c3ca500SJoseph Chen		${RKTOOLS}/loaderimage --pack --trustos ${RKBIN}/${tos_image}   ${tee_output} ${tee_load_addr} ${PLATFORM_TRUST_IMG_SIZE}
657cd7ae718SJoseph Chen	else
6587c3ca500SJoseph Chen		echo "ERROR: No any tee bin"
659a64486b5SJoseph Chen		exit 1
660cd7ae718SJoseph Chen	fi
6617c3ca500SJoseph Chen	echo "pack trust okay! Input: $ini"
66269cce37bSJoseph Chen}
66369cce37bSJoseph Chen
6647c3ca500SJoseph Chenfunction pack_arm64_trust_image()
66569cce37bSJoseph Chen{
6667c3ca500SJoseph Chen	ini=$1
66769cce37bSJoseph Chen	cd ${RKBIN}
6687c3ca500SJoseph Chen	${RKTOOLS}/trust_merger ${PLATFORM_SHA} ${PLATFORM_RSA} ${PLATFORM_TRUST_IMG_SIZE} $ini
66969cce37bSJoseph Chen	cd - && mv ${RKBIN}/trust*.img ./
6707c3ca500SJoseph Chen	echo "pack trust okay! Input: $ini"
67169cce37bSJoseph Chen}
67269cce37bSJoseph Chen
6737c3ca500SJoseph Chenfunction pack_trust_image()
67469cce37bSJoseph Chen{
6758f53a15cSJoseph Chen	if [ "$PACK_FORMAT" != "rk" ]; then
6768f53a15cSJoseph Chen		return
6778f53a15cSJoseph Chen	fi
6788f53a15cSJoseph Chen
679*a11e2c82SJoseph Chen	rm trust*.img -rf
680dd590c93SJoseph Chen	if [ "$FILE" != "" ]; then
681dd590c93SJoseph Chen		ini=$FILE;
6827c3ca500SJoseph Chen	else
6837c3ca500SJoseph Chen		if [ "$ARM64_TRUSTZONE" = "y" ]; then
6847c3ca500SJoseph Chen			ini=${RKBIN}/RKTRUST/${RKCHIP_TRUST}TRUST.ini
6857c3ca500SJoseph Chen		else
6867c3ca500SJoseph Chen			ini=${RKBIN}/RKTRUST/${RKCHIP_TRUST}TOS.ini
6877c3ca500SJoseph Chen		fi
6887c3ca500SJoseph Chen	fi
6897c3ca500SJoseph Chen	if [ ! -f $ini ]; then
6907c3ca500SJoseph Chen		echo "pack trust failed! Can't find: $ini"
6917c3ca500SJoseph Chen		return
692dd590c93SJoseph Chen	fi
693dd590c93SJoseph Chen
694783f7f6eSJoseph Chen	numline=`cat $ini | wc -l`
695783f7f6eSJoseph Chen	if [ $numline -eq 1 ]; then
696783f7f6eSJoseph Chen		image=`sed -n "/PATH=/p" $ini | tr -d '\r' | cut -d '=' -f 2`
697783f7f6eSJoseph Chen		cp ${RKBIN}/${image} ./trust.img
6987c3ca500SJoseph Chen		echo "pack trust okay! Input: $ini"
699783f7f6eSJoseph Chen		return;
70069cce37bSJoseph Chen	else
7017c3ca500SJoseph Chen		if [ "$ARM64_TRUSTZONE" = "y" ]; then
7027c3ca500SJoseph Chen			pack_arm64_trust_image $ini
7037c3ca500SJoseph Chen		else
7047c3ca500SJoseph Chen			pack_arm32_trust_image $ini
705dd590c93SJoseph Chen		fi
706cd7ae718SJoseph Chen	fi
707cd7ae718SJoseph Chen}
708cd7ae718SJoseph Chen
7098f53a15cSJoseph Chenfunction pack_fit_image()
7108f53a15cSJoseph Chen{
7114b4c6841SJoseph Chen	if grep -q '^CONFIG_FIT_SIGNATURE=y' .config ; then
712f9afd3dcSJoseph Chen		./scripts/fit-vboot.sh $*
7134b4c6841SJoseph Chen	else
7148f53a15cSJoseph Chen		./scripts/fit-vboot-uboot.sh --no-vboot --no-rebuild
715*a11e2c82SJoseph Chen		rm uboot.img trust*.img -rf
7168f53a15cSJoseph Chen		echo "pack uboot.img (with uboot trust) okay! Input: $ini"
7174b4c6841SJoseph Chen	fi
7188f53a15cSJoseph Chen}
7198f53a15cSJoseph Chen
7208f53a15cSJoseph Chenfunction pack_images()
7218f53a15cSJoseph Chen{
7228f53a15cSJoseph Chen	if [ "$NOPACK" != "y" ]; then
7238f53a15cSJoseph Chen		if [ "$PACK_FORMAT" = "rk" ]; then
7248f53a15cSJoseph Chen			pack_uboot_image
7258f53a15cSJoseph Chen			pack_trust_image
7268f53a15cSJoseph Chen			pack_loader_image
7278f53a15cSJoseph Chen		elif [ "$PACK_FORMAT" = "fit" ]; then
728f9afd3dcSJoseph Chen			pack_fit_image $ARGS
7298f53a15cSJoseph Chen		fi
7308f53a15cSJoseph Chen	fi
7318f53a15cSJoseph Chen}
7328f53a15cSJoseph Chen
7338f53a15cSJoseph Chenfunction clean_files()
7348f53a15cSJoseph Chen{
7358f53a15cSJoseph Chen	if [ -f spl/u-boot-spl.dtb ]; then
736*a11e2c82SJoseph Chen		rm spl/u-boot-spl.dtb -rf
7378f53a15cSJoseph Chen	fi
7388f53a15cSJoseph Chen	if [ -f tpl/u-boot-tpl.dtb ]; then
739*a11e2c82SJoseph Chen		rm tpl/u-boot-tpl.dtb -rf
7408f53a15cSJoseph Chen	fi
7418f53a15cSJoseph Chen	if [ -f u-boot.dtb ]; then
742*a11e2c82SJoseph Chen		rm u-boot.dtb -rf
7438f53a15cSJoseph Chen	fi
7448f53a15cSJoseph Chen}
7458f53a15cSJoseph Chen
7467c3ca500SJoseph Chenfunction finish()
74730b04afcSJoseph Chen{
74830b04afcSJoseph Chen	echo
749622ccf34SJoseph Chen	if [ ! -z "$OPTION" ]; then
750622ccf34SJoseph Chen		echo "Platform ${RKCHIP_LABEL} is build OK, with exist .config ($OPTION)"
7516084ba49SJoseph Chen	elif [ "$BOARD" = '' -o "$BOARD" = 'nopack' ]; then
7525202fe1fSJoseph Chen		echo "Platform ${RKCHIP_LABEL} is build OK, with exist .config"
75330b04afcSJoseph Chen	else
7545202fe1fSJoseph Chen		echo "Platform ${RKCHIP_LABEL} is build OK, with new .config(make ${BOARD}_defconfig)"
75530b04afcSJoseph Chen	fi
75630b04afcSJoseph Chen}
75730b04afcSJoseph Chen
758cd7ae718SJoseph Chenprepare
7597c2526e9SJoseph Chenselect_toolchain
760de440615SJoseph Chenselect_chip_info
76141cf5e5aSJoseph Chenfixup_platform_configure
7620ff0e214SJoseph Chensub_commands
7638f53a15cSJoseph Chenclean_files
764622ccf34SJoseph Chenmake CROSS_COMPILE=${TOOLCHAIN_GCC} ${OPTION} all --jobs=${JOB}
7658f53a15cSJoseph Chenpack_images
76630b04afcSJoseph Chenfinish
767