LLVM IR中缺少虚拟寄存器号

时间:2018-02-02 23:57:33

标签: llvm llvm-clang llvm-ir register-allocation

考虑以下两个例子:

int test_plus(int a, int b)
{
  int c = a + b;
  return c;
}

int reg_incr(int a)
{
  int b = a + 1;
  return b;
}

LLVM IR将是:

; Function Attrs: nounwind ssp uwtable
define i32 @test_plus(i32, i32) #0 {
  %3 = alloca i32, align 4
  %4 = alloca i32, align 4
  %5 = alloca i32, align 4
  store i32 %0, i32* %3, align 4
  store i32 %1, i32* %4, align 4
  %6 = load i32, i32* %3, align 4
  %7 = load i32, i32* %4, align 4
  %8 = add nsw i32 %6, %7
  store i32 %8, i32* %5, align 4
  %9 = load i32, i32* %5, align 4
  ret i32 %9
}

; Function Attrs: nounwind ssp uwtable
define i32 @reg_incr(i32) #0 {
  %2 = alloca i32, align 4
  %3 = alloca i32, align 4
  store i32 %0, i32* %2, align 4
  %4 = load i32, i32* %2, align 4
  %5 = add nsw i32 %4, 1
  store i32 %5, i32* %3, align 4
  %6 = load i32, i32* %3, align 4
  ret i32 %6
}

在第一个函数中,缺少注册%2%0%1用于参数);

同样,在第二个函数中,缺少注册%1

只是好奇,缺少的是什么?为什么他们不一致?

1 个答案:

答案 0 :(得分:0)

我相信#0指的是函数本身。 #1/#2引用参数