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

描述

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

一、准备工作

开始之前,需要准备:

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

构建完成后,输出如下:

OpenHarmony

1.1 编译输出目录简介

hb set命令选择qemu_riscv_mini_system_demo平台后,hb build命令构建完成后,所有输出文件将会保存在out/riscv32_virt/qemu_riscv_mini_system_demo 目录,具体内容如下:

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问题:

OpenHarmony

解决方法:

sudo apt install ninja-build

正常编译成功之后,可以看到如下输出:

OpenHarmony

三、用QEMU运行OpenHarmony轻量系统

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

3.1 qemu-run脚本简介

OpenHarmony顶层目录,有一个qemu-run的链接文件:

OpenHarmony

它实际指向一个脚本文件:

OpenHarmony

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

3.2 qemu-run脚本参数

脚本qemu-run文件支持一些命令行参数,具体如下:

OpenHarmony

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

3.3 qemu-run运行效果

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

运行后,可以看到启动日志:

OpenHarmony

OpenHarmony

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

3.4 退出QEMU交互模式

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

四、问题解决

首次运行qemu-run脚本,可能会遇到报错 libncursesw.so.5 找不到:

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
打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分