为Nitrogen i.MX6开发板构建一个Ubuntu Core 18的镜像
by liam zheng on 6 July 2020
本篇博文由Taiten Peng编写
您有i.MX6硬件吗?并且想知道如何在其上面运行Ubuntu Core?在这篇博客中,我们将为一款基于i.MX6的边缘设备构建一个带有Ubuntu通用内核的Ubuntu Core 18镜像。
上游对边缘设备中Nitrogen6X硬件支持很友好,并且内核补丁已经合并到Ubuntu 4.15 LTS内核中。这使得你可以创建一个Ubuntu Core 18的镜像,和体验Canonical官方的内核。
准备工作
参考硬件:2G内存版本Nitrogen6X
工具——构建环境
- 主机OS:Ubuntu 18.04 LTS 64位
- 工具:ubuntu-image, snapcraft
通过以下的命令安装ubuntu-image和snapcraft。
sudo snap install --classic ubuntu-image sudo
snap install --classic snapcraft
基础理解概览
为了构建一个Ubuntu Core镜像,需要准备一些例如gadget snap或者已签名的型号申明文件的基础组件。内核snap也是需要,从技术角度来说,在Nitrogen6X平台上没有必要一定是自定义内核snap。
为i.MX6构建一个自定义Ubuntu Core镜像
用Nitrogen6X硬件为例。
构建一个gadget snap
带有上游u-boot源代码的Nitrogen6q2g板子的示例gadget snap可参考
创建一个型号申明和签名
Example model json file
{
"type": "model",
"authority-id": "YOUR_ID",
"brand-id": "YOUR_ID",
"series": "16",
"base": "core18",
"model": "nitrogen6x",
"architecture": "armhf",
"gadget": "nitrogen6",
"kernel": "pc-kernel=18",
"timestamp": "2019-06-21T08:56:10+00:00"
}
更多关于创建型号申明文件和签名的内容可阅读此教程。
构建一个Ubuntu Core 18镜像
sudo ubuntu-image --snap YOUR_GADGET_SNAP.snap -o nitrogen6x.img YOUR_MODEL_ASSERTION.model
对应的命令如下:
ubuntu-image --snap nitrogen6x-gadget-snap/nitrogen6_18-0.1_armhf.snap -o nitrogen6x.img nitrogen6x.model
安装和启动
刷写bootloader
Nitrogen6X不会从SD卡或者USB启动booloader,您需要执行下面步骤来更新SPI Flash。
开机,然后使用下面命令进入u-boot:
fatload mmc 0:1 0x13000000 u-boot.imx;sf probe;sf erase 0 0xc2000;sf write 0x13000000 0x400 ${filesize}
更新u-boot环境变量……
此脚本从gadget snap中的uboot.env文件加载了一个所需的环境设置来引导启动Ubuntu Core。
在重置后,系统将会启动并进入Ubuntu Core 18。


初始化启动控台需要您创建一个网络和您的Ubuntu账号。请注意,您需要创建一个Ubuntu SSO账号和上传您的SSH公匙以确保能访问Ubuntu Core设备。
进阶:构建一个自定义Ubuntu内核
需要注意的是,在构建镜像时使用自定义内核。内核snap将不能收到snap商店的任何更新。
如您想要在Ubuntu内核上尝试一些实验性的内核补丁。(例如为其他的i.MX6板子添加支持)
获取源代码:https://kernel.ubuntu.com/git/ubuntu/ubuntu-bionic.git/
您也许需要添加下面的补丁来整合额外的内核模块到内核snap的initrd.img文件中。
diff --git a/snapcraft.yaml b/snapcraft.yaml
index 2452c4031066..e4a94c3059fd 100644
--- a/snapcraft.yaml
+++ b/snapcraft.yaml
@@ -17,6 +17,24 @@ parts:
kconfigflavour: generic
kconfigs:
- CONFIG_DEBUG_INFO=n
+ kernel-initrd-modules:
+ - usb-storage
+ - nls_iso8859-1
使用下面命令构建内核snap:
snapcraft --target-arch=armhf
下一步
订阅博客文章
查看更多内容
快速推进 Renesas RZ 平台上的工业与 AI 部署
已认证的 Ubuntu 24.04 LTS 镜像现已可用 Canonical 欣然宣布,面向 Renesas RZ/G2L 和 RZ/G2LC 64 位微处理器(MPU)平台的已认证 Ubuntu 24.04 LTS 及 Ubuntu Core 24 镜像现已正式发布通用(GA)版本。借助可直接用于生产环境的 Ubuntu 版本,用户可获得企业级安全保障、长期技术支持,并充分启用 Renesas RZ/G 系列丰富的多媒体功能。 除面向 RZ/G2L 和 RZ/G2LC 的 GA 发布外,Canonical 同时推出适用于 Renesas RZ/V2L 平台的 Ubuntu 镜像,并提供 AI Snap 教程,用于在 Ubuntu 上部署 Renesas AI 应用。该镜 […]
推出面向 Ubuntu Core 22 的 FIPS 140-3
随着面向 Ubuntu 22.04 LTS 的FIPS 140-3认证加密模块的发布,Canonical 延续其长期传统,助力客户将 Ubuntu 部署到美国联邦市场。FIPS 140-3 是美国国家标准与技术研究院(NIST)制定的一项标准,规定了如何安全使用加密技术,其中包含一套严格的认证流程,以确保加密实施的正确性。Ubuntu 22.04 LTS 加密库已通过该流程,现在可通过 Ubuntu Pro 订阅使用。 作为该认证流程的一部分,我们首次将 Ubuntu Core 纳入完全认证的操作环境,从 Ubuntu Core 22 开始,并将在未来的 FIPS 认证中持续支持 Ubuntu Core。在本文中,我们将介绍什么是 Ubuntu Core,以及如何将其与 […]
Canonical 发布 Ubuntu 26.04 LTS Resolute Raccoon
Ubuntu 为企业工作负载提供深度芯片优化与前沿安全防护(第 11 个长期支持版本)。 2026 年 4 月 23 日,Canonical 正式发布代号为 “Resolute Raccoon” 的 Ubuntu 26.04 LTS,用户可通过 Ubuntu 下载页面进行下载并安装。 Resolute Raccoon 在过渡版本推出的高稳定性优化基础上进一步升级,支持 TPM 硬件全盘加密、优化应用权限弹窗提示功能、为基于 Arm® 架构的服务器提供 Livepatch 实时补丁更新,并采用基于 Rust 语言的工具以提升内存安全性。该版本原生支持 NVIDIA CUDA、AMD ROCm 等行业领先的 AI/ML 工具包,使 Ubuntu 26.04 LTS 成为 AI […]