This shows you the differences between two versions of the page.
| Both sides previous revision Previous revision Next revision | Previous revision | ||
|
products:sbc:common:development:build-ubuntu [2022/07/04 23:54] nick |
products:sbc:common:development:build-ubuntu [2022/08/07 22:18] (current) ruby [Add User to a Docker Group] |
||
|---|---|---|---|
| Line 1: | Line 1: | ||
| - | ====== Build Ubuntu | + | ====== Build Ubuntu ====== |
| ===== Introduction ===== | ===== Introduction ===== | ||
| - | We provided | + | We provide |
| - | You can follow the steps below to build the Ubuntu OS image. | + | You can follow the steps below: |
| - | ===== Host Setup ===== | + | ===== Preparation |
| - | Install | + | Install |
| - | ``` | + | ```shell |
| - | sudo apt update | + | $ sudo apt update |
| - | sudo apt install git make lsb-release qemu-user-static | + | $ sudo apt install git make lsb-release qemu-user-static |
| ``` | ``` | ||
| ===== Get Fenix Source Code ===== | ===== Get Fenix Source Code ===== | ||
| - | Clone the Fenix repository to somewhere, e.g. `~/project` | + | Clone the Fenix repository to somewhere, e.g. '' |
| - | ``` | + | ```shell |
| - | mkdir ~/project | + | $ mkdir ~/project |
| - | cd ~/ | + | $ cd ~/ |
| - | git clone --depth 1 https:// | + | $ git clone --depth 1 https:// |
| ``` | ``` | ||
| Line 30: | Line 30: | ||
| You should setup the build environment first. \\ | You should setup the build environment first. \\ | ||
| - | For example: '' | + | For example: '' |
| - | ``` | + | ```shell |
| - | cd ~/ | + | $ cd ~/ |
| - | source env/ | + | $ source env/ |
| ``` | ``` | ||
| Line 40: | Line 40: | ||
| Just type '' | Just type '' | ||
| - | |||
| - | ``` | ||
| - | make | ||
| - | ``` | ||
| <WRAP tip > | <WRAP tip > | ||
| - | If this is your first time building | + | If it's the first time to build an image, the script will check your host's environment and install some essential packages. In addition, repositories (U-Boot, Linux) will be cloned automatically from the Khadas GitHub. |
| </ | </ | ||
| + | ===== Other Build Commands ===== | ||
| - | ===== Build U-Boot ===== | ||
| - | ``` | + | ==== Build U-Boot ==== |
| - | make uboot | + | |
| + | ```shell | ||
| + | $ make uboot | ||
| ``` | ``` | ||
| - | ===== Build U-Boot Debian Package | + | ==== Build U-Boot Debian Package ==== |
| - | ``` | + | ```shell |
| - | make uboot-deb | + | $ make uboot-deb |
| ``` | ``` | ||
| - | ===== Build Linux ===== | + | ==== Build Linux ==== |
| - | ``` | + | ```shell |
| - | make kernel | + | $ make kernel |
| ``` | ``` | ||
| - | ===== Build Linux Debian Package | + | ==== Build Linux Debian Package ==== |
| - | ``` | + | ```shell |
| - | make kernel-deb | + | $ make kernel-deb |
| ``` | ``` | ||
| - | ===== Build GPU Debian Package | + | ==== Build GPU Debian Package ==== |
| - | ``` | + | ```shell |
| - | make gpu-deb | + | $ make gpu-deb |
| ``` | ``` | ||
| - | ===== Build the Board Debian Package | + | ==== Build the Board Debian Package ==== |
| - | ``` | + | ```shell |
| - | make board-deb | + | $ make board-deb |
| ``` | ``` | ||
| - | ===== Build all Debian Packages | + | ==== Build all Debian Packages ==== |
| - | ``` | + | ```shell |
| - | make debs | + | $ make debs |
| ``` | ``` | ||
| - | ===== Build U-Boot Image ===== | + | ==== Build U-Boot Image ==== |
| - | ``` | + | ```shell |
| - | make uboot-image | + | $ make uboot-image |
| ``` | ``` | ||
| - | ===== Clean Linux Source Tree ===== | + | ==== Clean Linux Source Tree ==== |
| - | ``` | + | ```shell |
| - | make kernel-clean | + | $ make kernel-clean |
| ``` | ``` | ||
| - | ===== Show Linux Menuconfig | + | ==== Show Linux Menuconfig ==== |
| - | ``` | + | ```shell |
| - | make kernel-config | + | $ make kernel-config |
| ``` | ``` | ||
| - | ===== Save Linux Defconfig | + | ==== Save Linux Defconfig ==== |
| - | ``` | + | ```shell |
| - | make kernel-saveconfig | + | $ make kernel-saveconfig |
| ``` | ``` | ||
| - | ===== Clean U-Boot Source Tree ===== | + | ==== Clean U-Boot Source Tree ==== |
| - | ``` | + | ```shell |
| $ make uboot-clean | $ make uboot-clean | ||
| ``` | ``` | ||
| - | ===== Help Messages | + | ==== Help Messages ==== |
| You can get help messages by executing '' | You can get help messages by executing '' | ||
| - | ``` | + | ```shell |
| - | make help | + | $ make help |
| Fenix scripts help messages: | Fenix scripts help messages: | ||
| all - Create image according to environment. | all - Create image according to environment. | ||
| Line 151: | Line 149: | ||
| ``` | ``` | ||
| - | ===== Build Options | + | ==== Build Options ==== |
| Options for building: | Options for building: | ||
| * '' | * '' | ||
| - | * Enable ccache (default) | + | * '' |
| - | * NO_CCACHE=no make | + | * '' |
| - | * Disable ccache | + | |
| - | * NO_CCACHE=yes make | + | |
| * '' | * '' | ||
| - | * Don't compress | + | * '' |
| - | * COMPRESS_IMAGE=no make | + | * '' |
| - | * Compress image with xz | + | |
| - | * COMPRESS_IMAGE=yes make | + | |
| * '' | * '' | ||
| - | * Develop build | + | * '' |
| - | * BUILD_TYPE=develop make | + | * '' |
| - | * Release build | + | |
| - | * BUILD_TYPE=release make | + | |
| - | ===== Build Fenix in Docker ===== | + | ===== Build in Docker ===== |
| - | Fenix is supported by Docker. We provide a `Ubuntu 20.04` build host, so you can build all images | + | You can also choose to build the OS image in a Docker |
| - | #### Install Docker | + | ==== Install Docker |
| - | Please refer to [Docker Documentation](https:// | + | Please refer to [[https:// |
| - | #### Add User to a Docker Group | + | ==== Add User to a Docker Group ==== |
| - | ``` | + | ```shell |
| $ sudo usermod -aG docker $USER | $ sudo usermod -aG docker $USER | ||
| ``` | ``` | ||
| - | *Note: | + | <WRAP important > |
| + | You need to logout or reboot the system to take effect. | ||
| + | </ | ||
| - | #### Run Docker | + | |
| - | ``` | + | ==== Check Docker |
| + | |||
| + | ```shell | ||
| $ docker run hello-world | $ docker run hello-world | ||
| ``` | ``` | ||
| If you see the following print-out, Docker has installed successfully: | If you see the following print-out, Docker has installed successfully: | ||
| - | ``` | + | |
| + | ```txt | ||
| Unable to find image ' | Unable to find image ' | ||
| latest: Pulling from library/ | latest: Pulling from library/ | ||
| Line 223: | Line 220: | ||
| | | ||
| ``` | ``` | ||
| - | #### Run Fenix in Docker | + | |
| + | ==== Build Fenix in Docker | ||
| Get Docker image: | Get Docker image: | ||
| - | ``` | + | |
| + | ```shell | ||
| $ cd ~/ | $ cd ~/ | ||
| $ docker pull numbqq/ | $ docker pull numbqq/ | ||
| Line 231: | Line 231: | ||
| Build image in Docker: | Build image in Docker: | ||
| - | ``` | + | |
| + | ```shell | ||
| $ docker run -it --name fenix -v $(pwd):/ | $ docker run -it --name fenix -v $(pwd):/ | ||
| -v / | -v / | ||
| Line 241: | Line 242: | ||
| ``` | ``` | ||
| Start your build from inside the Docker container. | Start your build from inside the Docker container. | ||
| - | ``` | + | |
| + | ```shell | ||
| khadas@919cab43f66d: | khadas@919cab43f66d: | ||
| khadas@919cab43f66d: | khadas@919cab43f66d: | ||
| Line 248: | Line 250: | ||
| Restart the Docker container. | Restart the Docker container. | ||
| - | ```bash | + | ```shell |
| $ docker start fenix | $ docker start fenix | ||
| $ docker exec -ti fenix bash | $ docker exec -ti fenix bash | ||
| ``` | ``` | ||
| - | |||
| - | ### Get the Latest Nightly build | ||
| - | - See [Fenix](https:// | ||
| - | - Release Build, Test Build Ubuntu, Test Build Debian | ||
| - | ![image](/ | ||
| - | - You can see the firmware page when you click on the latest workflow | ||
| - | |||
| - | ### See Also | ||
| - | [Docker](https:// | ||