Merge pull request #128 from prodeveloper0/features/prebuilt-rootfs

feat: support building with user prebuilt rootfs
This commit is contained in:
luckfox-eng33 2024-09-05 15:01:40 +08:00 committed by GitHub
commit bdf11eb003
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 64 additions and 22 deletions

1
.gitignore vendored
View File

@ -4,5 +4,6 @@
RK-RELEASE-NOTES-V1.4.1.txt
IMAGE/
output/
prebuilt_rootfs.tar.gz
project/app/wifi_app/wpa_supplicant.conf
config/

View File

@ -39,6 +39,7 @@ SDK_CONFIG_DIR=${SDK_ROOT_DIR}/config
DTS_CONFIG=${SDK_CONFIG_DIR}/dts_config
KERNEL_DEFCONFIG=${SDK_CONFIG_DIR}/kernel_defconfig
BUILDROOT_DEFCONFIG=${SDK_CONFIG_DIR}/buildroot_defconfig
PREBUILT_ROOTFS_PATH=${SDK_ROOT_DIR}/prebuilt_rootfs.tar.gz
UBUNTU_DIR=${SDK_SYSDRV_DIR}/tools/board/ubuntu
if [ $(getconf _NPROCESSORS_ONLN) -eq 1 ]; then
@ -106,6 +107,14 @@ function msg_error() {
echo -e "${C_RED}[$(basename $0):error] $1${C_NORMAL}"
}
function check_prebuilt_rootfs() {
if [ -f "$PREBUILT_ROOTFS_PATH" ] && [ $CONFIG_USE_PREBUILT_ROOTFS == "y" ]; then
echo "y"
else
echo "n"
fi
}
err_handler() {
ret=$?
[ "$ret" -eq 0 ] && return
@ -650,26 +659,41 @@ function build_sysdrv() {
echo "============Start building sysdrv============"
mkdir -p ${RK_PROJECT_OUTPUT_IMAGE}
make -C ${SDK_SYSDRV_DIR}
rootfs_tarball="$RK_PROJECT_PATH_SYSDRV/rootfs_${RK_LIBC_TPYE}_${RK_CHIP}.tar"
rootfs_out_dir="$RK_PROJECT_OUTPUT/rootfs_${RK_LIBC_TPYE}_${RK_CHIP}"
if ! [ -d $RK_PROJECT_OUTPUT ]; then
mkdir -p $RK_PROJECT_OUTPUT
fi
if [ $(check_prebuilt_rootfs) == "y" ]; then
make -C ${SDK_SYSDRV_DIR} uboot
make -C ${SDK_SYSDRV_DIR} kernel
make -C ${SDK_SYSDRV_DIR} env
if [ -f $rootfs_tarball ]; then
rootfs_tarball=$PREBUILT_ROOTFS_PATH
if [ -d $rootfs_out_dir ]; then
rm -rf $rootfs_out_dir
fi
tar xf $rootfs_tarball -C $RK_PROJECT_OUTPUT
mkdir -p $rootfs_out_dir
tar xf $rootfs_tarball -C $rootfs_out_dir
else
msg_error "Not found rootfs tarball: $rootfs_tarball"
exit 1
if ! [ -d $RK_PROJECT_OUTPUT ]; then
mkdir -p $RK_PROJECT_OUTPUT
fi
make -C ${SDK_SYSDRV_DIR}
if [ -f $rootfs_tarball ]; then
if [ -d $rootfs_out_dir ]; then
rm -rf $rootfs_out_dir
fi
tar xf $rootfs_tarball -C $RK_PROJECT_OUTPUT
else
msg_error "Not found rootfs tarball: $rootfs_tarball"
exit 1
fi
msg_info "If you need to add custom files, please upload them to <Luckfox Sdk>/output/out/rootfs_${RK_LIBC_TPYE}_${RK_CHIP}."
fi
msg_info "If you need to add custom files, please upload them to <Luckfox Sdk>/output/out/rootfs_${RK_LIBC_TPYE}_${RK_CHIP}."
finish_build
}
@ -694,27 +718,37 @@ function build_kernel() {
function build_rootfs() {
check_config RK_BOOT_MEDIUM || check_config RK_TARGET_ROOTFS || return 0
make rootfs -C ${SDK_SYSDRV_DIR}
local rootfs_tarball rootfs_out_dir
rootfs_tarball="$RK_PROJECT_PATH_SYSDRV/rootfs_${RK_LIBC_TPYE}_${RK_CHIP}.tar"
rootfs_out_dir="$RK_PROJECT_OUTPUT/rootfs_${RK_LIBC_TPYE}_${RK_CHIP}"
if ! [ -d $RK_PROJECT_OUTPUT ]; then
mkdir -p $RK_PROJECT_OUTPUT
fi
if [ -f $rootfs_tarball ]; then
if [ $(check_prebuilt_rootfs) == "y" ]; then
rootfs_tarball=$PREBUILT_ROOTFS_PATH
if [ -d $rootfs_out_dir ]; then
rm -rf $rootfs_out_dir
fi
tar xf $rootfs_tarball -C $RK_PROJECT_OUTPUT
mkdir -p $rootfs_out_dir
tar xf $rootfs_tarball -C $rootfs_out_dir
else
msg_error "Not found rootfs tarball: $rootfs_tarball"
exit 1
make rootfs -C ${SDK_SYSDRV_DIR}
if ! [ -d $RK_PROJECT_OUTPUT ]; then
mkdir -p $RK_PROJECT_OUTPUT
fi
if [ -f $rootfs_tarball ]; then
if [ -d $rootfs_out_dir ]; then
rm -rf $rootfs_out_dir
fi
tar xf $rootfs_tarball -C $RK_PROJECT_OUTPUT
else
msg_error "Not found rootfs tarball: $rootfs_tarball"
exit 1
fi
msg_info "If you need to add custom files, please upload them to <Luckfox Sdk>/output/out/rootfs_${RK_LIBC_TPYE}_${RK_CHIP}."
fi
msg_info "If you need to add custom files, please upload them to <Luckfox Sdk>/output/out/rootfs_${RK_LIBC_TPYE}_${RK_CHIP}."
finish_build
}
@ -1012,8 +1046,11 @@ function build_all() {
[[ $RK_ENABLE_RECOVERY = "y" ]] && build_recovery
build_sysdrv
build_media
build_app
if [ $(check_prebuilt_rootfs) != "y" ]; then
build_media
build_app
fi
build_firmware
finish_build
@ -1227,6 +1264,10 @@ function __PACKAGE_ROOTFS() {
local rootfs_tarball rootfs_out_dir
rootfs_tarball="$RK_PROJECT_PATH_SYSDRV/rootfs_${RK_LIBC_TPYE}_${RK_CHIP}.tar"
if [ $(check_prebuilt_rootfs) == "y" ]; then
rootfs_tarball=$PREBUILT_ROOTFS_PATH
fi
if [ ! -f $rootfs_tarball ]; then
msg_error "Build rootfs is not yet complete, packaging cannot proceed!"
exit 0