How to Build a Buildroot File System and Add System Tools on the OK3588-C Platform?

This article takes the Forlinx OK3588-C development board platform as an example to explain how to use Buildroot to build a file system and add common system tools such as OpenCV. It is suitable for developers who need to customize embedded Linux systems.

1. Overview

This article applies to the Buildroot system of Linux 5.10.209. The purpose of this article is to show how to make customized modifications to Buildroot 209.

2. Operations

2.1 SDK Source Code Download and Decompression

forlinx@ubuntu20:~/3-3588-SDK_Kernel_5.10.209/1-Linux5.10.209+Qt5.15.10+Forlinx_Desktop22.04/OK3588-linux-source$ ls
app           build_secret_uboot.sh  debian  external  output   rkbin  rtos    ubuntu
build_close.sh  build.sh         device   kernel    prebuilts  rkflash.sh  tools   uefi  buildroot  common           docs    Makefile  README.md  rockdev     u-boot  yocto

2.2 Buildroot Compilation Available

To compile buildroot, delete or remove rootfs.ext4 from this directory (move to another directory or rename it)

forlinx@ubuntu20:~/3-3588-SDK_Kernel_5.10.209/1-Linux5.10.209+Qt5.15.10+Forlinx_Desktop22.04/OK3588-linux-source/prebuilts/forlinx/buildroot$ ls

rootfs.ext4

2.3 Compiling Default Configuration Items

To ensure compatibility with the previous default Buildroot configuration items (forlinx_ok3588_defconfig), re-compile by executing ./build.sh or ./build.sh buildroot.

During the build process, according to the configuration items in forlinx_ok3588_defconfig, the source code packages of software projects will be fetched from the server and placed in the /buildroot/package directory.

forlinx@ubuntu20:~/3-3588-SDK_Kernel_5.10.209/1-Linux5.10.209+Qt5.15.10+Forlinx_Desktop22.04/OK3588-linux-source/buildroot/package$

After the compilation is complete, a number of files are added and generated.

Generate files under buildroot/output/forlinx_ok3588/

Table of Contents Usage Description
build Store the intermediate and temporary files generated during the compilation process. If these files are deleted, the recompilation time will be very long.
host Contains tools and binary files compiled for the build system host. That is, the cross-compiler.
images Stores the finally generated firmware image files. rootfs.ext4 is the Buildroot system image and can be directly replaced.
scripts Contains various script files used by Buildroot. Used for automated building, configuring the environment, or handling specific tasks.
staging Contains header files, library files, and other development-related files of the target system. Required during the cross-compilation process.
target Contains the complete content of the root file system (rootfs) on the target device. Only contains files required at runtime and does not include development-related header files or libraries.

After compilation, it will be directly packaged into update.img.

Note: Many problems may occur during this process, such as the inability to obtain packages due to network timeouts, insufficient number of threads during compilation, insufficient memory, or insufficient swap partition. Non-software-source-code-related problems are generally considered from these aspects. Remember not to use sudo with root privileges.

2.4. Adding System Tools or Required Library Files to the Buildroot System

Here, take OpenCV4 as an example:

①. Enter the Buildroot directory and compile forlinx_ok3588_defconfig

make forlinx_ok3588_defconfig

②. Open the menuconfig graphical interface and select the projects need to be compiled.

make menuconfig ARCH=arm64

How to Build a Buildroot File System and Add System Tools on the OK3588-C Platform?

Options Usage
Target options Configure the architecture and hardware parameters of the target device.
Build options Configure the build behavior of Buildroot.
Toolchain Configure the cross-compilation toolchain
System configuration Configure the cross-compilation toolchain.
Kernel Configure the Linux kernel.
Target packages Select the software packages to be installed on the target system.
Filesystem images Configure the type of the generated file system image.
Bootloaders Configure the bootloaders (e.g., U-Boot, GRUB).
Host utilities Configure the tools running on the host.
Legacy config options Handle deprecated or obsolete configuration options.

If OpenCV4 is needed now, directly search in the visual list, check the required configuration items, save them, and generate a new.config file.

③ Compilation

Compile the tool package separately

make opencv4

Full compilation

Directly execute make

make

④ After the full compilation is completed, Buildroot will add the executable and dependent

libraries of OpenCV4 to the target file system, which will be present in buildroot/output/forlinx_ok3588/image/rootfs.ext4.

At the same time, Buildroot will copy the library files dependent on OpenCV4 compilation to the toolchain, which is the host directory under buildroot/output/forlinx_ok3588 mentioned above. If necessary, you can package the compiler for use.

Usage: You can deploy the cross-compilation environment by directly setting the environment variables in the environment-setup file under the host directory.

source environment-setup

⑤ Save the current configuration to defconfig

It is recommended to make a backup and keep the original forlinx_ok3588_defconfig.

make savedefconfig

2.5. Replacement and Transplantation

Generally, the cross-compilation tool and the generated file system image are used, which are under:

buildroot/output/forlinx_ok3588/host 
buildroot/output/forlinx_ok3588/image/rootfs.ext4



Dear friends, we have created an exclusive embedded technical exchange group on Facebook, where our experts share the latest technological trends and practical skills. Join us and grow together!