0

有没有办法获得 lli 执行跟踪。作为给定程序的示例:

define dso_local i32 @main() {
  %1 = alloca i32, align 4
  store i32 1, i32* %1, align 4
  %2 = load i32, i32* %1, align 4
  ret i32 %2
}

我想要一些运行时输出,例如:

$ lli test.ll -trace

%1 = alloca(4)
st %1, 1       ; [%1] = 1
ld %1 -> %2    ; %2 = 1
ret %2         ; ret 1

我找到了一个 XRay 项目,但它似乎很复杂。是否有任何 llc 本机方式来输出执行跟踪?

4

1 回答 1

1

我没有找到,最后写了一些足够通用的东西来满足我的需要,但甚至几乎不适合一般用途。一个大问题是任何代码都可以调用本机代码,并且大多数代码经常这样做,因此跟踪器在遇到无法处理的CallInst之前只跟踪几条指令。

如果您只对非常短的指令序列感兴趣,Analysis/ConstantFolding.h中的函数可能会有所帮助……也可能不会,这取决于您的目的。如果您必须自己编写跟踪器,您可能想四处寻找使用InstVisitor的代码,其中一些代码可能是可用的、可重用的或一个很好的起点。祝你好运。

于 2018-10-28T13:07:19.497 回答