LLVM:指令并不支配所有用途

时间:2013-11-07 09:53:51

标签: llvm llvm-ir

我用最少的指令(通常是3-5)分割所有基本块:

llvm::SplitBlock(BasicBlock, &*BasicBlockiter, Pass);

并尝试从IR获取目标文件

llc -filetype=obj 2.ll

我收到了以下错误:

Instruction does not dominate all uses!
  %1 = alloca i32
  %mul = load i32* %1
Instruction does not dominate all uses!
  %1 = alloca i32
  %99 = load i32* %1

While deleting: i32 %
Use still stuck around after Def is destroyed:  %var = alloca i32
Assertion failed: use_empty() && "Uses remain when a value is destroyed!"

error: expected instruction opcode
invoke.cont2:                                     ; preds = %main_block, %invoke
.cont

IR:

  invoke.cont2:                                     ; preds = %main_block, %invoke.cont
  %call4 = invoke i32 @_ZStorSt13_Ios_OpenmodeS_(i32 8, i32 16)
          to label %invoke.cont3 unwind label %lpad1
  store i32 %call4, i32* %var4

我认为在拆分后,指令位于不同的基本块中。 如果我将块拆分成10-15条指令,一切正常。 如何预测/检查并避免此错误?

1 个答案:

答案 0 :(得分:1)

在你的第一个版本中,你有一个终止符指令之后的指令,这是不正确的,因为这个指令永远不会被执行。

在你的第二个版本中(这里没有提到,请使用stackoverflow而不是私人电子邮件......)在定义它之前使用%调用(在商店中)(%call = ...),所以显然你的定义确实如此不是每次使用之前...... 但正如我所说,商店不应该在调用之后,因为调用是一个终结者。

解决方案是将您的商店放在下一个基本块中(您可以创建一个新的):

%invoke.cont
  %call = invoke i8* @_ZNKSs5c_strEv(%"class.std::basic_string"* @loadedFile)
          to label %invoke.cont2_before unwind label %lpad1

invoke.cont2_before:                                     ; preds = %invoke.cont
  store i8* %call, i8** %reduced_var
  br label %invoke.cont2

invoke.cont2:                                     ; preds = %main_block, %invoke.cont2_before
  %call4 = invoke i32 @_ZStorSt13_Ios_OpenmodeS_(i32 8, i32 16)
          to label %invoke.cont3_before unwind label %lpad1

等...