Mercurial > mxe-octave
diff src/build-gcc.mk @ 3496:3c7b3646d0b3
update to gcc 4.8.2 and allow building for MinGW-64
author | John W. Eaton <jwe@octave.org> |
---|---|
date | Mon, 03 Feb 2014 18:16:02 -0500 |
parents | 13be64f9f16d |
children | dfc2729af6ee |
line wrap: on
line diff
--- a/src/build-gcc.mk Mon Feb 03 18:13:15 2014 -0500 +++ b/src/build-gcc.mk Mon Feb 03 18:16:02 2014 -0500 @@ -3,17 +3,20 @@ PKG := build-gcc $(PKG)_IGNORE := -$(PKG)_VERSION := 4.8.1 -$(PKG)_CHECKSUM := 4e655032cda30e1928fcc3f00962f4238b502169 +$(PKG)_VERSION := 4.8.2 +$(PKG)_CHECKSUM := 810fb70bd721e1d9f446b6503afe0a9088b62986 $(PKG)_SUBDIR := gcc-$($(PKG)_VERSION) $(PKG)_FILE := gcc-$($(PKG)_VERSION).tar.bz2 $(PKG)_URL := ftp://ftp.gnu.org/pub/gnu/gcc/gcc-$($(PKG)_VERSION)/$($(PKG)_FILE) $(PKG)_URL_2 := ftp://ftp.mirrorservice.org/sites/sourceware.org/pub/gcc/releases/gcc-$($(PKG)_VERSION)/$($(PKG)_FILE) -ifeq ($(MXE_NATIVE_BUILD),yes) - $(PKG)_DEPS := build-cmake -else - ifeq ($(MXE_SYSTEM),mingw) - $(PKG)_DEPS := mingwrt w32api build-binutils + +$(PKG)_DEPS := build-cmake +ifeq ($(MXE_SYSTEM),mingw) + $(PKG)_DEPS += build-binutils + ifeq ($(ENABLE_64),yes) + $(PKG)_DEPS += gcc-cloog gcc-gmp gcc-isl gcc-mpc gcc-mpfr mingw-w64 + else + $(PKG)_DEPS += mingwrt w32api endif endif @@ -30,12 +33,14 @@ --with-gnu-as \ --disable-nls \ --without-x \ - --disable-sjlj-exceptions \ --disable-win32-registry \ --enable-threads=win32 + ifneq ($(ENABLE_64),yes) + $(PKG)_SYSDEP_CONFIGURE_OPTIONS += \ + --disable-sjlj-exceptions + endif endif - define $(PKG)_UPDATE $(WGET) -q -O- 'http://ftp.gnu.org/gnu/gcc/?C=M;O=D' | \ $(SED) -n 's,.*<a href="gcc-\([0-9][^"]*\)/".*,\1,p' | \ @@ -43,8 +48,8 @@ head -1 endef -define $(PKG)_BUILD - cd '$(1)' && ./contrib/download_prerequisites +define $(PKG)_CONFIGURE + # configure gcc mkdir '$(1).build' cd '$(1).build' && '$(1)/configure' \ --target='$(TARGET)' \ @@ -52,15 +57,55 @@ --prefix='$(BUILD_TOOLS_PREFIX)' \ --enable-languages='c,c++,fortran' \ --disable-multilib \ + $($(PKG)_SYSDEP_CONFIGURE_OPTIONS) \ $(ENABLE_SHARED_OR_STATIC) \ - $($(PKG)_SYSDEP_CONFIGURE_OPTIONS) \ --disable-libgomp \ --disable-libmudflap \ + --with-cloog='$(BUILD_TOOLS_PREFIX)' \ + --with-gmp='$(BUILD_TOOLS_PREFIX)' \ + --with-isl='$(BUILD_TOOLS_PREFIX)' \ + --with-mpc='$(BUILD_TOOLS_PREFIX)' \ + --with-mpfr='$(BUILD_TOOLS_PREFIX)' \ $(shell [ `uname -s` == Darwin ] && echo "LDFLAGS='-Wl,-no_pie'") +endef + +ifeq ($(ENABLE_64),yes) + define $(PKG)_BUILD_1 + # build standalone gcc + $($(PKG)_CONFIGURE) + $(MAKE) -C '$(1).build' -j '$(JOBS)' all-gcc + $(MAKE) -C '$(1).build' -j 1 install-gcc + + # build mingw-w64-crt + cd '$(1)' && $(call UNPACK_PKG_ARCHIVE,mingw-w64,$(TAR)) + mkdir '$(1).crt-build' + cd '$(1).crt-build' && '$(1)/$(mingw-w64_SUBDIR)/mingw-w64-crt/configure' \ + --host='$(TARGET)' \ + --prefix='$(HOST_PREFIX)' + $(MAKE) -C '$(1).crt-build' -j '$(JOBS)' || $(MAKE) -C '$(1).crt-build' -j '$(JOBS)' + $(MAKE) -C '$(1).crt-build' -j 1 install + + # build rest of gcc + cd '$(1).build' + $(MAKE) -C '$(1).build' -j '$(JOBS)' + $(MAKE) -C '$(1).build' -j 1 install + + if [ -f $(BUILD_TOOLS_PREFIX)/lib/gcc/$(TARGET)/lib/libgcc_s.a ]; then \ + mv $(BUILD_TOOLS_PREFIX)/lib/gcc/$(TARGET)/lib/libgcc_s.a $(BUILD_TOOLS_PREFIX)/lib/gcc/$(TARGET)/4.8.2/libgcc_s.a; \ + fi + endef +else + define $(PKG)_BUILD_1 + $($(PKG)_CONFIGURE) $(MAKE) -C '$(1).build' -j '$(JOBS)' $(MAKE) -C '$(1).build' -j 1 install mkdir -p $(TOP_DIR)/cross-tools/$(HOST_BINDIR) $(MAKE) -C '$(1).build' -j 1 DESTDIR=$(TOP_DIR)/cross-tools install + endef +endif + +define $(PKG)_BUILD + $($(PKG)_BUILD_1) # create pkg-config script if [ '$(MXE_NATIVE_BUILD)' = 'no' ]; then \