qemu是什么
qemu是一个通用的开源的计算机模拟器和虚拟化器,可以在不同的架构上运行任意操作系统或程序,也可以与KVM或Xen配合进行加速。
qemu的安装
sudo apt update
sudo apt install qemu qemu-user qemu-user-static
这将安装qemu以及用于模拟不同用户恐惧架构(包括ARM、RISCV等)的附加包
安装完之后可以使用下列命令查看
ls /usr/bin/
使用qemu统计可执行文件中的实际运行指令数目
之前简单得通过将目标文件反汇编,去数汇编指令的数目,但是后面发现源文件中有多个for循环与while循环,因为通过反汇编统计的结果并不是可执行文件最终执行的指令数目。
首先使用与目标指令相对应的交叉编译器,将源文件编译链接成可执行文件,具体的编译链接过程,在本人的另一篇博客中有说明,可自行查看编译链接过程
riscv64-unknown-elf-gcc -o main.elf main.c
如果源文件为C++文件,则需
riscv64-unknown-elf-g++ -o main.elf main.cpp
使用qemu运行RISCV程序并启用指令跟踪,qemu允许使用"-d"选项来输出调试信息&#x