xref: /rk3399_rockchip-uboot/make.sh (revision 41cf5e5a16714dd40c62cf9540d4f27009cb5a77)
127a50c86SAndy Yan#!/bin/sh
2cd7ae718SJoseph Chenset -e
327a50c86SAndy YanBOARD=$1
40ff0e214SJoseph ChenSUBCMD=$2
580fb8d2cSShunqian ZhengRKCHIP=${BOARD##*-}
680fb8d2cSShunqian ZhengRKCHIP=$(echo ${RKCHIP} | tr '[a-z]' '[A-Z]')
727a50c86SAndy YanJOB=`sed -n "N;/processor/p" /proc/cpuinfo|wc -l`
87c19369dSJoseph ChenSUPPROT_LIST=`ls configs/*-r[v,k][0-9][0-9][0-9][0-9]_defconfig`
927a50c86SAndy Yan
10366bd23fSJoseph Chen# Declare global default output dir and cmd, update in prepare()
11366bd23fSJoseph ChenOUTDIR=.
12366bd23fSJoseph ChenOUTOPT=
13366bd23fSJoseph Chen
14bc98b3c8SJoseph Chen# Declare global rkbin tools and rkbin Responsity path, updated in prepare()
15bc98b3c8SJoseph ChenTOOLCHAIN_RKBIN=./
16bc98b3c8SJoseph ChenRKBIN=./
17bc98b3c8SJoseph Chen# RKTOOL path
18bc98b3c8SJoseph ChenRKBIN_TOOLS=../rkbin/tools
19bc98b3c8SJoseph Chen
20bc98b3c8SJoseph Chen# Declare global toolchain path for CROSS_COMPILE, updated in select_toolchain()
21bc98b3c8SJoseph ChenTOOLCHAIN_GCC=./
220ff0e214SJoseph ChenTOOLCHAIN_OBJDUMP=./
23bc98b3c8SJoseph Chen# GCC toolchain
24d8540eacSJoseph ChenGCC_ARM32=arm-linux-gnueabihf-
25d8540eacSJoseph ChenGCC_ARM64=aarch64-linux-gnu-
26d8540eacSJoseph ChenTOOLCHAIN_ARM32=../prebuilts/gcc/linux-x86/arm/gcc-linaro-6.3.1-2017.05-x86_64_arm-linux-gnueabihf/bin
27d8540eacSJoseph ChenTOOLCHAIN_ARM64=../prebuilts/gcc/linux-x86/aarch64/gcc-linaro-6.3.1-2017.05-x86_64_aarch64-linux-gnu/bin
280ff0e214SJoseph Chen# OBJDMP
29d8540eacSJoseph ChenOBJ_ARM32=arm-linux-gnueabihf-objdump
30d8540eacSJoseph ChenOBJ_ARM64=aarch64-linux-gnu-objdump
31bc98b3c8SJoseph Chen
32*41cf5e5aSJoseph Chen# Declare global plaform configure, updated in fixup_platform_configure()
33*41cf5e5aSJoseph ChenPLATFORM_RSA=
34*41cf5e5aSJoseph ChenPLATFORM_SHA=
35*41cf5e5aSJoseph ChenPLATFORM_UBOOT_IMG_SIZE=
36*41cf5e5aSJoseph ChenPLATFORM_TRUST_IMG_SIZE=
37*41cf5e5aSJoseph ChenPLATFORM_AARCH32=
38*41cf5e5aSJoseph Chen
39cd7ae718SJoseph Chenprepare()
40cd7ae718SJoseph Chen{
41366bd23fSJoseph Chen	local absolute_path cmd
42cd7ae718SJoseph Chen
43cd7ae718SJoseph Chen	# Check invaid args and help
44bc98b3c8SJoseph Chen	if [ "$BOARD" = '--help' -o "$BOARD" = '-h' -o "$BOARD" = '--h' -o "$BOARD" = '' ]; then
45cd7ae718SJoseph Chen		echo
46bc98b3c8SJoseph Chen		echo "Usage: ./make.sh [board]"
47cd7ae718SJoseph Chen		echo "Example:"
48cd7ae718SJoseph Chen		echo "./make.sh evb-rk3399     ---- build for evb-rk3399_defconfig"
49cd7ae718SJoseph Chen		echo "./make.sh firefly-rk3288 ---- build for firefly-rk3288_defconfig"
50cd7ae718SJoseph Chen		exit 1
51cd7ae718SJoseph Chen	elif [ ! -f configs/${BOARD}_defconfig ]; then
52cd7ae718SJoseph Chen		echo "Can't find: configs/${BOARD}_defconfig"
537c19369dSJoseph Chen		echo
547c19369dSJoseph Chen		echo "*************** Support list ***************"
557c19369dSJoseph Chen		echo "$SUPPROT_LIST"
567c19369dSJoseph Chen		echo "********************************************"
577c19369dSJoseph Chen		echo
58cd7ae718SJoseph Chen		exit 1
59cd7ae718SJoseph Chen	fi
60cd7ae718SJoseph Chen
61bc98b3c8SJoseph Chen	# Initialize RKBIN and TOOLCHAIN_RKBIN
62bc98b3c8SJoseph Chen	if [ -d ${RKBIN_TOOLS} ]; then
63bc98b3c8SJoseph Chen		absolute_path=$(cd `dirname ${RKBIN_TOOLS}`; pwd)
64bc98b3c8SJoseph Chen		RKBIN=${absolute_path}
65bc98b3c8SJoseph Chen		TOOLCHAIN_RKBIN=${absolute_path}/tools
66cd7ae718SJoseph Chen	else
67cd7ae718SJoseph Chen		echo
68cd7ae718SJoseph Chen		echo "Can't find '../rkbin/' Responsity, please download it before pack image!"
69cd7ae718SJoseph Chen		echo "How to obtain? 3 ways:"
70cd7ae718SJoseph Chen		echo "	1. Login your Rockchip gerrit account: \"Projects\" -> \"List\" -> search \"rk/rkbin\" Responsity"
71cd7ae718SJoseph Chen		echo "	2. Github Responsity: https://github.com/rockchip-linux/rkbin"
72cd7ae718SJoseph Chen		echo "	3. Download full release SDK Responsity"
73cd7ae718SJoseph Chen		exit 1
74cd7ae718SJoseph Chen	fi
757c2526e9SJoseph Chen
76366bd23fSJoseph Chen	# Assign output directory
77366bd23fSJoseph Chen	cmd=${SUBCMD%=*}
78366bd23fSJoseph Chen	if [ "${cmd}" = 'O' ]; then
79366bd23fSJoseph Chen		OUTDIR=${SUBCMD#*=}
80366bd23fSJoseph Chen		OUTOPT=O=${OUTDIR}
817c2526e9SJoseph Chen	fi
82cd7ae718SJoseph Chen}
83cd7ae718SJoseph Chen
8427a50c86SAndy Yanselect_toolchain()
8527a50c86SAndy Yan{
86bc98b3c8SJoseph Chen	local absolute_path
87bc98b3c8SJoseph Chen
88366bd23fSJoseph Chen	if grep  -q '^CONFIG_ARM64=y' ${OUTDIR}/.config ; then
89bc98b3c8SJoseph Chen		if [ -d ${TOOLCHAIN_ARM64} ]; then
90bc98b3c8SJoseph Chen			absolute_path=$(cd `dirname ${TOOLCHAIN_ARM64}`; pwd)
91bc98b3c8SJoseph Chen			TOOLCHAIN_GCC=${absolute_path}/bin/${GCC_ARM64}
920ff0e214SJoseph Chen			TOOLCHAIN_OBJDUMP=${absolute_path}/bin/${OBJ_ARM64}
93bc98b3c8SJoseph Chen		else
94366bd23fSJoseph Chen			echo "Can't find toolchain: ${TOOLCHAIN_ARM64}"
95bc98b3c8SJoseph Chen			exit 1
9627a50c86SAndy Yan		fi
9727a50c86SAndy Yan	else
98bc98b3c8SJoseph Chen		if [ -d ${TOOLCHAIN_ARM32} ]; then
99bc98b3c8SJoseph Chen			absolute_path=$(cd `dirname ${TOOLCHAIN_ARM32}`; pwd)
100bc98b3c8SJoseph Chen			TOOLCHAIN_GCC=${absolute_path}/bin/${GCC_ARM32}
1010ff0e214SJoseph Chen			TOOLCHAIN_OBJDUMP=${absolute_path}/bin/${OBJ_ARM32}
102bc98b3c8SJoseph Chen		else
103366bd23fSJoseph Chen			echo "Can't find toolchain: ${TOOLCHAIN_ARM32}"
104bc98b3c8SJoseph Chen			exit 1
10527a50c86SAndy Yan		fi
10627a50c86SAndy Yan	fi
107bc98b3c8SJoseph Chen
108bc98b3c8SJoseph Chen	echo "toolchain: ${TOOLCHAIN_GCC}"
109bc98b3c8SJoseph Chen}
110bc98b3c8SJoseph Chen
1110ff0e214SJoseph Chensub_commands()
1120ff0e214SJoseph Chen{
1130ff0e214SJoseph Chen	local elf=${SUBCMD%-*} opt=${SUBCMD#*-}
1140ff0e214SJoseph Chen
115366bd23fSJoseph Chen	if [ "$elf" = 'elf' ]; then
116366bd23fSJoseph Chen		if [ ! -f ${OUTDIR}/u-boot ]; then
117366bd23fSJoseph Chen			echo "Can't find elf file: ${OUTDIR}/u-boot"
1180ff0e214SJoseph Chen			exit 1
1190ff0e214SJoseph Chen		else
1200ff0e214SJoseph Chen			# default 'elf' without option, use '-D'
1210ff0e214SJoseph Chen			if [ "${elf}" = 'elf' -a "${opt}" = 'elf' ]; then
1220ff0e214SJoseph Chen				opt=D
1230ff0e214SJoseph Chen			fi
1240ff0e214SJoseph Chen
125366bd23fSJoseph Chen			${TOOLCHAIN_OBJDUMP} -${opt} ${OUTDIR}/u-boot | less
12607de173aSJoseph Chen			exit 0
12707de173aSJoseph Chen		fi
128a43a18b2SJoseph Chen	elif [ "$SUBCMD" = 'trust' ]; then
129a43a18b2SJoseph Chen		pack_trust_image
130a43a18b2SJoseph Chen		exit 0
131a43a18b2SJoseph Chen	elif [ "$SUBCMD" = 'loader' ]; then
132a43a18b2SJoseph Chen		pack_loader_image
133a43a18b2SJoseph Chen		exit 0
1340ff0e214SJoseph Chen	fi
1350ff0e214SJoseph Chen}
1360ff0e214SJoseph Chen
137*41cf5e5aSJoseph Chenfixup_platform_configure()
138bc98b3c8SJoseph Chen{
139*41cf5e5aSJoseph Chen# <1> Fixup chip name for searching trust/loader ini files
14080fb8d2cSShunqian Zheng	if [ "$RKCHIP" = 'RK3228' -o "$RKCHIP" = 'RK3229' ]; then
14180fb8d2cSShunqian Zheng		RKCHIP=RK322X
142bc98b3c8SJoseph Chen	fi
143*41cf5e5aSJoseph Chen
144*41cf5e5aSJoseph Chen# <2> Fixup rsa/sha pack mode for platforms
145*41cf5e5aSJoseph Chen	# RK3308/PX30/RK3326 use RSA-PKCS1 V2.1, it's pack magic is "3"
146*41cf5e5aSJoseph Chen	if [ $RKCHIP = "PX30" -o $RKCHIP = "RK3326" -o $RKCHIP = "RK3308" ]; then
147*41cf5e5aSJoseph Chen		PLATFORM_RSA="--rsa 3"
148*41cf5e5aSJoseph Chen	# RK3368 use rk big endian SHA256, it's pack magic is "2"
149*41cf5e5aSJoseph Chen	elif [ $RKCHIP = "RK3368" ]; then
150*41cf5e5aSJoseph Chen		PLATFORM_SHA="--sha 2"
151*41cf5e5aSJoseph Chen	# other platforms use default configure
152*41cf5e5aSJoseph Chen	fi
153*41cf5e5aSJoseph Chen
154*41cf5e5aSJoseph Chen# <3> Fixup images size pack for platforms
155*41cf5e5aSJoseph Chen	if [ $RKCHIP = "RK3308" ]; then
156*41cf5e5aSJoseph Chen		if grep -q '^CONFIG_ARM64_BOOT_AARCH32=y' ${OUTDIR}/.config ; then
157*41cf5e5aSJoseph Chen			PLATFORM_UBOOT_IMG_SIZE="--size 512 2"
158*41cf5e5aSJoseph Chen			PLATFORM_TRUST_IMG_SIZE="--size 512 2"
159*41cf5e5aSJoseph Chen		else
160*41cf5e5aSJoseph Chen			PLATFORM_UBOOT_IMG_SIZE="--size 1024 2"
161*41cf5e5aSJoseph Chen			PLATFORM_TRUST_IMG_SIZE="--size 1024 2"
162*41cf5e5aSJoseph Chen		fi
163*41cf5e5aSJoseph Chen	fi
164*41cf5e5aSJoseph Chen
165*41cf5e5aSJoseph Chen# <4> Fixup PLATFORM_AARCH32 for ARM64 cpu platforms
166*41cf5e5aSJoseph Chen	if [ $RKCHIP = "RK3308" ]; then
167*41cf5e5aSJoseph Chen		if grep -q '^CONFIG_ARM64_BOOT_AARCH32=y' ${OUTDIR}/.config ; then
168*41cf5e5aSJoseph Chen			PLATFORM_AARCH32="AARCH32"
169*41cf5e5aSJoseph Chen		fi
170*41cf5e5aSJoseph Chen	fi
17127a50c86SAndy Yan}
172de9a6cd2SJoseph Chen
173cd7ae718SJoseph Chenpack_uboot_image()
174de9a6cd2SJoseph Chen{
175cd7ae718SJoseph Chen	local UBOOT_LOAD_ADDR
176de9a6cd2SJoseph Chen
177366bd23fSJoseph Chen	UBOOT_LOAD_ADDR=`sed -n "/CONFIG_SYS_TEXT_BASE=/s/CONFIG_SYS_TEXT_BASE=//p" ${OUTDIR}/include/autoconf.mk|tr -d '\r'`
178*41cf5e5aSJoseph Chen	${TOOLCHAIN_RKBIN}/loaderimage --pack --uboot ${OUTDIR}/u-boot.bin uboot.img ${UBOOT_LOAD_ADDR} ${PLATFORM_UBOOT_IMG_SIZE}
1797c19369dSJoseph Chen
1807c19369dSJoseph Chen	if [ -f ${OUTDIR}/u-boot.img ]; then
1817c19369dSJoseph Chen		rm ${OUTDIR}/u-boot.img
1827c19369dSJoseph Chen	fi
1837c19369dSJoseph Chen
1847c19369dSJoseph Chen	if [ -f ${OUTDIR}/u-boot-dtb.img ]; then
1857c19369dSJoseph Chen		rm ${OUTDIR}/u-boot-dtb.img
1867c19369dSJoseph Chen	fi
1877c19369dSJoseph Chen
188366bd23fSJoseph Chen	echo "pack uboot okay! Input: ${OUTDIR}/u-boot.bin"
189de9a6cd2SJoseph Chen}
190de9a6cd2SJoseph Chen
191cd7ae718SJoseph Chenpack_loader_image()
192cd7ae718SJoseph Chen{
19380fb8d2cSShunqian Zheng	if [ ! -f ${RKBIN}/RKBOOT/${RKCHIP}MINIALL.ini ]; then
19480fb8d2cSShunqian Zheng		echo "pack loader failed! Can't find: ${RKBIN}/RKBOOT/${RKCHIP}MINIALL.ini"
19551441a28SJoseph Chen		return
19651441a28SJoseph Chen	fi
19751441a28SJoseph Chen
198cd7ae718SJoseph Chen	cd ${RKBIN}
19980fb8d2cSShunqian Zheng	${TOOLCHAIN_RKBIN}/boot_merger --replace tools/rk_tools/ ./ ${RKBIN}/RKBOOT/${RKCHIP}MINIALL.ini
200cd7ae718SJoseph Chen	cd -
201cd7ae718SJoseph Chen	mv ${RKBIN}/*_loader_*.bin ./
20280fb8d2cSShunqian Zheng	echo "pack loader okay! Input: ${RKBIN}/RKBOOT/${RKCHIP}MINIALL.ini"
203cd7ae718SJoseph Chen}
204cd7ae718SJoseph Chen
205cd7ae718SJoseph Chenpack_trust_image()
206cd7ae718SJoseph Chen{
207*41cf5e5aSJoseph Chen	local TOS TOS_TA DARM_BASE TEE_LOAD_ADDR TEE_OFFSET=0x8400000
208cd7ae718SJoseph Chen
209cd7ae718SJoseph Chen	# ARM64 uses trust_merger
210fa400ae5SJoseph Chen	if grep -Eq ''^CONFIG_ARM64=y'|'^CONFIG_ARM64_BOOT_AARCH32=y'' ${OUTDIR}/.config ; then
211*41cf5e5aSJoseph Chen		if [ ! -f ${RKBIN}/RKTRUST/${RKCHIP}${PLATFORM_AARCH32}TRUST.ini ]; then
212*41cf5e5aSJoseph Chen			echo "pack trust failed! Can't find: ${RKBIN}/RKTRUST/${RKCHIP}${PLATFORM_AARCH32}TRUST.ini"
21351441a28SJoseph Chen			return
21451441a28SJoseph Chen		fi
21551441a28SJoseph Chen
216cd7ae718SJoseph Chen		cd ${RKBIN}
217*41cf5e5aSJoseph Chen		${TOOLCHAIN_RKBIN}/trust_merger ${PLATFORM_SHA} ${PLATFORM_RSA} ${PLATFORM_TRUST_IMG_SIZE} --replace tools/rk_tools/ ./ ${RKBIN}/RKTRUST/${RKCHIP}${PLATFORM_AARCH32}TRUST.ini
218e5e978b3SJoseph Chen
219cd7ae718SJoseph Chen		cd -
220cd7ae718SJoseph Chen		mv ${RKBIN}/trust.img ./trust.img
221*41cf5e5aSJoseph Chen		echo "pack trust okay! Input: ${RKBIN}/RKTRUST/${RKCHIP}${PLATFORM_AARCH32}TRUST.ini"
222cd7ae718SJoseph Chen	# ARM uses loaderimage
223cd7ae718SJoseph Chen	else
22480fb8d2cSShunqian Zheng		if [ ! -f ${RKBIN}/RKTRUST/${RKCHIP}TOS.ini ]; then
22580fb8d2cSShunqian Zheng			echo "pack trust failed! Can't find: ${RKBIN}/RKTRUST/${RKCHIP}TOS.ini"
22651441a28SJoseph Chen			return
22751441a28SJoseph Chen		fi
22851441a28SJoseph Chen
229cd7ae718SJoseph Chen		# OP-TEE is 132M(0x8400000) offset from DRAM base.
230366bd23fSJoseph Chen		DARM_BASE=`sed -n "/CONFIG_SYS_SDRAM_BASE=/s/CONFIG_SYS_SDRAM_BASE=//p" ${OUTDIR}/include/autoconf.mk|tr -d '\r'`
231cd7ae718SJoseph Chen		TEE_LOAD_ADDR=$((DARM_BASE+TEE_OFFSET))
232cd7ae718SJoseph Chen
233cd7ae718SJoseph Chen		# Convert Dec to Hex
234cd7ae718SJoseph Chen		TEE_LOAD_ADDR=$(echo "obase=16;${TEE_LOAD_ADDR}"|bc)
235cd7ae718SJoseph Chen
2360e90839aSJoseph Chen		# Parse orignal path
23780fb8d2cSShunqian Zheng		TOS=`sed -n "/TOS=/s/TOS=//p" ${RKBIN}/RKTRUST/${RKCHIP}TOS.ini|tr -d '\r'`
23880fb8d2cSShunqian Zheng		TOS_TA=`sed -n "/TOSTA=/s/TOSTA=//p" ${RKBIN}/RKTRUST/${RKCHIP}TOS.ini|tr -d '\r'`
239cd7ae718SJoseph Chen
2400e90839aSJoseph Chen		# replace "./tools/rk_tools/" with "./" to compatible legacy ini content of rkdevelop branch
2410e90839aSJoseph Chen		TOS=$(echo ${TOS} | sed "s/tools\/rk_tools\//\.\//g")
2420e90839aSJoseph Chen		TOS_TA=$(echo ${TOS_TA} | sed "s/tools\/rk_tools\//\.\//g")
2430e90839aSJoseph Chen
244a64486b5SJoseph Chen		if [ $TOS_TA -a $TOS ]; then
245*41cf5e5aSJoseph Chen			${TOOLCHAIN_RKBIN}/loaderimage --pack --trustos ${RKBIN}/${TOS} ./trust.img ${TEE_LOAD_ADDR} ${PLATFORM_TRUST_IMG_SIZE}
246*41cf5e5aSJoseph Chen			${TOOLCHAIN_RKBIN}/loaderimage --pack --trustos ${RKBIN}/${TOS_TA} ./trust_with_ta.img ${TEE_LOAD_ADDR} ${PLATFORM_TRUST_IMG_SIZE}
247cd7ae718SJoseph Chen			echo "Both trust.img and trust_with_ta.img are ready"
248cd7ae718SJoseph Chen		elif [ $TOS ]; then
249*41cf5e5aSJoseph Chen			${TOOLCHAIN_RKBIN}/loaderimage --pack --trustos ${RKBIN}/${TOS} ./trust.img ${TEE_LOAD_ADDR} ${PLATFORM_TRUST_IMG_SIZE}
250cd7ae718SJoseph Chen			echo "trust.img is ready"
251cd7ae718SJoseph Chen		elif [ $TOS_TA ]; then
252*41cf5e5aSJoseph Chen			${TOOLCHAIN_RKBIN}/loaderimage --pack --trustos ${RKBIN}/${TOS_TA} ./trust.img ${TEE_LOAD_ADDR} ${PLATFORM_TRUST_IMG_SIZE}
253cd7ae718SJoseph Chen			echo "trust.img with ta is ready"
254cd7ae718SJoseph Chen		else
255a64486b5SJoseph Chen			echo "Can't find any tee bin"
256a64486b5SJoseph Chen			exit 1
257cd7ae718SJoseph Chen		fi
25851441a28SJoseph Chen
25980fb8d2cSShunqian Zheng		echo "pack trust okay! Input: ${RKBIN}/RKTRUST/${RKCHIP}TOS.ini"
260cd7ae718SJoseph Chen	fi
261cd7ae718SJoseph Chen}
262cd7ae718SJoseph Chen
263cd7ae718SJoseph Chenprepare
26427a50c86SAndy Yanecho "make for ${BOARD}_defconfig by -j${JOB}"
265366bd23fSJoseph Chenmake ${BOARD}_defconfig ${OUTOPT}
2667c2526e9SJoseph Chenselect_toolchain
267*41cf5e5aSJoseph Chenfixup_platform_configure
2680ff0e214SJoseph Chensub_commands
269366bd23fSJoseph Chenmake CROSS_COMPILE=${TOOLCHAIN_GCC}  all --jobs=${JOB} ${OUTOPT}
270cd7ae718SJoseph Chenpack_uboot_image
271d93242f2SJoseph Chenpack_loader_image
272cd7ae718SJoseph Chenpack_trust_image
273