binutils: decouple from toolchain selection, use version 2.24, fix libiberty installation

Signed-off-by: Felix Fietkau <nbd@openwrt.org>

SVN-Revision: 41036
lede-17.01
Felix Fietkau 2014-06-06 10:51:47 +00:00
parent 5d680ffda8
commit a57aec309d
1 changed files with 18 additions and 62 deletions

View File

@ -8,24 +8,13 @@
include $(TOPDIR)/rules.mk include $(TOPDIR)/rules.mk
PKG_NAME:=binutils PKG_NAME:=binutils
PKG_VERSION:=$(strip $(subst ",, $(CONFIG_BINUTILS_VERSION))) PKG_VERSION:=2.24
#")) PKG_RELEASE:=1
PKG_RELEASE:=6
ifeq ($(findstring linaro, $(CONFIG_BINUTILS_VERSION)),linaro) PKG_SOURCE_URL:=@GNU/binutils
PKG_SOURCE_URL:=https://releases.linaro.org/13.12/components/toolchain/binutils-linaro/ PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.bz2
PKG_REV:=2.24-2013.12 PKG_VERSION:=$(PKG_VERSION)
PKG_SOURCE:=$(PKG_NAME)-linaro-$(PKG_REV).tar.xz PKG_MD5SUM:=e0f71a7b2ddab0f8612336ac81d9636b
BINUTILS_DIR:=$(PKG_NAME)-linaro-$(PKG_REV)
PKG_BUILD_DIR:=$(BUILD_DIR_TOOLCHAIN)/$(BINUTILS_DIR)
PKG_VERSION:=$(PKG_REV)
else
PKG_SOURCE_URL:=@GNU/binutils
PKG_SOURCE:=binutils-$(PKG_VERSION).tar.bz2
endif
PKG_MD5SUM:=
PATCH_DIR:=$(TOPDIR)/toolchain/binutils/patches/$(PKG_VERSION)
PKG_FIXUP:=autoreconf PKG_FIXUP:=autoreconf
PKG_LIBTOOL_PATHS:=. gas bfd opcodes gprof binutils ld libiberty gold intl PKG_LIBTOOL_PATHS:=. gas bfd opcodes gprof binutils ld libiberty gold intl
@ -56,61 +45,28 @@ define Package/binutils/description
The Binutils package contains a linker, an assembler, and other tools for handling object files The Binutils package contains a linker, an assembler, and other tools for handling object files
endef endef
CONFIGURE_ARGS = \
--target=$(REAL_GNU_TARGET_NAME) \
--host=$(REAL_GNU_TARGET_NAME) \
--build=$(GNU_HOST_NAME) \
--prefix=/usr \
--disable-multilib \
--disable-werror \
--disable-nls \
--enable-shared \
$(SOFT_FLOAT_CONFIG_OPTION) \
$(call qstrip,$(CONFIG_EXTRA_BINUTILS_CONFIG_OPTIONS))
TARGET_CFLAGS += $(FPIC) TARGET_CFLAGS += $(FPIC)
TARGET_LDFLAGS := -L$(PKG_BUILD_DIR)/libiberty $(TARGET_LDFLAGS)
define Build/Configure CONFIGURE_ARGS += \
$(call Build/Configure/Default) --enable-install-libiberty \
$(call Build/Compile/Default, \ --enable-install-libbfd
configure-bfd \
configure-binutils \ define Build/Install
configure-etc \ $(call Build/Install/Default)
configure-gas \ $(MAKE) -C $(PKG_BUILD_DIR)/libiberty \
configure-gprof \ target_header_dir=libiberty \
configure-intl \ DESTDIR="$(PKG_INSTALL_DIR)" \
configure-ld \ MULTIOSDIR="" \
configure-libiberty \ install
configure-opcodes \
)
$(MAKE) CFLAGS="$(TARGET_CFLAGS)" -C $(PKG_BUILD_DIR)/bfd/po Makefile
endef endef
define Build/InstallDev define Build/InstallDev
$(INSTALL_DIR) $(1)/usr/{lib,include} $(CP) $(PKG_INSTALL_DIR)/* $(1)/
$(CP) \
$(PKG_INSTALL_DIR)/usr/lib/* \
$(1)/usr/lib/
$(CP) \
$(PKG_BUILD_DIR)/include/*.h \
$(1)/usr/include/
$(CP) \
$(PKG_INSTALL_DIR)/usr/include/* \
$(1)/usr/include/
rm -f $(1)/usr/include/gdbm.h
endef
define Build/Compile
+$(MAKE) $(PKG_JOBS) -C $(PKG_BUILD_DIR)/bfd/doc/ CFLAGS="-I$(PKG_BUILD_DIR)/include" chew
$(call Build/Compile/Default)
endef endef
define Package/objdump/install define Package/objdump/install
$(INSTALL_DIR) $(1)/usr/bin $(1)/usr/lib $(INSTALL_DIR) $(1)/usr/bin $(1)/usr/lib
$(CP) $(PKG_INSTALL_DIR)/usr/bin/objdump $(1)/usr/bin/ $(CP) $(PKG_INSTALL_DIR)/usr/bin/objdump $(1)/usr/bin/
$(CP) $(PKG_INSTALL_DIR)/usr/lib/libopcodes*.so $(1)/usr/lib/
$(CP) $(PKG_INSTALL_DIR)/usr/lib/libbfd*.so $(1)/usr/lib/
endef endef
define Package/binutils/install define Package/binutils/install