binutils: make it a proper package
* Convert binutils to a proper autotargets package
* Add version 2.21 and drop version 2.17
* Hook up packaged binutils for target gcc
* Build tools are on HOST_DIR now so change it
* Move cross/host gcc to HOST_DIR
* Drop kludge from commit 3c77bab2ee
This is fixed in the next commit "gcc: install copies of libgcc,
libstdc++ and libgcj to the sysroot" - tested for arm & x86_64
targets.
* TARGET_CROSS now pointed to HOST_DIR too
[Peter: Config.in tweaks]
Signed-off-by: Gustavo Zacarias <gustavo@zacarias.com.ar>
Signed-off-by: Peter Korsgaard <jacmet@sunsite.dk>
This commit is contained in:
parent
b25cf0a05c
commit
009407e6be
4
Makefile
4
Makefile
@ -245,7 +245,7 @@ BASE_TARGETS += host-ccache
|
|||||||
endif
|
endif
|
||||||
|
|
||||||
ifeq ($(BR2_TOOLCHAIN_BUILDROOT),y)
|
ifeq ($(BR2_TOOLCHAIN_BUILDROOT),y)
|
||||||
BASE_TARGETS += uclibc-configured binutils cross_compiler uclibc-target-utils kernel-headers
|
BASE_TARGETS += uclibc-configured host-binutils cross_compiler uclibc-target-utils kernel-headers
|
||||||
else
|
else
|
||||||
BASE_TARGETS += uclibc
|
BASE_TARGETS += uclibc
|
||||||
endif
|
endif
|
||||||
@ -618,7 +618,7 @@ endif
|
|||||||
|
|
||||||
configured: dirs kernel-headers uclibc-config busybox-config linux26-config
|
configured: dirs kernel-headers uclibc-config busybox-config linux26-config
|
||||||
|
|
||||||
prepatch: gcc-patched binutils-patched gdb-patched uclibc-patched
|
prepatch: gcc-patched gdb-patched uclibc-patched
|
||||||
|
|
||||||
cross: $(BASE_TARGETS)
|
cross: $(BASE_TARGETS)
|
||||||
|
|
||||||
|
@ -35,6 +35,7 @@ endmenu
|
|||||||
menu "Development tools"
|
menu "Development tools"
|
||||||
source "package/autoconf/Config.in"
|
source "package/autoconf/Config.in"
|
||||||
source "package/automake/Config.in"
|
source "package/automake/Config.in"
|
||||||
|
source "package/binutils/Config.in"
|
||||||
source "package/bison/Config.in"
|
source "package/bison/Config.in"
|
||||||
source "package/bsdiff/Config.in"
|
source "package/bsdiff/Config.in"
|
||||||
source "package/ccache/Config.in"
|
source "package/ccache/Config.in"
|
||||||
|
@ -109,7 +109,7 @@ TARGET_CXXFLAGS=$(TARGET_CFLAGS)
|
|||||||
TARGET_SYSROOT_OPT=--sysroot=$(STAGING_DIR)
|
TARGET_SYSROOT_OPT=--sysroot=$(STAGING_DIR)
|
||||||
|
|
||||||
ifeq ($(BR2_TOOLCHAIN_BUILDROOT),y)
|
ifeq ($(BR2_TOOLCHAIN_BUILDROOT),y)
|
||||||
TARGET_CROSS=$(STAGING_DIR)/usr/bin/$(REAL_GNU_TARGET_NAME)-
|
TARGET_CROSS=$(HOST_DIR)/usr/bin/$(REAL_GNU_TARGET_NAME)-
|
||||||
else ifeq ($(BR2_TOOLCHAIN_EXTERNAL),y)
|
else ifeq ($(BR2_TOOLCHAIN_EXTERNAL),y)
|
||||||
TOOLCHAIN_EXTERNAL_PREFIX=$(call qstrip,$(BR2_TOOLCHAIN_EXTERNAL_PREFIX))
|
TOOLCHAIN_EXTERNAL_PREFIX=$(call qstrip,$(BR2_TOOLCHAIN_EXTERNAL_PREFIX))
|
||||||
ifeq ($(BR2_TOOLCHAIN_EXTERNAL_DOWNLOAD),y)
|
ifeq ($(BR2_TOOLCHAIN_EXTERNAL_DOWNLOAD),y)
|
||||||
|
21
package/binutils/Config.in
Normal file
21
package/binutils/Config.in
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
config BR2_PACKAGE_BINUTILS
|
||||||
|
bool "libbfd (binutils)"
|
||||||
|
depends on BR2_TOOLCHAIN_BUILDROOT
|
||||||
|
select BR2_PACKAGE_GETTEXT if BR2_NEEDS_GETTEXT_IF_LOCALE
|
||||||
|
select BR2_PACKAGE_LIBINTL if BR2_NEEDS_GETTEXT_IF_LOCALE
|
||||||
|
help
|
||||||
|
Install libbfd from binutils in the target.
|
||||||
|
|
||||||
|
This is used by oprofile to avoid a full-blown target binutils.
|
||||||
|
|
||||||
|
config BR2_PACKAGE_BINUTILS_TARGET
|
||||||
|
bool "binutils binaries"
|
||||||
|
depends on BR2_PACKAGE_BINUTILS
|
||||||
|
help
|
||||||
|
The GNU Binutils are a collection of binary tools:
|
||||||
|
|
||||||
|
ld - the GNU linker.
|
||||||
|
as - the GNU assembler.
|
||||||
|
and others...
|
||||||
|
|
||||||
|
http://www.gnu.org/software/binutils/
|
@ -1,18 +1,11 @@
|
|||||||
# Choose binutils version.
|
|
||||||
|
|
||||||
comment "Binutils Options"
|
comment "Binutils Options"
|
||||||
|
|
||||||
choice
|
choice
|
||||||
prompt "Binutils Version"
|
prompt "Binutils Version"
|
||||||
default BR2_BINUTILS_VERSION_2_20_1
|
default BR2_BINUTILS_VERSION_2_21
|
||||||
help
|
help
|
||||||
Select the version of binutils you wish to use.
|
Select the version of binutils you wish to use.
|
||||||
|
|
||||||
config BR2_BINUTILS_VERSION_2_17
|
|
||||||
depends on !BR2_avr32
|
|
||||||
depends on BR2_DEPRECATED
|
|
||||||
bool "binutils 2.17"
|
|
||||||
|
|
||||||
config BR2_BINUTILS_VERSION_2_18
|
config BR2_BINUTILS_VERSION_2_18
|
||||||
depends on !BR2_avr32
|
depends on !BR2_avr32
|
||||||
depends on BR2_DEPRECATED
|
depends on BR2_DEPRECATED
|
||||||
@ -40,19 +33,23 @@ choice
|
|||||||
depends on !BR2_avr32
|
depends on !BR2_avr32
|
||||||
bool "binutils 2.20.1"
|
bool "binutils 2.20.1"
|
||||||
|
|
||||||
|
config BR2_BINUTILS_VERSION_2_21
|
||||||
|
depends on !BR2_avr32
|
||||||
|
bool "binutils 2.21"
|
||||||
|
|
||||||
endchoice
|
endchoice
|
||||||
|
|
||||||
config BR2_BINUTILS_VERSION
|
config BR2_BINUTILS_VERSION
|
||||||
string
|
string
|
||||||
default "2.17" if BR2_BINUTILS_VERSION_2_17
|
|
||||||
default "2.18" if BR2_BINUTILS_VERSION_2_18
|
default "2.18" if BR2_BINUTILS_VERSION_2_18
|
||||||
default "2.18-avr32-1.0.1" if BR2_BINUTILS_VERSION_2_18_AVR32_1_0_1
|
default "2.18-avr32-1.0.1" if BR2_BINUTILS_VERSION_2_18_AVR32_1_0_1
|
||||||
default "2.19" if BR2_BINUTILS_VERSION_2_19
|
default "2.19" if BR2_BINUTILS_VERSION_2_19
|
||||||
default "2.19.1" if BR2_BINUTILS_VERSION_2_19_1
|
default "2.19.1" if BR2_BINUTILS_VERSION_2_19_1
|
||||||
default "2.20" if BR2_BINUTILS_VERSION_2_20
|
default "2.20" if BR2_BINUTILS_VERSION_2_20
|
||||||
default "2.20.1" if BR2_BINUTILS_VERSION_2_20_1
|
default "2.20.1" if BR2_BINUTILS_VERSION_2_20_1
|
||||||
|
default "2.21" if BR2_BINUTILS_VERSION_2_21
|
||||||
|
|
||||||
config BR2_EXTRA_BINUTILS_CONFIG_OPTIONS
|
config BR2_BINUTILS_EXTRA_CONFIG_OPTIONS
|
||||||
string "Additional binutils options"
|
string "Additional binutils options"
|
||||||
default ""
|
default ""
|
||||||
help
|
help
|
24
package/binutils/binutils-2.21/110-arm-eabi-conf.patch
Normal file
24
package/binutils/binutils-2.21/110-arm-eabi-conf.patch
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
diff -rdup binutils-2.18.50.0.3.orig/configure binutils-2.18.50.0.3/configure
|
||||||
|
--- binutils-2.18.50.0.3.orig/configure 2007-11-22 12:41:26.000000000 +0100
|
||||||
|
+++ binutils-2.18.50.0.3/configure 2007-11-22 12:45:01.000000000 +0100
|
||||||
|
@@ -2245,7 +2245,7 @@ case "${target}" in
|
||||||
|
noconfigdirs="$noconfigdirs target-libffi target-qthreads"
|
||||||
|
libgloss_dir=arm
|
||||||
|
;;
|
||||||
|
- arm*-*-linux-gnueabi)
|
||||||
|
+ arm*-*-linux-*gnueabi)
|
||||||
|
noconfigdirs="$noconfigdirs target-qthreads"
|
||||||
|
noconfigdirs="$noconfigdirs target-libobjc"
|
||||||
|
case ${with_newlib} in
|
||||||
|
diff -rdup binutils-2.18.50.0.3.orig/configure.ac binutils-2.18.50.0.3/configure.ac
|
||||||
|
--- binutils-2.18.50.0.3.orig/configure.ac 2007-11-22 12:41:26.000000000 +0100
|
||||||
|
+++ binutils-2.18.50.0.3/configure.ac 2007-11-22 12:44:54.000000000 +0100
|
||||||
|
@@ -522,7 +522,7 @@ case "${target}" in
|
||||||
|
noconfigdirs="$noconfigdirs target-libffi target-qthreads"
|
||||||
|
libgloss_dir=arm
|
||||||
|
;;
|
||||||
|
- arm*-*-linux-gnueabi)
|
||||||
|
+ arm*-*-linux-*gnueabi)
|
||||||
|
noconfigdirs="$noconfigdirs target-qthreads"
|
||||||
|
noconfigdirs="$noconfigdirs target-libobjc"
|
||||||
|
case ${with_newlib} in
|
42
package/binutils/binutils-2.21/120-sh-conf.patch
Normal file
42
package/binutils/binutils-2.21/120-sh-conf.patch
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
diff -rdup binutils-2.18.50.0.9.old/configure binutils-2.18.50.0.9/configure
|
||||||
|
--- binutils-2.18.50.0.9.old/configure 2008-08-23 17:36:13.000000000 +0200
|
||||||
|
+++ binutils-2.18.50.0.9/configure 2008-10-14 14:25:22.000000000 +0200
|
||||||
|
@@ -2281,7 +2281,7 @@ case "${target}" in
|
||||||
|
am33_2.0-*-linux*)
|
||||||
|
noconfigdirs="$noconfigdirs ${libgcj} target-newlib target-libgloss"
|
||||||
|
;;
|
||||||
|
- sh-*-linux*)
|
||||||
|
+ sh*-*-linux*)
|
||||||
|
noconfigdirs="$noconfigdirs ${libgcj} target-newlib target-libgloss"
|
||||||
|
;;
|
||||||
|
sh*-*-pe|mips*-*-pe|*arm-wince-pe)
|
||||||
|
@@ -2606,7 +2606,7 @@ case "${target}" in
|
||||||
|
romp-*-*)
|
||||||
|
noconfigdirs="$noconfigdirs bfd binutils ld gas opcodes target-libgloss ${libgcj}"
|
||||||
|
;;
|
||||||
|
- sh-*-* | sh64-*-*)
|
||||||
|
+ sh*-*-* | sh64-*-*)
|
||||||
|
case "${host}" in
|
||||||
|
i[3456789]86-*-vsta) ;; # don't add gprof back in
|
||||||
|
i[3456789]86-*-go32*) ;; # don't add gprof back in
|
||||||
|
diff -rdup binutils-2.18.50.0.9.old/configure.ac binutils-2.18.50.0.9/configure.ac
|
||||||
|
--- binutils-2.18.50.0.9.old/configure.ac 2008-08-23 17:36:13.000000000 +0200
|
||||||
|
+++ binutils-2.18.50.0.9/configure.ac 2008-10-14 14:25:11.000000000 +0200
|
||||||
|
@@ -530,7 +530,7 @@ case "${target}" in
|
||||||
|
am33_2.0-*-linux*)
|
||||||
|
noconfigdirs="$noconfigdirs ${libgcj} target-newlib target-libgloss"
|
||||||
|
;;
|
||||||
|
- sh-*-linux*)
|
||||||
|
+ sh*-*-linux*)
|
||||||
|
noconfigdirs="$noconfigdirs ${libgcj} target-newlib target-libgloss"
|
||||||
|
;;
|
||||||
|
sh*-*-pe|mips*-*-pe|*arm-wince-pe)
|
||||||
|
@@ -855,7 +855,7 @@ case "${target}" in
|
||||||
|
romp-*-*)
|
||||||
|
noconfigdirs="$noconfigdirs bfd binutils ld gas opcodes target-libgloss ${libgcj}"
|
||||||
|
;;
|
||||||
|
- sh-*-* | sh64-*-*)
|
||||||
|
+ sh*-*-* | sh64-*-*)
|
||||||
|
case "${host}" in
|
||||||
|
i[[3456789]]86-*-vsta) ;; # don't add gprof back in
|
||||||
|
i[[3456789]]86-*-go32*) ;; # don't add gprof back in
|
@ -0,0 +1,24 @@
|
|||||||
|
diff -u binutils-2.17.50.0.17.oorig/ld/Makefile.am binutils-2.17.50.0.17/ld/Makefile.am
|
||||||
|
--- binutils-2.17.50.0.17.oorig/ld/Makefile.am 2007-06-18 19:29:29.000000000 +0200
|
||||||
|
+++ binutils-2.17.50.0.17/ld/Makefile.am 2007-06-25 10:00:36.000000000 +0200
|
||||||
|
@@ -18,7 +18,7 @@
|
||||||
|
# We put the scripts in the directory $(scriptdir)/ldscripts.
|
||||||
|
# We can't put the scripts in $(datadir) because the SEARCH_DIR
|
||||||
|
# directives need to be different for native and cross linkers.
|
||||||
|
-scriptdir = $(tooldir)/lib
|
||||||
|
+scriptdir = $(libdir)
|
||||||
|
|
||||||
|
EMUL = @EMUL@
|
||||||
|
EMULATION_OFILES = @EMULATION_OFILES@
|
||||||
|
diff -u binutils-2.17.50.0.17.oorig/ld/Makefile.in binutils-2.17.50.0.17/ld/Makefile.in
|
||||||
|
--- binutils-2.17.50.0.17.oorig/ld/Makefile.in 2007-06-18 19:29:29.000000000 +0200
|
||||||
|
+++ binutils-2.17.50.0.17/ld/Makefile.in 2007-06-25 10:00:36.000000000 +0200
|
||||||
|
@@ -287,7 +287,7 @@
|
||||||
|
# We put the scripts in the directory $(scriptdir)/ldscripts.
|
||||||
|
# We can't put the scripts in $(datadir) because the SEARCH_DIR
|
||||||
|
# directives need to be different for native and cross linkers.
|
||||||
|
-scriptdir = $(tooldir)/lib
|
||||||
|
+scriptdir = $(libdir)
|
||||||
|
BASEDIR = $(srcdir)/..
|
||||||
|
BFDDIR = $(BASEDIR)/bfd
|
||||||
|
INCDIR = $(BASEDIR)/include
|
@ -0,0 +1,21 @@
|
|||||||
|
diff -Nura binutils-2.21.orig/ld/emultempl/elf32.em binutils-2.21/ld/emultempl/elf32.em
|
||||||
|
--- binutils-2.21.orig/ld/emultempl/elf32.em 2010-10-29 09:10:36.000000000 -0300
|
||||||
|
+++ binutils-2.21/ld/emultempl/elf32.em 2010-12-10 09:26:56.746102724 -0300
|
||||||
|
@@ -1270,6 +1270,8 @@
|
||||||
|
&& command_line.rpath == NULL)
|
||||||
|
{
|
||||||
|
lib_path = (const char *) getenv ("LD_RUN_PATH");
|
||||||
|
+ if ((lib_path) && (strlen (lib_path) == 0))
|
||||||
|
+ lib_path = NULL;
|
||||||
|
if (gld${EMULATION_NAME}_search_needed (lib_path, &n,
|
||||||
|
force))
|
||||||
|
break;
|
||||||
|
@@ -1497,6 +1499,8 @@
|
||||||
|
rpath = command_line.rpath;
|
||||||
|
if (rpath == NULL)
|
||||||
|
rpath = (const char *) getenv ("LD_RUN_PATH");
|
||||||
|
+ if ((rpath) && (strlen (rpath) == 0))
|
||||||
|
+ rpath = NULL;
|
||||||
|
|
||||||
|
for (abfd = link_info.input_bfds; abfd; abfd = abfd->link_next)
|
||||||
|
if (bfd_get_flavour (abfd) == bfd_target_elf_flavour)
|
55
package/binutils/binutils.mk
Normal file
55
package/binutils/binutils.mk
Normal file
@ -0,0 +1,55 @@
|
|||||||
|
#############################################################
|
||||||
|
#
|
||||||
|
# binutils
|
||||||
|
#
|
||||||
|
#############################################################
|
||||||
|
|
||||||
|
BINUTILS_VERSION = $(call qstrip,$(BR2_BINUTILS_VERSION))
|
||||||
|
BINUTILS_SOURCE = binutils-$(BINUTILS_VERSION).tar.bz2
|
||||||
|
BINUTILS_SITE = $(BR2_GNU_MIRROR)/binutils
|
||||||
|
ifeq ($(ARCH),avr32)
|
||||||
|
BINUTILS_SITE = ftp://www.at91.com/pub/buildroot
|
||||||
|
endif
|
||||||
|
BINUTILS_EXTRA_CONFIG_OPTIONS = $(call qstrip,$(BR2_BINUTILS_EXTRA_CONFIG_OPTIONS))
|
||||||
|
BINUTILS_INSTALL_STAGING = YES
|
||||||
|
BINUTILS_DEPENDENCIES = $(if $(BR2_NEEDS_GETTEXT_IF_LOCALE),gettext libintl)
|
||||||
|
|
||||||
|
# We need to specify host & target to avoid breaking ARM EABI
|
||||||
|
BINUTILS_CONF_OPT = --disable-multilib --disable-werror \
|
||||||
|
--host=$(REAL_GNU_TARGET_NAME) \
|
||||||
|
--target=$(REAL_GNU_TARGET_NAME) \
|
||||||
|
--enable-shared \
|
||||||
|
$(BINUTILS_EXTRA_CONFIG_OPTIONS)
|
||||||
|
|
||||||
|
# Install binutils after busybox to prefer full-blown utilities
|
||||||
|
ifeq ($(BR2_PACKAGE_BUSYBOX),y)
|
||||||
|
BINUTILS_DEPENDENCIES += busybox
|
||||||
|
endif
|
||||||
|
|
||||||
|
# "host" binutils should actually be "cross"
|
||||||
|
# We just keep the convention of "host utility" for now
|
||||||
|
HOST_BINUTILS_CONF_OPT = --disable-multilib --disable-werror \
|
||||||
|
--target=$(REAL_GNU_TARGET_NAME) \
|
||||||
|
$(BR2_CONFIGURE_STAGING_SYSROOT) \
|
||||||
|
$(BINUTILS_EXTRA_CONFIG_OPTIONS)
|
||||||
|
|
||||||
|
# We just want libbfd, not the full-blown binutils in staging
|
||||||
|
define BINUTILS_INSTALL_STAGING_CMDS
|
||||||
|
$(MAKE) -C $(@D)/bfd DESTDIR=$(STAGING_DIR) install
|
||||||
|
endef
|
||||||
|
|
||||||
|
# only libbfd in the target...
|
||||||
|
BINUTILS_INSTALL_FROM = $(@D)/bfd
|
||||||
|
|
||||||
|
# unless we want full...
|
||||||
|
ifeq ($(BR2_PACKAGE_BINUTILS_TARGET),y)
|
||||||
|
BINUTILS_INSTALL_FROM = $(@D)
|
||||||
|
endif
|
||||||
|
|
||||||
|
define BINUTILS_INSTALL_TARGET_CMDS
|
||||||
|
$(TARGET_MAKE_ENV) $(MAKE) -C $(BINUTILS_INSTALL_FROM) \
|
||||||
|
DESTDIR=$(TARGET_DIR) install
|
||||||
|
endef
|
||||||
|
|
||||||
|
$(eval $(call AUTOTARGETS,package,binutils))
|
||||||
|
$(eval $(call AUTOTARGETS,package,binutils,host))
|
@ -1,6 +1,6 @@
|
|||||||
BR2_CONFIGURE_DEVEL_SYSROOT=--with-sysroot=$(TOOLCHAIN_DIR)/uClibc_dev/
|
BR2_CONFIGURE_DEVEL_SYSROOT=--with-sysroot=$(TOOLCHAIN_DIR)/uClibc_dev/
|
||||||
BR2_CONFIGURE_STAGING_SYSROOT=--with-sysroot=$(STAGING_DIR)
|
BR2_CONFIGURE_STAGING_SYSROOT=--with-sysroot=$(STAGING_DIR)
|
||||||
BR2_CONFIGURE_BUILD_TOOLS=--with-build-time-tools=$(STAGING_DIR)/usr/$(REAL_GNU_TARGET_NAME)/bin
|
BR2_CONFIGURE_BUILD_TOOLS=--with-build-time-tools=$(HOST_DIR)/usr/$(REAL_GNU_TARGET_NAME)/bin
|
||||||
|
|
||||||
# gcc has a bunch of needed stuff....
|
# gcc has a bunch of needed stuff....
|
||||||
include toolchain/gcc/Makefile.in
|
include toolchain/gcc/Makefile.in
|
||||||
|
@ -1,139 +0,0 @@
|
|||||||
--- binutils-2.16.91.0.7/bfd/configure
|
|
||||||
+++ binutils-2.16.91.0.7/bfd/configure
|
|
||||||
@@ -3576,7 +3576,7 @@
|
|
||||||
;;
|
|
||||||
|
|
||||||
# This must be Linux ELF.
|
|
||||||
-linux-gnu*)
|
|
||||||
+linux-gnu*|linux-uclibc*)
|
|
||||||
lt_cv_deplibs_check_method=pass_all
|
|
||||||
;;
|
|
||||||
|
|
||||||
--- binutils-2.16.91.0.7/binutils/configure
|
|
||||||
+++ binutils-2.16.91.0.7/binutils/configure
|
|
||||||
@@ -3411,7 +3411,7 @@
|
|
||||||
;;
|
|
||||||
|
|
||||||
# This must be Linux ELF.
|
|
||||||
-linux-gnu*)
|
|
||||||
+linux-gnu*|linux-uclibc*)
|
|
||||||
lt_cv_deplibs_check_method=pass_all
|
|
||||||
;;
|
|
||||||
|
|
||||||
--- binutils-2.16.91.0.7/configure
|
|
||||||
+++ binutils-2.16.91.0.7/configure
|
|
||||||
@@ -1270,7 +1270,7 @@
|
|
||||||
am33_2.0-*-linux*)
|
|
||||||
noconfigdirs="$noconfigdirs ${libgcj} target-newlib target-libgloss"
|
|
||||||
;;
|
|
||||||
- sh-*-linux*)
|
|
||||||
+ sh*-*-linux*)
|
|
||||||
noconfigdirs="$noconfigdirs ${libgcj} target-newlib target-libgloss"
|
|
||||||
;;
|
|
||||||
sh*-*-pe|mips*-*-pe|*arm-wince-pe)
|
|
||||||
@@ -1578,7 +1578,7 @@
|
|
||||||
romp-*-*)
|
|
||||||
noconfigdirs="$noconfigdirs bfd binutils ld gas opcodes target-libgloss ${libgcj}"
|
|
||||||
;;
|
|
||||||
- sh-*-* | sh64-*-*)
|
|
||||||
+ sh*-*-* | sh64-*-*)
|
|
||||||
case "${host}" in
|
|
||||||
i[3456789]86-*-vsta) ;; # don't add gprof back in
|
|
||||||
i[3456789]86-*-go32*) ;; # don't add gprof back in
|
|
||||||
--- binutils-2.16.91.0.7/configure.in
|
|
||||||
+++ binutils-2.16.91.0.7/configure.in
|
|
||||||
@@ -468,7 +468,7 @@
|
|
||||||
am33_2.0-*-linux*)
|
|
||||||
noconfigdirs="$noconfigdirs ${libgcj} target-newlib target-libgloss"
|
|
||||||
;;
|
|
||||||
- sh-*-linux*)
|
|
||||||
+ sh*-*-linux*)
|
|
||||||
noconfigdirs="$noconfigdirs ${libgcj} target-newlib target-libgloss"
|
|
||||||
;;
|
|
||||||
sh*-*-pe|mips*-*-pe|*arm-wince-pe)
|
|
||||||
@@ -776,7 +776,7 @@
|
|
||||||
romp-*-*)
|
|
||||||
noconfigdirs="$noconfigdirs bfd binutils ld gas opcodes target-libgloss ${libgcj}"
|
|
||||||
;;
|
|
||||||
- sh-*-* | sh64-*-*)
|
|
||||||
+ sh*-*-* | sh64-*-*)
|
|
||||||
case "${host}" in
|
|
||||||
i[[3456789]]86-*-vsta) ;; # don't add gprof back in
|
|
||||||
i[[3456789]]86-*-go32*) ;; # don't add gprof back in
|
|
||||||
--- binutils-2.16.91.0.7/gas/configure
|
|
||||||
+++ binutils-2.16.91.0.7/gas/configure
|
|
||||||
@@ -3411,7 +3411,7 @@
|
|
||||||
;;
|
|
||||||
|
|
||||||
# This must be Linux ELF.
|
|
||||||
-linux-gnu*)
|
|
||||||
+linux-gnu*|linux-uclibc*)
|
|
||||||
lt_cv_deplibs_check_method=pass_all
|
|
||||||
;;
|
|
||||||
|
|
||||||
--- binutils-2.16.91.0.7/gprof/configure
|
|
||||||
+++ binutils-2.16.91.0.7/gprof/configure
|
|
||||||
@@ -3419,6 +3419,11 @@
|
|
||||||
lt_cv_file_magic_test_file=`echo /lib/libc.so* /lib/libc-*.so`
|
|
||||||
;;
|
|
||||||
|
|
||||||
+linux-uclibc*)
|
|
||||||
+ lt_cv_deplibs_check_method=pass_all
|
|
||||||
+ lt_cv_file_magic_test_file=`echo /lib/libuClibc-*.so`
|
|
||||||
+ ;;
|
|
||||||
+
|
|
||||||
netbsd* | knetbsd*-gnu)
|
|
||||||
if echo __ELF__ | $CC -E - | grep __ELF__ > /dev/null; then
|
|
||||||
lt_cv_deplibs_check_method='match_pattern /lib[^/\.]+\.so\.[0-9]+\.[0-9]+$'
|
|
||||||
--- binutils-2.16.91.0.7/ld/configure
|
|
||||||
+++ binutils-2.16.91.0.7/ld/configure
|
|
||||||
@@ -3413,7 +3413,7 @@
|
|
||||||
;;
|
|
||||||
|
|
||||||
# This must be Linux ELF.
|
|
||||||
-linux-gnu*)
|
|
||||||
+linux-gnu*|linux-uclibc*)
|
|
||||||
lt_cv_deplibs_check_method=pass_all
|
|
||||||
;;
|
|
||||||
|
|
||||||
--- binutils-2.16.91.0.7/libtool.m4
|
|
||||||
+++ binutils-2.16.91.0.7/libtool.m4
|
|
||||||
@@ -739,7 +739,7 @@
|
|
||||||
;;
|
|
||||||
|
|
||||||
# This must be Linux ELF.
|
|
||||||
-linux-gnu*)
|
|
||||||
+linux-gnu*|linux-uclibc*)
|
|
||||||
lt_cv_deplibs_check_method=pass_all
|
|
||||||
;;
|
|
||||||
|
|
||||||
--- binutils-2.16.91.0.7/ltconfig
|
|
||||||
+++ binutils-2.16.91.0.7/ltconfig
|
|
||||||
@@ -602,6 +602,7 @@
|
|
||||||
|
|
||||||
# Transform linux* to *-*-linux-gnu*, to support old configure scripts.
|
|
||||||
case $host_os in
|
|
||||||
+linux-uclibc*) ;;
|
|
||||||
linux-gnu*) ;;
|
|
||||||
linux*) host=`echo $host | sed 's/^\(.*-.*-linux\)\(.*\)$/\1-gnu\2/'`
|
|
||||||
esac
|
|
||||||
@@ -1247,7 +1248,7 @@
|
|
||||||
;;
|
|
||||||
|
|
||||||
# This must be Linux ELF.
|
|
||||||
-linux-gnu*)
|
|
||||||
+linux-gnu*|linux-uclibc*)
|
|
||||||
version_type=linux
|
|
||||||
need_lib_prefix=no
|
|
||||||
need_version=no
|
|
||||||
--- binutils-2.16.91.0.7/opcodes/configure
|
|
||||||
+++ binutils-2.16.91.0.7/opcodes/configure
|
|
||||||
@@ -3579,7 +3579,7 @@
|
|
||||||
;;
|
|
||||||
|
|
||||||
# This must be Linux ELF.
|
|
||||||
-linux-gnu*)
|
|
||||||
+linux-gnu*|linux-uclibc*)
|
|
||||||
lt_cv_deplibs_check_method=pass_all
|
|
||||||
;;
|
|
||||||
|
|
@ -1,24 +0,0 @@
|
|||||||
diff -urN binutils-2.16.91.0.7.orig/configure binutils-2.16.91.0.7/configure
|
|
||||||
--- binutils-2.16.91.0.7.orig/configure 2006-05-31 14:54:24.000000000 +0300
|
|
||||||
+++ binutils-2.16.91.0.7/configure 2006-05-31 14:55:53.000000000 +0300
|
|
||||||
@@ -1299,7 +1299,7 @@
|
|
||||||
arm-*-elf* | strongarm-*-elf* | xscale-*-elf* | arm*-*-eabi* )
|
|
||||||
noconfigdirs="$noconfigdirs target-libffi target-qthreads"
|
|
||||||
;;
|
|
||||||
- arm*-*-linux-gnueabi)
|
|
||||||
+ arm*-*-linux-gnueabi | arm*-*-linux-uclibcgnueabi)
|
|
||||||
noconfigdirs="$noconfigdirs target-libffi target-qthreads"
|
|
||||||
noconfigdirs="$noconfigdirs target-libjava target-libobjc"
|
|
||||||
;;
|
|
||||||
diff -urN binutils-2.16.91.0.7.orig/configure.in binutils-2.16.91.0.7/configure.in
|
|
||||||
--- binutils-2.16.91.0.7.orig/configure.in 2006-05-31 14:54:24.000000000 +0300
|
|
||||||
+++ binutils-2.16.91.0.7/configure.in 2006-05-31 14:55:53.000000000 +0300
|
|
||||||
@@ -497,7 +497,7 @@
|
|
||||||
arm-*-elf* | strongarm-*-elf* | xscale-*-elf* | arm*-*-eabi* )
|
|
||||||
noconfigdirs="$noconfigdirs target-libffi target-qthreads"
|
|
||||||
;;
|
|
||||||
- arm*-*-linux-gnueabi)
|
|
||||||
+ arm*-*-linux-gnueabi | arm*-*-linux-uclibcgnueabi)
|
|
||||||
noconfigdirs="$noconfigdirs target-libffi target-qthreads"
|
|
||||||
noconfigdirs="$noconfigdirs target-libjava target-libobjc"
|
|
||||||
;;
|
|
@ -1,50 +0,0 @@
|
|||||||
#!/bin/sh -e
|
|
||||||
## 001_ld_makefile_patch.dpatch
|
|
||||||
##
|
|
||||||
## All lines beginning with `## DP:' are a description of the patch.
|
|
||||||
## DP: Description: correct where ld scripts are installed
|
|
||||||
## DP: Author: Chris Chimelis <chris@debian.org>
|
|
||||||
## DP: Upstream status: N/A
|
|
||||||
## DP: Date: ??
|
|
||||||
|
|
||||||
if [ $# -ne 1 ]; then
|
|
||||||
echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
[ -f debian/patches/00patch-opts ] && . debian/patches/00patch-opts
|
|
||||||
patch_opts="${patch_opts:--f --no-backup-if-mismatch}"
|
|
||||||
|
|
||||||
case "$1" in
|
|
||||||
-patch) patch $patch_opts -p1 < $0;;
|
|
||||||
-unpatch) patch $patch_opts -p1 -R < $0;;
|
|
||||||
*)
|
|
||||||
echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
|
|
||||||
exit 1;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
exit 0
|
|
||||||
|
|
||||||
@DPATCH@
|
|
||||||
--- binutils-2.16.91.0.1/ld/Makefile.am
|
|
||||||
+++ binutils-2.16.91.0.1/ld/Makefile.am
|
|
||||||
@@ -20,7 +20,7 @@
|
|
||||||
# We put the scripts in the directory $(scriptdir)/ldscripts.
|
|
||||||
# We can't put the scripts in $(datadir) because the SEARCH_DIR
|
|
||||||
# directives need to be different for native and cross linkers.
|
|
||||||
-scriptdir = $(tooldir)/lib
|
|
||||||
+scriptdir = $(libdir)
|
|
||||||
|
|
||||||
EMUL = @EMUL@
|
|
||||||
EMULATION_OFILES = @EMULATION_OFILES@
|
|
||||||
--- binutils-2.16.91.0.1/ld/Makefile.in
|
|
||||||
+++ binutils-2.16.91.0.1/ld/Makefile.in
|
|
||||||
@@ -268,7 +268,7 @@
|
|
||||||
# We put the scripts in the directory $(scriptdir)/ldscripts.
|
|
||||||
# We can't put the scripts in $(datadir) because the SEARCH_DIR
|
|
||||||
# directives need to be different for native and cross linkers.
|
|
||||||
-scriptdir = $(tooldir)/lib
|
|
||||||
+scriptdir = $(libdir)
|
|
||||||
BASEDIR = $(srcdir)/..
|
|
||||||
BFDDIR = $(BASEDIR)/bfd
|
|
||||||
INCDIR = $(BASEDIR)/include
|
|
@ -1,43 +0,0 @@
|
|||||||
#!/bin/sh -e
|
|
||||||
## 006_better_file_error.dpatch by David Kimdon <dwhedon@gordian.com>
|
|
||||||
##
|
|
||||||
## All lines beginning with `## DP:' are a description of the patch.
|
|
||||||
## DP: Specify which filename is causing an error if the filename is a
|
|
||||||
## DP: directory. (#45832)
|
|
||||||
|
|
||||||
if [ $# -ne 1 ]; then
|
|
||||||
echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
[ -f debian/patches/00patch-opts ] && . debian/patches/00patch-opts
|
|
||||||
patch_opts="${patch_opts:--f --no-backup-if-mismatch}"
|
|
||||||
|
|
||||||
case "$1" in
|
|
||||||
-patch) patch $patch_opts -p1 < $0;;
|
|
||||||
-unpatch) patch $patch_opts -p1 -R < $0;;
|
|
||||||
*)
|
|
||||||
echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
|
|
||||||
exit 1;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
exit 0
|
|
||||||
|
|
||||||
@DPATCH@
|
|
||||||
diff -urNad /home/james/debian/packages/binutils/binutils-2.14.90.0.6/bfd/opncls.c binutils-2.14.90.0.6/bfd/opncls.c
|
|
||||||
--- /home/james/debian/packages/binutils/binutils-2.14.90.0.6/bfd/opncls.c 2003-07-23 16:08:09.000000000 +0100
|
|
||||||
+++ binutils-2.14.90.0.6/bfd/opncls.c 2003-09-10 22:35:00.000000000 +0100
|
|
||||||
@@ -150,6 +150,13 @@
|
|
||||||
{
|
|
||||||
bfd *nbfd;
|
|
||||||
const bfd_target *target_vec;
|
|
||||||
+ struct stat s;
|
|
||||||
+
|
|
||||||
+ if (stat (filename, &s) == 0)
|
|
||||||
+ if (S_ISDIR(s.st_mode)) {
|
|
||||||
+ bfd_set_error (bfd_error_file_not_recognized);
|
|
||||||
+ return NULL;
|
|
||||||
+ }
|
|
||||||
|
|
||||||
nbfd = _bfd_new_bfd ();
|
|
||||||
if (nbfd == NULL)
|
|
@ -1,47 +0,0 @@
|
|||||||
#!/bin/sh -e
|
|
||||||
## 012_check_ldrunpath_length.dpatch by Chris Chimelis <chris@debian.org>
|
|
||||||
##
|
|
||||||
## All lines beginning with `## DP:' are a description of the patch.
|
|
||||||
## DP: Only generate an RPATH entry if LD_RUN_PATH is not empty, for
|
|
||||||
## DP: cases where -rpath isn't specified. (#151024)
|
|
||||||
|
|
||||||
if [ $# -ne 1 ]; then
|
|
||||||
echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
[ -f debian/patches/00patch-opts ] && . debian/patches/00patch-opts
|
|
||||||
patch_opts="${patch_opts:--f --no-backup-if-mismatch}"
|
|
||||||
|
|
||||||
case "$1" in
|
|
||||||
-patch) patch $patch_opts -p1 < $0;;
|
|
||||||
-unpatch) patch $patch_opts -p1 -R < $0;;
|
|
||||||
*)
|
|
||||||
echo >&2 "`basename $0`: script expects -patch|-unpatch as argument"
|
|
||||||
exit 1;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
exit 0
|
|
||||||
|
|
||||||
@DPATCH@
|
|
||||||
diff -urNad /home/james/debian/packages/binutils/new/binutils-2.15/ld/emultempl/elf32.em binutils-2.15/ld/emultempl/elf32.em
|
|
||||||
--- /home/james/debian/packages/binutils/new/binutils-2.15/ld/emultempl/elf32.em 2004-05-21 23:12:58.000000000 +0100
|
|
||||||
+++ binutils-2.15/ld/emultempl/elf32.em 2004-05-21 23:12:59.000000000 +0100
|
|
||||||
@@ -692,6 +692,8 @@
|
|
||||||
&& command_line.rpath == NULL)
|
|
||||||
{
|
|
||||||
lib_path = (const char *) getenv ("LD_RUN_PATH");
|
|
||||||
+ if ((lib_path) && (strlen (lib_path) == 0))
|
|
||||||
+ lib_path = NULL;
|
|
||||||
if (gld${EMULATION_NAME}_search_needed (lib_path, &n,
|
|
||||||
force))
|
|
||||||
break;
|
|
||||||
@@ -871,6 +873,8 @@
|
|
||||||
rpath = command_line.rpath;
|
|
||||||
if (rpath == NULL)
|
|
||||||
rpath = (const char *) getenv ("LD_RUN_PATH");
|
|
||||||
+ if ((rpath) && (strlen (rpath) == 0))
|
|
||||||
+ rpath = NULL;
|
|
||||||
if (! (bfd_elf_size_dynamic_sections
|
|
||||||
(output_bfd, command_line.soname, rpath,
|
|
||||||
command_line.filter_shlib,
|
|
@ -1,26 +0,0 @@
|
|||||||
--- binutils/bfd/elf32-mips.c~
|
|
||||||
+++ binutils/bfd/elf32-mips.c
|
|
||||||
@@ -1613,7 +1613,9 @@
|
|
||||||
|
|
||||||
/* The SVR4 MIPS ABI says that this should be 0x10000, and Linux uses
|
|
||||||
page sizes of up to that limit, so we need to respect it. */
|
|
||||||
-#define ELF_MAXPAGESIZE 0x10000
|
|
||||||
+/*#define ELF_MAXPAGESIZE 0x10000*/
|
|
||||||
+/* Use 4K to shrink the elf header. NOT for general use! */
|
|
||||||
+#define ELF_MAXPAGESIZE 0x1000
|
|
||||||
#define elf32_bed elf32_tradbed
|
|
||||||
|
|
||||||
/* Include the target file again for this target. */
|
|
||||||
--- binutils/bfd/elfn32-mips.c~
|
|
||||||
+++ binutils/bfd/elfn32-mips.c
|
|
||||||
@@ -2399,7 +2399,9 @@
|
|
||||||
|
|
||||||
/* The SVR4 MIPS ABI says that this should be 0x10000, and Linux uses
|
|
||||||
page sizes of up to that limit, so we need to respect it. */
|
|
||||||
-#define ELF_MAXPAGESIZE 0x10000
|
|
||||||
+/*#define ELF_MAXPAGESIZE 0x10000*/
|
|
||||||
+/* Use 4K to shrink the elf header. NOT for general use! */
|
|
||||||
+#define ELF_MAXPAGESIZE 0x1000
|
|
||||||
#define elf32_bed elf32_tradbed
|
|
||||||
|
|
||||||
/* Include the target file again for this target. */
|
|
@ -1,17 +0,0 @@
|
|||||||
---
|
|
||||||
configure | 2 +-
|
|
||||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
|
||||||
|
|
||||||
Index: binutils-2.17/configure
|
|
||||||
===================================================================
|
|
||||||
--- binutils-2.17.orig/configure
|
|
||||||
+++ binutils-2.17/configure
|
|
||||||
@@ -3637,7 +3637,7 @@
|
|
||||||
# For an installed makeinfo, we require it to be from texinfo 4.4 or
|
|
||||||
# higher, else we use the "missing" dummy.
|
|
||||||
if ${MAKEINFO} --version \
|
|
||||||
- | egrep 'texinfo[^0-9]*([1-3][0-9]|4\.[4-9]|[5-9])' >/dev/null 2>&1; then
|
|
||||||
+ | egrep 'texinfo[^0-9]*([1-3][0-9]|4\.[4-9]|4\.[1-9][0-9]|[5-9])' >/dev/null 2>&1; then
|
|
||||||
:
|
|
||||||
else
|
|
||||||
MAKEINFO="$MISSING makeinfo"
|
|
@ -1,179 +0,0 @@
|
|||||||
#############################################################
|
|
||||||
#
|
|
||||||
# build binutils for use on the host system
|
|
||||||
#
|
|
||||||
#############################################################
|
|
||||||
BINUTILS_VERSION:=$(call qstrip,$(BR2_BINUTILS_VERSION))
|
|
||||||
|
|
||||||
EXTRA_BINUTILS_CONFIG_OPTIONS=$(call qstrip,$(BR2_EXTRA_BINUTILS_CONFIG_OPTIONS))
|
|
||||||
ifeq ($(findstring avr32,$(BINUTILS_VERSION)),avr32)
|
|
||||||
BINUTILS_SITE:=ftp://www.at91.com/pub/buildroot/
|
|
||||||
else
|
|
||||||
BINUTILS_SITE:=$(BR2_GNU_MIRROR)/binutils/
|
|
||||||
endif
|
|
||||||
|
|
||||||
# We do not rely on the host's gmp/mpfr but use a known working one
|
|
||||||
BINUTILS_HOST_PREREQ:=
|
|
||||||
BINUTILS_TARGET_PREREQ:=
|
|
||||||
|
|
||||||
BINUTILS_HOST_PREREQ:=host-gmp host-mpfr
|
|
||||||
HOST_SOURCE += host-gmp-source host-mpfr-source
|
|
||||||
|
|
||||||
BINUTILS_TARGET_PREREQ:=gmp mpfr
|
|
||||||
|
|
||||||
EXTRA_BINUTILS_CONFIG_OPTIONS+=--with-gmp=$(HOST_DIR)/usr
|
|
||||||
EXTRA_BINUTILS_CONFIG_OPTIONS+=--with-mpfr=$(HOST_DIR)/usr
|
|
||||||
|
|
||||||
BINUTILS_TARGET_CONFIG_OPTIONS=--with-gmp=$(STAGING_DIR)/usr
|
|
||||||
BINUTILS_TARGET_CONFIG_OPTIONS+=--with-mpfr=$(STAGING_DIR)/usr
|
|
||||||
|
|
||||||
ifeq ($(BR2_PACKAGE_LIBMPC),y)
|
|
||||||
BINUTILS_ADD_MPC = y
|
|
||||||
endif
|
|
||||||
|
|
||||||
ifeq ($(findstring x4.5.,x$(GCC_VERSION)),x4.5.)
|
|
||||||
BINUTILS_ADD_MPC = y
|
|
||||||
endif
|
|
||||||
|
|
||||||
ifeq ($(BINUTILS_ADD_MPC),y)
|
|
||||||
BINUTILS_HOST_PREREQ += host-mpc
|
|
||||||
HOST_SOURCE += host-mpc-source
|
|
||||||
BINUTILS_TARGET_PREREQ += mpc
|
|
||||||
EXTRA_BINUTILS_CONFIG_OPTIONS += --with-mpc=$(HOST_DIR)/usr
|
|
||||||
BINUTILS_TARGET_CONFIG_OPTIONS += --with-mpc=$(STAGING_DIR)/usr
|
|
||||||
endif
|
|
||||||
|
|
||||||
BINUTILS_PATCH_DIR:=toolchain/binutils/$(BINUTILS_VERSION)
|
|
||||||
|
|
||||||
ifneq ($(filter xtensa%,$(ARCH)),)
|
|
||||||
include target/xtensa/patch.in
|
|
||||||
BINUTILS_PATCH_EXTRA:=$(call XTENSA_PATCH,binutils,$(BINUTILS_PATCH_DIR),. ..)
|
|
||||||
endif
|
|
||||||
|
|
||||||
BINUTILS_SOURCE:=binutils-$(BINUTILS_VERSION).tar.bz2
|
|
||||||
BINUTILS_DIR:=$(TOOLCHAIN_DIR)/binutils-$(BINUTILS_VERSION)
|
|
||||||
BINUTILS_CAT:=$(BZCAT)
|
|
||||||
|
|
||||||
BINUTILS_DIR1:=$(TOOLCHAIN_DIR)/binutils-$(BINUTILS_VERSION)-build
|
|
||||||
|
|
||||||
$(DL_DIR)/$(BINUTILS_SOURCE):
|
|
||||||
mkdir -p $(DL_DIR)
|
|
||||||
$(call DOWNLOAD,$(BINUTILS_SITE),$(BINUTILS_SOURCE))
|
|
||||||
|
|
||||||
binutils-unpacked: $(BINUTILS_DIR)/.patched
|
|
||||||
$(BINUTILS_DIR)/.unpacked: $(DL_DIR)/$(BINUTILS_SOURCE)
|
|
||||||
mkdir -p $(TOOLCHAIN_DIR)
|
|
||||||
rm -rf $(BINUTILS_DIR)
|
|
||||||
$(BINUTILS_CAT) $(DL_DIR)/$(BINUTILS_SOURCE) | tar -C $(TOOLCHAIN_DIR) $(TAR_OPTIONS) -
|
|
||||||
$(CONFIG_UPDATE) $(@D)
|
|
||||||
touch $@
|
|
||||||
|
|
||||||
binutils-patched: $(BINUTILS_DIR)/.patched
|
|
||||||
$(BINUTILS_DIR)/.patched: $(BINUTILS_DIR)/.unpacked
|
|
||||||
# Apply appropriate binutils patches.
|
|
||||||
ifneq ($(wildcard $(BINUTILS_PATCH_DIR)),)
|
|
||||||
toolchain/patch-kernel.sh $(BINUTILS_DIR) $(BINUTILS_PATCH_DIR) \*.patch $(BINUTILS_PATCH_EXTRA)
|
|
||||||
endif
|
|
||||||
touch $@
|
|
||||||
|
|
||||||
$(BINUTILS_DIR1)/.configured: $(BINUTILS_DIR)/.patched
|
|
||||||
mkdir -p $(BINUTILS_DIR1)
|
|
||||||
(cd $(BINUTILS_DIR1); rm -rf config.cache; \
|
|
||||||
$(HOST_CONFIGURE_OPTS) \
|
|
||||||
$(BINUTILS_DIR)/configure $(QUIET) \
|
|
||||||
--prefix=$(STAGING_DIR)/usr \
|
|
||||||
--build=$(GNU_HOST_NAME) \
|
|
||||||
--host=$(GNU_HOST_NAME) \
|
|
||||||
--target=$(REAL_GNU_TARGET_NAME) \
|
|
||||||
$(BR2_CONFIGURE_DEVEL_SYSROOT) \
|
|
||||||
$(BR2_CONFIGURE_STAGING_SYSROOT) \
|
|
||||||
$(DISABLE_NLS) \
|
|
||||||
--disable-multilib \
|
|
||||||
--disable-werror \
|
|
||||||
$(SOFT_FLOAT_CONFIG_OPTION) \
|
|
||||||
$(EXTRA_BINUTILS_CONFIG_OPTIONS) \
|
|
||||||
$(QUIET) \
|
|
||||||
)
|
|
||||||
touch $@
|
|
||||||
|
|
||||||
$(BINUTILS_DIR1)/binutils/objdump: $(BINUTILS_DIR1)/.configured
|
|
||||||
$(MAKE) -C $(BINUTILS_DIR1) all
|
|
||||||
|
|
||||||
# Make install will put gettext data in staging_dir/share/locale.
|
|
||||||
# Unfortunatey, it isn't configureable.
|
|
||||||
$(STAGING_DIR)/usr/bin/$(REAL_GNU_TARGET_NAME)-ld: $(BINUTILS_DIR1)/binutils/objdump
|
|
||||||
$(MAKE) -C $(BINUTILS_DIR1) install
|
|
||||||
# tooldir=/usr build_tooldir=/usr install
|
|
||||||
#rm -f $(STAGING_DIR)/usr/bin/{ar,as,ld,nm,objdump,ranlib,strip}
|
|
||||||
|
|
||||||
binutils: $(BINUTILS_HOST_PREREQ) $(STAGING_DIR)/usr/bin/$(REAL_GNU_TARGET_NAME)-ld
|
|
||||||
|
|
||||||
binutils-source: $(DL_DIR)/$(BINUTILS_SOURCE)
|
|
||||||
|
|
||||||
binutils-clean:
|
|
||||||
-$(MAKE) -C $(BINUTILS_DIR1) DESTDIR=$(STAGING_DIR) \
|
|
||||||
tooldir=/usr build_tooldir=/usr uninstall
|
|
||||||
-$(MAKE) -C $(BINUTILS_DIR1) clean
|
|
||||||
rm -rf $(wildcard $(patsubst %,$(STAGING_DIR)/usr/bin/*%,ar as ld nm objdump ranlib strip c++filt)) \
|
|
||||||
$(wildcard $(patsubst %,$(STAGING_DIR)/usr/lib/%*,libiberty ldscripts))
|
|
||||||
|
|
||||||
binutils-dirclean:
|
|
||||||
rm -rf $(BINUTILS_DIR1)
|
|
||||||
|
|
||||||
binutils-src-dirclean:
|
|
||||||
rm -rf $(BINUTILS_DIR)
|
|
||||||
|
|
||||||
#############################################################
|
|
||||||
#
|
|
||||||
# build binutils for use on the target system
|
|
||||||
#
|
|
||||||
#############################################################
|
|
||||||
BINUTILS_DIR2:=$(BUILD_DIR)/binutils-$(BINUTILS_VERSION)-target
|
|
||||||
$(BINUTILS_DIR2)/.configured: $(BINUTILS_DIR)/.patched
|
|
||||||
mkdir -p $(BINUTILS_DIR2)
|
|
||||||
(cd $(BINUTILS_DIR2); rm -rf config.cache; \
|
|
||||||
$(TARGET_CONFIGURE_OPTS) \
|
|
||||||
$(BINUTILS_DIR)/configure $(QUIET) \
|
|
||||||
--prefix=/usr \
|
|
||||||
--exec-prefix=/usr \
|
|
||||||
--build=$(GNU_HOST_NAME) \
|
|
||||||
--host=$(REAL_GNU_TARGET_NAME) \
|
|
||||||
--target=$(REAL_GNU_TARGET_NAME) \
|
|
||||||
--mandir=/usr/share/man \
|
|
||||||
--infodir=/usr/share/info \
|
|
||||||
$(DISABLE_NLS) \
|
|
||||||
$(BINUTILS_TARGET_CONFIG_OPTIONS) \
|
|
||||||
--disable-multilib \
|
|
||||||
--disable-werror \
|
|
||||||
$(SOFT_FLOAT_CONFIG_OPTION) \
|
|
||||||
)
|
|
||||||
touch $@
|
|
||||||
|
|
||||||
$(BINUTILS_DIR2)/binutils/objdump: $(BINUTILS_DIR2)/.configured
|
|
||||||
PATH=$(TARGET_PATH) $(MAKE) -C $(BINUTILS_DIR2) all
|
|
||||||
|
|
||||||
$(TARGET_DIR)/usr/bin/ld: $(BINUTILS_DIR2)/binutils/objdump
|
|
||||||
PATH=$(TARGET_PATH) \
|
|
||||||
$(MAKE) DESTDIR=$(TARGET_DIR) \
|
|
||||||
tooldir=/usr build_tooldir=/usr \
|
|
||||||
-C $(BINUTILS_DIR2) install
|
|
||||||
rm -rf $(TARGET_DIR)/share/locale
|
|
||||||
-$(STRIPCMD) $(TARGET_DIR)/usr/$(REAL_GNU_TARGET_NAME)/bin/* > /dev/null 2>&1
|
|
||||||
-$(STRIPCMD) $(TARGET_DIR)/usr/bin/* > /dev/null 2>&1
|
|
||||||
|
|
||||||
# If both binutils-target and busybox are selected, make certain binutils
|
|
||||||
# gets to run after busybox, so it can overwrite the busybox symlink for
|
|
||||||
# ar if enabled
|
|
||||||
ifeq ($(BR2_PACKAGE_BUSYBOX),y)
|
|
||||||
BINUTILS_TARGET_PREREQ += busybox
|
|
||||||
endif
|
|
||||||
|
|
||||||
binutils_target: $(BINUTILS_TARGET_PREREQ) $(TARGET_DIR)/usr/bin/ld
|
|
||||||
|
|
||||||
binutils_target-clean:
|
|
||||||
-$(MAKE) -C $(BINUTILS_DIR2) clean
|
|
||||||
rm -f $(TARGET_DIR)/bin/$(REAL_GNU_TARGET_NAME)* \
|
|
||||||
$(addprefix $(TARGET_DIR)/usr/bin/, addr2line ar as gprof ld nm objcopy objdump ranlib readelf size strings strip c++filt)
|
|
||||||
|
|
||||||
binutils_target-dirclean:
|
|
||||||
rm -rf $(BINUTILS_DIR2)
|
|
@ -1,6 +1,10 @@
|
|||||||
config BR2_PACKAGE_GCC_TARGET
|
config BR2_PACKAGE_GCC_TARGET
|
||||||
bool "native toolchain in the target filesystem"
|
bool "native toolchain in the target filesystem"
|
||||||
depends on BR2_HAVE_DEVFILES
|
depends on BR2_HAVE_DEVFILES
|
||||||
|
select BR2_PACKAGE_BINUTILS_TARGET
|
||||||
|
select BR2_PACKAGE_MPC if BR2_GCC_VERSION_4_5_X
|
||||||
|
select BR2_PACKAGE_MPFR
|
||||||
|
select BR2_PACKAGE_GMP
|
||||||
help
|
help
|
||||||
If you want the target system to be able to run
|
If you want the target system to be able to run
|
||||||
binutils/gcc and compile native code, say Y here.
|
binutils/gcc and compile native code, say Y here.
|
||||||
|
@ -53,9 +53,6 @@ else
|
|||||||
GCC_OPTSPACE=--enable-target-optspace
|
GCC_OPTSPACE=--enable-target-optspace
|
||||||
endif
|
endif
|
||||||
|
|
||||||
GCC_TARGET_PREREQ=
|
|
||||||
GCC_STAGING_PREREQ=
|
|
||||||
|
|
||||||
#############################################################
|
#############################################################
|
||||||
#
|
#
|
||||||
# Setup some initial stuff
|
# Setup some initial stuff
|
||||||
@ -106,25 +103,28 @@ ifeq ($(BR2_INSTALL_OBJC),y)
|
|||||||
GCC_TARGET_LANGUAGES:=$(GCC_TARGET_LANGUAGES),objc
|
GCC_TARGET_LANGUAGES:=$(GCC_TARGET_LANGUAGES),objc
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
ifeq ($(BR2_INSTALL_FORTRAN),y)
|
||||||
|
GCC_TARGET_LANGUAGES:=$(GCC_TARGET_LANGUAGES),fortran
|
||||||
|
endif
|
||||||
|
|
||||||
GCC_WITH_HOST_GMP = --with-gmp=$(HOST_DIR)/usr
|
GCC_WITH_HOST_GMP = --with-gmp=$(HOST_DIR)/usr
|
||||||
GCC_WITH_HOST_MPFR = --with-mpfr=$(HOST_DIR)/usr
|
GCC_WITH_HOST_MPFR = --with-mpfr=$(HOST_DIR)/usr
|
||||||
HOST_SOURCE += host-gmp-source host-mpfr-source
|
HOST_SOURCE += host-gmp-source host-mpfr-source
|
||||||
|
GCC_HOST_PREREQ = host-gmp host-mpfr
|
||||||
|
|
||||||
ifeq ($(findstring x4.5.,x$(GCC_VERSION)),x4.5.)
|
ifeq ($(findstring x4.5.,x$(GCC_VERSION)),x4.5.)
|
||||||
GCC_WITH_HOST_MPC = --with-mpc=$(HOST_DIR)/usr
|
GCC_WITH_HOST_MPC = --with-mpc=$(HOST_DIR)/usr
|
||||||
HOST_SOURCE += host-mpc-source
|
HOST_SOURCE += host-mpc-source
|
||||||
|
GCC_HOST_PREREQ += host-mpc
|
||||||
endif
|
endif
|
||||||
|
|
||||||
ifeq ($(BR2_INSTALL_FORTRAN),y)
|
GCC_TARGET_PREREQ += mpfr gmp
|
||||||
GCC_TARGET_LANGUAGES:=$(GCC_TARGET_LANGUAGES),fortran
|
|
||||||
#GCC_TARGET_PREREQ+=$(TARGET_DIR)/usr/lib/libmpfr.so $(TARGET_DIR)/usr/lib/libgmp.so
|
|
||||||
#GCC_STAGING_PREREQ+=$(TOOLCHAIN_DIR)/mpfr/lib/libmpfr.so
|
|
||||||
GCC_WITH_TARGET_GMP = --with-gmp=$(STAGING_DIR)/usr
|
GCC_WITH_TARGET_GMP = --with-gmp=$(STAGING_DIR)/usr
|
||||||
GCC_WITH_TARGET_MPFR = --with-mpfr=$(STAGING_DIR)/usr
|
GCC_WITH_TARGET_MPFR = --with-mpfr=$(STAGING_DIR)/usr
|
||||||
ifeq ($(findstring x4.5.,x$(GCC_VERSION)),x4.5.)
|
ifeq ($(findstring x4.5.,x$(GCC_VERSION)),x4.5.)
|
||||||
|
GCC_TARGET_PREREQ += mpc
|
||||||
GCC_WITH_TARGET_MPC = --with-mpc=$(STAGING_DIR)/usr
|
GCC_WITH_TARGET_MPC = --with-mpc=$(STAGING_DIR)/usr
|
||||||
endif
|
endif
|
||||||
endif
|
|
||||||
|
|
||||||
ifeq ($(BR2_GCC_SHARED_LIBGCC),y)
|
ifeq ($(BR2_GCC_SHARED_LIBGCC),y)
|
||||||
GCC_SHARED_LIBGCC:=--enable-shared
|
GCC_SHARED_LIBGCC:=--enable-shared
|
||||||
@ -203,17 +203,12 @@ endif
|
|||||||
#############################################################
|
#############################################################
|
||||||
GCC_BUILD_DIR1:=$(TOOLCHAIN_DIR)/gcc-$(GCC_VERSION)-initial
|
GCC_BUILD_DIR1:=$(TOOLCHAIN_DIR)/gcc-$(GCC_VERSION)-initial
|
||||||
|
|
||||||
|
|
||||||
# The --without-headers option stopped working with gcc 3.0 and has never been
|
|
||||||
# fixed, so we need to actually have working C library header files prior to
|
|
||||||
# the step or libgcc will not build...
|
|
||||||
|
|
||||||
$(GCC_BUILD_DIR1)/.configured: $(GCC_DIR)/.patched
|
$(GCC_BUILD_DIR1)/.configured: $(GCC_DIR)/.patched
|
||||||
mkdir -p $(GCC_BUILD_DIR1)
|
mkdir -p $(GCC_BUILD_DIR1)
|
||||||
(cd $(GCC_BUILD_DIR1); rm -rf config.cache; \
|
(cd $(GCC_BUILD_DIR1); rm -rf config.cache; \
|
||||||
$(HOST_CONFIGURE_OPTS) \
|
$(HOST_CONFIGURE_OPTS) \
|
||||||
$(GCC_DIR)/configure $(QUIET) \
|
$(GCC_DIR)/configure $(QUIET) \
|
||||||
--prefix=$(STAGING_DIR)/usr \
|
--prefix=$(HOST_DIR)/usr \
|
||||||
--build=$(GNU_HOST_NAME) \
|
--build=$(GNU_HOST_NAME) \
|
||||||
--host=$(GNU_HOST_NAME) \
|
--host=$(GNU_HOST_NAME) \
|
||||||
--target=$(REAL_GNU_TARGET_NAME) \
|
--target=$(REAL_GNU_TARGET_NAME) \
|
||||||
@ -243,7 +238,6 @@ $(GCC_BUILD_DIR1)/.configured: $(GCC_DIR)/.patched
|
|||||||
touch $@
|
touch $@
|
||||||
|
|
||||||
$(GCC_BUILD_DIR1)/.compiled: $(GCC_BUILD_DIR1)/.configured
|
$(GCC_BUILD_DIR1)/.compiled: $(GCC_BUILD_DIR1)/.configured
|
||||||
# gcc >= 4.3.0 have to also build all-target-libgcc
|
|
||||||
ifeq ($(BR2_GCC_SUPPORTS_FINEGRAINEDMTUNE),y)
|
ifeq ($(BR2_GCC_SUPPORTS_FINEGRAINEDMTUNE),y)
|
||||||
$(GCC_CONF_ENV) $(MAKE) -C $(GCC_BUILD_DIR1) all-gcc
|
$(GCC_CONF_ENV) $(MAKE) -C $(GCC_BUILD_DIR1) all-gcc
|
||||||
else
|
else
|
||||||
@ -252,16 +246,11 @@ endif
|
|||||||
touch $@
|
touch $@
|
||||||
|
|
||||||
gcc_initial=$(GCC_BUILD_DIR1)/.installed
|
gcc_initial=$(GCC_BUILD_DIR1)/.installed
|
||||||
$(gcc_initial) $(STAGING_DIR)/usr/bin/$(REAL_GNU_TARGET_NAME)-gcc: $(GCC_BUILD_DIR1)/.compiled
|
$(gcc_initial) $(HOST_DIR)/usr/bin/$(REAL_GNU_TARGET_NAME)-gcc: $(GCC_BUILD_DIR1)/.compiled
|
||||||
# gcc >= 4.3.0 have to also install install-target-libgcc
|
|
||||||
ifeq ($(BR2_GCC_SUPPORTS_FINEGRAINEDMTUNE),y)
|
|
||||||
PATH=$(TARGET_PATH) $(MAKE) -C $(GCC_BUILD_DIR1) install-gcc
|
PATH=$(TARGET_PATH) $(MAKE) -C $(GCC_BUILD_DIR1) install-gcc
|
||||||
else
|
|
||||||
PATH=$(TARGET_PATH) $(MAKE) -C $(GCC_BUILD_DIR1) install-gcc
|
|
||||||
endif
|
|
||||||
touch $(gcc_initial)
|
touch $(gcc_initial)
|
||||||
|
|
||||||
gcc_initial: binutils $(STAGING_DIR)/usr/bin/$(REAL_GNU_TARGET_NAME)-gcc
|
gcc_initial: $(GCC_HOST_PREREQ) host-binutils $(HOST_DIR)/usr/bin/$(REAL_GNU_TARGET_NAME)-gcc
|
||||||
|
|
||||||
gcc_initial-clean:
|
gcc_initial-clean:
|
||||||
rm -rf $(GCC_BUILD_DIR1)
|
rm -rf $(GCC_BUILD_DIR1)
|
||||||
@ -276,22 +265,16 @@ gcc_initial-dirclean:
|
|||||||
#############################################################
|
#############################################################
|
||||||
GCC_BUILD_DIR2:=$(TOOLCHAIN_DIR)/gcc-$(GCC_VERSION)-intermediate
|
GCC_BUILD_DIR2:=$(TOOLCHAIN_DIR)/gcc-$(GCC_VERSION)-intermediate
|
||||||
|
|
||||||
|
|
||||||
# The --without-headers option stopped working with gcc 3.0 and has never been
|
# The --without-headers option stopped working with gcc 3.0 and has never been
|
||||||
# fixed, so we need to actually have working C library header files prior to
|
# fixed, so we need to actually have working C library header files prior to
|
||||||
# the step or libgcc will not build...
|
# the step or libgcc will not build...
|
||||||
|
|
||||||
$(GCC_BUILD_DIR2)/.configured: $(GCC_DIR)/.patched
|
$(GCC_BUILD_DIR2)/.configured: $(GCC_DIR)/.patched
|
||||||
mkdir -p $(GCC_BUILD_DIR2)
|
mkdir -p $(GCC_BUILD_DIR2)
|
||||||
-rmdir $(STAGING_DIR)/usr/$(REAL_GNU_TARGET_NAME)/lib
|
|
||||||
mkdir -p $(STAGING_DIR)/lib
|
|
||||||
ln -snf ../../lib $(STAGING_DIR)/usr/$(REAL_GNU_TARGET_NAME)/lib
|
|
||||||
$(if $(BR2_ARCH_IS_64),mkdir -p $(STAGING_DIR)/lib64)
|
|
||||||
$(if $(BR2_ARCH_IS_64),ln -snf ../../lib64 $(STAGING_DIR)/usr/$(REAL_GNU_TARGET_NAME)/lib64)
|
|
||||||
(cd $(GCC_BUILD_DIR2); rm -rf config.cache; \
|
(cd $(GCC_BUILD_DIR2); rm -rf config.cache; \
|
||||||
$(HOST_CONFIGURE_OPTS) \
|
$(HOST_CONFIGURE_OPTS) \
|
||||||
$(GCC_DIR)/configure $(QUIET) \
|
$(GCC_DIR)/configure $(QUIET) \
|
||||||
--prefix=$(STAGING_DIR)/usr \
|
--prefix=$(HOST_DIR)/usr \
|
||||||
--build=$(GNU_HOST_NAME) \
|
--build=$(GNU_HOST_NAME) \
|
||||||
--host=$(GNU_HOST_NAME) \
|
--host=$(GNU_HOST_NAME) \
|
||||||
--target=$(REAL_GNU_TARGET_NAME) \
|
--target=$(REAL_GNU_TARGET_NAME) \
|
||||||
@ -338,7 +321,7 @@ else
|
|||||||
endif
|
endif
|
||||||
touch $(gcc_intermediate)
|
touch $(gcc_intermediate)
|
||||||
|
|
||||||
gcc_intermediate: uclibc-configured $(STAGING_DIR)/usr/bin/$(REAL_GNU_TARGET_NAME)-gcc
|
gcc_intermediate: uclibc-configured $(HOST_DIR)/usr/bin/$(REAL_GNU_TARGET_NAME)-gcc
|
||||||
|
|
||||||
gcc_intermediate-clean:
|
gcc_intermediate-clean:
|
||||||
rm -rf $(GCC_BUILD_DIR2)
|
rm -rf $(GCC_BUILD_DIR2)
|
||||||
@ -363,11 +346,11 @@ GCC_BUILD_DIR3:=$(TOOLCHAIN_DIR)/gcc-$(GCC_VERSION)-final
|
|||||||
$(GCC_BUILD_DIR3)/.configured: $(GCC_SRC_DIR)/.patched $(GCC_STAGING_PREREQ)
|
$(GCC_BUILD_DIR3)/.configured: $(GCC_SRC_DIR)/.patched $(GCC_STAGING_PREREQ)
|
||||||
mkdir -p $(GCC_BUILD_DIR3)
|
mkdir -p $(GCC_BUILD_DIR3)
|
||||||
# Important! Required for limits.h to be fixed.
|
# Important! Required for limits.h to be fixed.
|
||||||
ln -snf ../include/ $(STAGING_DIR)/usr/$(REAL_GNU_TARGET_NAME)/sys-include
|
ln -snf ../include/ $(HOST_DIR)/usr/$(REAL_GNU_TARGET_NAME)/sys-include
|
||||||
(cd $(GCC_BUILD_DIR3); rm -rf config.cache; \
|
(cd $(GCC_BUILD_DIR3); rm -rf config.cache; \
|
||||||
$(HOST_CONFIGURE_OPTS) \
|
$(HOST_CONFIGURE_OPTS) \
|
||||||
$(GCC_SRC_DIR)/configure $(QUIET) \
|
$(GCC_SRC_DIR)/configure $(QUIET) \
|
||||||
--prefix=$(STAGING_DIR)/usr \
|
--prefix=$(HOST_DIR)/usr \
|
||||||
--build=$(GNU_HOST_NAME) \
|
--build=$(GNU_HOST_NAME) \
|
||||||
--host=$(GNU_HOST_NAME) \
|
--host=$(GNU_HOST_NAME) \
|
||||||
--target=$(REAL_GNU_TARGET_NAME) \
|
--target=$(REAL_GNU_TARGET_NAME) \
|
||||||
@ -412,19 +395,19 @@ $(GCC_BUILD_DIR3)/.installed: $(GCC_BUILD_DIR3)/.compiled
|
|||||||
fi
|
fi
|
||||||
# Strip the host binaries
|
# Strip the host binaries
|
||||||
ifeq ($(GCC_STRIP_HOST_BINARIES),true)
|
ifeq ($(GCC_STRIP_HOST_BINARIES),true)
|
||||||
strip --strip-all -R .note -R .comment $(filter-out %-gccbug %-embedspu,$(wildcard $(STAGING_DIR)/usr/bin/$(REAL_GNU_TARGET_NAME)-*))
|
strip --strip-all -R .note -R .comment $(filter-out %-gccbug %-embedspu,$(wildcard $(HOST_DIR)/usr/bin/$(REAL_GNU_TARGET_NAME)-*))
|
||||||
endif
|
endif
|
||||||
# Make sure we have 'cc'.
|
# Make sure we have 'cc'.
|
||||||
if [ ! -e $(STAGING_DIR)/usr/bin/$(REAL_GNU_TARGET_NAME)-cc ]; then \
|
if [ ! -e $(HOST_DIR)/usr/bin/$(REAL_GNU_TARGET_NAME)-cc ]; then \
|
||||||
ln -snf $(REAL_GNU_TARGET_NAME)-gcc \
|
ln -snf $(REAL_GNU_TARGET_NAME)-gcc \
|
||||||
$(STAGING_DIR)/usr/bin/$(REAL_GNU_TARGET_NAME)-cc; \
|
$(HOST_DIR)/usr/bin/$(REAL_GNU_TARGET_NAME)-cc; \
|
||||||
fi
|
fi
|
||||||
if [ ! -e $(STAGING_DIR)/usr/$(REAL_GNU_TARGET_NAME)/bin/cc ]; then \
|
if [ ! -e $(HOST_DIR)/usr/$(REAL_GNU_TARGET_NAME)/bin/cc ]; then \
|
||||||
ln -snf gcc $(STAGING_DIR)/usr/$(REAL_GNU_TARGET_NAME)/bin/cc; \
|
ln -snf gcc $(HOST_DIR)/usr/$(REAL_GNU_TARGET_NAME)/bin/cc; \
|
||||||
fi
|
fi
|
||||||
# Set up the symlinks to enable lying about target name.
|
# Set up the symlinks to enable lying about target name.
|
||||||
set -e; \
|
set -e; \
|
||||||
(cd $(STAGING_DIR)/usr; \
|
(cd $(HOST_DIR)/usr; \
|
||||||
ln -snf $(REAL_GNU_TARGET_NAME) $(GNU_TARGET_NAME); \
|
ln -snf $(REAL_GNU_TARGET_NAME) $(GNU_TARGET_NAME); \
|
||||||
cd bin; \
|
cd bin; \
|
||||||
for app in $(REAL_GNU_TARGET_NAME)-*; do \
|
for app in $(REAL_GNU_TARGET_NAME)-*; do \
|
||||||
@ -438,31 +421,31 @@ endif
|
|||||||
|
|
||||||
$(STAMP_DIR)/gcc_libs_target_installed: $(GCC_BUILD_DIR3)/.installed
|
$(STAMP_DIR)/gcc_libs_target_installed: $(GCC_BUILD_DIR3)/.installed
|
||||||
ifeq ($(BR2_GCC_SHARED_LIBGCC),y)
|
ifeq ($(BR2_GCC_SHARED_LIBGCC),y)
|
||||||
# These are in /lib, so...
|
# These go in /lib, so...
|
||||||
rm -rf $(TARGET_DIR)/usr/lib/libgcc_s*.so*
|
rm -rf $(TARGET_DIR)/usr/lib/libgcc_s*.so*
|
||||||
-cp -dpf $(STAGING_DIR)/usr/$(REAL_GNU_TARGET_NAME)/lib*/libgcc_s* \
|
-cp -dpf $(HOST_DIR)/usr/$(REAL_GNU_TARGET_NAME)/lib*/libgcc_s* \
|
||||||
$(TARGET_DIR)/lib/
|
$(TARGET_DIR)/lib/
|
||||||
-$(STRIPCMD) $(STRIP_STRIP_UNNEEDED) $(TARGET_DIR)/lib/libgcc_s*
|
-$(STRIPCMD) $(STRIP_STRIP_UNNEEDED) $(TARGET_DIR)/lib/libgcc_s*
|
||||||
endif
|
endif
|
||||||
ifeq ($(BR2_INSTALL_LIBSTDCPP),y)
|
ifeq ($(BR2_INSTALL_LIBSTDCPP),y)
|
||||||
ifeq ($(BR2_GCC_SHARED_LIBGCC),y)
|
ifeq ($(BR2_GCC_SHARED_LIBGCC),y)
|
||||||
mkdir -p $(TARGET_DIR)/usr/lib
|
mkdir -p $(TARGET_DIR)/usr/lib
|
||||||
-cp -dpf $(STAGING_DIR)/usr/$(REAL_GNU_TARGET_NAME)/lib*/libstdc++.so* \
|
-cp -dpf $(HOST_DIR)/usr/$(REAL_GNU_TARGET_NAME)/lib*/libstdc++.so* \
|
||||||
$(TARGET_DIR)/usr/lib/
|
$(TARGET_DIR)/usr/lib/
|
||||||
-$(STRIPCMD) $(STRIP_STRIP_UNNEEDED) $(TARGET_DIR)/usr/lib/libstdc++.so*
|
-$(STRIPCMD) $(STRIP_STRIP_UNNEEDED) $(TARGET_DIR)/usr/lib/libstdc++.so*
|
||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
ifeq ($(BR2_INSTALL_LIBGCJ),y)
|
ifeq ($(BR2_INSTALL_LIBGCJ),y)
|
||||||
cp -dpf $(STAGING_DIR)/usr/$(REAL_GNU_TARGET_NAME)/lib*/libgcj.so* $(TARGET_DIR)/usr/lib/
|
cp -dpf $(HOST_DIR)/usr/$(REAL_GNU_TARGET_NAME)/lib*/libgcj.so* $(TARGET_DIR)/usr/lib/
|
||||||
mkdir -p $(TARGET_DIR)/usr/lib/security
|
mkdir -p $(TARGET_DIR)/usr/lib/security
|
||||||
cp -dpf $(STAGING_DIR)/usr/lib/security/classpath.security \
|
cp -dpf $(HOST_DIR)/usr/lib/security/classpath.security \
|
||||||
$(TARGET_DIR)/usr/lib/security/
|
$(TARGET_DIR)/usr/lib/security/
|
||||||
-$(STRIPCMD) $(STRIP_STRIP_UNNEEDED) $(TARGET_DIR)/usr/lib/libgcj.so*
|
-$(STRIPCMD) $(STRIP_STRIP_UNNEEDED) $(TARGET_DIR)/usr/lib/libgcj.so*
|
||||||
endif
|
endif
|
||||||
mkdir -p $(@D)
|
mkdir -p $(@D)
|
||||||
touch $@
|
touch $@
|
||||||
|
|
||||||
cross_compiler:=$(STAGING_DIR)/usr/bin/$(REAL_GNU_TARGET_NAME)-gcc
|
cross_compiler:=$(HOST_DIR)/usr/bin/$(REAL_GNU_TARGET_NAME)-gcc
|
||||||
cross_compiler gcc: gcc_intermediate \
|
cross_compiler gcc: gcc_intermediate \
|
||||||
$(LIBFLOAT_TARGET) uclibc $(GCC_BUILD_DIR3)/.installed \
|
$(LIBFLOAT_TARGET) uclibc $(GCC_BUILD_DIR3)/.installed \
|
||||||
$(STAMP_DIR)/gcc_libs_target_installed \
|
$(STAMP_DIR)/gcc_libs_target_installed \
|
||||||
@ -473,8 +456,8 @@ gcc-source: $(DL_DIR)/$(GCC_SOURCE)
|
|||||||
gcc-clean:
|
gcc-clean:
|
||||||
rm -rf $(GCC_BUILD_DIR3)
|
rm -rf $(GCC_BUILD_DIR3)
|
||||||
for prog in cpp gcc gcc-[0-9]* protoize unprotoize gcov gccbug cc; do \
|
for prog in cpp gcc gcc-[0-9]* protoize unprotoize gcov gccbug cc; do \
|
||||||
rm -f $(STAGING_DIR)/usr/bin/$(REAL_GNU_TARGET_NAME)-$$prog; \
|
rm -f $(HOST_DIR)/usr/bin/$(REAL_GNU_TARGET_NAME)-$$prog; \
|
||||||
rm -f $(STAGING_DIR)/usr/bin/$(GNU_TARGET_NAME)-$$prog; \
|
rm -f $(HOST_DIR)/usr/bin/$(GNU_TARGET_NAME)-$$prog; \
|
||||||
done
|
done
|
||||||
|
|
||||||
gcc-dirclean: gcc_initial-dirclean
|
gcc-dirclean: gcc_initial-dirclean
|
||||||
@ -487,7 +470,7 @@ gcc-dirclean: gcc_initial-dirclean
|
|||||||
#############################################################
|
#############################################################
|
||||||
GCC_BUILD_DIR4:=$(BUILD_DIR)/gcc-$(GCC_VERSION)-target
|
GCC_BUILD_DIR4:=$(BUILD_DIR)/gcc-$(GCC_VERSION)-target
|
||||||
|
|
||||||
$(GCC_BUILD_DIR4)/.prepared: $(STAMP_DIR)/gcc_libs_target_installed $(GCC_TARGET_PREREQ)
|
$(GCC_BUILD_DIR4)/.prepared: $(STAMP_DIR)/gcc_libs_target_installed
|
||||||
mkdir -p $(GCC_BUILD_DIR4)
|
mkdir -p $(GCC_BUILD_DIR4)
|
||||||
touch $@
|
touch $@
|
||||||
|
|
||||||
@ -556,7 +539,7 @@ $(TARGET_DIR)/usr/bin/gcc: $(GCC_BUILD_DIR4)/.compiled
|
|||||||
# Work around problem of missing syslimits.h
|
# Work around problem of missing syslimits.h
|
||||||
if [ ! -f $(TARGET_DIR)/usr/$(GCC_LIB_SUBDIR)/$(GCC_INCLUDE_DIR)/syslimits.h ]; then \
|
if [ ! -f $(TARGET_DIR)/usr/$(GCC_LIB_SUBDIR)/$(GCC_INCLUDE_DIR)/syslimits.h ]; then \
|
||||||
echo "warning: working around missing syslimits.h"; \
|
echo "warning: working around missing syslimits.h"; \
|
||||||
cp -f $(STAGING_DIR)/$(GCC_LIB_SUBDIR)/$(GCC_INCLUDE_DIR)/syslimits.h \
|
cp -f $(HOST_DIR)/$(GCC_LIB_SUBDIR)/$(GCC_INCLUDE_DIR)/syslimits.h \
|
||||||
$(TARGET_DIR)/usr/$(GCC_LIB_SUBDIR)/$(GCC_INCLUDE_DIR)/; \
|
$(TARGET_DIR)/usr/$(GCC_LIB_SUBDIR)/$(GCC_INCLUDE_DIR)/; \
|
||||||
fi
|
fi
|
||||||
# Make sure we have 'cc'.
|
# Make sure we have 'cc'.
|
||||||
@ -567,7 +550,7 @@ $(TARGET_DIR)/usr/bin/gcc: $(GCC_BUILD_DIR4)/.compiled
|
|||||||
#rm -rf $(TARGET_DIR)/usr/lib/libgcc_s*.so*
|
#rm -rf $(TARGET_DIR)/usr/lib/libgcc_s*.so*
|
||||||
touch -c $@
|
touch -c $@
|
||||||
|
|
||||||
gcc_target: uclibc_target binutils_target $(TARGET_DIR)/usr/bin/gcc
|
gcc_target: uclibc_target $(GCC_TARGET_PREREQ) binutils $(TARGET_DIR)/usr/bin/gcc
|
||||||
|
|
||||||
gcc_target-clean:
|
gcc_target-clean:
|
||||||
rm -rf $(GCC_BUILD_DIR4)
|
rm -rf $(GCC_BUILD_DIR4)
|
||||||
|
@ -1,7 +1,6 @@
|
|||||||
# Include files required for the internal toolchain backend
|
# Include files required for the internal toolchain backend
|
||||||
|
|
||||||
include toolchain/dependencies/dependencies.mk
|
include toolchain/dependencies/dependencies.mk
|
||||||
include toolchain/binutils/binutils.mk
|
|
||||||
include toolchain/elf2flt/elf2flt.mk
|
include toolchain/elf2flt/elf2flt.mk
|
||||||
include toolchain/gcc/gcc-uclibc-4.x.mk
|
include toolchain/gcc/gcc-uclibc-4.x.mk
|
||||||
include toolchain/gdb/gdb.mk
|
include toolchain/gdb/gdb.mk
|
||||||
|
@ -3,6 +3,6 @@
|
|||||||
if BR2_TOOLCHAIN_BUILDROOT
|
if BR2_TOOLCHAIN_BUILDROOT
|
||||||
source "toolchain/kernel-headers/Config.in"
|
source "toolchain/kernel-headers/Config.in"
|
||||||
source "toolchain/uClibc/Config.in"
|
source "toolchain/uClibc/Config.in"
|
||||||
source "toolchain/binutils/Config.in"
|
source "package/binutils/Config.in.host"
|
||||||
source "toolchain/gcc/Config.in"
|
source "toolchain/gcc/Config.in"
|
||||||
endif
|
endif
|
||||||
|
@ -2,7 +2,6 @@
|
|||||||
|
|
||||||
# Explicit ordering:
|
# Explicit ordering:
|
||||||
include toolchain/helpers.mk
|
include toolchain/helpers.mk
|
||||||
include toolchain/binutils/binutils.mk
|
|
||||||
include toolchain/dependencies/dependencies.mk
|
include toolchain/dependencies/dependencies.mk
|
||||||
include toolchain/elf2flt/elf2flt.mk
|
include toolchain/elf2flt/elf2flt.mk
|
||||||
include toolchain/gcc/gcc-uclibc-4.x.mk
|
include toolchain/gcc/gcc-uclibc-4.x.mk
|
||||||
|
@ -1,7 +1,6 @@
|
|||||||
# Required includes for the external toolchain backend
|
# Required includes for the external toolchain backend
|
||||||
|
|
||||||
include toolchain/helpers.mk
|
include toolchain/helpers.mk
|
||||||
include toolchain/binutils/binutils.mk
|
|
||||||
include toolchain/dependencies/dependencies.mk
|
include toolchain/dependencies/dependencies.mk
|
||||||
include toolchain/elf2flt/elf2flt.mk
|
include toolchain/elf2flt/elf2flt.mk
|
||||||
include toolchain/gcc/gcc-uclibc-4.x.mk
|
include toolchain/gcc/gcc-uclibc-4.x.mk
|
||||||
|
Loading…
Reference in New Issue
Block a user