Convert Figma logo to code with AI

armbian logobuild

Armbian Linux build framework generates custom Debian or Ubuntu image for x86, aarch64, riscv64 & armhf

4,522
2,495
4,522
128

Top Related Projects

Buildroot, making embedded Linux easy. Note that this is not the official repository, but only a mirror. The official Git repository is at https://gitlab.com/buildroot.org/buildroot/. Do not open issues or file pull requests here.

22,214

This repository is a mirror of https://git.openwrt.org/openwrt/openwrt.git It is for reference only and is not active for check-ins. We will continue to accept Pull Requests here. They will be merged via staging trees then into openwrt.git.

2,322

Craft and deploy bulletproof embedded software in Elixir

Quick Overview

Armbian/build is an open-source project that provides a build framework for creating custom Linux distributions for various ARM-based single-board computers (SBCs). It allows users to generate tailored operating systems for a wide range of ARM devices, including popular boards like Raspberry Pi, Orange Pi, and many others.

Pros

  • Supports a wide variety of ARM-based devices
  • Highly customizable, allowing users to create tailored distributions
  • Active community and regular updates
  • Comprehensive documentation and user guides

Cons

  • Steep learning curve for beginners
  • Build process can be time-consuming and resource-intensive
  • Some devices may have limited support or require additional configuration
  • Requires Linux environment for building (not natively supported on Windows or macOS)

Getting Started

To get started with Armbian/build:

  1. Clone the repository:

    git clone https://github.com/armbian/build.git
    
  2. Install dependencies (Ubuntu/Debian example):

    sudo apt-get install -y build-essential bc bison flex libssl-dev python3 swig
    
  3. Configure your build:

    cd build
    ./compile.sh
    
  4. Follow the interactive prompts to select your target board and desired options.

  5. Wait for the build process to complete. The resulting image will be in the output/images directory.

For more detailed instructions and advanced usage, refer to the official documentation at https://docs.armbian.com/.

Competitor Comparisons

Buildroot, making embedded Linux easy. Note that this is not the official repository, but only a mirror. The official Git repository is at https://gitlab.com/buildroot.org/buildroot/. Do not open issues or file pull requests here.

Pros of Buildroot

  • More flexible and customizable for a wider range of embedded systems
  • Supports a larger number of architectures and platforms
  • Extensive documentation and active community support

Cons of Buildroot

  • Steeper learning curve for beginners
  • Longer build times for complex configurations
  • Less focus on specific single-board computers (SBCs)

Code Comparison

Armbian build script example:

compile_uboot() {
    local uboot_dir="$SRC/u-boot"
    cd "${uboot_dir}" || exit_with_error "Cannot change directory to u-boot"
    make ARCH=arm CROSS_COMPILE="$CCACHE $UBOOT_COMPILER" "$UBOOT_TARGET" -j${NCPU}
}

Buildroot Makefile example:

define UBOOT_BUILD_CMDS
    $(TARGET_MAKE_ENV) $(MAKE) -C $(@D) $(UBOOT_MAKE_OPTS)
endef

Both projects use build scripts, but Buildroot's approach is more generalized and integrated into its build system, while Armbian's scripts are more specific to its supported platforms.

22,214

This repository is a mirror of https://git.openwrt.org/openwrt/openwrt.git It is for reference only and is not active for check-ins. We will continue to accept Pull Requests here. They will be merged via staging trees then into openwrt.git.

Pros of OpenWrt

  • More focused on networking and router-specific features
  • Larger community and ecosystem of packages
  • Better support for a wide range of network devices

Cons of OpenWrt

  • Steeper learning curve for non-networking enthusiasts
  • Less flexible for general-purpose computing tasks
  • More complex build system for custom images

Code Comparison

OpenWrt (Makefile):

include $(TOPDIR)/rules.mk

PKG_NAME:=example
PKG_VERSION:=1.0
PKG_RELEASE:=1

include $(INCLUDE_DIR)/package.mk

define Package/example
  SECTION:=utils
  CATEGORY:=Utilities
  TITLE:=Example package
endef

define Package/example/install
    $(INSTALL_DIR) $(1)/usr/bin
    $(INSTALL_BIN) $(PKG_BUILD_DIR)/example $(1)/usr/bin/
endef

$(eval $(call BuildPackage,example))

Armbian (build.sh):

#!/bin/bash
set -e

# build
compile_uboot
compile_kernel
compile_rootfs

# create image
create_image

# cleanup
cleanup

Both projects use different build systems and approaches, reflecting their distinct focuses on networking (OpenWrt) and general-purpose Linux distributions (Armbian).

2,322

Craft and deploy bulletproof embedded software in Elixir

Pros of Nerves

  • Focused on embedded systems and IoT applications, providing a more specialized environment
  • Utilizes Elixir, offering functional programming benefits and concurrency features
  • Streamlined firmware creation and OTA updates for embedded devices

Cons of Nerves

  • Limited to Elixir ecosystem, potentially restricting language choices
  • Steeper learning curve for developers not familiar with Elixir or functional programming
  • Smaller community compared to Armbian, potentially resulting in fewer resources and support options

Code Comparison

Nerves (mix.exs):

def deps do
  [
    {:nerves, "~> 1.7", runtime: false},
    {:nerves_system_rpi3, "~> 1.13", runtime: false, targets: :rpi3}
  ]
end

Armbian (build-all.sh):

for board in "${BOARD[@]}"; do
  ./compile.sh BOARD="$board" BRANCH="$BRANCH" RELEASE="$RELEASE" \
    BUILD_MINIMAL="yes" BUILD_DESKTOP="no" KERNEL_ONLY="no" \
    KERNEL_CONFIGURE="no" COMPRESS_OUTPUTIMAGE="sha,gpg,7z"
done

The Nerves code snippet shows dependency management for a Nerves project, while the Armbian code demonstrates a build script for compiling multiple board configurations.

Convert Figma logo designs to code with AI

Visual Copilot

Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.

Try Visual Copilot

README

Armbian logo
Armbian Linux Build Framework

GitHub contributors Artifacts generation GitHub last commit (branch)

What does this project do?

  • Builds custom kernel, image or a distribution optimized for low-resource hardware,
  • Include filesystem generation, low-level control software, kernel image and bootloader compilation,
  • Provides a consistent user experience by keeping system standards across different platforms.

Getting started

Requirements for self hosted

  • x86_64 / aarch64 machine
  • at least 2GB of memory and ~35GB of disk space for VM, container or bare metal installation
  • Armbian / Ubuntu Jammy 22.04.x for native building or any Docker capable Linux for containerised
  • Windows 10/11 with WSL2 subsystem running Ubuntu Jammy 22.04.x
  • Superuser rights (configured sudo or root access).
  • Make sure your system is up-to-date! Outdated Docker binaries, for example, can cause trouble.

For stable branch use --branch=v25.02

apt-get -y install git
git clone --depth=1 --branch=main https://github.com/armbian/build
cd build
./compile.sh

Armbian logo

  • Interactive graphical interface.
  • Prepares the workspace by installing the necessary dependencies and sources.
  • It guides the entire process and creates a kernel package or a ready-to-use SD card image.

Build parameter examples

Show work-in-progress areas in interactive mode:

./compile.sh EXPERT="yes"

Build minimal CLI Armbian Jammy for Bananapi M5 with LTS kernel:

./compile.sh \
BOARD=bananapim5 \
BRANCH=current \
RELEASE=jammy \
BUILD_MINIMAL=yes \
BUILD_DESKTOP=no \
KERNEL_CONFIGURE=no

Build with GitHub actions: (advanced version)

name: "Build Armbian"
on:
  workflow_dispatch:
jobs:
  build-armbian:
    runs-on: ubuntu-latest
    steps:
      - uses: armbian/build@main
        with:
          armbian_token:     "${{ secrets.GITHUB_TOKEN }}"  # GitHub token
          armbian_release:   "jammy"                        # userspace
          armbian_target:    "build"                        # build=image, kernel=kernel
          armbian_board:     "bananapim5"                   # build target

Generated image will be uploaded to your repository release. Note: GitHub upload file limit is 2Gb.

More information:

Download prebuilt images releases

Point

Rolling

Compared with industry standards

Expand Check similarities, advantages and disadvantages compared with leading industry standard build software.
FunctionArmbianYoctoBuildroot
Targetgeneral purposeembeddedembedded / IOT
U-boot and kernelcompiled from sourcescompiled from sourcescompiled from sources
Board support maintenance  completeoutsideoutside
Root file systemDebian or Ubuntu basedcustomcustom
Package managerAPTanynone
Configurabilitylimitedlargelarge
Initramfs supportyesyesyes
Getting startedquickvery slowslow
Cross compilationyesyesyes

Project structure

Expand
├── cache                                Work / cache directory
│   ├── aptcache                         Packages
│   ├── ccache                           C/C++ compiler
│   ├── docker                           Docker last pull
│   ├── git-bare                         Minimal Git
│   ├── git-bundles                      Full Git
│   ├── initrd                           Ram disk
│   ├── memoize                          Git status
│   ├── patch                            Kernel drivers patch
│   ├── pip                              Python
│   ├── rootfs                           Compressed userspaces
│   ├── sources                          Kernel, u-boot and other sources
│   ├── tools                            Additional tools like ORAS
│   └── utility
├── config                               Packages repository configurations
│   ├── targets.conf                     Board build target configuration
│   ├── boards                           Board configurations
│   ├── bootenv                          Initial boot loaders environments per family
│   ├── bootscripts                      Initial Boot loaders scripts per family
│   ├── cli                              CLI packages configurations per distribution
│   ├── desktop                          Desktop packages configurations per distribution
│   ├── distributions                    Distributions settings
│   ├── kernel                           Kernel build configurations per family
│   ├── sources                          Kernel and u-boot sources locations and scripts
│   ├── templates                        User configuration templates which populate userpatches
│   └── torrents                         External compiler and rootfs cache torrents
├── extensions                           Extend build system with specific functionality
├── lib                                  Main build framework libraries
│   ├── functions
│   │   ├── artifacts
│   │   ├── bsp
│   │   ├── cli
│   │   ├── compilation
│   │   ├── configuration
│   │   ├── general
│   │   ├── host
│   │   ├── image
│   │   ├── logging
│   │   ├── main
│   │   └── rootfs
│   └── tools
├── output                               Build artifact
│   └── deb                              Deb packages
│   └── images                           Bootable images - RAW or compressed
│   └── debug                            Patch and build logs
│   └── config                           Kernel configuration export location
│   └── patch                            Created patches location
├── packages                             Support scripts, binary blobs, packages
│   ├── blobs                            Wallpapers, various configs, closed source bootloaders
│   ├── bsp-cli                          Automatically added to armbian-bsp-cli package
│   ├── bsp-desktop                      Automatically added to armbian-bsp-desktopo package
│   ├── bsp                              Scripts and configs overlay for rootfs
│   └── extras-buildpkgs                 Optional compilation and packaging engine
├── patch                                Collection of patches
│   ├── atf                              ARM trusted firmware
│   ├── kernel                           Linux kernel patches
|   |   └── family-branch                Per kernel family and branch
│   ├── misc                             Linux kernel packaging patches
│   └── u-boot                           Universal boot loader patches
|       ├── u-boot-board                 For specific board
|       └── u-boot-family                For entire kernel family
├── tools                                Tools for dealing with kernel patches and configs
└── userpatches                          User: configuration patching area
    ├── lib.config                       User: framework common config/override file
    ├── config-default.conf              User: default user config file
    ├── customize-image.sh               User: script will execute just before closing the image
    ├── atf                              User: ARM trusted firmware
    ├── kernel                           User: Linux kernel per kernel family
    ├── misc                             User: various
    └── u-boot                           User: universal boot loader patches

Contribution

Want to help?

We always need those volunteering positions:

Just apply and follow!

Support

For commercial or prioritized assistance:

Free support:

Find free support via general project search engine, documentation, community forums or IRC/Discord. Remember that our awesome community members mainly provide this in a best-effort manner, so there are no guaranteed solutions.

Contact

Contributors

Thank you to all the people who already contributed to Armbian!

Also

Armbian Partners

Armbian's partnership program helps to support Armbian and the Armbian community! Please take a moment to familiarize yourself with our Partners:

Star History

Star History Chart

License

This software is published under the GPL-2.0 License license.