Debian System Compilation
Hardware Configuration
Recommended hardware configuration for compiling Ubuntu development environment:
64-bit CPU
Ubuntu 20.04, do not use Windows Subsystem (WSL)
16GB of RAM
250GB free space for compiling
Normal user to compile, do not use root user to compile
Software Configuration
Install environment packages
sudo apt update
sudo apt-get install git ssh make gcc libssl-dev liblz4-tool \
expect g++ patchelf chrpath gawk texinfo chrpath diffstat binfmt-support \
qemu-user-static live-build bison flex fakeroot cmake gcc-multilib g++-multilib \
unzip device-tree-compiler libncurses-dev
sudo pip install python-pip pyelftools
Installation configuration git
sudo apt install git-all
Configure account name and email
git config --global user.email "your_name@xxx.com"
git config --global user.name "your_name"
Get SDK
Email support@neardi.com for development materials
After downloading, check the MD5 code and Neardi-3588-SDK-Linux-${Version}.tar.gz.md5sum for consistency before unzipping:
$ md5sum Neardi-3588-SDK-Linux-${Version}.tar.gz
******************************** Neardi-3588-SDK-Linux-${Version}.tar.gz
Unzip:
tar zxvf Neardi-3588-SDK-Linux-${Version}.tar.gz
Extract:
cd Neardi-3588-SDK-Linux-${Version}
git reset --hard
Compile SDK
Select Configuration
boardConfig | explain |
---|---|
BoardConfig-rk3588-neardi-linux-lpm3588-f1.mk | ETHx6 + HDMI1 + HDMI2 + DP + HDMIIN |
./build.sh lunch BoardConfig-rk3588-neardi-linux-lpm3588-f1.mk
Fully Automatic Compilation
For the first compilation of the SDK, it is imperative to compile everything once, otherwise packaging will fail.
Fully automatic compilation will execute all compilations, generating u-boot, kernel, and buildroot.
./build.sh
Compile Debian
./build.sh debian
Packaging Firmware
RK firmware is packaged in a proprietary format by Rockchip, and can be flashed onto eMMC or SD card using tools provided by Rockchip (Note: Unless specified otherwise, the firmware mentioned on the WIKI by default refers to RK firmware).
# Package RK firmware
./build.sh updateimg
The complete firmware will be saved to rockdev/update.img
。
Partial Compilation
Compile u-boot
./build.sh uboot
Compile kernel
./build.sh kernel
Compile recovery
./build.sh recovery
FAQ
Compilation Errors
lz4 Error
Incorrect parameters
Usage :
lz4 [arg] [input] [output]
input : a filename
with no FILE, or when FILE is - or stdin, read standard input
Arguments :
-1 : Fast compression (default)
-9 : High compression
-d : decompression (default for .lz4 extension)
-z : force compression
-f : overwrite output without prompting
-h/-H : display help/long help and exit
arch/arm64/boot/Makefile:31: recipe for target 'arch/arm64/boot/Image.lz4' failed
make[2]: *** [arch/arm64/boot/Image.lz4] Error 1
make[2]: *** Deleting file 'arch/arm64/boot/Image.lz4'
arch/arm64/Makefile:170: recipe for target 'Image.lz4' failed
make[1]: *** [Image.lz4] Error 2
make[1]: *** Waiting for unfinished jobs....
Workaround, re-install LZ4 manually:
git clone https://github.com/lz4/lz4.git
cd lz4
make
sudo make install