Machine Configuration
All CI behavior is controlled by .github/machines.json. Adding, removing, or reconfiguring a machine means editing this file and regenerating the workflows — no manual YAML editing required.
machines.json Schema
{
"yocto_branch": "scarthgap",
"machines": [
{
"name": "raspberrypi-armv8",
"config": "kas/machines/raspberrypi-armv8.yaml:kas/scarthgap.yaml:...",
"workflows": ["manual", "tag", "onpush"],
"build_target": "pantavisor-starter",
"output": "pantavisor-starter*.rootfs.wic*",
"sdk": 1
}
]
}
| Field | Required | Description |
|---|---|---|
yocto_branch | yes | Yocto release name; used as a suffix in all generated file names |
name | yes | Machine identifier; combined with yocto_branch in workflow jobs |
config | yes | Colon-separated KAS config fragments to compose for this machine |
workflows | yes | Which workflow types to generate: manual, onpush, tag |
build_target | no | BitBake target (default: pantavisor-starter) |
output | no | Glob for artifacts to collect (default: pantavisor-starter*.rootfs.wic*) |
sdk | no | Set to 1 to also run bitbake -c populate_sdk |
Workflow Types
| Type | File generated | Trigger | Build engine |
|---|---|---|---|
tag | release.yaml | tag push via tag-scarthgap.yaml | buildkas-upload.yaml (build + S3) |
onpush | onpush-scarthgap.yaml | push to master | buildkas-target.yaml (build only) |
manual | manual-scarthgap.yaml | workflow_dispatch | buildkas-target.yaml (build only) |
Machines with only ["manual"] are never built automatically. The colibri-imx6ull is an example — it requires hardware-specific handling not suitable for general CI.
Regenerating Workflows
After any change to machines.json:
.github/scripts/makemachines # flatten KAS fragments → kas/build-configs/release/
.github/scripts/makeworkflows # regenerate onpush-*, manual-*, release.yaml
Always commit machines.json together with the generated files.
tag-scarthgap.yamlis not regenerated — it is a static orchestrator. Edit it directly when the tag trigger logic needs to change.
Adding a Machine
- Add an entry to
.github/machines.jsonwithname,config,workflows, and any optional fields. - Add the KAS machine fragment at
kas/machines/<name>.yamlif it does not exist. - Run
makemachines && makeworkflows. - Verify the generated
kas/build-configs/release/<name>-scarthgap.yamllooks correct. - Commit all four pieces:
machines.json, the KAS fragment, the release config, and the updated workflow files.
KAS Config Composition
The config field is a colon-separated list of KAS YAML fragments that kas build merges in order:
kas/machines/<board>.yaml # board-specific BSP layers and MACHINE
kas/scarthgap.yaml # Yocto release pins
kas/bsp-base.yaml # common BSP distro settings
kas/build-configs/build-base-starter.yaml # image target and features
Some machines add extra fragments:
kas/scarthgap-nxp.yaml— NXP proprietary layer pinskas/scarthgap-var.yaml— Variscite BSP pinskas/with-lxc-next.yaml— LXC 6.x instead of LXC 3.x
makemachines resolves each fragment's SRCREV pins and writes a single self-contained kas/build-configs/release/<name>-scarthgap.yaml that can reproduce the build without network access to layer repos.
Automated Machine Updates
schedule-updatemachines.yaml runs every 8 hours (offset by 15 minutes from schedule-updates.yaml) and executes makemachines && makeworkflows inside the KAS container. If the output differs from HEAD, it opens a PR on autopr/machine-update-master-next.