Re: building cross-compiler for m68hc11/m68hc12

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



29.2.2012 16:29, Mihai Daniel OPREA kirjoitti:
Thank you Kai Ruottu for all your help.

I managed to build binutils-2.19. After that I tried building gcc-4.3.2, which failed due to "compiler internal
error: segmentation fault". I then tried building gcc-3.3.6 (the version which was used to compile the successful
m68hc11 build), which failed as well because of "open with O_CREAT in second argument needs 3 arguments".

Building old FSF sources with very new tools may be a problem :-(  They
were written to be compiled with the tools available at that time so if
any standard has changed that has influence. I don't know how 'open()'
has changed in Linux/glibc since the gcc-3.3.6 time... In any case your
Ubuntu 11.10 32-bit system, told in your 1st msg, is very "uptodate" as
a development platform for old sources. My development/build platform
is CentOS 5.7 with glibc-2.5 and gcc-4.1.2 as the native C library and
GCC. Furthermore I didn't even use the native GCC and glibc when
building but a cross GCC for the early 2000's Red Hat 7.3 distro, a
gcc-4.1.2 for 'i386-redhat-linux7.3' and RHL 7.3's glibc-2.2.5 as the
target C library. So it wasn't any surprise that there were no
problems. Before starting to write this, I restarted the gcc-4.2.4
build with the native gcc-4.1.2 (and glibc-2.5). This far no problems,
'libssp' for the 'm68hc11-elf' target being just built...

Fortunately however, the link you indicated contains a guide for installing the m68hc11 port from sources:
http://www.gnu-m68hc11.org/m68hc11_inst_ptc.php
The first step is building binutils-2.15. I tried it both with applying the supplied patch (binutils-2.15-
m68hc1x-20040801.diffs.gz) and without applying it, but it failed both times with the message:
"array type has incomplete element type" in tc-m68hc11.h.

I can try newer (Linux) binutils sources than 2.14.90 and see how long
they will succeed for 'm68hc11-elf' target...

The prerequisites state that a gcc-3.2 or gcc-3.3 host compiler and binutils-2.14 or binutils-2.15 are required.

Talking only about the GCC version and binutils version as if only they
could have some influence is misleading. Also the C headers used during
compile may have influence, for instance the problem with 'open()'. And
if we are talking about copying linked executables made for an very
uptodate system, running them on much older systems is always
impossible. Your "for-Ubuntu 11.10-made" executables wouldn't work on
any older systems meanwhile those "for RHL7.3" or even the native
"for CentOS 5.7" would work on many systems, including Ubuntu 11.10.
Currently I have Ubuntu 11.04 (x86_64) on my laptop and 10.04 in one
older desktop so I could check the toolchain workings in them easily.

Do I actually need gcc-3.3 and binutils-2.15 in order to build gcc-3.3
> and binutils-2.15? If so, how do I go about it?

The obvious answer would be: "Get a binutils, GCC and glibc toolchain
for some old generic Linux/ia32 target and build things with it". But
this advice isn't so simple to apply, where one gets these?  One choice
could be :

https://sourcery.mentor.com/sgpp/lite/ia32/portal/release1026

The toolchain is from 2009, so 3 years old and for 3 years old things...

Making crosstoolchains for old systems of course requires an access to
the install stuff of them. Anyone who started with Linux in early 1990's
of course have many install CDs in one's shelf or closet, finding them
on net may though be very hard...

BTW, the gcc-4.2.4 build for m68hc11-elf had succeeded nicely, no
problems. The binutils-2.14.9.0.8 from:

ftp.kernel.org/pub/linux/devel/binutils

were still used, must check how they could be built with the native
CentOS 5.7 tools, I compiled them with gcc-3.2.3 for RHL 7.3, when
expecting problems with a newer GCC...


[Index of Archives]     [Linux C Programming]     [Linux Kernel]     [eCos]     [Fedora Development]     [Fedora Announce]     [Autoconf]     [The DWARVES Debugging Tools]     [Yosemite Campsites]     [Yosemite News]     [Linux GCC]

  Powered by Linux