Compile Android8.1¶
Download Android SDK¶
Due to the larger SDK, you can choose the cloud disk to download Firefly-RK3399_Android8.1_xxx.7za from the download page (you can directly use the Firefly-RK3399 source package):
After the download is complete, verify the MD5 code before decompression:
$md5sum ~/firefly_rk3399_android8.1_git_20211217.7z.001
$md5sum ~/firefly_rk3399_android8.1_git_20211217.7z.002
$md5sum ~/firefly_rk3399_android8.1_git_20211217.7z.003
48b4cfcb538cdc39ea53349989691617 firefly_rk3399_android8.1_git_20211217.7z.001
05776d4966d92efdcb88170355d8fbd4 firefly_rk3399_android8.1_git_20211217.7z.002
c83f54d89b4cde6eb620b92cd2e99a05 firefly_rk3399_android8.1_git_20211217.7z.003
Then unzip:
mkdir -p ~/proj/roc-rk3399-pc
cd ~/proj/roc-rk3399-pc
7z x ~/firefly_rk3399_android8.1_git_20211217.7z.001 -r -o.
git reset --hard
Update the remote warehouse:
git remote rm origin
git remote add gitlab git@gitlab.com:TeeFirefly/firenow-oreo-rk3399.git
Synchronize the source code from gitlab:
git pull gitlab firefly-rk3399:firefly-rk3399
You can also view the source code online at the following address: [https://gitlab.com/TeeFirefly/firenow-oreo-rk3399#]
AIO-3399J product compilation method¶
HDMI display compilation¶
./FFTools/make.sh -d rk3399-firefly-aio -j8 -l rk3399_firefly_aio_mid-userdebug
./FFTools/mkupdate/mkupdate.sh -l rk3399_firefly_aio_mid-userdebug
HDMI + EDP display compilation
Dual LVDS
./FFTools/make.sh -d rk3399-firefly-aio-lvds -j8 -l rk3399_firefly_aio_lvds_mid-userdebug
./FFTools/mkupdate/mkupdate.sh -l rk3399_firefly_aio_lvds_mid-userdebug
Single LVDS
./FFTools/make.sh -d rk3399-firefly-aio-lvds-HSX101H40C -j8 -l rk3399_firefly_aio_lvds_mid-userdebug
./FFTools/mkupdate/mkupdate.sh -l rk3399_firefly_aio_lvds_mid-userdebug
Manually compile Android 8.1¶
Before compiling, execute the following command to configure environment variables:
export JAVA_HOME=/usr/lib/jvm/java-8-openjdk-amd64
export PATH=$JAVA_HOME/bin:$PATH
export CLASSPATH=.:$JAVA_HOME/lib:$JAVA_HOME/lib/tools.jar
Compile kernel:
cd ~/proj/AIO-3399J/kernel/
make ARCH=arm64 firefly_defconfig
make -j8 ARCH=arm64 rk3399-firefly-aio.img
Compile uboot:
cd ~/proj/AIO-3399J/u-boot/
make rk3399_defconfig
make ARCHV=aarch64 -j8
Compile Android:
cd ~/proj/AIO-3399J/
source build/envsetup.sh
lunch rk3399_firefly_aio_mid-userdebug
make -j8
./mkimage.sh
Use Firefly official script to compile¶
Compile the kernel separately:
cd ~/proj/AIO-3399J/
./FFTools/make.sh -k -j8
Compile the uboot separately:
cd ~/proj/AIO-3399J/
./FFTools/make.sh -u -j8
Compile Android upper layer separately:
cd ~/proj/AIO-3399J/
./FFTools/make.sh -a -j8
Compile ubooot, kernel, Android at the same time:
cd ~/proj/AIO-3399J/
./FFTools/make.sh -j8
Packaged into unified firmware¶
After compiling, you can use Firefly’s official script to package into unified firmware, execute the following command:
./FFTools/mkupdate/mkupdate.sh -l rk3399_firefly_aio_mid-userdebug
According to different -l XXX-userdebug parameters, the packaged unified firmware will be stored in different directories (rockdev/image-XXX/): product name XXX_XXX_date XXX.img
It is also very simple to package the unified firmware update.img
under Windows, copy the compiled files to the rockdev/Image
directory of AndroidTool, and then run the mkupdate.bat
batch file under the rockdev
directory Create update.img
and store it in the rockdev/Image
directory.
Partition mirror¶
boot.img:The Android initramfs image contains the basic file system of the Android root directory, which is responsible for initializing and loading the system partition.
system.img: Android file system partition image in ext4 file system format.
kernel.img: Kernel image.
resource.img: Resource image, including boot pictures and kernel device tree.
misc.img: The misc partition image is responsible for switching the startup mode and passing the parameters of the emergency mode.
recovery.img: Recovery mode image.
rk3399_loader_v1.12.112.bin:Loader file.
uboot.img: U-Boot image file.
trust.img: Arm trusted file (ATF) image file.
parameter.txt: Partition layout and kernel command line.
vendor.img: TODO
oem.img: TODO
baseparameter.img: TODO
Other Android versions¶
Main maintenance:
Support but not maintain: