make.sh: optimize code
1. use global variables for important definitions, easy to update; 2. add more error message warning; 3. fix some issues. Change-Id: I702f4efe5839c1c7eaf66f412011aadf6627f323 Signed-off-by: Joseph Chen <chenjh@rock-chips.com>
This commit is contained in:
parent
0e90839a14
commit
bc98b3c8fc
91
make.sh
91
make.sh
|
|
@ -1,20 +1,33 @@
|
||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
set -e
|
set -e
|
||||||
BOARD=$1
|
BOARD=$1
|
||||||
DIR=${BOARD#*-}
|
RKCHIP=${BOARD##*-}
|
||||||
DSTDIR=rockdev/${DIR}
|
DSTDIR=rockdev/${RKCHIP}
|
||||||
RKCHIP=$(echo $DIR | tr '[a-z]' '[A-Z]')
|
RKCHIP=$(echo ${RKCHIP} | tr '[a-z]' '[A-Z]')
|
||||||
TOOLCHAIN=arm-linux-gnueabi-
|
|
||||||
JOB=`sed -n "N;/processor/p" /proc/cpuinfo|wc -l`
|
JOB=`sed -n "N;/processor/p" /proc/cpuinfo|wc -l`
|
||||||
|
|
||||||
|
# Declare global rkbin tools and rkbin Responsity path, updated in prepare()
|
||||||
|
TOOLCHAIN_RKBIN=./
|
||||||
|
RKBIN=./
|
||||||
|
# RKTOOL path
|
||||||
|
RKBIN_TOOLS=../rkbin/tools
|
||||||
|
|
||||||
|
# Declare global toolchain path for CROSS_COMPILE, updated in select_toolchain()
|
||||||
|
TOOLCHAIN_GCC=./
|
||||||
|
# GCC toolchain
|
||||||
|
GCC_ARM32=arm-linux-androideabi-
|
||||||
|
GCC_ARM64=aarch64-linux-android-
|
||||||
|
TOOLCHAIN_ARM32=../prebuilts/gcc/linux-x86/arm/arm-linux-androideabi-4.9/bin
|
||||||
|
TOOLCHAIN_ARM64=../prebuilts/gcc/linux-x86/aarch64/aarch64-linux-android-4.9/bin
|
||||||
|
|
||||||
prepare()
|
prepare()
|
||||||
{
|
{
|
||||||
local dst
|
local absolute_path
|
||||||
|
|
||||||
# Check invaid args and help
|
# Check invaid args and help
|
||||||
if [ "$BOARD" = '--help' -o "$BOARD" = '-h' -o "$BOARD" = '--h' ]; then
|
if [ "$BOARD" = '--help' -o "$BOARD" = '-h' -o "$BOARD" = '--h' -o "$BOARD" = '' ]; then
|
||||||
echo
|
echo
|
||||||
echo "Usage: ./make.sh board"
|
echo "Usage: ./make.sh [board]"
|
||||||
echo "Example:"
|
echo "Example:"
|
||||||
echo "./make.sh evb-rk3399 ---- build for evb-rk3399_defconfig"
|
echo "./make.sh evb-rk3399 ---- build for evb-rk3399_defconfig"
|
||||||
echo "./make.sh firefly-rk3288 ---- build for firefly-rk3288_defconfig"
|
echo "./make.sh firefly-rk3288 ---- build for firefly-rk3288_defconfig"
|
||||||
|
|
@ -24,11 +37,11 @@ prepare()
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Initialize RKBIN and RKTOOLS
|
# Initialize RKBIN and TOOLCHAIN_RKBIN
|
||||||
dst=../rkbin/tools
|
if [ -d ${RKBIN_TOOLS} ]; then
|
||||||
if [ -d ${dst} ]; then
|
absolute_path=$(cd `dirname ${RKBIN_TOOLS}`; pwd)
|
||||||
RKBIN=$(cd `dirname ${dst}`; pwd)
|
RKBIN=${absolute_path}
|
||||||
RKTOOLS=${RKBIN}/tools
|
TOOLCHAIN_RKBIN=${absolute_path}/tools
|
||||||
else
|
else
|
||||||
echo
|
echo
|
||||||
echo "Can't find '../rkbin/' Responsity, please download it before pack image!"
|
echo "Can't find '../rkbin/' Responsity, please download it before pack image!"
|
||||||
|
|
@ -42,22 +55,34 @@ prepare()
|
||||||
|
|
||||||
select_toolchain()
|
select_toolchain()
|
||||||
{
|
{
|
||||||
local dst path
|
local absolute_path
|
||||||
|
|
||||||
if grep -q '^CONFIG_ARM64=y' ${DSTDIR}/out/.config ; then
|
if grep -q '^CONFIG_ARM64=y' ${DSTDIR}/out/.config ; then
|
||||||
TOOLCHAIN=aarch64-linux-gnu-
|
if [ -d ${TOOLCHAIN_ARM64} ]; then
|
||||||
dst=../prebuilts/gcc/linux-x86/aarch64/aarch64-linux-android-4.9/bin
|
absolute_path=$(cd `dirname ${TOOLCHAIN_ARM64}`; pwd)
|
||||||
if [ -d ${dst} ]; then
|
TOOLCHAIN_GCC=${absolute_path}/bin/${GCC_ARM64}
|
||||||
path=$(cd `dirname ${dst}`; pwd)
|
else
|
||||||
TOOLCHAIN=${path}/bin/aarch64-linux-android-
|
echo "Can't find toolchain: ${TOOLCHAIN_GCC}"
|
||||||
|
exit 1
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
dst=../prebuilts/gcc/linux-x86/arm/arm-linux-androideabi-4.9/bin
|
if [ -d ${TOOLCHAIN_ARM32} ]; then
|
||||||
if [ -d ${dst} ]; then
|
absolute_path=$(cd `dirname ${TOOLCHAIN_ARM32}`; pwd)
|
||||||
path=$(cd `dirname ${dst}`; pwd)
|
TOOLCHAIN_GCC=${absolute_path}/bin/${GCC_ARM32}
|
||||||
TOOLCHAIN=${path}/bin/arm-linux-androideabi-
|
else
|
||||||
|
echo "Can't find toolchain: ${TOOLCHAIN_GCC}"
|
||||||
|
exit 1
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
echo toolchain: ${TOOLCHAIN}
|
|
||||||
|
echo "toolchain: ${TOOLCHAIN_GCC}"
|
||||||
|
}
|
||||||
|
|
||||||
|
fixup_chip_name()
|
||||||
|
{
|
||||||
|
if [ "$RKCHIP" = 'RK3228' -o "$RKCHIP" = 'RK3229' ]; then
|
||||||
|
RKCHIP=RK322X
|
||||||
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
pack_uboot_image()
|
pack_uboot_image()
|
||||||
|
|
@ -65,13 +90,13 @@ pack_uboot_image()
|
||||||
local UBOOT_LOAD_ADDR
|
local UBOOT_LOAD_ADDR
|
||||||
|
|
||||||
UBOOT_LOAD_ADDR=`sed -n "/CONFIG_SYS_TEXT_BASE=/s/CONFIG_SYS_TEXT_BASE=//p" ${DSTDIR}/out/include/autoconf.mk|tr -d '\r'`
|
UBOOT_LOAD_ADDR=`sed -n "/CONFIG_SYS_TEXT_BASE=/s/CONFIG_SYS_TEXT_BASE=//p" ${DSTDIR}/out/include/autoconf.mk|tr -d '\r'`
|
||||||
${RKTOOLS}/loaderimage --pack --uboot ${DSTDIR}/out/u-boot.bin uboot.img ${UBOOT_LOAD_ADDR}
|
${TOOLCHAIN_RKBIN}/loaderimage --pack --uboot ${DSTDIR}/out/u-boot.bin uboot.img ${UBOOT_LOAD_ADDR}
|
||||||
}
|
}
|
||||||
|
|
||||||
pack_loader_image()
|
pack_loader_image()
|
||||||
{
|
{
|
||||||
cd ${RKBIN}
|
cd ${RKBIN}
|
||||||
${RKTOOLS}/boot_merger --replace tools/rk_tools/ ./ ${RKBIN}/RKBOOT/${RKCHIP}MINIALL.ini
|
${TOOLCHAIN_RKBIN}/boot_merger --replace tools/rk_tools/ ./ ${RKBIN}/RKBOOT/${RKCHIP}MINIALL.ini
|
||||||
cd -
|
cd -
|
||||||
mv ${RKBIN}/*_loader_*.bin ./
|
mv ${RKBIN}/*_loader_*.bin ./
|
||||||
}
|
}
|
||||||
|
|
@ -83,7 +108,7 @@ pack_trust_image()
|
||||||
# ARM64 uses trust_merger
|
# ARM64 uses trust_merger
|
||||||
if grep -q '^CONFIG_ARM64=y' ${DSTDIR}/out/.config ; then
|
if grep -q '^CONFIG_ARM64=y' ${DSTDIR}/out/.config ; then
|
||||||
cd ${RKBIN}
|
cd ${RKBIN}
|
||||||
${RKTOOLS}/trust_merger --replace tools/rk_tools/ ./ ${RKBIN}/RKTRUST/${RKCHIP}TRUST.ini
|
${TOOLCHAIN_RKBIN}/trust_merger --replace tools/rk_tools/ ./ ${RKBIN}/RKTRUST/${RKCHIP}TRUST.ini
|
||||||
cd -
|
cd -
|
||||||
mv ${RKBIN}/trust.img ./trust.img
|
mv ${RKBIN}/trust.img ./trust.img
|
||||||
# ARM uses loaderimage
|
# ARM uses loaderimage
|
||||||
|
|
@ -104,14 +129,14 @@ pack_trust_image()
|
||||||
TOS_TA=$(echo ${TOS_TA} | sed "s/tools\/rk_tools\//\.\//g")
|
TOS_TA=$(echo ${TOS_TA} | sed "s/tools\/rk_tools\//\.\//g")
|
||||||
|
|
||||||
if [ $TOS_TA -a $TOS ]; then
|
if [ $TOS_TA -a $TOS ]; then
|
||||||
${RKTOOLS}/loaderimage --pack --trustos ${RKBIN}/${TOS} ./trust.img ${TEE_LOAD_ADDR}
|
${TOOLCHAIN_RKBIN}/loaderimage --pack --trustos ${RKBIN}/${TOS} ./trust.img ${TEE_LOAD_ADDR}
|
||||||
${RKTOOLS}/loaderimage --pack --trustos ${RKBIN}/${TOS_TA} ./trust_with_ta.img ${TEE_LOAD_ADDR}
|
${TOOLCHAIN_RKBIN}/loaderimage --pack --trustos ${RKBIN}/${TOS_TA} ./trust_with_ta.img ${TEE_LOAD_ADDR}
|
||||||
echo "Both trust.img and trust_with_ta.img are ready"
|
echo "Both trust.img and trust_with_ta.img are ready"
|
||||||
elif [ $TOS ]; then
|
elif [ $TOS ]; then
|
||||||
${RKTOOLS}/loaderimage --pack --trustos ${RKBIN}/${TOS} ./trust.img ${TEE_LOAD_ADDR}
|
${TOOLCHAIN_RKBIN}/loaderimage --pack --trustos ${RKBIN}/${TOS} ./trust.img ${TEE_LOAD_ADDR}
|
||||||
echo "trust.img is ready"
|
echo "trust.img is ready"
|
||||||
elif [ $TOS_TA ]; then
|
elif [ $TOS_TA ]; then
|
||||||
${RKTOOLS}/loaderimage --pack --trustos ${RKBIN}/${TOS_TA} ./trust.img ${TEE_LOAD_ADDR}
|
${TOOLCHAIN_RKBIN}/loaderimage --pack --trustos ${RKBIN}/${TOS_TA} ./trust.img ${TEE_LOAD_ADDR}
|
||||||
echo "trust.img with ta is ready"
|
echo "trust.img with ta is ready"
|
||||||
else
|
else
|
||||||
echo "Can't find any tee bin"
|
echo "Can't find any tee bin"
|
||||||
|
|
@ -121,11 +146,11 @@ pack_trust_image()
|
||||||
}
|
}
|
||||||
|
|
||||||
prepare
|
prepare
|
||||||
|
select_toolchain
|
||||||
echo "make for ${BOARD}_defconfig by -j${JOB}"
|
echo "make for ${BOARD}_defconfig by -j${JOB}"
|
||||||
make ${BOARD}_defconfig O=${DSTDIR}/out
|
make ${BOARD}_defconfig O=${DSTDIR}/out
|
||||||
select_toolchain
|
make CROSS_COMPILE=${TOOLCHAIN_GCC} all --jobs=${JOB} O=${DSTDIR}/out
|
||||||
make CROSS_COMPILE=${TOOLCHAIN} all --jobs=${JOB} O=${DSTDIR}/out
|
fixup_chip_name
|
||||||
pack_loader_image
|
pack_loader_image
|
||||||
pack_uboot_image
|
pack_uboot_image
|
||||||
pack_trust_image
|
pack_trust_image
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue