1de440615SJoseph Chen#!/bin/bash 2cd7ae718SJoseph Chenset -e 327a50c86SAndy YanBOARD=$1 4b6255198SJoseph ChenSUBCMD=$1 553ea5791SJoseph ChenFUNCADDR=$1 627a50c86SAndy YanJOB=`sed -n "N;/processor/p" /proc/cpuinfo|wc -l` 7b6255198SJoseph ChenSUPPORT_LIST=`ls configs/*[r,p][x,v,k][0-9][0-9]*_defconfig` 827a50c86SAndy Yan 9de440615SJoseph Chen# @target board: defined in arch/arm/mach-rockchip/<soc>/Kconfig 10de440615SJoseph Chen# @label: show build message 11de440615SJoseph Chen# @loader: search for ini file to pack loader 12de440615SJoseph Chen# @trust: search for ini file to pack trust 13de440615SJoseph Chen# 14de440615SJoseph Chen# "NA" means use default name reading from .config 15de440615SJoseph Chen# 16de440615SJoseph Chen# Format: target board label loader trust 17de440615SJoseph ChenRKCHIP_INI_DESC=("CONFIG_TARGET_GVA_RK3229 NA RK322XAT NA" 183776a9bdSJoseph Chen "CONFIG_COPROCESSOR_RK1808 RK3399PRO-NPU RK3399PRONPU RK3399PRONPU" 19de440615SJoseph Chen# to be add... 20de440615SJoseph Chen ) 21de440615SJoseph Chen 22fb90bd1dSJoseph Chen########################################### User can modify ############################################# 23fb90bd1dSJoseph Chen# User's rkbin tool relative path 24bc98b3c8SJoseph ChenRKBIN_TOOLS=../rkbin/tools 25bc98b3c8SJoseph Chen 26fb90bd1dSJoseph Chen# User's GCC toolchain and relative path 2753ea5791SJoseph ChenADDR2LINE_ARM32=arm-linux-gnueabihf-addr2line 2853ea5791SJoseph ChenADDR2LINE_ARM64=aarch64-linux-gnu-addr2line 29fb90bd1dSJoseph ChenOBJ_ARM32=arm-linux-gnueabihf-objdump 30fb90bd1dSJoseph ChenOBJ_ARM64=aarch64-linux-gnu-objdump 31d8540eacSJoseph ChenGCC_ARM32=arm-linux-gnueabihf- 32d8540eacSJoseph ChenGCC_ARM64=aarch64-linux-gnu- 33d8540eacSJoseph ChenTOOLCHAIN_ARM32=../prebuilts/gcc/linux-x86/arm/gcc-linaro-6.3.1-2017.05-x86_64_arm-linux-gnueabihf/bin 34d8540eacSJoseph ChenTOOLCHAIN_ARM64=../prebuilts/gcc/linux-x86/aarch64/gcc-linaro-6.3.1-2017.05-x86_64_aarch64-linux-gnu/bin 35fb90bd1dSJoseph Chen 36fb90bd1dSJoseph Chen########################################### User not touch ############################################# 3723ba6841SJoseph ChenBIN_PATH_FIXUP="--replace tools/rk_tools/ ./" 3823ba6841SJoseph ChenRKTOOLS=./tools 3923ba6841SJoseph Chen 40de440615SJoseph Chen# Declare global INI file searching index name for every chip, update in select_chip_info() 41d443b7d5SJoseph ChenRKCHIP= 42de440615SJoseph ChenRKCHIP_LABEL= 43de440615SJoseph ChenRKCHIP_LOADER= 44de440615SJoseph ChenRKCHIP_TRUST= 45d443b7d5SJoseph Chen 4623ba6841SJoseph Chen# Declare rkbin repository path, updated in prepare() 47fb90bd1dSJoseph ChenRKBIN= 48fb90bd1dSJoseph Chen 49fb90bd1dSJoseph Chen# Declare global toolchain path for CROSS_COMPILE, updated in select_toolchain() 50fb90bd1dSJoseph ChenTOOLCHAIN_GCC= 51fb90bd1dSJoseph ChenTOOLCHAIN_OBJDUMP= 5253ea5791SJoseph ChenTOOLCHAIN_ADDR2LINE= 53fb90bd1dSJoseph Chen 54fb90bd1dSJoseph Chen# Declare global default output dir and cmd, update in prepare() 55b6255198SJoseph ChenOUTDIR=$2 56fb90bd1dSJoseph ChenOUTOPT= 57bc98b3c8SJoseph Chen 5841cf5e5aSJoseph Chen# Declare global plaform configure, updated in fixup_platform_configure() 5941cf5e5aSJoseph ChenPLATFORM_RSA= 6041cf5e5aSJoseph ChenPLATFORM_SHA= 6141cf5e5aSJoseph ChenPLATFORM_UBOOT_IMG_SIZE= 6241cf5e5aSJoseph ChenPLATFORM_TRUST_IMG_SIZE= 6341cf5e5aSJoseph ChenPLATFORM_AARCH32= 64fb90bd1dSJoseph Chen######################################################################################################### 65b6255198SJoseph Chenhelp() 66b6255198SJoseph Chen{ 67b6255198SJoseph Chen echo 686a764259SJoseph Chen echo "Usage:" 696a764259SJoseph Chen echo " ./make.sh [board|subcmd] [O=<dir>]" 706a764259SJoseph Chen echo 716a764259SJoseph Chen echo " - board: board name of defconfig" 726a764259SJoseph Chen echo " - subcmd: loader|loader-all|trust|uboot|elf|map|sym|<addr>|" 736a764259SJoseph Chen echo " - O=<dir>: assigned output directory" 74b6255198SJoseph Chen echo 75b6255198SJoseph Chen echo "Example:" 76b6255198SJoseph Chen echo 776a764259SJoseph Chen echo "1. Build board:" 78b6255198SJoseph Chen echo " ./make.sh evb-rk3399 ---- build for evb-rk3399_defconfig" 79b6255198SJoseph Chen echo " ./make.sh evb-rk3399 O=rockdev ---- build for evb-rk3399_defconfig with output dir "./rockdev"" 80b6255198SJoseph Chen echo " ./make.sh firefly-rk3288 ---- build for firefly-rk3288_defconfig" 81b6255198SJoseph Chen echo " ./make.sh ---- build with exist .config" 82b6255198SJoseph Chen echo 83b6255198SJoseph Chen echo " After build, images of uboot, loader and trust are all generated." 84b6255198SJoseph Chen echo 856a764259SJoseph Chen echo "2. Pack helper:" 866a764259SJoseph Chen echo " ./make.sh trust --- pack trust.img" 876a764259SJoseph Chen echo " ./make.sh uboot --- pack uboot.img" 886a764259SJoseph Chen echo " ./make.sh loader --- pack loader bin" 896a764259SJoseph Chen echo " ./make.sh loader-all --- pack loader bin (all supported loaders)" 90b6255198SJoseph Chen echo 91b6255198SJoseph Chen echo "3. Debug helper:" 92b6255198SJoseph Chen echo " ./make.sh elf --- dump elf file with -D(default)" 93b6255198SJoseph Chen echo " ./make.sh elf-S --- dump elf file with -S" 946a764259SJoseph Chen echo " ./make.sh elf-d --- dump elf file with -d" 956a764259SJoseph Chen echo " ./make.sh <addr> --- dump function symbol and code position of address" 96b6255198SJoseph Chen echo " ./make.sh map --- cat u-boot.map" 97b6255198SJoseph Chen echo " ./make.sh sym --- cat u-boot.sym" 98b6255198SJoseph Chen} 9941cf5e5aSJoseph Chen 100cd7ae718SJoseph Chenprepare() 101cd7ae718SJoseph Chen{ 102b6255198SJoseph Chen local absolute_path cmd dir count 10330b04afcSJoseph Chen 10453ea5791SJoseph Chen # Parse output directory 'O=<dir>' 105b6255198SJoseph Chen cmd=${OUTDIR%=*} 10630b04afcSJoseph Chen if [ "${cmd}" = 'O' ]; then 107b6255198SJoseph Chen OUTDIR=${OUTDIR#*=} 10830b04afcSJoseph Chen OUTOPT=O=${OUTDIR} 10930b04afcSJoseph Chen else 110b6255198SJoseph Chen case $BOARD in 11153ea5791SJoseph Chen # Parse from exit .config 112*1b6c85a0SJoseph Chen ''|elf*|loader*|debug*|trust|uboot|map|sym) 113b6255198SJoseph Chen count=`find -name .config | wc -l` 114b6255198SJoseph Chen dir=`find -name .config` 11553ea5791SJoseph Chen # Good, find only one .config 116b6255198SJoseph Chen if [ $count -eq 1 ]; then 117b6255198SJoseph Chen dir=${dir%/*} 118b6255198SJoseph Chen OUTDIR=${dir#*/} 11953ea5791SJoseph Chen # Set OUTOPT if not current directory 120b6255198SJoseph Chen if [ $OUTDIR != '.' ]; then 121b6255198SJoseph Chen OUTOPT=O=${OUTDIR} 122b6255198SJoseph Chen fi 123b6255198SJoseph Chen elif [ $count -eq 0 ]; then 124b6255198SJoseph Chen echo 125b6255198SJoseph Chen echo "Build failed, Can't find .config" 126b6255198SJoseph Chen help 127b6255198SJoseph Chen exit 1 128b6255198SJoseph Chen else 129b6255198SJoseph Chen echo 130b6255198SJoseph Chen echo "Build failed, find $count '.config': " 131b6255198SJoseph Chen echo "$dir" 132b6255198SJoseph Chen echo "Please leave only one of them" 133b6255198SJoseph Chen exit 1 134b6255198SJoseph Chen fi 135b6255198SJoseph Chen ;; 136b6255198SJoseph Chen 137b6255198SJoseph Chen *) 13830b04afcSJoseph Chen OUTDIR=. 139b6255198SJoseph Chen ;; 140b6255198SJoseph Chen esac 14130b04afcSJoseph Chen fi 142cd7ae718SJoseph Chen 143b6255198SJoseph Chen # Parse help and make defconfig 144b6255198SJoseph Chen case $BOARD in 14553ea5791SJoseph Chen #Help 146b6255198SJoseph Chen --help|-help|help|--h|-h) 147b6255198SJoseph Chen help 148b6255198SJoseph Chen exit 0 149b6255198SJoseph Chen ;; 15053ea5791SJoseph Chen 15153ea5791SJoseph Chen #Subcmd 152*1b6c85a0SJoseph Chen ''|elf*|loader*|debug*|trust|uboot|map|sym) 153b6255198SJoseph Chen ;; 154b6255198SJoseph Chen 155b6255198SJoseph Chen *) 15653ea5791SJoseph Chen #Func address is valid ? 1577070f875SJoseph Chen if [ -z $(echo ${FUNCADDR} | sed 's/[0-9,a-f,A-F,x,X]//g') ]; then 15853ea5791SJoseph Chen return 15953ea5791SJoseph Chen elif [ ! -f configs/${BOARD}_defconfig ]; then 16030b04afcSJoseph Chen echo 161cd7ae718SJoseph Chen echo "Can't find: configs/${BOARD}_defconfig" 1627c19369dSJoseph Chen echo 16330b04afcSJoseph Chen echo "******** Rockchip Support List *************" 16430b04afcSJoseph Chen echo "${SUPPORT_LIST}" 1657c19369dSJoseph Chen echo "********************************************" 1667c19369dSJoseph Chen echo 167cd7ae718SJoseph Chen exit 1 168b6255198SJoseph Chen else 169b6255198SJoseph Chen echo "make for ${BOARD}_defconfig by -j${JOB}" 170b6255198SJoseph Chen make ${BOARD}_defconfig ${OUTOPT} 171cd7ae718SJoseph Chen fi 172b6255198SJoseph Chen ;; 173b6255198SJoseph Chen esac 174cd7ae718SJoseph Chen 17523ba6841SJoseph Chen # Initialize RKBIN 176bc98b3c8SJoseph Chen if [ -d ${RKBIN_TOOLS} ]; then 177bc98b3c8SJoseph Chen absolute_path=$(cd `dirname ${RKBIN_TOOLS}`; pwd) 178bc98b3c8SJoseph Chen RKBIN=${absolute_path} 179cd7ae718SJoseph Chen else 180cd7ae718SJoseph Chen echo 181fb90bd1dSJoseph Chen echo "Can't find '../rkbin/' repository, please download it before pack image!" 182cd7ae718SJoseph Chen echo "How to obtain? 3 ways:" 183fb90bd1dSJoseph Chen echo " 1. Login your Rockchip gerrit account: \"Projects\" -> \"List\" -> search \"rk/rkbin\" repository" 184fb90bd1dSJoseph Chen echo " 2. Github repository: https://github.com/rockchip-linux/rkbin" 185fb90bd1dSJoseph Chen echo " 3. Download full release SDK repository" 186cd7ae718SJoseph Chen exit 1 187cd7ae718SJoseph Chen fi 18830b04afcSJoseph Chen} 1897c2526e9SJoseph Chen 19027a50c86SAndy Yanselect_toolchain() 19127a50c86SAndy Yan{ 192bc98b3c8SJoseph Chen local absolute_path 193bc98b3c8SJoseph Chen 194366bd23fSJoseph Chen if grep -q '^CONFIG_ARM64=y' ${OUTDIR}/.config ; then 195bc98b3c8SJoseph Chen if [ -d ${TOOLCHAIN_ARM64} ]; then 196bc98b3c8SJoseph Chen absolute_path=$(cd `dirname ${TOOLCHAIN_ARM64}`; pwd) 197bc98b3c8SJoseph Chen TOOLCHAIN_GCC=${absolute_path}/bin/${GCC_ARM64} 1980ff0e214SJoseph Chen TOOLCHAIN_OBJDUMP=${absolute_path}/bin/${OBJ_ARM64} 19953ea5791SJoseph Chen TOOLCHAIN_ADDR2LINE=${absolute_path}/bin/${ADDR2LINE_ARM64} 200bc98b3c8SJoseph Chen else 201366bd23fSJoseph Chen echo "Can't find toolchain: ${TOOLCHAIN_ARM64}" 202bc98b3c8SJoseph Chen exit 1 20327a50c86SAndy Yan fi 20427a50c86SAndy Yan else 205bc98b3c8SJoseph Chen if [ -d ${TOOLCHAIN_ARM32} ]; then 206bc98b3c8SJoseph Chen absolute_path=$(cd `dirname ${TOOLCHAIN_ARM32}`; pwd) 207bc98b3c8SJoseph Chen TOOLCHAIN_GCC=${absolute_path}/bin/${GCC_ARM32} 2080ff0e214SJoseph Chen TOOLCHAIN_OBJDUMP=${absolute_path}/bin/${OBJ_ARM32} 20953ea5791SJoseph Chen TOOLCHAIN_ADDR2LINE=${absolute_path}/bin/${ADDR2LINE_ARM32} 210bc98b3c8SJoseph Chen else 211366bd23fSJoseph Chen echo "Can't find toolchain: ${TOOLCHAIN_ARM32}" 212bc98b3c8SJoseph Chen exit 1 21327a50c86SAndy Yan fi 21427a50c86SAndy Yan fi 215bc98b3c8SJoseph Chen 21653ea5791SJoseph Chen # echo "toolchain: ${TOOLCHAIN_GCC}" 217bc98b3c8SJoseph Chen} 218bc98b3c8SJoseph Chen 2190ff0e214SJoseph Chensub_commands() 2200ff0e214SJoseph Chen{ 2215c75ab41SJoseph Chen local cmd=${SUBCMD%-*} opt=${SUBCMD#*-} 2220ff0e214SJoseph Chen 223b6255198SJoseph Chen case $cmd in 224b6255198SJoseph Chen elf) 225366bd23fSJoseph Chen if [ ! -f ${OUTDIR}/u-boot ]; then 226366bd23fSJoseph Chen echo "Can't find elf file: ${OUTDIR}/u-boot" 2270ff0e214SJoseph Chen exit 1 2280ff0e214SJoseph Chen else 229b6255198SJoseph Chen # default 'cmd' without option, use '-D' 2305c75ab41SJoseph Chen if [ "${cmd}" = 'elf' -a "${opt}" = 'elf' ]; then 2315c75ab41SJoseph Chen opt=D 2320ff0e214SJoseph Chen fi 2335c75ab41SJoseph Chen ${TOOLCHAIN_OBJDUMP} -${opt} ${OUTDIR}/u-boot | less 23407de173aSJoseph Chen exit 0 23507de173aSJoseph Chen fi 236b6255198SJoseph Chen ;; 237b6255198SJoseph Chen 238*1b6c85a0SJoseph Chen debug) 239*1b6c85a0SJoseph Chen if [ "${cmd}" = 'debug' -a "${opt}" = 'debug' ]; then 240*1b6c85a0SJoseph Chen echo 241*1b6c85a0SJoseph Chen echo "The commands will modify .config and files, and can't auto restore changes!" 242*1b6c85a0SJoseph Chen echo "debug-N, the N:" 243*1b6c85a0SJoseph Chen echo " 1. lib/initcall.c debug() -> printf()" 244*1b6c85a0SJoseph Chen echo " 2. common/board_r.c and common/board_f.c debug() -> printf()" 245*1b6c85a0SJoseph Chen echo " 3. global #define DEBUG" 246*1b6c85a0SJoseph Chen echo " 4. enable CONFIG_ROCKCHIP_DEBUGGER" 247*1b6c85a0SJoseph Chen echo " 5. enable CONFIG_ROCKCHIP_CRC" 248*1b6c85a0SJoseph Chen echo " 6. enable CONFIG_BOOTSTAGE_PRINTF_TIMESTAMP" 249*1b6c85a0SJoseph Chen echo " 7. enable CONFIG_ROCKCHIP_CRASH_DUMP" 250*1b6c85a0SJoseph Chen echo " 8. set CONFIG_BOOTDELAY=5" 251*1b6c85a0SJoseph Chen echo 252*1b6c85a0SJoseph Chen echo "Enabled: " 253*1b6c85a0SJoseph Chen grep '^CONFIG_ROCKCHIP_DEBUGGER=y' ${OUTDIR}/.config > /dev/null \ 254*1b6c85a0SJoseph Chen && echo " CONFIG_ROCKCHIP_DEBUGGER" 255*1b6c85a0SJoseph Chen grep '^CONFIG_ROCKCHIP_CRC=y' ${OUTDIR}/.config > /dev/null \ 256*1b6c85a0SJoseph Chen && echo " CONFIG_ROCKCHIP_CRC" 257*1b6c85a0SJoseph Chen grep '^CONFIG_BOOTSTAGE_PRINTF_TIMESTAMP=y' ${OUTDIR}/.config > /dev/null \ 258*1b6c85a0SJoseph Chen && echo " CONFIG_BOOTSTAGE_PRINTF_TIMESTAMP" 259*1b6c85a0SJoseph Chen grep '^CONFIG_ROCKCHIP_CRASH_DUMP=y' ${OUTDIR}/.config > /dev/null \ 260*1b6c85a0SJoseph Chen && echo " CONFIG_ROCKCHIP_CRASH_DUMP" 261*1b6c85a0SJoseph Chen 262*1b6c85a0SJoseph Chen elif [ "${opt}" = '1' ]; then 263*1b6c85a0SJoseph Chen sed -i 's/\<debug\>/printf/g' lib/initcall.c 264*1b6c85a0SJoseph Chen echo "DEBUG [1]: lib/initcall.c debug() -> printf()" 265*1b6c85a0SJoseph Chen elif [ "${opt}" = '2' ]; then 266*1b6c85a0SJoseph Chen sed -i 's/\<debug\>/printf/g' ./common/board_f.c 267*1b6c85a0SJoseph Chen sed -i 's/\<debug\>/printf/g' ./common/board_r.c 268*1b6c85a0SJoseph Chen echo "DEBUG [2]: common/board_r.c and common/board_f.c debug() -> printf()" 269*1b6c85a0SJoseph Chen elif [ "${opt}" = '3' ]; then 270*1b6c85a0SJoseph Chen sed -i '$i \#define DEBUG\' include/configs/rockchip-common.h 271*1b6c85a0SJoseph Chen echo "DEBUG [3]: global #define DEBUG" 272*1b6c85a0SJoseph Chen elif [ "${opt}" = '4' ]; then 273*1b6c85a0SJoseph Chen sed -i 's/\# CONFIG_ROCKCHIP_DEBUGGER is not set/CONFIG_ROCKCHIP_DEBUGGER=y/g' ${OUTDIR}/.config 274*1b6c85a0SJoseph Chen echo "DEBUG [4]: CONFIG_ROCKCHIP_DEBUGGER is enabled" 275*1b6c85a0SJoseph Chen elif [ "${opt}" = '5' ]; then 276*1b6c85a0SJoseph Chen sed -i 's/\# CONFIG_ROCKCHIP_CRC is not set/CONFIG_ROCKCHIP_CRC=y/g' ${OUTDIR}/.config 277*1b6c85a0SJoseph Chen echo "DEBUG [5]: CONFIG_ROCKCHIP_CRC is enabled" 278*1b6c85a0SJoseph Chen elif [ "${opt}" = '6' ]; then 279*1b6c85a0SJoseph Chen sed -i 's/\# CONFIG_BOOTSTAGE_PRINTF_TIMESTAMP is not set/CONFIG_BOOTSTAGE_PRINTF_TIMESTAMP=y/g' ${OUTDIR}/.config 280*1b6c85a0SJoseph Chen echo "DEBUG [6]: CONFIG_BOOTSTAGE_PRINTF_TIMESTAMP is enabled" 281*1b6c85a0SJoseph Chen elif [ "${opt}" = '7' ]; then 282*1b6c85a0SJoseph Chen sed -i 's/\# CONFIG_ROCKCHIP_CRASH_DUMP is not set/CONFIG_ROCKCHIP_CRASH_DUMP=y/g' ${OUTDIR}/.config 283*1b6c85a0SJoseph Chen echo "DEBUG [7]: CONFIG_ROCKCHIP_CRASH_DUMP is enabled" 284*1b6c85a0SJoseph Chen elif [ "${opt}" = '8' ]; then 285*1b6c85a0SJoseph Chen sed -i 's/^CONFIG_BOOTDELAY=0/CONFIG_BOOTDELAY=5/g' ${OUTDIR}/.config 286*1b6c85a0SJoseph Chen echo "DEBUG [8]: CONFIG_BOOTDELAY is 5s" 287*1b6c85a0SJoseph Chen fi 288*1b6c85a0SJoseph Chen echo 289*1b6c85a0SJoseph Chen exit 0 290*1b6c85a0SJoseph Chen ;; 291*1b6c85a0SJoseph Chen 292b6255198SJoseph Chen map) 293b6255198SJoseph Chen cat ${OUTDIR}/u-boot.map | less 294b6255198SJoseph Chen exit 0 295b6255198SJoseph Chen ;; 296b6255198SJoseph Chen 297b6255198SJoseph Chen sym) 298b6255198SJoseph Chen cat ${OUTDIR}/u-boot.sym | less 299b6255198SJoseph Chen exit 0 300b6255198SJoseph Chen ;; 301b6255198SJoseph Chen 302b6255198SJoseph Chen trust) 303a43a18b2SJoseph Chen pack_trust_image 304a43a18b2SJoseph Chen exit 0 305b6255198SJoseph Chen ;; 306b6255198SJoseph Chen 307b6255198SJoseph Chen loader) 3085c75ab41SJoseph Chen pack_loader_image ${opt} 309a43a18b2SJoseph Chen exit 0 310b6255198SJoseph Chen ;; 311b6255198SJoseph Chen 312b6255198SJoseph Chen uboot) 313fb90bd1dSJoseph Chen pack_uboot_image 314fb90bd1dSJoseph Chen exit 0 315b6255198SJoseph Chen ;; 316b6255198SJoseph Chen 317b6255198SJoseph Chen *) 31853ea5791SJoseph Chen # Search function and code position of address 3197070f875SJoseph Chen if [ -z $(echo ${FUNCADDR} | sed 's/[0-9,a-f,A-F,x,X]//g') ] && [ ${FUNCADDR} ]; then 3207070f875SJoseph Chen # With prefix: '0x' or '0X' 3217070f875SJoseph Chen if [ `echo ${FUNCADDR} | sed -n "/0[x,X]/p" | wc -l` -ne 0 ]; then 3227070f875SJoseph Chen FUNCADDR=`echo $FUNCADDR | awk '{ print strtonum($0) }'` 3237070f875SJoseph Chen FUNCADDR=`echo "obase=16;${FUNCADDR}"|bc |tr '[A-Z]' '[a-z]'` 3247070f875SJoseph Chen fi 3257070f875SJoseph Chen 32653ea5791SJoseph Chen echo 32753ea5791SJoseph Chen sed -n "/${FUNCADDR}/p" ${OUTDIR}/u-boot.sym 32853ea5791SJoseph Chen ${TOOLCHAIN_ADDR2LINE} -e ${OUTDIR}/u-boot ${FUNCADDR} 32953ea5791SJoseph Chen exit 0 33053ea5791SJoseph Chen fi 331b6255198SJoseph Chen ;; 332b6255198SJoseph Chen esac 3330ff0e214SJoseph Chen} 3340ff0e214SJoseph Chen 335de440615SJoseph Chen# We select chip info to do: 336de440615SJoseph Chen# 1. RKCHIP: fixup platform configure 337de440615SJoseph Chen# 2. RKCHIP_LOADER: search ini file to pack loader 338de440615SJoseph Chen# 3. RKCHIP_TRUST: search ini file to pack trust 339de440615SJoseph Chen# 4. RKCHIP_LABEL: show build message 340de440615SJoseph Chen# 341de440615SJoseph Chen# We read chip info from .config and 'RKCHIP_INI_DESC' 342de440615SJoseph Chenselect_chip_info() 343bc98b3c8SJoseph Chen{ 344de440615SJoseph Chen local target_board item value 345d443b7d5SJoseph Chen 346de440615SJoseph Chen # Read RKCHIP firstly from .config 347596700d7SShunqian Zheng # The regular expression that matching: 348596700d7SShunqian Zheng # - PX30, PX3SE 349596700d7SShunqian Zheng # - RK????, RK????X 350596700d7SShunqian Zheng # - RV???? 351596700d7SShunqian Zheng local chip_reg='^CONFIG_ROCKCHIP_[R,P][X,V,K][0-9ESX]{2,5}' 352596700d7SShunqian Zheng count=`egrep -c ${chip_reg} ${OUTDIR}/.config` 353596700d7SShunqian Zheng # Obtain the matching only 354596700d7SShunqian Zheng RKCHIP=`egrep -o ${chip_reg} ${OUTDIR}/.config` 355d443b7d5SJoseph Chen 356d443b7d5SJoseph Chen if [ $count -eq 1 ]; then 357d443b7d5SJoseph Chen RKCHIP=${RKCHIP##*_} 358f0aa0521SJoseph Chen grep '^CONFIG_ROCKCHIP_RK3368=y' ${OUTDIR}/.config >/dev/null \ 359f0aa0521SJoseph Chen && RKCHIP=RK3368H 360d443b7d5SJoseph Chen elif [ $count -gt 1 ]; then 361596700d7SShunqian Zheng # Grep the RK CHIP variant 362596700d7SShunqian Zheng grep '^CONFIG_ROCKCHIP_PX3SE=y' ${OUTDIR}/.config > /dev/null \ 363596700d7SShunqian Zheng && RKCHIP=PX3SE 364596700d7SShunqian Zheng grep '^CONFIG_ROCKCHIP_RK3126=y' ${OUTDIR}/.config >/dev/null \ 365596700d7SShunqian Zheng && RKCHIP=RK3126 366596700d7SShunqian Zheng grep '^CONFIG_ROCKCHIP_RK3326=y' ${OUTDIR}/.config >/dev/null \ 367596700d7SShunqian Zheng && RKCHIP=RK3326 368596700d7SShunqian Zheng grep '^CONFIG_ROCKCHIP_RK3128X=y' ${OUTDIR}/.config >/dev/null \ 369596700d7SShunqian Zheng && RKCHIP=RK3128X 370d443b7d5SJoseph Chen else 371d443b7d5SJoseph Chen echo "Can't get Rockchip SoC definition in .config" 372d443b7d5SJoseph Chen exit 1 373bc98b3c8SJoseph Chen fi 37441cf5e5aSJoseph Chen 375de440615SJoseph Chen # Default use RKCHIP 376de440615SJoseph Chen RKCHIP_LABEL=${RKCHIP} 377de440615SJoseph Chen RKCHIP_LOADER=${RKCHIP} 378de440615SJoseph Chen RKCHIP_TRUST=${RKCHIP} 379de440615SJoseph Chen 380de440615SJoseph Chen # Read from RKCHIP_INI_DESC 381de440615SJoseph Chen for item in "${RKCHIP_INI_DESC[@]}" 382de440615SJoseph Chen do 383de440615SJoseph Chen target_board=`echo $item | awk '{ print $1 }'` 384de440615SJoseph Chen if grep -q "^${target_board}=y" ${OUTDIR}/.config ; then 385de440615SJoseph Chen value=`echo $item | awk '{ print $2 }'` 386de440615SJoseph Chen if [ "$value" != "NA" ]; then 387de440615SJoseph Chen RKCHIP_LABEL=${value}; 388de440615SJoseph Chen fi 389de440615SJoseph Chen value=`echo $item | awk '{ print $3 }'` 390de440615SJoseph Chen if [ "$value" != "NA" ]; then 391de440615SJoseph Chen RKCHIP_LOADER=${value}; 392de440615SJoseph Chen fi 393de440615SJoseph Chen value=`echo $item | awk '{ print $4 }'` 394de440615SJoseph Chen if [ "$value" != "NA" ]; then 395de440615SJoseph Chen RKCHIP_TRUST=${value}; 396de440615SJoseph Chen fi 397de440615SJoseph Chen fi 398de440615SJoseph Chen done 399de440615SJoseph Chen} 400de440615SJoseph Chen 401de440615SJoseph Chen# Fixup platform special configure 402de440615SJoseph Chen# 1. fixup pack mode; 403de440615SJoseph Chen# 2. fixup image size 404de440615SJoseph Chen# 3. fixup ARM64 cpu boot with AArch32 405de440615SJoseph Chenfixup_platform_configure() 406de440615SJoseph Chen{ 407de440615SJoseph Chen local count plat 408de440615SJoseph Chen 409de440615SJoseph Chen# <*> Fixup rsa/sha pack mode for platforms 41041cf5e5aSJoseph Chen # RK3308/PX30/RK3326 use RSA-PKCS1 V2.1, it's pack magic is "3" 41141cf5e5aSJoseph Chen if [ $RKCHIP = "PX30" -o $RKCHIP = "RK3326" -o $RKCHIP = "RK3308" ]; then 41241cf5e5aSJoseph Chen PLATFORM_RSA="--rsa 3" 41341cf5e5aSJoseph Chen # RK3368 use rk big endian SHA256, it's pack magic is "2" 41441cf5e5aSJoseph Chen elif [ $RKCHIP = "RK3368" ]; then 41541cf5e5aSJoseph Chen PLATFORM_SHA="--sha 2" 41641cf5e5aSJoseph Chen # other platforms use default configure 41741cf5e5aSJoseph Chen fi 41841cf5e5aSJoseph Chen 419de440615SJoseph Chen# <*> Fixup images size pack for platforms 42041cf5e5aSJoseph Chen if [ $RKCHIP = "RK3308" ]; then 42141cf5e5aSJoseph Chen if grep -q '^CONFIG_ARM64_BOOT_AARCH32=y' ${OUTDIR}/.config ; then 42241cf5e5aSJoseph Chen PLATFORM_UBOOT_IMG_SIZE="--size 512 2" 42341cf5e5aSJoseph Chen PLATFORM_TRUST_IMG_SIZE="--size 512 2" 42441cf5e5aSJoseph Chen else 42541cf5e5aSJoseph Chen PLATFORM_UBOOT_IMG_SIZE="--size 1024 2" 42641cf5e5aSJoseph Chen PLATFORM_TRUST_IMG_SIZE="--size 1024 2" 42741cf5e5aSJoseph Chen fi 42841cf5e5aSJoseph Chen fi 42941cf5e5aSJoseph Chen 430de440615SJoseph Chen# <*> Fixup PLATFORM_AARCH32 for ARM64 cpu platforms 43141cf5e5aSJoseph Chen if [ $RKCHIP = "RK3308" ]; then 43241cf5e5aSJoseph Chen if grep -q '^CONFIG_ARM64_BOOT_AARCH32=y' ${OUTDIR}/.config ; then 43341cf5e5aSJoseph Chen PLATFORM_AARCH32="AARCH32" 43441cf5e5aSJoseph Chen fi 43541cf5e5aSJoseph Chen fi 43627a50c86SAndy Yan} 437de9a6cd2SJoseph Chen 438cd7ae718SJoseph Chenpack_uboot_image() 439de9a6cd2SJoseph Chen{ 440cd7ae718SJoseph Chen local UBOOT_LOAD_ADDR 441de9a6cd2SJoseph Chen 442366bd23fSJoseph Chen UBOOT_LOAD_ADDR=`sed -n "/CONFIG_SYS_TEXT_BASE=/s/CONFIG_SYS_TEXT_BASE=//p" ${OUTDIR}/include/autoconf.mk|tr -d '\r'` 443fb90bd1dSJoseph Chen ${RKTOOLS}/loaderimage --pack --uboot ${OUTDIR}/u-boot.bin uboot.img ${UBOOT_LOAD_ADDR} ${PLATFORM_UBOOT_IMG_SIZE} 4447c19369dSJoseph Chen 445fb90bd1dSJoseph Chen # Delete u-boot.img and u-boot-dtb.img, which makes users not be confused with final uboot.img 4467c19369dSJoseph Chen if [ -f ${OUTDIR}/u-boot.img ]; then 4477c19369dSJoseph Chen rm ${OUTDIR}/u-boot.img 4487c19369dSJoseph Chen fi 4497c19369dSJoseph Chen 4507c19369dSJoseph Chen if [ -f ${OUTDIR}/u-boot-dtb.img ]; then 4517c19369dSJoseph Chen rm ${OUTDIR}/u-boot-dtb.img 4527c19369dSJoseph Chen fi 4537c19369dSJoseph Chen 454366bd23fSJoseph Chen echo "pack uboot okay! Input: ${OUTDIR}/u-boot.bin" 455de9a6cd2SJoseph Chen} 456de9a6cd2SJoseph Chen 457cd7ae718SJoseph Chenpack_loader_image() 458cd7ae718SJoseph Chen{ 4595c75ab41SJoseph Chen local mode=$1 files ini 460d9d90a73SJoseph Chen 461de440615SJoseph Chen if [ ! -f ${RKBIN}/RKBOOT/${RKCHIP_LOADER}MINIALL.ini ]; then 462de440615SJoseph Chen echo "pack loader failed! Can't find: ${RKBIN}/RKBOOT/${RKCHIP_LOADER}MINIALL.ini" 46351441a28SJoseph Chen return 46451441a28SJoseph Chen fi 46551441a28SJoseph Chen 466cd7ae718SJoseph Chen cd ${RKBIN} 4675c75ab41SJoseph Chen 4685c75ab41SJoseph Chen if [ "${mode}" = 'all' ]; then 469de440615SJoseph Chen files=`ls ${RKBIN}/RKBOOT/${RKCHIP_LOADER}MINIALL*.ini` 470d9d90a73SJoseph Chen for ini in $files 471d9d90a73SJoseph Chen do 472d9d90a73SJoseph Chen if [ -f "$ini" ]; then 47323ba6841SJoseph Chen ${RKTOOLS}/boot_merger ${BIN_PATH_FIXUP} $ini 474d9d90a73SJoseph Chen echo "pack loader okay! Input: $ini" 475d9d90a73SJoseph Chen fi 476d9d90a73SJoseph Chen done 4775c75ab41SJoseph Chen else 47823ba6841SJoseph Chen ${RKTOOLS}/boot_merger ${BIN_PATH_FIXUP} ${RKBIN}/RKBOOT/${RKCHIP_LOADER}MINIALL.ini 479de440615SJoseph Chen echo "pack loader okay! Input: ${RKBIN}/RKBOOT/${RKCHIP_LOADER}MINIALL.ini" 4805c75ab41SJoseph Chen fi 481d9d90a73SJoseph Chen 482fb90bd1dSJoseph Chen cd - && mv ${RKBIN}/*_loader_*.bin ./ 483cd7ae718SJoseph Chen} 484cd7ae718SJoseph Chen 485cd7ae718SJoseph Chenpack_trust_image() 486cd7ae718SJoseph Chen{ 48741cf5e5aSJoseph Chen local TOS TOS_TA DARM_BASE TEE_LOAD_ADDR TEE_OFFSET=0x8400000 488cd7ae718SJoseph Chen 489cd7ae718SJoseph Chen # ARM64 uses trust_merger 490fa400ae5SJoseph Chen if grep -Eq ''^CONFIG_ARM64=y'|'^CONFIG_ARM64_BOOT_AARCH32=y'' ${OUTDIR}/.config ; then 491de440615SJoseph Chen if [ ! -f ${RKBIN}/RKTRUST/${RKCHIP_TRUST}${PLATFORM_AARCH32}TRUST.ini ]; then 492de440615SJoseph Chen echo "pack trust failed! Can't find: ${RKBIN}/RKTRUST/${RKCHIP_TRUST}${PLATFORM_AARCH32}TRUST.ini" 49351441a28SJoseph Chen return 49451441a28SJoseph Chen fi 49551441a28SJoseph Chen 496cd7ae718SJoseph Chen cd ${RKBIN} 49723ba6841SJoseph Chen ${RKTOOLS}/trust_merger ${PLATFORM_SHA} ${PLATFORM_RSA} ${PLATFORM_TRUST_IMG_SIZE} ${BIN_PATH_FIXUP} ${RKBIN}/RKTRUST/${RKCHIP_TRUST}${PLATFORM_AARCH32}TRUST.ini 498e5e978b3SJoseph Chen 499fb90bd1dSJoseph Chen cd - && mv ${RKBIN}/trust.img ./trust.img 500de440615SJoseph Chen echo "pack trust okay! Input: ${RKBIN}/RKTRUST/${RKCHIP_TRUST}${PLATFORM_AARCH32}TRUST.ini" 501cd7ae718SJoseph Chen # ARM uses loaderimage 502cd7ae718SJoseph Chen else 503de440615SJoseph Chen if [ ! -f ${RKBIN}/RKTRUST/${RKCHIP_TRUST}TOS.ini ]; then 504de440615SJoseph Chen echo "pack trust failed! Can't find: ${RKBIN}/RKTRUST/${RKCHIP_TRUST}TOS.ini" 50551441a28SJoseph Chen return 50651441a28SJoseph Chen fi 50751441a28SJoseph Chen 508cd7ae718SJoseph Chen # OP-TEE is 132M(0x8400000) offset from DRAM base. 509366bd23fSJoseph Chen DARM_BASE=`sed -n "/CONFIG_SYS_SDRAM_BASE=/s/CONFIG_SYS_SDRAM_BASE=//p" ${OUTDIR}/include/autoconf.mk|tr -d '\r'` 510cd7ae718SJoseph Chen TEE_LOAD_ADDR=$((DARM_BASE+TEE_OFFSET)) 511cd7ae718SJoseph Chen 512cd7ae718SJoseph Chen # Convert Dec to Hex 513cd7ae718SJoseph Chen TEE_LOAD_ADDR=$(echo "obase=16;${TEE_LOAD_ADDR}"|bc) 514cd7ae718SJoseph Chen 5150e90839aSJoseph Chen # Parse orignal path 516de440615SJoseph Chen TOS=`sed -n "/TOS=/s/TOS=//p" ${RKBIN}/RKTRUST/${RKCHIP_TRUST}TOS.ini|tr -d '\r'` 517de440615SJoseph Chen TOS_TA=`sed -n "/TOSTA=/s/TOSTA=//p" ${RKBIN}/RKTRUST/${RKCHIP_TRUST}TOS.ini|tr -d '\r'` 518cd7ae718SJoseph Chen 5190e90839aSJoseph Chen # replace "./tools/rk_tools/" with "./" to compatible legacy ini content of rkdevelop branch 5200e90839aSJoseph Chen TOS=$(echo ${TOS} | sed "s/tools\/rk_tools\//\.\//g") 5210e90839aSJoseph Chen TOS_TA=$(echo ${TOS_TA} | sed "s/tools\/rk_tools\//\.\//g") 5220e90839aSJoseph Chen 523596700d7SShunqian Zheng if [ x$TOS_TA != x -a x$TOS != x ]; then 524fb90bd1dSJoseph Chen ${RKTOOLS}/loaderimage --pack --trustos ${RKBIN}/${TOS} ./trust.img ${TEE_LOAD_ADDR} ${PLATFORM_TRUST_IMG_SIZE} 525fb90bd1dSJoseph Chen ${RKTOOLS}/loaderimage --pack --trustos ${RKBIN}/${TOS_TA} ./trust_with_ta.img ${TEE_LOAD_ADDR} ${PLATFORM_TRUST_IMG_SIZE} 526cd7ae718SJoseph Chen echo "Both trust.img and trust_with_ta.img are ready" 527cd7ae718SJoseph Chen elif [ $TOS ]; then 528fb90bd1dSJoseph Chen ${RKTOOLS}/loaderimage --pack --trustos ${RKBIN}/${TOS} ./trust.img ${TEE_LOAD_ADDR} ${PLATFORM_TRUST_IMG_SIZE} 529cd7ae718SJoseph Chen echo "trust.img is ready" 530cd7ae718SJoseph Chen elif [ $TOS_TA ]; then 531fb90bd1dSJoseph Chen ${RKTOOLS}/loaderimage --pack --trustos ${RKBIN}/${TOS_TA} ./trust.img ${TEE_LOAD_ADDR} ${PLATFORM_TRUST_IMG_SIZE} 532cd7ae718SJoseph Chen echo "trust.img with ta is ready" 533cd7ae718SJoseph Chen else 534a64486b5SJoseph Chen echo "Can't find any tee bin" 535a64486b5SJoseph Chen exit 1 536cd7ae718SJoseph Chen fi 53751441a28SJoseph Chen 538de440615SJoseph Chen echo "pack trust okay! Input: ${RKBIN}/RKTRUST/${RKCHIP_TRUST}TOS.ini" 539cd7ae718SJoseph Chen fi 540cd7ae718SJoseph Chen} 541cd7ae718SJoseph Chen 54230b04afcSJoseph Chenfinish() 54330b04afcSJoseph Chen{ 54430b04afcSJoseph Chen echo 54530b04afcSJoseph Chen if [ "$BOARD" = '' ]; then 546de440615SJoseph Chen echo "Platform ${RKCHIP_LABEL}${PLATFORM_AARCH32} is build OK, with exist .config" 54730b04afcSJoseph Chen else 548de440615SJoseph Chen echo "Platform ${RKCHIP_LABEL}${PLATFORM_AARCH32} is build OK, with new .config(make ${BOARD}_defconfig)" 54930b04afcSJoseph Chen fi 55030b04afcSJoseph Chen} 55130b04afcSJoseph Chen 552cd7ae718SJoseph Chenprepare 5537c2526e9SJoseph Chenselect_toolchain 554de440615SJoseph Chenselect_chip_info 55541cf5e5aSJoseph Chenfixup_platform_configure 5560ff0e214SJoseph Chensub_commands 557366bd23fSJoseph Chenmake CROSS_COMPILE=${TOOLCHAIN_GCC} all --jobs=${JOB} ${OUTOPT} 558cd7ae718SJoseph Chenpack_uboot_image 559d93242f2SJoseph Chenpack_loader_image 560cd7ae718SJoseph Chenpack_trust_image 56130b04afcSJoseph Chenfinish 562