使用指导

MICA 主要包含三部分组件:

  1. 内核模块 :提供RTOS启动、专用中断收发、保留内存管理等功能。不同的部署模式会有对应的内核态实现,例如 bare-metal 部署模式,对应的内核模块是 mcs_km.ko。

  2. micad :MICA 的守护进程。负责管理和控制RTOS实例的创建、运行及销毁。micad 监听来自于 mica 命令行工具的调用,并根据这些调用执行相应的操作。此外,micad 还负责不同实例上的服务注册等功能。

  3. mica :MICA 的命令行工具。可以使用 mica 命令根据配置文件来创建、启动、停止RTOS实例,并且能够查看实例的状态和关联的服务信息。

下面,会基于 openEuler Embedded mcs 镜像介绍 MICA 的使用流程。


在ARM64 QEMU上运行

  1. 制作 dtb

部署 Client OS 需要在 Linux 的设备树中添加 mcs-remoteproc 设备节点,为 Client OS 预留出必要的保留内存。 当前,可以通过 mcs 仓库提供的 create_dtb.sh 脚本生成对应的 dtb:

# create a dtb for qemu_cortex_a53
$ ./create_dtb.sh qemu-a53

成功执行后,会在当前目录下生成 qemu.dtb 文件,对应 QEMU 配置为:2G RAM, 4 cores

  1. 启动 QEMU

Note

下文的QEMU启动命令默认使能 virtio-net,请先阅读 QEMU 使用指导 了解如何开启网络。

使用生成出来的 dtb,按照以下命令启动 QEMU,注意,bare-metal 部署和 jailhouse 部署所依赖的 QEMU 命令略有不同:

使用生成出来的 qemu.dtb,按照以下命令启动 QEMU,注意:
1. -m-smp 要与 dtb 的配置(2G RAM, 4 cores)保持一致,否则会启动失败。
2. 需要指定 maxcpus=3 为 Client OS 预留出 core 3。
$ sudo qemu-system-aarch64 -M virt,gic-version=3 -cpu cortex-a53 -nographic \
    -device virtio-net-device,netdev=tap0 \
    -netdev tap,id=tap0,script=/etc/qemu-ifup \
    -m 2G -smp 4 \
    -append 'maxcpus=3' \
    -kernel zImage \
    -initrd openeuler-image-*.cpio.gz \
    -dtb qemu.dtb
  1. 部署 Client OS

用户首先需要创建配置文件来关联实时OS以及指定部署方式,之后可以通过 mica 命令基于配置文件部署 client OS。 关于配置文件和 mica 命令的详细介绍请参考 mica命令与配置文件介绍

当前 openEuler Embedded mcs 镜像默认安装了一些配置文件样例:/etc/mica/*.conf,因此可以通过以下步骤启动:

  1. 调整内核打印等级:

# 为了不影响shell的使用,先屏蔽内核打印:
qemu-aarch64:~$ echo "1 4 1 7" > /proc/sys/kernel/printk
  1. 启动 client OS:

镜像启动时默认会根据 /etc/mica/qemu-zephyr-rproc.conf 创建 client OS 实例。
通过 mica status 查看该实例状态:
qemu-aarch64:~$ mica status
Name                          Assigned CPU        State               Service
qemu-zephyr                   3                   Offline
可以看到实例的名称为 qemu-zephyr,关联的 CPU ID 为3,状态为 Offline。
通过 mica start <Name> 启动实例:
qemu-aarch64:~$ mica start qemu-zephyr
starting qemu-zephyr...
start qemu-zephyr successfully!

启动成功后,执行 mica status 查询状态:

qemu-aarch64:~$ mica status
Name                          Assigned CPU        State               Service
qemu-zephyr                   3                   Running             rpmsg-tty1(/dev/ttyRPMSG0) rpmsg-tty(/dev/ttyRPMSG1)

状态更新为 Running,并且能观察到该实例提供了两个服务:rpmsg-tty 以及 rpmsg-tty1。 rpmsg-tty 绑定了 zephyr 的 shell,因此可以通过 screen 打开 tty 设备 /dev/ttyRPMSG1 来访问 zephyr 的 shell:

# 打开 Client OS 的 shell
qemu-aarch64:~$ screen /dev/ttyRPMSG1

... ...
# 回车后可以连上 shell,并执行 zephyr 的 shell 命令

uart:~$ kernel version
Zephyr version 3.2.0

之后,可以通过 Ctrl-a kCtrl-a Ctrl-k 组合键退出shell,参考 screen(1) — Linux manual page

  1. 停止 client OS:

通过 mica stop <Name> 停止实例:

qemu-aarch64:~$ mica stop qemu-zephyr
stopping qemu-zephyr...
stop qemu-zephyr successfully!
qemu-aarch64:~$ mica status
Name                          Assigned CPU        State               Service
qemu-zephyr                   3                   Offline
  1. 销毁 client OS:

通过 mica rm <Name> 销毁实例:

qemu-aarch64:~$ mica rm qemu-zephyr
removing qemu-zephyr...
rm qemu-zephyr successfully!
qemu-aarch64:~$ mica status
Name                          Assigned CPU        State               Service

销毁实例后,可以执行 mica create qemu-zephyr-rproc.conf 重新创建实例。


在树莓派4B上运行

oebuild 构建出来的 MCS 镜像已经通过 dt-overlay 等方式预留了相关资源,并且默认使用了支持 psci 的 uefi 引导固件。 因此只需要根据 openeuler-image-uefi启动使用指导 进行镜像启动,再部署 MICA 即可,步骤跟QEMU类似。

raspberrypi4-64:~$ mica start rpi4-uniproton
raspberrypi4-64:~$ mica stop rpi4-uniproton

在x86工控机上运行

Note

当前 x86 工控机只支持运行 UniProton,并且 x86 的部署方法与 arm64 有所不同,整合工作还在进行中。

首先,需要先根据 工控机HVAEIPC-M10 镜像构建安装指导 在工控机上安装 openEuler Embedded 镜像。

之后,我们还需要编译 UniProton 以及 x86环境下需要的额外启动程序 ap_boot, 请参考 openEuler Embedded & Uniproton x86 MICA环境安装指导

启动 openEuler Embedded 后,需要为 UniProton 预留出必要的内存、CPU资源。如四核CPU建议预留一个核,内存建议预留512M。 可通过修改 boot 分区的 grub.cfg 配置内核启动参数,新增 maxcpus=3 memmap=512M\$0x110000000 参数,参考如下:

openEuler-Embedded:~$ mount /dev/sda1 /boot
openEuler-Embedded:~$ cat /boot/efi/boot/grub.cfg
# Automatically created by OE
serial --unit=0 --speed=115200 --word=8 --parity=no --stop=1
default=boot
timeout=10

menuentry 'boot'{
linux /bzImage  root=*** rw rootwait quiet maxcpus=3 memmap=512M\$0x110000000 console=ttyS0,115200 console=tty0
}

修改完成后,请重启工控机,并通过以下命令查看当前CPU和内存的使用情况:

# 查看CPU核心数
$ nproc
3
# 查看内存使用情况
$ cat /proc/iomem
...
110000000-12fffffff : Reserved
...

这说明当前系统正在使用3个CPU,已经预留出了一个CPU。 内存方面,系统已经预留出了从0x110000000到0x12fffffff的内存资源。

接下来,我们通过在openEuler Embedded上运行如下命令启动MICA:

# 调整内核打印等级(可选择不执行)
$ echo "1 4 1 7" > /proc/sys/kernel/printk

$ mica start /path/to/executable

# 若成功运行,会有如下打印:
...
start client os
...
pls open /dev/pts/1 to talk with client OS
pty_thread for console is running
...
found matched endpoint, creating console with id:2 in host os

# 根据打印提示(found matched endpoint, creating console with id:2 in host os),
# 说明成功创建了console,可以通过 /dev/pts/1 查看 UniProton 的串口输出,例如:
$ screen /dev/pts/1

# 敲回车后,可以查看uniproton输出信息
# 可以通过 <Ctrl-a k> 或 <Ctrl-a Ctrl-k> 组合键退出console,具体请参考 screen 的 manual page

如果想停止当前的Client OS,可以通过以下命令:

$ mica stop