Try ubuntu core (by quqi99)

作者:张华 发表于:2024-07-20
版权声明:可以任意转载,转载时请务必以超链接形式标明文章原始出处和作者信息及本版权声明(http://blog.csdn.net/quqi99)

try ubuntu core on qemu

#ovmf is to ensure compatibility with the required UEFI features in ubuntu core
sudo apt install qemu-kvm ovmf
kvm-ok
#swtpm is to provide a TPM emulator
sudo snap install --edge test-snapd-swtpm
#Download ubuntu core - https://ubuntu.com/core/docs/supported-platforms
wget https://cdimage.ubuntu.com/ubuntu-core/24/stable/current/ubuntu-core-24-amd64.img.xz
xz -d ubuntu-core-24-amd64.img.xz
#With TPM emulation and full disk encryption
sudo qemu-system-x86_64 -enable-kvm -smp 1 -m 2048 -machine q35 -cpu host -global ICH9-LPC.disable_s3=1 \-net nic,model=virtio -net user,hostfwd=tcp::8022-:22,hostfwd=tcp::8090-:80  \-drive file=/usr/share/OVMF/OVMF_CODE.secboot.fd,if=pflash,format=raw,unit=0,readonly=on \-drive file=/usr/share/OVMF/OVMF_VARS.ms.fd,if=pflash,format=raw,unit=1 \-drive "file=/images/kvm/ubuntu-core-24-amd64.img",if=none,format=raw,id=disk1 \-device virtio-blk-pci,drive=disk1,bootindex=1 -serial mon:stdio
#https://login.ubuntu.com  and https://login.ubuntu.com/ssh-keys
ssh <your-name>@localhost -p 8022

try ubuntu core on raspberry pi

#download image from https://ubuntu.com/core/docs/supported-platforms , eg: ubuntu-core-24-arm64+raspi.img.xz
xz -d ubuntu-core-24-arm64+raspi.img.xz
sudo dd if=ubuntu-core-24-arm64+raspi.img of=/dev/sdb status=progress; sync

try ubuntu core on x64 computer

#dd to usb or disk
sudo dd if=/images/kvm/ubuntu-core-24-amd64.img of=/dev/sdb status=progress; sync

树霉派上的linux启动流程理论分析

注意:下面的过程只是我从网上做的一个理论分析,并没有做实验,只是想让自己大致心里清楚有些大致的步骤。

树莓派4b启动流程:romboot–>uboot–>kernel–>rootfs
1, 第一阶段bootloader, 上电后,加载bootrom(固化在芯片内部,4b之前通过EEPROM加载SD上的bootcode.bin)到GPU中运行来初始化PLL, DDR等
2, 第二阶段bootloader, 从SD/网络/USB等加载start4.elf, 接着读取config.txt去进行uboot的启动流程
3, 启动kernel

通过JTAG将uboot引导安装到开发板Nor Flash/BIOS中,有两类,一类是并口,一类是USB代替并口(/dev/ttyUSB0)
通过uboot将OS(如tftp)引导安装到开发板NAND Flash中
打开Raspberry Pi Imager烧录镜(romboot)像到SD中, 默认串口没有输出,需修改config.txt在末尾添加enable_uart=1
在这里插入图片描述
1, 交叉编译工具的安装与uboot的编译

wget https://releases.linaro.org/components/toolchain/binaries/latest-7/aarch64-linux-gnu/gcc-linaro-7.5.0-2019.12-x86_64_aarch64-linux-gnu.tar.xz
tar -xvf gcc-linaro-7.5.0-2019.12-x86_64_aarch64-linux-gnu.tar.xz -C /bak/soft/arm
alias crosscompiler='export KERNEL=kernel8;export ARCH=arm64;export CROSS_COMPILE=/bak/soft/arm/gcc-linaro-7.5.0-2019.12-x86_64_aarch64-linux-gnu/bin/aarch64-linux-gnu-'
git clone https://github.com/u-boot/u-boot.git
cp ./u-boot <your-sd>
git checkout v2020.04-rc3
sudo apt install u-boot-tools bison bc make flex libssl-dev ncurses-* -y
crosscompiler
make rpi_4_defconfig
make -j $(nproc)
cat << EOF |tee ./config.txt
ls u-boot.bin
arm_control=0x200  #64 bits
kernel=u-boot.bin
dtoverlay=disable-bt #If serial debugging is enabled, Bluetooth cannot be used
EOF下面是一个客户使用的config.txt, 本来无法进入ubuntu core内核,但改为dtoverlay=vc4-kms-v3d就修复了
[cm4]
otg_mode=1
[pi4]
kernel=uboot_rpi_4.bin
dtoverlay=vc4-fkms-v3d,cma-128
dtoverlay=dwc2,dr_mode=host
[pi3]
kernel=uboot_rpi_3.bin
dtoverlay=vc4-fkms-v3d,cma-128
max_framebuffers=2
[all]
arm_64bit=1
enable_uart=1

2, 编译树莓派Linux源代码, 并通过tftp加载kernel

git clone --branch rpi-5.6.y https://github.com/raspberrypi/linux
mkdir rpi_hw
make O=rpi_hw bcm2711_defconfig
make O=rpi_hw menuconfig
make O=rpi_hw -j $(nproc)
ls rpi_hw/arch/arm64/boot
sudo cp rpi_hw/arch/arm64/boot/Image /bak/tftp/

进入u-boot命令窗口(就像进入bios一样的, 可能需要在出现“Hit any key to stop autoboot: 3”时,按下空格键)后运行

sudo minicom -D /dev/ttyUSB0 -b 115200  #press power key
setenv ipaddr 10.1.1.100 #设置开发板的静态地址(自定义)
setenv serverip 10.1.1.160 #设置根文件系统的nfs服务器地址
setenv netmask 255.255.255.0
saveenv
reset
setenv kernel_addr_r 0x8000
setenv kernel Image
setenv netboot 'tftp ${kernel_addr_r} ${kernel} && booti ${kernel_addr_r} - ${fdtcontroladdr}'
setenv bootcmd 'run netboot'
setenv bootargs 'console=ttyAMA0'
saveenv
reset

设置cmdline, 可以用下列的u-boot命令设置,也可以在/run/mnt/ubuntu-seed/cmdline.txt中设置

setenv nfsroot /opt/nfs/
setenv bootargs "console=ttyAMA0,115200 root=/dev/nfs rw nfsroot=${serverip}:${nfsroot},v3,tcp ip=$ipaddr:$serverip::$netmask::eth0:off"
saveenv

搭建tftp服务器的步骤:

#windows client is Tftp64
sudo apt install tftpd-hpa tftp-hpa -y  
cat << EOF |tee /etc/default/tftpd-hpa
# /etc/default/tftpd-hpa
TFTP_USERNAME="tftp"
TFTP_DIRECTORY="/bak/tftp"
TFTP_ADDRESS=":69"
TFTP_OPTIONS="--secure --create"
EOF
sudo chown tftp:tftp /bak/tftp
sudo systemctl restart tftpd-hpa
echo 'test' |sudo tee /bak/tftp/test.txt
tftp 127.0.0.1 -c get test.txt

3, 从nfs文件系统中挂载根文件系统

sd里有两个分区,一个rootfs一个boot, 将boot分区的所有文件拷到file路径下
sudo cp <rootfs_in_sd> /opt/nfs/ -R
sudo mkdir -p /opt/nfs/file
sudo cp <all-files-in-boot> /opt/nfs/file/
sudo vim etc/fstab10.1.1.160:/opt/nfs/file /boot nfs defaults,vers=4.1,proto=tcp 0 0

Reference

[1] https://ubuntu.com/core/docs/testing-with-qemu
[2] https://blog.csdn.net/quqi99/article/details/80425722
[3] https://cloud.tencent.com/developer/article/1806436

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/49304.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Rust编程-高级特性

unsafe&#xff1a;内存不安全 内存安全问题&#xff0c;例如空指针解引用 关键字unsafe来切换到不安全模式&#xff0c;并在被标记后的代码块中使用不安全代码 使用unsafe告诉编译器后面代码安全性自行负责 因为电脑硬件安全问题&#xff0c;必须编写可能不安全的代码 可以将…

matlab--legend利用for循环添加图例

第一种方法 %% 第一种方法 R 1:4; THETA1 atand(R./1.8); legend_name {}; for i 1:4THETA atand(R(i)./1.8);intTheta floor(THETA);R_THERA 1.8 - (R(i)./tand(intTheta-10:intTheta10));R_THERA1 1.8 - (R(i)/tand(intTheta));plot(R_THERA);grid on;hold onlegend…

在字符串的 格式化 与 反格式化 中用到的 模块 和 方法

目录 一&#xff0c;Open函数使用 二&#xff0c;Json与pickle 一&#xff0c;json模块 1. 将 Python 对象转换为 JSON 字符串 2. 将 JSON 字符串解析为 Python 对象 3. 读取和写入 JSON 文件 4. 处理 JSON 中的特殊数据类型 5. 错误处理 二&#xff0c;pikel模块 1. …

领夹麦克风哪个品牌好,电脑麦克风哪个品牌好,热门麦克风推荐

​在信息快速传播的时代&#xff0c;直播和视频创作成为了表达与交流的重要方式。对于追求卓越声音品质的创作者而言&#xff0c;一款性能卓越的无线麦克风宛如一把利剑。接下来&#xff0c;我要为大家介绍几款备受好评的无线麦克风&#xff0c;这些都是我在实际使用中体验良好…

淘客返利系统中的服务发现与注册机制详解

淘客返利系统中的服务发现与注册机制详解 大家好&#xff0c;我是微赚淘客系统3.0的小编&#xff0c;是个冬天不穿秋裤&#xff0c;天冷也要风度的程序猿&#xff01;在本文中&#xff0c;我们将深入探讨淘客返利系统中的服务发现与注册机制&#xff0c;并结合Java代码进行详细…

【Linux常用命令】之sed命令

Linux常用命令之sed命令 文章目录 Linux常用命令之sed命令常用命令之sed背景介绍 总结 作者简介 听雨&#xff1a;一名在一线从事多年研发的程序员&#xff0c;从事网站后台开发&#xff0c;熟悉java技术栈&#xff0c;对前端技术也有研究&#xff0c;同时也是一名骑行爱好者。…

SpringBoot大模型流式接口

话不多说&#xff0c;直接上货 import cn.hutool.core.util.IdUtil; import com.alibaba.fastjson.JSONObject; import org.springframework.http.MediaType; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.Re…

人工智能(AI)在办公场所的广泛应用

人工智能&#xff08;AI&#xff09;在办公场所的广泛应用正逐步改变着我们的工作方式和效率。随着技术的进步&#xff0c;越来越多的公司和组织开始采用各种AI技术来优化工作流程、提升生产力&#xff0c;并提供更好的用户体验。以下是人工智能在办公方面的一些主要作用和影响…

linux学习笔记整理: 关于linux:nginx服务器 2024/7/20;

nginx服务器: 自理解: nginx是一种分发式服务器,统一进入的接口,并将进入的用户进行指定性分发给不同服务器地址交互; Nginx是一款轻量级的Web 服务器/反向代理服务器及电子邮件&#xff08;IMAP/POP3&#xff09;代理服务器&#xff0c;在BSD-like 协议下发行。其特点是占有内…

Java 如何获取一个 class 的所有属性和方法

&#x1f446;&#x1f3fb;&#x1f446;&#x1f3fb;&#x1f446;&#x1f3fb;关注博主&#xff0c;让你的代码变得更加优雅。 前言 Hutool 是一个小而全的Java工具类库&#xff0c;通过静态方法封装&#xff0c;降低相关API的学习成本&#xff0c;提高工作效率&#xf…

LeetCode 125.验证回文串 C++写法

LeetCode 125.验证回文串 C写法 思路&#x1f914;&#xff1a; 我们不对字符串进行删除&#xff0c;这样效率太低了&#xff0c;所以可以左右开工&#xff0c;下标begin和end遇到不是字母数字字符的就跳过&#xff0c;当两边都是字母就进行比对&#xff0c;一样就继续往后走&a…

sqlserver 跨服务器进行数据增删改查

--连接远程服务器 exec sp_addlinkedserver 目标服务器名&#xff08;自定义取名&#xff09;, , SQLOLEDB , 192.168.180.18&#xff08;目标服务器IP&#xff09; --登录远程服务器 exec sp_addlinkedsrvlogin 目标服务器名, false ,null, &#xff08;用户名&#xff09…

PCL 批量处理点云文件

系列文章目录 文章目录 系列文章目录前言一、PCL是什么&#xff1f;二、配置PCL环境三、使用步骤1.引入库2.主函数 总结 前言 点云处理时往往会需要对多个点云进行处理&#xff0c;比如在预处理&#xff0c;保存点云时。下面提供一个简单的点云批量转换例子&#xff0c;PCD文件…

Midjourney绘画提示词精选

Midjourney绘画提示词精选 在探索Midjourney这一强大的AI绘画工具时&#xff0c;选择合适的提示词是创作出令人惊艳作品的关键。这些提示词不仅能够帮助Midjourney理解你的创作意图&#xff0c;还能引导它生成出符合你期望的图像。以下是对Midjourney绘画提示词的精选与解析&a…

power bi 度量值相关函数

power bi 度量值相关函数 1. 度量值的好处2. 度量值上下文3. calculate() 函数4. 度量值存储方式 1. 度量值的好处 度量值不会增加一列&#xff0c;不会修改表格度量值自带筛选功能 2. 度量值上下文 新建行和新建度量值的区别 度量值是筛选上下文&#xff1a;度量值天生具有…

机器学习 | 阿里云安全恶意程序检测

目录 一、数据探索1.1 数据说明1.2 训练集数据探索1.2.1 数据特征类型1.2.2 数据分布1.2.3 缺失值1.2.4 异常值1.2.5 标签分布探索 1.3 测试集探索1.3.1 数据信息1.3.2 缺失值1.3.3 数据分布1.3.4 异常值 1.4 数据集联合分析1.4.1 file_id 分析1.4.2 API 分析 二、特征工程与基…

SimGCL和XSimGCL

SimGCL 动机 传统的SGL(图自监督学习)使得模型可以自行发掘任务特征,解决了数据稀疏和长尾分布的问题,SGL采用节点dropout、边dropout和随机游走三种方式对图结构进行扰动(图增强)进行对比学习,可以有效提高性能 SGL主要解决传统推荐系统面临的数据稀疏和长尾分布问题。…

k8s中pod创建过程

1&#xff0c;客户端向apiserver发起一个create pod请求 2&#xff0c;apiserver接收到pod创建请求后&#xff0c;生成一个包含创建信息的yaml 3&#xff0c;apiserver将yaml信息写入etcd数据库 4&#xff0c;根据scheduler调度器为pod分配node主机 5&#xff0c;node kubelet检…

无监督目标检测:挑战与机遇的双重奏

无监督目标检测&#xff1a;挑战与机遇的双重奏 无监督目标检测是计算机视觉领域中一个前沿且充满挑战的研究课题。它旨在无需大量标注数据的情况下&#xff0c;识别图像中的目标。这一技术的发展&#xff0c;对于减少人工标注成本、提高检测效率具有重要意义。本文将深入探讨…

2024中国大学生算法设计超级联赛(1)

&#x1f680;欢迎来到本文&#x1f680; &#x1f349;个人简介&#xff1a;陈童学哦&#xff0c;彩笔ACMer一枚。 &#x1f3c0;所属专栏&#xff1a;杭电多校集训 本文用于记录回顾总结解题思路便于加深理解。 &#x1f4e2;&#x1f4e2;&#x1f4e2;传送门 A - 循环位移解…