Solution Management
This document introduces SpacemiT's solution management for the OpenWrt SDK. The current released SDK supports the k1-sbc, which supports for multiple board types; for example, the k1-sbc solution supports the k1-x_MUSE-Pi and k1-x_deb1 board types. Further updates will be released in the future.
Solution Overview
Using the development board solution k1-sbc as an example, it typically involves the following configuration files, which will be introduced in subsequent sub-sections.
#Solution Configuration
feeds/spacemit_openwrt_feeds/spacemit_k1_defconfig
#olution Compilation Entry Point
openwrt/target/linux/spacemit/Makefile
#Solution Definition
openwrt/target/linux/spacemit/k1-sbc/config-6.1
openwrt/target/linux/spacemit/k1-sbc/target.mk
openwrt/target/linux/spacemit/k1-sbc/base-files/
#Solution Device Tree Management
openwrt/target/linux/spacemit/dts/
#Solution Boot Parameters
openwrt/target/linux/spacemit/image/env_k1-x.txt
#Firmware Definition
openwrt/target/linux/spacemit/image/k1-sbc.mk
#Firmware Partitions for the Solution
openwrt/target/linux/spacemit/image/partition_tables/partition_2M.json
openwrt/target/linux/spacemit/image/partition_tables/partition_flash.json
openwrt/target/linux/spacemit/image/partition_tables/partition_universal.json
#Initial Setup Configuration for the Solution
openwrt/target/linux/spacemit/base-files/etc/uci-defaults/
Configuration for the Solution
feeds/spacemit_openwrt_feeds/spacemit_k1_defconfig
This file contains the build configuration for the k1-sbc solution and guides the compilation process of OpenWrt.
Makefile for the Solution
openwrt/target/linux/spacemit/Makefile
Add the name of the solution to SUBTARGETS:
    ...
 12 SUBTARGETS:=k1-nas k1-sbc
    ...
Directory for the Solution
openwrt/target/linux/spacemit/k1-sbc
Create a directory with the same name as the solution: k1-sbc, containing the following:
- 
openwrt/target/linux/spacemit/k1-sbc/config-6.1config-6.1is the kernel configuration for this solution. When compiling the kernel, mergeopenwrt/target/linux/generic/config-6.1with this solution'sconfig-6.1, giving priority to the options specified here.
- 
openwrt/target/linux/spacemit/k1-sbc/target.mkDefines general information for the solution, such as DEVICE_TYPE:=router(optional values include router, nas). This is defined by OpenWrt, where different device types include different default packages.
- 
openwrt/target/linux/spacemit/k1-sbc/base-files/Contains configuration files to be packaged into the root file system, such as: 
openwrt/target/linux/spacemit/k1-sbc/base-files$ tree
.
├── etc
│   ├── board.d
│   │   ├── 01_leds
│   │   └── 02_network
│   ├── hostapd.conf
│   ├── hosts
│   ├── init.d
│   │   └── custom_wifi_ap
│   └── inittab
├── lib
│   ├── preinit
│   │   └── 79_move_config
│   └── upgrade
│       └── platform.sh
└── usr
    └── bin
        ├── uas-gadget2-bot.sh
        ├── uas-gadget2.sh
        └── uas-gadget3.sh
8 directories, 11 files
Device Tree for the Solution
openwrt/target/linux/spacemit/dts/
Kernel device trees for various board types are stored here. To add support for a new board type, please refer to Device Management
Partition Table for the Solution
openwrt/target/linux/spacemit/image/partition_tables/
This directory contains partition tables that are shared across multiple solutions. These partition tables define configurations for various storage media.
It is possible to add a new partition table that matches the capacity of the onboard storage device. When flashing firmware using the Titan Flasher Tool, the appropriate partition table will be automatically selected:
- partition_2M.json— Used for NOR flash booting, typically paired with eMMC/SSD block devices
- partition_universal.json— Used for booting from block devices
- partition_flash.json— Used for mass production with the Titan Flasher Tool
Note: Modifying the partition table may affect the normal boot process of the system. For detailed modification instructions, please refer to refer to the Boot Develepment Guide.
Boot Parameters for the Solution
openwrt/target/linux/spacemit/image/env_k1-x.txt
This file defines U-Boot environment variables with the highest priority. It allows configuration of boot arguments (bootargs), loglevel, and other settings.
The default bootargs are:
commonargs=setenv bootargs earlycon=${earlycon} earlyprintk console=tty1 console=${console} loglevel=${loglevel} clk_ignore_unused swiotlb=65536 rdinit=${init}
The environment variables such as earlycon, console, loglevel, and init in env_k1-x.txt can be redefined.
# Common parameter
earlycon=sbi
console=ttyS0,115200
init=/init
bootdelay=0
loglevel=8
Alternatively, the entire bootargs can also redefined.
bootargs=earlycon=sbi console=ttyS0,115200 loglevel=4
Firmware for the Solution
openwrt/target/linux/spacemit/image/k1-sbc.mk
This Makefile configures the firmware compilation for the solution, including supported board types, generating sdcard.img, and creating the spacemit.zip flashing package.
For example, to skip generating sdcard.img, remove sdcard-img from IMAGE/pack.zip.
Another example, to add support for the MUSE-Pi board type within the current solution, include the device tree name k1-x_MUSE-Pi in DEVICE_DTS.
Additionally, ensure that a file named k1-x_MUSE-Pi.dts exists in openwrt/target/linux/spacemit/dts/.
# SPDX-License-Identifier: GPL-2.0-only
#
# Copyright (C) 2024 Spacemit Ltd.
define Device/debX
  DEVICE_VENDOR := Spacemit
  DEVICE_MODEL :=k1-x deb board
  DEVICE_DTS_DIR:= ../dts
  DEVICE_DTS := k1-x_deb1 k1-x_MUSE-Pi 
  SOC := KeyStone
  KERNEL_NAME := Image
  KERNEL_IMG := Image.itb
  KERNEL := kernel-bin | fit none
  IMAGES := pack.zip
  IMAGE/pack.zip := $(KERNEL_IMG) | boot-common | sdcard-img | archive-zip
endef
TARGET_DEVICES += debX
Initial Setup for the Solution
openwrt/target/linux/spacemit/base-files/etc/uci-defaults/
The defualt settings of the Unified Configuration interface (UCI) provide a mechanism to preconfigure the firmare image using UCI commands. Scripts placed in this directory will be executed automatically during the first boot to apply system defaults.
Adding a New Solution
Using the k1-sbc solution as an example, the following modifications are required:
- 
Update SUBTARGETS in openwrt/target/linux/spacemit/Makefileto include the solution name, such ask1-sbc
- 
Create a new directory for the solution, such as openwrt/target/linux/spacemit/k1-sbc/, and include the following files:openwrt/target/linux/spacemit/k1-sbc/config-6.1
 openwrt/target/linux/spacemit/k1-sbc/target.mk
- 
Add firmware compilation and compatible board support in openwrt/target/linux/spacemit/image/k1-sbc.mk
- 
Add a corresponding build configuration file in the feeds/spacemit_openwrt_feeds/directory, such asspacemit_k1_defconfigfor thek1-sbcsolution
Adding Support for New Board Types
Each solution should define at least one supported board type. To add support for additional board types, refer to Device Management for details.
U-Boot/OpenSBI Compilation Configurations
When new U-Boot/OpenSBI build configurations are required, the following modifications should be made:
uboot
- Add new compilation configurations in the U-Boot source repository, such as u-boot-2022.10/configs/k1_defconfig.
- Modify openwrt/package/boot/uboot-spacemit/Makefile:
 50 define Build/Configure
 51     $(MAKE) -C $(LOCAL_SOURCE_DIR) k1_defconfig
 52 endef
 53 
OpenSBI
- Add new compilation configurations in the OpenSBI source repository, such as opensbi-1.3/platform/generic/configs/k1_defconfig.
- Modify openwrt/package/boot/opensbi-spacemit/Makefile.
 59 define Build/Compile
 60     $(eval $(Package/opensbi_$(BUILD_VARIANT))) \
 61         +$(MAKE_VARS) $(MAKE) -C $(LOCAL_SOURCE_DIR) \
 62         PLATFORM=$(PLAT) PLATFORM_DEFCONFIG=k1_defconfig
 63 endef
 64