From a1040ee8e210ee2bcc029d64308251935783b612 Mon Sep 17 00:00:00 2001 From: guowenxue <guowenxue@gmail.com> Date: Mon, 17 Jan 2022 19:51:27 +0800 Subject: [PATCH] update rootfs build.sh --- bsp/bootloader/build.sh | 89 ++++++++++++++++---------------------------- 1 files changed, 32 insertions(+), 57 deletions(-) diff --git a/bsp/bootloader/build.sh b/bsp/bootloader/build.sh index b95e98c..15afe14 100755 --- a/bsp/bootloader/build.sh +++ b/bsp/bootloader/build.sh @@ -1,70 +1,39 @@ #!/bin/bash +# This shell script used auto download bootloader source code and do cross compile -PRJ_PATH=`pwd` -PRJ_NAME=`basename ${PRJ_PATH}` - -IMG_PATH=${PRJ_PATH}/../images/ - -BOARD=igkboard - -CROSS_TOOL=/opt/buildroot/cortexA7/bin/arm-linux- - -# bootloader tarball path and branch -TAR_PATH=${PRJ_PATH}/../tarball -BSP_BRANCH=lf-5.10.52-2.1.0 - - -BOOT=emmc +source ../scripts/setup_env.sh UBOOT_SRC=uboot-imx +IMG_NAME=u-boot-${BOARD}.imx -IMG_NAME=u-boot-${BOARD}-${BOOT}.imx - -PATCH_FILE=${PRJ_PATH}/patch/${UBOOT_SRC}-${BOARD}.patch - -CONF_FILE=configs/${BOARD}_defconfig - -JOBS=`cat /proc/cpuinfo | grep processor | wc -l` +patch_file=$(eval echo `jq -r ".UBOOT_SRC.PATCH" $JSON_CONF`) +arch=$(eval echo `jq -r ".CONFIG.ARCH" $JSON_CONF`) +defconf=$(eval echo `jq -r ".CONFIG.DEFCONF" $JSON_CONF`) set -u set -e -STAGE=0 - -function msg_banner() -{ - STAGE=`expr $STAGE + 1` - - echo "" - echo "+---------------------------------------------+" - printf " Stage $STAGE: $1\n" - echo "+---------------------------------------------+" - echo "" -} - function do_fetch() { - msg_banner "Fetch ${UBOOT_SRC} source code" - if [ -d ${UBOOT_SRC} ] ; then - printf "\n\n -- ${UBOOT_SRC} fetched already -- \n\n" + if [ -d $UBOOT_SRC ] ; then + pr_warn "$UBOOT_SRC fetched already." return 0; fi - printf "\n -- decompress ${UBOOT_SRC}-${BSP_BRANCH}.tar.xz now ... -- \n\n" - tar -xJf ${TAR_PATH}/${UBOOT_SRC}-${BSP_BRANCH}.tar.xz + do_fetch_json $JSON_CONF UBOOT_SRC $UBOOT_SRC + rm -rf *.tar* } function do_patch() { - msg_banner "Patch for ${UBOOT_SRC} source code" - cd ${UBOOT_SRC} - if [ ! -s $CONF_FILE -a -s $PATCH_FILE ] ; then - patch -p1 < $PATCH_FILE + if [ ! -s configs/$defconf -a -s $patch_file ] ; then + pr_warn "Patch for ${UBOOT_SRC} source code" + patch -p1 < $patch_file fi - printf "\n\nModify cross compiler in Makefile: $CROSS_TOOL\n\n" + pr_warn "Modify cross compiler in Makefile: $CROSS_TOOL" sed -i -e "s|^CROSS_COMPILE=.*|CROSS_COMPILE?=${CROSS_TOOL}|g" Makefile cd ${PRJ_PATH} @@ -72,12 +41,13 @@ function do_build() { - msg_banner "Build for ${UBOOT_SRC} source code" + pr_warn "Build for ${UBOOT_SRC} source code" cd ${UBOOT_SRC} - make ${BOARD}_defconfig + make $defconf make -j ${JOBS} + cp u-boot-dtb.imx ${IMG_NAME} chmod a+x ${IMG_NAME} @@ -87,20 +57,18 @@ function do_install() { - msg_banner "Install $IMG_NAME" + pr_warn "Install bootloader $IMG_NAME" cd ${UBOOT_SRC} - mkdir -p ${IMG_PATH} - cp ${IMG_NAME} ${IMG_PATH} - cp ${IMG_NAME} /tftp + do_install_json $JSON_CONF "INSTALL" cd ${PRJ_PATH} } function do_clean() { - msg_banner "Clean ${UBOOT_SRC} source code" + pr_warn "Clean ${UBOOT_SRC} source code" cd ${UBOOT_SRC} @@ -111,21 +79,23 @@ function gen_patch() { - msg_banner "Clean ${UBOOT_SRC} source code" + pr_warn "Clean ${UBOOT_SRC} source code" + cd ${UBOOT_SRC} make savedefconfig - mv defconfig ${CONF_FILE} + mv defconfig configs/$defconf make distclean cd - mv ${UBOOT_SRC} ${UBOOT_SRC}-${BOARD} + pr_warn "Fetch orignal source code" do_fetch - msg_banner "Generate ${UBOOT_SRC} patch file" + pr_warn "Generate ${UBOOT_SRC} patch file" set +e - diff -Nuar ${UBOOT_SRC} ${UBOOT_SRC}-${BOARD} > ${UBOOT_SRC}-${BOARD}.patch + diff -Nuar ${UBOOT_SRC} ${UBOOT_SRC}-${BOARD} > $patch_file rm -rf ${UBOOT_SRC} mv ${UBOOT_SRC}-${BOARD} ${UBOOT_SRC} @@ -135,7 +105,7 @@ { echo "" echo "Usage:" - echo " $0 [-b] [p] [-c] [-h]" + echo " $0 [-b] [-p] [-c] [-h]" echo " -b: download and build $PRJ_NAME" echo " -p: generate $PRJ_NAME patch file" echo " -c: clean the source code" @@ -161,6 +131,11 @@ exit; ;; + "h") + do_usage + exit; + ;; + "*") do_usage exit; -- Gitblit v1.9.1