GDB调试qemu源码纪录

时间:2021-01-25 07:01:02

今天介绍下如何利用gdb调试qemu

1、首先获取qemu源码

获取地址:https://www.qemu.org/

2、编译安装qemu

进入qemu目录 ./configure --enable-debug

make

make install

安装之后一般会在/usr/local/bin目录下生成各种可执行文件,其中我们要调试的是qemu-system-x86_64(当然根据实际情况可能略有差异)

3、安装虚拟机

比如:

qemu-img create ubuntu.12.04.qcow2  -f qcow2 8G

qemu-system-x86_64 -m 512 -enable-kvm ubuntu12.04.qcow2 ubuntu.iso

之后会跳出一个窗口显示安装进度

4、调试虚拟机

gdb qemu-system-x86_64 进入调试窗口

set args -m 1024 -enable-kvm /var/lib/libvirt/images/ubun-qcow2(-m制定内存大小   enable-kvm后跟的是镜像文件路径)

break main

start

开始调试即可

//////附简要GDB 命令

next(n):下一部

step(s):单步进入

bt 列举函数栈帧

print 查看变量或者内存的值

break 行号或者函数名:下断点

info breakpoints 查看当前断点信息

delete   清除所有断点

continue (c)运行到下一个断点

print /x var 16进制显示(var)值
print可以指定显示的格式,这里用'/x'表示16进制的格式。 
可以支持的变量显示格式有: 
x  按十六进制格式显示变量。 
d  按十进制格式显示变量。 
u  按十六进制格式显示无符号整型。 
o  按八进制格式显示变量。 
t  按二进制格式显示变量。 
a  按十六进制格式显示变量。 
c  按字符格式显示变量。 
f  按浮点数格式显示变量。

print x=4 修改运行时候的变量值

以马内利