2012-02-14 92 views
9

好吧,我使用Ocamlyacc制作词法分析器和解析器。我已经完成了我的研究,我认为这与我的makefile没有为我的编译器选择正确的位版本或类似的东西有关?我不太了解makefile,这就是我问的原因。gcc ld:找不到架构x86_64的符号

我在另一台电脑上运行我的程序,它没有任何问题,所以它必须与我的机器有关。

这是一个MacBook Pro 64位。我正在使用Xcode 4.2.1。

这里的生成文件:

SHELL  = /bin/sh 

C_C   = gcc 
CPP_C  = g++ 
ifdef GPROF 
C_CPP_FLAGS = -pg -O3 
else 
ifndef DEBUG 
C_CPP_FLAGS = -O3 
else 
C_CPP_FLAGS = -g 
endif 
endif 
C_LD   = $(C_C) 
CPP_LD  = $(CPP_C) 

C_YACC  = bison 
C_LEX  = flex 

AR   = ar 
RANLIB  = ranlib 

OCAML_C  = ocamlc 
OCAML_OPT_C = ocamlopt 
ifdef GPROF 
OCAML_C_FLAGS  = -dtypes 
OCAML_OPT_C_FLAGS = -dtypes 
OCAML_LD  = $(OCAML_C) -g 
OCAML_OPT_LD = $(OCAML_OPT_C) -p 
else 
ifndef DEBUG 
OCAML_C_FLAGS  = -dtypes 
OCAML_OPT_C_FLAGS = -dtypes 
OCAML_LD  = $(OCAML_C) -g 
OCAML_OPT_LD = $(OCAML_OPT_C) 
else 
OCAML_C_FLAGS  = -dtypes 
OCAML_OPT_C_FLAGS = -dtypes 
OCAML_LD  = $(OCAML_C) -g 
OCAML_OPT_LD = $(OCAML_OPT_C) 
endif 
endif 
OCAML_MKTOP = ocamlmktop 
OCAML_CP  = ocamlcp 
OCAML_DEP = ocamldep 
OCAML_LEX = ocamllex 
OCAML_YACC = ocamlyacc 

OCAML_C_CPP_INC = -I $(shell $(OCAML_C) -v | tail -1 | sed -e \ 
         's/^Standard library directory: //') 

是我得到的错误是:

ld: symbol(s) not found for architecture x86_64 

下面是完整的输出:

make 
Linking OCAML (top level) program nanoml.top 
ocamlmktop -o nanoml.top -custom nano.cmo nanoLex.cmo nanoParse.cmo main.cmo \ 
-cc g++ -cclib ' ' 
/var/folders/n3/jgblhwmj40lchgq71bmgr8sw0000gn/T/camlprimbd6a63.c:784: warning: deprecated conversion from string constant to ‘char*’ 
. 
. //The same line ALOT of times. Removed due to limit of chars in a single post. 
. 
/var/folders/n3/jgblhwmj40lchgq71bmgr8sw0000gn/T/camlprimbd6a63.c:784: warning: deprecated conversion from string constant to ‘char*’ 
ld: warning: ignoring file /usr/local/lib/ocaml/libcamlrun.a, file was built for archive which is not the architecture being linked (x86_64) 
Undefined symbols for architecture x86_64: 
    "_main", referenced from: 
     start in crt1.10.6.o 
    "_caml_alloc_dummy", referenced from: 
     _caml_builtin_cprim in ccZbZ9Mf.o 
. 
. //And many of these lines 
. 
    "_caml_get_exception_backtrace", referenced from: 
     _caml_builtin_cprim in ccZbZ9Mf.o 
ld: symbol(s) not found for architecture x86_64 
collect2: ld returned 1 exit status 
File "_none_", line 1, characters 0-1: 
Error: Error while building custom runtime system 
make: *** [nanoml.top] Error 2 

预先感谢您!编辑: 我只使用Ocaml。没有C++或C需要与它链接。我从来没有试过用makefile运行我的ocaml代码,但是我可以在这台计算机上运行其他ocaml代码。这是第一次失败,但这是我第一次使用makefile。

而且相同的生成文件和代码在其他机器上工作(尽管老机器),所以我认为这与使用64位的这一个有关。

,我发现我已经给另一个生成文件看起来像这样:

# Generic compilation rules 

%.o : %.c 
    @echo Compiling C file $< 
    $(C_C) $(C_CPP_FLAGS) $(C_CPP_INCLUDES) -c $< -o [email protected] 

%.o : %.cc 
    @echo Compiling C++ file $< 
    $(CPP_C) $(C_CPP_FLAGS) $(C_CPP_INCLUDES) -c $< -o [email protected] 

%.o : %.cpp 
    @echo Compiling C++ file $< 
    $(CPP_C) $(C_CPP_FLAGS) $(C_CPP_INCLUDES) -c $< -o [email protected] 

%.cmi: %.mli 
    @echo Compiling OCAML interface $< 
    $(OCAML_C) $(OCAML_C_FLAGS) $(OCAML_INCLUDES) -c $< -o [email protected] 

%.cmo: %.ml 
    @echo Compiling \(to byte code\) OCAML module $< 
    $(OCAML_C) $(OCAML_C_FLAGS) $(OCAML_INCLUDES) -c $< -o [email protected] 

%.cmx: %.ml 
    @echo Compiling \(to native code\) OCAML module $< 
    $(OCAML_OPT_C) $(OCAML_OPT_C_FLAGS) $(OCAML_INCLUDES) -c $< -o [email protected] 

%.ml: %.mll 
    @echo Lexing OCAML file $< 
    $(OCAML_LEX) $< 

%.ml %.mli: %.mly 
    @echo Yaccing OCAML file $< 
    $(OCAML_YACC) $< 



# Generic cleaning rules 

default-clean: 
    rm -f *~ *.o *.cmo *.cmx .*.depend *.cmi 

.PHONY: default-clean 



# Generic link rules and library creation rules 
# 
# These rules assume that the following variables are set (when necessary): 
# 
# - C_EXE   : name of the C executable 
# - CPP_EXE  : name of the C++ executable 
# - OCAML_EXE  : name of the OCaml executable (without suffix) 
# - OCAML_TPL_EXE : name of the OCaml custom toplevel (without suffix) 
# - C_CPP_LIB  : name of the C/C++ library 
# - OCAML_LIB  : name of the OCaml library (without suffix) 
# - C_CPP_EXE_OBJ : list of C/C++ objects (without suffix) to build exe 
# - OCAML_EXE_OBJ : list of OCaml modules (without suffix) to build exe 
# - C_CPP_LIB_OBJ : list of C/C++ objects (without suffix) to build lib 
# - OCAML_LIB_OBJ : list of OCaml modules (without suffix) to build lib 
# - C_CPP_LD_FLAGS : C and C++ linker flags 
# - OCAML_LD_FLAGS : OCaml linker (both native and bytecode) flags 
# - C_CPP_LD_LIBS : C and C++ linker libraries 
# - OCAML_LD_LIBS : OCaml linker (both native and bytecode) libraries 

ifdef C_EXE 
$(C_EXE): $(C_CPP_EXE_OBJ:%=%.o) 
    @echo Linking C program [email protected] 
    $(C_LD) $(C_CPP_LD_FLAGS) -o [email protected] $(C_CPP_EXE_OBJ:%=%.o) $(C_CPP_LD_LIBS) 
endif 

ifdef CPP_EXE 
$(CPP_EXE): $(C_CPP_EXE_OBJ:%=%.o) 
    @echo Linking C++ program [email protected] 
    $(CPP_LD) $(C_CPP_LD_FLAGS) -o [email protected] $(C_CPP_EXE_OBJ:%=%.o) $(C_CPP_LD_LIBS) 
endif 

ifdef C_CPP_LIB 
$(C_CPP_LIB).a: $(C_CPP_LIB_OBJ:%=%.o) 
    @echo Creating C/C++ library [email protected] 
    $(AR) r [email protected] $? 
    $(RANLIB) [email protected] 
endif 

ifdef OCAML_EXE 
$(OCAML_EXE).byte: $(C_CPP_EXE_OBJ:%=%.o) $(OCAML_EXE_OBJ:%=%.cmo) 
    @echo Linking OCAML \(byte code\) program [email protected] 
    $(OCAML_LD) $(OCAML_LD_FLAGS) -o [email protected] -custom $(OCAML_LD_LIBS:%=%.cma) $(C_CPP_EXE_OBJ:%=%.o) $(OCAML_EXE_OBJ:%=%.cmo) \ 
    -cc $(CPP_C) -cclib '$(C_CPP_LD_FLAGS) $(C_CPP_LD_LIBS)' 

$(OCAML_EXE).opt: $(C_CPP_EXE_OBJ:%=%.o) $(OCAML_EXE_OBJ:%=%.cmx) 
    @echo Linking OCAML \(native code\) program [email protected] 
    $(OCAML_OPT_LD) $(OCAML_LD_FLAGS) -o [email protected] $(OCAML_LD_LIBS:%=%.cmxa) $(C_CPP_EXE_OBJ:%=%.o) $(OCAML_EXE_OBJ:%=%.cmx) \ 
    -cc $(CPP_C) -cclib '$(C_CPP_LD_FLAGS) $(C_CPP_LD_LIBS)' 

$(OCAML_EXE).top: $(C_CPP_EXE_OBJ:%=%.o) $(OCAML_EXE_OBJ:%=%.cmo) 
    @echo Linking OCAML \(top level\) program [email protected] 
    $(OCAML_MKTOP) $(OCAML_LD_FLAGS) -o [email protected] -custom $(OCAML_LD_LIBS:%=%.cma) $(C_CPP_EXE_OBJ:%=%.o) $(OCAML_EXE_OBJ:%=%.cmo) \ 
    -cc $(CPP_C) -cclib '$(C_CPP_LD_FLAGS) $(C_CPP_LD_LIBS)' 


endif 

ifdef OCAML_TPL_EXE 
$(OCAML_TPL_EXE).byte: $(C_CPP_EXE_OBJ:%=%.o) $(OCAML_EXE_OBJ:%=%.cmo) 
    @echo Linking OCAML \(byte code\) toplevel [email protected] 
    $(OCAML_MKTOP) $(OCAML_LD_FLAGS) -o [email protected] -custom $(OCAML_LD_LIBS:%=%.cma) $(C_CPP_EXE_OBJ:%=%.o) $(OCAML_EXE_OBJ:%=%.cmo) \ 
    -cc $(CPP_C) -cclib '$(C_CPP_LD_FLAGS) $(C_CPP_LD_LIBS)' 
endif 

ifdef OCAML_LIB 
$(OCAML_LIB).cma: $(OCAML_LIB_OBJ:%=%.cmo) 
    @echo Creating OCAML \(byte code\) library [email protected] 
    $(OCAML_LD) $(OCAML_LD_FLAGS) -a -o [email protected] $(OCAML_LIB_OBJ:%=%.cmo) 

$(OCAML_LIB).cmxa $(OCAML_LIB).a: $(OCAML_LIB_OBJ:%=%.cmx) 
    @echo Creating OCAML \(native code\) library [email protected] 
    $(OCAML_OPT_LD) $(OCAML_LD_FLAGS) -a -o [email protected] $(OCAML_LIB_OBJ:%=%.cmx) 
endif 

ifdef OCAML_CINTF 
ifdef OCAML_BYTECODE_CINTF 
$(OCAML_CINTF).o: $(OCAML_CINTF_OBJ:%=%.cmo) 
    @echo Creating OCAML \(native code\) C interface library [email protected] 
    $(OCAML_LD) $(OCAML_LD_FLAGS) -output-obj -o [email protected] $(OCAML_LD_LIBS:%=%.cma) $(OCAML_CINTF_OBJ:%=%.cmo) 

$(OCAML_CINTF_LIB).a: $(OCAML_CINTF).o $(C_CPP_CINTF_OBJ:%=%.o) 
    @echo Creating C/C++ interface library [email protected] 
    $(AR) r [email protected] $? 
    $(RANLIB) [email protected] 
else 
$(OCAML_CINTF).o: $(OCAML_CINTF_OBJ:%=%.cmx) 
    @echo Creating OCAML \(native code\) C interface library [email protected] 
    $(OCAML_OPT_LD) $(OCAML_LD_FLAGS) -output-obj -o [email protected] $(OCAML_LD_LIBS:%=%.cmxa) $(OCAML_CINTF_OBJ:%=%.cmx) 

$(OCAML_CINTF_LIB).a: $(OCAML_CINTF).o $(C_CPP_CINTF_OBJ:%=%.o) 
    @echo Creating C/C++ interface library [email protected] 
    $(AR) r [email protected] $? 
    $(RANLIB) [email protected] 
endif 
endif 



# Generic dependencies creation rules 

.%.mli.depend: %.mli 
    @echo Generating dependencies for OCAML interface $< 
    $(OCAML_DEP) $< > [email protected] 

.%.ml.depend: %.ml 
    @echo Generating dependencies for OCAML module $< 
    $(OCAML_DEP) $< > [email protected] 

回答

4

看起来也许你的OCaml编译器产生的32位可执行文件。一种说法是:

$ ocamlopt -config 

如果您看到architecture i386,它是一个32位编译器。如果你看到architecture amd64,它是一个64位编译器。无论如何,这些是我在Macbook Pro上看到的两个不同的值。

编辑

Makefile你给并不能真正说明你想要做什么。它只是为某些语言处理器定义了名称。真正的Makefile可能在其他地方。

由于Makefile实际上并没有说明你在做什么,我意识到我没有看到任何证据表明你将OCaml和C++(或C)连接在一起。除了看起来像OCaml文件外,第一行输出不显示任何内容。此外,它们是 ,名为xyz.cmo,它们是字节码 OCaml文件。也就是说,它们不是32位的 64位(本地)文件。

你有一些C++和一些OCaml组件需要链接在一起,还是你的项目纯OCaml?如果它是纯粹的OCaml,我会说这个问题全在Makefile。如果您只是想运行OCaml代码,则不必担心体系结构。

如果有一些C++或C,那么你需要用-arch i386编译它(得到32位对象),然后用它知道它的产生32位目标接头(ld)联系在一起的一切。 (或者,正如Fabrice Le Fessant所说,你可以安装一个64位OCaml压缩器。)

一个可能的建议是创建一个微小的OCaml文件,看看你是否可以编译和运行它。

使用的字节码编译器,它看起来像这样:

$ uname -rs 
Darwin 10.8.0 
$ cat tiny.ml 
Printf.printf "hello world\n" 
$ ocamlc -o tiny tiny.ml 
$ file tiny.cmo 
tiny.cmo: Objective caml object file (.cmo) (Version 006). 
$ file tiny 
tiny: a /sw/bin/ocamlrun script text executable 
$ tiny 
hello world 

使用原生32位编译器,它看起来像这样:

$ ocamlopt -o tiny tiny.ml 
$ file tiny.cmx 
tiny.cmx: Objective caml native object file (.cmx) (Version 011). 
$ file tiny.o 
tiny.o: Mach-O object i386 
$ file tiny 
tiny: Mach-O executable i386 
$ tiny 
hello world 

编辑2

你第二个makefile仍然没有显示你想要做什么,具体来说。它只是为编译和链接不同类型的可执行文件定义了一些制定规则。但是,既然你说你的项目全是OCaml,那么我会说整个问题都在这个Makefile中。

问题似乎是这个Makefile指定OCaml编译器应该使用哪个C编译器和库作为它的后端,使用-cc-cclib选项。在大多数系统上,只需将标准C编译器指定为OCaml的后端即可。在Mac OS X上,存在32位/ 64位体系结构复杂性。由于你可以在没有这个Makefile的情况下成功编译OCaml,所以我建议OCaml编译器已经知道如何编译和链接OCaml程序。所以你可以尝试从Makefile中删除-cc-cclib选项。

要做到这一点:在OCAML_EXE下的所有三个区段除去第三行完全(用-cc-cclib线),和除去上一行尾部的反斜杠。

+0

啊,我看到的i386所以这是一个32位编译器。如何让我的g ++/gcc编译器以32位而不是64位运行? – 2012-02-15 21:54:27

+0

'cc -arch i386'适合我。 – 2012-02-15 22:01:44

+0

我已经尝试了“gcc -arch i386”和“gcc -arch amd64”。这两个结果如下: “ld:warning:忽略文件/usr/local/lib/ocaml/libcamlrun.a,该文件是为归档而构建的,而不是被链接的体系结构(x86_64)”。 – 2012-02-16 04:54:47

10

有趣的线

LD:警告:忽略文件/usr/local/lib/ocaml/libcamlrun.a,文件是 归档内置这是不被链接(x86_64的)

架构

它告诉你,你的ocaml运行时间可能是一个32位库,而不是你需要的64位的 。

您可能想要尝试g ++的“-m32”标志以32位编译所有内容,或者安装64位版本的ocaml。

+0

我该如何将该标志应用于我的makefile?我对makefile一无所知,而且我尝试失败 – 2012-02-15 19:53:00

+0

你不需要了解太多,试着找到文本“-cc g ++”所在的位置(或者只是-cc),并将“g ++”改为“'g ++ - M32' ”。 – 2012-02-16 09:09:11

+2

我只是做了这个(不是ocaml相关的,但是与OP相同的错误)并且得到了这个 'ld:symbol(s)not found for architecture i386' :D:D:D – mraaroncruz 2012-07-17 12:09:58

0

在试图编译gphoto2时,我在过去两天里一直有这个问题。我刚刚从OS X 10.8升级到OS X 10.9。起初,我认为这将是新的XCode版本和命令行工具的问题。

我就确定更新的一切,但在ocaml的结构矛盾仍然存在的话,我决定安装OCaml中的自制版本:

$ brew install ocaml 

等瞧

相关问题