2014-07-01 182 views
4

我有一个计算int factorial.c的阶乘的c代码。我将它编译为llvm可读代码“factorial.ll”,并在编译的llvm代码中进行修改。 目标是执行修改后的llvm代码并查看其输出,我该怎么做?如何执行llvm代码

回答

3

这将取决于您的输出LLVM组装和哪些库将其链接反对,但例如执行以下factorial.ll用shell命令lli

$ lli factorial.ll 
Factorial of 10 = 3628800 

将与JIT和使用执行main功能标准printf将结果输出到标准输出。

@.str = private unnamed_addr constant [22 x i8] c"Factorial of %d = %d\0A\00", align 1 
declare i32 @printf(i8*, ...) 

define i32 @factorial(i32 %n) nounwind uwtable { 
entry: 
    %n.addr = alloca i32, align 4 
    store i32 %n, i32* %n.addr, align 4 
    %0 = load i32* %n.addr, align 4 
    %cmp = icmp sle i32 %0, 1 
    br i1 %cmp, label %cond.true, label %cond.false 

cond.true:          ; preds = %entry 
    br label %cond.end 

cond.false:          ; preds = %entry 
    %1 = load i32* %n.addr, align 4 
    %2 = load i32* %n.addr, align 4 
    %sub = sub nsw i32 %2, 1 
    %call = call i32 @factorial(i32 %sub) 
    %mul = mul nsw i32 %1, %call 
    br label %cond.end 

cond.end:           ; preds = %cond.false, %cond.true 
    %cond = phi i32 [ 1, %cond.true ], [ %mul, %cond.false ] 
    ret i32 %cond 
} 

define i32 @main(i32 %argc, i8** %argv) nounwind uwtable { 
entry: 
    %retval = alloca i32, align 4 
    %argc.addr = alloca i32, align 4 
    %argv.addr = alloca i8**, align 8 
    store i32 0, i32* %retval 
    store i32 %argc, i32* %argc.addr, align 4 
    store i8** %argv, i8*** %argv.addr, align 8 
    %call = call i32 @factorial(i32 10) 
    %call1 = call i32 (i8*, ...)* @printf(i8* getelementptr inbounds ([22 x i8]* @.str, i32 0, i32 0), i32 10, i32 %call) 
    ret i32 0 
} 
+0

不错,这就是我在找的:)谢谢 – user3794683