From c9219683b791a6abb1c2340bfe5385bcaa7064ac Mon Sep 17 00:00:00 2001
From: guowenxue <guowenxue@gmail.com>
Date: Mon, 17 Jan 2022 11:12:33 +0800
Subject: [PATCH] update bootloader,kernel,rootfs,top build shell script for new version

---
 bsp/bootloader/build.sh |   91 ++++++++++++++++-----------------------------
 1 files changed, 33 insertions(+), 58 deletions(-)

diff --git a/bsp/bootloader/build.sh b/bsp/bootloader/build.sh
index c6f2481..ee36c1d 100755
--- a/bsp/bootloader/build.sh
+++ b/bsp/bootloader/build.sh
@@ -1,83 +1,53 @@
 #!/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=imx6ull
-
-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=.cfg-${BOARD}
-
-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"
-    sed -i -e "s|^CROSS_COMPILE=.*|CROSS_COMPILE=${CROSS_TOOL}|g" Makefile
+    pr_warn "Modify cross compiler in Makefile: $CROSS_TOOL\n"
+    sed -i -e "s|^CROSS_COMPILE=.*|CROSS_COMPILE?=${CROSS_TOOL}|g" Makefile
 
     cd ${PRJ_PATH}
 }
 
 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 configs/${BOARD}_defconfig
+    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