【开源鸿蒙】使用QEMU运行OpenHarmony轻量系统 原创

码工许师傅
发布于 2024-9-13 20:27
浏览
0收藏

本文将会介绍如何从源码安装QEMU 6.2.0,以及如何使用QEMU运行OpenHarmony轻量系统。通过本文,你将会对QEMU和OpenHarmony轻量系统又一个初步的认知,并对如何使用QEMU又一个初步的理解和体会。

一、准备工作

开始之前,需要准备:

上一篇文章介绍了如何为QEMU RISC-V虚拟平台构建OpenHarmony轻量系统。

构建完成后,输出如下:
【开源鸿蒙】使用QEMU运行OpenHarmony轻量系统-鸿蒙开发者社区

1.1 编译输出目录简介

hb set命令选择qemu_riscv_mini_system_demo平台后,hb build命令构建完成后,所有输出文件将会保存在out/riscv32_virt/qemu_riscv_mini_system_demo 目录,具体内容如下:
【开源鸿蒙】使用QEMU运行OpenHarmony轻量系统-鸿蒙开发者社区

其中,OHOS_Image就是本文将要运行的RISC-V平台的OpenHarmony轻量系统ELF文件。

二、QEMU安装

按照如下步骤,从源码安装QEMU 6.2.0版本。

2.1 安装依赖

sudo apt install build-essential zlib1g-dev pkg-config libglib2.0-dev  binutils-dev libboost-all-dev autoconf libtool libssl-dev libpixman-1-dev virtualenv flex bison

2.2 获取源码

wget https://download.qemu.org/qemu-6.2.0.tar.xz

官网下载: qemu-6.2.0.tar.xz

2.3 编译安装

# 解压源码包
tar -xf qemu-6.2.0.tar.xz

# 跳转到源码解压后目录
cd qemu-6.2.0

# 创建构建目录,用于存放中间文件
mkdir build && cd build

# 创建qemu安装目录,也可以改为其他目录
sudo mkdir /usr/qemu/

# 配置源码,生成构建规则文件
# --prefix 参数指定安装目录
../configure --prefix=/usr/eqmu/

# 开始构建,8个并发任务
make -j8

等待编译结束, 执行安装命令:

make install

最后将安装路径添加到环境变量中:

vim ~/.bashrc

在~/.bashrc最末尾加入:

export PATH=$PATH:/usr/qemu/bin

2.4 问题解决

上一小节描述的步骤中,可能出现一些问题,本节介绍如何解决常见的问题。

Cannot find Ninja问题:
【开源鸿蒙】使用QEMU运行OpenHarmony轻量系统-鸿蒙开发者社区

解决方法:

sudo apt install ninja-build

正常编译成功之后,可以看到如下输出:
【开源鸿蒙】使用QEMU运行OpenHarmony轻量系统-鸿蒙开发者社区

三、用QEMU运行OpenHarmony轻量系统

编译成功后,就可以进入本篇文章的正题了——尝试使用QEMU运行RISC-V虚拟平台的OpenHarmony轻量系统。

3.1 qemu-run脚本简介

OpenHarmony顶层目录,有一个qemu-run的链接文件:
【开源鸿蒙】使用QEMU运行OpenHarmony轻量系统-鸿蒙开发者社区

它实际指向一个脚本文件:
【开源鸿蒙】使用QEMU运行OpenHarmony轻量系统-鸿蒙开发者社区

该脚本用于启动qemu虚拟机,并加载可执行程序。

3.2 qemu-run脚本参数

脚本qemu-run文件支持一些命令行参数,具体如下:
【开源鸿蒙】使用QEMU运行OpenHarmony轻量系统-鸿蒙开发者社区

由于exec默认值已经是正确的可执行程序了,所以直接运行该脚本就可以启动虚拟机,并运行OpenHarmony轻量系统。

3.3 qemu-run运行效果

前面介绍过,由于已经使用hb build编译成功了,直接运行qemu-run,就可以运行RISC-V虚拟平台的OpenHarmony轻量系统。

运行后,可以看到启动日志:
【开源鸿蒙】使用QEMU运行OpenHarmony轻量系统-鸿蒙开发者社区
【开源鸿蒙】使用QEMU运行OpenHarmony轻量系统-鸿蒙开发者社区

成功看到OpenHarmony系统启动日志了,可喜可贺!

3.4 退出QEMU交互模式

qemu-run默认会进入QEMU交互模式,退出需要使用:Ctrl+A,然后再按X键

四、问题解决

首次运行qemu-run脚本,可能会遇到报错 libncursesw.so.5 找不到:
【开源鸿蒙】使用QEMU运行OpenHarmony轻量系统-鸿蒙开发者社区

解决方法:

sudo apt install libncursesw5

五、参考链接

  1. OpenHarmony官网: https://www.openharmony.cn/
  2. OpenHarmony编译形态整体说明: https://docs.openharmony.cn/pages/v4.0/zh-cn/device-dev/quick-start/quickstart-appendix-compiledform.md
  3. OpenHarmony代码仓: https://gitee.com/openharmony/
  4. OpenHarmony riscv32_virt说明:https://gitee.com/openharmony/device_qemu/tree/HEAD/riscv32_virt

©著作权归作者所有,如需转载,请注明出处,否则将追究法律责任
收藏
回复
举报
回复
    相关推荐