• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1# QEMU(ESP32 教程)
2
3## 1.简介
4
5QEMU可以模拟内核运行在不同的单板,解除对物理开发板的依赖。esp32子目录包含部分Qemu esp32虚拟化平台验证的OpenHarmony kernel\_liteos\_m的代码,它可以用来模拟单核esp32单板。
6
7## 2.环境搭建
8
9   1. esp-idf安装
10
11      使用安装指导请参考:(https://docs.espressif.com/projects/esp-idf/zh_CN/release-v4.1/get-started/index.html)
12
13      注:esp-idf安装可以跳过,当前已将生成好的bootloader.binpartition-table.bin放入vendor\ohemu\qemu_xtensa_mini_system_demo\image文件夹中。
14
15      注:若跳过安装esp-idf可以按照下列方式安装工具链:
16
17      提示:[可直接下载](https://repo.huaweicloud.com/openharmony/compiler/gcc_esp/2019r2-8.2.0/linux/esp-2019r2-8.2.0.zip)
18
19      可选的编译器安装流程:
20
21      a) 下载官方release的SDK包:https://www.espressif.com/zh-hans/support/download/sdks-demos?keys=&field_type_tid%5B%5D=13
22
23      b) 将下载好的SDK包放入linux系统,进入目录执行如下指令:
24
25         ```shell
26         unzip esp-idf-v4.3.1.zip
27         cd esp-idf-v4.3.1/
28         ./install.sh
29         . ./export.sh
30         ```
31
32      注:本教程使用的工具链版本为gcc version 8.2.0 (crosstool-NG esp-2019r2)或gcc version 8.4.0 (crosstool-NG esp-2021r1)
33
34   2. esptool安装
35
36      a) 步骤1中export.sh脚本会设置esptool工具路径,需要确保esptool工具版本为3.1及以上。
37         ```shell
38         esptool.py version
39         ```
40      b) 如果esp-idf自带esptool工具版本过低,需删除当前esptool路径对应的环境变量,并执行以下命令。(python版本建议为3.8及以上)
41         ```shell
42         python -m pip install esptool
43         ```
44
45   3. qemu-system-xtensa编译
46
47      a) 编译安装
48
49         ```shell
50         git clone https://github.com/espressif/qemu.git
51         cd qemu
52         ./configure --target-list=xtensa-softmmu \
53            --enable-gcrypt \
54            --enable-debug --enable-sanitizers \
55            --disable-strip --disable-user \
56            --disable-capstone --disable-vnc \
57            --disable-sdl --disable-gtk
58         ```
59
60      b) 等待编译结束,执行安装命令(如果编译失败请参考https://github.com/espressif/qemu/issues/21):
61
62         ```shell
63         ninja -C build
64         ```
65
66      c) 将qemu添加到环境变量中(user_qemu_xxx_path修改为自己的安装路径):
67
68         ```shell
69         vim ~/.bashrc
70         export QEMU=user_qemu_xxx_path/qemu/build
71         source ~/.bashrc
72         ```
73
74      d) 安装依赖
75
76         ```shell
77         ldd $QEMU/qemu-system-xtensa
78         ```
79
80         根据ldd执行结果,安装缺少的依赖库
81
82         (注:更多安装指导,请参考链接:[Home · espressif/qemu Wiki · GitHub](https://github.com/espressif/qemu/wiki#configure))
83
84## 3.获取源码
85
86[代码获取](https://gitee.com/openharmony/docs/blob/master/zh-cn/device-dev/get-code/sourcecode-acquire.md)
87
88提示: 可以使用 `repo` 命令来获取源码。
89
90## 4.源码构建
91
92   1. 执行hb set命令并选择项目`qemu_xtensa_mini_system_demo`。
93
94   2. 执行hb clean && hb build命令构建产生 `OHOS_Image` 的可执行文件。
95
96      ```shell
97      hb set
98      hb clean && hb build
99      ```
100
101   3. 在构建完成之后,对应的可执行文件在主目录下:
102
103      ```
104      out/esp32/qemu_xtensa_mini_system_demo/
105      ```
106
107## 5.在Qemu中运行镜像
108
109   1. 运行qemu(不配合GDB)
110
111      ```shell
112      ./qemu-run
113      ```
114
115   2. 启动qemu(配合GDB)
116
117      a) 启动GDB服务器,等待连接
118
119         ```shell
120         ./qemu-run -g
121         ```
122
123      b) 新建终端并使用GDB连接qemu
124
125         ```shell
126         xtensa-esp32-elf-gdb out/esp32/qemu_xtensa_mini_system_demo/OHOS_Image -ex "target remote :1234"
127         ```
128
129   注:由于默认安装的qemu自带qemu-system-xtensa工具与当前安装的qemu-system-xtensa工具重名,因此采用绝对路径执行当前的qemu-system-xtensa工具。
130   注:qemu退出方式为:按下ctrl加a键,然后松开再按下x键。
131
132(注:更多操作指导,请参考:[Home · espressif/qemu Wiki · GitHub](https://github.com/espressif/qemu/wiki#configure))
133