0

只是一个关于在 LLVM 汇编代码中接受用户输入的快速问题。它会在主函数的参数中吗?目前我的主要功能如下所示:

define i32 @main() nounwind {
factorial.exit:
  %0 = tail call i32 @factorial(i32 3) nounwind   ; <i32> [#uses=1]
  %1 = tail call i32 (i8*, ...)* @printf(i8* getelementptr inbounds ([4 x i8]* @.str, i32     0, i32 0), i32 %0) nounwind ; <i32> [#uses0]
  ret i32 0
}

它现在计算 3 的阶乘,或者我在 3 中放置的任何数字。我目前正在从终端执行此操作,但我将制作一个 makefile 最终执行它。我如何让它从终端获取用户输入,我想我会在将它编译为字节码之后执行它类似于“lli factorial.bc 5”,它会给我5的阶乘。

谢谢你的帮助!

4

2 回答 2

0

所以我能够使用“cin”语句而不是在 main 方法中使用参数来做到这一点。我用 C 对其进行编码并使用 LLVM 网站生成程序集。

于 2012-10-07T22:13:44.073 回答
0

编译llvm.org/demo上的代码会产生以下结果:

define i32 @main(i32 %argc, i8** nocapture %argv) nounwind uwtable {
  %1 = getelementptr inbounds i8** %argv, i64 1
  %2 = load i8** %1, align 8, !tbaa !0
  %3 = tail call i64 @strtol(i8* nocapture %2, i8** null, i32 10) nounwind
  %4 = trunc i64 %3 to i32
  %5 = icmp eq i32 %4, 0
  br i1 %5, label %factorial.exit, label %tailrecurse.i

tailrecurse.i:                                    ; preds = %tailrecurse.i, %0
  %X.tr2.i = phi i32 [ %6, %tailrecurse.i ], [ %4, %0 ]
  %accumulator.tr1.i = phi i32 [ %7, %tailrecurse.i ], [ 1, %0 ]
  %6 = add nsw i32 %X.tr2.i, -1
  %7 = mul nsw i32 %accumulator.tr1.i, %X.tr2.i
  %8 = icmp eq i32 %6, 0
  br i1 %8, label %factorial.exit, label %tailrecurse.i

factorial.exit:                                   ; preds = %tailrecurse.i, %0
  %accumulator.tr.lcssa.i = phi i32 [ 1, %0 ], [ %7, %tailrecurse.i ]
  %9 = tail call i32 (i8*, ...)* @printf(i8* getelementptr inbounds ([4 x i8]* @.str, i64 0, i64 0), i32 %accumulator.tr.lcssa.i) nounwind
  ret i32 0
}

特别是您应该查看%1(ie argv+1) 和%2(ie *(argv+1)):当您调用 时lli factorial.bc 5%2将包含指向字符串 5的指针。

于 2012-10-07T20:38:38.020 回答