From f7a146878596312f233d4866732e05e68108daf3 Mon Sep 17 00:00:00 2001
From: guowenxue <guowenxue@gmail.com>
Date: Wed, 29 Dec 2021 15:02:49 +0800
Subject: [PATCH] update build.sh, add firmware in rootfs

---
 bsp/kernel/build.sh |  108 ++++++++++++++++++++++++++++++++++--------------------
 1 files changed, 68 insertions(+), 40 deletions(-)

diff --git a/bsp/kernel/build.sh b/bsp/kernel/build.sh
index d38bbbc..6e373c8 100755
--- a/bsp/kernel/build.sh
+++ b/bsp/kernel/build.sh
@@ -1,26 +1,22 @@
 #!/bin/bash
 
-INST_DRIVER=0
-
 PRJ_PATH=`pwd`
 
-IMG_PATH=${PRJ_PATH}/../images/boot
-  
-BOARD=imx6ull
- 
+# update by top build.sh
+BOARD=igkboard
+BSP_BRANCH=lf-5.10.52-2.1.0
 CROSS_TOOL=/opt/buildroot/cortexA7/bin/arm-linux-
 
-# linux kernel tarball path and branch
+INST_DRIVER=1
+
 TAR_PATH=${PRJ_PATH}/../tarball
-BSP_BRANCH=lf-5.10.52-2.1.0
+IMG_PATH=${PRJ_PATH}/../images/boot
 
 BOOT=emmc
-
 LINUX_SRC=linux-imx
 
 PATCH_FILE=${PRJ_PATH}/patch/${LINUX_SRC}-${BOARD}.patch
-
-CONF_FILE=.cfg-${BOARD}
+CONF_FILE=arch/arm/configs/${BOARD}_defconfig
 
 JOBS=`cat /proc/cpuinfo | grep processor | wc -l`
 
@@ -30,12 +26,12 @@
 STAGE=0
 
 function msg_banner()
-{ 
+{
 	STAGE=`expr $STAGE + 1`
 	
     echo ""
-    echo "+---------------------------------------------+" 
-    printf " Stage $STAGE: $1\n" 
+    echo "+---------------------------------------------+"
+    printf " Stage $STAGE: $1\n"
     echo "+---------------------------------------------+"
     echo ""
 }
@@ -43,7 +39,7 @@
 function do_fetch()
 {
     msg_banner "Fetch ${LINUX_SRC} source code"
-    if [ -d ${LINUX_SRC} ] ; then 
+    if [ -d ${LINUX_SRC} ] ; then
         printf "\n\n -- ${LINUX_SRC} fetched already -- \n\n"
         return 0;
     fi
@@ -63,23 +59,19 @@
     fi
 
     printf "\n\nModify cross compiler in Makefile: $CROSS_TOOL\n\n"
-    sed -i -e "s|^CROSS_COMPILE=.*|CROSS_COMPILE=${CROSS_TOOL}|g" Makefile
+    sed -i -e "s|^CROSS_COMPILE=.*|CROSS_COMPILE?=${CROSS_TOOL}|g" Makefile
 
     cd ${PRJ_PATH}
 }
-  
+
 function do_build()
 {
     msg_banner "Build for ${LINUX_SRC} source code"
 
     cd ${LINUX_SRC}
 
-    if [ ! -f .config ] ; then 
-        cp $CONF_FILE .config
-    fi
-
+    make ${BOARD}_defconfig
     make -j ${JOBS}
-
 
     cd ${PRJ_PATH}
 }
@@ -95,14 +87,15 @@
 
     set -x
     cp arch/arm/boot/zImage ${IMG_PATH}
-    cp arch/arm/boot/dts/imx6ul-14x14-evk-emmc.dtb ${IMG_PATH}/${BOARD}-${BOOT}.dtb
+    cp arch/arm/boot/dts/${BOARD}-${BOOT}.dtb ${IMG_PATH}/
 
     cp arch/arm/boot/zImage /tftp
-    cp arch/arm/boot/dts/imx6ul-14x14-evk-emmc.dtb /tftp/${BOARD}-${BOOT}.dtb
+    cp arch/arm/boot/dts/${BOARD}-${BOOT}.dtb /tftp/
     set +x
 
     if [ $INST_DRIVER != 0 ]  ;then
-        make modules_install INSTALL_MOD_PATH=${PRJ_PATH}/../rootfs INSTALL_MOD_STRIP=1
+        rm -rf ${PRJ_PATH}/../rootfs/driver
+        make modules_install INSTALL_MOD_PATH=${PRJ_PATH}/../rootfs/driver INSTALL_MOD_STRIP=1
     fi
 
     cd ${PRJ_PATH}
@@ -114,42 +107,77 @@
 
     cd ${LINUX_SRC}
 
-    if [ -f .config ] ; then 
-        cp .config $CONF_FILE
-    fi
-
     make distclean
 
     cd ${PRJ_PATH}
 }
 
 function gen_patch()
-{ 
-    do_clean
+{
+    msg_banner "Clean ${LINUX_SRC} source code"
+    cd ${LINUX_SRC}
+    make savedefconfig
+    mv defconfig ${CONF_FILE}
+    make distclean
+    cd -
 
-    mv ${LINUX_SRC} ${LINUX_SRC}-${BOARD} 
+    mv ${LINUX_SRC} ${LINUX_SRC}-${BOARD}
 
     do_fetch
 
     msg_banner "Generate ${LINUX_SRC} patch file"
 
     set +e
+
     diff -Nuar -x "include-prefixes" -x logo_linux_clut224.ppm ${LINUX_SRC} ${LINUX_SRC}-${BOARD} > ${LINUX_SRC}-${BOARD}.patch
 
     rm -rf ${LINUX_SRC}
     mv ${LINUX_SRC}-${BOARD} ${LINUX_SRC}
 }
 
-if [[ $# == 1 ]] && [[ $1 == "patch" ]] ; then
-    gen_patch
-    exit 0;
-fi
+function do_usage()
+{
+    echo ""
+    echo "Usage:"
+    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"
+    echo "     -h: show this help message"
+    echo ""
+    exit;
+}
+
+while getopts "bpch" OPTNAME
+do
+    case "${OPTNAME}" in
+        "b")
+            break;
+            ;;
+
+        "p")
+            gen_patch
+            exit;
+            ;;
+
+        "c")
+            do_clean
+            exit;
+            ;;
+
+        "*")
+            do_usage
+            exit;
+            ;;
+    esac
+done
+
+# Default do build action
 
 do_fetch
-
 do_patch
-
 do_build
-
 do_install
-  
+
+exit;
+

--
Gitblit v1.9.1