On Sun, 31 Jul 2016 19:40:37 +0100 Mick wrote: > Hi All, > > I am dipping my toe into cross-compile territory, in order to build i686 > binaries for a 32bit box, which is too old to do its own emerges. I am using > an amd64 box which is significantly faster to do all the heavy lifting and > started applying this page: > > https://wiki.gentoo.org/wiki/Embedded_Handbook/General/Creating_a_cross-compiler > > which I followed up with: > > https://wiki.gentoo.org/wiki/Cross_build_environment
And here comes this misconception again... Please, tell me, why on the earth cross-compiling is needed for amd64 to produce i686 binaries?! amd64 CPU _natively_ supports x86 instructions, amd64 kernel natively supports x86 code (this can be disabled during kernel config, but usually it isn't), amd64 gcc *can* produce x86 binaries. There are two ways to help older x86 boxes to build packages faster: 1. Set up distcc to produce x86 code on your amd64 processors. Just add -m32 to your *FLAGS. 2. Copy old box system to a chroot dir on amd64. Run setarch i686 and chroot to that directory, and build 32-bit packages as usual! There are two ways to deliver them: 2.a. Generate binary packages on new box and install them on old boxes. 2.b. Instead of copying old box's root, mount it over NFS. I'm currently using 1, but planning to switch to 2.a, because distcc can't help with everything (execution of java, python, autotools and other stuff can't be helped with distcc). I used 2.b earlier on very old box (it is dead now). 3. Well, one can do full cross-compilation as you proposed, but this is ridiculous. Cross-compilation is always a pain and if it can be avoided, it should be avoided. Best regards, Andrew Savchenko
pgpBOHdczNQK1.pgp
Description: PGP signature