Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

mingw-w64 host: Failure on installing kernel headers on 3.x #11

Open
class101 opened this issue Jan 14, 2014 · 28 comments
Open

mingw-w64 host: Failure on installing kernel headers on 3.x #11

class101 opened this issue Jan 14, 2014 · 28 comments

Comments

@class101
Copy link

I have attempted to install all recent linux kernels 3.x and they failed with the same error, also attempted the latest LT support 2.x kernel but it also failled but havent a log for this one will resubmit ticket later

fatal error: elf.h: No such file or directory

[DEBUG]  ==> Executing: 'make' '-C' '/root/tmp/linux-build/.build/src/linux-3.12' 'O=/root/tmp/linux-build/.build/x86_64-unknown-linux-gnu/build/build-kernel-headers' 'ARCH=x86' 'INSTALL_HDR_PATH=/root/gcc-4.8.2-x86_64-unknown-linux-gnu/x86_64-unknown-linux-gnu/sysroot/usr' 'V=1' 'headers_install' 
[ALL  ]  make[1]: Entering directory '/root/tmp/linux-build/.build/src/linux-3.12'
[ALL  ]  /usr/bin/make -C /root/tmp/linux-build/.build/x86_64-unknown-linux-gnu/build/build-kernel-headers KBUILD_SRC=/root/tmp/linux-build/.build/src/linux-3.12 KBUILD_EXTMOD="" -f /root/tmp/linux-build/.build/src/linux-3.12/Makefile headers_install
[ALL  ]  set -e; : '  CHK     include/generated/uapi/linux/version.h'; mkdir -p include/generated/uapi/linux/;  (echo #define LINUX_VERSION_CODE 199680; echo '#define KERNEL_VERSION(a,b,c) (((a) << 16) + ((b) << 8) + (c))';) < /root/tmp/linux-build/.build/src/linux-3.12/Makefile > include/generated/uapi/linux/version.h.tmp; if [ -r include/generated/uapi/linux/version.h ] && cmp -s include/generated/uapi/linux/version.h include/generated/uapi/linux/version.h.tmp; then rm -f include/generated/uapi/linux/version.h.tmp; else : '  UPD     include/generated/uapi/linux/version.h'; mv -f include/generated/uapi/linux/version.h.tmp include/generated/uapi/linux/version.h; fi
[ALL  ]  /usr/bin/make -f /root/tmp/linux-build/.build/src/linux-3.12/scripts/Makefile.build obj=scripts/basic
[ALL  ]  rm -f .tmp_quiet_recordmcount
[ALL  ]  /usr/bin/make -f /root/tmp/linux-build/.build/src/linux-3.12/scripts/Makefile.asm-generic             src=asm obj=arch/x86/include/generated/asm
[ALL  ]  /usr/bin/make -f /root/tmp/linux-build/.build/src/linux-3.12/scripts/Makefile.asm-generic             src=uapi/asm obj=arch/x86/include/generated/uapi/asm
[ALL  ]  /usr/bin/make -f /root/tmp/linux-build/.build/src/linux-3.12/scripts/Makefile.build obj=arch/x86/syscalls all
[ALL  ]  make[3]: Nothing to be done for 'all'.
[ALL  ]  /usr/bin/make -f /root/tmp/linux-build/.build/src/linux-3.12/scripts/Makefile.build obj=arch/x86/tools relocs
[ALL  ]    gcc -Wp,-MD,arch/x86/tools/.relocs_32.o.d -Iarch/x86/tools -Wall -Wmissing-prototypes -Wstrict-prototypes -O2 -fomit-frame-pointer   -I/root/tmp/linux-build/.build/src/linux-3.12/tools/include -c -o arch/x86/tools/relocs_32.o /root/tmp/linux-build/.build/src/linux-3.12/arch/x86/tools/relocs_32.c
[ALL  ]  In file included from X:/LIBRARIES/tmp/linux-build/.build/src/linux-3.12/arch/x86/tools/relocs_32.c:1:0:
[ERROR]  X:/LIBRARIES/tmp/linux-build/.build/src/linux-3.12/arch/x86/tools/relocs.h:12:17: fatal error: elf.h: No such file or directory
[ALL  ]   #include <elf.h>
[ALL  ]                   ^
[ALL  ]  compilation terminated.
[ALL  ]  scripts/Makefile.host:134: recipe for target 'arch/x86/tools/relocs_32.o' failed
[ERROR]  make[3]: *** [arch/x86/tools/relocs_32.o] Error 1
[ALL  ]  /root/tmp/linux-build/.build/src/linux-3.12/arch/x86/Makefile:151: recipe for target 'archscripts' failed
[ERROR]  make[2]: *** [archscripts] Error 2
[ALL  ]  Makefile:130: recipe for target 'sub-make' failed
[ERROR]  make[1]: *** [sub-make] Error 2
[ALL  ]  make[1]: Leaving directory '/root/tmp/linux-build/.build/src/linux-3.12'
[ERROR]  
[ERROR]  >>
[ERROR]  >>  Build failed in step '(top-level)'
[ERROR]  >>
[ERROR]  >>  Error happened in: CT_DoExecLog[scripts/functions@257]
[ERROR]  >>        called from: do_kernel_install[scripts/build/kernel/linux.sh@112]
[ERROR]  >>        called from: do_kernel_headers[scripts/build/kernel/linux.sh@91]
[ERROR]  >>        called from: main[scripts/crosstool-NG.sh@692]
@mingwandroid
Copy link
Collaborator

Installing Linux headers on Windows doesn't work out of the box (nor does
installing {e}glibc).

If you look in the crosstool-ng of ctng-firefox-builds you'll see
patches/linux/3.10.19, and in there there are 3 patches that fix the linux
headers install problem. If you were to copy these to the 3.12 folder then
re-run your build you'd stand a good chance of getting past this stage.

On Tue, Jan 14, 2014 at 3:55 PM, Arnaud.Dovi [email protected]:

I have attempted to install all recent linux kernels 3.x and they failed
with the same error, also attempted the latest LT support 2.x kernel but it
also failled but havent a log for this one will resubmit ticket later

fatal error: elf.h: No such file or directory

[DEBUG] ==> Executing: 'make' '-C' '/root/tmp/linux-build/.build/src/linux-3.12' 'O=/root/tmp/linux-build/.build/x86_64-unknown-linux-gnu/build/build-kernel-headers' 'ARCH=x86' 'INSTALL_HDR_PATH=/root/gcc-4.8.2-x86_64-unknown-linux-gnu/x86_64-unknown-linux-gnu/sysroot/usr' 'V=1' 'headers_install'
[ALL ] make[1]: Entering directory '/root/tmp/linux-build/.build/src/linux-3.12'
[ALL ] /usr/bin/make -C /root/tmp/linux-build/.build/x86_64-unknown-linux-gnu/build/build-kernel-headers KBUILD_SRC=/root/tmp/linux-build/.build/src/linux-3.12 KBUILD_EXTMOD="" -f /root/tmp/linux-build/.build/src/linux-3.12/Makefile headers_install
[ALL ] set -e; : ' CHK include/generated/uapi/linux/version.h'; mkdir -p include/generated/uapi/linux/; (echo #define LINUX_VERSION_CODE 199680; echo '#define KERNEL_VERSION(a,b,c) (((a) << 16) + ((b) << 8) + (c))';) < /root/tmp/linux-build/.build/src/linux-3.12/Makefile > include/generated/uapi/linux/version.h.tmp; if [ -r include/generated/uapi/linux/version.h ] && cmp -s include/generated/uapi/linux/version.h include/generated/uapi/linux/version.h.tmp; then rm -f include/generated/uapi/linux/version.h.tmp; else : ' UPD include/generated/uapi/linux/version.h'; mv -f include/generated/uapi/linux/version.h.tmp include/generated/uapi/linux/version.h; fi
[ALL ] /usr/bin/make -f /root/tmp/linux-build/.build/src/linux-3.12/scripts/Makefile.build obj=scripts/basic
[ALL ] rm -f .tmp_quiet_recordmcount
[ALL ] /usr/bin/make -f /root/tmp/linux-build/.build/src/linux-3.12/scripts/Makefile.asm-generic src=asm obj=arch/x86/include/generated/asm
[ALL ] /usr/bin/make -f /root/tmp/linux-build/.build/src/linux-3.12/scripts/Makefile.asm-generic src=uapi/asm obj=arch/x86/include/generated/uapi/asm
[ALL ] /usr/bin/make -f /root/tmp/linux-build/.build/src/linux-3.12/scripts/Makefile.build obj=arch/x86/syscalls all
[ALL ] make[3]: Nothing to be done for 'all'.
[ALL ] /usr/bin/make -f /root/tmp/linux-build/.build/src/linux-3.12/scripts/Makefile.build obj=arch/x86/tools relocs
[ALL ] gcc -Wp,-MD,arch/x86/tools/.relocs_32.o.d -Iarch/x86/tools -Wall -Wmissing-prototypes -Wstrict-prototypes -O2 -fomit-frame-pointer -I/root/tmp/linux-build/.build/src/linux-3.12/tools/include -c -o arch/x86/tools/relocs_32.o /root/tmp/linux-build/.build/src/linux-3.12/arch/x86/tools/relocs_32.c
[ALL ] In file included from X:/LIBRARIES/tmp/linux-build/.build/src/linux-3.12/arch/x86/tools/relocs_32.c:1:0:
[ERROR] X:/LIBRARIES/tmp/linux-build/.build/src/linux-3.12/arch/x86/tools/relocs.h:12:17: fatal error: elf.h: No such file or directory
[ALL ] #include <elf.h>
[ALL ] ^
[ALL ] compilation terminated.
[ALL ] scripts/Makefile.host:134: recipe for target 'arch/x86/tools/relocs_32.o' failed
[ERROR] make[3]: *** [arch/x86/tools/relocs_32.o] Error 1
[ALL ] /root/tmp/linux-build/.build/src/linux-3.12/arch/x86/Makefile:151: recipe for target 'archscripts' failed
[ERROR] make[2]: *** [archscripts] Error 2
[ALL ] Makefile:130: recipe for target 'sub-make' failed
[ERROR] make[1]: *** [sub-make] Error 2
[ALL ] make[1]: Leaving directory '/root/tmp/linux-build/.build/src/linux-3.12'
[ERROR]
[ERROR] >>
[ERROR] >> Build failed in step '(top-level)'
[ERROR] >>
[ERROR] >> Error happened in: CT_DoExecLog[scripts/functions@257]
[ERROR] >> called from: do_kernel_install[scripts/build/kernel/linux.sh@112]
[ERROR] >> called from: do_kernel_headers[scripts/build/kernel/linux.sh@91]
[ERROR] >> called from: main[scripts/crosstool-NG.sh@692]


Reply to this email directly or view it on GitHubhttps://github.com//issues/11
.

@class101
Copy link
Author

will try that but if I rmemeber I have tried with 3.10.19 patched too and it failed

@mingwandroid
Copy link
Collaborator

Well, I only focussed on raspberry pi, and that should work:

from ctng-firefox-builds:
./build.sh --target-os=raspi

btw, Win 64bit Darwin compilers have another bug in them, but I am getting
there..

On Tue, Jan 14, 2014 at 4:49 PM, Arnaud.Dovi [email protected]:

will try that but if I rmemeber I have tried with 3.10.19 patched too and
it failed


Reply to this email directly or view it on GitHubhttps://github.com//issues/11#issuecomment-32282584
.

@class101
Copy link
Author

Just retested with a reworked patch for 3.12 (not sure did it well) but it failed with same include error

110-scripts-Makefile.headersinst-install-headers-from-sc-3.12.patch http://pastebin.com/GxdpPLTN

Else thank you for darwin I'm going to head on it soon, yet I reworked my builds hosted Windows with all your precious helps I better understand how it is built, yet successfully built under ct-ng-dw + mingw-w64 through build.sh

Target: Windows 64-Bit Seh (gcc-4.8.2-x86_64-unknown-mingw32-seh)
build.sh config: http://pastebin.com/GEcMZQzz
ctng disable expat: http://pastebin.com/rKfGHH5V

Target: Windows 32-Bit Dwarf2 (gcc-4.8.2-i686-unknown-mingw32-dw2)
build.sh config: http://pastebin.com/7MULkswr
ctng disable expat: same

@class101
Copy link
Author

I just notice I forgot to update the line + $(shell echo -n &gt; $(INSTALL_HDR_PATH)/.input-files) with 1 2 3 will try fix that

@mingwandroid
Copy link
Collaborator

I just notice I forgot to update the line + $(shell echo -n >
$(INSTALL_HDR_PATH)/.input-files) with 1 2 3 will try fix that

You aren't applying patches by hand are you? I hope you are only forward
porting by hand when the automatic patch method fails?

GDB without expat is generally pretty useless I think, or at least it is
for remote debugging of embedded targets as XML is used to describe the
registers. GDB support in crosstool-ng needs some work to be honest with
you. Optionally a GDB should be buildable for all of build, host, and
target.

On Tue, Jan 14, 2014 at 5:47 PM, Arnaud.Dovi [email protected]:

I just notice I forgot to update the line + $(shell echo -n >
$(INSTALL_HDR_PATH)/.input-files) with 1 2 3 will try fix that


Reply to this email directly or view it on GitHubhttps://github.com//issues/11#issuecomment-32288407
.

@class101
Copy link
Author

if it is in the svn i do them with tortoisesvn else with diff of mingw, ok havent really tested yet the dbg on windows, just the compilers they are ok

@class101
Copy link
Author

I think I have found the root cause of this elf.h issue

Its a circular dependency problem

__headers: $(version_h) scripts_basic asm-generic archheaders archscripts FORCE
    $(Q)$(MAKE) $(build)=scripts build_unifdef

PHONY += headers_install
headers_install: __headers
    $(if $(wildcard $(srctree)/arch/$(hdr-arch)/include/uapi/asm/Kbuild),, \
      $(error Headers not exportable for the $(SRCARCH) architecture))
    $(Q)$(MAKE) $(hdr-inst)=include/uapi
    $(Q)$(MAKE) $(hdr-inst)=arch/$(hdr-arch)/include/uapi/asm $(hdr-dst)

In short headers_install depends on archscripts but archscripts compiles a code with a header elf.h installed by headers_install

Next once you fix this you will realize the headers are copied under linux\elf.h of the sysroot when the code looks for elf.h

@mingwandroid
Copy link
Collaborator

Which version of linux are you trying to build headers for here? Can you
paste your .config file please?

On Fri, Jan 17, 2014 at 3:29 AM, Arnaud.Dovi [email protected]:

__headers: $(version_h) scripts_basic asm-generic archheaders archscripts
FORCE
$(Q)$(MAKE) $(build)=scripts build_unifdef

PHONY += headers_install
headers_install: __headers
$(if $(wildcard $(srctree)/arch/$(hdr-arch)/include/uapi/asm/Kbuild),,
$(error Headers not exportable for the $(SRCARCH) architecture))
$(Q)$(MAKE) $(hdr-inst)=include/uapi
$(Q)$(MAKE) $(hdr-inst)=arch/$(hdr-arch)/include/uapi/asm $(hdr-dst)

In short headers_install depends on archscripts but archscripts compiles a code with a header elf.h installed by headers_install

Next once you fix this you realize the headers are copied under <linux\elf.h> of the sysroot when the code looks for <elf.h>


Reply to this email directly or view it on GitHubhttps://github.com//issues/11#issuecomment-32577454
.

@class101
Copy link
Author

I have tested with 3.0.19 because with the 3 patches, 3.12 same fails, and the 2.6 longterm as another issue if I remember, been able to get ride of build.sh so I can build straight with your fork with patch applied

I have even tested cygwin + mingw64 that is integrated inside with a few MS Junction to solve the pathing problems, but same fails

config: http://pastebin.com/VrdYPwXW

ALSO: I notice anytime I manually delete the BUILD Source folders of linux 3.x on Windows, it fails on a file name aux.c

Couldn't this special name aux.c produce an internal error ? If I remember this special file is not part of older kernels so the error did not occur with 2.x kernels

src\linux-3.10.19\drivers\gpu\drm\nouveau\core\subdev\i2c\aux.c - The system cannot find the file specified.

Going to test right now on a older kernel same setup.

OFFTOPIC: been able to compile gdb with expat for Windows, this time I copied expat headers and libs in the sysroot and all went fine except python not detected so I disabled it.

OFFTOPIC: Btw I notice Y Morin released patches for its sources few hours ago, do you also apply them on your fork ?

@class101
Copy link
Author

been able to successfully generate windows 32/64-bit toolchains dw2/seh with updated components,

Mingw-w64 3.1.0 (nopatch)
GMP 5.1.3 (same patch 5.1.2)
gdb 7.6.2 (small mingw definition patch required for 7.6.1 too)
cloog 0.18.1 (no patch)

-I have used msys2, installed mingw-w64 with pacman for easier package management
-Applied all your build.sh project patches
-Applied this patch (with gdb expat/python fixe for this setup) http://pastebin.com/maanUVaC
-Config Windows 64 SEH : http://pastebin.com/mWhsTzDQ
-built ct-ng-dw with msys then exported PATH=/mingw64/bin:${PATH} or export PATH=/mingw32/bin:${PATH}
-/ct-ng build

also my patch add cflags and ldflags to the gdb configuration because once you link fix the link to python you need to define __USE_MINGW_ANSI_STDIO=1 which is ommitted in your fork and patches. Also I know ugly patch because I know it suppose you have /mingw64 /mingw32, just handy for the purpose of a workaround if anyone is looking for one.

@mingwandroid
Copy link
Collaborator

Great! Why not fork this project and make pull requests? I'd be more than happy to review them.

For GMP, instead of my intrusive fixes about reldir it can be fixed by calling configure with a relative path, as I do for the GCC build now ( see call to CT_FindRelativePath in crosstool-ng/scripts/build/cc/100-gcc.sh ), you may want to investigate that as a nicer way. I consider *-use-srcdirrel-to-avoid-MSYS-path-namespace-mismatch.patch an interesting proof-of-concept of how it could be fixed in each project, but it isn't something I would expect any upstream to ever merge (I wouldn't) so it would be a patch that would never forward porting forever.

I see that you are re-using the 'system' expat (i.e. MSYS2/MINGW-packages ones) libraries? I think adding expat as a companion library to crosstool-ng might be the preferred option (but I may be completely wrong in that too!)

For -D__USE_MINGW_ANSI_STDIO=1, I already set that in crosstool-ng/scripts/crosstool-NG.sh.in :
if [ ! "${CT_BUILD/mingw/}" = "${CT_BUILD}" ]; then
CT_CFLAGS_FOR_BUILD+=" -D__USE_MINGW_ANSI_STDIO=1"
fi
.. so I think the problem here is that CFLAGS_FOR_BUILD isn't being moved into CFLAGS during the build of GDB-for-build? Please investigate doing it that way.

I will be moving (the good) patches from ctng-firefox-builds back into this project then adding this project into the MSYS2-packages repository which should make things easier in future. Some of the more hacky and Windows specific patches I may keep in MSYS2-packages instead, because I don't think Yann Morin would want to merge e.g. my linux-kernel-headers or {e}glibc patches into crosstool-ng as it'd increase the workload when updating verisons; I also don't think linux or {e}glibc would welcome those changes - though I may submit them to those projects just to get their reactions (I'm sure they will be funny at least).

@class101
Copy link
Author

Yeah but I'm a little hesitant on using Git, as Windows user TortoiseGit does not have all the great features of TortoiseSVN and generally when you know svn and you come to git, it is like chinese huhu o_0
But since github supports svn I'm using TortoiseSVN on it to checkout, but maybe I'm able to commit on a branches, not sure if they support svn to git conversion. Yet I just know that any git project as a /trunk and /branches synchronized with the git repo, and the revision number is svn like, so I see you are at revision 120 on the build project and 265 on the ctng fork.

Interesting for GMP, honestly I did not even attempted without patch and guess what I just tried and it GMP 5.1.3 worked WITHOUT a single patch ! So it is even better no ? or the error come at the use ? Because here without patch, GMP Installing GMP for host, Configuring GMP, Building GMP, Installing GMP, Installing GMP for host: done in 207.16s (at 07:00) =)

For expat I was tempted to do that yeah but then come Python to move, and python unlike expat as lots of dependencies so I have found easier to change a little configuration option rather than breaking the initial system installation because I try to keep the msys2 free of manual changes

For D__USE_MINGW_ANSI_STDIO yeah I have seen you set it well in crosstool-NG.sh but did you look at the gdb.sh , it set correctly the cflags for a GDB NATIVE configuration, but the GDB CROSS configuration script configure is called without setting CFLAGS so my patch just set it back nothing much.

For merging patches that's good yeah I'm looking for that too because we are not supposed to know the build project exists with currently interesting patches specially for 4.8.2 gcc it has fixed all the problems 👍

For linux yet I'm stuck testing with step at step $(warning ) to try find what happens, what I'm sure yet is that on every 3.x I have tested , 3.12.8 included, the fails happens before installing headers to the sysroot, in the new step called archscripts, it is attempting to compile a arch scripts relocs_32.c and relocs_64.c in $(Q)$(MAKE) $(build)=arch/x86/tools relocs and they include relocs.h

#ifndef RELOCS_H
#define RELOCS_H

#include <stdio.h>
#include <stdarg.h>
#include <stdlib.h>
#include <stdint.h>
#include <inttypes.h>
#include <string.h>
#include <errno.h>
#include <unistd.h>
#include <elf.h>
#include <byteswap.h>
#define USE_BSD
#include <endian.h>
#include <regex.h>
#include <tools/le_byteshift.h>

void die(char *fmt, ...);

#define ARRAY_SIZE(x) (sizeof(x) / sizeof((x)[0]))

enum symtype {
    S_ABS,
    S_REL,
    S_SEG,
    S_LIN,
    S_NSYMTYPES
};

void process_32(FILE *fp, int use_real_mode, int as_text,
        int show_absolute_syms, int show_absolute_relocs);
void process_64(FILE *fp, int use_real_mode, int as_text,
        int show_absolute_syms, int show_absolute_relocs);

#endif /* RELOCS_H */

@mingwandroid
Copy link
Collaborator

Github made a special github program for Windows users:
https://github-windows.s3.amazonaws.com/GitHubSetup.exe
I tried it briefly, it seemed ok, but IMHO you should try to get comfortable with the git CLI. TortoiseGit is also getting more useful as time progresses. I can recommend setting up beyond compare as your difftool and mergetool too.

For -D__USE_MINGW_ANSI_STDIO=1, clearly that's a Windows specific hack in gdb.sh and CFLAGS_FOR_BUILD should be moved into CFLAGS instead as that's a general, correct fix for all systems.

I don't really follow you "For linux", I assume you mean running the linux headers install on Windows? Did you port my 3.10.19 patches to the other versions you tried? If not, then there's no chance (at all) of it working :-)

@class101
Copy link
Author

Just found linux 3.x solution I think is just ok to remove the archscript step

--- linux-3.12.8/Makefile.orig  2014-01-16 00:31:56.000000000 +0100
+++ linux-3.12.8/Makefile   2014-01-20 00:03:25.961403100 +0100
@@ -906,7 +906,7 @@
 archscripts:

 PHONY += __headers
-__headers: $(version_h) scripts_basic asm-generic archheaders archscripts FORCE
+__headers: $(version_h) scripts_basic asm-generic archheaders FORCE
    $(Q)$(MAKE) $(build)=scripts build_unifdef

 PHONY += headers_install_all

Then headers gotr copied successfully without the need of the header copy patch but you still need 100-fixdep-fixes-for-Windows.patch and 120-Win32-FreeBSD-use-upstream-unifdef.patch as far I checked with 3.12 and 3.12.8

 HOSTCC  scripts/unifdef-upstream/win32/win32.o
  HOSTLD  scripts/unifdef
  INSTALL include/asm-generic (35 files)
  INSTALL include/drm (18 files)
  INSTALL include/linux/byteorder (2 files)
  INSTALL include/linux/caif (2 files)
  INSTALL include/linux/can (5 files)
  INSTALL include/linux/dvb (8 files)
  INSTALL include/linux/hdlc (1 file)
  INSTALL include/linux/hsi (1 file)
  INSTALL include/linux/isdn (1 file)
  INSTALL include/linux/mmc (1 file)
  INSTALL include/linux/netfilter/ipset (4 files)
  INSTALL include/linux/netfilter (80 files)
  INSTALL include/linux/netfilter_arp (2 files)
  INSTALL include/linux/netfilter_bridge (18 files)
  INSTALL include/linux/netfilter_ipv4 (10 files)
  INSTALL include/linux/netfilter_ipv6 (12 files)
  INSTALL include/linux/nfsd (5 files)
  INSTALL include/linux/raid (2 files)
  INSTALL include/linux/spi (1 file)
  INSTALL include/linux/sunrpc (1 file)
  INSTALL include/linux/tc_act (8 files)
  INSTALL include/linux/tc_ematch (4 files)
  INSTALL include/linux/usb (10 files)
  INSTALL include/linux/wimax (1 file)
  INSTALL include/linux (388 files)
  INSTALL include/mtd (5 files)
  INSTALL include/rdma (6 files)
  INSTALL include/scsi/fc (4 files)
  INSTALL include/scsi (3 files)
  INSTALL include/sound (10 files)
  INSTALL include/video (3 files)
  INSTALL include/xen (2 files)
  INSTALL include/uapi (0 file)
  INSTALL include/asm (64 files)

BTW I also notice the GetText compilation is EXTREMELY long, you should add --disable-nls because it is compiling so much things not needed.

@mingwandroid
Copy link
Collaborator

It would be good for us to get to the bottom of why I don't need to remove the archscripts step I think.

@class101
Copy link
Author

Been able to successfully build Linux 64-bit seh toolchain kernel 3.12.8 , glibc 2.18, gcc 4.8.2 from Windows without building gettext and libiconv (slow steps as hell to do 4 more companions when they are already available in pacman)

Index: scripts/build/cc/100-gcc.sh ; patched a copy (cp -a) procedure which made an include path like sysroot/usr/include/include instead of sysroot/usr/include (probably caused by a trailing / symbol) this was then causing errors like stdio.h to be missing.

Index: config/libc/glibc.in:
disabled GETTEXT_NEEDED

Index: scripts/build/libc/glibc-eglibc.sh-common:
pointing to /mingw64 assuming it exists in the msys2 environment -I/mingw${CT_ARCH_BITNESS}/include -I/mingw${CT_ARCH_BITNESS}/${CT_BUILD}/include

Index: scripts/build/libc/glibc-eglibc.sh-common:
stubs.h is required before make install-headers

Index: patches/glibc/2.18/130-Fix-crossrpc-to-build-on-non-Linux.patch
eglibc 2.18 patch required for glibc too

Index: patches/glibc/2.18/140-glibc-disable-install-symlink-script-rellns.patch
At the very end of the step "libc" a script is called script/rellns.sh that is removing the absolute path but in our case we need the absolute path for the cp to work properly so I'm just exiting the script by echoing what we need

Index: patches/linux/3.12.8/100-fixdep-fixes-for-Windows.patch
Old existing patch still required

Index: patches/linux/3.12.8/120-Win32-FreeBSD-use-upstream-unifdef.patch
Old existing patch still required

Index: patches/linux/3.12.8/140-kernel-disable-archscripts.patch
Quick patch to see if nothing important missing

Index: patches/linux/3.12.8/100-fixdep-fixes-for-Windows.patch
Old existing patch still required

To note also 2 or 3 mk files are generated with windows style path x:/LIBRARIES/.. , fixed by replacing x:/LIBRARIES to my /root fstab mount directly infile , then "exit 2" to continue, I did not attempted to fix this in code

So below the patch I'm applying after the buildsh ones.

Btw they are more personal patches but this may help you because they are all the patch in one file I used to successfully generate Linux and Windows toolchains

http://pastebin.com/FdzyHySi

@mingwandroid
Copy link
Collaborator

I'm not sure what best to do about elf.h, I'm guessing an empty file somewhere in the header search path might be the cleanest approach as it appears to be another assumption that we're building on Linux? Then again, if it really does need something from that header then copying the real elf.h might work better than an empty file.

Thanks for helping to test this. Shall we close this issue?

@mingwandroid
Copy link
Collaborator

Before we close this, I want to make sure everything is addressed.

You said before:

"Next once you fix this you will realize the headers are copied under linux\elf.h of the sysroot when the code looks for elf.h"

.. what was the fix for this? I'm about to test your elf.h circluar dep fix, so I guess if this is still a problem I'll run into it?

You asked:

"OFFTOPIC: Btw I notice Y Morin released patches for its sources few hours ago, do you also apply them on your fork ?"

Well, we do merge in Y Morin's changes every few months or after a major release. It's somewhat time consuming to do it too frequently though. Next time will probably be when 1.20 is released.

@class101
Copy link
Author

Yet for me is ok but I did not really did extensive test of it so I will reopen later if it is causing nex problems

Btw I have found a new problem this time on Windows should I create new ticket ?

Well the problem is simple anyway:

It is impossible to have CT_SHARED_LIBS under Windows and so on, whether you choose Static or not in the menuconfig for Windows, the shared libs are never done because of this in the final core compiler and one or two other locations,

I don't understand because it seems the original crosstool-ng also does have this issue so nobody really builds shared libs in Windows ??

    [ "${CT_SHARED_LIBS}" = "y" ] || extra_config+=("--disable-shared")

So instead of setting --enable-shared over the disable option in an extra config and guess if it is accepted or not I do

Index: config/kernel/windows.in
--- config/kernel/windows.in.orig   2014-01-22 02:13:21.908067800 +0100
+++ config/kernel/windows.in        2014-01-22 02:13:40.415521900 +0100
@@ -3,5 +3,6 @@
 ## depends on ARCH_x86
 ##
 ## select WINDOWS
+## select KERNEL_SUPPORTS_SHARED_LIBS
 ##
 ## help Build a toolchain targeting systems running Windows as host

Then I'm allowed to have CT_SHARED_LIBS=y on windows

Without it is impossible to get the dll compiled, you can try, uncheck the static option in gcc, uncheck the static one in the toolchains options, the shared dll are never compiled

@mingwandroid
Copy link
Collaborator

I did run into problem with elf.h as you described even after applying the archscripts patch:

"Next once you fix this you will realize the headers are copied under linux\elf.h of the sysroot when the code looks for elf.h"

.. can you remember what you did to fix it? Sorry to repeat the question. If you can't remember then no problem I'll figure it out!

@class101
Copy link
Author

Oops sorry, I did not run into the problem here after removing archscript even after deleting source and reapplying so I'm sure there is no other patch I may have missed. On which kernel did you tested ? me 3.12.8 and 3.13

The thing that comes to minds in your case is that archscript may be called from a different location than mine because archscript real location is arch\x86\Makefile and is define too in the Main Makefile in

archprepare: archheaders archscripts prepare1 scripts_basic

or

no-dot-config-targets := clean mrproper distclean
cscope gtags TAGS tags help %docs check% coccicheck
$(version_h) headers_% archheaders archscripts
kernelversion %src-pkg

But I dont need to remove it from here

ct-ng-dw.x86_64-unknown-linux.config http://pastebin.com/ReSzYrMF

btw if u want to reach me fast im on steam or I have google hangout in the phone too, because Im french based and as I have no jobs yet have strange day cycles heheh

@mingwandroid
Copy link
Collaborator

I was incorrect, your archscripts change did get me past that problem, thanks.

For libiconv and gettext on Windows, you are right building these does take quite some time, but I like crosstool-ng to be as stand-alone as possible (even yhough I'm on the MSYS2/Paman dev team). I think I will ask Yann Morin for advise on this topic. In my opinion, setting {GETTEXT|LIBCONV}_VERSION="system" would be the best way to allow the user to specify that they want to use the system versions of those libraries. Finally, you can also pass to build.sh --ctng-save-steps=yes so that you can later skip gettext and libiconv rebuilds. This is the approach I'm adopting.

Thanks for the IM offer, you can get me on Google hangouts too. I'm in the UK. I'm also on IRC (OFTC servers: #msys2 or #mingw-w64 and Freenode servers: #crosstool-ng)

I'm working on making sure that glibc 2.15 and multilib work ok with host/build=Windows, target=Linux.

@class101
Copy link
Author

Cool thanks will add you

I have seen you glibc patches, but why are you developing multilib ? Isn't it just for the purpose of not having two compilers ? I'd like to try multilib too but there is no way to get the seh + multilib ? Maybe is it coming in gcc 4.9 ?

@mingwandroid
Copy link
Collaborator

AFAIK, Linux always and only uses dwarf table based exception handling and SEH is a target=Windows-only thing.

You are correct that for target=Windows you can't build compilers that are multilib with different exception models for each variant, but this is not a problem when you target=Linux (or target=Darwin for that matter!)

Of course the toolchains themselves itself do not depend on exceptions either.

.. or am I missing something?

I don't expect gcc 4.9 to allow split exception handling but I could be wrong!

@class101
Copy link
Author

Ho, thank you for that I do not find official SEH documentations and as I'm pretty new at c++ coding, What do you suggest on Windows ? I plan to build a small c++ code for win/linux/mac 32/64bit (a small proxy server based on boost.asio), do you think seh is a real perf improvment and debugging under Windows or dw2 is enough for all

@mingwandroid
Copy link
Collaborator

You can find descriptions of the three exception types supported by GCC here:
http://gcc.gnu.org/wiki/WindowsGCCImprovements

.. and here is a good description of the pros and cons of the three available choices for MinGW-w64
http://qt-project.org/wiki/MinGW-64-bit

I think you need to be explicit when discussing machines/OSes in cross compilation scenarios. The host/build machine is irrelevant in these matters the only thing that matters is the target machine, so:

If you build cross-GCC to run on Windows or Darwin (or Linux), targeting Linux (or Darwin, AFAIK!) then the exception method will always be Dwarf-based.

If you build cross-GCC to run on Linux or Darwin (or Windows), targeting Windows then it is more complicated:
If target is Windows 64bit you can build the compilers to use either one of sjlj, SEH or DW2. SEH is considered the best.
If target is Windows 32bit you can build the compilers to use either one of sjlj or DW2.

Personally I tend to avoid exceptions as I personally don't think it is a very good way to structure or reason about programs. IMHO they are essentially just a much more complicated version of "goto" statements and encourage people to not think about their error handling carefully. As for boost.asio, I cannot offer any useful comments there as I've never used it.

@class101
Copy link
Author

Yeah indeed sorry not being precise, I mean, my host is always a Windows so my cross-gcc will always run on Windows and I will target Windows, Linux, MAC

yeah indeed I try to not use the try catch, in c# often they can be a severe performance hit when a simple if condition check does the job without the perf. hit

I think I'm going to dw2 so I can experience building multilib, easier to manage 3 compilers than 6, so if I understand for building a multilib crossgcc I must use a multilib gcc, exactly as you are doing in build.sh, so I understand a bit more why do you prefer to build everything from scratch, the libs are not always availables with the build gcc you are using

Thank again for all your informations

mingwandroid added a commit that referenced this issue Apr 26, 2014
Fix from Arnaud Dovi:

#11

"
I think I have found the root cause of this elf.h issue

Its a circular dependency problem

  __headers: $(version_h) scripts_basic asm-generic archheaders archscripts FORCE
      $(Q)$(MAKE) $(build)=scripts build_unifdef

  PHONY += headers_install
  headers_install: __headers
      $(if $(wildcard $(srctree)/arch/$(hdr-arch)/include/uapi/asm/Kbuild),, \
        $(error Headers not exportable for the $(SRCARCH) architecture))
      $(Q)$(MAKE) $(hdr-inst)=include/uapi
      $(Q)$(MAKE) $(hdr-inst)=arch/$(hdr-arch)/include/uapi/asm $(hdr-dst)

In short headers_install depends on archscripts but archscripts compiles a code
with a header elf.h installed by headers_install

Next once you fix this you will realize the headers are copied under linux\elf.h
of the sysroot when the code looks for elf.h
"
mingwandroid pushed a commit that referenced this issue Jan 9, 2015
config/linux: Update kernel versions
mingwandroid added a commit that referenced this issue Jan 31, 2016
For versions 3.10.19, 3.10.38, 3.10.62, 3.12 and 4.3.3

Fix from Arnaud Dovi:

#11

"
I think I have found the root cause of this elf.h issue

Its a circular dependency problem

  __headers: $(version_h) scripts_basic asm-generic archheaders archscripts FORCE
      $(Q)$(MAKE) $(build)=scripts build_unifdef

  PHONY += headers_install
  headers_install: __headers
      $(if $(wildcard $(srctree)/arch/$(hdr-arch)/include/uapi/asm/Kbuild),, \
        $(error Headers not exportable for the $(SRCARCH) architecture))
      $(Q)$(MAKE) $(hdr-inst)=include/uapi
      $(Q)$(MAKE) $(hdr-inst)=arch/$(hdr-arch)/include/uapi/asm $(hdr-dst)

In short headers_install depends on archscripts but archscripts compiles a code
with a header elf.h installed by headers_install

Next once you fix this you will realize the headers are copied under linux\elf.h
of the sysroot when the code looks for elf.h
"

Signed-off-by: Ray Donnelly <[email protected]>
mingwandroid added a commit that referenced this issue Sep 10, 2016
For versions 3.10.19, 3.10.38, 3.10.62, 3.10.98, 3.12 and 4.3.3

Fix from Arnaud Dovi:

#11

"
I think I have found the root cause of this elf.h issue

Its a circular dependency problem

  __headers: $(version_h) scripts_basic asm-generic archheaders archscripts FORCE
      $(Q)$(MAKE) $(build)=scripts build_unifdef

  PHONY += headers_install
  headers_install: __headers
      $(if $(wildcard $(srctree)/arch/$(hdr-arch)/include/uapi/asm/Kbuild),, \
        $(error Headers not exportable for the $(SRCARCH) architecture))
      $(Q)$(MAKE) $(hdr-inst)=include/uapi
      $(Q)$(MAKE) $(hdr-inst)=arch/$(hdr-arch)/include/uapi/asm $(hdr-dst)

In short headers_install depends on archscripts but archscripts compiles a code
with a header elf.h installed by headers_install

Next once you fix this you will realize the headers are copied under linux\elf.h
of the sysroot when the code looks for elf.h
"

Signed-off-by: Ray Donnelly <[email protected]>
mingwandroid added a commit that referenced this issue Sep 10, 2016
For versions 3.10.19, 3.10.38, 3.10.62, 3.10.98, 3.12 and 4.3.3

Fix from Arnaud Dovi:

#11

"
I think I have found the root cause of this elf.h issue

Its a circular dependency problem

  __headers: $(version_h) scripts_basic asm-generic archheaders archscripts FORCE
      $(Q)$(MAKE) $(build)=scripts build_unifdef

  PHONY += headers_install
  headers_install: __headers
      $(if $(wildcard $(srctree)/arch/$(hdr-arch)/include/uapi/asm/Kbuild),, \
        $(error Headers not exportable for the $(SRCARCH) architecture))
      $(Q)$(MAKE) $(hdr-inst)=include/uapi
      $(Q)$(MAKE) $(hdr-inst)=arch/$(hdr-arch)/include/uapi/asm $(hdr-dst)

In short headers_install depends on archscripts but archscripts compiles a code
with a header elf.h installed by headers_install

Next once you fix this you will realize the headers are copied under linux\elf.h
of the sysroot when the code looks for elf.h
"

Signed-off-by: Ray Donnelly <[email protected]>
mingwandroid added a commit that referenced this issue Sep 16, 2016
For versions 3.10.19, 3.10.38, 3.10.62, 3.10.98, 3.12, 4.3.3 and 4.4.3

Fix from Arnaud Dovi:

#11

"
I think I have found the root cause of this elf.h issue

Its a circular dependency problem

  __headers: $(version_h) scripts_basic asm-generic archheaders archscripts FORCE
      $(Q)$(MAKE) $(build)=scripts build_unifdef

  PHONY += headers_install
  headers_install: __headers
      $(if $(wildcard $(srctree)/arch/$(hdr-arch)/include/uapi/asm/Kbuild),, \
        $(error Headers not exportable for the $(SRCARCH) architecture))
      $(Q)$(MAKE) $(hdr-inst)=include/uapi
      $(Q)$(MAKE) $(hdr-inst)=arch/$(hdr-arch)/include/uapi/asm $(hdr-dst)

In short headers_install depends on archscripts but archscripts compiles a code
with a header elf.h installed by headers_install

Next once you fix this you will realize the headers are copied under linux\elf.h
of the sysroot when the code looks for elf.h
"

Signed-off-by: Ray Donnelly <[email protected]>
mingwandroid added a commit that referenced this issue Jan 14, 2017
For versions 3.10.19, 3.10.38, 3.10.62, 3.10.98, 3.12, 4.3.3 and 4.4.3

Fix from Arnaud Dovi:

#11

"
I think I have found the root cause of this elf.h issue

Its a circular dependency problem

  __headers: $(version_h) scripts_basic asm-generic archheaders archscripts FORCE
      $(Q)$(MAKE) $(build)=scripts build_unifdef

  PHONY += headers_install
  headers_install: __headers
      $(if $(wildcard $(srctree)/arch/$(hdr-arch)/include/uapi/asm/Kbuild),, \
        $(error Headers not exportable for the $(SRCARCH) architecture))
      $(Q)$(MAKE) $(hdr-inst)=include/uapi
      $(Q)$(MAKE) $(hdr-inst)=arch/$(hdr-arch)/include/uapi/asm $(hdr-dst)

In short headers_install depends on archscripts but archscripts compiles a code
with a header elf.h installed by headers_install

Next once you fix this you will realize the headers are copied under linux\elf.h
of the sysroot when the code looks for elf.h
"

Signed-off-by: Ray Donnelly <[email protected]>
mingwandroid added a commit that referenced this issue Jan 16, 2017
For versions 3.10.19, 3.10.38, 3.10.62, 3.10.98, 3.12, 4.3.3 and 4.4.3

Fix from Arnaud Dovi:

#11

"
I think I have found the root cause of this elf.h issue

Its a circular dependency problem

  __headers: $(version_h) scripts_basic asm-generic archheaders archscripts FORCE
      $(Q)$(MAKE) $(build)=scripts build_unifdef

  PHONY += headers_install
  headers_install: __headers
      $(if $(wildcard $(srctree)/arch/$(hdr-arch)/include/uapi/asm/Kbuild),, \
        $(error Headers not exportable for the $(SRCARCH) architecture))
      $(Q)$(MAKE) $(hdr-inst)=include/uapi
      $(Q)$(MAKE) $(hdr-inst)=arch/$(hdr-arch)/include/uapi/asm $(hdr-dst)

In short headers_install depends on archscripts but archscripts compiles a code
with a header elf.h installed by headers_install

Next once you fix this you will realize the headers are copied under linux\elf.h
of the sysroot when the code looks for elf.h
"

Signed-off-by: Ray Donnelly <[email protected]>
mingwandroid added a commit that referenced this issue Jan 30, 2017
For versions 3.10.19, 3.10.38, 3.10.62, 3.10.98, 3.12, 4.3.3 and 4.4.3

Fix from Arnaud Dovi:

#11

"
I think I have found the root cause of this elf.h issue

Its a circular dependency problem

  __headers: $(version_h) scripts_basic asm-generic archheaders archscripts FORCE
      $(Q)$(MAKE) $(build)=scripts build_unifdef

  PHONY += headers_install
  headers_install: __headers
      $(if $(wildcard $(srctree)/arch/$(hdr-arch)/include/uapi/asm/Kbuild),, \
        $(error Headers not exportable for the $(SRCARCH) architecture))
      $(Q)$(MAKE) $(hdr-inst)=include/uapi
      $(Q)$(MAKE) $(hdr-inst)=arch/$(hdr-arch)/include/uapi/asm $(hdr-dst)

In short headers_install depends on archscripts but archscripts compiles a code
with a header elf.h installed by headers_install

Next once you fix this you will realize the headers are copied under linux\elf.h
of the sysroot when the code looks for elf.h
"

Signed-off-by: Ray Donnelly <[email protected]>
mingwandroid added a commit that referenced this issue Feb 15, 2017
For versions 3.10.19, 3.10.38, 3.10.62, 3.10.98, 3.12, 4.3.3 and 4.4.3

Fix from Arnaud Dovi:

#11

"
I think I have found the root cause of this elf.h issue

Its a circular dependency problem

  __headers: $(version_h) scripts_basic asm-generic archheaders archscripts FORCE
      $(Q)$(MAKE) $(build)=scripts build_unifdef

  PHONY += headers_install
  headers_install: __headers
      $(if $(wildcard $(srctree)/arch/$(hdr-arch)/include/uapi/asm/Kbuild),, \
        $(error Headers not exportable for the $(SRCARCH) architecture))
      $(Q)$(MAKE) $(hdr-inst)=include/uapi
      $(Q)$(MAKE) $(hdr-inst)=arch/$(hdr-arch)/include/uapi/asm $(hdr-dst)

In short headers_install depends on archscripts but archscripts compiles a code
with a header elf.h installed by headers_install

Next once you fix this you will realize the headers are copied under linux\elf.h
of the sysroot when the code looks for elf.h
"

Signed-off-by: Ray Donnelly <[email protected]>
mingwandroid added a commit that referenced this issue Feb 17, 2017
For versions 3.10.19, 3.10.38, 3.10.62, 3.10.98, 3.12, 4.3.3 and 4.4.3

Fix from Arnaud Dovi:

#11

"
I think I have found the root cause of this elf.h issue

Its a circular dependency problem

  __headers: $(version_h) scripts_basic asm-generic archheaders archscripts FORCE
      $(Q)$(MAKE) $(build)=scripts build_unifdef

  PHONY += headers_install
  headers_install: __headers
      $(if $(wildcard $(srctree)/arch/$(hdr-arch)/include/uapi/asm/Kbuild),, \
        $(error Headers not exportable for the $(SRCARCH) architecture))
      $(Q)$(MAKE) $(hdr-inst)=include/uapi
      $(Q)$(MAKE) $(hdr-inst)=arch/$(hdr-arch)/include/uapi/asm $(hdr-dst)

In short headers_install depends on archscripts but archscripts compiles a code
with a header elf.h installed by headers_install

Next once you fix this you will realize the headers are copied under linux\elf.h
of the sysroot when the code looks for elf.h
"

Signed-off-by: Ray Donnelly <[email protected]>
mingwandroid added a commit that referenced this issue Feb 20, 2017
For versions 3.10.19, 3.10.38, 3.10.62, 3.10.98, 3.12, 4.3.3 and 4.4.3

Fix from Arnaud Dovi:

#11

"
I think I have found the root cause of this elf.h issue

Its a circular dependency problem

  __headers: $(version_h) scripts_basic asm-generic archheaders archscripts FORCE
      $(Q)$(MAKE) $(build)=scripts build_unifdef

  PHONY += headers_install
  headers_install: __headers
      $(if $(wildcard $(srctree)/arch/$(hdr-arch)/include/uapi/asm/Kbuild),, \
        $(error Headers not exportable for the $(SRCARCH) architecture))
      $(Q)$(MAKE) $(hdr-inst)=include/uapi
      $(Q)$(MAKE) $(hdr-inst)=arch/$(hdr-arch)/include/uapi/asm $(hdr-dst)

In short headers_install depends on archscripts but archscripts compiles a code
with a header elf.h installed by headers_install

Next once you fix this you will realize the headers are copied under linux\elf.h
of the sysroot when the code looks for elf.h
"

Signed-off-by: Ray Donnelly <[email protected]>
mingwandroid added a commit that referenced this issue Feb 21, 2017
For versions 3.10.19, 3.10.38, 3.10.62, 3.10.98, 3.12, 4.3.3 and 4.4.3

Fix from Arnaud Dovi:

#11

"
I think I have found the root cause of this elf.h issue

Its a circular dependency problem

  __headers: $(version_h) scripts_basic asm-generic archheaders archscripts FORCE
      $(Q)$(MAKE) $(build)=scripts build_unifdef

  PHONY += headers_install
  headers_install: __headers
      $(if $(wildcard $(srctree)/arch/$(hdr-arch)/include/uapi/asm/Kbuild),, \
        $(error Headers not exportable for the $(SRCARCH) architecture))
      $(Q)$(MAKE) $(hdr-inst)=include/uapi
      $(Q)$(MAKE) $(hdr-inst)=arch/$(hdr-arch)/include/uapi/asm $(hdr-dst)

In short headers_install depends on archscripts but archscripts compiles a code
with a header elf.h installed by headers_install

Next once you fix this you will realize the headers are copied under linux\elf.h
of the sysroot when the code looks for elf.h
"

Signed-off-by: Ray Donnelly <[email protected]>
mingwandroid added a commit that referenced this issue Feb 21, 2017
For versions 3.10.19, 3.10.38, 3.10.62, 3.10.98, 3.12, 4.3.3 and 4.4.3

Fix from Arnaud Dovi:

#11

"
I think I have found the root cause of this elf.h issue

Its a circular dependency problem

  __headers: $(version_h) scripts_basic asm-generic archheaders archscripts FORCE
      $(Q)$(MAKE) $(build)=scripts build_unifdef

  PHONY += headers_install
  headers_install: __headers
      $(if $(wildcard $(srctree)/arch/$(hdr-arch)/include/uapi/asm/Kbuild),, \
        $(error Headers not exportable for the $(SRCARCH) architecture))
      $(Q)$(MAKE) $(hdr-inst)=include/uapi
      $(Q)$(MAKE) $(hdr-inst)=arch/$(hdr-arch)/include/uapi/asm $(hdr-dst)

In short headers_install depends on archscripts but archscripts compiles a code
with a header elf.h installed by headers_install

Next once you fix this you will realize the headers are copied under linux\elf.h
of the sysroot when the code looks for elf.h
"

Signed-off-by: Ray Donnelly <[email protected]>
mingwandroid added a commit that referenced this issue Mar 14, 2017
For versions 3.10.19, 3.10.38, 3.10.62, 3.10.98, 3.12, 4.3.3 and 4.4.3

Fix from Arnaud Dovi:

#11

"
I think I have found the root cause of this elf.h issue

Its a circular dependency problem

  __headers: $(version_h) scripts_basic asm-generic archheaders archscripts FORCE
      $(Q)$(MAKE) $(build)=scripts build_unifdef

  PHONY += headers_install
  headers_install: __headers
      $(if $(wildcard $(srctree)/arch/$(hdr-arch)/include/uapi/asm/Kbuild),, \
        $(error Headers not exportable for the $(SRCARCH) architecture))
      $(Q)$(MAKE) $(hdr-inst)=include/uapi
      $(Q)$(MAKE) $(hdr-inst)=arch/$(hdr-arch)/include/uapi/asm $(hdr-dst)

In short headers_install depends on archscripts but archscripts compiles a code
with a header elf.h installed by headers_install

Next once you fix this you will realize the headers are copied under linux\elf.h
of the sysroot when the code looks for elf.h
"

Signed-off-by: Ray Donnelly <[email protected]>
mingwandroid added a commit that referenced this issue Mar 26, 2017
For versions 3.10.19, 3.10.38, 3.10.62, 3.10.98, 3.12, 4.3.3 and 4.4.3

Fix from Arnaud Dovi:

#11

"
I think I have found the root cause of this elf.h issue

Its a circular dependency problem

  __headers: $(version_h) scripts_basic asm-generic archheaders archscripts FORCE
      $(Q)$(MAKE) $(build)=scripts build_unifdef

  PHONY += headers_install
  headers_install: __headers
      $(if $(wildcard $(srctree)/arch/$(hdr-arch)/include/uapi/asm/Kbuild),, \
        $(error Headers not exportable for the $(SRCARCH) architecture))
      $(Q)$(MAKE) $(hdr-inst)=include/uapi
      $(Q)$(MAKE) $(hdr-inst)=arch/$(hdr-arch)/include/uapi/asm $(hdr-dst)

In short headers_install depends on archscripts but archscripts compiles a code
with a header elf.h installed by headers_install

Next once you fix this you will realize the headers are copied under linux\elf.h
of the sysroot when the code looks for elf.h
"

Signed-off-by: Ray Donnelly <[email protected]>
mingwandroid added a commit that referenced this issue Apr 14, 2017
For versions 3.10.19, 3.10.38, 3.10.62, 3.10.98, 3.12, 4.3.3 and 4.4.3

Fix from Arnaud Dovi:

#11

"
I think I have found the root cause of this elf.h issue

Its a circular dependency problem

  __headers: $(version_h) scripts_basic asm-generic archheaders archscripts FORCE
      $(Q)$(MAKE) $(build)=scripts build_unifdef

  PHONY += headers_install
  headers_install: __headers
      $(if $(wildcard $(srctree)/arch/$(hdr-arch)/include/uapi/asm/Kbuild),, \
        $(error Headers not exportable for the $(SRCARCH) architecture))
      $(Q)$(MAKE) $(hdr-inst)=include/uapi
      $(Q)$(MAKE) $(hdr-inst)=arch/$(hdr-arch)/include/uapi/asm $(hdr-dst)

In short headers_install depends on archscripts but archscripts compiles a code
with a header elf.h installed by headers_install

Next once you fix this you will realize the headers are copied under linux\elf.h
of the sysroot when the code looks for elf.h
"

Signed-off-by: Ray Donnelly <[email protected]>
mingwandroid added a commit that referenced this issue Apr 17, 2017
For versions 3.10.19, 3.10.38, 3.10.62, 3.10.98, 3.12, 4.3.3 and 4.4.3

Fix from Arnaud Dovi:

#11

"
I think I have found the root cause of this elf.h issue

Its a circular dependency problem

  __headers: $(version_h) scripts_basic asm-generic archheaders archscripts FORCE
      $(Q)$(MAKE) $(build)=scripts build_unifdef

  PHONY += headers_install
  headers_install: __headers
      $(if $(wildcard $(srctree)/arch/$(hdr-arch)/include/uapi/asm/Kbuild),, \
        $(error Headers not exportable for the $(SRCARCH) architecture))
      $(Q)$(MAKE) $(hdr-inst)=include/uapi
      $(Q)$(MAKE) $(hdr-inst)=arch/$(hdr-arch)/include/uapi/asm $(hdr-dst)

In short headers_install depends on archscripts but archscripts compiles a code
with a header elf.h installed by headers_install

Next once you fix this you will realize the headers are copied under linux\elf.h
of the sysroot when the code looks for elf.h
"

Signed-off-by: Ray Donnelly <[email protected]>
mingwandroid added a commit that referenced this issue Apr 17, 2017
For versions 3.10.19, 3.10.38, 3.10.62, 3.10.98, 3.12, 4.3.3 and 4.4.3

Fix from Arnaud Dovi:

#11

"
I think I have found the root cause of this elf.h issue

Its a circular dependency problem

  __headers: $(version_h) scripts_basic asm-generic archheaders archscripts FORCE
      $(Q)$(MAKE) $(build)=scripts build_unifdef

  PHONY += headers_install
  headers_install: __headers
      $(if $(wildcard $(srctree)/arch/$(hdr-arch)/include/uapi/asm/Kbuild),, \
        $(error Headers not exportable for the $(SRCARCH) architecture))
      $(Q)$(MAKE) $(hdr-inst)=include/uapi
      $(Q)$(MAKE) $(hdr-inst)=arch/$(hdr-arch)/include/uapi/asm $(hdr-dst)

In short headers_install depends on archscripts but archscripts compiles a code
with a header elf.h installed by headers_install

Next once you fix this you will realize the headers are copied under linux\elf.h
of the sysroot when the code looks for elf.h
"

Signed-off-by: Ray Donnelly <[email protected]>
mingwandroid added a commit that referenced this issue Apr 17, 2017
For versions 3.10.19, 3.10.38, 3.10.62, 3.10.98, 3.12, 4.3.3 and 4.4.3

Fix from Arnaud Dovi:

#11

"
I think I have found the root cause of this elf.h issue

Its a circular dependency problem

  __headers: $(version_h) scripts_basic asm-generic archheaders archscripts FORCE
      $(Q)$(MAKE) $(build)=scripts build_unifdef

  PHONY += headers_install
  headers_install: __headers
      $(if $(wildcard $(srctree)/arch/$(hdr-arch)/include/uapi/asm/Kbuild),, \
        $(error Headers not exportable for the $(SRCARCH) architecture))
      $(Q)$(MAKE) $(hdr-inst)=include/uapi
      $(Q)$(MAKE) $(hdr-inst)=arch/$(hdr-arch)/include/uapi/asm $(hdr-dst)

In short headers_install depends on archscripts but archscripts compiles a code
with a header elf.h installed by headers_install

Next once you fix this you will realize the headers are copied under linux\elf.h
of the sysroot when the code looks for elf.h
"

Signed-off-by: Ray Donnelly <[email protected]>
mingwandroid added a commit that referenced this issue Apr 17, 2017
For versions 3.10.19, 3.10.38, 3.10.62, 3.10.98, 3.12, 4.3.3 and 4.4.3

Fix from Arnaud Dovi:

#11

"
I think I have found the root cause of this elf.h issue

Its a circular dependency problem

  __headers: $(version_h) scripts_basic asm-generic archheaders archscripts FORCE
      $(Q)$(MAKE) $(build)=scripts build_unifdef

  PHONY += headers_install
  headers_install: __headers
      $(if $(wildcard $(srctree)/arch/$(hdr-arch)/include/uapi/asm/Kbuild),, \
        $(error Headers not exportable for the $(SRCARCH) architecture))
      $(Q)$(MAKE) $(hdr-inst)=include/uapi
      $(Q)$(MAKE) $(hdr-inst)=arch/$(hdr-arch)/include/uapi/asm $(hdr-dst)

In short headers_install depends on archscripts but archscripts compiles a code
with a header elf.h installed by headers_install

Next once you fix this you will realize the headers are copied under linux\elf.h
of the sysroot when the code looks for elf.h
"

Signed-off-by: Ray Donnelly <[email protected]>
mingwandroid added a commit that referenced this issue May 31, 2017
For versions 3.10.19, 3.10.38, 3.10.62, 3.10.98, 3.12, 4.3.3 and 4.4.3

Fix from Arnaud Dovi:

#11

"
I think I have found the root cause of this elf.h issue

Its a circular dependency problem

  __headers: $(version_h) scripts_basic asm-generic archheaders archscripts FORCE
      $(Q)$(MAKE) $(build)=scripts build_unifdef

  PHONY += headers_install
  headers_install: __headers
      $(if $(wildcard $(srctree)/arch/$(hdr-arch)/include/uapi/asm/Kbuild),, \
        $(error Headers not exportable for the $(SRCARCH) architecture))
      $(Q)$(MAKE) $(hdr-inst)=include/uapi
      $(Q)$(MAKE) $(hdr-inst)=arch/$(hdr-arch)/include/uapi/asm $(hdr-dst)

In short headers_install depends on archscripts but archscripts compiles a code
with a header elf.h installed by headers_install

Next once you fix this you will realize the headers are copied under linux\elf.h
of the sysroot when the code looks for elf.h
"

Signed-off-by: Ray Donnelly <[email protected]>
mingwandroid added a commit that referenced this issue Jun 23, 2017
For versions 3.10.19, 3.10.38, 3.10.62, 3.10.98, 3.12, 4.3.3 and 4.4.3

Fix from Arnaud Dovi:

#11

"
I think I have found the root cause of this elf.h issue

Its a circular dependency problem

  __headers: $(version_h) scripts_basic asm-generic archheaders archscripts FORCE
      $(Q)$(MAKE) $(build)=scripts build_unifdef

  PHONY += headers_install
  headers_install: __headers
      $(if $(wildcard $(srctree)/arch/$(hdr-arch)/include/uapi/asm/Kbuild),, \
        $(error Headers not exportable for the $(SRCARCH) architecture))
      $(Q)$(MAKE) $(hdr-inst)=include/uapi
      $(Q)$(MAKE) $(hdr-inst)=arch/$(hdr-arch)/include/uapi/asm $(hdr-dst)

In short headers_install depends on archscripts but archscripts compiles a code
with a header elf.h installed by headers_install

Next once you fix this you will realize the headers are copied under linux\elf.h
of the sysroot when the code looks for elf.h
"

Signed-off-by: Ray Donnelly <[email protected]>
mingwandroid added a commit that referenced this issue Jul 1, 2017
For versions 3.10.19, 3.10.38, 3.10.62, 3.10.98, 3.12, 4.3.3 and 4.4.3

Fix from Arnaud Dovi:

#11

"
I think I have found the root cause of this elf.h issue

Its a circular dependency problem

  __headers: $(version_h) scripts_basic asm-generic archheaders archscripts FORCE
      $(Q)$(MAKE) $(build)=scripts build_unifdef

  PHONY += headers_install
  headers_install: __headers
      $(if $(wildcard $(srctree)/arch/$(hdr-arch)/include/uapi/asm/Kbuild),, \
        $(error Headers not exportable for the $(SRCARCH) architecture))
      $(Q)$(MAKE) $(hdr-inst)=include/uapi
      $(Q)$(MAKE) $(hdr-inst)=arch/$(hdr-arch)/include/uapi/asm $(hdr-dst)

In short headers_install depends on archscripts but archscripts compiles a code
with a header elf.h installed by headers_install

Next once you fix this you will realize the headers are copied under linux\elf.h
of the sysroot when the code looks for elf.h
"

Signed-off-by: Ray Donnelly <[email protected]>
mingwandroid added a commit that referenced this issue May 17, 2018
For versions 3.10.19, 3.10.38, 3.10.62, 3.10.98, 3.12, 4.3.3 and 4.4.3

Fix from Arnaud Dovi:

#11

"
I think I have found the root cause of this elf.h issue

Its a circular dependency problem

  __headers: $(version_h) scripts_basic asm-generic archheaders archscripts FORCE
      $(Q)$(MAKE) $(build)=scripts build_unifdef

  PHONY += headers_install
  headers_install: __headers
      $(if $(wildcard $(srctree)/arch/$(hdr-arch)/include/uapi/asm/Kbuild),, \
        $(error Headers not exportable for the $(SRCARCH) architecture))
      $(Q)$(MAKE) $(hdr-inst)=include/uapi
      $(Q)$(MAKE) $(hdr-inst)=arch/$(hdr-arch)/include/uapi/asm $(hdr-dst)

In short headers_install depends on archscripts but archscripts compiles a code
with a header elf.h installed by headers_install

Next once you fix this you will realize the headers are copied under linux\elf.h
of the sysroot when the code looks for elf.h
"

Signed-off-by: Ray Donnelly <[email protected]>
msarahan pushed a commit to ContinuumIO/crosstool-ng that referenced this issue Aug 16, 2018
For versions 3.10.19, 3.10.38, 3.10.62, 3.10.98, 3.12, 4.3.3 and 4.4.3

Fix from Arnaud Dovi:

diorcety/crosstool-ng#11

"
I think I have found the root cause of this elf.h issue

Its a circular dependency problem

  __headers: $(version_h) scripts_basic asm-generic archheaders archscripts FORCE
      $(Q)$(MAKE) $(build)=scripts build_unifdef

  PHONY += headers_install
  headers_install: __headers
      $(if $(wildcard $(srctree)/arch/$(hdr-arch)/include/uapi/asm/Kbuild),, \
        $(error Headers not exportable for the $(SRCARCH) architecture))
      $(Q)$(MAKE) $(hdr-inst)=include/uapi
      $(Q)$(MAKE) $(hdr-inst)=arch/$(hdr-arch)/include/uapi/asm $(hdr-dst)

In short headers_install depends on archscripts but archscripts compiles a code
with a header elf.h installed by headers_install

Next once you fix this you will realize the headers are copied under linux\elf.h
of the sysroot when the code looks for elf.h
"

Signed-off-by: Ray Donnelly <[email protected]>
mingwandroid added a commit to ContinuumIO/crosstool-ng that referenced this issue Feb 10, 2019
For versions 3.10.19, 3.10.38, 3.10.62, 3.10.98, 3.12, 4.3.3 and 4.4.3

Fix from Arnaud Dovi:

diorcety/crosstool-ng#11

"
I think I have found the root cause of this elf.h issue

Its a circular dependency problem

  __headers: $(version_h) scripts_basic asm-generic archheaders archscripts FORCE
      $(Q)$(MAKE) $(build)=scripts build_unifdef

  PHONY += headers_install
  headers_install: __headers
      $(if $(wildcard $(srctree)/arch/$(hdr-arch)/include/uapi/asm/Kbuild),, \
        $(error Headers not exportable for the $(SRCARCH) architecture))
      $(Q)$(MAKE) $(hdr-inst)=include/uapi
      $(Q)$(MAKE) $(hdr-inst)=arch/$(hdr-arch)/include/uapi/asm $(hdr-dst)

In short headers_install depends on archscripts but archscripts compiles a code
with a header elf.h installed by headers_install

Next once you fix this you will realize the headers are copied under linux\elf.h
of the sysroot when the code looks for elf.h
"

Signed-off-by: Ray Donnelly <[email protected]>
mingwandroid added a commit to ContinuumIO/crosstool-ng that referenced this issue Oct 7, 2019
For versions 3.10.19, 3.10.38, 3.10.62, 3.10.98, 3.12, 4.3.3 and 4.4.3

Fix from Arnaud Dovi:

diorcety/crosstool-ng#11

"
I think I have found the root cause of this elf.h issue

Its a circular dependency problem

  __headers: $(version_h) scripts_basic asm-generic archheaders archscripts FORCE
      $(Q)$(MAKE) $(build)=scripts build_unifdef

  PHONY += headers_install
  headers_install: __headers
      $(if $(wildcard $(srctree)/arch/$(hdr-arch)/include/uapi/asm/Kbuild),, \
        $(error Headers not exportable for the $(SRCARCH) architecture))
      $(Q)$(MAKE) $(hdr-inst)=include/uapi
      $(Q)$(MAKE) $(hdr-inst)=arch/$(hdr-arch)/include/uapi/asm $(hdr-dst)

In short headers_install depends on archscripts but archscripts compiles a code
with a header elf.h installed by headers_install

Next once you fix this you will realize the headers are copied under linux\elf.h
of the sysroot when the code looks for elf.h
"

Signed-off-by: Ray Donnelly <[email protected]>
isuruf pushed a commit to conda-forge/crosstool-ng that referenced this issue May 11, 2020
For versions 3.10.19, 3.10.38, 3.10.62, 3.10.98, 3.12, 4.3.3 and 4.4.3

Fix from Arnaud Dovi:

diorcety/crosstool-ng#11

"
I think I have found the root cause of this elf.h issue

Its a circular dependency problem

  __headers: $(version_h) scripts_basic asm-generic archheaders archscripts FORCE
      $(Q)$(MAKE) $(build)=scripts build_unifdef

  PHONY += headers_install
  headers_install: __headers
      $(if $(wildcard $(srctree)/arch/$(hdr-arch)/include/uapi/asm/Kbuild),, \
        $(error Headers not exportable for the $(SRCARCH) architecture))
      $(Q)$(MAKE) $(hdr-inst)=include/uapi
      $(Q)$(MAKE) $(hdr-inst)=arch/$(hdr-arch)/include/uapi/asm $(hdr-dst)

In short headers_install depends on archscripts but archscripts compiles a code
with a header elf.h installed by headers_install

Next once you fix this you will realize the headers are copied under linux\elf.h
of the sysroot when the code looks for elf.h
"

Signed-off-by: Ray Donnelly <[email protected]>
mingwandroid added a commit to mingwandroid/crosstool-ng that referenced this issue Jan 22, 2021
For versions 3.10.19, 3.10.38, 3.10.62, 3.10.98, 3.12, 4.3.3 and 4.4.3

Fix from Arnaud Dovi:

diorcety/crosstool-ng#11

"
I think I have found the root cause of this elf.h issue

Its a circular dependency problem

  __headers: $(version_h) scripts_basic asm-generic archheaders archscripts FORCE
      $(Q)$(MAKE) $(build)=scripts build_unifdef

  PHONY += headers_install
  headers_install: __headers
      $(if $(wildcard $(srctree)/arch/$(hdr-arch)/include/uapi/asm/Kbuild),, \
        $(error Headers not exportable for the $(SRCARCH) architecture))
      $(Q)$(MAKE) $(hdr-inst)=include/uapi
      $(Q)$(MAKE) $(hdr-inst)=arch/$(hdr-arch)/include/uapi/asm $(hdr-dst)

In short headers_install depends on archscripts but archscripts compiles a code
with a header elf.h installed by headers_install

Next once you fix this you will realize the headers are copied under linux\elf.h
of the sysroot when the code looks for elf.h
"

Signed-off-by: Ray Donnelly <[email protected]>
mingwandroid added a commit to mingwandroid/crosstool-ng that referenced this issue Feb 18, 2021
For versions 3.10.19, 3.10.38, 3.10.62, 3.10.98, 3.12, 4.3.3 and 4.4.3

Fix from Arnaud Dovi:

diorcety/crosstool-ng#11

"
I think I have found the root cause of this elf.h issue

Its a circular dependency problem

  __headers: $(version_h) scripts_basic asm-generic archheaders archscripts FORCE
      $(Q)$(MAKE) $(build)=scripts build_unifdef

  PHONY += headers_install
  headers_install: __headers
      $(if $(wildcard $(srctree)/arch/$(hdr-arch)/include/uapi/asm/Kbuild),, \
        $(error Headers not exportable for the $(SRCARCH) architecture))
      $(Q)$(MAKE) $(hdr-inst)=include/uapi
      $(Q)$(MAKE) $(hdr-inst)=arch/$(hdr-arch)/include/uapi/asm $(hdr-dst)

In short headers_install depends on archscripts but archscripts compiles a code
with a header elf.h installed by headers_install

Next once you fix this you will realize the headers are copied under linux\elf.h
of the sysroot when the code looks for elf.h
"

Signed-off-by: Ray Donnelly <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants