xref: /rk3399_rockchip-uboot/make.sh (revision 07d90e7755d2e5140e8e2c34d555da8e47b4af3f)
1de440615SJoseph Chen#!/bin/bash
2f7bec228SJoseph Chen#
3f7bec228SJoseph Chen# Copyright (c) 2019 Fuzhou Rockchip Electronics Co., Ltd
4f7bec228SJoseph Chen#
5f7bec228SJoseph Chen# SPDX-License-Identifier: GPL-2.0
6f7bec228SJoseph Chen#
7f7bec228SJoseph Chen
8cd7ae718SJoseph Chenset -e
927a50c86SAndy YanJOB=`sed -n "N;/processor/p" /proc/cpuinfo|wc -l`
10b6255198SJoseph ChenSUPPORT_LIST=`ls configs/*[r,p][x,v,k][0-9][0-9]*_defconfig`
1127a50c86SAndy Yan
120583701dSJoseph Chen# @LOADER: map to $RKCHIP_LOADER for loader ini
130583701dSJoseph Chen# @TRUST:  map to $RKCHIP_TRUST for trust ini
140583701dSJoseph Chen# @LABEL:  map to $RKCHIP_LEBEL for verbose message
150583701dSJoseph Chen# @-:      default state/value
160583701dSJoseph ChenCHIP_TYPE_FIXUP_TABLE=(
170583701dSJoseph Chen	# CONFIG_XXX                         RKCHIP         LOADER       TRUST         LABEL
180583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK3368              RK3368H         -            -             -"
190583701dSJoseph Chen	"CONFIG_ROCKCHIP_RV1108              RV110X          -            -             -"
200583701dSJoseph Chen	"CONFIG_ROCKCHIP_PX3SE               PX3SE           -            -             -"
210583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK3126              RK3126          -            -             -"
220583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK3326              RK3326          -            -             -"
230583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK3128X             RK3128X         -            -             -"
240583701dSJoseph Chen	"CONFIG_ROCKCHIP_PX5                 PX5             -            -             -"
250583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK3399PRO           RK3399PRO       -            -             -"
260583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK1806              RK1806          -            -             -"
270583701dSJoseph Chen	"CONFIG_TARGET_GVA_RK3229            RK322X          RK322XAT     -             -"
280583701dSJoseph Chen	"CONFIG_COPROCESSOR_RK1808           RKNPU-LION      RKNPULION    RKNPULION     -"
290583701dSJoseph Chen)
300583701dSJoseph Chen
310583701dSJoseph Chen# <*> Fixup rsa/sha pack mode for platforms
320583701dSJoseph Chen#     RSA: RK3308/PX30/RK3326/RK1808 use RSA-PKCS1 V2.1, it's pack magic is "3", and others use default configure.
330583701dSJoseph Chen#     SHA: RK3368 use rk big endian SHA256, it's pack magic is "2", and others use default configure.
340583701dSJoseph Chen# <*> Fixup images size pack for platforms
350583701dSJoseph Chen# <*> Fixup verbose message about AARCH32
36de440615SJoseph Chen#
370583701dSJoseph Chen# @RSA:     rsa mode
380583701dSJoseph Chen# @SHA:     sha mode
390583701dSJoseph Chen# @A64-KB:  arm64 platform image size: [uboot,trust]
400583701dSJoseph Chen# @A64-NUM: arm64 platform image number of total: [uboot,trust]
410583701dSJoseph Chen# @A32-KB:  arm32 platform image size: [uboot,trust]
420583701dSJoseph Chen# @A32-NUM: arm32 platform image number of total: [uboot,trust]
430583701dSJoseph Chen# @LOADER:  map to $RKCHIP_LOADER for loader ini
440583701dSJoseph Chen# @TRUST:   map to $RKCHIP_TRUST for trust ini
450583701dSJoseph Chen# @-:       default state/value
460583701dSJoseph ChenCHIP_CFG_FIXUP_TABLE=(
470583701dSJoseph Chen	# CONFIG_XXX              RSA     SHA     A64-KB      A64-NUM     A32-KB       A32-NUM      LOAER        TRUST
480583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK3368    -       2       -,-          -,-        -,-          -,-           -           -"
490583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK3036    -       -       512,512      1,1        -,-          -,-           -           -"
500583701dSJoseph Chen	"CONFIG_ROCKCHIP_PX30      3       -       -,-          -,-        -,-          -,-           -           -"
510583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK3326    3       -       -,-          -,-        -,-          -,-           AARCH32     -"
520583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK3308    3       -       1024,1024    2,2        512,512      2,2           -           AARCH32"
530583701dSJoseph Chen	"CONFIG_ROCKCHIP_RK1808    3       -       1024,1024    2,2        -,-          -,-           -           -"
542e566761SJoseph Chen	"CONFIG_ROCKCHIP_RV1126    3       -       -,-          -,-        -,-          -,-           -           -"
55de440615SJoseph Chen)
56de440615SJoseph Chen
5700dada44SJoseph ChenCHIP_TPL_MAGIC_TABLE=(
5800dada44SJoseph Chen	"CONFIG_ROCKCHIP_PX30      RK33"
5900dada44SJoseph Chen	"CONFIG_ROCKCHIP_RV1126    110B"
6000dada44SJoseph Chen)
6100dada44SJoseph Chen
62fb90bd1dSJoseph Chen########################################### User can modify #############################################
63fb90bd1dSJoseph Chen# User's rkbin tool relative path
64bc98b3c8SJoseph ChenRKBIN_TOOLS=../rkbin/tools
65bc98b3c8SJoseph Chen
66fb90bd1dSJoseph Chen# User's GCC toolchain and relative path
6753ea5791SJoseph ChenADDR2LINE_ARM32=arm-linux-gnueabihf-addr2line
6853ea5791SJoseph ChenADDR2LINE_ARM64=aarch64-linux-gnu-addr2line
69fb90bd1dSJoseph ChenOBJ_ARM32=arm-linux-gnueabihf-objdump
70fb90bd1dSJoseph ChenOBJ_ARM64=aarch64-linux-gnu-objdump
71d8540eacSJoseph ChenGCC_ARM32=arm-linux-gnueabihf-
72d8540eacSJoseph ChenGCC_ARM64=aarch64-linux-gnu-
73d8540eacSJoseph ChenTOOLCHAIN_ARM32=../prebuilts/gcc/linux-x86/arm/gcc-linaro-6.3.1-2017.05-x86_64_arm-linux-gnueabihf/bin
74d8540eacSJoseph ChenTOOLCHAIN_ARM64=../prebuilts/gcc/linux-x86/aarch64/gcc-linaro-6.3.1-2017.05-x86_64_aarch64-linux-gnu/bin
75fb90bd1dSJoseph Chen
76fb90bd1dSJoseph Chen########################################### User not touch #############################################
7723ba6841SJoseph ChenRKTOOLS=./tools
7823ba6841SJoseph Chen
79de440615SJoseph Chen# Declare global INI file searching index name for every chip, update in select_chip_info()
800583701dSJoseph ChenRKCHIP="-"
810583701dSJoseph ChenRKCHIP_LABEL="-"
820583701dSJoseph ChenRKCHIP_LOADER="-"
830583701dSJoseph ChenRKCHIP_TRUST="-"
84d443b7d5SJoseph Chen
85b768b915SJoseph ChenINI_TRUST=
86b768b915SJoseph ChenINI_LOADER=
87b768b915SJoseph Chen
8823ba6841SJoseph Chen# Declare rkbin repository path, updated in prepare()
89fb90bd1dSJoseph ChenRKBIN=
90fb90bd1dSJoseph Chen
91fb90bd1dSJoseph Chen# Declare global toolchain path for CROSS_COMPILE, updated in select_toolchain()
92fb90bd1dSJoseph ChenTOOLCHAIN_GCC=
93fb90bd1dSJoseph ChenTOOLCHAIN_OBJDUMP=
9453ea5791SJoseph ChenTOOLCHAIN_ADDR2LINE=
95fb90bd1dSJoseph Chen
9641cf5e5aSJoseph Chen# Declare global plaform configure, updated in fixup_platform_configure()
9741cf5e5aSJoseph ChenPLATFORM_RSA=
9841cf5e5aSJoseph ChenPLATFORM_SHA=
99b42b4e11SJoseph ChenPLATFORM_UBOOT_SIZE=
100b42b4e11SJoseph ChenPLATFORM_TRUST_SIZE=
101b42b4e11SJoseph ChenPLATFORM_TYPE="RKFW"
102aa8ddc58SJoseph Chen
103fb90bd1dSJoseph Chen#########################################################################################################
1047c3ca500SJoseph Chenfunction help()
105b6255198SJoseph Chen{
106b6255198SJoseph Chen	echo
1076a764259SJoseph Chen	echo "Usage:"
108b768b915SJoseph Chen	echo "	./make.sh [board|sub-command]"
1096a764259SJoseph Chen	echo
1106a764259SJoseph Chen	echo "	 - board:        board name of defconfig"
11107329002SJoseph Chen	echo "	 - sub-command:  elf*|loader*|spl*|tpl*|itb|trust*|uboot|map|sym|<addr>"
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{
149bc98b3c8SJoseph Chen	if [ -d ${RKBIN_TOOLS} ]; then
150bc98b3c8SJoseph Chen		absolute_path=$(cd `dirname ${RKBIN_TOOLS}`; pwd)
151bc98b3c8SJoseph Chen		RKBIN=${absolute_path}
152cd7ae718SJoseph Chen	else
153b768b915SJoseph Chen		echo "ERROR: No ../rkbin repository"
154cd7ae718SJoseph Chen		exit 1
155cd7ae718SJoseph Chen	fi
15669b6e590SJoseph Chen
1577c3ca500SJoseph Chen	if grep -Eq ''^CONFIG_ARM64=y'|'^CONFIG_ARM64_BOOT_AARCH32=y'' .config ; then
1587c3ca500SJoseph Chen		ARM64_TRUSTZONE="y"
1597c3ca500SJoseph Chen	fi
1607c3ca500SJoseph Chen
16169b6e590SJoseph Chen	if grep  -q '^CONFIG_ROCKCHIP_FIT_IMAGE_PACK=y' .config ; then
162b42b4e11SJoseph Chen		PLATFORM_TYPE="FIT"
163b768b915SJoseph Chen	fi
164b768b915SJoseph Chen}
165b768b915SJoseph Chen
166b768b915SJoseph Chenfunction process_args()
167b768b915SJoseph Chen{
168b768b915SJoseph Chen	while [ $# -gt 0 ]; do
169b768b915SJoseph Chen		case $1 in
170b768b915SJoseph Chen			--help|-help|help|--h|-h)
171b768b915SJoseph Chen				help
172b768b915SJoseph Chen				exit 0
173b768b915SJoseph Chen				;;
174b42b4e11SJoseph Chen
175f9976ae4SJoseph Chen			''|loader|trust|uboot|spl*|tpl*|debug*|itb|env|fit*)
176b42b4e11SJoseph Chen				ARG_CMD=$1
177b768b915SJoseph Chen				shift 1
178b768b915SJoseph Chen				;;
179b42b4e11SJoseph Chen
180*07d90e77SJoseph Chen			--sz-trust)
181*07d90e77SJoseph Chen				ARG_TRUST_SIZE="--size $2 $3"
182*07d90e77SJoseph Chen				shift 3
183*07d90e77SJoseph Chen				;;
184*07d90e77SJoseph Chen
185*07d90e77SJoseph Chen			--sz-uboot)
186*07d90e77SJoseph Chen				ARG_UBOOT_SIZE="--size $2 $3"
187*07d90e77SJoseph Chen				shift 3
188*07d90e77SJoseph Chen				;;
189*07d90e77SJoseph Chen
190f9976ae4SJoseph Chen			--no-pack)
191f9976ae4SJoseph Chen				ARG_NO_PACK="y"
192f9976ae4SJoseph Chen				shift 1
193f9976ae4SJoseph Chen				;;
194f9976ae4SJoseph Chen
195f9976ae4SJoseph Chen			--no-uboot)
196f9976ae4SJoseph Chen				ARG_NO_UBOOT="y"
197f9976ae4SJoseph Chen				shift 1
198f9976ae4SJoseph Chen				;;
199f9976ae4SJoseph Chen
200b768b915SJoseph Chen			map|sym|elf*)
201b42b4e11SJoseph Chen				ARG_CMD=$1
202b42b4e11SJoseph Chen				if [ "$2" == "spl" -o "$2" == "tpl" ]; then
203b768b915SJoseph Chen					ARG_S_TPL=$2
204b768b915SJoseph Chen					shift 1
205b768b915SJoseph Chen				fi
206b768b915SJoseph Chen				shift 1
207b768b915SJoseph Chen				;;
208b42b4e11SJoseph Chen
2091ff581bbSJoseph Chen			*.ini)
210b768b915SJoseph Chen				if [ ! -f $1 ]; then
211b768b915SJoseph Chen					echo "ERROR: No $1"
212b768b915SJoseph Chen				fi
213b768b915SJoseph Chen				if grep -q 'CODE471_OPTION' $1 ; then
214b768b915SJoseph Chen					ARG_INI_LOADER=$1
215b768b915SJoseph Chen				elif grep -Eq ''BL31_OPTION'|'TOS'' $1 ; then
216b768b915SJoseph Chen					ARG_INI_TRUST=$1
217b768b915SJoseph Chen				fi
218b768b915SJoseph Chen				shift 1
219b768b915SJoseph Chen				;;
220b42b4e11SJoseph Chen
221b768b915SJoseph Chen			*)
2221ff581bbSJoseph Chen				# out scripts args
2231ff581bbSJoseph Chen				NUM=$(./scripts/fit-mkimg.sh --p-check $1)
224b42b4e11SJoseph Chen				if  [ ${NUM} -ne 0 ]; then
225b42b4e11SJoseph Chen					[ ${NUM} -eq 1 ] && ARG_LIST_FIT="${ARG_LIST_FIT} $1"
226b42b4e11SJoseph Chen					[ ${NUM} -eq 2 ] && ARG_LIST_FIT="${ARG_LIST_FIT} $1 $2"
2271ff581bbSJoseph Chen					shift ${NUM}
2281ff581bbSJoseph Chen					continue
229b768b915SJoseph Chen				# FUNC address
2301ff581bbSJoseph Chen				elif [ -z $(echo $1 | sed 's/[0-9,a-f,A-F,x,X,-]//g') ]; then
231b768b915SJoseph Chen					ARG_FUNCADDR=$1
2321ff581bbSJoseph Chen				# xxx_defconfig
233b768b915SJoseph Chen				else
234b768b915SJoseph Chen					ARG_BOARD=$1
235124e8c09SJoseph Chen					if [ ! -f configs/${ARG_BOARD}_defconfig -a ! -f configs/${ARG_BOARD}.config ]; then
236b768b915SJoseph Chen						echo -e "\n${SUPPORT_LIST}\n"
237b768b915SJoseph Chen						echo "ERROR: No configs/${ARG_BOARD}_defconfig"
238b768b915SJoseph Chen						exit 1
239124e8c09SJoseph Chen					elif [ -f configs/${ARG_BOARD}.config ]; then
2401df865f3SJoseph Chen						BASE1_DEFCONFIG=`sed -n "/CONFIG_BASE_DEFCONFIG=/s/CONFIG_BASE_DEFCONFIG=//p" configs/${ARG_BOARD}.config |tr -d '\r' | tr -d '"'`
2411df865f3SJoseph Chen						BASE0_DEFCONFIG=`sed -n "/CONFIG_BASE_DEFCONFIG=/s/CONFIG_BASE_DEFCONFIG=//p" configs/${BASE1_DEFCONFIG} |tr -d '\r' | tr -d '"'`
2421df865f3SJoseph Chen						MAKE_CMD="make ${BASE0_DEFCONFIG} ${BASE1_DEFCONFIG} ${ARG_BOARD}.config -j${JOB}"
243124e8c09SJoseph Chen						echo "## ${MAKE_CMD}"
2441df865f3SJoseph Chen						make ${BASE0_DEFCONFIG} ${BASE1_DEFCONFIG} ${ARG_BOARD}.config ${OPTION}
245b768b915SJoseph Chen					else
246124e8c09SJoseph Chen						MAKE_CMD="make ${ARG_BOARD}_defconfig -j${JOB}"
247124e8c09SJoseph Chen						echo "## ${MAKE_CMD}"
248124e8c09SJoseph Chen						make ${ARG_BOARD}_defconfig ${OPTION}
249b768b915SJoseph Chen					fi
250b768b915SJoseph Chen				fi
251b768b915SJoseph Chen				shift 1
252b768b915SJoseph Chen				;;
253b768b915SJoseph Chen		esac
254b768b915SJoseph Chen	done
255b768b915SJoseph Chen
256b768b915SJoseph Chen	if [ ! -f .config ]; then
257b768b915SJoseph Chen		echo
258b768b915SJoseph Chen		echo "ERROR: No .config"
259b768b915SJoseph Chen		help
260b768b915SJoseph Chen		exit 1
26169b6e590SJoseph Chen	fi
26230b04afcSJoseph Chen}
2637c2526e9SJoseph Chen
2647c3ca500SJoseph Chenfunction select_toolchain()
26527a50c86SAndy Yan{
266d6821889SJoseph Chen	if grep -q '^CONFIG_ARM64=y' .config ; then
267bc98b3c8SJoseph Chen		if [ -d ${TOOLCHAIN_ARM64} ]; then
268bc98b3c8SJoseph Chen			absolute_path=$(cd `dirname ${TOOLCHAIN_ARM64}`; pwd)
269bc98b3c8SJoseph Chen			TOOLCHAIN_GCC=${absolute_path}/bin/${GCC_ARM64}
2700ff0e214SJoseph Chen			TOOLCHAIN_OBJDUMP=${absolute_path}/bin/${OBJ_ARM64}
27153ea5791SJoseph Chen			TOOLCHAIN_ADDR2LINE=${absolute_path}/bin/${ADDR2LINE_ARM64}
272bc98b3c8SJoseph Chen		else
2737c3ca500SJoseph Chen			echo "ERROR: No toolchain: ${TOOLCHAIN_ARM64}"
274bc98b3c8SJoseph Chen			exit 1
27527a50c86SAndy Yan		fi
27627a50c86SAndy Yan	else
277bc98b3c8SJoseph Chen		if [ -d ${TOOLCHAIN_ARM32} ]; then
278bc98b3c8SJoseph Chen			absolute_path=$(cd `dirname ${TOOLCHAIN_ARM32}`; pwd)
279bc98b3c8SJoseph Chen			TOOLCHAIN_GCC=${absolute_path}/bin/${GCC_ARM32}
2800ff0e214SJoseph Chen			TOOLCHAIN_OBJDUMP=${absolute_path}/bin/${OBJ_ARM32}
28153ea5791SJoseph Chen			TOOLCHAIN_ADDR2LINE=${absolute_path}/bin/${ADDR2LINE_ARM32}
282bc98b3c8SJoseph Chen		else
2837c3ca500SJoseph Chen			echo "ERROR: No toolchain: ${TOOLCHAIN_ARM32}"
284bc98b3c8SJoseph Chen			exit 1
28527a50c86SAndy Yan		fi
28627a50c86SAndy Yan	fi
287bc98b3c8SJoseph Chen}
288bc98b3c8SJoseph Chen
2897c3ca500SJoseph Chenfunction sub_commands()
2900ff0e214SJoseph Chen{
291f9afd3dcSJoseph Chen	# skip "--" parameter, such as "--rollback-index-..."
292b42b4e11SJoseph Chen	if [[ "${ARG_CMD}" != "--*" ]]; then
293b42b4e11SJoseph Chen		cmd=${ARG_CMD%-*}
294b42b4e11SJoseph Chen		arg=${ARG_CMD#*-}
295f9afd3dcSJoseph Chen	else
296b42b4e11SJoseph Chen		cmd=${ARG_CMD}
297f9afd3dcSJoseph Chen	fi
298f9afd3dcSJoseph Chen
299b42b4e11SJoseph Chen	if [ "${ARG_S_TPL}" == "tpl" -o "${ARG_S_TPL}" == "spl" ]; then
300b768b915SJoseph Chen		elf=`find -name u-boot-${ARG_S_TPL}`
301b768b915SJoseph Chen		map=`find -name u-boot-${ARG_S_TPL}.map`
302b768b915SJoseph Chen		sym=`find -name u-boot-${ARG_S_TPL}.sym`
303b768b915SJoseph Chen	else
3047c3ca500SJoseph Chen		elf=u-boot
3057c3ca500SJoseph Chen		map=u-boot.map
3067c3ca500SJoseph Chen		sym=u-boot.sym
30734bdfea0SJoseph Chen	fi
3080ff0e214SJoseph Chen
309b42b4e11SJoseph Chen	case ${cmd} in
310b6255198SJoseph Chen		elf)
3117c3ca500SJoseph Chen			if [ ! -f ${elf} ]; then
3127c3ca500SJoseph Chen				echo "ERROR: No elf: ${elf}"
3130ff0e214SJoseph Chen				exit 1
3140ff0e214SJoseph Chen			else
315b42b4e11SJoseph Chen				if [ "${cmd}" == "elf" -a "${arg}" == "elf" ]; then
316b42b4e11SJoseph Chen					arg=D # default
3170ff0e214SJoseph Chen				fi
318b42b4e11SJoseph Chen				${TOOLCHAIN_OBJDUMP} -${arg} ${elf} | less
31907de173aSJoseph Chen				exit 0
32007de173aSJoseph Chen			fi
321b6255198SJoseph Chen			;;
322b6255198SJoseph Chen
3231b6c85a0SJoseph Chen		debug)
324b42b4e11SJoseph Chen			./scripts/rkpatch.sh ${arg}
3251b6c85a0SJoseph Chen			exit 0
3261b6c85a0SJoseph Chen			;;
3271b6c85a0SJoseph Chen
32869b6e590SJoseph Chen		fit)
329b42b4e11SJoseph Chen			if [ "${arg}" == "ns" ]; then
3300d7448d0SJoseph Chen				./scripts/fit-mkimg.sh --uboot-itb --boot-itb --no-vboot ${ARG_LIST_FIT}
3316cf81e27SJoseph Chen			fi
33269b6e590SJoseph Chen			exit 0
33369b6e590SJoseph Chen			;;
33469b6e590SJoseph Chen
335b6255198SJoseph Chen		map)
33634bdfea0SJoseph Chen			cat ${map} | less
337b6255198SJoseph Chen			exit 0
338b6255198SJoseph Chen			;;
339b6255198SJoseph Chen
340b6255198SJoseph Chen		sym)
34134bdfea0SJoseph Chen			cat ${sym} | less
342b6255198SJoseph Chen			exit 0
343b6255198SJoseph Chen			;;
344b6255198SJoseph Chen
345b6255198SJoseph Chen		trust)
346d6e1155eSJoseph Chen			pack_trust_image
347a43a18b2SJoseph Chen			exit 0
348b6255198SJoseph Chen			;;
349b6255198SJoseph Chen
350b6255198SJoseph Chen		loader)
351d6e1155eSJoseph Chen			pack_loader_image
352a43a18b2SJoseph Chen			exit 0
353b6255198SJoseph Chen			;;
354b6255198SJoseph Chen
35507329002SJoseph Chen		tpl|spl)
35607329002SJoseph Chen			pack_spl_loader_image ${ARG_CMD}
357daa3bef5SJoseph Chen			exit 0
358daa3bef5SJoseph Chen			;;
359daa3bef5SJoseph Chen
360daa3bef5SJoseph Chen		itb)
361daa3bef5SJoseph Chen			pack_uboot_itb_image
362daa3bef5SJoseph Chen			exit 0
363daa3bef5SJoseph Chen			;;
364daa3bef5SJoseph Chen
365b6255198SJoseph Chen		uboot)
366b768b915SJoseph Chen			pack_uboot_image
367fb90bd1dSJoseph Chen			exit 0
368b6255198SJoseph Chen			;;
369b6255198SJoseph Chen
370398d3e80SJoseph Chen		env)
371398d3e80SJoseph Chen			make CROSS_COMPILE=${TOOLCHAIN_GCC} envtools
372398d3e80SJoseph Chen			exit 0
373398d3e80SJoseph Chen			;;
374398d3e80SJoseph Chen
375f9afd3dcSJoseph Chen		--rollback-index*)
376b42b4e11SJoseph Chen			pack_fit_image ${ARG_LIST_FIT}
377f9afd3dcSJoseph Chen			exit 0
378f9afd3dcSJoseph Chen			;;
379b6255198SJoseph Chen		*)
38053ea5791SJoseph Chen			# Search function and code position of address
381b42b4e11SJoseph Chen			FUNCADDR=${ARG_FUNCADDR}
382fc99e044SJoseph Chen			RELOC_OFF=${FUNCADDR#*-}
383fc99e044SJoseph Chen			FUNCADDR=${FUNCADDR%-*}
384fc99e044SJoseph Chen			if [ -z $(echo ${FUNCADDR} | sed 's/[0-9,a-f,A-F,x,X,-]//g') ] && [ ${FUNCADDR} ]; then
3857070f875SJoseph Chen				# With prefix: '0x' or '0X'
3867070f875SJoseph Chen				if [ `echo ${FUNCADDR} | sed -n "/0[x,X]/p" | wc -l` -ne 0 ]; then
387b42b4e11SJoseph Chen					FUNCADDR=`echo ${FUNCADDR} | awk '{ print strtonum($0) }'`
3887070f875SJoseph Chen					FUNCADDR=`echo "obase=16;${FUNCADDR}"|bc |tr '[A-Z]' '[a-z]'`
3897070f875SJoseph Chen				fi
390fc99e044SJoseph Chen				if [ `echo ${RELOC_OFF} | sed -n "/0[x,X]/p" | wc -l` -ne 0 ] && [ ${RELOC_OFF} ]; then
391b42b4e11SJoseph Chen					RELOC_OFF=`echo ${RELOC_OFF} | awk '{ print strtonum($0) }'`
392fc99e044SJoseph Chen					RELOC_OFF=`echo "obase=16;${RELOC_OFF}"|bc |tr '[A-Z]' '[a-z]'`
393fc99e044SJoseph Chen				fi
394fc99e044SJoseph Chen
395fc99e044SJoseph Chen				# If reloc address is assigned, do sub
396fc99e044SJoseph Chen				if [ "${FUNCADDR}" != "${RELOC_OFF}" ]; then
397fc99e044SJoseph Chen					# Hex -> Dec -> SUB -> Hex
398fc99e044SJoseph Chen					FUNCADDR=`echo $((16#${FUNCADDR}))`
399fc99e044SJoseph Chen					RELOC_OFF=`echo $((16#${RELOC_OFF}))`
400fc99e044SJoseph Chen					FUNCADDR=$((FUNCADDR-RELOC_OFF))
401fc99e044SJoseph Chen					FUNCADDR=$(echo "obase=16;${FUNCADDR}"|bc |tr '[A-Z]' '[a-z]')
402fc99e044SJoseph Chen				fi
4037070f875SJoseph Chen
40453ea5791SJoseph Chen				echo
40534bdfea0SJoseph Chen				sed -n "/${FUNCADDR}/p" ${sym}
40634bdfea0SJoseph Chen				${TOOLCHAIN_ADDR2LINE} -e ${elf} ${FUNCADDR}
40753ea5791SJoseph Chen				exit 0
40853ea5791SJoseph Chen			fi
409b6255198SJoseph Chen			;;
410b6255198SJoseph Chen	esac
4110ff0e214SJoseph Chen}
4120ff0e214SJoseph Chen
413b42b4e11SJoseph Chen#
414de440615SJoseph Chen# We select chip info to do:
415de440615SJoseph Chen#	1. RKCHIP:        fixup platform configure
416de440615SJoseph Chen#	2. RKCHIP_LOADER: search ini file to pack loader
417de440615SJoseph Chen#	3. RKCHIP_TRUST:  search ini file to pack trust
418de440615SJoseph Chen#	4. RKCHIP_LABEL:  show build message
419de440615SJoseph Chen#
4207c3ca500SJoseph Chenfunction select_chip_info()
421bc98b3c8SJoseph Chen{
422de440615SJoseph Chen	# Read RKCHIP firstly from .config
423596700d7SShunqian Zheng	# The regular expression that matching:
424596700d7SShunqian Zheng	#  - PX30, PX3SE
425596700d7SShunqian Zheng	#  - RK????, RK????X
426596700d7SShunqian Zheng	#  - RV????
4277c3ca500SJoseph Chen	chip_pattern='^CONFIG_ROCKCHIP_[R,P][X,V,K][0-9ESX]{1,5}'
4287c3ca500SJoseph Chen	RKCHIP=`egrep -o ${chip_pattern} .config`
429d443b7d5SJoseph Chen
4300583701dSJoseph Chen	# default
431d443b7d5SJoseph Chen	RKCHIP=${RKCHIP##*_}
432b42b4e11SJoseph Chen	# fixup ?
4337c3ca500SJoseph Chen	for item in "${CHIP_TYPE_FIXUP_TABLE[@]}"
434de440615SJoseph Chen	do
435b42b4e11SJoseph Chen		config_xxx=`echo ${item} | awk '{ print $1 }'`
4367c3ca500SJoseph Chen		if grep  -q "^${config_xxx}=y" .config ; then
437b42b4e11SJoseph Chen			RKCHIP=`echo ${item} | awk '{ print $2 }'`
438b42b4e11SJoseph Chen			RKCHIP_LOADER=`echo ${item} | awk '{ print $3 }'`
439b42b4e11SJoseph Chen			RKCHIP_TRUST=`echo  ${item} | awk '{ print $4 }'`
440b42b4e11SJoseph Chen			RKCHIP_LABEL=`echo  ${item} | awk '{ print $5 }'`
441de440615SJoseph Chen		fi
4420583701dSJoseph Chen	done
4430583701dSJoseph Chen
444b42b4e11SJoseph Chen	if [ "${RKCHIP_LOADER}" == "-" ]; then
4450583701dSJoseph Chen		RKCHIP_LOADER=${RKCHIP}
446de440615SJoseph Chen	fi
447b42b4e11SJoseph Chen	if [ "${RKCHIP_TRUST}" == "-" ]; then
4480583701dSJoseph Chen		RKCHIP_TRUST=${RKCHIP}
4490583701dSJoseph Chen	fi
450b42b4e11SJoseph Chen	if [ "${RKCHIP_LABEL}" == "-" ]; then
4510583701dSJoseph Chen		RKCHIP_LABEL=${RKCHIP}
4520583701dSJoseph Chen	fi
4530583701dSJoseph Chen}
4540583701dSJoseph Chen
455*07d90e77SJoseph Chen# Priority: default < CHIP_CFG_FIXUP_TABLE() < make.sh args
4560583701dSJoseph Chenfunction fixup_platform_configure()
4570583701dSJoseph Chen{
458b768b915SJoseph Chen	u_kb="-" u_num="-" t_kb="-" t_num="-"  sha="-" rsa="-"
4590583701dSJoseph Chen
4607c3ca500SJoseph Chen	for item in "${CHIP_CFG_FIXUP_TABLE[@]}"
4610583701dSJoseph Chen	do
462b42b4e11SJoseph Chen		config_xxx=`echo ${item} | awk '{ print $1 }'`
4637c3ca500SJoseph Chen		if grep  -q "^${config_xxx}=y" .config ; then
4640583701dSJoseph Chen			# <*> Fixup rsa/sha pack mode for platforms
465b42b4e11SJoseph Chen			rsa=`echo ${item} | awk '{ print $2 }'`
466b42b4e11SJoseph Chen			sha=`echo ${item} | awk '{ print $3 }'`
4670583701dSJoseph Chen
4680583701dSJoseph Chen			# <*> Fixup images size pack for platforms, and ini file
46989d0489dSJoseph Chen			if grep -q '^CONFIG_ARM64=y' .config ; then
47089d0489dSJoseph Chen				u_kb=`echo  ${item} | awk '{ print $4 }' | awk -F "," '{ print $1 }'`
47189d0489dSJoseph Chen				t_kb=`echo  ${item} | awk '{ print $4 }' | awk -F "," '{ print $2 }'`
47289d0489dSJoseph Chen				u_num=`echo ${item} | awk '{ print $5 }' | awk -F "," '{ print $1 }'`
47389d0489dSJoseph Chen				t_num=`echo ${item} | awk '{ print $5 }' | awk -F "," '{ print $2 }'`
47489d0489dSJoseph Chen			else
475b42b4e11SJoseph Chen				u_kb=`echo  ${item} | awk '{ print $6 }' | awk -F "," '{ print $1 }'`
476b42b4e11SJoseph Chen				t_kb=`echo  ${item} | awk '{ print $6 }' | awk -F "," '{ print $2 }'`
477b42b4e11SJoseph Chen				u_num=`echo ${item} | awk '{ print $7 }' | awk -F "," '{ print $1 }'`
478b42b4e11SJoseph Chen				t_num=`echo ${item} | awk '{ print $7 }' | awk -F "," '{ print $2 }'`
47989d0489dSJoseph Chen				# AArch32
48089d0489dSJoseph Chen				if grep -q '^CONFIG_ARM64_BOOT_AARCH32=y' .config ; then
481b42b4e11SJoseph Chen					PADDING=`echo ${item} | awk '{ print $8 }'`
482b42b4e11SJoseph Chen					if [ "${PADDING}" != "-" ]; then
483b42b4e11SJoseph Chen						RKCHIP_LOADER=${RKCHIP_LOADER}${PADDING}
4840583701dSJoseph Chen					fi
485b42b4e11SJoseph Chen					PADDING=`echo  ${item} | awk '{ print $9 }'`
486b42b4e11SJoseph Chen					if [ "${PADDING}" != "-" ]; then
487b42b4e11SJoseph Chen						RKCHIP_TRUST=${RKCHIP_TRUST}${PADDING}
4880583701dSJoseph Chen					fi
4890583701dSJoseph Chen					RKCHIP_LABEL=${RKCHIP_LABEL}"AARCH32"
49089d0489dSJoseph Chen				fi
491de440615SJoseph Chen			fi
492de440615SJoseph Chen		fi
493de440615SJoseph Chen	done
494de440615SJoseph Chen
495b42b4e11SJoseph Chen	if [ "${sha}" != "-" ]; then
496b42b4e11SJoseph Chen		PLATFORM_SHA="--sha ${sha}"
4970583701dSJoseph Chen	fi
498b42b4e11SJoseph Chen	if [ "${rsa}" != "-" ]; then
499b42b4e11SJoseph Chen		PLATFORM_RSA="--rsa ${rsa}"
5000583701dSJoseph Chen	fi
501b42b4e11SJoseph Chen	if [ "${u_kb}" != "-" ]; then
502b42b4e11SJoseph Chen		PLATFORM_UBOOT_SIZE="--size ${u_kb} ${u_num}"
5030583701dSJoseph Chen	fi
504b42b4e11SJoseph Chen	if [ "${t_kb}" != "-" ]; then
505b42b4e11SJoseph Chen		PLATFORM_TRUST_SIZE="--size ${t_kb} ${t_num}"
506b768b915SJoseph Chen	fi
507*07d90e77SJoseph Chen
508*07d90e77SJoseph Chen	# args
509*07d90e77SJoseph Chen	if [ ! -z "${ARG_UBOOT_SIZE}" ]; then
510*07d90e77SJoseph Chen		PLATFORM_UBOOT_SIZE=${ARG_UBOOT_SIZE}
511*07d90e77SJoseph Chen	fi
512*07d90e77SJoseph Chen
513*07d90e77SJoseph Chen	if [ ! -z "${ARG_TRUST_SIZE}" ]; then
514*07d90e77SJoseph Chen		PLATFORM_TRUST_SIZE=${ARG_TRUST_SIZE}
515*07d90e77SJoseph Chen	fi
516b768b915SJoseph Chen}
517b768b915SJoseph Chen
518496a6e1eSJoseph Chen# Priority: default < CHIP_TYPE_FIXUP_TABLE() < defconfig < make.sh args
519b768b915SJoseph Chenfunction select_ini_file()
520b768b915SJoseph Chen{
521b768b915SJoseph Chen	# default
522b768b915SJoseph Chen	INI_LOADER=${RKBIN}/RKBOOT/${RKCHIP_LOADER}MINIALL.ini
523b42b4e11SJoseph Chen	if [ "${ARM64_TRUSTZONE}" == "y" ]; then
524b768b915SJoseph Chen		INI_TRUST=${RKBIN}/RKTRUST/${RKCHIP_TRUST}TRUST.ini
525b768b915SJoseph Chen	else
526b768b915SJoseph Chen		INI_TRUST=${RKBIN}/RKTRUST/${RKCHIP_TRUST}TOS.ini
52741cf5e5aSJoseph Chen	fi
52841cf5e5aSJoseph Chen
529496a6e1eSJoseph Chen	# defconfig
530496a6e1eSJoseph Chen	NAME=`sed -n "/CONFIG_LOADER_INI=/s/CONFIG_LOADER_INI=//p" .config |tr -d '\r' | tr -d '"'`
531496a6e1eSJoseph Chen	if [ ! -z "${NAME}" ]; then
532496a6e1eSJoseph Chen		INI_LOADER=${RKBIN}/RKBOOT/${NAME}
533496a6e1eSJoseph Chen	fi
534496a6e1eSJoseph Chen	NAME=`sed -n "/CONFIG_TRUST_INI=/s/CONFIG_TRUST_INI=//p" .config |tr -d '\r' | tr -d '"'`
535496a6e1eSJoseph Chen	if [ ! -z "${NAME}" ]; then
536496a6e1eSJoseph Chen		INI_TRUST=${RKBIN}/RKTRUST/${NAME}
537496a6e1eSJoseph Chen	fi
538496a6e1eSJoseph Chen
539b768b915SJoseph Chen	# args
540b42b4e11SJoseph Chen	if [ "${ARG_INI_TRUST}" != "" ]; then
541b42b4e11SJoseph Chen		INI_TRUST=${ARG_INI_TRUST}
542b768b915SJoseph Chen	fi
543b42b4e11SJoseph Chen	if [ "${ARG_INI_LOADER}" != "" ]; then
544b42b4e11SJoseph Chen		INI_LOADER=${ARG_INI_LOADER}
545b768b915SJoseph Chen	fi
54627a50c86SAndy Yan}
547de9a6cd2SJoseph Chen
548b6e67ca8SJoseph Chenfunction handle_args_late()
549b6e67ca8SJoseph Chen{
550b42b4e11SJoseph Chen	ARG_LIST_FIT="${ARG_LIST_FIT} --ini-trust ${INI_TRUST} --ini-loader ${INI_LOADER}"
551b6e67ca8SJoseph Chen}
552b6e67ca8SJoseph Chen
5537c3ca500SJoseph Chenfunction pack_uboot_image()
554de9a6cd2SJoseph Chen{
555b42b4e11SJoseph Chen	if [ "${PLATFORM_TYPE}" != "RKFW" ]; then
5568f53a15cSJoseph Chen		return
5578f53a15cSJoseph Chen	fi
5588f53a15cSJoseph Chen
559f089d907SJoseph Chen	# Check file size
5607c3ca500SJoseph Chen	head_kb=2
5617c3ca500SJoseph Chen	uboot_kb=`ls -l u-boot.bin | awk '{ print $5 }'`
562b42b4e11SJoseph Chen	if [ "${PLATFORM_UBOOT_SIZE}" == "" ]; then
5637c3ca500SJoseph Chen		uboot_max_kb=1046528
564f089d907SJoseph Chen	else
565b42b4e11SJoseph Chen		uboot_max_kb=`echo ${PLATFORM_UBOOT_SIZE} | awk '{print strtonum($2)}'`
5667c3ca500SJoseph Chen		uboot_max_kb=$(((uboot_max_kb-head_kb)*1024))
567f089d907SJoseph Chen	fi
568f089d907SJoseph Chen
569b42b4e11SJoseph Chen	if [ ${uboot_kb} -gt ${uboot_max_kb} ]; then
570f089d907SJoseph Chen		echo
571b42b4e11SJoseph Chen		echo "ERROR: pack uboot failed! u-boot.bin actual: ${uboot_kb} bytes, max limit: ${uboot_max_kb} bytes"
572f089d907SJoseph Chen		exit 1
573f089d907SJoseph Chen	fi
574f089d907SJoseph Chen
5757c3ca500SJoseph Chen	# Pack
5767c3ca500SJoseph Chen	uboot_load_addr=`sed -n "/CONFIG_SYS_TEXT_BASE=/s/CONFIG_SYS_TEXT_BASE=//p" include/autoconf.mk|tr -d '\r'`
577b42b4e11SJoseph Chen	if [ -z ${uboot_load_addr} ]; then
5787c3ca500SJoseph Chen		echo "ERROR: No CONFIG_SYS_TEXT_BASE for u-boot";
5797c3ca500SJoseph Chen		exit 1
580daa679a7SKever Yang	fi
581b42b4e11SJoseph Chen	${RKTOOLS}/loaderimage --pack --uboot u-boot.bin uboot.img ${uboot_load_addr} ${PLATFORM_UBOOT_SIZE}
582a11e2c82SJoseph Chen	rm u-boot.img u-boot-dtb.img -rf
583d6821889SJoseph Chen	echo "pack uboot okay! Input: u-boot.bin"
584de9a6cd2SJoseph Chen}
585de9a6cd2SJoseph Chen
5867c3ca500SJoseph Chenfunction pack_uboot_itb_image()
587daa3bef5SJoseph Chen{
588b42b4e11SJoseph Chen	ini=${INI_TRUST}
589b42b4e11SJoseph Chen	if [ ! -f ${INI_TRUST} ]; then
590b42b4e11SJoseph Chen		echo "pack trust failed! Can't find: ${INI_TRUST}"
5910d0d4395SJoseph Chen		return
5920d0d4395SJoseph Chen	fi
5930d0d4395SJoseph Chen
594b42b4e11SJoseph Chen	if [ "${ARM64_TRUSTZONE}" == "y" ]; then
595b42b4e11SJoseph Chen		bl31=`sed -n '/_bl31_/s/PATH=//p' ${ini} |tr -d '\r'`
5967c3ca500SJoseph Chen		cp ${RKBIN}/${bl31} bl31.elf
5977c3ca500SJoseph Chen		make CROSS_COMPILE=${TOOLCHAIN_GCC} u-boot.itb
598b42b4e11SJoseph Chen		echo "pack u-boot.itb okay! Input: ${ini}"
5990d0d4395SJoseph Chen	else
600b42b4e11SJoseph Chen		tos_image=`sed -n "/TOS=/s/TOS=//p" ${ini} |tr -d '\r'`
601b42b4e11SJoseph Chen		tosta_image=`sed -n "/TOSTA=/s/TOSTA=//p" ${ini} |tr -d '\r'`
602b42b4e11SJoseph Chen		if [ ${tosta_image} ]; then
6037c3ca500SJoseph Chen			cp ${RKBIN}/${tosta_image} tee.bin
604b42b4e11SJoseph Chen		elif [ ${tos_image} ]; then
6057c3ca500SJoseph Chen			cp ${RKBIN}/${tos_image}   tee.bin
6067c3ca500SJoseph Chen		else
6077c3ca500SJoseph Chen			echo "ERROR: No any tee bin"
6080d0d4395SJoseph Chen			exit 1
6090d0d4395SJoseph Chen		fi
6100d0d4395SJoseph Chen
611b42b4e11SJoseph Chen		tee_offset=`sed -n "/ADDR=/s/ADDR=//p" ${ini} |tr -d '\r'`
612b42b4e11SJoseph Chen		if [ "${tee_offset}" == "" ]; then
6137c3ca500SJoseph Chen			tee_offset=0x8400000
614d13b75e1SJoseph Chen		fi
615d13b75e1SJoseph Chen
616b42b4e11SJoseph Chen		mcu_enabled=`awk -F"," '/MCU=/ { printf $3 }' ${ini} | tr -d ' '`
617b42b4e11SJoseph Chen		if [ "${mcu_enabled}" == "enabled" ]; then
618b42b4e11SJoseph Chen			mcu_image=`awk -F"," '/MCU=/  { printf $1 }' ${ini} | tr -d ' ' | cut -c 5-`
61985101532SJoseph Chen			cp ${RKBIN}/${mcu_image} mcu.bin
6201a2ec6b5SJoseph Chen			mcu_offset=`awk -F"," '/MCU=/ { printf $2 }' ${ini} | tr -d ' '`
6211a2ec6b5SJoseph Chen			optional_mcu="-m "${mcu_offset}
6221a2ec6b5SJoseph Chen		else
6231a2ec6b5SJoseph Chen			optional_mcu=
6241a2ec6b5SJoseph Chen		fi
6251a2ec6b5SJoseph Chen
6261a2ec6b5SJoseph Chen		compression=`awk -F"," '/COMPRESSION=/  { printf $1 }' ${ini} | tr -d ' ' | cut -c 13-`
6271a2ec6b5SJoseph Chen		if [ -z "${compression}" ]; then
6281a2ec6b5SJoseph Chen			compression="none"
62985101532SJoseph Chen		fi
63085101532SJoseph Chen
631db3b6a92SJoseph Chen		SPL_FIT_SOURCE=`sed -n "/CONFIG_SPL_FIT_SOURCE=/s/CONFIG_SPL_FIT_SOURCE=//p" .config | tr -d '""'`
632b42b4e11SJoseph Chen		if [ ! -z ${SPL_FIT_SOURCE} ]; then
633b42b4e11SJoseph Chen			cp ${SPL_FIT_SOURCE} u-boot.its
634db3b6a92SJoseph Chen		else
635db3b6a92SJoseph Chen			SPL_FIT_GENERATOR=`sed -n "/CONFIG_SPL_FIT_GENERATOR=/s/CONFIG_SPL_FIT_GENERATOR=//p" .config | tr -d '""'`
6361a2ec6b5SJoseph Chen			${SPL_FIT_GENERATOR} -u -t ${tee_offset} -c ${compression} ${optional_mcu} > u-boot.its
637db3b6a92SJoseph Chen		fi
638d13b75e1SJoseph Chen		./tools/mkimage -f u-boot.its -E u-boot.itb
639b42b4e11SJoseph Chen		echo "pack u-boot.itb okay! Input: ${ini}"
6400d0d4395SJoseph Chen	fi
641b768b915SJoseph Chen	echo
642daa3bef5SJoseph Chen}
643daa3bef5SJoseph Chen
6447c3ca500SJoseph Chenfunction pack_spl_loader_image()
645daa3bef5SJoseph Chen{
6467c3ca500SJoseph Chen	mode=$1
647b42b4e11SJoseph Chen	tmpdir=${RKBIN}/tmp
648b42b4e11SJoseph Chen	tmpini=${tmpdir}/${RKCHIP_LOADER}MINIALL.ini
649b42b4e11SJoseph Chen	ini=${INI_LOADER}
650b42b4e11SJoseph Chen	if [ ! -f ${INI_LOADER} ]; then
651b42b4e11SJoseph Chen		echo "pack loader failed! Can't find: ${INI_LOADER}"
652daa3bef5SJoseph Chen		return
653daa3bef5SJoseph Chen	fi
654daa3bef5SJoseph Chen
65500dada44SJoseph Chen	# Find magic for TPL
65600dada44SJoseph Chen	for item in "${CHIP_TPL_MAGIC_TABLE[@]}"
65700dada44SJoseph Chen	do
65800dada44SJoseph Chen		config_xxx=`echo ${item} | awk '{ print $1 }'`
65900dada44SJoseph Chen		if grep -q "^${config_xxx}=y" .config ; then
66000dada44SJoseph Chen			header=`echo ${item} | awk '{ print $2 }'`
66100dada44SJoseph Chen		fi
66200dada44SJoseph Chen	done
66300dada44SJoseph Chen
66400dada44SJoseph Chen	if [ -z ${header} ]; then
66500dada44SJoseph Chen		header=`sed -n '/NAME=/s/NAME=//p' ${ini}`
66600dada44SJoseph Chen	fi
66700dada44SJoseph Chen
66800dada44SJoseph Chen	# Prepare files
669b42b4e11SJoseph Chen	rm ${tmpdir} -rf && mkdir ${tmpdir} -p
670b42b4e11SJoseph Chen	cp spl/u-boot-spl.bin ${tmpdir}/ && cp ${ini} ${tmpini}
67100dada44SJoseph Chen
67207329002SJoseph Chen	if [ "${mode}" == "tpl-spl" ]; then	# pack tpl+spl
673daa3bef5SJoseph Chen		label="TPL+SPL"
674b42b4e11SJoseph Chen		cp tpl/u-boot-tpl.bin ${tmpdir}/
675b42b4e11SJoseph Chen		dd if=${tmpdir}/u-boot-tpl.bin of=${tmpdir}/tpl.bin bs=1 skip=4
676b42b4e11SJoseph Chen		sed -i "1s/^/${header:0:4}/" ${tmpdir}/tpl.bin
677b42b4e11SJoseph Chen		sed -i "s/FlashData=.*$/FlashData=.\/tmp\/tpl.bin/" ${tmpini}
67800dada44SJoseph Chen		sed -i "0,/Path1=.*/s/Path1=.*$/Path1=.\/tmp\/tpl.bin/" ${tmpini}
67900dada44SJoseph Chen		sed -i "s/FlashBoot=.*$/FlashBoot=.\/tmp\/u-boot-spl.bin/" ${tmpini}
68000dada44SJoseph Chen	elif [ "${mode}" == "tpl" ]; then	# pack tpl
68100dada44SJoseph Chen		label="TPL"
68200dada44SJoseph Chen		cp tpl/u-boot-tpl.bin ${tmpdir}/
68300dada44SJoseph Chen		dd if=${tmpdir}/u-boot-tpl.bin of=${tmpdir}/tpl.bin bs=1 skip=4
68400dada44SJoseph Chen		sed -i "1s/^/${header:0:4}/" ${tmpdir}/tpl.bin
68500dada44SJoseph Chen		sed -i "s/FlashData=.*$/FlashData=.\/tmp\/tpl.bin/" ${tmpini}
68600dada44SJoseph Chen		sed -i "0,/Path1=.*/s/Path1=.*$/Path1=.\/tmp\/tpl.bin/" ${tmpini}
6877c3ca500SJoseph Chen	else
6887c3ca500SJoseph Chen		label="SPL"
689b42b4e11SJoseph Chen		sed -i "s/FlashBoot=.*$/FlashBoot=.\/tmp\/u-boot-spl.bin/" ${tmpini}
69000dada44SJoseph Chen	fi
691daa3bef5SJoseph Chen
69200dada44SJoseph Chen	# Pack
6937c3ca500SJoseph Chen	cd ${RKBIN}
694b42b4e11SJoseph Chen	${RKTOOLS}/boot_merger ${tmpini}
6957c3ca500SJoseph Chen
696b42b4e11SJoseph Chen	rm ${tmpdir} -rf && cd -
697b42b4e11SJoseph Chen	rm *_loader_*.bin -rf && mv ${RKBIN}/*_loader_*.bin ./
698aa8ddc58SJoseph Chen	filename=`basename *_loader_*.bin`
699b42b4e11SJoseph Chen	if [[ ${filename} != *spl* ]]; then
700b4e157ffSJoseph Chen		rename 's/loader_/spl_loader_/' *_loader_*.bin
701aa8ddc58SJoseph Chen	fi
702b42b4e11SJoseph Chen	echo "pack loader(${label}) okay! Input: ${ini}"
703daa3bef5SJoseph Chen}
704daa3bef5SJoseph Chen
7057c3ca500SJoseph Chenfunction pack_loader_image()
706cd7ae718SJoseph Chen{
707b42b4e11SJoseph Chen	ini=${INI_LOADER}
708b42b4e11SJoseph Chen	if [ ! -f ${INI_LOADER} ]; then
709b42b4e11SJoseph Chen		echo "pack loader failed! Can't find: ${INI_LOADER}"
71051441a28SJoseph Chen		return
71151441a28SJoseph Chen	fi
71251441a28SJoseph Chen
713a11e2c82SJoseph Chen	rm *_loader_*.bin -rf
714b42b4e11SJoseph Chen	numline=`cat ${ini} | wc -l`
715b42b4e11SJoseph Chen	if [ ${numline} -eq 1 ]; then
716b42b4e11SJoseph Chen		image=`sed -n "/PATH=/p" ${ini} | tr -d '\r' | cut -d '=' -f 2`
717783f7f6eSJoseph Chen		cp ${RKBIN}/${image} ./
7187c3ca500SJoseph Chen	else
719cd7ae718SJoseph Chen		cd ${RKBIN}
720b42b4e11SJoseph Chen		${RKTOOLS}/boot_merger ${ini}
721fb90bd1dSJoseph Chen		cd - && mv ${RKBIN}/*_loader_*.bin ./
7227c3ca500SJoseph Chen	fi
7237c3ca500SJoseph Chen
72469b6e590SJoseph Chen	file=`ls *loader*.bin`
725b42b4e11SJoseph Chen	echo "pack ${file} okay! Input: ${ini}"
726cd7ae718SJoseph Chen}
727cd7ae718SJoseph Chen
7287c3ca500SJoseph Chenfunction pack_arm32_trust_image()
729cd7ae718SJoseph Chen{
7307c3ca500SJoseph Chen	ini=$1
731b42b4e11SJoseph Chen	tos_image=`sed -n "/TOS=/s/TOS=//p" ${ini} |tr -d '\r'`
732b42b4e11SJoseph Chen	tosta_image=`sed -n "/TOSTA=/s/TOSTA=//p" ${ini} |tr -d '\r'`
733b42b4e11SJoseph Chen	tee_output=`sed -n "/OUTPUT=/s/OUTPUT=//p" ${ini} |tr -d '\r'`
734b42b4e11SJoseph Chen	if [ "${tee_output}" == "" ]; then
7357c3ca500SJoseph Chen		tee_output="./trust.img"
73651441a28SJoseph Chen	fi
737b42b4e11SJoseph Chen	tee_offset=`sed -n "/ADDR=/s/ADDR=//p" ${ini} |tr -d '\r'`
738b42b4e11SJoseph Chen	if [ "${tee_offset}" == "" ]; then
7397c3ca500SJoseph Chen		tee_offset=0x8400000
74051441a28SJoseph Chen	fi
74151441a28SJoseph Chen
742cd7ae718SJoseph Chen	# OP-TEE is 132M(0x8400000) offset from DRAM base.
743eee9fb0aSJoseph Chen	dram_base=`sed -n "/CONFIG_SYS_SDRAM_BASE=/s/CONFIG_SYS_SDRAM_BASE=//p" include/autoconf.mk|tr -d '\r'`
7447c3ca500SJoseph Chen	tee_load_addr=$((dram_base+tee_offset))
7457c3ca500SJoseph Chen	tee_load_addr=$(echo "obase=16;${tee_load_addr}"|bc) # Convert Dec to Hex
7460e90839aSJoseph Chen
747b42b4e11SJoseph Chen	if [ ${tosta_image} ]; then
748b42b4e11SJoseph Chen		${RKTOOLS}/loaderimage --pack --trustos ${RKBIN}/${tosta_image} ${tee_output} ${tee_load_addr} ${PLATFORM_TRUST_SIZE}
749b42b4e11SJoseph Chen	elif [ ${tos_image} ]; then
750b42b4e11SJoseph Chen		${RKTOOLS}/loaderimage --pack --trustos ${RKBIN}/${tos_image}   ${tee_output} ${tee_load_addr} ${PLATFORM_TRUST_SIZE}
751cd7ae718SJoseph Chen	else
7527c3ca500SJoseph Chen		echo "ERROR: No any tee bin"
753a64486b5SJoseph Chen		exit 1
754cd7ae718SJoseph Chen	fi
755b42b4e11SJoseph Chen	echo "pack trust okay! Input: ${ini}"
75669cce37bSJoseph Chen}
75769cce37bSJoseph Chen
7587c3ca500SJoseph Chenfunction pack_arm64_trust_image()
75969cce37bSJoseph Chen{
7607c3ca500SJoseph Chen	ini=$1
76169cce37bSJoseph Chen	cd ${RKBIN}
762b42b4e11SJoseph Chen	${RKTOOLS}/trust_merger ${PLATFORM_SHA} ${PLATFORM_RSA} ${PLATFORM_TRUST_SIZE} ${ini}
76369cce37bSJoseph Chen	cd - && mv ${RKBIN}/trust*.img ./
764b42b4e11SJoseph Chen	echo "pack trust okay! Input: ${ini}"
76569cce37bSJoseph Chen}
76669cce37bSJoseph Chen
7677c3ca500SJoseph Chenfunction pack_trust_image()
76869cce37bSJoseph Chen{
769b42b4e11SJoseph Chen	if [ "${PLATFORM_TYPE}" != "RKFW" ]; then
7708f53a15cSJoseph Chen		return
7718f53a15cSJoseph Chen	fi
7728f53a15cSJoseph Chen
773a11e2c82SJoseph Chen	rm trust*.img -rf
774b42b4e11SJoseph Chen	ini=${INI_TRUST}
775b42b4e11SJoseph Chen	if [ ! -f ${INI_TRUST} ]; then
776b42b4e11SJoseph Chen		echo "pack trust failed! Can't find: ${INI_TRUST}"
7777c3ca500SJoseph Chen		return
778dd590c93SJoseph Chen	fi
779dd590c93SJoseph Chen
780b42b4e11SJoseph Chen	numline=`cat ${ini} | wc -l`
781b42b4e11SJoseph Chen	if [ ${numline} -eq 1 ]; then
782b42b4e11SJoseph Chen		image=`sed -n "/PATH=/p" ${ini} | tr -d '\r' | cut -d '=' -f 2`
783783f7f6eSJoseph Chen		cp ${RKBIN}/${image} ./trust.img
784b42b4e11SJoseph Chen		echo "pack trust okay! Input: ${ini}"
785783f7f6eSJoseph Chen		return;
78669cce37bSJoseph Chen	else
787b42b4e11SJoseph Chen		if [ "${ARM64_TRUSTZONE}" == "y" ]; then
788b42b4e11SJoseph Chen			pack_arm64_trust_image ${ini}
7897c3ca500SJoseph Chen		else
790b42b4e11SJoseph Chen			pack_arm32_trust_image ${ini}
791dd590c93SJoseph Chen		fi
792cd7ae718SJoseph Chen	fi
793cd7ae718SJoseph Chen}
794cd7ae718SJoseph Chen
7958f53a15cSJoseph Chenfunction pack_fit_image()
7968f53a15cSJoseph Chen{
797f9976ae4SJoseph Chen	if [ "${ARG_NO_UBOOT}" == "y" ]; then
798f9976ae4SJoseph Chen		rm u-boot-nodtb.bin u-boot.dtb -rf
799f9976ae4SJoseph Chen		touch u-boot-nodtb.bin u-boot.dtb
800f9976ae4SJoseph Chen	fi
801f9976ae4SJoseph Chen
8024b4c6841SJoseph Chen	if grep -q '^CONFIG_FIT_SIGNATURE=y' .config ; then
803cc0b1aa3SJoseph Chen		./scripts/fit-mkimg.sh --uboot-itb --boot-itb ${ARG_LIST_FIT}
8044b4c6841SJoseph Chen	else
805a11e2c82SJoseph Chen		rm uboot.img trust*.img -rf
806cc0b1aa3SJoseph Chen		./scripts/fit-mkimg.sh --uboot-itb --no-vboot --no-rebuild ${ARG_LIST_FIT}
807b42b4e11SJoseph Chen		echo "pack uboot.img okay! Input: ${INI_TRUST}"
8084b4c6841SJoseph Chen	fi
8098f53a15cSJoseph Chen}
8108f53a15cSJoseph Chen
8118f53a15cSJoseph Chenfunction pack_images()
8128f53a15cSJoseph Chen{
813b42b4e11SJoseph Chen	if [ "${ARG_NO_PACK}" != "y" ]; then
814b42b4e11SJoseph Chen		if [ "${PLATFORM_TYPE}" == "RKFW" ]; then
8158f53a15cSJoseph Chen			pack_uboot_image
8168f53a15cSJoseph Chen			pack_trust_image
8178f53a15cSJoseph Chen			pack_loader_image
818b42b4e11SJoseph Chen		elif [ "${PLATFORM_TYPE}" == "FIT" ]; then
819b42b4e11SJoseph Chen			pack_fit_image ${ARG_LIST_FIT}
8208f53a15cSJoseph Chen		fi
8218f53a15cSJoseph Chen	fi
8228f53a15cSJoseph Chen}
8238f53a15cSJoseph Chen
8248f53a15cSJoseph Chenfunction clean_files()
8258f53a15cSJoseph Chen{
826b42b4e11SJoseph Chen	rm spl/u-boot-spl.dtb tpl/u-boot-tpl.dtb u-boot.dtb -rf
8278f53a15cSJoseph Chen}
8288f53a15cSJoseph Chen
8297c3ca500SJoseph Chenfunction finish()
83030b04afcSJoseph Chen{
83130b04afcSJoseph Chen	echo
832b42b4e11SJoseph Chen	if [ "${ARG_BOARD}" == "" ]; then
8335202fe1fSJoseph Chen		echo "Platform ${RKCHIP_LABEL} is build OK, with exist .config"
83430b04afcSJoseph Chen	else
835124e8c09SJoseph Chen		echo "Platform ${RKCHIP_LABEL} is build OK, with new .config(${MAKE_CMD})"
83630b04afcSJoseph Chen	fi
83730b04afcSJoseph Chen}
83830b04afcSJoseph Chen
839b768b915SJoseph Chenprocess_args $*
840cd7ae718SJoseph Chenprepare
8417c2526e9SJoseph Chenselect_toolchain
842de440615SJoseph Chenselect_chip_info
84341cf5e5aSJoseph Chenfixup_platform_configure
844b768b915SJoseph Chenselect_ini_file
845b6e67ca8SJoseph Chenhandle_args_late
8460ff0e214SJoseph Chensub_commands
8478f53a15cSJoseph Chenclean_files
848b42b4e11SJoseph Chenmake CROSS_COMPILE=${TOOLCHAIN_GCC} all --jobs=${JOB}
8498f53a15cSJoseph Chenpack_images
85030b04afcSJoseph Chenfinish
8511ff581bbSJoseph Chen
852