本文提供release和debug两个版本的Qemu2.5.1.1二进制文件,由Clang with Microsoft CodeGen(简称clangc2)生成,目的是提供pdb调试文件方便调试分析Qemu的源代码。
先用msys2生成config-host.h等配置文件动态文件,然后用clangc2编译,用到的配置命令如下,所以有些特性是没有的。
../qemu-2.5.1.1/configure --prefix=`pwd`/installdir --target-list=x86_64-softmmu --with-system-pixman --disable-user --disable-linux-user --disable-bsd-user --disable-guest-agent --disable-guest-agent-msi --disable-pie --disable-modules --disable-sparse --disable-gnutls --disable-nettle --disable-gcrypt --disable-gtk --disable-vte --disable-curses --disable-vnc --disable-vnc-sasl --disable-vnc-jpeg --disable-vnc-png --disable-cocoa --disable-virtfs --disable-xen --disable-xen-pci-passthrough --disable-brlapi --disable-curl --disable-fdt --disable-bluez --disable-kvm --disable-rdma --disable-uuid --disable-vde --disable-netmap --disable-linux-aio --disable-cap-ng --disable-attr --disable-vhost-net --disable-spice --disable-rbd --disable-libiscsi --disable-libnfs --disable-smartcard --disable-libusb --disable-usb-redir --disable-lzo --disable-snappy --disable-bzip2 --disable-seccomp --disable-coroutine-pool --disable-glusterfs --disable-archipelago --disable-tpm --disable-libssh2 --disable-vhdx --disable-numa --disable-tcmalloc --disable-jemalloc --enable-sdl --with-sdlabi=1.2
可以运行Qemu官网提供的linux测试文件(http://wiki.qemu.org/download/linux-0.2.img.bz2)
qemu-system-x86_64.exe d:\temp\linux-0.2.img
可以运行UEFI,EDK2带的OVMF
qemu-system-x86_64.exe -bios d:\temp\OVMF.release -hda d:\temp\myefihd.vdi
debug版本编译时hw\ide\atapi.c文件编译不过,所以用的是release的atapi.obj,最终debug版本运行时可能会崩溃。
debug版本有对应的pdb调试文件,给原始Qemu2.5.1.1源代码打上附件中的patch后放到e:\readsrc\qemu\2.5.1.1\qemu-2.5.1.1-clangc2\目录下,windbg调试时能自动找到源代码。
利用pdbproject(https://visualstudiogallery.msdn.microsoft.com/6ad3d6a9-88e7-4610-9624-86ccbda4534b)可以从pdb文件生成vs工程,用vs看代码很方便。如果pdbproject失败,用windbg带的dbh工具打开pdb,利用src命令显示所有的源代码,把需要的源代码文件添加到vs工程,设置好工程属性中的头文件路径就行。
附件:qemu-2.5.1.1-clangc2.7z
SHA1:ba24a22c6e59e730db2df691a3562ef1538838f7