]> git.ipfire.org Git - ipfire-3.x.git/blobdiff - gcc/gcc.nm
git: Update to 2.23.0
[ipfire-3.x.git] / gcc / gcc.nm
index c806eab5beacfd90e6a0de5c61c3649f43877baf..64831ef3a197fa7e1532dce0a61aadd98c011357 100644 (file)
@@ -3,12 +3,12 @@
 # Copyright (C) - IPFire Development Team <info@ipfire.org>                   #
 ###############################################################################
 
-# Configure build to compile with cloog and ppl.
-build_cloog_ppl = 1
+# Configure build to compile with graphite
+build_graphite = 1
 
 name       = gcc
-version    = 4.7.0
-release    = 0.1
+version    = 9.1.0
+release    = 1
 
 maintainer = Michael Tremer <michael.tremer@ipfire.org>
 groups     = Development/Compilers
@@ -22,39 +22,48 @@ description
 end
 
 # This is the at least required version of binutils.
-required_binutils_version = 2.21.51.0.8-1
+binutils_version = 2.24
 
 source_dl  = http://ftp.gnu.org/gnu/gcc/%{thisapp}/
+source_dl += ftp://gcc.gnu.org/pub/gcc/infrastructure/
 sources    = %{thisapp}.tar.gz
 
 build
        requires
                autogen
-               binutils>=%{required_binutils_version}
+               binutils >= %{binutils_version}
                dejagnu
                elfutils-devel
                expect
                filesystem >= 002
                flex
-               glibc-devel
+               glibc-devel >= 2.16
                gmp-devel
                libffi-devel
-               libmpc-devel
+               libmpc-devel >= 0.8.1
                mpfr-devel
                perl
                texinfo
                zlib-devel
        end
 
-       # If cloog support is enabled, we require the devel packages for build.
-       if "%{build_cloog_ppl}" == "1"
-               requires += cloog-ppl-devel
-               requires += ppl-devel
+       # If graphite support is enabled, we require the devel packages for build.
+       if "%{build_graphite}" == "1"
+               requires += isl-devel >= 0.14
        end
 
        # Build libquadmath (only on x86).
        build_libquadmath = 0
 
+       # Build liblsan (only on x86_64).
+       build_liblsan = 0
+
+       # Build libtasn (only on x86_64).
+       build_libtsan = 0
+
+       # Build libubsan
+       build_libubsan = 0
+
        # A couple of configure arguments depending on the architecture and
        # configuration.
        configure_options =
@@ -65,19 +74,20 @@ build
                configure_options = --disable-multilib
 
                build_libquadmath = 1
+               build_liblsan = 1
+               build_libtsan = 1
+               build_libubsan = 1
        end
 
        if "%{DISTRO_ARCH}" == "i686"
                configure_options = --with-arch=%{DISTRO_ARCH} --with-tune=generic
 
                build_libquadmath = 1
+               build_libubsan = 1
        end
 
-       if "%{DISTRO_ARCH}" == "armv5tel"
-               make_bootstrap = bootstrap
-
-               configure_options += --disable-sjlj-exceptions
-               configure_options += --with-float=soft
+       if "%{DISTRO_ARCH}" == "aarch64"
+               build_libubsan = 1
        end
 
        if "%{DISTRO_ARCH}" == "armv7hl"
@@ -86,21 +96,28 @@ build
                configure_options += --disable-sjlj-exceptions
 
                configure_options += \
-                       --with-cpu=cortex-a8 \
                        --with-tune=cortex-a8 \
                        --with-arch=armv7-a \
                        --with-float=hard \
                        --with-fpu=vfpv3-d16 \
                        --with-abi=aapcs-linux
+
+               build_libubsan = 1
        end
 
-       if "%{build_cloog_ppl}" == "1"
-               configure_options += --with-cloog --with-ppl
+       if "%{DISTRO_ARCH}" == "armv5tel"
+               make_bootstrap = bootstrap
+
+               configure_options += --disable-sjlj-exceptions
+               configure_options += --with-float=soft
+
+               build_libubsan = 1
        end
 
-       # CFLAGS for hardening.
-       HARD_CFLAGS = -DEFAULT_PIE -DEFAULT_SSP -DEFAULT_PIE_SSP -DEFAULT_ESP_SPP \
-               -DENABLE_ESP_SSP -DEFAULT_RELRO -DEFAULT_BIND_NOW
+       if "%{build_graphite}" == "1"
+               configure_options += \
+                       --with-isl
+       end
 
        prepare_cmds
                mkdir -v %{DIR_SRC}/gcc-build
@@ -129,46 +146,34 @@ build
                sed -i gcc/Makefile.in \
                        -e "s/-fno-exceptions/& -fno-asynchronous-unwind-tables/"
 
-               # we want to be able to control the pie patch logic via something other
-               # than ALL_CFLAGS and ALL_CXXFLAGS...
-               sed -i gcc/Makefile.in \
-                       -e '/^ALL_CFLAGS/iHARD_CFLAGS = ' \
-                       -e 's|^ALL_CFLAGS = |ALL_CFLAGS = $(HARD_CFLAGS) |' \
-                       -e '/^ALL_CXXFLAGS/iHARD_CFLAGS = ' \
-                       -e 's|^ALL_CXXFLAGS = |ALL_CXXFLAGS = $(HARD_CFLAGS) |'
-
-               # Enable the GCC hardening by default.
-               sed -i gcc/Makefile.in \
-                       -e "s|^HARD_CFLAGS = |HARD_CFLAGS = %{HARD_CFLAGS} |"
-
-               # Compile the compiler with -fPIC as well.
-               # However, genautomata crashes with a "Bus Error" when compiled
-               # with PIC.
-               sed -i gcc/Makefile.in \
-                       -e "s|^ESP_NOPIE_CFLAGS = .*|ESP_NOPIE_CFLAGS =|" \
-                       -e 's|^build/genautomata$(build_exeext) .*|& -fno-PIC|'
-
-               # Default to -gdwarf-4 -fno-debug-types-section rather than -gdwarf-2
-               sed -i gcc/common.opt \
-                       -e '/UInteger Var(dwarf_version)/s/Init(2)/Init(4)/' \
-                       -e '/flag_debug_types_section/s/Init(1)/Init(0)/' \
-                       -e '/dwarf_record_gcc_switches/s/Init(0)/Init(1)/' \
-                       -e 's/\(may be either 2, 3 or 4; the default version is \)2\./\14./'
-
-               ./contrib/gcc_update --touch
+               #./contrib/gcc_update --touch
        end
 
+       export CC=gcc
+       export CXX=g++
+
        build
                cd %{DIR_SRC}/gcc-build
 
                # Modify CFLAGS
                CFLAGS="%{CFLAGS}"
                CFLAGS=$(echo ${CFLAGS} | sed -e 's/\(-Wp,\)\?-D_FORTIFY_SOURCE=[12]//g')
+               CFLAGS=$(echo ${CFLAGS} | sed -e 's/-Werror=format-security//g')
                CFLAGS=$(echo ${CFLAGS} | sed -e 's/-m64//g;s/-m32//g;s/-m31//g')
+               CFLAGS=$(echo ${CFLAGS} | sed -e 's/-mfpmath=sse/-mfpmath=sse -msse2/g')
                CFLAGS=$(echo ${CFLAGS} | sed -e 's/-march=i.86//g')
                CFLAGS=$(echo ${CFLAGS} | sed -e 's/ -pipe / /g')
                CFLAGS=$(echo "${CFLAGS}" | sed -e 's/[[:blank:]]\+/ /g')
                CXXFLAGS=$(echo  ${CFLAGS} | sed -e 's/ -Wall//g')
+               CXXFLAGS=$(echo  ${CXXFLAGS} | sed -e 's/ -fexceptions / /g')
+               #CXXFLAGS=$(echo  ${CXXFLAGS} | sed -e 's/ -Werror=format-security / -Wformat -Werror=format-security /g')
+
+               case "${CFLAGS}" in
+                       *-fasynchronous-unwind-tables*)
+                               sed -i -e "s/-fno-exceptions /-fno-exceptions -fno-asynchronous-unwind-tables/" \
+                                       ../%{thisapp}/Makefile.in
+                               ;;
+               esac
 
                CFLAGS="${CFLAGS}" \
                CXXFLAGS="${CXXFLAGS}" \
@@ -179,7 +184,8 @@ build
                        --prefix=/usr \
                        --libdir=%{libdir} \
                        --libexecdir=%{libdir} \
-                       --mandir=/usr/share/man \
+                       --mandir=%{mandir} \
+                       --with-boot-ldflags="%{LDFLAGS}" \
                        --enable-esp \
                        --enable-shared \
                        --enable-threads=posix \
@@ -188,19 +194,24 @@ build
                        --enable-languages=c,c++,lto \
                        --enable-bootstrap \
                        --enable-checking=release \
-                       --disable-build-with-cxx \
-                       --disable-build-poststage1-with-cxx \
+                       --enable-default-pie \
                        --disable-werror \
                        --disable-libssp \
-                       --disable-static \
                        --with-system-zlib \
                        --with-bugurl=http://bugtracker.ipfire.org \
                        --disable-libunwind-exceptions \
                        --enable-gnu-unique-object \
                        --enable-linker-build-id \
                        --with-linker-hash-style=gnu \
+                       --enable-plugin \
+                       --enable-initfini-array \
+                       --disable-libgcj \
+                       --enable-gnu-indirect-function \
                        %{configure_options}
 
+               # https://gcc.gnu.org/bugzilla/show_bug.cgi?id=58012
+               # XXX disabled flags: --disable-static
+
                # GCC does not support a parallel build.
                make %{make_bootstrap} BOOT_CFLAGS="${CFLAGS}"
 
@@ -214,7 +225,7 @@ build
        end
 
        #test
-       #       cd %{DIR_SRC}/gcc-build && make check
+       #       cd %{DIR_SRC}/gcc-build && make -k check || true
        #       cd %{DIR_APP} && ./contrib/test_summary
        #end
 
@@ -243,9 +254,10 @@ build
                EOF
                                ;;
                        *)
-                               ln -svf ../../../../../%{libdir}/libgcc_s.so.1 ${FULLPATH}/libgcc_s.so
+                               ln -svf ../../../../..%{libdir}/libgcc_s.so.1 ${FULLPATH}/libgcc_s.so
                                ;;
                esac
+               chmod 755 %{BUILDROOT}%{libdir}/libgcc_s.so.1
 
                # Remove some GNU debugger stuff.
                rm -vf %{BUILDROOT}%{libdir}/lib*.py
@@ -266,12 +278,8 @@ build
                chmod 755 %{BUILDROOT}%{libdir}/libgomp.so.1.*
 
                # libstdc++
-               ln -svf ../../../libstdc++.so.6.0.17 ${FULLPATH}/libstdc++.so
-
-               # libmudflap
-               ln -svf ../../../libmudflap.so.0.0.0 ${FULLPATH}/libmudflap.so
-               ln -svf ../../../libmudflapth.so.0.0.0 ${FULLPATH}/libmudflapth.so
-               chmod 755 %{BUILDROOT}%{libdir}/libmudflap{,th}.so.0.*
+               ln -svf ../../../libstdc++.so.6.0.26 ${FULLPATH}/libstdc++.so
+               mv -vf %{BUILDROOT}%{libdir}/lib{std,sup}c++.a ${FULLPATH}
 
                # libquadmath
                if [ "%{build_libquadmath}" = "1" ]; then
@@ -283,11 +291,31 @@ build
                mv -vf %{BUILDROOT}%{libdir}/libitm.spec ${FULLPATH}/
                ln -svf ../../../libitm.so.1.0.0 ${FULLPATH}/libitm.so
                chmod 755 %{BUILDROOT}%{libdir}/libitm.so.1.*
+
+               # liblsan
+               if [ "%{build_liblsan}" = "1" ]; then
+                       ln -svf ../../../liblsan.so.0.0.0 ${FULLPATH}/liblsan.so
+                       chmod 755 %{BUILDROOT}%{libdir}/liblsan.so.*
+               fi
+
+               # libtsan
+               if [ "%{build_libtsan}" = "1" ]; then
+                       ln -svf ../../../libtsan.so.0.0.0 ${FULLPATH}/libtsan.so
+                       chmod 755 %{BUILDROOT}%{libdir}/libtsan.so.*
+               fi
+
+               # libubsan
+               if [ "%{build_libubsan}" = "1" ]; then
+                       ln -svf ../../../libubsan.so.1.0.0 ${FULLPATH}/libubsan.so
+                       chmod 755 %{BUILDROOT}%{libdir}/libubsan.so.*
+               fi
        end
 
        keep_libraries
                %{libdir}/gcc/%{DISTRO_BUILDTARGET}/%{version}/libgcc.a
                %{libdir}/gcc/%{DISTRO_BUILDTARGET}/%{version}/libgcc_eh.a
+               %{libdir}/gcc/%{DISTRO_BUILDTARGET}/%{version}/libstdc++.a
+               %{libdir}/gcc/%{DISTRO_BUILDTARGET}/%{version}/libsupc++.a
        end
 end
 
@@ -296,8 +324,9 @@ packages
                groups += Build
 
                requires
-                       binutils >= %{required_binutils_version}
+                       binutils >= %{binutils_version}
                        filesystem >= 002
+                       glibc >= 2.16
                        glibc-devel
                        gmp-devel
                        cpp = %{thisver}
@@ -308,10 +337,6 @@ packages
                # We do not ship libgcc-devel anymore.
                provides += libgcc-devel = %{thisver}
                obsoletes += libgcc-devel < %{thisver}
-
-               if "%{build_cloog_ppl}" == "1"
-                       requires += cloog-ppl >= 0.15
-               end
        end
 
        package %{name}-c++
@@ -369,6 +394,7 @@ packages
                end
 
                provides = /lib/cpp
+               requires = gcc-c++ = %{thisver}
        end
 
        package libgcc
@@ -381,6 +407,11 @@ packages
                files
                        %{libdir}/libgcc*.so.*
                end
+
+               obsoletes
+                       libmudflap
+                       libmudflap-devel
+               end
        end
 
        package libstdc++
@@ -413,48 +444,29 @@ packages
                end
        end
 
-       package libgomp
-               summary = GCC OpenMP v3.0 shared support library.
-               description
-                       This package contains GCC shared support library which is needed
-                       for OpenMP v3.0 support.
-               end
-
-               files
-                       %{libdir}/libgomp*.so.*
-               end
-       end
+       package libstdc++-static
+               summary = Static libraries for the GNU standard C++ library
+               description = %{summary}
 
-       package libmudflap
-               summary = GCC mudflap shared support library.
-               description
-                       This package contains GCC shared support library which is needed
-                       for mudflap support.
+               requires
+                       libstdc++-devel = %{thisver}
                end
 
                files
-                       %{libdir}/libmudflap*.so.*
+                       %{libdir}/gcc/%{DISTRO_BUILDTARGET}/%{version}/libstdc++.a
+                       %{libdir}/gcc/%{DISTRO_BUILDTARGET}/%{version}/libsupc++.a
                end
        end
 
-       package libmudflap-devel
-               summary = Development files for GCC mudflap support.
+       package libgomp
+               summary = GCC OpenMP v3.0 shared support library.
                description
-                       This package contains headers for building mudflap-instrumented programs.
-
-                       To instrument a non-threaded program, add -fmudflap
-                       option to GCC and when linking add -lmudflap, for threaded programs
-                       also add -fmudflapth and -lmudflapth.
-               end
-
-               requires
-                       libmudflap = %{thisver}
+                       This package contains GCC shared support library which is needed
+                       for OpenMP v3.0 support.
                end
 
                files
-                       %{libdir}/gcc/%{DISTRO_BUILDTARGET}/%{version}/include/mf-runtime.h
-                       %{libdir}/gcc/%{DISTRO_BUILDTARGET}/%{version}/libmudflap.so
-                       %{libdir}/gcc/%{DISTRO_BUILDTARGET}/%{version}/libmudflapth.so
+                       %{libdir}/libgomp*.so.*
                end
        end
 
@@ -484,6 +496,7 @@ packages
                        end
 
                        files
+                               %{libdir}/libquadmath.so
                                %{libdir}/gcc/%{DISTRO_BUILDTARGET}/%{version}/include/quadmath.h
                                %{libdir}/gcc/%{DISTRO_BUILDTARGET}/%{version}/include/quadmath_weak.h
                                %{libdir}/gcc/%{DISTRO_BUILDTARGET}/%{version}/libquadmath.so
@@ -499,7 +512,7 @@ packages
                end
 
                files
-                       %{libdir}/libitm.so.1*
+                       %{libdir}/libitm.so.*
                end
        end
 
@@ -516,12 +529,80 @@ packages
                end
 
                files
+                       %{libdir}/libitm.so
                        %{libdir}/gcc/%{DISTRO_BUILDTARGET}/%{version}/include/itm.h
                        %{libdir}/gcc/%{DISTRO_BUILDTARGET}/%{version}/include/itm_weak.h
                        %{libdir}/gcc/%{DISTRO_BUILDTARGET}/%{version}/libitm.so
                end
        end
 
+       package libatomic
+               summary = The GNU Atomic library
+               description
+                       This package contains the GNU Atomic library which is a
+                       GCC support runtime library for atomisc operations not
+                       supported by hardware.
+               end
+
+               files
+                       %{libdir}/libatomic.so.*
+               end
+       end
+
+       package libasan
+               summary = The Address Sanitizer runtime library
+               description
+                       This package contains the Address Sanitizer library
+                       which is used for -fsanitize=address instrumented programs.
+               end
+
+               files
+                       %{libdir}/libasan.so.*
+               end
+       end
+
+       if "%{build_libtsan}" == "1"
+               package libtsan
+                       summary = The Thread Sanitizer runtime library
+                       description
+                               This package contains the Thread Sanitizer library
+                               which is used for -fsanitize=thread instrumented programs.
+                       end
+
+                       files
+                               %{libdir}/libtsan.so.*
+                       end
+               end
+       end
+
+       if "%{build_libubsan}" == "1"
+               package libubsan
+                       summary = The Undefined Behavior Sanitizer runtime library
+                       description
+                               This package contains the Undefined Behavior Sanitizer library
+                               which is used for -fsanitize=undefined instrumented programs.
+                       end
+
+                       files
+                               %{libdir}/libubsan.so.*
+                       end
+               end
+       end
+
+       if "%{build_liblsan}" == "1"
+               package liblsan
+                       summary = The Leak Sanitizer runtime library
+                       description
+                               This package contains the Leak Sanitizer library
+                               which is used for -fsanitize=leak instrumented programs.
+                       end
+
+                       files
+                               %{libdir}/liblsan.so.*
+                       end
+               end
+       end
+
        package gcc-plugin-devel
                summary = Support for compiling GCC plugins.
                description