在学习一个大型系统时,动态的方式(执行和调试)好过静态的方式,因此如果能掌握调试LLVM Pass的方法,也就能更好学习Pass的原理,并编写自己的Pass。
本文记录笔者在调试LLVMPass时遇到的问题。
开始调试前,需要构建Debug版本的LLVM,推荐使用笔者的另一篇博文中的方法,亲测可以在40分钟左右完成构建。构建LLVM Debug版本的目的主要是为了保存调试信息,方便调试器(例如GDB)进行调试。
官方提供了一篇教程,但这篇教程是基于旧的PassManager生成的,并不适用于现有的版本,如果直接按照原文的方法进行操作,会提示-hello参数无法设置,因为新版的PassManager使用的是-pass="XXX"的方式,但hello和hello2的注册方式并不能够被新版的PassManager检测到,所以将其直接修改为-pass=hello仍然是无法执行的。
观察调试的原理:首先用gdb调试opt程序,然后设置一个断点——可以是设置在PassManager的run方法上,也可以设置在待调试的Pass的run方法上。最后在gdb中设置opt加载的pass和输入文件等信息,启动调试。
因此,在新版的PassManager中可以通过运行教程中给出的命令来实现调试。不需要再查找so文件,大大方便了用户。
在此处贴一个使用到是命令
gdb opt
break llvm::HelloWorldPass::run
run -disable-output /tmp/a.ll -passes=helloworld
方法可以参考上面,一样的配方。所以新的PassManager还挺好用的,不需要再自己指定调试共享so文件的位置了。
谨以本文补充LLVM新的PassManager中没有的调试的内容。