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 -,- -,- - -" 54de440615SJoseph Chen) 55de440615SJoseph Chen 56fb90bd1dSJoseph Chen########################################### User can modify ############################################# 57fb90bd1dSJoseph Chen# User's rkbin tool relative path 58bc98b3c8SJoseph ChenRKBIN_TOOLS=../rkbin/tools 59bc98b3c8SJoseph Chen 60fb90bd1dSJoseph Chen# User's GCC toolchain and relative path 6153ea5791SJoseph ChenADDR2LINE_ARM32=arm-linux-gnueabihf-addr2line 6253ea5791SJoseph ChenADDR2LINE_ARM64=aarch64-linux-gnu-addr2line 63fb90bd1dSJoseph ChenOBJ_ARM32=arm-linux-gnueabihf-objdump 64fb90bd1dSJoseph ChenOBJ_ARM64=aarch64-linux-gnu-objdump 65d8540eacSJoseph ChenGCC_ARM32=arm-linux-gnueabihf- 66d8540eacSJoseph ChenGCC_ARM64=aarch64-linux-gnu- 67d8540eacSJoseph ChenTOOLCHAIN_ARM32=../prebuilts/gcc/linux-x86/arm/gcc-linaro-6.3.1-2017.05-x86_64_arm-linux-gnueabihf/bin 68d8540eacSJoseph ChenTOOLCHAIN_ARM64=../prebuilts/gcc/linux-x86/aarch64/gcc-linaro-6.3.1-2017.05-x86_64_aarch64-linux-gnu/bin 69fb90bd1dSJoseph Chen 70fb90bd1dSJoseph Chen########################################### User not touch ############################################# 7123ba6841SJoseph ChenRKTOOLS=./tools 7223ba6841SJoseph Chen 73de440615SJoseph Chen# Declare global INI file searching index name for every chip, update in select_chip_info() 740583701dSJoseph ChenRKCHIP="-" 750583701dSJoseph ChenRKCHIP_LABEL="-" 760583701dSJoseph ChenRKCHIP_LOADER="-" 770583701dSJoseph ChenRKCHIP_TRUST="-" 78d443b7d5SJoseph Chen 79b768b915SJoseph ChenINI_TRUST= 80b768b915SJoseph ChenINI_LOADER= 81b768b915SJoseph Chen 8223ba6841SJoseph Chen# Declare rkbin repository path, updated in prepare() 83fb90bd1dSJoseph ChenRKBIN= 84fb90bd1dSJoseph Chen 85fb90bd1dSJoseph Chen# Declare global toolchain path for CROSS_COMPILE, updated in select_toolchain() 86fb90bd1dSJoseph ChenTOOLCHAIN_GCC= 87fb90bd1dSJoseph ChenTOOLCHAIN_OBJDUMP= 8853ea5791SJoseph ChenTOOLCHAIN_ADDR2LINE= 89fb90bd1dSJoseph Chen 90fb90bd1dSJoseph Chen# Declare global default output dir and cmd, update in prepare() 91622ccf34SJoseph ChenOPTION= 92bc98b3c8SJoseph Chen 9341cf5e5aSJoseph Chen# Declare global plaform configure, updated in fixup_platform_configure() 9441cf5e5aSJoseph ChenPLATFORM_RSA= 9541cf5e5aSJoseph ChenPLATFORM_SHA= 9641cf5e5aSJoseph ChenPLATFORM_UBOOT_IMG_SIZE= 9741cf5e5aSJoseph ChenPLATFORM_TRUST_IMG_SIZE= 98b768b915SJoseph Chen 99b768b915SJoseph ChenIMAGE_FORMAT="RKFW" 100b768b915SJoseph ChenIMAGE_NOPACK="n" 101aa8ddc58SJoseph Chen 102fb90bd1dSJoseph Chen######################################################################################################### 1037c3ca500SJoseph Chenfunction help() 104b6255198SJoseph Chen{ 105b6255198SJoseph Chen echo 1066a764259SJoseph Chen echo "Usage:" 107b768b915SJoseph Chen echo " ./make.sh [board|sub-command]" 1086a764259SJoseph Chen echo 1096a764259SJoseph Chen echo " - board: board name of defconfig" 110b768b915SJoseph Chen echo " - sub-command: elf*|loader*|spl*|itb|trust*|uboot|map|sym|<addr>|EXT_DTB=*" 111f3d60245SJoseph Chen echo " - ini: assigned ini file to pack trust/loader" 112f3d60245SJoseph Chen echo 113f3d60245SJoseph Chen echo "Output:" 114f3d60245SJoseph Chen echo " When board built okay, there are uboot/trust/loader images in current directory" 115b6255198SJoseph Chen echo 116b6255198SJoseph Chen echo "Example:" 117b6255198SJoseph Chen echo 118d6821889SJoseph Chen echo "1. Build:" 119fc99e044SJoseph Chen echo " ./make.sh evb-rk3399 --- build for evb-rk3399_defconfig" 120fc99e044SJoseph Chen echo " ./make.sh firefly-rk3288 --- build for firefly-rk3288_defconfig" 121622ccf34SJoseph Chen echo " ./make.sh EXT_DTB=rk-kernel.dtb --- build with exist .config and external dtb" 122fc99e044SJoseph Chen echo " ./make.sh --- build with exist .config" 123398d3e80SJoseph Chen echo " ./make.sh env --- build envtools" 124b6255198SJoseph Chen echo 125d6821889SJoseph Chen echo "2. Pack:" 1266a764259SJoseph Chen echo " ./make.sh uboot --- pack uboot.img" 12769cce37bSJoseph Chen echo " ./make.sh trust --- pack trust.img" 128f3d60245SJoseph Chen echo " ./make.sh trust <ini> --- pack trust img with assigned ini file" 1296a764259SJoseph Chen echo " ./make.sh loader --- pack loader bin" 130f3d60245SJoseph Chen echo " ./make.sh loader <ini> --- pack loader img with assigned ini file" 131f3d60245SJoseph Chen echo " ./make.sh spl --- pack loader with u-boot-spl.bin and u-boot-tpl.bin" 132f3d60245SJoseph Chen echo " ./make.sh spl-s --- pack loader only replace miniloader with u-boot-spl.bin" 133f3d60245SJoseph Chen echo " ./make.sh itb --- pack u-boot.itb(TODO: bl32 is not included for ARMv8)" 134b6255198SJoseph Chen echo 135d6821889SJoseph Chen echo "3. Debug:" 136b6255198SJoseph Chen echo " ./make.sh elf --- dump elf file with -D(default)" 137b6255198SJoseph Chen echo " ./make.sh elf-S --- dump elf file with -S" 1386a764259SJoseph Chen echo " ./make.sh elf-d --- dump elf file with -d" 139f3d60245SJoseph Chen echo " ./make.sh elf-* --- dump elf file with -*" 140fc99e044SJoseph Chen echo " ./make.sh <no reloc_addr> --- dump function symbol and code position of address(no relocated)" 141fc99e044SJoseph Chen echo " ./make.sh <reloc_addr-reloc_off> --- dump function symbol and code position of address(relocated)" 142b6255198SJoseph Chen echo " ./make.sh map --- cat u-boot.map" 143b6255198SJoseph Chen echo " ./make.sh sym --- cat u-boot.sym" 144b6255198SJoseph Chen} 14541cf5e5aSJoseph Chen 1467c3ca500SJoseph Chenfunction prepare() 147cd7ae718SJoseph Chen{ 148bc98b3c8SJoseph Chen if [ -d ${RKBIN_TOOLS} ]; then 149bc98b3c8SJoseph Chen absolute_path=$(cd `dirname ${RKBIN_TOOLS}`; pwd) 150bc98b3c8SJoseph Chen RKBIN=${absolute_path} 151cd7ae718SJoseph Chen else 152b768b915SJoseph Chen echo "ERROR: No ../rkbin repository" 153cd7ae718SJoseph Chen exit 1 154cd7ae718SJoseph Chen fi 15569b6e590SJoseph Chen 1567c3ca500SJoseph Chen if grep -Eq ''^CONFIG_ARM64=y'|'^CONFIG_ARM64_BOOT_AARCH32=y'' .config ; then 1577c3ca500SJoseph Chen ARM64_TRUSTZONE="y" 1587c3ca500SJoseph Chen fi 1597c3ca500SJoseph Chen 16069b6e590SJoseph Chen if grep -q '^CONFIG_ROCKCHIP_FIT_IMAGE_PACK=y' .config ; then 161b768b915SJoseph Chen IMAGE_FORMAT="FIT" 162b768b915SJoseph Chen fi 163b768b915SJoseph Chen} 164b768b915SJoseph Chen 165b768b915SJoseph Chenfunction process_args() 166b768b915SJoseph Chen{ 167b768b915SJoseph Chen while [ $# -gt 0 ]; do 168b768b915SJoseph Chen case $1 in 169b768b915SJoseph Chen --help|-help|help|--h|-h) 170b768b915SJoseph Chen help 171b768b915SJoseph Chen exit 0 172b768b915SJoseph Chen ;; 173b768b915SJoseph Chen 174b768b915SJoseph Chen ''|loader|trust|uboot|spl*|debug*|itb|env|EXT_DTB=*|nopack|fit*) 175b768b915SJoseph Chen ARG_SUBCMD=$1 176b768b915SJoseph Chen shift 1 177b768b915SJoseph Chen ;; 178b768b915SJoseph Chen 179b768b915SJoseph Chen --rollback-index-uboot) 180b768b915SJoseph Chen ARG_ROLLBACK_IDX_UBOOT="--rollback-index-uboot "$2 181b768b915SJoseph Chen shift 2 182b768b915SJoseph Chen ;; 183b768b915SJoseph Chen 184b768b915SJoseph Chen --rollback-index-boot) 185b768b915SJoseph Chen ARG_ROLLBACK_IDX_BOOT="--rollback-index-boot "$2 186b768b915SJoseph Chen shift 2 187b768b915SJoseph Chen ;; 188b768b915SJoseph Chen 189*9b9964b1SJoseph Chen --new-spl) 190*9b9964b1SJoseph Chen ARG_NEW_SPL=$1 191*9b9964b1SJoseph Chen shift 1 192*9b9964b1SJoseph Chen ;; 193b768b915SJoseph Chen map|sym|elf*) 194b768b915SJoseph Chen ARG_SUBCMD=$1 195b768b915SJoseph Chen if [ "$2" = "spl" -o "$2" = "tpl" ]; then 196b768b915SJoseph Chen ARG_S_TPL=$2 197b768b915SJoseph Chen shift 1 198b768b915SJoseph Chen fi 199b768b915SJoseph Chen shift 1 200b768b915SJoseph Chen ;; 201b768b915SJoseph Chen 202b768b915SJoseph Chen *.ini|*.INI) 203b768b915SJoseph Chen if [ ! -f $1 ]; then 204b768b915SJoseph Chen echo "ERROR: No $1" 205b768b915SJoseph Chen fi 206b768b915SJoseph Chen if grep -q 'CODE471_OPTION' $1 ; then 207b768b915SJoseph Chen ARG_INI_LOADER=$1 208b768b915SJoseph Chen elif grep -Eq ''BL31_OPTION'|'TOS'' $1 ; then 209b768b915SJoseph Chen ARG_INI_TRUST=$1 210b768b915SJoseph Chen fi 211b768b915SJoseph Chen shift 1 212b768b915SJoseph Chen ;; 213b768b915SJoseph Chen 214b768b915SJoseph Chen *) 215b768b915SJoseph Chen # FUNC address 216b768b915SJoseph Chen if [ -z $(echo $1 | sed 's/[0-9,a-f,A-F,x,X,-]//g') ]; then 217b768b915SJoseph Chen ARG_FUNCADDR=$1 218b768b915SJoseph Chen else 219b768b915SJoseph Chen ARG_BOARD=$1 220b768b915SJoseph Chen if [ ! -f configs/${ARG_BOARD}_defconfig ]; then 221b768b915SJoseph Chen echo -e "\n${SUPPORT_LIST}\n" 222b768b915SJoseph Chen echo "ERROR: No configs/${ARG_BOARD}_defconfig" 223b768b915SJoseph Chen exit 1 224b768b915SJoseph Chen else 225b768b915SJoseph Chen echo "make for ${ARG_BOARD}_defconfig by -j${JOB}" 226b768b915SJoseph Chen make ${ARG_BOARD}_defconfig ${OPTION} 227b768b915SJoseph Chen fi 228b768b915SJoseph Chen fi 229b768b915SJoseph Chen shift 1 230b768b915SJoseph Chen ;; 231b768b915SJoseph Chen esac 232b768b915SJoseph Chen done 233b768b915SJoseph Chen 234b768b915SJoseph Chen if [ ! -f .config ]; then 235b768b915SJoseph Chen echo 236b768b915SJoseph Chen echo "ERROR: No .config" 237b768b915SJoseph Chen help 238b768b915SJoseph Chen exit 1 23969b6e590SJoseph Chen fi 24030b04afcSJoseph Chen} 2417c2526e9SJoseph Chen 2427c3ca500SJoseph Chenfunction select_toolchain() 24327a50c86SAndy Yan{ 244d6821889SJoseph Chen if grep -q '^CONFIG_ARM64=y' .config ; then 245bc98b3c8SJoseph Chen if [ -d ${TOOLCHAIN_ARM64} ]; then 246bc98b3c8SJoseph Chen absolute_path=$(cd `dirname ${TOOLCHAIN_ARM64}`; pwd) 247bc98b3c8SJoseph Chen TOOLCHAIN_GCC=${absolute_path}/bin/${GCC_ARM64} 2480ff0e214SJoseph Chen TOOLCHAIN_OBJDUMP=${absolute_path}/bin/${OBJ_ARM64} 24953ea5791SJoseph Chen TOOLCHAIN_ADDR2LINE=${absolute_path}/bin/${ADDR2LINE_ARM64} 250bc98b3c8SJoseph Chen else 2517c3ca500SJoseph Chen echo "ERROR: No toolchain: ${TOOLCHAIN_ARM64}" 252bc98b3c8SJoseph Chen exit 1 25327a50c86SAndy Yan fi 25427a50c86SAndy Yan else 255bc98b3c8SJoseph Chen if [ -d ${TOOLCHAIN_ARM32} ]; then 256bc98b3c8SJoseph Chen absolute_path=$(cd `dirname ${TOOLCHAIN_ARM32}`; pwd) 257bc98b3c8SJoseph Chen TOOLCHAIN_GCC=${absolute_path}/bin/${GCC_ARM32} 2580ff0e214SJoseph Chen TOOLCHAIN_OBJDUMP=${absolute_path}/bin/${OBJ_ARM32} 25953ea5791SJoseph Chen TOOLCHAIN_ADDR2LINE=${absolute_path}/bin/${ADDR2LINE_ARM32} 260bc98b3c8SJoseph Chen else 2617c3ca500SJoseph Chen echo "ERROR: No toolchain: ${TOOLCHAIN_ARM32}" 262bc98b3c8SJoseph Chen exit 1 26327a50c86SAndy Yan fi 26427a50c86SAndy Yan fi 265bc98b3c8SJoseph Chen} 266bc98b3c8SJoseph Chen 2677c3ca500SJoseph Chenfunction sub_commands() 2680ff0e214SJoseph Chen{ 269f9afd3dcSJoseph Chen # skip "--" parameter, such as "--rollback-index-..." 270b768b915SJoseph Chen if [[ "$ARG_SUBCMD" != "--*" ]]; then 271b768b915SJoseph Chen cmd=${ARG_SUBCMD%-*} 272b768b915SJoseph Chen opt=${ARG_SUBCMD#*-} 273f9afd3dcSJoseph Chen else 274b768b915SJoseph Chen cmd=$ARG_SUBCMD 275f9afd3dcSJoseph Chen fi 276f9afd3dcSJoseph Chen 277b768b915SJoseph Chen if [ "$ARG_S_TPL" == "tpl" -o "$ARG_S_TPL" == "spl" ]; then 278b768b915SJoseph Chen elf=`find -name u-boot-${ARG_S_TPL}` 279b768b915SJoseph Chen map=`find -name u-boot-${ARG_S_TPL}.map` 280b768b915SJoseph Chen sym=`find -name u-boot-${ARG_S_TPL}.sym` 281b768b915SJoseph Chen else 2827c3ca500SJoseph Chen elf=u-boot 2837c3ca500SJoseph Chen map=u-boot.map 2847c3ca500SJoseph Chen sym=u-boot.sym 28534bdfea0SJoseph Chen fi 2860ff0e214SJoseph Chen 287b6255198SJoseph Chen case $cmd in 288b6255198SJoseph Chen elf) 2897c3ca500SJoseph Chen if [ ! -f ${elf} ]; then 2907c3ca500SJoseph Chen echo "ERROR: No elf: ${elf}" 2910ff0e214SJoseph Chen exit 1 2920ff0e214SJoseph Chen else 293b6255198SJoseph Chen # default 'cmd' without option, use '-D' 2945c75ab41SJoseph Chen if [ "${cmd}" = 'elf' -a "${opt}" = 'elf' ]; then 2955c75ab41SJoseph Chen opt=D 2960ff0e214SJoseph Chen fi 29734bdfea0SJoseph Chen ${TOOLCHAIN_OBJDUMP} -${opt} ${elf} | less 29807de173aSJoseph Chen exit 0 29907de173aSJoseph Chen fi 300b6255198SJoseph Chen ;; 301b6255198SJoseph Chen 3021b6c85a0SJoseph Chen debug) 303fcccd23aSJoseph Chen ./scripts/rkpatch.sh ${opt} 3041b6c85a0SJoseph Chen exit 0 3051b6c85a0SJoseph Chen ;; 3061b6c85a0SJoseph Chen 30769b6e590SJoseph Chen fit) 3084b4c6841SJoseph Chen if [ "$opt" = "ns" ]; then 309*9b9964b1SJoseph Chen ./scripts/fit-vboot.sh --no-vboot --ini-trust $INI_TRUST --ini-loader $INI_LOADER $ARG_NEW_SPL 3106cf81e27SJoseph Chen fi 31169b6e590SJoseph Chen exit 0 31269b6e590SJoseph Chen ;; 31369b6e590SJoseph Chen 314b6255198SJoseph Chen map) 31534bdfea0SJoseph Chen cat ${map} | less 316b6255198SJoseph Chen exit 0 317b6255198SJoseph Chen ;; 318b6255198SJoseph Chen 319b6255198SJoseph Chen sym) 32034bdfea0SJoseph Chen cat ${sym} | less 321b6255198SJoseph Chen exit 0 322b6255198SJoseph Chen ;; 323b6255198SJoseph Chen 324b6255198SJoseph Chen trust) 325d6e1155eSJoseph Chen pack_trust_image 326a43a18b2SJoseph Chen exit 0 327b6255198SJoseph Chen ;; 328b6255198SJoseph Chen 329b6255198SJoseph Chen loader) 330d6e1155eSJoseph Chen pack_loader_image 331a43a18b2SJoseph Chen exit 0 332b6255198SJoseph Chen ;; 333b6255198SJoseph Chen 334daa3bef5SJoseph Chen spl) 335daa3bef5SJoseph Chen pack_spl_loader_image ${opt} 336daa3bef5SJoseph Chen exit 0 337daa3bef5SJoseph Chen ;; 338daa3bef5SJoseph Chen 339daa3bef5SJoseph Chen itb) 340daa3bef5SJoseph Chen pack_uboot_itb_image 341daa3bef5SJoseph Chen exit 0 342daa3bef5SJoseph Chen ;; 343daa3bef5SJoseph Chen 344b6255198SJoseph Chen uboot) 345b768b915SJoseph Chen pack_uboot_image 346fb90bd1dSJoseph Chen exit 0 347b6255198SJoseph Chen ;; 348b6255198SJoseph Chen 349398d3e80SJoseph Chen env) 350398d3e80SJoseph Chen make CROSS_COMPILE=${TOOLCHAIN_GCC} envtools 351398d3e80SJoseph Chen exit 0 352398d3e80SJoseph Chen ;; 353398d3e80SJoseph Chen 354f9afd3dcSJoseph Chen --rollback-index*) 355*9b9964b1SJoseph Chen pack_fit_image $ARG_ROLLBACK_IDX_UBOOT $ARG_ROLLBACK_IDX_BOOT --ini-trust $INI_TRUST --ini-loader $INI_LOADER $ARG_NEW_SPL 356f9afd3dcSJoseph Chen exit 0 357f9afd3dcSJoseph Chen ;; 358f9afd3dcSJoseph Chen 359622ccf34SJoseph Chen EXT_DTB=*) 360b768b915SJoseph Chen OPTION=${ARG_SUBCMD} 361622ccf34SJoseph Chen ;; 362622ccf34SJoseph Chen 3638f53a15cSJoseph Chen nopack) 364b768b915SJoseph Chen IMAGE_NOPACK="y" 3658f53a15cSJoseph Chen ;; 3668f53a15cSJoseph Chen 367b6255198SJoseph Chen *) 36853ea5791SJoseph Chen # Search function and code position of address 369b768b915SJoseph Chen FUNCADDR=$ARG_FUNCADDR 370b768b915SJoseph Chen 371fc99e044SJoseph Chen RELOC_OFF=${FUNCADDR#*-} 372fc99e044SJoseph Chen FUNCADDR=${FUNCADDR%-*} 373fc99e044SJoseph Chen if [ -z $(echo ${FUNCADDR} | sed 's/[0-9,a-f,A-F,x,X,-]//g') ] && [ ${FUNCADDR} ]; then 3747070f875SJoseph Chen # With prefix: '0x' or '0X' 3757070f875SJoseph Chen if [ `echo ${FUNCADDR} | sed -n "/0[x,X]/p" | wc -l` -ne 0 ]; then 3767070f875SJoseph Chen FUNCADDR=`echo $FUNCADDR | awk '{ print strtonum($0) }'` 3777070f875SJoseph Chen FUNCADDR=`echo "obase=16;${FUNCADDR}"|bc |tr '[A-Z]' '[a-z]'` 3787070f875SJoseph Chen fi 379fc99e044SJoseph Chen if [ `echo ${RELOC_OFF} | sed -n "/0[x,X]/p" | wc -l` -ne 0 ] && [ ${RELOC_OFF} ]; then 380fc99e044SJoseph Chen RELOC_OFF=`echo $RELOC_OFF | awk '{ print strtonum($0) }'` 381fc99e044SJoseph Chen RELOC_OFF=`echo "obase=16;${RELOC_OFF}"|bc |tr '[A-Z]' '[a-z]'` 382fc99e044SJoseph Chen fi 383fc99e044SJoseph Chen 384fc99e044SJoseph Chen # If reloc address is assigned, do sub 385fc99e044SJoseph Chen if [ "${FUNCADDR}" != "${RELOC_OFF}" ]; then 386fc99e044SJoseph Chen # Hex -> Dec -> SUB -> Hex 387fc99e044SJoseph Chen FUNCADDR=`echo $((16#${FUNCADDR}))` 388fc99e044SJoseph Chen RELOC_OFF=`echo $((16#${RELOC_OFF}))` 389fc99e044SJoseph Chen FUNCADDR=$((FUNCADDR-RELOC_OFF)) 390fc99e044SJoseph Chen FUNCADDR=$(echo "obase=16;${FUNCADDR}"|bc |tr '[A-Z]' '[a-z]') 391fc99e044SJoseph Chen fi 3927070f875SJoseph Chen 39353ea5791SJoseph Chen echo 39434bdfea0SJoseph Chen sed -n "/${FUNCADDR}/p" ${sym} 39534bdfea0SJoseph Chen ${TOOLCHAIN_ADDR2LINE} -e ${elf} ${FUNCADDR} 39653ea5791SJoseph Chen exit 0 39753ea5791SJoseph Chen fi 398b6255198SJoseph Chen ;; 399b6255198SJoseph Chen esac 4000ff0e214SJoseph Chen} 4010ff0e214SJoseph Chen 402de440615SJoseph Chen# We select chip info to do: 403de440615SJoseph Chen# 1. RKCHIP: fixup platform configure 404de440615SJoseph Chen# 2. RKCHIP_LOADER: search ini file to pack loader 405de440615SJoseph Chen# 3. RKCHIP_TRUST: search ini file to pack trust 406de440615SJoseph Chen# 4. RKCHIP_LABEL: show build message 407de440615SJoseph Chen# 408de440615SJoseph Chen# We read chip info from .config and 'RKCHIP_INI_DESC' 4097c3ca500SJoseph Chenfunction select_chip_info() 410bc98b3c8SJoseph Chen{ 411de440615SJoseph Chen # Read RKCHIP firstly from .config 412596700d7SShunqian Zheng # The regular expression that matching: 413596700d7SShunqian Zheng # - PX30, PX3SE 414596700d7SShunqian Zheng # - RK????, RK????X 415596700d7SShunqian Zheng # - RV???? 4167c3ca500SJoseph Chen chip_pattern='^CONFIG_ROCKCHIP_[R,P][X,V,K][0-9ESX]{1,5}' 4177c3ca500SJoseph Chen RKCHIP=`egrep -o ${chip_pattern} .config` 418d443b7d5SJoseph Chen 4190583701dSJoseph Chen # default 420d443b7d5SJoseph Chen RKCHIP=${RKCHIP##*_} 42141cf5e5aSJoseph Chen 4220583701dSJoseph Chen # need fixup ? 4237c3ca500SJoseph Chen for item in "${CHIP_TYPE_FIXUP_TABLE[@]}" 424de440615SJoseph Chen do 4257c3ca500SJoseph Chen config_xxx=`echo $item | awk '{ print $1 }'` 4267c3ca500SJoseph Chen if grep -q "^${config_xxx}=y" .config ; then 4277c3ca500SJoseph Chen RKCHIP=`echo $item | awk '{ print $2 }'` 4287c3ca500SJoseph Chen RKCHIP_LOADER=`echo $item | awk '{ print $3 }'` 4297c3ca500SJoseph Chen RKCHIP_TRUST=`echo $item | awk '{ print $4 }'` 4307c3ca500SJoseph Chen RKCHIP_LABEL=`echo $item | awk '{ print $5 }'` 431de440615SJoseph Chen fi 4320583701dSJoseph Chen done 4330583701dSJoseph Chen 4340583701dSJoseph Chen if [ "$RKCHIP_LOADER" = "-" ]; then 4350583701dSJoseph Chen RKCHIP_LOADER=${RKCHIP} 436de440615SJoseph Chen fi 4370583701dSJoseph Chen if [ "$RKCHIP_TRUST" = "-" ]; then 4380583701dSJoseph Chen RKCHIP_TRUST=${RKCHIP} 4390583701dSJoseph Chen fi 4400583701dSJoseph Chen if [ "$RKCHIP_LABEL" = "-" ]; then 4410583701dSJoseph Chen RKCHIP_LABEL=${RKCHIP} 4420583701dSJoseph Chen fi 4430583701dSJoseph Chen} 4440583701dSJoseph Chen 4450583701dSJoseph Chenfunction fixup_platform_configure() 4460583701dSJoseph Chen{ 447b768b915SJoseph Chen u_kb="-" u_num="-" t_kb="-" t_num="-" sha="-" rsa="-" 4480583701dSJoseph Chen 4497c3ca500SJoseph Chen for item in "${CHIP_CFG_FIXUP_TABLE[@]}" 4500583701dSJoseph Chen do 4517c3ca500SJoseph Chen config_xxx=`echo $item | awk '{ print $1 }'` 4527c3ca500SJoseph Chen if grep -q "^${config_xxx}=y" .config ; then 4530583701dSJoseph Chen # <*> Fixup rsa/sha pack mode for platforms 454b768b915SJoseph Chen rsa=`echo $item | awk '{ print $2 }'` 455b768b915SJoseph Chen sha=`echo $item | awk '{ print $3 }'` 4560583701dSJoseph Chen 4570583701dSJoseph Chen # <*> Fixup images size pack for platforms, and ini file 4580583701dSJoseph Chen if grep -q '^CONFIG_ARM64_BOOT_AARCH32=y' .config ; then 459b768b915SJoseph Chen u_kb=`echo $item | awk '{ print $6 }' | awk -F "," '{ print $1 }'` 460b768b915SJoseph Chen t_kb=`echo $item | awk '{ print $6 }' | awk -F "," '{ print $2 }'` 461b768b915SJoseph Chen u_num=`echo $item | awk '{ print $7 }' | awk -F "," '{ print $1 }'` 462b768b915SJoseph Chen t_num=`echo $item | awk '{ print $7 }' | awk -F "," '{ print $2 }'` 4630583701dSJoseph Chen 4647c3ca500SJoseph Chen PAD_LOADER=`echo $item | awk '{ print $8 }'` 4657c3ca500SJoseph Chen PAD_TRUST=`echo $item | awk '{ print $9 }'` 4660583701dSJoseph Chen if [ "$PAD_LOADER" != "-" ]; then 4670583701dSJoseph Chen RKCHIP_LOADER=${RKCHIP_LOADER}${PAD_LOADER} 4680583701dSJoseph Chen fi 4690583701dSJoseph Chen if [ "$PAD_TRUST" != "-" ]; then 4700583701dSJoseph Chen RKCHIP_TRUST=${RKCHIP_TRUST}${PAD_TRUST} 4710583701dSJoseph Chen fi 4720583701dSJoseph Chen RKCHIP_LABEL=${RKCHIP_LABEL}"AARCH32" 4730583701dSJoseph Chen else 474b768b915SJoseph Chen u_kb=`echo $item | awk '{ print $4 }' | awk -F "," '{ print $1 }'` 475b768b915SJoseph Chen t_kb=`echo $item | awk '{ print $4 }' | awk -F "," '{ print $2 }'` 476b768b915SJoseph Chen u_num=`echo $item | awk '{ print $5 }' | awk -F "," '{ print $1 }'` 477b768b915SJoseph Chen t_num=`echo $item | awk '{ print $5 }' | awk -F "," '{ print $2 }'` 478de440615SJoseph Chen fi 479de440615SJoseph Chen fi 480de440615SJoseph Chen done 481de440615SJoseph Chen 482b768b915SJoseph Chen if [ "$sha" != "-" ]; then 483b768b915SJoseph Chen PLATFORM_SHA="--sha $sha" 4840583701dSJoseph Chen fi 485b768b915SJoseph Chen if [ "$rsa" != "-" ]; then 486b768b915SJoseph Chen PLATFORM_RSA="--rsa $rsa" 4870583701dSJoseph Chen fi 488b768b915SJoseph Chen if [ "$u_kb" != "-" ]; then 489b768b915SJoseph Chen PLATFORM_UBOOT_IMG_SIZE="--size $u_kb $u_num" 4900583701dSJoseph Chen fi 491b768b915SJoseph Chen if [ "$t_kb" != "-" ]; then 492b768b915SJoseph Chen PLATFORM_TRUST_IMG_SIZE="--size $t_kb $t_num" 493b768b915SJoseph Chen fi 494b768b915SJoseph Chen} 495b768b915SJoseph Chen 496b768b915SJoseph Chenfunction select_ini_file() 497b768b915SJoseph Chen{ 498b768b915SJoseph Chen # default 499b768b915SJoseph Chen INI_LOADER=${RKBIN}/RKBOOT/${RKCHIP_LOADER}MINIALL.ini 500b768b915SJoseph Chen if [ "$ARM64_TRUSTZONE" = "y" ]; then 501b768b915SJoseph Chen INI_TRUST=${RKBIN}/RKTRUST/${RKCHIP_TRUST}TRUST.ini 502b768b915SJoseph Chen else 503b768b915SJoseph Chen INI_TRUST=${RKBIN}/RKTRUST/${RKCHIP_TRUST}TOS.ini 50441cf5e5aSJoseph Chen fi 50541cf5e5aSJoseph Chen 506b768b915SJoseph Chen # args 507b768b915SJoseph Chen if [ "$ARG_INI_TRUST" != "" ]; then 508b768b915SJoseph Chen INI_TRUST=$ARG_INI_TRUST 509b768b915SJoseph Chen fi 510b768b915SJoseph Chen if [ "$ARG_INI_LOADER" != "" ]; then 511b768b915SJoseph Chen INI_LOADER=$ARG_INI_LOADER 512b768b915SJoseph Chen fi 51327a50c86SAndy Yan} 514de9a6cd2SJoseph Chen 5157c3ca500SJoseph Chenfunction pack_uboot_image() 516de9a6cd2SJoseph Chen{ 517b768b915SJoseph Chen if [ "$IMAGE_FORMAT" != "RKFW" ]; then 5188f53a15cSJoseph Chen return 5198f53a15cSJoseph Chen fi 5208f53a15cSJoseph Chen 521f089d907SJoseph Chen # Check file size 5227c3ca500SJoseph Chen head_kb=2 5237c3ca500SJoseph Chen uboot_kb=`ls -l u-boot.bin | awk '{print $5}'` 524f089d907SJoseph Chen if [ "$PLATFORM_UBOOT_IMG_SIZE" = "" ]; then 5257c3ca500SJoseph Chen uboot_max_kb=1046528 526f089d907SJoseph Chen else 5277c3ca500SJoseph Chen uboot_max_kb=`echo $PLATFORM_UBOOT_IMG_SIZE | awk '{print strtonum($2)}'` 5287c3ca500SJoseph Chen uboot_max_kb=$(((uboot_max_kb-head_kb)*1024)) 529f089d907SJoseph Chen fi 530f089d907SJoseph Chen 5317c3ca500SJoseph Chen if [ $uboot_kb -gt $uboot_max_kb ]; then 532f089d907SJoseph Chen echo 5337c3ca500SJoseph Chen echo "ERROR: pack uboot failed! u-boot.bin actual: $uboot_kb bytes, max limit: $uboot_max_kb bytes" 534f089d907SJoseph Chen exit 1 535f089d907SJoseph Chen fi 536f089d907SJoseph Chen 5377c3ca500SJoseph Chen # Pack 5387c3ca500SJoseph Chen uboot_load_addr=`sed -n "/CONFIG_SYS_TEXT_BASE=/s/CONFIG_SYS_TEXT_BASE=//p" include/autoconf.mk|tr -d '\r'` 5397c3ca500SJoseph Chen if [ -z $uboot_load_addr ]; then 5407c3ca500SJoseph Chen echo "ERROR: No CONFIG_SYS_TEXT_BASE for u-boot"; 5417c3ca500SJoseph Chen exit 1 542daa679a7SKever Yang fi 5437c3ca500SJoseph Chen ${RKTOOLS}/loaderimage --pack --uboot u-boot.bin uboot.img ${uboot_load_addr} ${PLATFORM_UBOOT_IMG_SIZE} 544a11e2c82SJoseph Chen rm u-boot.img u-boot-dtb.img -rf 54591205f1dSJoseph Chen echo "pack uboot okay! Input: u-boot.bin" 546de9a6cd2SJoseph Chen} 547de9a6cd2SJoseph Chen 5487c3ca500SJoseph Chenfunction pack_uboot_itb_image() 549daa3bef5SJoseph Chen{ 550b768b915SJoseph Chen ini=$INI_TRUST 5517c3ca500SJoseph Chen 552b768b915SJoseph Chen if [ ! -f $INI_TRUST ]; then 553b768b915SJoseph Chen echo "pack trust failed! Can't find: $INI_TRUST" 5540d0d4395SJoseph Chen return 5550d0d4395SJoseph Chen fi 5560d0d4395SJoseph Chen 5577c3ca500SJoseph Chen if [ "$ARM64_TRUSTZONE" = "y" ]; then 5587c3ca500SJoseph Chen bl31=`sed -n '/_bl31_/s/PATH=//p' $ini |tr -d '\r'` 5597c3ca500SJoseph Chen cp ${RKBIN}/${bl31} bl31.elf 5607c3ca500SJoseph Chen make CROSS_COMPILE=${TOOLCHAIN_GCC} u-boot.itb 5617c3ca500SJoseph Chen echo "pack u-boot.itb okay! Input: $ini" 5620d0d4395SJoseph Chen else 5637c3ca500SJoseph Chen tos_image=`sed -n "/TOS=/s/TOS=//p" $ini |tr -d '\r'` 5647c3ca500SJoseph Chen tosta_image=`sed -n "/TOSTA=/s/TOSTA=//p" $ini |tr -d '\r'` 5657c3ca500SJoseph Chen if [ $tosta_image ]; then 5667c3ca500SJoseph Chen cp ${RKBIN}/${tosta_image} tee.bin 5677c3ca500SJoseph Chen elif [ $tos_image ]; then 5687c3ca500SJoseph Chen cp ${RKBIN}/${tos_image} tee.bin 5697c3ca500SJoseph Chen else 5707c3ca500SJoseph Chen echo "ERROR: No any tee bin" 5710d0d4395SJoseph Chen exit 1 5720d0d4395SJoseph Chen fi 5730d0d4395SJoseph Chen 5747c3ca500SJoseph Chen tee_offset=`sed -n "/ADDR=/s/ADDR=//p" $ini |tr -d '\r'` 5757c3ca500SJoseph Chen if [ "$tee_offset" = "" ]; then 5767c3ca500SJoseph Chen tee_offset=0x8400000 577d13b75e1SJoseph Chen fi 578d13b75e1SJoseph Chen 57985101532SJoseph Chen mcu_enabled=`awk -F"," '/MCU=/ { printf $3 }' $ini | tr -d ' '` 58085101532SJoseph Chen if [ "$mcu_enabled" = "enabled" ]; then 58185101532SJoseph Chen mcu_image=`awk -F"," '/MCU=/ { printf $1 }' $ini | tr -d ' ' | cut -c 5-` 58285101532SJoseph Chen mcu_offset=`awk -F"," '/MCU=/ { printf $2 }' $ini | tr -d ' '` 58385101532SJoseph Chen cp ${RKBIN}/${mcu_image} mcu.bin 58485101532SJoseph Chen fi 58585101532SJoseph Chen 586db3b6a92SJoseph Chen SPL_FIT_SOURCE=`sed -n "/CONFIG_SPL_FIT_SOURCE=/s/CONFIG_SPL_FIT_SOURCE=//p" .config | tr -d '""'` 587db3b6a92SJoseph Chen if [ ! -z $SPL_FIT_SOURCE ]; then 588db3b6a92SJoseph Chen cp $SPL_FIT_SOURCE u-boot.its 589db3b6a92SJoseph Chen else 590db3b6a92SJoseph Chen SPL_FIT_GENERATOR=`sed -n "/CONFIG_SPL_FIT_GENERATOR=/s/CONFIG_SPL_FIT_GENERATOR=//p" .config | tr -d '""'` 59185101532SJoseph Chen $SPL_FIT_GENERATOR $tee_offset $mcu_offset > u-boot.its 592db3b6a92SJoseph Chen fi 593d13b75e1SJoseph Chen ./tools/mkimage -f u-boot.its -E u-boot.itb 5947c3ca500SJoseph Chen echo "pack u-boot.itb okay! Input: $ini" 5950d0d4395SJoseph Chen fi 596b768b915SJoseph Chen echo 597daa3bef5SJoseph Chen} 598daa3bef5SJoseph Chen 5997c3ca500SJoseph Chenfunction pack_spl_loader_image() 600daa3bef5SJoseph Chen{ 6017c3ca500SJoseph Chen mode=$1 6027c3ca500SJoseph Chen tmp_dir=${RKBIN}/tmp 6037c3ca500SJoseph Chen tmp_ini=${tmp_dir}/${RKCHIP_LOADER}MINIALL.ini 604b768b915SJoseph Chen ini=$INI_LOADER 605b768b915SJoseph Chen if [ ! -f $INI_LOADER ]; then 606b768b915SJoseph Chen echo "pack loader failed! Can't find: $INI_LOADER" 607daa3bef5SJoseph Chen return 608daa3bef5SJoseph Chen fi 609daa3bef5SJoseph Chen 610a11e2c82SJoseph Chen rm ${tmp_dir} -rf 6117c3ca500SJoseph Chen mkdir ${tmp_dir} -p 6127c3ca500SJoseph Chen cp spl/u-boot-spl.bin ${tmp_dir}/ 6137c3ca500SJoseph Chen cp $ini $tmp_ini 614daa3bef5SJoseph Chen if [ "$mode" = 'spl' ]; then # pack tpl+spl 615daa3bef5SJoseph Chen label="TPL+SPL" 6167c3ca500SJoseph Chen cp tpl/u-boot-tpl.bin ${tmp_dir}/ 6177c3ca500SJoseph Chen header=`sed -n '/NAME=/s/NAME=//p' ${ini}` 6187c3ca500SJoseph Chen dd if=${tmp_dir}/u-boot-tpl.bin of=${tmp_dir}/tpl.bin bs=1 skip=4 6197c3ca500SJoseph Chen sed -i "1s/^/${header:0:4}/" ${tmp_dir}/tpl.bin 6207c3ca500SJoseph Chen sed -i "s/FlashData=.*$/FlashData=.\/tmp\/tpl.bin/" $tmp_ini 6217c3ca500SJoseph Chen else 6227c3ca500SJoseph Chen label="SPL" 623daa3bef5SJoseph Chen fi 624daa3bef5SJoseph Chen 6257c3ca500SJoseph Chen sed -i "s/FlashBoot=.*$/FlashBoot=.\/tmp\/u-boot-spl.bin/" $tmp_ini 6267c3ca500SJoseph Chen cd ${RKBIN} 6277c3ca500SJoseph Chen ${RKTOOLS}/boot_merger $tmp_ini 6287c3ca500SJoseph Chen rm ${tmp_dir} -rf 629daa3bef5SJoseph Chen cd - 630a11e2c82SJoseph Chen rm *_loader_*.bin -rf 631b4e157ffSJoseph Chen mv ${RKBIN}/*_loader_*.bin ./ 6327c3ca500SJoseph Chen 633aa8ddc58SJoseph Chen filename=`basename *_loader_*.bin` 634aa8ddc58SJoseph Chen if [[ $filename != *spl* ]]; then 635b4e157ffSJoseph Chen rename 's/loader_/spl_loader_/' *_loader_*.bin 636aa8ddc58SJoseph Chen fi 6377c3ca500SJoseph Chen echo "pack loader(${label}) okay! Input: $ini" 638daa3bef5SJoseph Chen} 639daa3bef5SJoseph Chen 6407c3ca500SJoseph Chenfunction pack_loader_image() 641cd7ae718SJoseph Chen{ 642b768b915SJoseph Chen ini=$INI_LOADER 643b768b915SJoseph Chen if [ ! -f $INI_LOADER ]; then 644b768b915SJoseph Chen echo "pack loader failed! Can't find: $INI_LOADER" 64551441a28SJoseph Chen return 64651441a28SJoseph Chen fi 64751441a28SJoseph Chen 648a11e2c82SJoseph Chen rm *_loader_*.bin -rf 649783f7f6eSJoseph Chen numline=`cat $ini | wc -l` 650783f7f6eSJoseph Chen if [ $numline -eq 1 ]; then 651783f7f6eSJoseph Chen image=`sed -n "/PATH=/p" $ini | tr -d '\r' | cut -d '=' -f 2` 652783f7f6eSJoseph Chen cp ${RKBIN}/${image} ./ 6537c3ca500SJoseph Chen else 654cd7ae718SJoseph Chen cd ${RKBIN} 6557c3ca500SJoseph Chen ${RKTOOLS}/boot_merger $ini 656fb90bd1dSJoseph Chen cd - && mv ${RKBIN}/*_loader_*.bin ./ 6577c3ca500SJoseph Chen fi 6587c3ca500SJoseph Chen 65969b6e590SJoseph Chen file=`ls *loader*.bin` 66069b6e590SJoseph Chen echo "pack $file okay! Input: $ini" 661cd7ae718SJoseph Chen} 662cd7ae718SJoseph Chen 6637c3ca500SJoseph Chenfunction pack_arm32_trust_image() 664cd7ae718SJoseph Chen{ 6657c3ca500SJoseph Chen ini=$1 6667c3ca500SJoseph Chen tos_image=`sed -n "/TOS=/s/TOS=//p" $ini |tr -d '\r'` 6677c3ca500SJoseph Chen tosta_image=`sed -n "/TOSTA=/s/TOSTA=//p" $ini |tr -d '\r'` 6687c3ca500SJoseph Chen tee_output=`sed -n "/OUTPUT=/s/OUTPUT=//p" $ini |tr -d '\r'` 6697c3ca500SJoseph Chen if [ "$tee_output" = "" ]; then 6707c3ca500SJoseph Chen tee_output="./trust.img" 67151441a28SJoseph Chen fi 6727c3ca500SJoseph Chen tee_offset=`sed -n "/ADDR=/s/ADDR=//p" $ini |tr -d '\r'` 6737c3ca500SJoseph Chen if [ "$tee_offset" = "" ]; then 6747c3ca500SJoseph Chen tee_offset=0x8400000 67551441a28SJoseph Chen fi 67651441a28SJoseph Chen 677cd7ae718SJoseph Chen # OP-TEE is 132M(0x8400000) offset from DRAM base. 678eee9fb0aSJoseph Chen dram_base=`sed -n "/CONFIG_SYS_SDRAM_BASE=/s/CONFIG_SYS_SDRAM_BASE=//p" include/autoconf.mk|tr -d '\r'` 6797c3ca500SJoseph Chen tee_load_addr=$((dram_base+tee_offset)) 6807c3ca500SJoseph Chen tee_load_addr=$(echo "obase=16;${tee_load_addr}"|bc) # Convert Dec to Hex 6810e90839aSJoseph Chen 6827c3ca500SJoseph Chen if [ $tosta_image ]; then 6837c3ca500SJoseph Chen ${RKTOOLS}/loaderimage --pack --trustos ${RKBIN}/${tosta_image} ${tee_output} ${tee_load_addr} ${PLATFORM_TRUST_IMG_SIZE} 6847c3ca500SJoseph Chen elif [ $tos_image ]; then 6857c3ca500SJoseph Chen ${RKTOOLS}/loaderimage --pack --trustos ${RKBIN}/${tos_image} ${tee_output} ${tee_load_addr} ${PLATFORM_TRUST_IMG_SIZE} 686cd7ae718SJoseph Chen else 6877c3ca500SJoseph Chen echo "ERROR: No any tee bin" 688a64486b5SJoseph Chen exit 1 689cd7ae718SJoseph Chen fi 6907c3ca500SJoseph Chen echo "pack trust okay! Input: $ini" 69169cce37bSJoseph Chen} 69269cce37bSJoseph Chen 6937c3ca500SJoseph Chenfunction pack_arm64_trust_image() 69469cce37bSJoseph Chen{ 6957c3ca500SJoseph Chen ini=$1 69669cce37bSJoseph Chen cd ${RKBIN} 6977c3ca500SJoseph Chen ${RKTOOLS}/trust_merger ${PLATFORM_SHA} ${PLATFORM_RSA} ${PLATFORM_TRUST_IMG_SIZE} $ini 69869cce37bSJoseph Chen cd - && mv ${RKBIN}/trust*.img ./ 6997c3ca500SJoseph Chen echo "pack trust okay! Input: $ini" 70069cce37bSJoseph Chen} 70169cce37bSJoseph Chen 7027c3ca500SJoseph Chenfunction pack_trust_image() 70369cce37bSJoseph Chen{ 704b768b915SJoseph Chen if [ "$IMAGE_FORMAT" != "RKFW" ]; then 7058f53a15cSJoseph Chen return 7068f53a15cSJoseph Chen fi 7078f53a15cSJoseph Chen 708a11e2c82SJoseph Chen rm trust*.img -rf 709b768b915SJoseph Chen ini=$INI_TRUST 710b768b915SJoseph Chen if [ ! -f $INI_TRUST ]; then 711b768b915SJoseph Chen echo "pack trust failed! Can't find: $INI_TRUST" 7127c3ca500SJoseph Chen return 713dd590c93SJoseph Chen fi 714dd590c93SJoseph Chen 715783f7f6eSJoseph Chen numline=`cat $ini | wc -l` 716783f7f6eSJoseph Chen if [ $numline -eq 1 ]; then 717783f7f6eSJoseph Chen image=`sed -n "/PATH=/p" $ini | tr -d '\r' | cut -d '=' -f 2` 718783f7f6eSJoseph Chen cp ${RKBIN}/${image} ./trust.img 7197c3ca500SJoseph Chen echo "pack trust okay! Input: $ini" 720783f7f6eSJoseph Chen return; 72169cce37bSJoseph Chen else 7227c3ca500SJoseph Chen if [ "$ARM64_TRUSTZONE" = "y" ]; then 7237c3ca500SJoseph Chen pack_arm64_trust_image $ini 7247c3ca500SJoseph Chen else 7257c3ca500SJoseph Chen pack_arm32_trust_image $ini 726dd590c93SJoseph Chen fi 727cd7ae718SJoseph Chen fi 728cd7ae718SJoseph Chen} 729cd7ae718SJoseph Chen 7308f53a15cSJoseph Chenfunction pack_fit_image() 7318f53a15cSJoseph Chen{ 7324b4c6841SJoseph Chen if grep -q '^CONFIG_FIT_SIGNATURE=y' .config ; then 733*9b9964b1SJoseph Chen ./scripts/fit-vboot.sh $ARG_ROLLBACK_IDX_UBOOT $ARG_ROLLBACK_IDX_BOOT --ini-trust $INI_TRUST --ini-loader $INI_LOADER $ARG_NEW_SPL 7344b4c6841SJoseph Chen else 735a11e2c82SJoseph Chen rm uboot.img trust*.img -rf 736*9b9964b1SJoseph Chen ./scripts/fit-vboot-uboot.sh --no-vboot --no-rebuild --ini-trust $INI_TRUST --ini-loader $INI_LOADER $ARG_NEW_SPL 737b768b915SJoseph Chen echo "pack uboot.img (with uboot trust) okay! Input: $INI_TRUST" 7384b4c6841SJoseph Chen fi 7398f53a15cSJoseph Chen} 7408f53a15cSJoseph Chen 7418f53a15cSJoseph Chenfunction pack_images() 7428f53a15cSJoseph Chen{ 743b768b915SJoseph Chen if [ "$IMAGE_NOPACK" != "y" ]; then 744b768b915SJoseph Chen if [ "$IMAGE_FORMAT" = "RKFW" ]; then 7458f53a15cSJoseph Chen pack_uboot_image 7468f53a15cSJoseph Chen pack_trust_image 7478f53a15cSJoseph Chen pack_loader_image 748b768b915SJoseph Chen elif [ "$IMAGE_FORMAT" = "FIT" ]; then 749*9b9964b1SJoseph Chen pack_fit_image $ARG_ROLLBACK_IDX_UBOOT $ARG_ROLLBACK_IDX_BOOT --ini-trust $INI_TRUST --ini-loader $INI_LOADER $ARG_NEW_SPL 7508f53a15cSJoseph Chen fi 7518f53a15cSJoseph Chen fi 7528f53a15cSJoseph Chen} 7538f53a15cSJoseph Chen 7548f53a15cSJoseph Chenfunction clean_files() 7558f53a15cSJoseph Chen{ 7568f53a15cSJoseph Chen if [ -f spl/u-boot-spl.dtb ]; then 757a11e2c82SJoseph Chen rm spl/u-boot-spl.dtb -rf 7588f53a15cSJoseph Chen fi 7598f53a15cSJoseph Chen if [ -f tpl/u-boot-tpl.dtb ]; then 760a11e2c82SJoseph Chen rm tpl/u-boot-tpl.dtb -rf 7618f53a15cSJoseph Chen fi 7628f53a15cSJoseph Chen if [ -f u-boot.dtb ]; then 763a11e2c82SJoseph Chen rm u-boot.dtb -rf 7648f53a15cSJoseph Chen fi 7658f53a15cSJoseph Chen} 7668f53a15cSJoseph Chen 7677c3ca500SJoseph Chenfunction finish() 76830b04afcSJoseph Chen{ 76930b04afcSJoseph Chen echo 770622ccf34SJoseph Chen if [ ! -z "$OPTION" ]; then 771622ccf34SJoseph Chen echo "Platform ${RKCHIP_LABEL} is build OK, with exist .config ($OPTION)" 772b768b915SJoseph Chen elif [ "$ARG_BOARD" = '' ]; then 7735202fe1fSJoseph Chen echo "Platform ${RKCHIP_LABEL} is build OK, with exist .config" 77430b04afcSJoseph Chen else 775b768b915SJoseph Chen echo "Platform ${RKCHIP_LABEL} is build OK, with new .config(make ${ARG_BOARD}_defconfig)" 77630b04afcSJoseph Chen fi 77730b04afcSJoseph Chen} 77830b04afcSJoseph Chen 779b768b915SJoseph Chenprocess_args $* 780cd7ae718SJoseph Chenprepare 7817c2526e9SJoseph Chenselect_toolchain 782de440615SJoseph Chenselect_chip_info 78341cf5e5aSJoseph Chenfixup_platform_configure 784b768b915SJoseph Chenselect_ini_file 7850ff0e214SJoseph Chensub_commands 7868f53a15cSJoseph Chenclean_files 787622ccf34SJoseph Chenmake CROSS_COMPILE=${TOOLCHAIN_GCC} ${OPTION} all --jobs=${JOB} 7888f53a15cSJoseph Chenpack_images 78930b04afcSJoseph Chenfinish 790