2013-02-09 40 views
0

我正在使用LLVM中編寫的探查器分析Spec2K6基準測試中的幾個文件,並且無法理解鏈接多個.bc文件的正確方法。在llvm中鏈接

例如,基準具有concat.c,它使用在xmalloc.c定義的的xmalloc方法,它使用從xexit.c xexit方法

我使用下面的命令之前鏈接多個文件.BC我簡介他們 -

CFLAGS='-D_GNU_SOURCE -D_XOPEN_SOURCE=600 -c -Wall -pedantic -Wno-long-long -g -O0 - I/net/x/silkyar/llvm/include -I/net/403.gcc/src' 
clang $CFLAGS -emit-llvm -c 403.gcc/src/concat.c -o concat.bc 
clang $CFLAGS -emit-llvm -c 403.gcc/src/xexit.c -o xexit.bc 
clang $CFLAGS -emit-llvm -c 403.gcc/src/xmalloc.c -o xmalloc.bc 
llvm-link concat.bc xexit.bc xmalloc.bc -o a.bc 
llc a.bc -o a.s 
g++ -o final a.s 
./final 

但這種失敗, LLVM鏈接:鏈接錯誤「xexit.bc」:鏈接全局命名爲「xexit」:象徵多次定義! /tmp/ccUldT0Y.o:(.debug_info+0​​x1e):未定義參照.Lline_table_start0' /tmp/ccUldT0Y.o:(.debug_info+0x42f): undefined reference to .Lline_table_start1' /tmp/ccUldT0Y.o:(.debug_info+0​​x4a0):未定義參考`.Lline_table_start2' collect2:LD返回1退出狀態

任何人都可以請指導我如何llvm鏈接的作品。

謝謝。

+0

你可以在舊的LLVM版本找到一個非常有用的工具'llvm-ld',它模仿了GNU ld的行爲。不幸的是,稍後有人將其刪除。 – 2013-02-12 08:49:34

回答

1

一般來說,llvm-link工作正常。這裏有一個簡單的演示(帶LLVM從主幹幾天前建):

$ cat lib.c 
int libfoo(int x) { 
    return x * 2; 
} 

$ cat user.c 
int libfoo(int); 


int bar(int a, int b) { 
    return a + libfoo(b); 
} 
$ clang -emit-llvm -c user.c -o user.bc 
$ clang -emit-llvm -c lib.c -o lib.bc 
$ llvm-link lib.bc user.bc -o linked.bc 
$ llvm-dis linked.bc 
$ cat linked.ll 
; ModuleID = 'linked.bc' 
target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64-S128" 
target triple = "x86_64-unknown-linux-gnu" 

define i32 @libfoo(i32 %x) nounwind uwtable { 
entry: 
    %x.addr = alloca i32, align 4 
    store i32 %x, i32* %x.addr, align 4 
    %0 = load i32* %x.addr, align 4 
    %mul = mul nsw i32 %0, 2 
    ret i32 %mul 
} 

define i32 @bar(i32 %a, i32 %b) nounwind uwtable { 
entry: 
    %a.addr = alloca i32, align 4 
    %b.addr = alloca i32, align 4 
    store i32 %a, i32* %a.addr, align 4 
    store i32 %b, i32* %b.addr, align 4 
    %0 = load i32* %a.addr, align 4 
    %1 = load i32* %b.addr, align 4 
    %call = call i32 @libfoo(i32 %1) 
    %add = add nsw i32 %0, %call 
    ret i32 %add 
} 

因此,你必須仔細檢查符號的重複,缺失,您的特定代碼等

+0

Hi Eli, 所以,事實證明,xexit被包含在CFLAGS的-I中多次,並且llvm-link在從命令中移除CFLAGS後工作。 感謝您的幫助。 – SArora 2013-02-10 04:35:33