Chuck Zhao
2009-Mar-27 17:53 UTC
[LLVMdev] LLVM-2.5 WinXP/Cygwin can't find puts() for the hello.c in GettingStarted document
I am using LLVM 2.5 release, together with llvm-gcc4.2-2.5. For the hello.c demo testing found close to the end of the GettingStarted document: #include <stdio.h> int main() { printf("hello world\n"); return 0; } Following the instructions: obtaining the bc file: /llvm-gcc -O3 -emit-llvm hello.c -c -o hello.bc/ running through lli: * */lli hello.bc/ I got this error msg: /*ERROR: Program used external function 'puts' which could not be resolved! Abort*/ I think this might have to do with my LD_LIBRARY_PATH settings, thus explicitly checked that it includes a path to libc, echo $LD_LIBRARY_PATH: *//lib:/usr/lib:/opt/llvm-2.5/lib:.:/home/czhao/suif/suif_1.3.0/i686-cygwin-cygwin/solib//* How could I fix this WinXP/Cygwin only thing? I tried the same steps on a Debian4-i386 machine, everything works fine. Thank you very much Chuck Env: WinXP/Cygwin/LLVM-2.5/LLVMGCC4.2-2.5 The bc code of the hello.c file: llvm-dis < hello.bc: ; ModuleID = '<stdin>' target datalayout = "e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:32:64-f32:32:32-f64:32:64-v64:64:64-v128:128:128-a0:0:64-f80:32:32" target triple = "i386-mingw32" @.str = internal constant [13 x i8] c"Hello, world\00" ; <[13 x i8]*> [#uses=1] define i32 @main() nounwind { entry: %0 = tail call i32 @puts(i8* getelementptr ([13 x i8]* @.str, i32 0, i32 0)) nounwind ; <i32> [#uses=0] ret i32 0 } declare i32 @puts(i8*) -------------- next part -------------- An HTML attachment was scrubbed... URL: <http://lists.llvm.org/pipermail/llvm-dev/attachments/20090327/e61a40e7/attachment.html>
Anton Korobeynikov
2009-Mar-27 18:29 UTC
[LLVMdev] LLVM-2.5 WinXP/Cygwin can't find puts() for the hello.c in GettingStarted document
Hi, Chuck> How could I fix this WinXP/Cygwin only thing?windows does not support dynamic linking, so there are 2 ways of providing external addresses of symbols: 1. register them explicitly 2. They should be available from some .DLL already preloaded into the binary. However, I'm not sure for 2. since cygwin uses unix-style of external symbols resolution. -- With best regards, Anton Korobeynikov Faculty of Mathematics and Mechanics, Saint Petersburg State University
Chuck Zhao
2009-Mar-29 13:03 UTC
[LLVMdev] LLVM-2.5 WinXP/Cygwin can't find puts() for the hello.c in GettingStarted document
Thanks, Anton, I find it hard to believe, as LLVM's CYGWIN path has been there for a long time. This _can't_ be a new problem. Somebody must have incurred and solved it before. Otherwise, a significant portion or LLVM tests or test-suites will fail. How could the sanity test go through? For people who use CYGWIN/LLVM as your default platform, how do you solve this problem? Or, if there isn't such a problem, my Cygwin env is strange. Thank you very much Chuck Anton Korobeynikov wrote:> Hi, Chuck > > >> How could I fix this WinXP/Cygwin only thing? >> > windows does not support dynamic linking, so there are 2 ways of > providing external addresses of symbols: > 1. register them explicitly > 2. They should be available from some .DLL already preloaded into the binary. > > However, I'm not sure for 2. since cygwin uses unix-style of external > symbols resolution. >-------------- next part -------------- An HTML attachment was scrubbed... URL: <http://lists.llvm.org/pipermail/llvm-dev/attachments/20090329/a49326f4/attachment.html>
Possibly Parallel Threads
- [LLVMdev] LLVM-2.5 WinXP/Cygwin can't find puts() for the hello.c in GettingStarted document
- [LLVMdev] LLVM Hello Pass load error when using opt -load Hello.so
- [LLVMdev] can't run the Hello Pass: registered multiple times
- [LLVMdev] can't run the Hello Pass: either not registered or registered multiple times, what is the problem?
- [LLVMdev] [PATCH] GettingStarted: mention problems with dynamic linking on Cygwin