Page 1 of 1

Clang Cross Compiler Options

Posted: Sun Jun 14, 2015 2:14 am
by hubris
I am struggling to get any coherent cross compiler environment setup, cygwin, windows, and its' just not Linux seem to get in the way. I have tried the wiki pages to create a cross compiled binutils which failed halfway through the make, but I ran the make install anyway as some of the components built (who knows if they will run correctly). Stacking more issues on top of this shakey foundation I went on the try build GCC - which not unexpectedly failed as well.

So I though perhaps I can use the i686-elf binutils that were build and clang++ which is supposed to be able to create a what I want. I might be both thick and confused but it seems that with the right command line options clang++ will compile for another platform - which makes me think that the cross compiling of clang++ itself is to host it on another machine rather than running on a host to generate for a specified target.

So I am using this command line

Code: Select all

CPP32FLAGS	:=	-std=c++1y -Os -target i686-none-elf -ffreestanding -nostdlib -nostdinc -fno-builtin -fno-rtti -fno-exceptions -r -Wall
CPP32		:=	clang++
I have also tried i686-elf the issue is that the output file is in COFF format. A hexdump of the output certainly confirms it is not ELF. So should I go quietly into the forest and shoot myself, or can someone shed some light on either my misunderstanding or how I am using clang.

Thanks in advance

Re: Clang Cross Compiler Options

Posted: Sun Jun 14, 2015 4:09 am
by DeltaDrizz
Search via YouTube "how to Build a Cross Compiler". I found the video and it worked great after some tries. To build it without errors and to get it work first time, install "intl" and "diffutils" in addition via Cygwin. Good luck ;)

Re: Clang Cross Compiler Options

Posted: Sun Jun 14, 2015 8:21 am
by hubris
Ok watched the video, although not quite on target it some extra info, unfortunately so do all of the other sources. Nothing seems to work as stated leading me to wonder if my machine is not cleanly setup.
So I create a new directory, and followed this http://wiki.osdev.org/LLVM_Cross-Compiler tutorial step by step and of course it fails towards the end while linking with an error saying something like _registerframe is not found, sorry for the vagueness I am in the middle of another 4 hour build.
I also tried to find if clang could build clang, once again a lot of positive hints but nothing definitive. I even tried setting the CC and CXX variables prior to the configure and once again clang uses gcc and g++ to build. So it seems that there is more information required.
Lastly I still cannot tell if clang is a front end to gnu tools or a replacement for them. mighty grumble...

Anyway has anyone actually built clang successfully on windows using either clang or gnu?

Re: Clang Cross Compiler Options

Posted: Sun Jun 14, 2015 9:42 am
by Octocontrabass
hubris wrote:I have tried the wiki pages to create a cross compiled binutils which failed halfway through the make,
This suggests problems with your build environment. That's probably why things aren't working.

I haven't built clang before (it doesn't support all of my target CPU architectures), but I have built binutils and gcc, so I might be able to help you get a build environment that can at least do that much.

Re: Clang Cross Compiler Options

Posted: Sun Jun 14, 2015 2:12 pm
by Roman
Clang is a front-end for the LLVM framework. I use clang for building object files and GNU binutils for linking them. You probably need to use this option: --target=i686-pc-none-elf

Re: Clang Cross Compiler Options

Posted: Sun Jun 14, 2015 11:11 pm
by hubris
well I have stripped all cygwin off of my machine, followed the video exactly as stated and of course it does not work as stated. The configure refused to guess at the host triple so after some fudging around I used i386-coff which allowed the configure to execute none of the many combinations of i686-[pc,unknown]-[coff,elf] worked.

So configure ran and then make failed with an error

Code: Select all

../../binutils-2.9.1/gas/config/tc-i386.h:396:32: error: array type has incomplete element type
 extern const struct relax_type md_relax_table[];
                                ^
Makefile:1291: recipe for target 'app.o' failed
So now I wonder why i386 and not i686 and all of the other issues still leading me to my environment. So I think the next step is to rebuild my machine and hope which ever gremlin is resident is cast out after the re-build.

Re: Clang Cross Compiler Options

Posted: Mon Jun 15, 2015 1:20 am
by Octocontrabass
hubris wrote:binutils-2.9.1
I'm not surprised a 17-year-old version of binutils can't figure out the host triple.

Re: Clang Cross Compiler Options

Posted: Mon Jun 15, 2015 1:23 am
by kzinti
What's more, the tutorial says to get a recent version (2.21 or above).

Re: Clang Cross Compiler Options

Posted: Mon Jun 15, 2015 2:06 am
by thepowersgang
In software terms, 2.21 is newer than 2.9 (they're not decimals, it's just a period used to separate different numbers)