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 79*b768b915SJoseph ChenINI_TRUST= 80*b768b915SJoseph ChenINI_LOADER= 81*b768b915SJoseph 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= 98*b768b915SJoseph Chen 99*b768b915SJoseph ChenIMAGE_FORMAT="RKFW" 100*b768b915SJoseph ChenIMAGE_NOPACK="n" 101aa8ddc58SJoseph Chen 102fb90bd1dSJoseph Chen######################################################################################################### 1037c3ca500SJoseph Chenfunction help() 104b6255198SJoseph Chen{ 105b6255198SJoseph Chen echo 1066a764259SJoseph Chen echo "Usage:" 107*b768b915SJoseph Chen echo " ./make.sh [board|sub-command]" 1086a764259SJoseph Chen echo 1096a764259SJoseph Chen echo " - board: board name of defconfig" 110*b768b915SJoseph 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 152*b768b915SJoseph 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 161*b768b915SJoseph Chen IMAGE_FORMAT="FIT" 162*b768b915SJoseph Chen fi 163*b768b915SJoseph Chen} 164*b768b915SJoseph Chen 165*b768b915SJoseph Chenfunction process_args() 166*b768b915SJoseph Chen{ 167*b768b915SJoseph Chen while [ $# -gt 0 ]; do 168*b768b915SJoseph Chen case $1 in 169*b768b915SJoseph Chen --help|-help|help|--h|-h) 170*b768b915SJoseph Chen help 171*b768b915SJoseph Chen exit 0 172*b768b915SJoseph Chen ;; 173*b768b915SJoseph Chen 174*b768b915SJoseph Chen ''|loader|trust|uboot|spl*|debug*|itb|env|EXT_DTB=*|nopack|fit*) 175*b768b915SJoseph Chen ARG_SUBCMD=$1 176*b768b915SJoseph Chen shift 1 177*b768b915SJoseph Chen ;; 178*b768b915SJoseph Chen 179*b768b915SJoseph Chen --rollback-index-uboot) 180*b768b915SJoseph Chen ARG_ROLLBACK_IDX_UBOOT="--rollback-index-uboot "$2 181*b768b915SJoseph Chen shift 2 182*b768b915SJoseph Chen ;; 183*b768b915SJoseph Chen 184*b768b915SJoseph Chen --rollback-index-boot) 185*b768b915SJoseph Chen ARG_ROLLBACK_IDX_BOOT="--rollback-index-boot "$2 186*b768b915SJoseph Chen shift 2 187*b768b915SJoseph Chen ;; 188*b768b915SJoseph Chen 189*b768b915SJoseph Chen map|sym|elf*) 190*b768b915SJoseph Chen ARG_SUBCMD=$1 191*b768b915SJoseph Chen if [ "$2" = "spl" -o "$2" = "tpl" ]; then 192*b768b915SJoseph Chen ARG_S_TPL=$2 193*b768b915SJoseph Chen shift 1 194*b768b915SJoseph Chen fi 195*b768b915SJoseph Chen shift 1 196*b768b915SJoseph Chen ;; 197*b768b915SJoseph Chen 198*b768b915SJoseph Chen *.ini|*.INI) 199*b768b915SJoseph Chen if [ ! -f $1 ]; then 200*b768b915SJoseph Chen echo "ERROR: No $1" 201*b768b915SJoseph Chen fi 202*b768b915SJoseph Chen if grep -q 'CODE471_OPTION' $1 ; then 203*b768b915SJoseph Chen ARG_INI_LOADER=$1 204*b768b915SJoseph Chen elif grep -Eq ''BL31_OPTION'|'TOS'' $1 ; then 205*b768b915SJoseph Chen ARG_INI_TRUST=$1 206*b768b915SJoseph Chen fi 207*b768b915SJoseph Chen shift 1 208*b768b915SJoseph Chen ;; 209*b768b915SJoseph Chen 210*b768b915SJoseph Chen *) 211*b768b915SJoseph Chen # FUNC address 212*b768b915SJoseph Chen if [ -z $(echo $1 | sed 's/[0-9,a-f,A-F,x,X,-]//g') ]; then 213*b768b915SJoseph Chen ARG_FUNCADDR=$1 214*b768b915SJoseph Chen else 215*b768b915SJoseph Chen ARG_BOARD=$1 216*b768b915SJoseph Chen if [ ! -f configs/${ARG_BOARD}_defconfig ]; then 217*b768b915SJoseph Chen echo -e "\n${SUPPORT_LIST}\n" 218*b768b915SJoseph Chen echo "ERROR: No configs/${ARG_BOARD}_defconfig" 219*b768b915SJoseph Chen exit 1 220*b768b915SJoseph Chen else 221*b768b915SJoseph Chen echo "make for ${ARG_BOARD}_defconfig by -j${JOB}" 222*b768b915SJoseph Chen make ${ARG_BOARD}_defconfig ${OPTION} 223*b768b915SJoseph Chen fi 224*b768b915SJoseph Chen fi 225*b768b915SJoseph Chen shift 1 226*b768b915SJoseph Chen ;; 227*b768b915SJoseph Chen esac 228*b768b915SJoseph Chen done 229*b768b915SJoseph Chen 230*b768b915SJoseph Chen if [ ! -f .config ]; then 231*b768b915SJoseph Chen echo 232*b768b915SJoseph Chen echo "ERROR: No .config" 233*b768b915SJoseph Chen help 234*b768b915SJoseph Chen exit 1 23569b6e590SJoseph Chen fi 23630b04afcSJoseph Chen} 2377c2526e9SJoseph Chen 2387c3ca500SJoseph Chenfunction select_toolchain() 23927a50c86SAndy Yan{ 240d6821889SJoseph Chen if grep -q '^CONFIG_ARM64=y' .config ; then 241bc98b3c8SJoseph Chen if [ -d ${TOOLCHAIN_ARM64} ]; then 242bc98b3c8SJoseph Chen absolute_path=$(cd `dirname ${TOOLCHAIN_ARM64}`; pwd) 243bc98b3c8SJoseph Chen TOOLCHAIN_GCC=${absolute_path}/bin/${GCC_ARM64} 2440ff0e214SJoseph Chen TOOLCHAIN_OBJDUMP=${absolute_path}/bin/${OBJ_ARM64} 24553ea5791SJoseph Chen TOOLCHAIN_ADDR2LINE=${absolute_path}/bin/${ADDR2LINE_ARM64} 246bc98b3c8SJoseph Chen else 2477c3ca500SJoseph Chen echo "ERROR: No toolchain: ${TOOLCHAIN_ARM64}" 248bc98b3c8SJoseph Chen exit 1 24927a50c86SAndy Yan fi 25027a50c86SAndy Yan else 251bc98b3c8SJoseph Chen if [ -d ${TOOLCHAIN_ARM32} ]; then 252bc98b3c8SJoseph Chen absolute_path=$(cd `dirname ${TOOLCHAIN_ARM32}`; pwd) 253bc98b3c8SJoseph Chen TOOLCHAIN_GCC=${absolute_path}/bin/${GCC_ARM32} 2540ff0e214SJoseph Chen TOOLCHAIN_OBJDUMP=${absolute_path}/bin/${OBJ_ARM32} 25553ea5791SJoseph Chen TOOLCHAIN_ADDR2LINE=${absolute_path}/bin/${ADDR2LINE_ARM32} 256bc98b3c8SJoseph Chen else 2577c3ca500SJoseph Chen echo "ERROR: No toolchain: ${TOOLCHAIN_ARM32}" 258bc98b3c8SJoseph Chen exit 1 25927a50c86SAndy Yan fi 26027a50c86SAndy Yan fi 261bc98b3c8SJoseph Chen} 262bc98b3c8SJoseph Chen 2637c3ca500SJoseph Chenfunction sub_commands() 2640ff0e214SJoseph Chen{ 265f9afd3dcSJoseph Chen # skip "--" parameter, such as "--rollback-index-..." 266*b768b915SJoseph Chen if [[ "$ARG_SUBCMD" != "--*" ]]; then 267*b768b915SJoseph Chen cmd=${ARG_SUBCMD%-*} 268*b768b915SJoseph Chen opt=${ARG_SUBCMD#*-} 269f9afd3dcSJoseph Chen else 270*b768b915SJoseph Chen cmd=$ARG_SUBCMD 271f9afd3dcSJoseph Chen fi 272f9afd3dcSJoseph Chen 273*b768b915SJoseph Chen if [ "$ARG_S_TPL" == "tpl" -o "$ARG_S_TPL" == "spl" ]; then 274*b768b915SJoseph Chen elf=`find -name u-boot-${ARG_S_TPL}` 275*b768b915SJoseph Chen map=`find -name u-boot-${ARG_S_TPL}.map` 276*b768b915SJoseph Chen sym=`find -name u-boot-${ARG_S_TPL}.sym` 277*b768b915SJoseph Chen else 2787c3ca500SJoseph Chen elf=u-boot 2797c3ca500SJoseph Chen map=u-boot.map 2807c3ca500SJoseph Chen sym=u-boot.sym 28134bdfea0SJoseph Chen fi 2820ff0e214SJoseph Chen 283b6255198SJoseph Chen case $cmd in 284b6255198SJoseph Chen elf) 2857c3ca500SJoseph Chen if [ ! -f ${elf} ]; then 2867c3ca500SJoseph Chen echo "ERROR: No elf: ${elf}" 2870ff0e214SJoseph Chen exit 1 2880ff0e214SJoseph Chen else 289b6255198SJoseph Chen # default 'cmd' without option, use '-D' 2905c75ab41SJoseph Chen if [ "${cmd}" = 'elf' -a "${opt}" = 'elf' ]; then 2915c75ab41SJoseph Chen opt=D 2920ff0e214SJoseph Chen fi 29334bdfea0SJoseph Chen ${TOOLCHAIN_OBJDUMP} -${opt} ${elf} | less 29407de173aSJoseph Chen exit 0 29507de173aSJoseph Chen fi 296b6255198SJoseph Chen ;; 297b6255198SJoseph Chen 2981b6c85a0SJoseph Chen debug) 299fcccd23aSJoseph Chen ./scripts/rkpatch.sh ${opt} 3001b6c85a0SJoseph Chen exit 0 3011b6c85a0SJoseph Chen ;; 3021b6c85a0SJoseph Chen 30369b6e590SJoseph Chen fit) 3044b4c6841SJoseph Chen if [ "$opt" = "ns" ]; then 305*b768b915SJoseph Chen ./scripts/fit-vboot.sh --no-vboot --ini-trust $INI_TRUST --ini-loader $INI_LOADER 3066cf81e27SJoseph Chen fi 30769b6e590SJoseph Chen exit 0 30869b6e590SJoseph Chen ;; 30969b6e590SJoseph Chen 310b6255198SJoseph Chen map) 31134bdfea0SJoseph Chen cat ${map} | less 312b6255198SJoseph Chen exit 0 313b6255198SJoseph Chen ;; 314b6255198SJoseph Chen 315b6255198SJoseph Chen sym) 31634bdfea0SJoseph Chen cat ${sym} | less 317b6255198SJoseph Chen exit 0 318b6255198SJoseph Chen ;; 319b6255198SJoseph Chen 320b6255198SJoseph Chen trust) 321d6e1155eSJoseph Chen pack_trust_image 322a43a18b2SJoseph Chen exit 0 323b6255198SJoseph Chen ;; 324b6255198SJoseph Chen 325b6255198SJoseph Chen loader) 326d6e1155eSJoseph Chen pack_loader_image 327a43a18b2SJoseph Chen exit 0 328b6255198SJoseph Chen ;; 329b6255198SJoseph Chen 330daa3bef5SJoseph Chen spl) 331daa3bef5SJoseph Chen pack_spl_loader_image ${opt} 332daa3bef5SJoseph Chen exit 0 333daa3bef5SJoseph Chen ;; 334daa3bef5SJoseph Chen 335daa3bef5SJoseph Chen itb) 336daa3bef5SJoseph Chen pack_uboot_itb_image 337daa3bef5SJoseph Chen exit 0 338daa3bef5SJoseph Chen ;; 339daa3bef5SJoseph Chen 340b6255198SJoseph Chen uboot) 341*b768b915SJoseph Chen pack_uboot_image 342fb90bd1dSJoseph Chen exit 0 343b6255198SJoseph Chen ;; 344b6255198SJoseph Chen 345398d3e80SJoseph Chen env) 346398d3e80SJoseph Chen make CROSS_COMPILE=${TOOLCHAIN_GCC} envtools 347398d3e80SJoseph Chen exit 0 348398d3e80SJoseph Chen ;; 349398d3e80SJoseph Chen 350f9afd3dcSJoseph Chen --rollback-index*) 351*b768b915SJoseph Chen pack_fit_image $ARG_ROLLBACK_IDX_UBOOT $ARG_ROLLBACK_IDX_BOOT --ini-trust $INI_TRUST --ini-loader $INI_LOADER 352f9afd3dcSJoseph Chen exit 0 353f9afd3dcSJoseph Chen ;; 354f9afd3dcSJoseph Chen 355622ccf34SJoseph Chen EXT_DTB=*) 356*b768b915SJoseph Chen OPTION=${ARG_SUBCMD} 357622ccf34SJoseph Chen ;; 358622ccf34SJoseph Chen 3598f53a15cSJoseph Chen nopack) 360*b768b915SJoseph Chen IMAGE_NOPACK="y" 3618f53a15cSJoseph Chen ;; 3628f53a15cSJoseph Chen 363b6255198SJoseph Chen *) 36453ea5791SJoseph Chen # Search function and code position of address 365*b768b915SJoseph Chen FUNCADDR=$ARG_FUNCADDR 366*b768b915SJoseph Chen 367fc99e044SJoseph Chen RELOC_OFF=${FUNCADDR#*-} 368fc99e044SJoseph Chen FUNCADDR=${FUNCADDR%-*} 369fc99e044SJoseph Chen if [ -z $(echo ${FUNCADDR} | sed 's/[0-9,a-f,A-F,x,X,-]//g') ] && [ ${FUNCADDR} ]; then 3707070f875SJoseph Chen # With prefix: '0x' or '0X' 3717070f875SJoseph Chen if [ `echo ${FUNCADDR} | sed -n "/0[x,X]/p" | wc -l` -ne 0 ]; then 3727070f875SJoseph Chen FUNCADDR=`echo $FUNCADDR | awk '{ print strtonum($0) }'` 3737070f875SJoseph Chen FUNCADDR=`echo "obase=16;${FUNCADDR}"|bc |tr '[A-Z]' '[a-z]'` 3747070f875SJoseph Chen fi 375fc99e044SJoseph Chen if [ `echo ${RELOC_OFF} | sed -n "/0[x,X]/p" | wc -l` -ne 0 ] && [ ${RELOC_OFF} ]; then 376fc99e044SJoseph Chen RELOC_OFF=`echo $RELOC_OFF | awk '{ print strtonum($0) }'` 377fc99e044SJoseph Chen RELOC_OFF=`echo "obase=16;${RELOC_OFF}"|bc |tr '[A-Z]' '[a-z]'` 378fc99e044SJoseph Chen fi 379fc99e044SJoseph Chen 380fc99e044SJoseph Chen # If reloc address is assigned, do sub 381fc99e044SJoseph Chen if [ "${FUNCADDR}" != "${RELOC_OFF}" ]; then 382fc99e044SJoseph Chen # Hex -> Dec -> SUB -> Hex 383fc99e044SJoseph Chen FUNCADDR=`echo $((16#${FUNCADDR}))` 384fc99e044SJoseph Chen RELOC_OFF=`echo $((16#${RELOC_OFF}))` 385fc99e044SJoseph Chen FUNCADDR=$((FUNCADDR-RELOC_OFF)) 386fc99e044SJoseph Chen FUNCADDR=$(echo "obase=16;${FUNCADDR}"|bc |tr '[A-Z]' '[a-z]') 387fc99e044SJoseph Chen fi 3887070f875SJoseph Chen 38953ea5791SJoseph Chen echo 39034bdfea0SJoseph Chen sed -n "/${FUNCADDR}/p" ${sym} 39134bdfea0SJoseph Chen ${TOOLCHAIN_ADDR2LINE} -e ${elf} ${FUNCADDR} 39253ea5791SJoseph Chen exit 0 39353ea5791SJoseph Chen fi 394b6255198SJoseph Chen ;; 395b6255198SJoseph Chen esac 3960ff0e214SJoseph Chen} 3970ff0e214SJoseph Chen 398de440615SJoseph Chen# We select chip info to do: 399de440615SJoseph Chen# 1. RKCHIP: fixup platform configure 400de440615SJoseph Chen# 2. RKCHIP_LOADER: search ini file to pack loader 401de440615SJoseph Chen# 3. RKCHIP_TRUST: search ini file to pack trust 402de440615SJoseph Chen# 4. RKCHIP_LABEL: show build message 403de440615SJoseph Chen# 404de440615SJoseph Chen# We read chip info from .config and 'RKCHIP_INI_DESC' 4057c3ca500SJoseph Chenfunction select_chip_info() 406bc98b3c8SJoseph Chen{ 407de440615SJoseph Chen # Read RKCHIP firstly from .config 408596700d7SShunqian Zheng # The regular expression that matching: 409596700d7SShunqian Zheng # - PX30, PX3SE 410596700d7SShunqian Zheng # - RK????, RK????X 411596700d7SShunqian Zheng # - RV???? 4127c3ca500SJoseph Chen chip_pattern='^CONFIG_ROCKCHIP_[R,P][X,V,K][0-9ESX]{1,5}' 4137c3ca500SJoseph Chen RKCHIP=`egrep -o ${chip_pattern} .config` 414d443b7d5SJoseph Chen 4150583701dSJoseph Chen # default 416d443b7d5SJoseph Chen RKCHIP=${RKCHIP##*_} 41741cf5e5aSJoseph Chen 4180583701dSJoseph Chen # need fixup ? 4197c3ca500SJoseph Chen for item in "${CHIP_TYPE_FIXUP_TABLE[@]}" 420de440615SJoseph Chen do 4217c3ca500SJoseph Chen config_xxx=`echo $item | awk '{ print $1 }'` 4227c3ca500SJoseph Chen if grep -q "^${config_xxx}=y" .config ; then 4237c3ca500SJoseph Chen RKCHIP=`echo $item | awk '{ print $2 }'` 4247c3ca500SJoseph Chen RKCHIP_LOADER=`echo $item | awk '{ print $3 }'` 4257c3ca500SJoseph Chen RKCHIP_TRUST=`echo $item | awk '{ print $4 }'` 4267c3ca500SJoseph Chen RKCHIP_LABEL=`echo $item | awk '{ print $5 }'` 427de440615SJoseph Chen fi 4280583701dSJoseph Chen done 4290583701dSJoseph Chen 4300583701dSJoseph Chen if [ "$RKCHIP_LOADER" = "-" ]; then 4310583701dSJoseph Chen RKCHIP_LOADER=${RKCHIP} 432de440615SJoseph Chen fi 4330583701dSJoseph Chen if [ "$RKCHIP_TRUST" = "-" ]; then 4340583701dSJoseph Chen RKCHIP_TRUST=${RKCHIP} 4350583701dSJoseph Chen fi 4360583701dSJoseph Chen if [ "$RKCHIP_LABEL" = "-" ]; then 4370583701dSJoseph Chen RKCHIP_LABEL=${RKCHIP} 4380583701dSJoseph Chen fi 4390583701dSJoseph Chen} 4400583701dSJoseph Chen 4410583701dSJoseph Chenfunction fixup_platform_configure() 4420583701dSJoseph Chen{ 443*b768b915SJoseph Chen u_kb="-" u_num="-" t_kb="-" t_num="-" sha="-" rsa="-" 4440583701dSJoseph Chen 4457c3ca500SJoseph Chen for item in "${CHIP_CFG_FIXUP_TABLE[@]}" 4460583701dSJoseph Chen do 4477c3ca500SJoseph Chen config_xxx=`echo $item | awk '{ print $1 }'` 4487c3ca500SJoseph Chen if grep -q "^${config_xxx}=y" .config ; then 4490583701dSJoseph Chen # <*> Fixup rsa/sha pack mode for platforms 450*b768b915SJoseph Chen rsa=`echo $item | awk '{ print $2 }'` 451*b768b915SJoseph Chen sha=`echo $item | awk '{ print $3 }'` 4520583701dSJoseph Chen 4530583701dSJoseph Chen # <*> Fixup images size pack for platforms, and ini file 4540583701dSJoseph Chen if grep -q '^CONFIG_ARM64_BOOT_AARCH32=y' .config ; then 455*b768b915SJoseph Chen u_kb=`echo $item | awk '{ print $6 }' | awk -F "," '{ print $1 }'` 456*b768b915SJoseph Chen t_kb=`echo $item | awk '{ print $6 }' | awk -F "," '{ print $2 }'` 457*b768b915SJoseph Chen u_num=`echo $item | awk '{ print $7 }' | awk -F "," '{ print $1 }'` 458*b768b915SJoseph Chen t_num=`echo $item | awk '{ print $7 }' | awk -F "," '{ print $2 }'` 4590583701dSJoseph Chen 4607c3ca500SJoseph Chen PAD_LOADER=`echo $item | awk '{ print $8 }'` 4617c3ca500SJoseph Chen PAD_TRUST=`echo $item | awk '{ print $9 }'` 4620583701dSJoseph Chen if [ "$PAD_LOADER" != "-" ]; then 4630583701dSJoseph Chen RKCHIP_LOADER=${RKCHIP_LOADER}${PAD_LOADER} 4640583701dSJoseph Chen fi 4650583701dSJoseph Chen if [ "$PAD_TRUST" != "-" ]; then 4660583701dSJoseph Chen RKCHIP_TRUST=${RKCHIP_TRUST}${PAD_TRUST} 4670583701dSJoseph Chen fi 4680583701dSJoseph Chen RKCHIP_LABEL=${RKCHIP_LABEL}"AARCH32" 4690583701dSJoseph Chen else 470*b768b915SJoseph Chen u_kb=`echo $item | awk '{ print $4 }' | awk -F "," '{ print $1 }'` 471*b768b915SJoseph Chen t_kb=`echo $item | awk '{ print $4 }' | awk -F "," '{ print $2 }'` 472*b768b915SJoseph Chen u_num=`echo $item | awk '{ print $5 }' | awk -F "," '{ print $1 }'` 473*b768b915SJoseph Chen t_num=`echo $item | awk '{ print $5 }' | awk -F "," '{ print $2 }'` 474de440615SJoseph Chen fi 475de440615SJoseph Chen fi 476de440615SJoseph Chen done 477de440615SJoseph Chen 478*b768b915SJoseph Chen if [ "$sha" != "-" ]; then 479*b768b915SJoseph Chen PLATFORM_SHA="--sha $sha" 4800583701dSJoseph Chen fi 481*b768b915SJoseph Chen if [ "$rsa" != "-" ]; then 482*b768b915SJoseph Chen PLATFORM_RSA="--rsa $rsa" 4830583701dSJoseph Chen fi 484*b768b915SJoseph Chen if [ "$u_kb" != "-" ]; then 485*b768b915SJoseph Chen PLATFORM_UBOOT_IMG_SIZE="--size $u_kb $u_num" 4860583701dSJoseph Chen fi 487*b768b915SJoseph Chen if [ "$t_kb" != "-" ]; then 488*b768b915SJoseph Chen PLATFORM_TRUST_IMG_SIZE="--size $t_kb $t_num" 489*b768b915SJoseph Chen fi 490*b768b915SJoseph Chen} 491*b768b915SJoseph Chen 492*b768b915SJoseph Chenfunction select_ini_file() 493*b768b915SJoseph Chen{ 494*b768b915SJoseph Chen # default 495*b768b915SJoseph Chen INI_LOADER=${RKBIN}/RKBOOT/${RKCHIP_LOADER}MINIALL.ini 496*b768b915SJoseph Chen if [ "$ARM64_TRUSTZONE" = "y" ]; then 497*b768b915SJoseph Chen INI_TRUST=${RKBIN}/RKTRUST/${RKCHIP_TRUST}TRUST.ini 498*b768b915SJoseph Chen else 499*b768b915SJoseph Chen INI_TRUST=${RKBIN}/RKTRUST/${RKCHIP_TRUST}TOS.ini 50041cf5e5aSJoseph Chen fi 50141cf5e5aSJoseph Chen 502*b768b915SJoseph Chen # args 503*b768b915SJoseph Chen if [ "$ARG_INI_TRUST" != "" ]; then 504*b768b915SJoseph Chen INI_TRUST=$ARG_INI_TRUST 505*b768b915SJoseph Chen fi 506*b768b915SJoseph Chen if [ "$ARG_INI_LOADER" != "" ]; then 507*b768b915SJoseph Chen INI_LOADER=$ARG_INI_LOADER 508*b768b915SJoseph Chen fi 50927a50c86SAndy Yan} 510de9a6cd2SJoseph Chen 5117c3ca500SJoseph Chenfunction pack_uboot_image() 512de9a6cd2SJoseph Chen{ 513*b768b915SJoseph Chen if [ "$IMAGE_FORMAT" != "RKFW" ]; then 5148f53a15cSJoseph Chen return 5158f53a15cSJoseph Chen fi 5168f53a15cSJoseph Chen 517f089d907SJoseph Chen # Check file size 5187c3ca500SJoseph Chen head_kb=2 5197c3ca500SJoseph Chen uboot_kb=`ls -l u-boot.bin | awk '{print $5}'` 520f089d907SJoseph Chen if [ "$PLATFORM_UBOOT_IMG_SIZE" = "" ]; then 5217c3ca500SJoseph Chen uboot_max_kb=1046528 522f089d907SJoseph Chen else 5237c3ca500SJoseph Chen uboot_max_kb=`echo $PLATFORM_UBOOT_IMG_SIZE | awk '{print strtonum($2)}'` 5247c3ca500SJoseph Chen uboot_max_kb=$(((uboot_max_kb-head_kb)*1024)) 525f089d907SJoseph Chen fi 526f089d907SJoseph Chen 5277c3ca500SJoseph Chen if [ $uboot_kb -gt $uboot_max_kb ]; then 528f089d907SJoseph Chen echo 5297c3ca500SJoseph Chen echo "ERROR: pack uboot failed! u-boot.bin actual: $uboot_kb bytes, max limit: $uboot_max_kb bytes" 530f089d907SJoseph Chen exit 1 531f089d907SJoseph Chen fi 532f089d907SJoseph Chen 5337c3ca500SJoseph Chen # Pack 5347c3ca500SJoseph Chen uboot_load_addr=`sed -n "/CONFIG_SYS_TEXT_BASE=/s/CONFIG_SYS_TEXT_BASE=//p" include/autoconf.mk|tr -d '\r'` 5357c3ca500SJoseph Chen if [ -z $uboot_load_addr ]; then 5367c3ca500SJoseph Chen echo "ERROR: No CONFIG_SYS_TEXT_BASE for u-boot"; 5377c3ca500SJoseph Chen exit 1 538daa679a7SKever Yang fi 5397c3ca500SJoseph Chen ${RKTOOLS}/loaderimage --pack --uboot u-boot.bin uboot.img ${uboot_load_addr} ${PLATFORM_UBOOT_IMG_SIZE} 540a11e2c82SJoseph Chen rm u-boot.img u-boot-dtb.img -rf 54191205f1dSJoseph Chen echo "pack uboot okay! Input: u-boot.bin" 542de9a6cd2SJoseph Chen} 543de9a6cd2SJoseph Chen 5447c3ca500SJoseph Chenfunction pack_uboot_itb_image() 545daa3bef5SJoseph Chen{ 546*b768b915SJoseph Chen ini=$INI_TRUST 5477c3ca500SJoseph Chen 548*b768b915SJoseph Chen if [ ! -f $INI_TRUST ]; then 549*b768b915SJoseph Chen echo "pack trust failed! Can't find: $INI_TRUST" 5500d0d4395SJoseph Chen return 5510d0d4395SJoseph Chen fi 5520d0d4395SJoseph Chen 5537c3ca500SJoseph Chen if [ "$ARM64_TRUSTZONE" = "y" ]; then 5547c3ca500SJoseph Chen bl31=`sed -n '/_bl31_/s/PATH=//p' $ini |tr -d '\r'` 5557c3ca500SJoseph Chen cp ${RKBIN}/${bl31} bl31.elf 5567c3ca500SJoseph Chen make CROSS_COMPILE=${TOOLCHAIN_GCC} u-boot.itb 5577c3ca500SJoseph Chen echo "pack u-boot.itb okay! Input: $ini" 5580d0d4395SJoseph Chen else 5597c3ca500SJoseph Chen tos_image=`sed -n "/TOS=/s/TOS=//p" $ini |tr -d '\r'` 5607c3ca500SJoseph Chen tosta_image=`sed -n "/TOSTA=/s/TOSTA=//p" $ini |tr -d '\r'` 5617c3ca500SJoseph Chen if [ $tosta_image ]; then 5627c3ca500SJoseph Chen cp ${RKBIN}/${tosta_image} tee.bin 5637c3ca500SJoseph Chen elif [ $tos_image ]; then 5647c3ca500SJoseph Chen cp ${RKBIN}/${tos_image} tee.bin 5657c3ca500SJoseph Chen else 5667c3ca500SJoseph Chen echo "ERROR: No any tee bin" 5670d0d4395SJoseph Chen exit 1 5680d0d4395SJoseph Chen fi 5690d0d4395SJoseph Chen 5707c3ca500SJoseph Chen tee_offset=`sed -n "/ADDR=/s/ADDR=//p" $ini |tr -d '\r'` 5717c3ca500SJoseph Chen if [ "$tee_offset" = "" ]; then 5727c3ca500SJoseph Chen tee_offset=0x8400000 573d13b75e1SJoseph Chen fi 574d13b75e1SJoseph Chen 57585101532SJoseph Chen mcu_enabled=`awk -F"," '/MCU=/ { printf $3 }' $ini | tr -d ' '` 57685101532SJoseph Chen if [ "$mcu_enabled" = "enabled" ]; then 57785101532SJoseph Chen mcu_image=`awk -F"," '/MCU=/ { printf $1 }' $ini | tr -d ' ' | cut -c 5-` 57885101532SJoseph Chen mcu_offset=`awk -F"," '/MCU=/ { printf $2 }' $ini | tr -d ' '` 57985101532SJoseph Chen cp ${RKBIN}/${mcu_image} mcu.bin 58085101532SJoseph Chen fi 58185101532SJoseph Chen 582db3b6a92SJoseph Chen SPL_FIT_SOURCE=`sed -n "/CONFIG_SPL_FIT_SOURCE=/s/CONFIG_SPL_FIT_SOURCE=//p" .config | tr -d '""'` 583db3b6a92SJoseph Chen if [ ! -z $SPL_FIT_SOURCE ]; then 584db3b6a92SJoseph Chen cp $SPL_FIT_SOURCE u-boot.its 585db3b6a92SJoseph Chen else 586db3b6a92SJoseph Chen SPL_FIT_GENERATOR=`sed -n "/CONFIG_SPL_FIT_GENERATOR=/s/CONFIG_SPL_FIT_GENERATOR=//p" .config | tr -d '""'` 58785101532SJoseph Chen $SPL_FIT_GENERATOR $tee_offset $mcu_offset > u-boot.its 588db3b6a92SJoseph Chen fi 589d13b75e1SJoseph Chen ./tools/mkimage -f u-boot.its -E u-boot.itb 5907c3ca500SJoseph Chen echo "pack u-boot.itb okay! Input: $ini" 5910d0d4395SJoseph Chen fi 592*b768b915SJoseph Chen echo 593daa3bef5SJoseph Chen} 594daa3bef5SJoseph Chen 5957c3ca500SJoseph Chenfunction pack_spl_loader_image() 596daa3bef5SJoseph Chen{ 5977c3ca500SJoseph Chen mode=$1 5987c3ca500SJoseph Chen tmp_dir=${RKBIN}/tmp 5997c3ca500SJoseph Chen tmp_ini=${tmp_dir}/${RKCHIP_LOADER}MINIALL.ini 600*b768b915SJoseph Chen ini=$INI_LOADER 601*b768b915SJoseph Chen if [ ! -f $INI_LOADER ]; then 602*b768b915SJoseph Chen echo "pack loader failed! Can't find: $INI_LOADER" 603daa3bef5SJoseph Chen return 604daa3bef5SJoseph Chen fi 605daa3bef5SJoseph Chen 606a11e2c82SJoseph Chen rm ${tmp_dir} -rf 6077c3ca500SJoseph Chen mkdir ${tmp_dir} -p 6087c3ca500SJoseph Chen cp spl/u-boot-spl.bin ${tmp_dir}/ 6097c3ca500SJoseph Chen cp $ini $tmp_ini 610daa3bef5SJoseph Chen if [ "$mode" = 'spl' ]; then # pack tpl+spl 611daa3bef5SJoseph Chen label="TPL+SPL" 6127c3ca500SJoseph Chen cp tpl/u-boot-tpl.bin ${tmp_dir}/ 6137c3ca500SJoseph Chen header=`sed -n '/NAME=/s/NAME=//p' ${ini}` 6147c3ca500SJoseph Chen dd if=${tmp_dir}/u-boot-tpl.bin of=${tmp_dir}/tpl.bin bs=1 skip=4 6157c3ca500SJoseph Chen sed -i "1s/^/${header:0:4}/" ${tmp_dir}/tpl.bin 6167c3ca500SJoseph Chen sed -i "s/FlashData=.*$/FlashData=.\/tmp\/tpl.bin/" $tmp_ini 6177c3ca500SJoseph Chen else 6187c3ca500SJoseph Chen label="SPL" 619daa3bef5SJoseph Chen fi 620daa3bef5SJoseph Chen 6217c3ca500SJoseph Chen sed -i "s/FlashBoot=.*$/FlashBoot=.\/tmp\/u-boot-spl.bin/" $tmp_ini 6227c3ca500SJoseph Chen cd ${RKBIN} 6237c3ca500SJoseph Chen ${RKTOOLS}/boot_merger $tmp_ini 6247c3ca500SJoseph Chen rm ${tmp_dir} -rf 625daa3bef5SJoseph Chen cd - 626a11e2c82SJoseph Chen rm *_loader_*.bin -rf 627b4e157ffSJoseph Chen mv ${RKBIN}/*_loader_*.bin ./ 6287c3ca500SJoseph Chen 629aa8ddc58SJoseph Chen filename=`basename *_loader_*.bin` 630aa8ddc58SJoseph Chen if [[ $filename != *spl* ]]; then 631b4e157ffSJoseph Chen rename 's/loader_/spl_loader_/' *_loader_*.bin 632aa8ddc58SJoseph Chen fi 6337c3ca500SJoseph Chen echo "pack loader(${label}) okay! Input: $ini" 634daa3bef5SJoseph Chen} 635daa3bef5SJoseph Chen 6367c3ca500SJoseph Chenfunction pack_loader_image() 637cd7ae718SJoseph Chen{ 638*b768b915SJoseph Chen ini=$INI_LOADER 639*b768b915SJoseph Chen if [ ! -f $INI_LOADER ]; then 640*b768b915SJoseph Chen echo "pack loader failed! Can't find: $INI_LOADER" 64151441a28SJoseph Chen return 64251441a28SJoseph Chen fi 64351441a28SJoseph Chen 644a11e2c82SJoseph Chen rm *_loader_*.bin -rf 645783f7f6eSJoseph Chen numline=`cat $ini | wc -l` 646783f7f6eSJoseph Chen if [ $numline -eq 1 ]; then 647783f7f6eSJoseph Chen image=`sed -n "/PATH=/p" $ini | tr -d '\r' | cut -d '=' -f 2` 648783f7f6eSJoseph Chen cp ${RKBIN}/${image} ./ 6497c3ca500SJoseph Chen else 650cd7ae718SJoseph Chen cd ${RKBIN} 6517c3ca500SJoseph Chen ${RKTOOLS}/boot_merger $ini 652fb90bd1dSJoseph Chen cd - && mv ${RKBIN}/*_loader_*.bin ./ 6537c3ca500SJoseph Chen fi 6547c3ca500SJoseph Chen 65569b6e590SJoseph Chen file=`ls *loader*.bin` 65669b6e590SJoseph Chen echo "pack $file okay! Input: $ini" 657cd7ae718SJoseph Chen} 658cd7ae718SJoseph Chen 6597c3ca500SJoseph Chenfunction pack_arm32_trust_image() 660cd7ae718SJoseph Chen{ 6617c3ca500SJoseph Chen ini=$1 6627c3ca500SJoseph Chen tos_image=`sed -n "/TOS=/s/TOS=//p" $ini |tr -d '\r'` 6637c3ca500SJoseph Chen tosta_image=`sed -n "/TOSTA=/s/TOSTA=//p" $ini |tr -d '\r'` 6647c3ca500SJoseph Chen tee_output=`sed -n "/OUTPUT=/s/OUTPUT=//p" $ini |tr -d '\r'` 6657c3ca500SJoseph Chen if [ "$tee_output" = "" ]; then 6667c3ca500SJoseph Chen tee_output="./trust.img" 66751441a28SJoseph Chen fi 6687c3ca500SJoseph Chen tee_offset=`sed -n "/ADDR=/s/ADDR=//p" $ini |tr -d '\r'` 6697c3ca500SJoseph Chen if [ "$tee_offset" = "" ]; then 6707c3ca500SJoseph Chen tee_offset=0x8400000 67151441a28SJoseph Chen fi 67251441a28SJoseph Chen 673cd7ae718SJoseph Chen # OP-TEE is 132M(0x8400000) offset from DRAM base. 674eee9fb0aSJoseph Chen dram_base=`sed -n "/CONFIG_SYS_SDRAM_BASE=/s/CONFIG_SYS_SDRAM_BASE=//p" include/autoconf.mk|tr -d '\r'` 6757c3ca500SJoseph Chen tee_load_addr=$((dram_base+tee_offset)) 6767c3ca500SJoseph Chen tee_load_addr=$(echo "obase=16;${tee_load_addr}"|bc) # Convert Dec to Hex 6770e90839aSJoseph Chen 6787c3ca500SJoseph Chen if [ $tosta_image ]; then 6797c3ca500SJoseph Chen ${RKTOOLS}/loaderimage --pack --trustos ${RKBIN}/${tosta_image} ${tee_output} ${tee_load_addr} ${PLATFORM_TRUST_IMG_SIZE} 6807c3ca500SJoseph Chen elif [ $tos_image ]; then 6817c3ca500SJoseph Chen ${RKTOOLS}/loaderimage --pack --trustos ${RKBIN}/${tos_image} ${tee_output} ${tee_load_addr} ${PLATFORM_TRUST_IMG_SIZE} 682cd7ae718SJoseph Chen else 6837c3ca500SJoseph Chen echo "ERROR: No any tee bin" 684a64486b5SJoseph Chen exit 1 685cd7ae718SJoseph Chen fi 6867c3ca500SJoseph Chen echo "pack trust okay! Input: $ini" 68769cce37bSJoseph Chen} 68869cce37bSJoseph Chen 6897c3ca500SJoseph Chenfunction pack_arm64_trust_image() 69069cce37bSJoseph Chen{ 6917c3ca500SJoseph Chen ini=$1 69269cce37bSJoseph Chen cd ${RKBIN} 6937c3ca500SJoseph Chen ${RKTOOLS}/trust_merger ${PLATFORM_SHA} ${PLATFORM_RSA} ${PLATFORM_TRUST_IMG_SIZE} $ini 69469cce37bSJoseph Chen cd - && mv ${RKBIN}/trust*.img ./ 6957c3ca500SJoseph Chen echo "pack trust okay! Input: $ini" 69669cce37bSJoseph Chen} 69769cce37bSJoseph Chen 6987c3ca500SJoseph Chenfunction pack_trust_image() 69969cce37bSJoseph Chen{ 700*b768b915SJoseph Chen if [ "$IMAGE_FORMAT" != "RKFW" ]; then 7018f53a15cSJoseph Chen return 7028f53a15cSJoseph Chen fi 7038f53a15cSJoseph Chen 704a11e2c82SJoseph Chen rm trust*.img -rf 705*b768b915SJoseph Chen ini=$INI_TRUST 706*b768b915SJoseph Chen if [ ! -f $INI_TRUST ]; then 707*b768b915SJoseph Chen echo "pack trust failed! Can't find: $INI_TRUST" 7087c3ca500SJoseph Chen return 709dd590c93SJoseph Chen fi 710dd590c93SJoseph Chen 711783f7f6eSJoseph Chen numline=`cat $ini | wc -l` 712783f7f6eSJoseph Chen if [ $numline -eq 1 ]; then 713783f7f6eSJoseph Chen image=`sed -n "/PATH=/p" $ini | tr -d '\r' | cut -d '=' -f 2` 714783f7f6eSJoseph Chen cp ${RKBIN}/${image} ./trust.img 7157c3ca500SJoseph Chen echo "pack trust okay! Input: $ini" 716783f7f6eSJoseph Chen return; 71769cce37bSJoseph Chen else 7187c3ca500SJoseph Chen if [ "$ARM64_TRUSTZONE" = "y" ]; then 7197c3ca500SJoseph Chen pack_arm64_trust_image $ini 7207c3ca500SJoseph Chen else 7217c3ca500SJoseph Chen pack_arm32_trust_image $ini 722dd590c93SJoseph Chen fi 723cd7ae718SJoseph Chen fi 724cd7ae718SJoseph Chen} 725cd7ae718SJoseph Chen 7268f53a15cSJoseph Chenfunction pack_fit_image() 7278f53a15cSJoseph Chen{ 7284b4c6841SJoseph Chen if grep -q '^CONFIG_FIT_SIGNATURE=y' .config ; then 729*b768b915SJoseph Chen ./scripts/fit-vboot.sh $ARG_ROLLBACK_IDX_UBOOT $ARG_ROLLBACK_IDX_BOOT --ini-trust $INI_TRUST --ini-loader $INI_LOADER 7304b4c6841SJoseph Chen else 731a11e2c82SJoseph Chen rm uboot.img trust*.img -rf 732*b768b915SJoseph Chen ./scripts/fit-vboot-uboot.sh --no-vboot --no-rebuild --ini-trust $INI_TRUST --ini-loader $INI_LOADER 733*b768b915SJoseph Chen echo "pack uboot.img (with uboot trust) okay! Input: $INI_TRUST" 7344b4c6841SJoseph Chen fi 7358f53a15cSJoseph Chen} 7368f53a15cSJoseph Chen 7378f53a15cSJoseph Chenfunction pack_images() 7388f53a15cSJoseph Chen{ 739*b768b915SJoseph Chen if [ "$IMAGE_NOPACK" != "y" ]; then 740*b768b915SJoseph Chen if [ "$IMAGE_FORMAT" = "RKFW" ]; then 7418f53a15cSJoseph Chen pack_uboot_image 7428f53a15cSJoseph Chen pack_trust_image 7438f53a15cSJoseph Chen pack_loader_image 744*b768b915SJoseph Chen elif [ "$IMAGE_FORMAT" = "FIT" ]; then 745*b768b915SJoseph Chen pack_fit_image $ARG_ROLLBACK_IDX_UBOOT $ARG_ROLLBACK_IDX_BOOT --ini-trust $INI_TRUST --ini-loader $INI_LOADER 7468f53a15cSJoseph Chen fi 7478f53a15cSJoseph Chen fi 7488f53a15cSJoseph Chen} 7498f53a15cSJoseph Chen 7508f53a15cSJoseph Chenfunction clean_files() 7518f53a15cSJoseph Chen{ 7528f53a15cSJoseph Chen if [ -f spl/u-boot-spl.dtb ]; then 753a11e2c82SJoseph Chen rm spl/u-boot-spl.dtb -rf 7548f53a15cSJoseph Chen fi 7558f53a15cSJoseph Chen if [ -f tpl/u-boot-tpl.dtb ]; then 756a11e2c82SJoseph Chen rm tpl/u-boot-tpl.dtb -rf 7578f53a15cSJoseph Chen fi 7588f53a15cSJoseph Chen if [ -f u-boot.dtb ]; then 759a11e2c82SJoseph Chen rm u-boot.dtb -rf 7608f53a15cSJoseph Chen fi 7618f53a15cSJoseph Chen} 7628f53a15cSJoseph Chen 7637c3ca500SJoseph Chenfunction finish() 76430b04afcSJoseph Chen{ 76530b04afcSJoseph Chen echo 766622ccf34SJoseph Chen if [ ! -z "$OPTION" ]; then 767622ccf34SJoseph Chen echo "Platform ${RKCHIP_LABEL} is build OK, with exist .config ($OPTION)" 768*b768b915SJoseph Chen elif [ "$ARG_BOARD" = '' ]; then 7695202fe1fSJoseph Chen echo "Platform ${RKCHIP_LABEL} is build OK, with exist .config" 77030b04afcSJoseph Chen else 771*b768b915SJoseph Chen echo "Platform ${RKCHIP_LABEL} is build OK, with new .config(make ${ARG_BOARD}_defconfig)" 77230b04afcSJoseph Chen fi 77330b04afcSJoseph Chen} 77430b04afcSJoseph Chen 775*b768b915SJoseph Chenprocess_args $* 776cd7ae718SJoseph Chenprepare 7777c2526e9SJoseph Chenselect_toolchain 778de440615SJoseph Chenselect_chip_info 77941cf5e5aSJoseph Chenfixup_platform_configure 780*b768b915SJoseph Chenselect_ini_file 7810ff0e214SJoseph Chensub_commands 7828f53a15cSJoseph Chenclean_files 783622ccf34SJoseph Chenmake CROSS_COMPILE=${TOOLCHAIN_GCC} ${OPTION} all --jobs=${JOB} 7848f53a15cSJoseph Chenpack_images 78530b04afcSJoseph Chenfinish 786