127a50c86SAndy Yan#!/bin/sh 2cd7ae718SJoseph Chenset -e 327a50c86SAndy YanBOARD=$1 40ff0e214SJoseph ChenSUBCMD=$2 580fb8d2cSShunqian ZhengRKCHIP=${BOARD##*-} 680fb8d2cSShunqian ZhengRKCHIP=$(echo ${RKCHIP} | tr '[a-z]' '[A-Z]') 727a50c86SAndy YanJOB=`sed -n "N;/processor/p" /proc/cpuinfo|wc -l` 8*fb90bd1dSJoseph ChenSUPPROT_LIST=`ls configs/*-[r,p][x,v,k][0-9][0-9]*_defconfig` 927a50c86SAndy Yan 10*fb90bd1dSJoseph Chen########################################### User can modify ############################################# 11*fb90bd1dSJoseph Chen# User's rkbin tool relative path 12bc98b3c8SJoseph ChenRKBIN_TOOLS=../rkbin/tools 13bc98b3c8SJoseph Chen 14*fb90bd1dSJoseph Chen# User's GCC toolchain and relative path 15*fb90bd1dSJoseph ChenOBJ_ARM32=arm-linux-gnueabihf-objdump 16*fb90bd1dSJoseph ChenOBJ_ARM64=aarch64-linux-gnu-objdump 17d8540eacSJoseph ChenGCC_ARM32=arm-linux-gnueabihf- 18d8540eacSJoseph ChenGCC_ARM64=aarch64-linux-gnu- 19d8540eacSJoseph ChenTOOLCHAIN_ARM32=../prebuilts/gcc/linux-x86/arm/gcc-linaro-6.3.1-2017.05-x86_64_arm-linux-gnueabihf/bin 20d8540eacSJoseph ChenTOOLCHAIN_ARM64=../prebuilts/gcc/linux-x86/aarch64/gcc-linaro-6.3.1-2017.05-x86_64_aarch64-linux-gnu/bin 21*fb90bd1dSJoseph Chen 22*fb90bd1dSJoseph Chen########################################### User not touch ############################################# 23*fb90bd1dSJoseph Chen# Declare global rkbin RKTOOLS and rkbin repository path, updated in prepare() 24*fb90bd1dSJoseph ChenRKTOOLS= 25*fb90bd1dSJoseph ChenRKBIN= 26*fb90bd1dSJoseph Chen 27*fb90bd1dSJoseph Chen# Declare global toolchain path for CROSS_COMPILE, updated in select_toolchain() 28*fb90bd1dSJoseph ChenTOOLCHAIN_GCC= 29*fb90bd1dSJoseph ChenTOOLCHAIN_OBJDUMP= 30*fb90bd1dSJoseph Chen 31*fb90bd1dSJoseph Chen# Declare global default output dir and cmd, update in prepare() 32*fb90bd1dSJoseph ChenOUTDIR= 33*fb90bd1dSJoseph ChenOUTOPT= 34bc98b3c8SJoseph Chen 3541cf5e5aSJoseph Chen# Declare global plaform configure, updated in fixup_platform_configure() 3641cf5e5aSJoseph ChenPLATFORM_RSA= 3741cf5e5aSJoseph ChenPLATFORM_SHA= 3841cf5e5aSJoseph ChenPLATFORM_UBOOT_IMG_SIZE= 3941cf5e5aSJoseph ChenPLATFORM_TRUST_IMG_SIZE= 4041cf5e5aSJoseph ChenPLATFORM_AARCH32= 41*fb90bd1dSJoseph Chen######################################################################################################### 4241cf5e5aSJoseph Chen 43cd7ae718SJoseph Chenprepare() 44cd7ae718SJoseph Chen{ 45366bd23fSJoseph Chen local absolute_path cmd 46cd7ae718SJoseph Chen 47*fb90bd1dSJoseph Chen # Check invalid args and help 48bc98b3c8SJoseph Chen if [ "$BOARD" = '--help' -o "$BOARD" = '-h' -o "$BOARD" = '--h' -o "$BOARD" = '' ]; then 49cd7ae718SJoseph Chen echo 50bc98b3c8SJoseph Chen echo "Usage: ./make.sh [board]" 51cd7ae718SJoseph Chen echo "Example:" 52cd7ae718SJoseph Chen echo "./make.sh evb-rk3399 ---- build for evb-rk3399_defconfig" 53cd7ae718SJoseph Chen echo "./make.sh firefly-rk3288 ---- build for firefly-rk3288_defconfig" 54cd7ae718SJoseph Chen exit 1 55cd7ae718SJoseph Chen elif [ ! -f configs/${BOARD}_defconfig ]; then 56cd7ae718SJoseph Chen echo "Can't find: configs/${BOARD}_defconfig" 577c19369dSJoseph Chen echo 587c19369dSJoseph Chen echo "*************** Support list ***************" 59*fb90bd1dSJoseph Chen echo "${SUPPROT_LIST}" 607c19369dSJoseph Chen echo "********************************************" 617c19369dSJoseph Chen echo 62cd7ae718SJoseph Chen exit 1 63cd7ae718SJoseph Chen fi 64cd7ae718SJoseph Chen 65*fb90bd1dSJoseph Chen # Initialize RKBIN and RKTOOLS 66bc98b3c8SJoseph Chen if [ -d ${RKBIN_TOOLS} ]; then 67bc98b3c8SJoseph Chen absolute_path=$(cd `dirname ${RKBIN_TOOLS}`; pwd) 68bc98b3c8SJoseph Chen RKBIN=${absolute_path} 69*fb90bd1dSJoseph Chen RKTOOLS=${absolute_path}/tools 70cd7ae718SJoseph Chen else 71cd7ae718SJoseph Chen echo 72*fb90bd1dSJoseph Chen echo "Can't find '../rkbin/' repository, please download it before pack image!" 73cd7ae718SJoseph Chen echo "How to obtain? 3 ways:" 74*fb90bd1dSJoseph Chen echo " 1. Login your Rockchip gerrit account: \"Projects\" -> \"List\" -> search \"rk/rkbin\" repository" 75*fb90bd1dSJoseph Chen echo " 2. Github repository: https://github.com/rockchip-linux/rkbin" 76*fb90bd1dSJoseph Chen echo " 3. Download full release SDK repository" 77cd7ae718SJoseph Chen exit 1 78cd7ae718SJoseph Chen fi 797c2526e9SJoseph Chen 80366bd23fSJoseph Chen # Assign output directory 81366bd23fSJoseph Chen cmd=${SUBCMD%=*} 82366bd23fSJoseph Chen if [ "${cmd}" = 'O' ]; then 83366bd23fSJoseph Chen OUTDIR=${SUBCMD#*=} 84366bd23fSJoseph Chen OUTOPT=O=${OUTDIR} 85*fb90bd1dSJoseph Chen else 86*fb90bd1dSJoseph Chen OUTDIR=. 877c2526e9SJoseph Chen fi 88cd7ae718SJoseph Chen} 89cd7ae718SJoseph Chen 9027a50c86SAndy Yanselect_toolchain() 9127a50c86SAndy Yan{ 92bc98b3c8SJoseph Chen local absolute_path 93bc98b3c8SJoseph Chen 94366bd23fSJoseph Chen if grep -q '^CONFIG_ARM64=y' ${OUTDIR}/.config ; then 95bc98b3c8SJoseph Chen if [ -d ${TOOLCHAIN_ARM64} ]; then 96bc98b3c8SJoseph Chen absolute_path=$(cd `dirname ${TOOLCHAIN_ARM64}`; pwd) 97bc98b3c8SJoseph Chen TOOLCHAIN_GCC=${absolute_path}/bin/${GCC_ARM64} 980ff0e214SJoseph Chen TOOLCHAIN_OBJDUMP=${absolute_path}/bin/${OBJ_ARM64} 99bc98b3c8SJoseph Chen else 100366bd23fSJoseph Chen echo "Can't find toolchain: ${TOOLCHAIN_ARM64}" 101bc98b3c8SJoseph Chen exit 1 10227a50c86SAndy Yan fi 10327a50c86SAndy Yan else 104bc98b3c8SJoseph Chen if [ -d ${TOOLCHAIN_ARM32} ]; then 105bc98b3c8SJoseph Chen absolute_path=$(cd `dirname ${TOOLCHAIN_ARM32}`; pwd) 106bc98b3c8SJoseph Chen TOOLCHAIN_GCC=${absolute_path}/bin/${GCC_ARM32} 1070ff0e214SJoseph Chen TOOLCHAIN_OBJDUMP=${absolute_path}/bin/${OBJ_ARM32} 108bc98b3c8SJoseph Chen else 109366bd23fSJoseph Chen echo "Can't find toolchain: ${TOOLCHAIN_ARM32}" 110bc98b3c8SJoseph Chen exit 1 11127a50c86SAndy Yan fi 11227a50c86SAndy Yan fi 113bc98b3c8SJoseph Chen 114bc98b3c8SJoseph Chen echo "toolchain: ${TOOLCHAIN_GCC}" 115bc98b3c8SJoseph Chen} 116bc98b3c8SJoseph Chen 117*fb90bd1dSJoseph Chen# Support subcmd: 118*fb90bd1dSJoseph Chen# ./make.sh evb-rk3288 elf --- dump elf file with -D(default) 119*fb90bd1dSJoseph Chen# ./make.sh evb-rk3288 elf-S --- dump elf file with -S 120*fb90bd1dSJoseph Chen# ./make.sh evb-rk3288 trust --- pack trust.img without compile u-boot 121*fb90bd1dSJoseph Chen# ./make.sh evb-rk3288 loader --- pack loader bin without compile u-boot 122*fb90bd1dSJoseph Chen# ./make.sh evb-rk3288 uboot --- pack uboot.img without compile u-boot 1230ff0e214SJoseph Chensub_commands() 1240ff0e214SJoseph Chen{ 1250ff0e214SJoseph Chen local elf=${SUBCMD%-*} opt=${SUBCMD#*-} 1260ff0e214SJoseph Chen 127366bd23fSJoseph Chen if [ "$elf" = 'elf' ]; then 128366bd23fSJoseph Chen if [ ! -f ${OUTDIR}/u-boot ]; then 129366bd23fSJoseph Chen echo "Can't find elf file: ${OUTDIR}/u-boot" 1300ff0e214SJoseph Chen exit 1 1310ff0e214SJoseph Chen else 1320ff0e214SJoseph Chen # default 'elf' without option, use '-D' 1330ff0e214SJoseph Chen if [ "${elf}" = 'elf' -a "${opt}" = 'elf' ]; then 1340ff0e214SJoseph Chen opt=D 1350ff0e214SJoseph Chen fi 1360ff0e214SJoseph Chen 137366bd23fSJoseph Chen ${TOOLCHAIN_OBJDUMP} -${opt} ${OUTDIR}/u-boot | less 13807de173aSJoseph Chen exit 0 13907de173aSJoseph Chen fi 140a43a18b2SJoseph Chen elif [ "$SUBCMD" = 'trust' ]; then 141a43a18b2SJoseph Chen pack_trust_image 142a43a18b2SJoseph Chen exit 0 143a43a18b2SJoseph Chen elif [ "$SUBCMD" = 'loader' ]; then 144a43a18b2SJoseph Chen pack_loader_image 145a43a18b2SJoseph Chen exit 0 146*fb90bd1dSJoseph Chen elif [ "$SUBCMD" = 'uboot' ]; then 147*fb90bd1dSJoseph Chen pack_uboot_image 148*fb90bd1dSJoseph Chen exit 0 1490ff0e214SJoseph Chen fi 1500ff0e214SJoseph Chen} 1510ff0e214SJoseph Chen 152*fb90bd1dSJoseph Chen# Support platform special configure 153*fb90bd1dSJoseph Chen# 1. fixup chip name; 154*fb90bd1dSJoseph Chen# 2. fixup pack mode; 155*fb90bd1dSJoseph Chen# 3. fixup image size 156*fb90bd1dSJoseph Chen# 4. fixup ARM64 cpu boot with AArch32 15741cf5e5aSJoseph Chenfixup_platform_configure() 158bc98b3c8SJoseph Chen{ 15941cf5e5aSJoseph Chen# <1> Fixup chip name for searching trust/loader ini files 16080fb8d2cSShunqian Zheng if [ "$RKCHIP" = 'RK3228' -o "$RKCHIP" = 'RK3229' ]; then 16180fb8d2cSShunqian Zheng RKCHIP=RK322X 162bc98b3c8SJoseph Chen fi 16341cf5e5aSJoseph Chen 16441cf5e5aSJoseph Chen# <2> Fixup rsa/sha pack mode for platforms 16541cf5e5aSJoseph Chen # RK3308/PX30/RK3326 use RSA-PKCS1 V2.1, it's pack magic is "3" 16641cf5e5aSJoseph Chen if [ $RKCHIP = "PX30" -o $RKCHIP = "RK3326" -o $RKCHIP = "RK3308" ]; then 16741cf5e5aSJoseph Chen PLATFORM_RSA="--rsa 3" 16841cf5e5aSJoseph Chen # RK3368 use rk big endian SHA256, it's pack magic is "2" 16941cf5e5aSJoseph Chen elif [ $RKCHIP = "RK3368" ]; then 17041cf5e5aSJoseph Chen PLATFORM_SHA="--sha 2" 17141cf5e5aSJoseph Chen # other platforms use default configure 17241cf5e5aSJoseph Chen fi 17341cf5e5aSJoseph Chen 17441cf5e5aSJoseph Chen# <3> Fixup images size pack for platforms 17541cf5e5aSJoseph Chen if [ $RKCHIP = "RK3308" ]; then 17641cf5e5aSJoseph Chen if grep -q '^CONFIG_ARM64_BOOT_AARCH32=y' ${OUTDIR}/.config ; then 17741cf5e5aSJoseph Chen PLATFORM_UBOOT_IMG_SIZE="--size 512 2" 17841cf5e5aSJoseph Chen PLATFORM_TRUST_IMG_SIZE="--size 512 2" 17941cf5e5aSJoseph Chen else 18041cf5e5aSJoseph Chen PLATFORM_UBOOT_IMG_SIZE="--size 1024 2" 18141cf5e5aSJoseph Chen PLATFORM_TRUST_IMG_SIZE="--size 1024 2" 18241cf5e5aSJoseph Chen fi 18341cf5e5aSJoseph Chen fi 18441cf5e5aSJoseph Chen 18541cf5e5aSJoseph Chen# <4> Fixup PLATFORM_AARCH32 for ARM64 cpu platforms 18641cf5e5aSJoseph Chen if [ $RKCHIP = "RK3308" ]; then 18741cf5e5aSJoseph Chen if grep -q '^CONFIG_ARM64_BOOT_AARCH32=y' ${OUTDIR}/.config ; then 18841cf5e5aSJoseph Chen PLATFORM_AARCH32="AARCH32" 18941cf5e5aSJoseph Chen fi 19041cf5e5aSJoseph Chen fi 19127a50c86SAndy Yan} 192de9a6cd2SJoseph Chen 193cd7ae718SJoseph Chenpack_uboot_image() 194de9a6cd2SJoseph Chen{ 195cd7ae718SJoseph Chen local UBOOT_LOAD_ADDR 196de9a6cd2SJoseph Chen 197366bd23fSJoseph Chen UBOOT_LOAD_ADDR=`sed -n "/CONFIG_SYS_TEXT_BASE=/s/CONFIG_SYS_TEXT_BASE=//p" ${OUTDIR}/include/autoconf.mk|tr -d '\r'` 198*fb90bd1dSJoseph Chen ${RKTOOLS}/loaderimage --pack --uboot ${OUTDIR}/u-boot.bin uboot.img ${UBOOT_LOAD_ADDR} ${PLATFORM_UBOOT_IMG_SIZE} 1997c19369dSJoseph Chen 200*fb90bd1dSJoseph Chen # Delete u-boot.img and u-boot-dtb.img, which makes users not be confused with final uboot.img 2017c19369dSJoseph Chen if [ -f ${OUTDIR}/u-boot.img ]; then 2027c19369dSJoseph Chen rm ${OUTDIR}/u-boot.img 2037c19369dSJoseph Chen fi 2047c19369dSJoseph Chen 2057c19369dSJoseph Chen if [ -f ${OUTDIR}/u-boot-dtb.img ]; then 2067c19369dSJoseph Chen rm ${OUTDIR}/u-boot-dtb.img 2077c19369dSJoseph Chen fi 2087c19369dSJoseph Chen 209366bd23fSJoseph Chen echo "pack uboot okay! Input: ${OUTDIR}/u-boot.bin" 210de9a6cd2SJoseph Chen} 211de9a6cd2SJoseph Chen 212cd7ae718SJoseph Chenpack_loader_image() 213cd7ae718SJoseph Chen{ 21480fb8d2cSShunqian Zheng if [ ! -f ${RKBIN}/RKBOOT/${RKCHIP}MINIALL.ini ]; then 21580fb8d2cSShunqian Zheng echo "pack loader failed! Can't find: ${RKBIN}/RKBOOT/${RKCHIP}MINIALL.ini" 21651441a28SJoseph Chen return 21751441a28SJoseph Chen fi 21851441a28SJoseph Chen 219cd7ae718SJoseph Chen cd ${RKBIN} 220*fb90bd1dSJoseph Chen ${RKTOOLS}/boot_merger --replace tools/rk_tools/ ./ ${RKBIN}/RKBOOT/${RKCHIP}MINIALL.ini 221*fb90bd1dSJoseph Chen cd - && mv ${RKBIN}/*_loader_*.bin ./ 22280fb8d2cSShunqian Zheng echo "pack loader okay! Input: ${RKBIN}/RKBOOT/${RKCHIP}MINIALL.ini" 223cd7ae718SJoseph Chen} 224cd7ae718SJoseph Chen 225cd7ae718SJoseph Chenpack_trust_image() 226cd7ae718SJoseph Chen{ 22741cf5e5aSJoseph Chen local TOS TOS_TA DARM_BASE TEE_LOAD_ADDR TEE_OFFSET=0x8400000 228cd7ae718SJoseph Chen 229cd7ae718SJoseph Chen # ARM64 uses trust_merger 230fa400ae5SJoseph Chen if grep -Eq ''^CONFIG_ARM64=y'|'^CONFIG_ARM64_BOOT_AARCH32=y'' ${OUTDIR}/.config ; then 23141cf5e5aSJoseph Chen if [ ! -f ${RKBIN}/RKTRUST/${RKCHIP}${PLATFORM_AARCH32}TRUST.ini ]; then 23241cf5e5aSJoseph Chen echo "pack trust failed! Can't find: ${RKBIN}/RKTRUST/${RKCHIP}${PLATFORM_AARCH32}TRUST.ini" 23351441a28SJoseph Chen return 23451441a28SJoseph Chen fi 23551441a28SJoseph Chen 236cd7ae718SJoseph Chen cd ${RKBIN} 237*fb90bd1dSJoseph Chen ${RKTOOLS}/trust_merger ${PLATFORM_SHA} ${PLATFORM_RSA} ${PLATFORM_TRUST_IMG_SIZE} --replace tools/rk_tools/ ./ ${RKBIN}/RKTRUST/${RKCHIP}${PLATFORM_AARCH32}TRUST.ini 238e5e978b3SJoseph Chen 239*fb90bd1dSJoseph Chen cd - && mv ${RKBIN}/trust.img ./trust.img 24041cf5e5aSJoseph Chen echo "pack trust okay! Input: ${RKBIN}/RKTRUST/${RKCHIP}${PLATFORM_AARCH32}TRUST.ini" 241cd7ae718SJoseph Chen # ARM uses loaderimage 242cd7ae718SJoseph Chen else 24380fb8d2cSShunqian Zheng if [ ! -f ${RKBIN}/RKTRUST/${RKCHIP}TOS.ini ]; then 24480fb8d2cSShunqian Zheng echo "pack trust failed! Can't find: ${RKBIN}/RKTRUST/${RKCHIP}TOS.ini" 24551441a28SJoseph Chen return 24651441a28SJoseph Chen fi 24751441a28SJoseph Chen 248cd7ae718SJoseph Chen # OP-TEE is 132M(0x8400000) offset from DRAM base. 249366bd23fSJoseph Chen DARM_BASE=`sed -n "/CONFIG_SYS_SDRAM_BASE=/s/CONFIG_SYS_SDRAM_BASE=//p" ${OUTDIR}/include/autoconf.mk|tr -d '\r'` 250cd7ae718SJoseph Chen TEE_LOAD_ADDR=$((DARM_BASE+TEE_OFFSET)) 251cd7ae718SJoseph Chen 252cd7ae718SJoseph Chen # Convert Dec to Hex 253cd7ae718SJoseph Chen TEE_LOAD_ADDR=$(echo "obase=16;${TEE_LOAD_ADDR}"|bc) 254cd7ae718SJoseph Chen 2550e90839aSJoseph Chen # Parse orignal path 25680fb8d2cSShunqian Zheng TOS=`sed -n "/TOS=/s/TOS=//p" ${RKBIN}/RKTRUST/${RKCHIP}TOS.ini|tr -d '\r'` 25780fb8d2cSShunqian Zheng TOS_TA=`sed -n "/TOSTA=/s/TOSTA=//p" ${RKBIN}/RKTRUST/${RKCHIP}TOS.ini|tr -d '\r'` 258cd7ae718SJoseph Chen 2590e90839aSJoseph Chen # replace "./tools/rk_tools/" with "./" to compatible legacy ini content of rkdevelop branch 2600e90839aSJoseph Chen TOS=$(echo ${TOS} | sed "s/tools\/rk_tools\//\.\//g") 2610e90839aSJoseph Chen TOS_TA=$(echo ${TOS_TA} | sed "s/tools\/rk_tools\//\.\//g") 2620e90839aSJoseph Chen 263a64486b5SJoseph Chen if [ $TOS_TA -a $TOS ]; then 264*fb90bd1dSJoseph Chen ${RKTOOLS}/loaderimage --pack --trustos ${RKBIN}/${TOS} ./trust.img ${TEE_LOAD_ADDR} ${PLATFORM_TRUST_IMG_SIZE} 265*fb90bd1dSJoseph Chen ${RKTOOLS}/loaderimage --pack --trustos ${RKBIN}/${TOS_TA} ./trust_with_ta.img ${TEE_LOAD_ADDR} ${PLATFORM_TRUST_IMG_SIZE} 266cd7ae718SJoseph Chen echo "Both trust.img and trust_with_ta.img are ready" 267cd7ae718SJoseph Chen elif [ $TOS ]; then 268*fb90bd1dSJoseph Chen ${RKTOOLS}/loaderimage --pack --trustos ${RKBIN}/${TOS} ./trust.img ${TEE_LOAD_ADDR} ${PLATFORM_TRUST_IMG_SIZE} 269cd7ae718SJoseph Chen echo "trust.img is ready" 270cd7ae718SJoseph Chen elif [ $TOS_TA ]; then 271*fb90bd1dSJoseph Chen ${RKTOOLS}/loaderimage --pack --trustos ${RKBIN}/${TOS_TA} ./trust.img ${TEE_LOAD_ADDR} ${PLATFORM_TRUST_IMG_SIZE} 272cd7ae718SJoseph Chen echo "trust.img with ta is ready" 273cd7ae718SJoseph Chen else 274a64486b5SJoseph Chen echo "Can't find any tee bin" 275a64486b5SJoseph Chen exit 1 276cd7ae718SJoseph Chen fi 27751441a28SJoseph Chen 27880fb8d2cSShunqian Zheng echo "pack trust okay! Input: ${RKBIN}/RKTRUST/${RKCHIP}TOS.ini" 279cd7ae718SJoseph Chen fi 280cd7ae718SJoseph Chen} 281cd7ae718SJoseph Chen 282cd7ae718SJoseph Chenprepare 28327a50c86SAndy Yanecho "make for ${BOARD}_defconfig by -j${JOB}" 284366bd23fSJoseph Chenmake ${BOARD}_defconfig ${OUTOPT} 2857c2526e9SJoseph Chenselect_toolchain 28641cf5e5aSJoseph Chenfixup_platform_configure 2870ff0e214SJoseph Chensub_commands 288366bd23fSJoseph Chenmake CROSS_COMPILE=${TOOLCHAIN_GCC} all --jobs=${JOB} ${OUTOPT} 289cd7ae718SJoseph Chenpack_uboot_image 290d93242f2SJoseph Chenpack_loader_image 291cd7ae718SJoseph Chenpack_trust_image 292