Update packaging for 4.8
authorAnas Nashif <anas.nashif@intel.com>
Sun, 7 Jul 2013 15:26:52 +0000 (11:26 -0400)
committerAnas Nashif <anas.nashif@intel.com>
Sun, 7 Jul 2013 15:26:52 +0000 (11:26 -0400)
packaging/change_spec
packaging/cross-armv5el-gcc48-icecream-backend.spec [deleted file]
packaging/cross-armv7el-gcc48-icecream-backend.spec [deleted file]
packaging/cross-armv7hl-gcc48-icecream-backend.spec
packaging/cross-i386-gcc48-icecream-backend.spec
packaging/cross-x86_64-gcc48-icecream-backend.spec
packaging/gcc.spec.in
packaging/gcc48-testresults.spec
packaging/gcc48.spec
packaging/libffi48.spec
packaging/libgcj48.spec

index ee12148..0e080ba 100644 (file)
@@ -2,8 +2,7 @@
 
 do_icecream=1
 do_cross_static=0
-do_cross_shared=0
-do_optional_compiler=0
+do_cross_shared=1
 do_optional_compiler_languages=0
 rm -f libgcj*.spec libgcj*.changes libffi*.spec libffi*.changes gcc*-testresults.spec gcc*-testresults.changes gcc*.spec cross*.spec cross*.changes
 
@@ -28,11 +27,7 @@ else
        esac
 fi
 
-       echo -n > $outfile
-       if test "$do_optional_compiler" = "1"; then
-           echo '%define run_tests 1' >> $outfile
-           echo '%define build_optional_compiler 1' >> $outfile
-       fi
+       : > $outfile
        if test "$do_optional_compiler_languages" = "1"; then
            echo '%define run_tests 1' >> $outfile
            echo '%define build_optional_compiler_languages 1' >> $outfile
@@ -54,7 +49,6 @@ s/@variant@/-64bit/g
 p
 }
 }' >> $outfile
-       if test "$do_optional_compiler" = "0"; then
        if test "$do_optional_compiler_languages" = "0"; then
        echo '%define building_libjava 1' > libgcj$base_ver.spec
        sed -e '/^# LIBJAVA-DELETE-BEGIN/,/^# LIBJAVA-DELETE-END/d;s/-n libgcj@base_ver@$//g;s/^Name:[[:space:]]*gcc/Name: libgcj/g' \
@@ -100,21 +94,18 @@ s/@variant@/-64bit/g
 p
 }
 }' \
-       | sed -e '/^%package -n libffi'$base_ver'$/d' \
-       | sed -e 's/-n libffi'$base_ver'$//g' \
 >> libffi$base_ver.spec
 
   test -f gcc$base_ver.changes \
     && ( ln -f gcc$base_ver.changes libgcj$base_ver.changes; \
         ln -f gcc$base_ver.changes libffi$base_ver.changes; \
         ln -f gcc$base_ver.changes gcc$base_ver-testresults.changes; )
-       fi
     fi
 
 # disabled: mips, sparc, alpha
 if test "$do_icecream" = 1 ; then
-  for arch in i386 x86_64 armv7hl armv5el armv7el; do
-    exclarch=`echo $arch | sed -e 's/i.86/%ix86/'`
+  for arch in i386 x86_64 armv7hl armv7l; do
+    exclarch=`echo $arch | sed -e 's/ppc$/ppc64/'`
     { sed -n -e '1,/COMMON-BEGIN/p' cross-icecream.spec.in
       sed -n -e '/COMMON-BEGIN/,/COMMON-END/p' $outfile
       sed -n -e '/COMMON-END/,$p' cross-icecream.spec.in; } |
@@ -147,5 +138,8 @@ if test "$do_cross_static" = 1 ; then
 #  test -f gcc$base_ver.changes && ln -f gcc$base_ver.changes cross-avr-gcc$base_ver.changes
 fi
 
+for f in *.spec; do
+  sed -i -e '/^# .*-\(BEGIN\|END\)$/d' $f
+done
 
 exit 0
diff --git a/packaging/cross-armv5el-gcc48-icecream-backend.spec b/packaging/cross-armv5el-gcc48-icecream-backend.spec
deleted file mode 100644 (file)
index 07728bb..0000000
+++ /dev/null
@@ -1,422 +0,0 @@
-#
-# spec file for package gcc (Version 4.0.1)
-#
-# Copyright (c) 2005 SUSE Linux AG, Nuernberg, Germany.
-# This file and all modifications and additions to the pristine
-# package are under the same license as the package itself.
-#
-# Please submit bugfixes or comments via http://www.suse.de/feedback/
-#
-
-%define build_cp 1
-%define build_ada 0
-%define build_libjava 0
-%define build_java 0
-%define build_fortran 0
-%define build_objc 0
-%define build_objcp 0
-%define build_nof 0
-%define build_with_mudflap 0
-%define gcc_target_arch armv5el-tizen-linux
-%define gcc_icecream 1
-
-%define binutils_target armv5el
-%if %{binutils_target} == "armv7l" || %{binutils_target} == "armv7hl" || %{binutils_target} == "armv7el"
-%define binutils_target arm
-%endif
-%if %{binutils_target} == "armv5el"
-%define binutils_target arm
-%endif
-%define canonical_target %(echo %{binutils_target} | sed -e "s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;")
-%if %{binutils_target} == "arm"
-%define canonical_target_abi -gnueabi
-%endif
-
-Name:         cross-armv5el-gcc48-icecream-backend
-BuildRequires: cross-%{binutils_target}-binutils
-BuildRequires: bison
-BuildRequires: flex
-BuildRequires: gettext-devel
-BuildRequires: glibc-devel-32bit
-BuildRequires: mpc-devel
-BuildRequires: mpfr-devel
-BuildRequires: perl
-BuildRequires: makeinfo
-BuildRequires: zlib-devel
-%ifarch %ix86 x86_64  %arm
-BuildRequires: cloog-devel
-BuildRequires: ppl-devel
-%endif
-%ifarch ia64
-BuildRequires: libunwind-devel
-%endif
-ExclusiveArch: ppc ppc64 %ix86 x86_64 ia64 
-%define _binary_payload w.ufdio
-
-# COMMON-BEGIN
-# COMMON-BEGIN
-%define biarch_targets x86_64 
-
-URL:          http://gcc.gnu.org/
-Version: 4.8.1
-Release:      1
-%define gcc_version %(echo %version | sed 's/_.*//')
-%define gcc_dir_version %(echo %gcc_version | cut -d '.' -f 1-2)
-%define snapshot_date %(echo %version | sed 's/[34]\.[0-9]\.[0-6]//' | sed 's/_/-/')
-%define binsuffix -4.8
-# COMMON-END
-# COMMON-BEGIN
-BuildRoot:     %{_tmppath}/%{name}-%{version}-build
-#Source:               gcc-%{gcc_version}%{snapshot_date}.tar.bz2
-Source:     gcc-%{version}.tar.bz2
-
-Source1:       change_spec
-Source2:       libgcj48-rpmlintrc
-Source3:       gcc48-rpmlintrc
-Source4:       ecj.jar
-Source6:       baselibs.conf
-# Patches auto-generated by git-buildpackage:
-Patch0:     0001-dir-version.patch
-Patch1:     0002-textdomain.patch
-Patch2:     0003-rename-info-files.patch
-Patch3:     0004-ARM-linker.patch
-
-# GCC-TESTSUITE-DELETE-BEGIN
-# LIBFFI-DELETE-BEGIN
-# LIBJAVA-DELETE-BEGIN
-Group:         Development/Toolchain
-Summary:       The GNU C Compiler and Support Files
-License:        GPL-3.0+
-
-%description
-Core package for the GNU Compiler Collection, including the C language
-frontend.
-
-Language frontends other than C are split to different sub-packages,
-namely gcc-ada, gcc-c++, gcc-fortran, gcc-java, gcc-objc and
-gcc-obj-c++.
-
-
-
-# COMMON-END
-# COMMON-BEGIN
-
-# Define the canonical target and host architecture
-#   %gcc_target_arch  is supposed to be the full target triple
-#   %TARGET_ARCH      is the canonicalized CPU part
-#   %CONFIGURE_TARGET is the target triple used for --target=
-%if 0%{?gcc_target_arch:1}
-%define CONFIGURE_TARGET %{gcc_target_arch}
-%define TARGET_ARCH %(echo %{gcc_target_arch} | cut -d - -f 1 | sed -e "s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;")
-%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "i586"
-%define CONFIGURE_TARGET i586-tizen-linux
-%endif
-%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "armv7l"
-%define CONFIGURE_TARGET armv7l-tizen-linux-gnueabi
-%endif
-%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "armv7hl"
-%define CONFIGURE_TARGET armv7hl-tizen-linux-gnueabi
-%endif
-%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "armv7el"
-%define CONFIGURE_TARGET armv7el-tizen-linux-gnueabi
-%endif
-%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "armv5el"
-%define CONFIGURE_TARGET armv5el-tizen-linux-gnueabi
-%endif
-%else
-%define TARGET_ARCH %(echo %{_target_cpu} | sed -e "s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;")
-%endif
-%define HOST_ARCH %(echo %{_host_cpu} | sed -e "s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;")
-
-%define biarch %(case " %{biarch_targets} " in (*" %{TARGET_ARCH} "*) echo 1;; (*) echo 0;; esac)
-
-%ifarch %arm
-%define GCCDIST %{HOST_ARCH}-tizen-linux-gnueabi
-%else
-%define GCCDIST %{HOST_ARCH}-tizen-linux
-%endif
-
-%define libsubdir %{_libdir}/gcc/%{GCCDIST}/%{gcc_dir_version}
-%define gxxinclude %{_prefix}/include/c++/%{gcc_dir_version}
-
-# COMMON-END
-# COMMON-BEGIN
-
-%prep
-#%setup -q -n gcc-%{gcc_version}%{snapshot_date}
-%setup -q -n gcc-%{version}
-# 0001-dir-version.patch
-%patch0 -p1
-%patch1 -p1
-%patch2 -p1
-%patch3 -p1
-
-%build
-# Avoid rebuilding of generated files
-contrib/gcc_update --touch
-# Avoid fucking up testsuite results with Java and indirect dispatch
-export LD_AS_NEEDED=0
-# Split version file into version used for directories (X.Y) and
-# version to report with --version (X.Y.Z).
-# See also gcc-dir-version.patch.
-# Also decrement the patchlevel version by one
-if test `cat gcc/DEV-PHASE` == "prerelease"; then
-  ( cat gcc/BASE-VER | cut -d '.' -f 1-2 | tr -d '\n'; echo -n .; cat gcc/BASE-VER | cut -d '.' -f 3 | tr '0123456789' '0012345678' ) > gcc/FULL-VER
-else
-  mv gcc/BASE-VER gcc/FULL-VER
-fi
-cat gcc/FULL-VER | cut -d '.' -f 1-2 > gcc/BASE-VER
-
-rm -rf obj-%{GCCDIST}
-mkdir obj-%{GCCDIST}
-cd obj-%{GCCDIST}
-RPM_OPT_FLAGS="$RPM_OPT_FLAGS -U_FORTIFY_SOURCE"
-RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-fno-rtti//g' -e 's/-fno-exceptions//g' -e 's/-Wmissing-format-attribute//g' -e 's/-fstack-protector//g' -e 's/-ffortify=.//g' -e 's/-Wall//g' -e 's/-m32//g' -e 's/-m64//g'`
-%ifarch %ix86
-# -mcpu is superceded by -mtune but -mtune is not supported by
-# our bootstrap compiler.  -mcpu gives a warning that stops
-# the build process, so remove it for now.  Also remove all other
-# -march and -mtune flags.  They are superseeded by proper
-# default compiler settings now.
-RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-mcpu=i.86//g' -e 's/-march=i.86//g' -e 's/-mtune=i.86//g'`
-%endif
-%if 0%{?gcc_target_arch:1} && 0%{!?gcc_icecream:1}
-# Kill all -march/tune/cpu because that screws building the target libs
-RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-m\(arch\|tune\|cpu\)=[^ ]*//g'`
-%endif
-# Replace 2 spaces by one finally
-RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/  / /g'`
-
-languages=c
-%if %{build_cp}
-languages=$languages,c++
-%endif
-%if %{build_objc}
-languages=$languages,objc
-%endif
-%if %{build_fortran}
-languages=$languages,fortran
-%endif
-%if %{build_objcp}
-languages=$languages,obj-c++
-%endif
-%if %{build_java}
-languages=$languages,java
-%endif
-%if %{build_ada}
-languages=$languages,ada
-%endif
-
-J=%{?jobs:%jobs}
-if test -z "$J"; then
-  J=$(getconf _NPROCESSORS_CONF)
-  JL=$(($J * 2))
-else
-  test 1 -gt "$J" && J=1
-  JL=$(($(getconf _NPROCESSORS_CONF)*2))
-fi
-if test "$J" == "0"; then
-  J=1
-fi
-if test "$JL" == "0"; then
-  JL=1
-fi
-PARALLEL="-j$J -l$JL"
-
-# we don't want some miscompiles in the testsuite, or some fault in
-# the compiler to kill the machine.  Hence we limit the amount of memory
-# by the physical RAM plus half of swap
-#MEM=$(free -m | awk '/^Mem:/ {print $2}')
-#SWAP=$(free -m | awk '/^Swap:/ {print $2}')
-#ulimit -v $(((MEM + SWAP/2)*1024))
-
-# In general we want to ship release checking enabled compilers
-# and run BETA with checking enabled.
-#ENABLE_CHECKING="--enable-checking=yes"
-ENABLE_CHECKING="--enable-checking=release"
-
-# Work around tail/head -1 changes
-export _POSIX2_VERSION=199209
-
-# configure tries to parse include/features.h to detect
-# if glibc supports SSP.  When cross compiling we would need
-# to install a cross glibc, which we don't, or make the whole
-# thing point to the native glibc, which is in /, hence the
-# --with-sysroot=/
-
-%if %{build_ada}
-# Using the host gnatmake like
-#   CC="gcc%{hostsuffix}" GNATBIND="gnatbind%{hostsuffix}"
-#   GNATMAKE="gnatmake%{hostsuffix}"
-# doesn't work due to PR33857, so an un-suffixed gnatmake has to be
-# available
-mkdir -p host-tools/bin
-cp -a /usr/bin/gnatmake%{hostsuffix} host-tools/bin/gnatmake
-cp -a /usr/bin/gnatlink%{hostsuffix} host-tools/bin/gnatlink
-cp -a /usr/bin/gnatbind%{hostsuffix} host-tools/bin/gnatbind
-cp -a /usr/bin/gcc%{hostsuffix} host-tools/bin/gcc
-ln -sf /usr/%{_lib} host-tools/%{_lib}
-export PATH="`pwd`/host-tools/bin:$PATH"
-%endif
-#%if 0%{?gcc_target_arch:1} && 0%{!?gcc_icecream:1}
-#%else
-#      --enable-threads=posix \
-#%endif
-#      --enable-shared \
-CFLAGS="$RPM_OPT_FLAGS" CXXFLAGS="$RPM_OPT_FLAGS" XCFLAGS="$RPM_OPT_FLAGS" \
-TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
-../configure \
-       --prefix=%{_prefix} \
-       --infodir=%{_infodir} \
-       --mandir=%{_mandir} \
-       --libdir=%{_libdir} \
-       --libexecdir=%{_libdir} \
-       --enable-languages=$languages \
-       $ENABLE_CHECKING \
-       --with-gxx-include-dir=%{_prefix}/include/c++/%{gcc_dir_version} \
-       --enable-ssp \
-       --disable-libssp \
-       --disable-libitm \
-%if 0%{?fast_build}
-       --disable-bootstrap \
-%endif
-       --disable-plugin \
-       --with-bugurl="http://bugs.tizen.org/" \
-       --with-pkgversion="Tizen Linux" \
-%if !%{build_libjava}
-        --disable-libgcj \
-%else
-       --with-java-home=%{_libdir}/jvm/java-1.5.0-gcj%{binsuffix}-1.5.0.0/jre \
-       --with-ecj-jar=%{libsubdir}/ecj.jar \
-        --disable-java-awt \
-%if !%{biarch_libjava}
-        --disable-libjava-multilib \
-%endif
-%endif
-%if !%{build_with_mudflap}
-       --disable-libmudflap \
-%endif
-       --with-slibdir=/%{_lib} \
-       --with-system-zlib \
-       --enable-__cxa_atexit \
-       --enable-libstdcxx-allocator=new \
-       --disable-libstdcxx-pch \
-       --enable-version-specific-runtime-libs \
-       --enable-linker-build-id \
-%if 0%{?gcc_target_arch:1}
-%if 0%{?gcc_icecream:1}
-       --with-build-sysroot=/ \
-       --with-sysroot=%{_prefix}/%{gcc_target_arch}%{?canonical_target_abi:%canonical_target_abi} \
-       --with-gxx-include-dir=%{_prefix}/%{gcc_target_arch}%{?canonical_target_abi:%canonical_target_abi}/usr/include/c++/%{gcc_dir_version} \
-       --enable-linux-futex \
-%endif
-%if 0%{?canonical_target:1}
-       --with-build-time-tools=/usr/%{canonical_target}-tizen-linux%{?canonical_target_abi:%canonical_target_abi}/bin \
-%endif
-%if 0%{?build_static:1}
-       --disable-shared \
-%endif
-%if "%{TARGET_ARCH}" == "spu"
-       --with-sysroot=/usr/spu \
-       --with-gxx-include-dir=%{_prefix}/spu/include/c++/%{gcc_dir_version} \
-       --with-newlib \
-%endif
-       --disable-nls \
-       --target=%{CONFIGURE_TARGET} \
-%else
-       --program-suffix=%{binsuffix} \
-       --enable-linux-futex \
-       --without-system-libunwind \
-%endif
-%if "%{TARGET_ARCH}" == "armv5tel"
-       --with-arch=armv5te \
-       --with-float=soft \
-       --with-mode=arm \
-       --with-abi=aapcs-linux \
-       --disable-sjlj-exceptions \
-%endif
-%if "%{TARGET_ARCH}" == "armv7el" 
-       --with-arch=armv7-a \
-       --with-tune=cortex-a9 \
-       --with-float=soft \
-       --with-abi=softfp \
-       --with-fpu=vfpv3 \
-       --disable-sjlj-exceptions \
-%endif
-%if "%{TARGET_ARCH}" == "armv7l" || "%{TARGET_ARCH}" == "armv7hl"
-       --with-arch=armv7-a \
-       --with-tune=cortex-a9 \
-       --with-float=hard \
-       --with-abi=aapcs-linux \
-       --with-fpu=vfpv3-d16 \
-       --disable-sjlj-exceptions \
-%endif
-%if "%{TARGET_ARCH}" == "i586"
-       --with-arch-32=i586 \
-       --with-tune=generic \
-%endif
-%if "%{TARGET_ARCH}" == "x86_64"
-       --with-arch-32=i586 \
-       --with-tune=generic \
-%endif
-       --build=%{GCCDIST}
-
-# COMMON-END
-# COMMON-END
-
-make %{?jobs:-j%jobs} all-gcc TARGET-gcc="cc1 cc1plus gcc-cross g++ native"
-
-%install
-cd obj-%{GCCDIST}
-rm -rf $RPM_BUILD_ROOT
-make -C gcc DESTDIR=$RPM_BUILD_ROOT/inst install-driver install-common
-make DESTDIR=$RPM_BUILD_ROOT/inst maybe-install-lto-plugin
-
-# But the assembler comes from the cross-binutils, and hence is _not_
-# named funnily, not even on ppc, so there we need the original target
-install -s -D %{_prefix}/bin/%{canonical_target}-tizen-linux%{?canonical_target_abi:%canonical_target_abi}-as \
-       $RPM_BUILD_ROOT/env/usr/bin/as
-install -s $RPM_BUILD_ROOT/inst%{_prefix}/bin/%{CONFIGURE_TARGET}-g++ \
-       $RPM_BUILD_ROOT/env/usr/bin/g++
-install -s $RPM_BUILD_ROOT/inst%{_prefix}/bin/%{CONFIGURE_TARGET}-gcc \
-       $RPM_BUILD_ROOT/env/usr/bin/gcc
-
-%define targetlibsubdir %{_libdir}/gcc/%{CONFIGURE_TARGET}/%{gcc_dir_version}
-for back in cc1 cc1plus; do 
-       install -s -D $RPM_BUILD_ROOT/inst%{targetlibsubdir}/$back \
-               $RPM_BUILD_ROOT/env%{targetlibsubdir}/$back
-done
-if test -f $RPM_BUILD_ROOT/inst%{targetlibsubdir}/liblto_plugin.so; then
-  install -s -D $RPM_BUILD_ROOT/inst%{targetlibsubdir}/liblto_plugin.so \
-               $RPM_BUILD_ROOT/env%{targetlibsubdir}/liblto_plugin.so
-fi
-
-libs=`for bin in $RPM_BUILD_ROOT/env/usr/bin/* $RPM_BUILD_ROOT/env%{targetlibsubdir}/*; do \
-  ldd $bin | sed -n '\,^[^/]*\(/[^ ]*\).*,{ s//\1/; p; }'  ;\
-done | sort -u `
-for lib in $libs; do
-   # Check wether the same library also exists in the parent directory,
-   # and prefer that on the assumption that it is a more generic one.
-   baselib=`echo "$lib" | sed 's,/[^/]*\(/[^/]*\)$,\1,'`
-   test -f "$baselib" && lib=$baselib
-   install -s -D $lib $RPM_BUILD_ROOT/env$lib
-done
-rm -rf $RPM_BUILD_ROOT/inst
-cd $RPM_BUILD_ROOT/env
-tar cvzf ../%{name}_%{_arch}.tar.gz *
-cd ..
-mkdir -p usr/share/icecream-envs
-mv %{name}_%{_arch}.tar.gz usr/share/icecream-envs
-rpm -q --changelog glibc >  usr/share/icecream-envs/%{name}_%{_arch}.glibc
-rpm -q --changelog binutils >  usr/share/icecream-envs/%{name}_%{_arch}.binutils
-rm -r env
-cd $RPM_BUILD_DIR
-
-%clean
-rm -rf $RPM_BUILD_ROOT
-
-%files
-%defattr(-,root,root)
-/usr/share/icecream-envs
-
-%changelog -n cross-armv5el-gcc48-icecream-backend
diff --git a/packaging/cross-armv7el-gcc48-icecream-backend.spec b/packaging/cross-armv7el-gcc48-icecream-backend.spec
deleted file mode 100644 (file)
index 2b148fc..0000000
+++ /dev/null
@@ -1,422 +0,0 @@
-#
-# spec file for package gcc (Version 4.0.1)
-#
-# Copyright (c) 2005 SUSE Linux AG, Nuernberg, Germany.
-# This file and all modifications and additions to the pristine
-# package are under the same license as the package itself.
-#
-# Please submit bugfixes or comments via http://www.suse.de/feedback/
-#
-
-%define build_cp 1
-%define build_ada 0
-%define build_libjava 0
-%define build_java 0
-%define build_fortran 0
-%define build_objc 0
-%define build_objcp 0
-%define build_nof 0
-%define build_with_mudflap 0
-%define gcc_target_arch armv7el-tizen-linux
-%define gcc_icecream 1
-
-%define binutils_target armv7el
-%if %{binutils_target} == "armv7l" || %{binutils_target} == "armv7hl" || %{binutils_target} == "armv7el"
-%define binutils_target arm
-%endif
-%if %{binutils_target} == "armv5el"
-%define binutils_target arm
-%endif
-%define canonical_target %(echo %{binutils_target} | sed -e "s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;")
-%if %{binutils_target} == "arm"
-%define canonical_target_abi -gnueabi
-%endif
-
-Name:         cross-armv7el-gcc48-icecream-backend
-BuildRequires: cross-%{binutils_target}-binutils
-BuildRequires: bison
-BuildRequires: flex
-BuildRequires: gettext-devel
-BuildRequires: glibc-devel-32bit
-BuildRequires: mpc-devel
-BuildRequires: mpfr-devel
-BuildRequires: perl
-BuildRequires: makeinfo
-BuildRequires: zlib-devel
-%ifarch %ix86 x86_64  %arm
-BuildRequires: cloog-devel
-BuildRequires: ppl-devel
-%endif
-%ifarch ia64
-BuildRequires: libunwind-devel
-%endif
-ExclusiveArch: ppc ppc64 %ix86 x86_64 ia64 
-%define _binary_payload w.ufdio
-
-# COMMON-BEGIN
-# COMMON-BEGIN
-%define biarch_targets x86_64 
-
-URL:          http://gcc.gnu.org/
-Version: 4.8.1
-Release:      1
-%define gcc_version %(echo %version | sed 's/_.*//')
-%define gcc_dir_version %(echo %gcc_version | cut -d '.' -f 1-2)
-%define snapshot_date %(echo %version | sed 's/[34]\.[0-9]\.[0-6]//' | sed 's/_/-/')
-%define binsuffix -4.8
-# COMMON-END
-# COMMON-BEGIN
-BuildRoot:     %{_tmppath}/%{name}-%{version}-build
-#Source:               gcc-%{gcc_version}%{snapshot_date}.tar.bz2
-Source:     gcc-%{version}.tar.bz2
-
-Source1:       change_spec
-Source2:       libgcj48-rpmlintrc
-Source3:       gcc48-rpmlintrc
-Source4:       ecj.jar
-Source6:       baselibs.conf
-# Patches auto-generated by git-buildpackage:
-Patch0:     0001-dir-version.patch
-Patch1:     0002-textdomain.patch
-Patch2:     0003-rename-info-files.patch
-Patch3:     0004-ARM-linker.patch
-
-# GCC-TESTSUITE-DELETE-BEGIN
-# LIBFFI-DELETE-BEGIN
-# LIBJAVA-DELETE-BEGIN
-Group:         Development/Toolchain
-Summary:       The GNU C Compiler and Support Files
-License:        GPL-3.0+
-
-%description
-Core package for the GNU Compiler Collection, including the C language
-frontend.
-
-Language frontends other than C are split to different sub-packages,
-namely gcc-ada, gcc-c++, gcc-fortran, gcc-java, gcc-objc and
-gcc-obj-c++.
-
-
-
-# COMMON-END
-# COMMON-BEGIN
-
-# Define the canonical target and host architecture
-#   %gcc_target_arch  is supposed to be the full target triple
-#   %TARGET_ARCH      is the canonicalized CPU part
-#   %CONFIGURE_TARGET is the target triple used for --target=
-%if 0%{?gcc_target_arch:1}
-%define CONFIGURE_TARGET %{gcc_target_arch}
-%define TARGET_ARCH %(echo %{gcc_target_arch} | cut -d - -f 1 | sed -e "s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;")
-%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "i586"
-%define CONFIGURE_TARGET i586-tizen-linux
-%endif
-%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "armv7l"
-%define CONFIGURE_TARGET armv7l-tizen-linux-gnueabi
-%endif
-%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "armv7hl"
-%define CONFIGURE_TARGET armv7hl-tizen-linux-gnueabi
-%endif
-%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "armv7el"
-%define CONFIGURE_TARGET armv7el-tizen-linux-gnueabi
-%endif
-%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "armv5el"
-%define CONFIGURE_TARGET armv5el-tizen-linux-gnueabi
-%endif
-%else
-%define TARGET_ARCH %(echo %{_target_cpu} | sed -e "s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;")
-%endif
-%define HOST_ARCH %(echo %{_host_cpu} | sed -e "s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;")
-
-%define biarch %(case " %{biarch_targets} " in (*" %{TARGET_ARCH} "*) echo 1;; (*) echo 0;; esac)
-
-%ifarch %arm
-%define GCCDIST %{HOST_ARCH}-tizen-linux-gnueabi
-%else
-%define GCCDIST %{HOST_ARCH}-tizen-linux
-%endif
-
-%define libsubdir %{_libdir}/gcc/%{GCCDIST}/%{gcc_dir_version}
-%define gxxinclude %{_prefix}/include/c++/%{gcc_dir_version}
-
-# COMMON-END
-# COMMON-BEGIN
-
-%prep
-#%setup -q -n gcc-%{gcc_version}%{snapshot_date}
-%setup -q -n gcc-%{version}
-# 0001-dir-version.patch
-%patch0 -p1
-%patch1 -p1
-%patch2 -p1
-%patch3 -p1
-
-%build
-# Avoid rebuilding of generated files
-contrib/gcc_update --touch
-# Avoid fucking up testsuite results with Java and indirect dispatch
-export LD_AS_NEEDED=0
-# Split version file into version used for directories (X.Y) and
-# version to report with --version (X.Y.Z).
-# See also gcc-dir-version.patch.
-# Also decrement the patchlevel version by one
-if test `cat gcc/DEV-PHASE` == "prerelease"; then
-  ( cat gcc/BASE-VER | cut -d '.' -f 1-2 | tr -d '\n'; echo -n .; cat gcc/BASE-VER | cut -d '.' -f 3 | tr '0123456789' '0012345678' ) > gcc/FULL-VER
-else
-  mv gcc/BASE-VER gcc/FULL-VER
-fi
-cat gcc/FULL-VER | cut -d '.' -f 1-2 > gcc/BASE-VER
-
-rm -rf obj-%{GCCDIST}
-mkdir obj-%{GCCDIST}
-cd obj-%{GCCDIST}
-RPM_OPT_FLAGS="$RPM_OPT_FLAGS -U_FORTIFY_SOURCE"
-RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-fno-rtti//g' -e 's/-fno-exceptions//g' -e 's/-Wmissing-format-attribute//g' -e 's/-fstack-protector//g' -e 's/-ffortify=.//g' -e 's/-Wall//g' -e 's/-m32//g' -e 's/-m64//g'`
-%ifarch %ix86
-# -mcpu is superceded by -mtune but -mtune is not supported by
-# our bootstrap compiler.  -mcpu gives a warning that stops
-# the build process, so remove it for now.  Also remove all other
-# -march and -mtune flags.  They are superseeded by proper
-# default compiler settings now.
-RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-mcpu=i.86//g' -e 's/-march=i.86//g' -e 's/-mtune=i.86//g'`
-%endif
-%if 0%{?gcc_target_arch:1} && 0%{!?gcc_icecream:1}
-# Kill all -march/tune/cpu because that screws building the target libs
-RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-m\(arch\|tune\|cpu\)=[^ ]*//g'`
-%endif
-# Replace 2 spaces by one finally
-RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/  / /g'`
-
-languages=c
-%if %{build_cp}
-languages=$languages,c++
-%endif
-%if %{build_objc}
-languages=$languages,objc
-%endif
-%if %{build_fortran}
-languages=$languages,fortran
-%endif
-%if %{build_objcp}
-languages=$languages,obj-c++
-%endif
-%if %{build_java}
-languages=$languages,java
-%endif
-%if %{build_ada}
-languages=$languages,ada
-%endif
-
-J=%{?jobs:%jobs}
-if test -z "$J"; then
-  J=$(getconf _NPROCESSORS_CONF)
-  JL=$(($J * 2))
-else
-  test 1 -gt "$J" && J=1
-  JL=$(($(getconf _NPROCESSORS_CONF)*2))
-fi
-if test "$J" == "0"; then
-  J=1
-fi
-if test "$JL" == "0"; then
-  JL=1
-fi
-PARALLEL="-j$J -l$JL"
-
-# we don't want some miscompiles in the testsuite, or some fault in
-# the compiler to kill the machine.  Hence we limit the amount of memory
-# by the physical RAM plus half of swap
-#MEM=$(free -m | awk '/^Mem:/ {print $2}')
-#SWAP=$(free -m | awk '/^Swap:/ {print $2}')
-#ulimit -v $(((MEM + SWAP/2)*1024))
-
-# In general we want to ship release checking enabled compilers
-# and run BETA with checking enabled.
-#ENABLE_CHECKING="--enable-checking=yes"
-ENABLE_CHECKING="--enable-checking=release"
-
-# Work around tail/head -1 changes
-export _POSIX2_VERSION=199209
-
-# configure tries to parse include/features.h to detect
-# if glibc supports SSP.  When cross compiling we would need
-# to install a cross glibc, which we don't, or make the whole
-# thing point to the native glibc, which is in /, hence the
-# --with-sysroot=/
-
-%if %{build_ada}
-# Using the host gnatmake like
-#   CC="gcc%{hostsuffix}" GNATBIND="gnatbind%{hostsuffix}"
-#   GNATMAKE="gnatmake%{hostsuffix}"
-# doesn't work due to PR33857, so an un-suffixed gnatmake has to be
-# available
-mkdir -p host-tools/bin
-cp -a /usr/bin/gnatmake%{hostsuffix} host-tools/bin/gnatmake
-cp -a /usr/bin/gnatlink%{hostsuffix} host-tools/bin/gnatlink
-cp -a /usr/bin/gnatbind%{hostsuffix} host-tools/bin/gnatbind
-cp -a /usr/bin/gcc%{hostsuffix} host-tools/bin/gcc
-ln -sf /usr/%{_lib} host-tools/%{_lib}
-export PATH="`pwd`/host-tools/bin:$PATH"
-%endif
-#%if 0%{?gcc_target_arch:1} && 0%{!?gcc_icecream:1}
-#%else
-#      --enable-threads=posix \
-#%endif
-#      --enable-shared \
-CFLAGS="$RPM_OPT_FLAGS" CXXFLAGS="$RPM_OPT_FLAGS" XCFLAGS="$RPM_OPT_FLAGS" \
-TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
-../configure \
-       --prefix=%{_prefix} \
-       --infodir=%{_infodir} \
-       --mandir=%{_mandir} \
-       --libdir=%{_libdir} \
-       --libexecdir=%{_libdir} \
-       --enable-languages=$languages \
-       $ENABLE_CHECKING \
-       --with-gxx-include-dir=%{_prefix}/include/c++/%{gcc_dir_version} \
-       --enable-ssp \
-       --disable-libssp \
-       --disable-libitm \
-%if 0%{?fast_build}
-       --disable-bootstrap \
-%endif
-       --disable-plugin \
-       --with-bugurl="http://bugs.tizen.org/" \
-       --with-pkgversion="Tizen Linux" \
-%if !%{build_libjava}
-        --disable-libgcj \
-%else
-       --with-java-home=%{_libdir}/jvm/java-1.5.0-gcj%{binsuffix}-1.5.0.0/jre \
-       --with-ecj-jar=%{libsubdir}/ecj.jar \
-        --disable-java-awt \
-%if !%{biarch_libjava}
-        --disable-libjava-multilib \
-%endif
-%endif
-%if !%{build_with_mudflap}
-       --disable-libmudflap \
-%endif
-       --with-slibdir=/%{_lib} \
-       --with-system-zlib \
-       --enable-__cxa_atexit \
-       --enable-libstdcxx-allocator=new \
-       --disable-libstdcxx-pch \
-       --enable-version-specific-runtime-libs \
-       --enable-linker-build-id \
-%if 0%{?gcc_target_arch:1}
-%if 0%{?gcc_icecream:1}
-       --with-build-sysroot=/ \
-       --with-sysroot=%{_prefix}/%{gcc_target_arch}%{?canonical_target_abi:%canonical_target_abi} \
-       --with-gxx-include-dir=%{_prefix}/%{gcc_target_arch}%{?canonical_target_abi:%canonical_target_abi}/usr/include/c++/%{gcc_dir_version} \
-       --enable-linux-futex \
-%endif
-%if 0%{?canonical_target:1}
-       --with-build-time-tools=/usr/%{canonical_target}-tizen-linux%{?canonical_target_abi:%canonical_target_abi}/bin \
-%endif
-%if 0%{?build_static:1}
-       --disable-shared \
-%endif
-%if "%{TARGET_ARCH}" == "spu"
-       --with-sysroot=/usr/spu \
-       --with-gxx-include-dir=%{_prefix}/spu/include/c++/%{gcc_dir_version} \
-       --with-newlib \
-%endif
-       --disable-nls \
-       --target=%{CONFIGURE_TARGET} \
-%else
-       --program-suffix=%{binsuffix} \
-       --enable-linux-futex \
-       --without-system-libunwind \
-%endif
-%if "%{TARGET_ARCH}" == "armv5tel"
-       --with-arch=armv5te \
-       --with-float=soft \
-       --with-mode=arm \
-       --with-abi=aapcs-linux \
-       --disable-sjlj-exceptions \
-%endif
-%if "%{TARGET_ARCH}" == "armv7el" 
-       --with-arch=armv7-a \
-       --with-tune=cortex-a9 \
-       --with-float=soft \
-       --with-abi=softfp \
-       --with-fpu=vfpv3 \
-       --disable-sjlj-exceptions \
-%endif
-%if "%{TARGET_ARCH}" == "armv7l" || "%{TARGET_ARCH}" == "armv7hl"
-       --with-arch=armv7-a \
-       --with-tune=cortex-a9 \
-       --with-float=hard \
-       --with-abi=aapcs-linux \
-       --with-fpu=vfpv3-d16 \
-       --disable-sjlj-exceptions \
-%endif
-%if "%{TARGET_ARCH}" == "i586"
-       --with-arch-32=i586 \
-       --with-tune=generic \
-%endif
-%if "%{TARGET_ARCH}" == "x86_64"
-       --with-arch-32=i586 \
-       --with-tune=generic \
-%endif
-       --build=%{GCCDIST}
-
-# COMMON-END
-# COMMON-END
-
-make %{?jobs:-j%jobs} all-gcc TARGET-gcc="cc1 cc1plus gcc-cross g++ native"
-
-%install
-cd obj-%{GCCDIST}
-rm -rf $RPM_BUILD_ROOT
-make -C gcc DESTDIR=$RPM_BUILD_ROOT/inst install-driver install-common
-make DESTDIR=$RPM_BUILD_ROOT/inst maybe-install-lto-plugin
-
-# But the assembler comes from the cross-binutils, and hence is _not_
-# named funnily, not even on ppc, so there we need the original target
-install -s -D %{_prefix}/bin/%{canonical_target}-tizen-linux%{?canonical_target_abi:%canonical_target_abi}-as \
-       $RPM_BUILD_ROOT/env/usr/bin/as
-install -s $RPM_BUILD_ROOT/inst%{_prefix}/bin/%{CONFIGURE_TARGET}-g++ \
-       $RPM_BUILD_ROOT/env/usr/bin/g++
-install -s $RPM_BUILD_ROOT/inst%{_prefix}/bin/%{CONFIGURE_TARGET}-gcc \
-       $RPM_BUILD_ROOT/env/usr/bin/gcc
-
-%define targetlibsubdir %{_libdir}/gcc/%{CONFIGURE_TARGET}/%{gcc_dir_version}
-for back in cc1 cc1plus; do 
-       install -s -D $RPM_BUILD_ROOT/inst%{targetlibsubdir}/$back \
-               $RPM_BUILD_ROOT/env%{targetlibsubdir}/$back
-done
-if test -f $RPM_BUILD_ROOT/inst%{targetlibsubdir}/liblto_plugin.so; then
-  install -s -D $RPM_BUILD_ROOT/inst%{targetlibsubdir}/liblto_plugin.so \
-               $RPM_BUILD_ROOT/env%{targetlibsubdir}/liblto_plugin.so
-fi
-
-libs=`for bin in $RPM_BUILD_ROOT/env/usr/bin/* $RPM_BUILD_ROOT/env%{targetlibsubdir}/*; do \
-  ldd $bin | sed -n '\,^[^/]*\(/[^ ]*\).*,{ s//\1/; p; }'  ;\
-done | sort -u `
-for lib in $libs; do
-   # Check wether the same library also exists in the parent directory,
-   # and prefer that on the assumption that it is a more generic one.
-   baselib=`echo "$lib" | sed 's,/[^/]*\(/[^/]*\)$,\1,'`
-   test -f "$baselib" && lib=$baselib
-   install -s -D $lib $RPM_BUILD_ROOT/env$lib
-done
-rm -rf $RPM_BUILD_ROOT/inst
-cd $RPM_BUILD_ROOT/env
-tar cvzf ../%{name}_%{_arch}.tar.gz *
-cd ..
-mkdir -p usr/share/icecream-envs
-mv %{name}_%{_arch}.tar.gz usr/share/icecream-envs
-rpm -q --changelog glibc >  usr/share/icecream-envs/%{name}_%{_arch}.glibc
-rpm -q --changelog binutils >  usr/share/icecream-envs/%{name}_%{_arch}.binutils
-rm -r env
-cd $RPM_BUILD_DIR
-
-%clean
-rm -rf $RPM_BUILD_ROOT
-
-%files
-%defattr(-,root,root)
-/usr/share/icecream-envs
-
-%changelog -n cross-armv7el-gcc48-icecream-backend
index 59b0c7f..e133c6a 100644 (file)
@@ -53,9 +53,7 @@ BuildRequires: libunwind-devel
 ExclusiveArch: ppc ppc64 %ix86 x86_64 ia64 
 %define _binary_payload w.ufdio
 
-# COMMON-BEGIN
-# COMMON-BEGIN
-%define biarch_targets x86_64 
+%define biarch_targets x86_64 s390x powerpc64 powerpc sparc sparc64
 
 URL:          http://gcc.gnu.org/
 Version: 4.8.1
@@ -64,27 +62,15 @@ Release:      1
 %define gcc_dir_version %(echo %gcc_version | cut -d '.' -f 1-2)
 %define snapshot_date %(echo %version | sed 's/[34]\.[0-9]\.[0-6]//' | sed 's/_/-/')
 %define binsuffix -4.8
-# COMMON-END
-# COMMON-BEGIN
 BuildRoot:     %{_tmppath}/%{name}-%{version}-build
-#Source:               gcc-%{gcc_version}%{snapshot_date}.tar.bz2
-Source:     gcc-%{version}.tar.bz2
-
+Source:                gcc-%{gcc_version}%{snapshot_date}.tar.bz2
 Source1:       change_spec
-Source2:       libgcj48-rpmlintrc
 Source3:       gcc48-rpmlintrc
 Source4:       ecj.jar
 Source6:       baselibs.conf
-# Patches auto-generated by git-buildpackage:
-Patch0:     0001-dir-version.patch
-Patch1:     0002-textdomain.patch
-Patch2:     0003-rename-info-files.patch
-Patch3:     0004-ARM-linker.patch
-
-# GCC-TESTSUITE-DELETE-BEGIN
-# LIBFFI-DELETE-BEGIN
-# LIBJAVA-DELETE-BEGIN
-Group:         Development/Toolchain
+
+
+Group:         Development/Languages/C and C++
 Summary:       The GNU C Compiler and Support Files
 License:        GPL-3.0+
 
@@ -98,8 +84,6 @@ gcc-obj-c++.
 
 
 
-# COMMON-END
-# COMMON-BEGIN
 
 # Define the canonical target and host architecture
 #   %gcc_target_arch  is supposed to be the full target triple
@@ -108,6 +92,12 @@ gcc-obj-c++.
 %if 0%{?gcc_target_arch:1}
 %define CONFIGURE_TARGET %{gcc_target_arch}
 %define TARGET_ARCH %(echo %{gcc_target_arch} | cut -d - -f 1 | sed -e "s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;")
+%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "powerpc"
+%define CONFIGURE_TARGET powerpc64-tizen-linux
+%endif
+%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "powerpc64"
+%define CONFIGURE_TARGET powerpc64-tizen-linux
+%endif
 %if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "i586"
 %define CONFIGURE_TARGET i586-tizen-linux
 %endif
@@ -117,11 +107,8 @@ gcc-obj-c++.
 %if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "armv7hl"
 %define CONFIGURE_TARGET armv7hl-tizen-linux-gnueabi
 %endif
-%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "armv7el"
-%define CONFIGURE_TARGET armv7el-tizen-linux-gnueabi
-%endif
-%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "armv5el"
-%define CONFIGURE_TARGET armv5el-tizen-linux-gnueabi
+%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "armv5tel"
+%define CONFIGURE_TARGET armv5tel-tizen-linux-gnueabi
 %endif
 %else
 %define TARGET_ARCH %(echo %{_target_cpu} | sed -e "s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;")
@@ -130,26 +117,39 @@ gcc-obj-c++.
 
 %define biarch %(case " %{biarch_targets} " in (*" %{TARGET_ARCH} "*) echo 1;; (*) echo 0;; esac)
 
+%ifarch ppc
+%define GCCDIST powerpc64-tizen-linux
+%else
+%ifarch %sparc
+%define GCCDIST sparc64-tizen-linux
+%else
 %ifarch %arm
 %define GCCDIST %{HOST_ARCH}-tizen-linux-gnueabi
 %else
 %define GCCDIST %{HOST_ARCH}-tizen-linux
 %endif
+%endif
+%endif
 
 %define libsubdir %{_libdir}/gcc/%{GCCDIST}/%{gcc_dir_version}
 %define gxxinclude %{_prefix}/include/c++/%{gcc_dir_version}
 
-# COMMON-END
-# COMMON-BEGIN
 
 %prep
-#%setup -q -n gcc-%{gcc_version}%{snapshot_date}
-%setup -q -n gcc-%{version}
-# 0001-dir-version.patch
-%patch0 -p1
-%patch1 -p1
-%patch2 -p1
-%patch3 -p1
+%setup -q -n gcc-%{gcc_version}%{snapshot_date}
+
+
+# We are configuring ppc as ppc64 but with switched multilibs.  Adjust
+# the libstdc++ abi testsuite baseline files accordingly
+%ifarch ppc
+if [ -d libstdc++-v3/config/abi/post/powerpc64-linux-gnu ]; then
+  mkdir -p libstdc++-v3/config/abi/post/powerpc64-linux-gnu/64
+  mv libstdc++-v3/config/abi/post/powerpc64-linux-gnu/baseline_symbols.txt \
+       libstdc++-v3/config/abi/post/powerpc64-linux-gnu/64/
+  mv libstdc++-v3/config/abi/post/powerpc64-linux-gnu/32/baseline_symbols.txt \
+       libstdc++-v3/config/abi/post/powerpc64-linux-gnu/
+fi
+%endif
 
 %build
 # Avoid rebuilding of generated files
@@ -180,6 +180,10 @@ RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-fno-rtti//g' -e 's/-fno-exceptions
 # default compiler settings now.
 RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-mcpu=i.86//g' -e 's/-march=i.86//g' -e 's/-mtune=i.86//g'`
 %endif
+%ifarch s390 s390x
+RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-fsigned-char//g'`
+RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-O1/-O2/g'`
+%endif
 %if 0%{?gcc_target_arch:1} && 0%{!?gcc_icecream:1}
 # Kill all -march/tune/cpu because that screws building the target libs
 RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-m\(arch\|tune\|cpu\)=[^ ]*//g'`
@@ -242,7 +246,7 @@ export _POSIX2_VERSION=199209
 # if glibc supports SSP.  When cross compiling we would need
 # to install a cross glibc, which we don't, or make the whole
 # thing point to the native glibc, which is in /, hence the
-# --with-sysroot=/
+# --with-build-sysroot=/
 
 %if %{build_ada}
 # Using the host gnatmake like
@@ -263,26 +267,27 @@ export PATH="`pwd`/host-tools/bin:$PATH"
 #      --enable-threads=posix \
 #%endif
 #      --enable-shared \
+%if "%{TARGET_ARCH}" == "armv7l" || "%{TARGET_ARCH}" == "armv7hl"
+# temporary workaround for a miscompilation of hash functions in java code
+GCJ_EXTRA_FLAGS="-marm"
+%endif
 CFLAGS="$RPM_OPT_FLAGS" CXXFLAGS="$RPM_OPT_FLAGS" XCFLAGS="$RPM_OPT_FLAGS" \
-TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
+TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS $GCJ_EXTRA_FLAGS" \
 ../configure \
        --prefix=%{_prefix} \
        --infodir=%{_infodir} \
        --mandir=%{_mandir} \
        --libdir=%{_libdir} \
        --libexecdir=%{_libdir} \
+    --disable-bootstrap \
        --enable-languages=$languages \
        $ENABLE_CHECKING \
        --with-gxx-include-dir=%{_prefix}/include/c++/%{gcc_dir_version} \
        --enable-ssp \
        --disable-libssp \
-       --disable-libitm \
-%if 0%{?fast_build}
-       --disable-bootstrap \
-%endif
        --disable-plugin \
        --with-bugurl="http://bugs.tizen.org/" \
-       --with-pkgversion="Tizen Linux" \
+       --with-pkgversion="Tizen" \
 %if !%{build_libjava}
         --disable-libgcj \
 %else
@@ -313,12 +318,14 @@ TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
 %if 0%{?canonical_target:1}
        --with-build-time-tools=/usr/%{canonical_target}-tizen-linux%{?canonical_target_abi:%canonical_target_abi}/bin \
 %endif
+%if 0%{?sysroot:1}
+       --with-sysroot=%sysroot \
+%endif
 %if 0%{?build_static:1}
        --disable-shared \
 %endif
 %if "%{TARGET_ARCH}" == "spu"
-       --with-sysroot=/usr/spu \
-       --with-gxx-include-dir=%{_prefix}/spu/include/c++/%{gcc_dir_version} \
+       --with-gxx-include-dir=%sysroot/include/c++/%{gcc_dir_version} \
        --with-newlib \
 %endif
        --disable-nls \
@@ -326,8 +333,12 @@ TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
 %else
        --program-suffix=%{binsuffix} \
        --enable-linux-futex \
+%ifarch ia64
+       --with-system-libunwind \
+%else
        --without-system-libunwind \
 %endif
+%endif
 %if "%{TARGET_ARCH}" == "armv5tel"
        --with-arch=armv5te \
        --with-float=soft \
@@ -335,15 +346,15 @@ TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
        --with-abi=aapcs-linux \
        --disable-sjlj-exceptions \
 %endif
-%if "%{TARGET_ARCH}" == "armv7el" 
+%if "%{TARGET_ARCH}" == "armv7l" 
        --with-arch=armv7-a \
        --with-tune=cortex-a9 \
-       --with-float=soft \
-       --with-abi=softfp \
-       --with-fpu=vfpv3 \
+       --with-float=hard \
+       --with-abi=aapcs-linux \
+       --with-fpu=vfpv3-d16 \
        --disable-sjlj-exceptions \
 %endif
-%if "%{TARGET_ARCH}" == "armv7l" || "%{TARGET_ARCH}" == "armv7hl"
+%if  "%{TARGET_ARCH}" == "armv7hl"
        --with-arch=armv7-a \
        --with-tune=cortex-a9 \
        --with-float=hard \
@@ -351,6 +362,22 @@ TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
        --with-fpu=vfpv3-d16 \
        --disable-sjlj-exceptions \
 %endif
+%if "%{TARGET_ARCH}" == "powerpc" || "%{TARGET_ARCH}" == "powerpc64"
+%if "%{TARGET_ARCH}" == "powerpc"
+       --with-cpu=default32 \
+%endif
+       --with-cpu-64=power4 \
+       --enable-secureplt \
+       --with-long-double-128 \
+%endif
+%if "%{TARGET_ARCH}" == "sparc64"
+       --with-cpu=ultrasparc \
+       --with-long-double-128 \
+%endif
+%if "%{TARGET_ARCH}" == "sparc"
+       --with-cpu=v8 \
+       --with-long-double-128 \
+%endif
 %if "%{TARGET_ARCH}" == "i586"
        --with-arch-32=i586 \
        --with-tune=generic \
@@ -359,10 +386,18 @@ TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
        --with-arch-32=i586 \
        --with-tune=generic \
 %endif
+%if "%{TARGET_ARCH}" == "s390"
+        --with-tune=z196 --with-arch=z10 \
+       --with-long-double-128 \
+       --enable-decimal-float \
+%endif
+%if "%{TARGET_ARCH}" == "s390x"
+        --with-tune=z196 --with-arch=z10 \
+       --with-long-double-128 \
+       --enable-decimal-float \
+%endif
        --build=%{GCCDIST}
 
-# COMMON-END
-# COMMON-END
 
 make %{?jobs:-j%jobs} all-gcc TARGET-gcc="cc1 cc1plus gcc-cross g++ native"
 
index 8b9e355..cf1baea 100644 (file)
@@ -50,12 +50,10 @@ BuildRequires: ppl-devel
 %ifarch ia64
 BuildRequires: libunwind-devel
 %endif
-ExclusiveArch: ppc ppc64 x86_64 ia64 
+ExclusiveArch: ppc ppc64 %ix86 x86_64 ia64 
 %define _binary_payload w.ufdio
 
-# COMMON-BEGIN
-# COMMON-BEGIN
-%define biarch_targets x86_64 
+%define biarch_targets x86_64 s390x powerpc64 powerpc sparc sparc64
 
 URL:          http://gcc.gnu.org/
 Version: 4.8.1
@@ -64,27 +62,15 @@ Release:      1
 %define gcc_dir_version %(echo %gcc_version | cut -d '.' -f 1-2)
 %define snapshot_date %(echo %version | sed 's/[34]\.[0-9]\.[0-6]//' | sed 's/_/-/')
 %define binsuffix -4.8
-# COMMON-END
-# COMMON-BEGIN
 BuildRoot:     %{_tmppath}/%{name}-%{version}-build
-#Source:               gcc-%{gcc_version}%{snapshot_date}.tar.bz2
-Source:     gcc-%{version}.tar.bz2
-
+Source:                gcc-%{gcc_version}%{snapshot_date}.tar.bz2
 Source1:       change_spec
-Source2:       libgcj48-rpmlintrc
 Source3:       gcc48-rpmlintrc
 Source4:       ecj.jar
 Source6:       baselibs.conf
-# Patches auto-generated by git-buildpackage:
-Patch0:     0001-dir-version.patch
-Patch1:     0002-textdomain.patch
-Patch2:     0003-rename-info-files.patch
-Patch3:     0004-ARM-linker.patch
-
-# GCC-TESTSUITE-DELETE-BEGIN
-# LIBFFI-DELETE-BEGIN
-# LIBJAVA-DELETE-BEGIN
-Group:         Development/Toolchain
+
+
+Group:         Development/Languages/C and C++
 Summary:       The GNU C Compiler and Support Files
 License:        GPL-3.0+
 
@@ -98,8 +84,6 @@ gcc-obj-c++.
 
 
 
-# COMMON-END
-# COMMON-BEGIN
 
 # Define the canonical target and host architecture
 #   %gcc_target_arch  is supposed to be the full target triple
@@ -108,6 +92,12 @@ gcc-obj-c++.
 %if 0%{?gcc_target_arch:1}
 %define CONFIGURE_TARGET %{gcc_target_arch}
 %define TARGET_ARCH %(echo %{gcc_target_arch} | cut -d - -f 1 | sed -e "s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;")
+%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "powerpc"
+%define CONFIGURE_TARGET powerpc64-tizen-linux
+%endif
+%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "powerpc64"
+%define CONFIGURE_TARGET powerpc64-tizen-linux
+%endif
 %if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "i586"
 %define CONFIGURE_TARGET i586-tizen-linux
 %endif
@@ -117,11 +107,8 @@ gcc-obj-c++.
 %if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "armv7hl"
 %define CONFIGURE_TARGET armv7hl-tizen-linux-gnueabi
 %endif
-%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "armv7el"
-%define CONFIGURE_TARGET armv7el-tizen-linux-gnueabi
-%endif
-%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "armv5el"
-%define CONFIGURE_TARGET armv5el-tizen-linux-gnueabi
+%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "armv5tel"
+%define CONFIGURE_TARGET armv5tel-tizen-linux-gnueabi
 %endif
 %else
 %define TARGET_ARCH %(echo %{_target_cpu} | sed -e "s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;")
@@ -130,26 +117,39 @@ gcc-obj-c++.
 
 %define biarch %(case " %{biarch_targets} " in (*" %{TARGET_ARCH} "*) echo 1;; (*) echo 0;; esac)
 
+%ifarch ppc
+%define GCCDIST powerpc64-tizen-linux
+%else
+%ifarch %sparc
+%define GCCDIST sparc64-tizen-linux
+%else
 %ifarch %arm
 %define GCCDIST %{HOST_ARCH}-tizen-linux-gnueabi
 %else
 %define GCCDIST %{HOST_ARCH}-tizen-linux
 %endif
+%endif
+%endif
 
 %define libsubdir %{_libdir}/gcc/%{GCCDIST}/%{gcc_dir_version}
 %define gxxinclude %{_prefix}/include/c++/%{gcc_dir_version}
 
-# COMMON-END
-# COMMON-BEGIN
 
 %prep
-#%setup -q -n gcc-%{gcc_version}%{snapshot_date}
-%setup -q -n gcc-%{version}
-# 0001-dir-version.patch
-%patch0 -p1
-%patch1 -p1
-%patch2 -p1
-%patch3 -p1
+%setup -q -n gcc-%{gcc_version}%{snapshot_date}
+
+
+# We are configuring ppc as ppc64 but with switched multilibs.  Adjust
+# the libstdc++ abi testsuite baseline files accordingly
+%ifarch ppc
+if [ -d libstdc++-v3/config/abi/post/powerpc64-linux-gnu ]; then
+  mkdir -p libstdc++-v3/config/abi/post/powerpc64-linux-gnu/64
+  mv libstdc++-v3/config/abi/post/powerpc64-linux-gnu/baseline_symbols.txt \
+       libstdc++-v3/config/abi/post/powerpc64-linux-gnu/64/
+  mv libstdc++-v3/config/abi/post/powerpc64-linux-gnu/32/baseline_symbols.txt \
+       libstdc++-v3/config/abi/post/powerpc64-linux-gnu/
+fi
+%endif
 
 %build
 # Avoid rebuilding of generated files
@@ -180,6 +180,10 @@ RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-fno-rtti//g' -e 's/-fno-exceptions
 # default compiler settings now.
 RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-mcpu=i.86//g' -e 's/-march=i.86//g' -e 's/-mtune=i.86//g'`
 %endif
+%ifarch s390 s390x
+RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-fsigned-char//g'`
+RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-O1/-O2/g'`
+%endif
 %if 0%{?gcc_target_arch:1} && 0%{!?gcc_icecream:1}
 # Kill all -march/tune/cpu because that screws building the target libs
 RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-m\(arch\|tune\|cpu\)=[^ ]*//g'`
@@ -242,7 +246,7 @@ export _POSIX2_VERSION=199209
 # if glibc supports SSP.  When cross compiling we would need
 # to install a cross glibc, which we don't, or make the whole
 # thing point to the native glibc, which is in /, hence the
-# --with-sysroot=/
+# --with-build-sysroot=/
 
 %if %{build_ada}
 # Using the host gnatmake like
@@ -263,26 +267,27 @@ export PATH="`pwd`/host-tools/bin:$PATH"
 #      --enable-threads=posix \
 #%endif
 #      --enable-shared \
+%if "%{TARGET_ARCH}" == "armv7l" || "%{TARGET_ARCH}" == "armv7hl"
+# temporary workaround for a miscompilation of hash functions in java code
+GCJ_EXTRA_FLAGS="-marm"
+%endif
 CFLAGS="$RPM_OPT_FLAGS" CXXFLAGS="$RPM_OPT_FLAGS" XCFLAGS="$RPM_OPT_FLAGS" \
-TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
+TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS $GCJ_EXTRA_FLAGS" \
 ../configure \
        --prefix=%{_prefix} \
        --infodir=%{_infodir} \
        --mandir=%{_mandir} \
        --libdir=%{_libdir} \
        --libexecdir=%{_libdir} \
+    --disable-bootstrap \
        --enable-languages=$languages \
        $ENABLE_CHECKING \
        --with-gxx-include-dir=%{_prefix}/include/c++/%{gcc_dir_version} \
        --enable-ssp \
        --disable-libssp \
-       --disable-libitm \
-%if 0%{?fast_build}
-       --disable-bootstrap \
-%endif
        --disable-plugin \
        --with-bugurl="http://bugs.tizen.org/" \
-       --with-pkgversion="Tizen Linux" \
+       --with-pkgversion="Tizen" \
 %if !%{build_libjava}
         --disable-libgcj \
 %else
@@ -313,12 +318,14 @@ TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
 %if 0%{?canonical_target:1}
        --with-build-time-tools=/usr/%{canonical_target}-tizen-linux%{?canonical_target_abi:%canonical_target_abi}/bin \
 %endif
+%if 0%{?sysroot:1}
+       --with-sysroot=%sysroot \
+%endif
 %if 0%{?build_static:1}
        --disable-shared \
 %endif
 %if "%{TARGET_ARCH}" == "spu"
-       --with-sysroot=/usr/spu \
-       --with-gxx-include-dir=%{_prefix}/spu/include/c++/%{gcc_dir_version} \
+       --with-gxx-include-dir=%sysroot/include/c++/%{gcc_dir_version} \
        --with-newlib \
 %endif
        --disable-nls \
@@ -326,8 +333,12 @@ TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
 %else
        --program-suffix=%{binsuffix} \
        --enable-linux-futex \
+%ifarch ia64
+       --with-system-libunwind \
+%else
        --without-system-libunwind \
 %endif
+%endif
 %if "%{TARGET_ARCH}" == "armv5tel"
        --with-arch=armv5te \
        --with-float=soft \
@@ -335,15 +346,15 @@ TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
        --with-abi=aapcs-linux \
        --disable-sjlj-exceptions \
 %endif
-%if "%{TARGET_ARCH}" == "armv7el" 
+%if "%{TARGET_ARCH}" == "armv7l" 
        --with-arch=armv7-a \
        --with-tune=cortex-a9 \
-       --with-float=soft \
-       --with-abi=softfp \
-       --with-fpu=vfpv3 \
+       --with-float=hard \
+       --with-abi=aapcs-linux \
+       --with-fpu=vfpv3-d16 \
        --disable-sjlj-exceptions \
 %endif
-%if "%{TARGET_ARCH}" == "armv7l" || "%{TARGET_ARCH}" == "armv7hl"
+%if  "%{TARGET_ARCH}" == "armv7hl"
        --with-arch=armv7-a \
        --with-tune=cortex-a9 \
        --with-float=hard \
@@ -351,6 +362,22 @@ TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
        --with-fpu=vfpv3-d16 \
        --disable-sjlj-exceptions \
 %endif
+%if "%{TARGET_ARCH}" == "powerpc" || "%{TARGET_ARCH}" == "powerpc64"
+%if "%{TARGET_ARCH}" == "powerpc"
+       --with-cpu=default32 \
+%endif
+       --with-cpu-64=power4 \
+       --enable-secureplt \
+       --with-long-double-128 \
+%endif
+%if "%{TARGET_ARCH}" == "sparc64"
+       --with-cpu=ultrasparc \
+       --with-long-double-128 \
+%endif
+%if "%{TARGET_ARCH}" == "sparc"
+       --with-cpu=v8 \
+       --with-long-double-128 \
+%endif
 %if "%{TARGET_ARCH}" == "i586"
        --with-arch-32=i586 \
        --with-tune=generic \
@@ -359,10 +386,18 @@ TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
        --with-arch-32=i586 \
        --with-tune=generic \
 %endif
+%if "%{TARGET_ARCH}" == "s390"
+        --with-tune=z196 --with-arch=z10 \
+       --with-long-double-128 \
+       --enable-decimal-float \
+%endif
+%if "%{TARGET_ARCH}" == "s390x"
+        --with-tune=z196 --with-arch=z10 \
+       --with-long-double-128 \
+       --enable-decimal-float \
+%endif
        --build=%{GCCDIST}
 
-# COMMON-END
-# COMMON-END
 
 make %{?jobs:-j%jobs} all-gcc TARGET-gcc="cc1 cc1plus gcc-cross g++ native"
 
index a6653b5..fc75198 100644 (file)
@@ -53,9 +53,7 @@ BuildRequires: libunwind-devel
 ExclusiveArch: ppc ppc64 %ix86 ia64 
 %define _binary_payload w.ufdio
 
-# COMMON-BEGIN
-# COMMON-BEGIN
-%define biarch_targets x86_64 
+%define biarch_targets x86_64 s390x powerpc64 powerpc sparc sparc64
 
 URL:          http://gcc.gnu.org/
 Version: 4.8.1
@@ -64,27 +62,15 @@ Release:      1
 %define gcc_dir_version %(echo %gcc_version | cut -d '.' -f 1-2)
 %define snapshot_date %(echo %version | sed 's/[34]\.[0-9]\.[0-6]//' | sed 's/_/-/')
 %define binsuffix -4.8
-# COMMON-END
-# COMMON-BEGIN
 BuildRoot:     %{_tmppath}/%{name}-%{version}-build
-#Source:               gcc-%{gcc_version}%{snapshot_date}.tar.bz2
-Source:     gcc-%{version}.tar.bz2
-
+Source:                gcc-%{gcc_version}%{snapshot_date}.tar.bz2
 Source1:       change_spec
-Source2:       libgcj48-rpmlintrc
 Source3:       gcc48-rpmlintrc
 Source4:       ecj.jar
 Source6:       baselibs.conf
-# Patches auto-generated by git-buildpackage:
-Patch0:     0001-dir-version.patch
-Patch1:     0002-textdomain.patch
-Patch2:     0003-rename-info-files.patch
-Patch3:     0004-ARM-linker.patch
-
-# GCC-TESTSUITE-DELETE-BEGIN
-# LIBFFI-DELETE-BEGIN
-# LIBJAVA-DELETE-BEGIN
-Group:         Development/Toolchain
+
+
+Group:         Development/Languages/C and C++
 Summary:       The GNU C Compiler and Support Files
 License:        GPL-3.0+
 
@@ -98,8 +84,6 @@ gcc-obj-c++.
 
 
 
-# COMMON-END
-# COMMON-BEGIN
 
 # Define the canonical target and host architecture
 #   %gcc_target_arch  is supposed to be the full target triple
@@ -108,6 +92,12 @@ gcc-obj-c++.
 %if 0%{?gcc_target_arch:1}
 %define CONFIGURE_TARGET %{gcc_target_arch}
 %define TARGET_ARCH %(echo %{gcc_target_arch} | cut -d - -f 1 | sed -e "s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;")
+%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "powerpc"
+%define CONFIGURE_TARGET powerpc64-tizen-linux
+%endif
+%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "powerpc64"
+%define CONFIGURE_TARGET powerpc64-tizen-linux
+%endif
 %if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "i586"
 %define CONFIGURE_TARGET i586-tizen-linux
 %endif
@@ -117,11 +107,8 @@ gcc-obj-c++.
 %if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "armv7hl"
 %define CONFIGURE_TARGET armv7hl-tizen-linux-gnueabi
 %endif
-%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "armv7el"
-%define CONFIGURE_TARGET armv7el-tizen-linux-gnueabi
-%endif
-%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "armv5el"
-%define CONFIGURE_TARGET armv5el-tizen-linux-gnueabi
+%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "armv5tel"
+%define CONFIGURE_TARGET armv5tel-tizen-linux-gnueabi
 %endif
 %else
 %define TARGET_ARCH %(echo %{_target_cpu} | sed -e "s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;")
@@ -130,26 +117,39 @@ gcc-obj-c++.
 
 %define biarch %(case " %{biarch_targets} " in (*" %{TARGET_ARCH} "*) echo 1;; (*) echo 0;; esac)
 
+%ifarch ppc
+%define GCCDIST powerpc64-tizen-linux
+%else
+%ifarch %sparc
+%define GCCDIST sparc64-tizen-linux
+%else
 %ifarch %arm
 %define GCCDIST %{HOST_ARCH}-tizen-linux-gnueabi
 %else
 %define GCCDIST %{HOST_ARCH}-tizen-linux
 %endif
+%endif
+%endif
 
 %define libsubdir %{_libdir}/gcc/%{GCCDIST}/%{gcc_dir_version}
 %define gxxinclude %{_prefix}/include/c++/%{gcc_dir_version}
 
-# COMMON-END
-# COMMON-BEGIN
 
 %prep
-#%setup -q -n gcc-%{gcc_version}%{snapshot_date}
-%setup -q -n gcc-%{version}
-# 0001-dir-version.patch
-%patch0 -p1
-%patch1 -p1
-%patch2 -p1
-%patch3 -p1
+%setup -q -n gcc-%{gcc_version}%{snapshot_date}
+
+
+# We are configuring ppc as ppc64 but with switched multilibs.  Adjust
+# the libstdc++ abi testsuite baseline files accordingly
+%ifarch ppc
+if [ -d libstdc++-v3/config/abi/post/powerpc64-linux-gnu ]; then
+  mkdir -p libstdc++-v3/config/abi/post/powerpc64-linux-gnu/64
+  mv libstdc++-v3/config/abi/post/powerpc64-linux-gnu/baseline_symbols.txt \
+       libstdc++-v3/config/abi/post/powerpc64-linux-gnu/64/
+  mv libstdc++-v3/config/abi/post/powerpc64-linux-gnu/32/baseline_symbols.txt \
+       libstdc++-v3/config/abi/post/powerpc64-linux-gnu/
+fi
+%endif
 
 %build
 # Avoid rebuilding of generated files
@@ -180,6 +180,10 @@ RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-fno-rtti//g' -e 's/-fno-exceptions
 # default compiler settings now.
 RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-mcpu=i.86//g' -e 's/-march=i.86//g' -e 's/-mtune=i.86//g'`
 %endif
+%ifarch s390 s390x
+RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-fsigned-char//g'`
+RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-O1/-O2/g'`
+%endif
 %if 0%{?gcc_target_arch:1} && 0%{!?gcc_icecream:1}
 # Kill all -march/tune/cpu because that screws building the target libs
 RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-m\(arch\|tune\|cpu\)=[^ ]*//g'`
@@ -242,7 +246,7 @@ export _POSIX2_VERSION=199209
 # if glibc supports SSP.  When cross compiling we would need
 # to install a cross glibc, which we don't, or make the whole
 # thing point to the native glibc, which is in /, hence the
-# --with-sysroot=/
+# --with-build-sysroot=/
 
 %if %{build_ada}
 # Using the host gnatmake like
@@ -263,26 +267,27 @@ export PATH="`pwd`/host-tools/bin:$PATH"
 #      --enable-threads=posix \
 #%endif
 #      --enable-shared \
+%if "%{TARGET_ARCH}" == "armv7l" || "%{TARGET_ARCH}" == "armv7hl"
+# temporary workaround for a miscompilation of hash functions in java code
+GCJ_EXTRA_FLAGS="-marm"
+%endif
 CFLAGS="$RPM_OPT_FLAGS" CXXFLAGS="$RPM_OPT_FLAGS" XCFLAGS="$RPM_OPT_FLAGS" \
-TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
+TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS $GCJ_EXTRA_FLAGS" \
 ../configure \
        --prefix=%{_prefix} \
        --infodir=%{_infodir} \
        --mandir=%{_mandir} \
        --libdir=%{_libdir} \
        --libexecdir=%{_libdir} \
+    --disable-bootstrap \
        --enable-languages=$languages \
        $ENABLE_CHECKING \
        --with-gxx-include-dir=%{_prefix}/include/c++/%{gcc_dir_version} \
        --enable-ssp \
        --disable-libssp \
-       --disable-libitm \
-%if 0%{?fast_build}
-       --disable-bootstrap \
-%endif
        --disable-plugin \
        --with-bugurl="http://bugs.tizen.org/" \
-       --with-pkgversion="Tizen Linux" \
+       --with-pkgversion="Tizen" \
 %if !%{build_libjava}
         --disable-libgcj \
 %else
@@ -313,12 +318,14 @@ TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
 %if 0%{?canonical_target:1}
        --with-build-time-tools=/usr/%{canonical_target}-tizen-linux%{?canonical_target_abi:%canonical_target_abi}/bin \
 %endif
+%if 0%{?sysroot:1}
+       --with-sysroot=%sysroot \
+%endif
 %if 0%{?build_static:1}
        --disable-shared \
 %endif
 %if "%{TARGET_ARCH}" == "spu"
-       --with-sysroot=/usr/spu \
-       --with-gxx-include-dir=%{_prefix}/spu/include/c++/%{gcc_dir_version} \
+       --with-gxx-include-dir=%sysroot/include/c++/%{gcc_dir_version} \
        --with-newlib \
 %endif
        --disable-nls \
@@ -326,8 +333,12 @@ TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
 %else
        --program-suffix=%{binsuffix} \
        --enable-linux-futex \
+%ifarch ia64
+       --with-system-libunwind \
+%else
        --without-system-libunwind \
 %endif
+%endif
 %if "%{TARGET_ARCH}" == "armv5tel"
        --with-arch=armv5te \
        --with-float=soft \
@@ -335,15 +346,15 @@ TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
        --with-abi=aapcs-linux \
        --disable-sjlj-exceptions \
 %endif
-%if "%{TARGET_ARCH}" == "armv7el" 
+%if "%{TARGET_ARCH}" == "armv7l" 
        --with-arch=armv7-a \
        --with-tune=cortex-a9 \
-       --with-float=soft \
-       --with-abi=softfp \
-       --with-fpu=vfpv3 \
+       --with-float=hard \
+       --with-abi=aapcs-linux \
+       --with-fpu=vfpv3-d16 \
        --disable-sjlj-exceptions \
 %endif
-%if "%{TARGET_ARCH}" == "armv7l" || "%{TARGET_ARCH}" == "armv7hl"
+%if  "%{TARGET_ARCH}" == "armv7hl"
        --with-arch=armv7-a \
        --with-tune=cortex-a9 \
        --with-float=hard \
@@ -351,6 +362,22 @@ TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
        --with-fpu=vfpv3-d16 \
        --disable-sjlj-exceptions \
 %endif
+%if "%{TARGET_ARCH}" == "powerpc" || "%{TARGET_ARCH}" == "powerpc64"
+%if "%{TARGET_ARCH}" == "powerpc"
+       --with-cpu=default32 \
+%endif
+       --with-cpu-64=power4 \
+       --enable-secureplt \
+       --with-long-double-128 \
+%endif
+%if "%{TARGET_ARCH}" == "sparc64"
+       --with-cpu=ultrasparc \
+       --with-long-double-128 \
+%endif
+%if "%{TARGET_ARCH}" == "sparc"
+       --with-cpu=v8 \
+       --with-long-double-128 \
+%endif
 %if "%{TARGET_ARCH}" == "i586"
        --with-arch-32=i586 \
        --with-tune=generic \
@@ -359,10 +386,18 @@ TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
        --with-arch-32=i586 \
        --with-tune=generic \
 %endif
+%if "%{TARGET_ARCH}" == "s390"
+        --with-tune=z196 --with-arch=z10 \
+       --with-long-double-128 \
+       --enable-decimal-float \
+%endif
+%if "%{TARGET_ARCH}" == "s390x"
+        --with-tune=z196 --with-arch=z10 \
+       --with-long-double-128 \
+       --enable-decimal-float \
+%endif
        --build=%{GCCDIST}
 
-# COMMON-END
-# COMMON-END
 
 make %{?jobs:-j%jobs} all-gcc TARGET-gcc="cc1 cc1plus gcc-cross g++ native"
 
index c152d02..8af5c00 100644 (file)
@@ -1,23 +1,39 @@
-%define fast_build 1
+#
+# spec file for package gcc48
+#
+# Copyright (c) 2009 SUSE LINUX Products GmbH, Nuernberg, Germany.
+#
+# All modifications and additions to the file contributed by third parties
+# remain the property of their copyright owners, unless otherwise agreed
+# upon. The license for this file, and modifications and additions to the
+# file, is the same license as for the pristine package itself (unless the
+# license for the pristine package is not an Open Source License, in which
+# case the license is the MIT License). An "Open Source License" is a
+# license that conforms to the Open Source Definition (Version 1.9)
+# published by the Open Source Initiative.
+
+# Please submit bugfixes or comments via http://bugs.opensuse.org/
+#
+
+# norootforbuild
+# icecream 0
+
 
-# Ada currently fails to build on a few platforms, enable it only
-# on those that work
-# Note that AdaCore only supports %ix86, x86_64 and ia64
-%ifarch %ix86 x86_64
-%define build_ada !0%{?building_libjava:1}%{?building_libffi:1}
-%else
 %define build_ada 0
-%endif
 
-%define quadmath_arch %ix86 x86_64 
+%define quadmath_arch %ix86 x86_64 ia64
+%define tsan_arch x86_64
+%define asan_arch x86_64 %ix86 ppc ppc64
+%define itm_arch x86_64 %ix86 %arm ppc ppc64
+%define atomic_arch x86_64 %ix86 %arm ppc ppc64 s390 s390x
 
 # We don't want to build java
-%define build_java 1
-%define build_libjava 0%{?building_libjava:1}%{?building_libffi:1}%{?building_testsuite:1}
+%define build_java 0
+%define build_libjava 0
 
 %define build_cp 1
-%define build_fortran 1
-%define build_objc 1
+%define build_fortran !0%{?building_libjava:1}%{?building_libffi:1}
+%define build_objc !0%{?building_libjava:1}%{?building_libffi:1}
 %define build_objcp !0%{?building_libjava:1}%{?building_libffi:1}
 %define build_with_mudflap 0
 
 %endif
 
 # For optional compilers only build C, C++ and Fortran
-##%if 0%{?build_optional_compiler:1}%{?build_optional_compiler_languages:1}
-%if 0%{!?building_libffi:1}
+%if 0%{?build_optional_compiler_languages:1}
 %define build_ada 0
 %define build_java 0
 %define build_libjava 0
-%define build_objc 1
-%define build_objcp 1
+%define build_objc 0
+%define build_objcp 0
 %endif
 
+# Shared library SONAME versions
+%ifarch hppa
+%define libgcc_s 4
+%else
+%define libgcc_s 1
+%endif
+%define libgcj_sover 14
+%define libgcj_bc_sover 1
+%define libffi_sover 4
+%define libmudflap_sover 0
+%define libgomp_sover 1
+%define libstdcxx_sover 6
+%define libobjc_sover 4
+%define libgfortran_sover 3
+%define libquadmath_sover 0
+%define libasan_sover 0
+%define libtsan_sover 0
+%define libatomic_sover 1
+%define libitm_sover 1
+
+# Shared library package suffix
+# This is used for the "non-standard" set of libraries, the standard
+# being defined by %product_libs_gcc_ver, the GCC version that should
+# provide un-suffixed shared library packages following the shared-library
+# policy.  Even suffixed variants should provide the shared-library policy
+# mandated names and ensure they conflict with each other.
+# Note that on SONAME changes of any library the %product_libs_gcc_ver
+# define needs to be either split or the newest GCC version still providing
+# the old SONAME needs to unconditionally produce an un-suffixed library
+# if %product_libs_gcc_ver is newer than it.  Similar the _oldest_ GCC
+# version first providing a new SONAME needs to unconditionally produce
+# an un-suffixed library if %product_libs_gcc_ver is lower that it.
+%if %{!?product_libs_gcc_ver:@base_ver@}%{?product_libs_gcc_ver} != @base_ver@
+%define pne 1
+%endif
+%define libgcc_s_suffix %{?pne:-gcc@base_ver@}
+# libgcj SONAME changes with every GCC version
+%define libgcj_suffix %nil
+%define libgcj_bc_suffix %{?pne:-gcc@base_ver@}
+%define libffi_suffix %{?pne:-gcc@base_ver@}
+%define libmudflap_suffix %{?pne:-gcc@base_ver@}
+%define libgomp_suffix %{?pne:-gcc@base_ver@}
+%define libstdcxx_suffix %{?pne:-gcc@base_ver@}
+%define libobjc_suffix %{?pne:-gcc@base_ver@}
+%define libgfortran_suffix %{?pne:-gcc@base_ver@}
+%define libquadmath_suffix %{?pne:-gcc@base_ver@}
+%define libasan_suffix %{?pne:-gcc@base_ver@}
+%define libtsan_suffix %{?pne:-gcc@base_ver@}
+%define libatomic_suffix %{?pne:-gcc@base_ver@}
+%define libitm_suffix %{?pne:-gcc@base_ver@}
+
+
+
 
 Name:         gcc@base_ver@
+BuildRequires: gcc-c++
 BuildRequires: bison
 BuildRequires: flex
-BuildRequires: gettext-tools
-BuildRequires: makeinfo
 BuildRequires: glibc-devel-32bit
 BuildRequires: mpc-devel
 BuildRequires: mpfr-devel
 BuildRequires: perl
-BuildRequires: texinfo
+BuildRequires: makeinfo
 BuildRequires: zlib-devel
-%ifarch %ix86 x86_64 %arm
-BuildRequires: cloog-devel
-BuildRequires: ppl-devel
+%ifarch %ix86 x86_64 ppc ppc64 s390 s390x ia64 %sparc hppa %arm
+BuildRequires: cloog-isl-devel
+BuildRequires: isl-devel
 %endif
 %if %{build_ada}
-%define hostsuffix -4.8
-BuildRequires: gcc48-ada
+%define hostsuffix -4.7
+BuildRequires: gcc47-ada
 %endif
 %if 0%{?building_libjava:1}%{?building_testsuite:1}
 BuildRequires: fastjar
-BuildRequires: unzip
 %endif
 %if 0%{?building_libffi:1}
 BuildRequires: pkg-config
 %endif
+%ifarch ia64
+BuildRequires: libunwind-devel
+%endif
 %if 0%{?run_tests:1}
 BuildRequires: dejagnu
 BuildRequires: expect
 BuildRequires: gdb
 %endif
 
-# Define version number of libgcc_s
-%define libgcc_s 1
-%define build_nof 0
-
 %define separate_bi32 0
 %define separate_bi64 0
-%ifarch x86_64 
+%ifarch ppc sparcv9
+# Beware, this does _not_ separate libgcj, as for that one multilibing
+# is inactive for the time being
+%define separate_bi64 1
+%endif
+%ifarch x86_64 s390x ppc64 sparc64
 %define separate_bi32 1
 %endif
 
@@ -94,7 +164,7 @@ BuildRequires: gdb
 %define separate_biarch_suffix -64bit
 %endif
 
-%ifarch x86_64
+%ifarch x86_64 ia64 s390x alpha ppc64 sparc64
 # 64-bit is primary build target
 %define build_primary_64bit 1
 %else
@@ -104,7 +174,7 @@ BuildRequires: gdb
 %define biarch_libjava 0
 
 # COMMON-BEGIN
-%define biarch_targets x86_64 
+%define biarch_targets x86_64 s390x powerpc64 powerpc sparc sparc64
 
 URL:          http://gcc.gnu.org/
 Version: 4.8.1
@@ -118,39 +188,39 @@ Release:      1
 %if !0%{?building_libjava:1}%{?building_libffi:1}%{?building_testsuite:1}
 Requires: binutils glibc-devel
 Requires: cpp@base_ver@ = %{version}-%{release}
-%if 0%{!?build_optional_compiler:1}
-Requires: libgcc%{libgcc_s} >= %{version}-%{release}
-Requires: libgomp1 >= %{version}-%{release}
+Requires: libgcc_s%{libgcc_s} >= %{version}-%{release}
+Requires: libgomp%{libgomp_sover} >= %{version}-%{release}
 %if %{build_with_mudflap}
-Requires: libmudflap0 >= %{version}-%{release}
-Requires: libmudflapth0 >= %{version}-%{release}
+Requires: libmudflap%{libmudflap_sover} >= %{version}-%{release}
+Requires: libmudflapth%{libmudflap_sover} >= %{version}-%{release}
 %endif
-%else
-Requires: libgcc@base_ver@ = %{version}-%{release}
-Requires: libgomp@base_ver@ = %{version}-%{release}
+%ifarch %asan_arch
+Requires: libasan%{libasan_sover} >= %{version}-%{release}
+%endif
+%ifarch %tsan_arch
+Requires: libtsan%{libtsan_sover} >= %{version}-%{release}
+%endif
+%ifarch %atomic_arch
+Requires: libatomic%{libatomic_sover} >= %{version}-%{release}
+%endif
+%ifarch %itm_arch
+Requires: libitm%{libitm_sover} >= %{version}-%{release}
 %endif
+Suggests: gcc@base_ver@-info gcc@base_ver@-locale
 %endif
 
 # COMMON-BEGIN
 BuildRoot:     %{_tmppath}/%{name}-%{version}-build
-#Source:               gcc-%{gcc_version}%{snapshot_date}.tar.bz2
-Source:     gcc-%{version}.tar.bz2
-
+Source:                gcc-%{gcc_version}%{snapshot_date}.tar.bz2
 Source1:       change_spec
-Source2:       libgcj48-rpmlintrc
 Source3:       gcc48-rpmlintrc
 Source4:       ecj.jar
 Source6:       baselibs.conf
-# Patches auto-generated by git-buildpackage:
-Patch0:     0001-dir-version.patch
-Patch1:     0002-textdomain.patch
-Patch2:     0003-rename-info-files.patch
-Patch3:     0004-ARM-linker.patch
+
 
 # GCC-TESTSUITE-DELETE-BEGIN
-# LIBFFI-DELETE-BEGIN
 # LIBJAVA-DELETE-BEGIN
-Group:         Development/Toolchain
+Group:         Development/Languages/C and C++
 Summary:       The GNU C Compiler and Support Files
 License:        GPL-3.0+
 
@@ -161,24 +231,20 @@ frontend.
 Language frontends other than C are split to different sub-packages,
 namely gcc-ada, gcc-c++, gcc-fortran, gcc-java, gcc-objc and
 gcc-obj-c++.
+# LIBFFI-DELETE-BEGIN
 
 
 
 # COMMON-END
 %package -n gcc@base_ver@-32bit
 Summary:      The GNU C Compiler 32bit support
-Group:        Development/Toolchain
+Group:        Development/Languages/C and C++
 Requires: gcc@base_ver@ = %{version}-%{release}
-%if 0%{!?build_optional_compiler:1}
-Requires: libgcc%{libgcc_s}-32bit >= %{version}-%{release}
-Requires: libgomp1-32bit >= %{version}-%{release}
+Requires: libgcc_s%{libgcc_s}-32bit >= %{version}-%{release}
+Requires: libgomp%{libgomp_sover}-32bit >= %{version}-%{release}
 %if %{build_with_mudflap}
-Requires: libmudflap0-32bit >= %{version}-%{release}
-Requires: libmudflapth0-32bit >= %{version}-%{release}
-%endif
-%else
-Requires: libgcc@base_ver@-32bit = %{version}-%{release}
-Requires: libgomp@base_ver@-32bit = %{version}-%{release}
+Requires: libmudflap%{libmudflap_sover}-32bit >= %{version}-%{release}
+Requires: libmudflapth%{libmudflap_sover}-32bit >= %{version}-%{release}
 %endif
 Requires: glibc-devel-32bit
 
@@ -187,18 +253,13 @@ This package contains 32bit support for the GNU Compiler Collection.
 
 %package -n gcc@base_ver@-64bit
 Summary:      The GNU C Compiler 64bit support
-Group:        Development/Toolchain
+Group:        Development/Languages/C and C++
 Requires: gcc@base_ver@ = %{version}-%{release}
-%if 0%{!?build_optional_compiler:1}
-Requires: libgcc%{libgcc_s}-64bit >= %{version}-%{release}
-Requires: libgomp1-64bit >= %{version}-%{release}
+Requires: libgcc_s%{libgcc_s}-64bit >= %{version}-%{release}
+Requires: libgomp%{libgomp_sover}-64bit >= %{version}-%{release}
 %if %{build_with_mudflap}
-Requires: libmudflap0-64bit >= %{version}-%{release}
-Requires: libmudflapth0-64bit >= %{version}-%{release}
-%endif
-%else
-Requires: libgcc@base_ver@-64bit = %{version}-%{release}
-Requires: libgomp@base_ver@-64bit = %{version}-%{release}
+Requires: libmudflap%{libmudflap_sover}-64bit >= %{version}-%{release}
+Requires: libmudflapth%{libmudflap_sover}-64bit >= %{version}-%{release}
 %endif
 Requires: glibc-devel-64bit
 
@@ -209,7 +270,7 @@ This package contains 64bit support for the GNU Compiler Collection.
 %package locale
 Summary:      Locale Data for the GNU Compiler Collection
 License:        GPL-3.0+
-Group:        Development/Toolchain
+Group:        Development/Languages/C and C++
 Requires: gcc@base_ver@ = %{version}-%{release}
 
 %description locale
@@ -220,7 +281,7 @@ in the current locale.
 %package c++
 Summary:      The GNU C++ Compiler
 License:        GPL-3.0+
-Group:        Development/Toolchain
+Group:        Development/Languages/C and C++
 Requires: gcc@base_ver@ = %{version}-%{release}
 Requires: libstdc++@base_ver@-devel = %{version}-%{release}
 
@@ -231,13 +292,12 @@ This package contains the GNU compiler for C++.
 %package -n libstdc++@base_ver@-devel@variant@
 Summary:      Include Files and Libraries mandatory for Development
 License:        GPL-3.0-with-GCC-exception
-Group:        Development/Toolchain
-%if 0%{!?build_optional_compiler:1}
-Requires: libstdc++6@variant@ >= %{version}-%{release}
-%else
-Requires: libstdc++@base_ver@@variant@ = %{version}-%{release}
-%endif
+Group:        Development/Languages/C and C++
+Requires: libstdc++%{libstdcxx_sover}@variant@ >= %{version}-%{release}
 Requires: glibc-devel@variant@
+%ifarch ia64
+Requires: libunwind-devel
+%endif
 
 %description -n libstdc++@base_ver@-devel@variant@
 This package contains all the headers and libraries of the standard C++
@@ -247,7 +307,7 @@ library. It is needed for compiling C++ code.
 %package -n libstdc++@base_ver@-doc
 Summary:      Documentation for the GNU C++ standard library
 License:        GPL-3.0+
-Group:        Documentation
+Group:        Documentation/HTML
 BuildArch:    noarch
 
 %description -n libstdc++@base_ver@-doc
@@ -255,81 +315,76 @@ Extensive HTML documentation for the GNU C++ standard library.
 
 
 # PACKAGE-BEGIN
-%package -n libgcc@base_ver@@variant@
+%package -n libgcc_s%{libgcc_s}%{libgcc_s_suffix}@variant@
 Summary:      C compiler runtime library
 License:        GPL-3.0-with-GCC-exception
-Group:        Base/Libraries
-%if 0%{!?build_optional_compiler:1}
-Provides: libgcc%{libgcc_s}@variant@ = %{version}-%{release}
-Conflicts: libgcc%{libgcc_s}@variant@ < %{version}-%{release}
-%else
-Autoprov: no
-%endif
+Group:        System/Base
+Provides:      libgcc_s%{libgcc_s}@variant@ = %{version}-%{release}
 
-%description -n libgcc@base_ver@@variant@
+%description -n libgcc_s%{libgcc_s}%{libgcc_s_suffix}@variant@
 Libgcc is needed for dynamically linked C programs.
 
-%post -n libgcc@base_ver@@variant@
+%post -n libgcc_s%{libgcc_s}%{libgcc_s_suffix}@variant@
 /sbin/ldconfig
 
-%postun -n libgcc@base_ver@@variant@
+%postun -n libgcc_s%{libgcc_s}%{libgcc_s_suffix}@variant@
 /sbin/ldconfig
 # PACKAGE-END
 
 # PACKAGE-BEGIN
-%package -n libgomp@base_ver@@variant@
+%package -n libgomp%{libgomp_sover}%{libgomp_suffix}@variant@
 Summary:      The GNU compiler collection OpenMP runtime library
 License:        GPL-3.0-with-GCC-exception
-Group:        Base/Libraries
-%if 0%{!?build_optional_compiler:1}
-Provides: libgomp1@variant@ = %{version}-%{release}
-Conflicts: libgomp1@variant@ < %{version}-%{release}
-%else
-Autoprov: no
-%endif
+Group:        System/Base
+Provides:      libgomp%{libgomp_sover}@variant@ = %{version}-%{release}
 
-%description -n libgomp@base_ver@@variant@
+%description -n libgomp%{libgomp_sover}%{libgomp_suffix}@variant@
 This is the OpenMP runtime library needed by OpenMP enabled programs
 that were built with the -fopenmp compiler option and by programs that
 were auto-parallelized via the -ftree-parallelize-loops compiler
 option.
 
 
-%post -n libgomp@base_ver@@variant@
+%post -n libgomp%{libgomp_sover}%{libgomp_suffix}@variant@
 /sbin/ldconfig
 
-%postun -n libgomp@base_ver@@variant@
+%postun -n libgomp%{libgomp_sover}%{libgomp_suffix}@variant@
 /sbin/ldconfig
 # PACKAGE-END
 
 # PACKAGE-BEGIN
-%package -n libstdc++@base_ver@@variant@
+%package -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}@variant@
 Summary:      The standard C++ shared library
 License:        GPL-3.0-with-GCC-exception
-Group:        Base/Libraries
-%if 0%{!?build_optional_compiler:1}
-Provides: libstdc++6@variant@ = %{version}-%{release}
-Conflicts: libstdc++6@variant@ < %{version}-%{release}
-%else
-Autoprov: no
-%endif
+Group:        System/Libraries
+Suggests:      libstdc++%{libstdcxx_sover}-locale
+Provides:      libstdc++%{libstdcxx_sover}@variant@ = %{version}-%{release}
 
-%description -n libstdc++@base_ver@@variant@
+%description -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}@variant@
 The standard C++ library, needed for dynamically linked C++ programs.
 
 
-%post -n libstdc++@base_ver@@variant@
+%post -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}@variant@
 /sbin/ldconfig
 
-%postun -n libstdc++@base_ver@@variant@
+%postun -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}@variant@
 /sbin/ldconfig
 # PACKAGE-END
 
+%package -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}-locale
+Summary:       Locale Data for the standard C++ shared library
+License:       GPL-3.0-with-GCC-exception
+Group:         System/Libraries
+Provides:      libstdc++%{libstdcxx_sover}-locale = %{version}-%{release}
+
+%description -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}-locale
+The standard C++ library locale data.
+
 
 %package info
 Summary:      Documentation for the GNU compiler collection
 License:      GFDL-1.2
-Group:        Documentation
+Group:        Documentation/Other
 BuildArch:    noarch
 
 %description info
@@ -341,9 +396,9 @@ and internals documentation.
 %package objc@variant@
 Summary:      GNU Objective C Compiler
 License:        GPL-3.0+
-Group:        Development/Toolchain
+Group:        Development/Languages/Other
 Requires: gcc@base_ver@ = %{version}-%{release}
-Requires: libobjc2@variant@ >= %{version}-%{release}
+Requires: libobjc%{libobjc_sover}@variant@ >= %{version}-%{release}
 
 %description objc@variant@
 This package contains the GNU Objective C compiler. Objective C is an
@@ -352,27 +407,26 @@ Nextstep OS. The source code is available in the gcc package.
 # PACKAGE-END
 
 # PACKAGE-BEGIN
-%package -n libobjc@base_ver@@variant@
+%package -n libobjc%{libobjc_sover}%{libobjc_suffix}@variant@
 Summary:      Library for the GNU Objective C Compiler
 License:        GPL-3.0-with-GCC-exception
 Group:        Development/Libraries/Other
-Provides: libobjc2@variant@ = %{version}-%{release}
-Conflicts: libobjc2@variant@ < %{version}-%{release}
+Provides:      libobjc%{libobjc_sover}@variant@ = %{version}-%{release}
 
-%description -n libobjc@base_ver@@variant@
+%description -n libobjc%{libobjc_sover}%{libobjc_suffix}@variant@
 The library for the GNU Objective C compiler.
 
-%post -n libobjc@base_ver@@variant@
+%post -n libobjc%{libobjc_sover}%{libobjc_suffix}@variant@
 /sbin/ldconfig
 
-%postun -n libobjc@base_ver@@variant@
+%postun -n libobjc%{libobjc_sover}%{libobjc_suffix}@variant@
 /sbin/ldconfig
 # PACKAGE-END
 
 %package obj-c++
 Summary:      GNU Objective C++ Compiler
 License:        GPL-3.0+
-Group:        Development/Toolchain
+Group:        Development/Languages/Other
 Requires: gcc@base_ver@-objc = %{version}-%{release}
 Requires: gcc@base_ver@-c++ = %{version}-%{release}
 
@@ -385,7 +439,7 @@ Nextstep OS. The source code is available in the gcc package.
 %package -n cpp@base_ver@
 Summary:      The GCC Preprocessor
 License:        GPL-3.0+
-Group:        Development/Toolchain
+Group:        Development/Languages/C and C++
 
 %description -n cpp@base_ver@
 This Package contains just the preprocessor that is used by the X11
@@ -396,7 +450,7 @@ packages.
 %package ada@variant@
 Summary:      GNU Ada95 Compiler Based on GCC (GNAT)
 License:        GPL-3.0+
-Group:        Development/Toolchain
+Group:        Development/Languages/Other
 Requires: gcc@base_ver@@variant@ = %{version}-%{release}
 Requires: libada@base_ver@@variant@ = %{version}-%{release}
 
@@ -412,11 +466,6 @@ must have installed a binary version to bootstrap the compiler.
 Summary:      GNU Ada Runtime Libraries
 License:      GPL-3.0-with-GCC-exception
 Group:        System/Libraries
-Provides: libgnarl-4_8@variant@ = %{version}-%{release}
-Conflicts: libgnarl-4_8@variant@ < %{version}-%{release}
-Provides: libgnat-4_8@variant@ = %{version}-%{release}
-Conflicts: libgnat-4_8@variant@ < %{version}-%{release}
-
 %description -n libada@base_ver@@variant@
 This package contains the shared libraries required to run programs
 compiled with the GNU Ada compiler (GNAT) if they are compiled to use
@@ -438,16 +487,9 @@ Summary:      The GNU Fortran Compiler and Support Files
 License:        GPL-3.0+
 Group:        Development/Languages/Fortran
 Requires: gcc@base_ver@ = %{version}-%{release}
-%if 0%{!?build_optional_compiler:1}
-Requires: libgfortran3@variant@ >= %{version}-%{release}
-%ifarch %quadmath_arch
-Requires: libquadmath0@variant@ >= %{version}-%{release}
-%endif
-%else
-Requires: libgfortran@base_ver@@variant@ = %{version}-%{release}
+Requires: libgfortran%{libgfortran_sover}@variant@ >= %{version}-%{release}
 %ifarch %quadmath_arch
-Requires: libquadmath@base_ver@@variant@ = %{version}-%{release}
-%endif
+Requires: libquadmath%{libquadmath_sover}@variant@ >= %{version}-%{release}
 %endif
 
 %description fortran@variant@
@@ -455,55 +497,42 @@ This is the Fortran compiler of the GNU Compiler Collection (GCC).
 # PACKAGE-END
 
 # PACKAGE-BEGIN
-%package -n libgfortran@base_ver@@variant@
+%package -n libgfortran%{libgfortran_sover}%{libgfortran_suffix}@variant@
 Summary:      The GNU Fortran Compiler Runtime Library
 License:        GPL-3.0-with-GCC-exception
 Group:        Development/Languages/Fortran
-%if 0%{!?build_optional_compiler:1}
-Provides: libgfortran3@variant@ = %{version}-%{release}
-Conflicts: libgfortran3@variant@ < %{version}-%{release}
-%ifarch %quadmath_arch
-Requires: libquadmath0@variant@ >= %{version}-%{release}
-%endif
-%else
 %ifarch %quadmath_arch
-Requires: libquadmath@base_ver@@variant@ = %{version}-%{release}
-%endif
-Autoprov: no
+Requires: libquadmath%{libquadmath_sover}@variant@ >= %{version}-%{release}
 %endif
+Provides:      libgfortran%{libgfortran_sover}@variant@ = %{version}-%{release}
 
-%description -n libgfortran@base_ver@@variant@
+%description -n libgfortran%{libgfortran_sover}%{libgfortran_suffix}@variant@
 The runtime library needed to run programs compiled with the Fortran compiler
 of the GNU Compiler Collection (GCC).
 
-%post -n libgfortran@base_ver@@variant@
+%post -n libgfortran%{libgfortran_sover}%{libgfortran_suffix}@variant@
 /sbin/ldconfig
 
-%postun -n libgfortran@base_ver@@variant@
+%postun -n libgfortran%{libgfortran_sover}%{libgfortran_suffix}@variant@
 /sbin/ldconfig
 # PACKAGE-END
 
 # PACKAGE-BEGIN
-%package -n libquadmath@base_ver@@variant@
+%package -n libquadmath%{libquadmath_sover}%{libquadmath_suffix}@variant@
 Summary:      The GNU Fortran Compiler Quadmath Runtime Library
 License:        LGPL-2.1
 Group:        Development/Languages/Fortran
-%if 0%{!?build_optional_compiler:1}
-Provides: libquadmath0@variant@ = %{version}-%{release}
-Conflicts: libquadmath0@variant@ < %{version}-%{release}
-%else
-Autoprov: no
-%endif
+Provides:      libquadmath%{libquadmath_sover}@variant@ = %{version}-%{release}
 
-%description -n libquadmath@base_ver@@variant@
+%description -n libquadmath%{libquadmath_sover}%{libquadmath_suffix}@variant@
 The runtime library needed to run programs compiled with the Fortran compiler
 of the GNU Compiler Collection (GCC) and quadruple precision floating point
 operations.
 
-%post -n libquadmath@base_ver@@variant@
+%post -n libquadmath%{libquadmath_sover}%{libquadmath_suffix}@variant@
 /sbin/ldconfig
 
-%postun -n libquadmath@base_ver@@variant@
+%postun -n libquadmath%{libquadmath_sover}%{libquadmath_suffix}@variant@
 /sbin/ldconfig
 # PACKAGE-END
 
@@ -511,11 +540,7 @@ operations.
 %package -n libmudflap@base_ver@@variant@
 Summary:      The Mudflap Extension Runtime Library
 License:        GPL-3.0-with-GCC-exception
-Group:        Development/Toolchain
-Provides: libmudflap0@variant@ = %{version}-%{release}
-Conflicts: libmudflap0@variant@ < %{version}-%{release}
-Provides: libmudflapth0@variant@ = %{version}-%{release}
-Conflicts: libmudflapth0@variant@ < %{version}-%{release}
+Group:        Development/Languages/C and C++
 
 %description -n libmudflap@base_ver@@variant@
 This is the Mudflap Extension Runtime Library.
@@ -527,19 +552,79 @@ This is the Mudflap Extension Runtime Library.
 /sbin/ldconfig
 # PACKAGE-END
 
+# PACKAGE-BEGIN
+%package -n libitm%{libitm_sover}%{libitm_suffix}@variant@
+Summary:      The GNU Compiler Transactional Memory Runtime Library
+License:        MIT
+Group:        Development/Languages/C and C++
+
+%description -n libitm%{libitm_sover}%{libitm_suffix}@variant@
+The runtime library needed to run programs compiled with the
+-fgnu-tm option of the GNU Compiler Collection (GCC).
+
+%post -n libitm%{libitm_sover}%{libitm_suffix}@variant@
+/sbin/ldconfig
+
+%postun -n libitm%{libitm_sover}%{libitm_suffix}@variant@
+/sbin/ldconfig
+# PACKAGE-END
+
+# PACKAGE-BEGIN
+%package -n libasan%{libasan_sover}%{libasan_suffix}@variant@
+Summary:      The GNU Compiler Address Sanitizer Runtime Library
+License:        MIT
+Group:        Development/Languages/C and C++
+
+%description -n libasan%{libasan_sover}%{libasan_suffix}@variant@
+The runtime library needed to run programs compiled with the
+-fsanitize=address option of the GNU Compiler Collection (GCC).
+
+%post -n libasan%{libasan_sover}%{libasan_suffix}@variant@
+/sbin/ldconfig
+
+%postun -n libasan%{libasan_sover}%{libasan_suffix}@variant@
+/sbin/ldconfig
+# PACKAGE-END
+
+# PACKAGE-BEGIN
+%package -n libtsan%{libtsan_sover}%{libtsan_suffix}@variant@
+Summary:      The GNU Compiler Thread Sanitizer Runtime Library
+License:        MIT
+Group:        Development/Languages/C and C++
+
+%description -n libtsan%{libtsan_sover}%{libtsan_suffix}@variant@
+The runtime library needed to run programs compiled with the
+-fsanitize=thread option of the GNU Compiler Collection (GCC).
+
+%post -n libtsan%{libtsan_sover}%{libtsan_suffix}@variant@
+/sbin/ldconfig
+
+%postun -n libtsan%{libtsan_sover}%{libtsan_suffix}@variant@
+/sbin/ldconfig
+# PACKAGE-END
+
+# PACKAGE-BEGIN
+%package -n libatomic%{libatomic_sover}%{libatomic_suffix}@variant@
+Summary:      The GNU Compiler Atomic Operations Runtime Library
+License:      GPL-3.0-with-GCC-exception
+Group:        Development/Languages/C and C++
+
+%description -n libatomic%{libatomic_sover}%{libatomic_suffix}@variant@
+The runtime library for atomic operations of the GNU Compiler Collection (GCC).
+
+%post -n libatomic%{libatomic_sover}%{libatomic_suffix}@variant@
+/sbin/ldconfig
+
+%postun -n libatomic%{libatomic_sover}%{libatomic_suffix}@variant@
+/sbin/ldconfig
+# PACKAGE-END
+
 
 %package -n libgcj@base_ver@
 # LIBJAVA-DELETE-END
 Summary:      Java Runtime Library for gcc
 License:      GPL-2.0-with-classpath-exception
 Group:        System/Libraries
-%define gcj_sover 13
-Provides: libgcj%{gcj_sover} = %{version}-%{release}
-Conflicts: libgcj%{gcj_sover} < %{version}-%{release}
-Provides: libgij%{gcj_sover} = %{version}-%{release}
-Conflicts: libgij%{gcj_sover} < %{version}-%{release}
-Provides: libgcj-tools%{gcj_sover} = %{version}-%{release}
-Conflicts: libgcj-tools%{gcj_sover} < %{version}-%{release}
 
 %description -n libgcj@base_ver@
 This library is needed if you want to use the GNU Java compiler, gcj.
@@ -555,7 +640,7 @@ Source code for this package is in gcc.
 %package -n gcc@base_ver@-java
 Summary:      The GNU Java Compiler
 License:        GPL-3.0+
-Group:        Development/Languages
+Group:        Development/Languages/Java
 Requires: gcc@base_ver@ = %{version}
 Requires: libgcj@base_ver@-devel = %{version}-%{release}
 
@@ -563,24 +648,21 @@ Requires: libgcj@base_ver@-devel = %{version}-%{release}
 The Java compiler from the GCC-tools-suite.
 
 
-%package -n libgcj_bc@base_ver@
+%package -n libgcj_bc%{libgcj_bc_sover}%{libgcj_bc_suffix}
 Summary:      Fake library for BC-ABI compatibility.
 License:        GPL-2.0-with-classpath-exception
-Group:        Development/Libraries
-Provides: libgcj_bc1 = %{version}-%{release}
-Conflicts: libgcj_bc1 < %{version}-%{release}
+Group:        Development/Libraries/Java
 # libgcj_bc is special in that it just contains a symlink to
 # a proper libgcj version.  So require that library and add
 # provides for the shlib version as created at link time
-Requires: libgcj%{gcj_sover}
-%ifarch x86_64 
-Provides: libgcj_bc.so.1()(64bit)
+Requires: libgcj%{libgcj_sover} >= %{version}-%{release}
+%ifarch x86_64 ia64 ppc64 s390x sparc64 aarch64
+Provides: libgcj_bc.so.%{libgcj_bc_sover}()(64bit)
 %else
-Provides: libgcj_bc.so.1
+Provides: libgcj_bc.so.%{libgcj_bc_sover}
 %endif
 
-
-%description -n libgcj_bc@base_ver@
+%description -n libgcj_bc%{libgcj_bc_sover}%{libgcj_bc_suffix}
 A fake library that is used at link time only. It ensures that
 binaries built with the BC-ABI link against a constant SONAME.
 This way, BC-ABI binaries continue to work if the SONAME underlying
@@ -599,15 +681,18 @@ These are the jar files that go along with the gcj front end to gcc.
 %package -n libgcj@base_ver@-devel
 Summary:      Include Files and Libraries mandatory for Development.
 License:        GPL-2.0-with-classpath-exception
-Group:        Development/Libraries
+Group:        Development/Libraries/Java
 Requires: libstdc++@base_ver@-devel = %{version}
-Requires: libgcj%{gcj_sover} >= %{version}-%{release}
-Requires: libgcj_bc1 >= %{version}-%{release}
+Requires: libgcj%{libgcj_sover} >= %{version}-%{release}
+Requires: libgcj_bc%{libgcj_bc_sover} >= %{version}-%{release}
 Requires: libgcj@base_ver@-jar = %{version}-%{release}
 Requires: gtk2-devel
 Requires: libart_lgpl-devel
 Requires: glibc-devel
 Requires: zlib-devel
+%ifarch ia64
+Requires: libunwind-devel
+%endif
 
 %description -n libgcj@base_ver@-devel
 This package contains all necessary include files and libraries needed
@@ -617,29 +702,26 @@ to develop applications that require these.
 %package -n gcc@base_ver@-gij
 Summary:      Java Bytecode Interpreter for gcc
 License:      GPL-2.0-with-classpath-exception
-Group:        Development/Libraries
-Requires: libgcj%{gcj_sover} >= %{version}-%{release}
+Group:        Development/Libraries/Java
+Requires: libgcj%{libgcj_sover} >= %{version}-%{release}
 
 %description -n gcc@base_ver@-gij
 This package contains the java bytecode interpreter gij and related tools.
 
 # LIBFFI-DELETE-END
 # PACKAGE-BEGIN
-%package -n libffi@base_ver@@variant@
+%package -n libffi%{libffi_sover}%{libffi_suffix}@variant@
 Summary:      Foreign Function Interface library
 License:        BSD-3-Clause
-Group:        Base/Libraries
-Provides: g-wrap:/usr/lib/libffi.so.4
-Provides: libffi4@variant@ = %{version}-%{release}
-Conflicts: libffi4@variant@ < %{version}-%{release}
+Group:        Development/Languages/C and C++
 
-%description -n libffi@base_ver@@variant@
+%description -n libffi%{libffi_sover}%{libffi_suffix}@variant@
 A foreign function interface is the popular name for the interface that allows code written in one language to call code written in another language.
 
-%post -n libffi@base_ver@@variant@
+%post -n libffi%{libffi_sover}%{libffi_suffix}@variant@
 /sbin/ldconfig
 
-%postun -n libffi@base_ver@@variant@
+%postun -n libffi%{libffi_sover}%{libffi_suffix}@variant@
 /sbin/ldconfig
 # PACKAGE-END
 
@@ -647,10 +729,8 @@ A foreign function interface is the popular name for the interface that allows c
 %package -n libffi@base_ver@-devel@variant@
 Summary:      Foreign Function Interface library development files
 License:        BSD 3-Clause
-Group:        Development/Toolchain
-Requires: libffi4@variant@ >= %{version}-%{release}
-Provides: libffi-devel@variant@ = %{version}-%{release}
-Conflicts: libffi-devel@variant@ < %{version}-%{release}
+Group:        Development/Languages/C and C++
+Requires: libffi%{libffi_sover}@variant@ >= %{version}-%{release}
 
 %description -n libffi@base_ver@-devel@variant@
 A foreign function interface is the popular name for the interface that allows code written in one language to call code written in another language.
@@ -659,8 +739,8 @@ A foreign function interface is the popular name for the interface that allows c
 %package -n gcc@base_ver@-testresults
 # GCC-TESTSUITE-DELETE-END
 Summary:      Testsuite results
-License:       Public-Domain
-Group:        Development/Toolchain
+License:       SUSE-Public-Domain
+Group:        Development/Languages/C and C++
 
 %description -n gcc@base_ver@-testresults
 Results from running the gcc and target library testsuites.
@@ -675,6 +755,12 @@ Results from running the gcc and target library testsuites.
 %if 0%{?gcc_target_arch:1}
 %define CONFIGURE_TARGET %{gcc_target_arch}
 %define TARGET_ARCH %(echo %{gcc_target_arch} | cut -d - -f 1 | sed -e "s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;")
+%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "powerpc"
+%define CONFIGURE_TARGET powerpc64-tizen-linux
+%endif
+%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "powerpc64"
+%define CONFIGURE_TARGET powerpc64-tizen-linux
+%endif
 %if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "i586"
 %define CONFIGURE_TARGET i586-tizen-linux
 %endif
@@ -684,11 +770,8 @@ Results from running the gcc and target library testsuites.
 %if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "armv7hl"
 %define CONFIGURE_TARGET armv7hl-tizen-linux-gnueabi
 %endif
-%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "armv7el"
-%define CONFIGURE_TARGET armv7el-tizen-linux-gnueabi
-%endif
-%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "armv5el"
-%define CONFIGURE_TARGET armv5el-tizen-linux-gnueabi
+%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "armv5tel"
+%define CONFIGURE_TARGET armv5tel-tizen-linux-gnueabi
 %endif
 %else
 %define TARGET_ARCH %(echo %{_target_cpu} | sed -e "s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;")
@@ -697,11 +780,19 @@ Results from running the gcc and target library testsuites.
 
 %define biarch %(case " %{biarch_targets} " in (*" %{TARGET_ARCH} "*) echo 1;; (*) echo 0;; esac)
 
+%ifarch ppc
+%define GCCDIST powerpc64-tizen-linux
+%else
+%ifarch %sparc
+%define GCCDIST sparc64-tizen-linux
+%else
 %ifarch %arm
 %define GCCDIST %{HOST_ARCH}-tizen-linux-gnueabi
 %else
 %define GCCDIST %{HOST_ARCH}-tizen-linux
 %endif
+%endif
+%endif
 
 %define libsubdir %{_libdir}/gcc/%{GCCDIST}/%{gcc_dir_version}
 %define gxxinclude %{_prefix}/include/c++/%{gcc_dir_version}
@@ -712,29 +803,24 @@ Results from running the gcc and target library testsuites.
 %define versmainlibdir %{libsubdir}
 %define versmainlibdirbi32 %{libsubdir}/32
 %define versmainlibdirbi64 %{libsubdir}/64
+%ifarch ppc
+%define versmainlibdirbi32 %{libsubdir}
+%define versmainlibdirbi64 %{libsubdir}/64
+%endif
 %if %{build_primary_64bit}
 %define versmainlibdirbi %{versmainlibdirbi32}
 %else
 %define versmainlibdirbi %{versmainlibdirbi64}
 %endif
 
-%if 0%{?build_optional_compiler:1}
-%define mainlibdir %{versmainlibdir}
-%define mainlibdirbi32 %{versmainlibdirbi32}
-%define mainlibdirbi64 %{versmainlibdirbi64}
-%define noflibdir %{versnoflibdir}
-%define mainlibdirbi %{versmainlibdirbi}
-%else
 %define mainlibdir %{_libdir}
 %define mainlibdirbi32 %{_prefix}/lib
 %define mainlibdirbi64 %{_prefix}/lib64
-%define noflibdir %{_prefix}/lib/nof
 %if %{build_primary_64bit}
 %define mainlibdirbi %{mainlibdirbi32}
 %else
 %define mainlibdirbi %{mainlibdirbi64}
 %endif
-%endif
 
 
 # Now define a few macros that make it easy to package libs and
@@ -742,88 +828,52 @@ Results from running the gcc and target library testsuites.
 # exact path the files are in.
 #   %mainlib  package X from all dirs that belong to the main package
 #   %biarchlib   package X from all dirs that belong to the -32/64bit package
-# by default, nof libs go where the 32bit libs go.
-%if %{build_nof}
 %define mainlib() %{mainlibdir}/%1\
-%{noflibdir}/%1\
 %{nil}
-%else
-%define mainlib() %{mainlibdir}/%1\
-%{nil}
-%endif
 %define biarchlib() %{nil}
 %if %{biarch}
 %if !%{separate_biarch}
-%if %{build_nof}
 %define mainlib() %{mainlibdir}/%1\
 %{mainlibdirbi}/%1\
-%{noflibdir}/%1\
-%{nil}
-%else
-%define mainlib() %{mainlibdir}/%1\
-%{mainlibdirbi}/%1\
-%{nil}
-%endif
-%else
-%if %{build_nof}
-%define biarchlib() %{mainlibdirbi}/%1\
-%{noflibdir}/%1\
-%{nil}
-%define mainlib() %{mainlibdir}/%1\
 %{nil}
 %else
 %define biarchlib() %{mainlibdirbi}/%1\
 %{nil}
 %endif
 %endif
-%endif
 
-%if %{build_nof}
 %define versmainlib() %{versmainlibdir}/%1\
-%{versnoflibdir}/%1\
 %{nil}
-%else
-%define versmainlib() %{versmainlibdir}/%1\
-%{nil}
-%endif
 %define versbiarchlib() %{nil}
 %if %{biarch}
 %if !%{separate_biarch}
-%if %{build_nof}
 %define versmainlib() %{versmainlibdir}/%1\
 %{versmainlibdirbi}/%1\
-%{versnoflibdir}/%1\
-%{nil}
-%else
-%define versmainlib() %{versmainlibdir}/%1\
-%{versmainlibdirbi}/%1\
-%{nil}
-%endif
-%else
-%if %{build_nof}
-%define versbiarchlib() %{versmainlibdirbi}/%1\
-%{versnoflibdir}/%1\
-%{nil}
-%define versmainlib() %{versmainlibdir}/%1\
 %{nil}
 %else
 %define versbiarchlib() %{versmainlibdirbi}/%1\
 %{nil}
 %endif
 %endif
-%endif
 
 
 # COMMON-BEGIN
 
 %prep
-#%setup -q -n gcc-%{gcc_version}%{snapshot_date}
-%setup -q -n gcc-%{version}
-# 0001-dir-version.patch
-%patch0 -p1
-%patch1 -p1
-%patch2 -p1
-%patch3 -p1
+%setup -q -n gcc-%{gcc_version}%{snapshot_date}
+
+
+# We are configuring ppc as ppc64 but with switched multilibs.  Adjust
+# the libstdc++ abi testsuite baseline files accordingly
+%ifarch ppc
+if [ -d libstdc++-v3/config/abi/post/powerpc64-linux-gnu ]; then
+  mkdir -p libstdc++-v3/config/abi/post/powerpc64-linux-gnu/64
+  mv libstdc++-v3/config/abi/post/powerpc64-linux-gnu/baseline_symbols.txt \
+       libstdc++-v3/config/abi/post/powerpc64-linux-gnu/64/
+  mv libstdc++-v3/config/abi/post/powerpc64-linux-gnu/32/baseline_symbols.txt \
+       libstdc++-v3/config/abi/post/powerpc64-linux-gnu/
+fi
+%endif
 
 %build
 # Avoid rebuilding of generated files
@@ -854,6 +904,10 @@ RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-fno-rtti//g' -e 's/-fno-exceptions
 # default compiler settings now.
 RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-mcpu=i.86//g' -e 's/-march=i.86//g' -e 's/-mtune=i.86//g'`
 %endif
+%ifarch s390 s390x
+RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-fsigned-char//g'`
+RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-O1/-O2/g'`
+%endif
 %if 0%{?gcc_target_arch:1} && 0%{!?gcc_icecream:1}
 # Kill all -march/tune/cpu because that screws building the target libs
 RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-m\(arch\|tune\|cpu\)=[^ ]*//g'`
@@ -916,7 +970,7 @@ export _POSIX2_VERSION=199209
 # if glibc supports SSP.  When cross compiling we would need
 # to install a cross glibc, which we don't, or make the whole
 # thing point to the native glibc, which is in /, hence the
-# --with-sysroot=/
+# --with-build-sysroot=/
 
 %if %{build_ada}
 # Using the host gnatmake like
@@ -937,26 +991,27 @@ export PATH="`pwd`/host-tools/bin:$PATH"
 #      --enable-threads=posix \
 #%endif
 #      --enable-shared \
+%if "%{TARGET_ARCH}" == "armv7l" || "%{TARGET_ARCH}" == "armv7hl"
+# temporary workaround for a miscompilation of hash functions in java code
+GCJ_EXTRA_FLAGS="-marm"
+%endif
 CFLAGS="$RPM_OPT_FLAGS" CXXFLAGS="$RPM_OPT_FLAGS" XCFLAGS="$RPM_OPT_FLAGS" \
-TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
+TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS $GCJ_EXTRA_FLAGS" \
 ../configure \
        --prefix=%{_prefix} \
        --infodir=%{_infodir} \
        --mandir=%{_mandir} \
        --libdir=%{_libdir} \
        --libexecdir=%{_libdir} \
+    --disable-bootstrap \
        --enable-languages=$languages \
        $ENABLE_CHECKING \
        --with-gxx-include-dir=%{_prefix}/include/c++/%{gcc_dir_version} \
        --enable-ssp \
        --disable-libssp \
-       --disable-libitm \
-%if 0%{?fast_build}
-       --disable-bootstrap \
-%endif
        --disable-plugin \
        --with-bugurl="http://bugs.tizen.org/" \
-       --with-pkgversion="Tizen Linux" \
+       --with-pkgversion="Tizen" \
 %if !%{build_libjava}
         --disable-libgcj \
 %else
@@ -987,12 +1042,14 @@ TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
 %if 0%{?canonical_target:1}
        --with-build-time-tools=/usr/%{canonical_target}-tizen-linux%{?canonical_target_abi:%canonical_target_abi}/bin \
 %endif
+%if 0%{?sysroot:1}
+       --with-sysroot=%sysroot \
+%endif
 %if 0%{?build_static:1}
        --disable-shared \
 %endif
 %if "%{TARGET_ARCH}" == "spu"
-       --with-sysroot=/usr/spu \
-       --with-gxx-include-dir=%{_prefix}/spu/include/c++/%{gcc_dir_version} \
+       --with-gxx-include-dir=%sysroot/include/c++/%{gcc_dir_version} \
        --with-newlib \
 %endif
        --disable-nls \
@@ -1000,8 +1057,12 @@ TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
 %else
        --program-suffix=%{binsuffix} \
        --enable-linux-futex \
+%ifarch ia64
+       --with-system-libunwind \
+%else
        --without-system-libunwind \
 %endif
+%endif
 %if "%{TARGET_ARCH}" == "armv5tel"
        --with-arch=armv5te \
        --with-float=soft \
@@ -1009,15 +1070,15 @@ TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
        --with-abi=aapcs-linux \
        --disable-sjlj-exceptions \
 %endif
-%if "%{TARGET_ARCH}" == "armv7el" 
+%if "%{TARGET_ARCH}" == "armv7l" 
        --with-arch=armv7-a \
        --with-tune=cortex-a9 \
-       --with-float=soft \
-       --with-abi=softfp \
-       --with-fpu=vfpv3 \
+       --with-float=hard \
+       --with-abi=aapcs-linux \
+       --with-fpu=vfpv3-d16 \
        --disable-sjlj-exceptions \
 %endif
-%if "%{TARGET_ARCH}" == "armv7l" || "%{TARGET_ARCH}" == "armv7hl"
+%if  "%{TARGET_ARCH}" == "armv7hl"
        --with-arch=armv7-a \
        --with-tune=cortex-a9 \
        --with-float=hard \
@@ -1025,6 +1086,22 @@ TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
        --with-fpu=vfpv3-d16 \
        --disable-sjlj-exceptions \
 %endif
+%if "%{TARGET_ARCH}" == "powerpc" || "%{TARGET_ARCH}" == "powerpc64"
+%if "%{TARGET_ARCH}" == "powerpc"
+       --with-cpu=default32 \
+%endif
+       --with-cpu-64=power4 \
+       --enable-secureplt \
+       --with-long-double-128 \
+%endif
+%if "%{TARGET_ARCH}" == "sparc64"
+       --with-cpu=ultrasparc \
+       --with-long-double-128 \
+%endif
+%if "%{TARGET_ARCH}" == "sparc"
+       --with-cpu=v8 \
+       --with-long-double-128 \
+%endif
 %if "%{TARGET_ARCH}" == "i586"
        --with-arch-32=i586 \
        --with-tune=generic \
@@ -1033,6 +1110,16 @@ TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
        --with-arch-32=i586 \
        --with-tune=generic \
 %endif
+%if "%{TARGET_ARCH}" == "s390"
+        --with-tune=z196 --with-arch=z10 \
+       --with-long-double-128 \
+       --enable-decimal-float \
+%endif
+%if "%{TARGET_ARCH}" == "s390x"
+        --with-tune=z196 --with-arch=z10 \
+       --with-long-double-128 \
+       --enable-decimal-float \
+%endif
        --build=%{GCCDIST}
 
 # COMMON-END
@@ -1041,15 +1128,11 @@ TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
 make stage1-bubble $PARALLEL
 make all-target-libffi $PARALLEL
 %else
+STAGE1_FLAGS="-g"
 # Only run profiled bootstrap on archs where it works
-#%ifarch %ix86 x86_64 
-#make profiledbootstrap-lean STAGE1_CFLAGS="-O -g" BOOT_CFLAGS="$RPM_OPT_FLAGS" $PARALLEL
+#%ifarch %ix86 x86_64 ppc ppc64 ia64
+#make profiledbootstrap-lean STAGE1_CFLAGS="$STAGE1_FLAGS" BOOT_CFLAGS="$RPM_OPT_FLAGS" $PARALLEL
 #%else
-%ifarch %arm
-STAGE1_FLAGS="-O0"
-%else
-STAGE1_FLAGS="-O -g"
-%endif
 #make bootstrap-lean STAGE1_CFLAGS="$STAGE1_FLAGS" BOOT_CFLAGS="$RPM_OPT_FLAGS" $PARALLEL
 make STAGE1_CFLAGS="$STAGE1_FLAGS" BOOT_CFLAGS="$RPM_OPT_FLAGS" $PARALLEL
 #%endif
@@ -1060,6 +1143,8 @@ echo "Run testsuite"
 (make -C %{GCCDIST}/libstdc++-v3 check-abi || true)
 mv %{GCCDIST}/libstdc++-v3/testsuite/libstdc++.log %{GCCDIST}/libstdc++-v3/testsuite/libstdc++-abi.log
 mv %{GCCDIST}/libstdc++-v3/testsuite/libstdc++.sum %{GCCDIST}/libstdc++-v3/testsuite/libstdc++-abi.sum
+# asan needs a whole shadow address space
+ulimit -v unlimited || true
 make -k check $PARALLEL || true
 mkdir ../testresults
 ../contrib/test_summary | tee ../testresults/test_summary.txt
@@ -1114,11 +1199,13 @@ rm -f $RPM_BUILD_ROOT%{libsubdir}/include/ffitarget.h
 rm -f $RPM_BUILD_ROOT%{_mandir}/man3/ffi%{binsuffix}.3*
 rm -f $RPM_BUILD_ROOT%{_mandir}/man3/ffi_call%{binsuffix}.3*
 rm -f $RPM_BUILD_ROOT%{_mandir}/man3/ffi_prep_cif%{binsuffix}.3*
+rm -f $RPM_BUILD_ROOT%{_mandir}/man3/ffi_prep_cif_var%{binsuffix}.3*
 %endif
 
 # Remove some useless .la files
 for lib in libobjc libgfortran libgfortranbegin libquadmath libcaf_single \
-    libmudflap libmudflapth libgomp libstdc++ libsupc++ libgcj-tools libgij; do
+    libmudflap libmudflapth libgomp libstdc++ libsupc++ libgcj-tools libgij \
+    libasan libatomic libitm libtsan; do
   rm -f $RPM_BUILD_ROOT%{versmainlibdir}/$lib.la
 %if %{biarch}
   rm -f $RPM_BUILD_ROOT%{versmainlibdirbi}/$lib.la
@@ -1183,7 +1270,6 @@ fi
 %endif
 # LIBJAVA-DELETE-END
 
-%if 0%{!?build_optional_compiler:1}
 # move shared libs from versionspecific dir to main libdir
 for libname in \
 %if 0%{?building_libjava:1}
@@ -1202,6 +1288,18 @@ for libname in \
   libstdc++ \
 %endif
   libgomp \
+%ifarch %atomic_arch
+  libatomic \
+%endif
+%ifarch %itm_arch
+  libitm \
+%endif
+%ifarch %asan_arch
+  libasan \
+%endif
+%ifarch %tsan_arch
+  libtsan \
+%endif
 %if %{build_with_mudflap}
   libmudflap libmudflapth \
 %endif
@@ -1222,6 +1320,12 @@ for libname in \
   fi
 %endif
 done
+# FIXME, tsan is not multilib
+%ifarch %tsan_arch
+%if %{biarch}
+rm -f $RPM_BUILD_ROOT%{versmainlibdirbi}/libtsan.so
+%endif
+%endif
 %if %{build_cp}
 %if !0%{?building_libjava:1}
 # And we want to move the shlib gdb pretty printers to a more sane
@@ -1245,18 +1349,16 @@ sed -i -e '/^libdir/s/\/gcc\/%{GCCDIST}\/%{gcc_dir_version}//g' $RPM_BUILD_ROOT%
 for lib in `find $RPM_BUILD_ROOT%{versmainlibdir} -maxdepth 1 -name libgcj_bc.so.*`; do
   rm $lib
 done
-ln -s libgcj.so.%{gcj_sover} $RPM_BUILD_ROOT%{mainlibdir}/libgcj_bc.so.1
+ln -s libgcj.so.%{libgcj_sover} $RPM_BUILD_ROOT%{mainlibdir}/libgcj_bc.so.%{libgcj_bc_sover}
 %if %{biarch_libjava}
 for lib in `find $RPM_BUILD_ROOT%{versmainlibdirbi} -maxdepth 1 -name libgcj_bc.so.*`; do
   rm $lib
 done
-ln -s libgcj.so.%{gcj_sover} $RPM_BUILD_ROOT%{mainlibdirbi}/libgcj_bc.so.1
-%endif
+ln -s libgcj.so.%{libgcj_sover} $RPM_BUILD_ROOT%{mainlibdirbi}/libgcj_bc.so.%{libgcj_bc_sover}
 %endif
 %endif
 
 # LIBJAVA-DELETE-BEGIN
-%if 0%{!?build_optional_compiler:1}
 # Move libgcc_s around
 if test -L $RPM_BUILD_ROOT/%{_lib}/libgcc_s.so; then
   rm -f $RPM_BUILD_ROOT/%{_lib}/libgcc_s.so
@@ -1287,49 +1389,7 @@ ln -sf %{versmainlibdirbi64}/libgcc_s.so $RPM_BUILD_ROOT%{versmainlibdirbi64}/li
 chmod a+x $RPM_BUILD_ROOT/lib64/libgcc_s.so.%{libgcc_s}
 %endif
 %endif
-%else
-# Move libgcc_s around
-mv $RPM_BUILD_ROOT/%{_lib}/libgcc_s.so.%{libgcc_s} $RPM_BUILD_ROOT%{versmainlibdir}/
-if test -L $RPM_BUILD_ROOT/%{_lib}/libgcc_s.so; then
-  rm -f $RPM_BUILD_ROOT/%{_lib}/libgcc_s.so
-  ln -sf %{versmainlibdir}/libgcc_s.so.%{libgcc_s} $RPM_BUILD_ROOT%{versmainlibdir}/libgcc_s.so
-else
-  mv $RPM_BUILD_ROOT/%{_lib}/libgcc_s.so $RPM_BUILD_ROOT%{versmainlibdir}/
-fi
-chmod a+x $RPM_BUILD_ROOT%{versmainlibdir}/libgcc_s.so.%{libgcc_s}
-%if %{biarch}
-%if %{build_primary_64bit}
-mv $RPM_BUILD_ROOT/lib/libgcc_s.so.%{libgcc_s} $RPM_BUILD_ROOT%{versmainlibdirbi32}/
-if test -L $RPM_BUILD_ROOT/lib/libgcc_s.so; then
-  rm -f $RPM_BUILD_ROOT/lib/libgcc_s.so
-  ln -sf %{versmainlibdirbi32}/libgcc_s.so.%{libgcc_s} $RPM_BUILD_ROOT%{versmainlibdirbi32}/libgcc_s.so
-else
-  mv $RPM_BUILD_ROOT/lib/libgcc_s.so $RPM_BUILD_ROOT%{versmainlibdirbi32}/
-fi
-ln -sf %{versmainlibdirbi32}/libgcc_s.so $RPM_BUILD_ROOT%{versmainlibdirbi32}/libgcc_s_32.so
-chmod a+x $RPM_BUILD_ROOT%{versmainlibdirbi32}/libgcc_s.so.%{libgcc_s}
-%else
-# 32-bit biarch systems
-mv $RPM_BUILD_ROOT/lib64/libgcc_s.so.%{libgcc_s} $RPM_BUILD_ROOT%{versmainlibdirbi64}/
-if test -L $RPM_BUILD_ROOT/lib64/libgcc_s.so; then
-  rm -f $RPM_BUILD_ROOT/lib64/libgcc_s.so
-  ln -sf %{versmainlibdirbi64}/libgcc_s.so.%{libgcc_s} $RPM_BUILD_ROOT%{versmainlibdirbi64}/libgcc_s.so
-else
-  mv $RPM_BUILD_ROOT/lib64/libgcc_s.so $RPM_BUILD_ROOT%{versmainlibdirbi64}/
-fi
-ln -sf %{versmainlibdirbi64}/libgcc_s.so $RPM_BUILD_ROOT%{versmainlibdirbi64}/libgcc_s_64.so
-chmod a+x $RPM_BUILD_ROOT%{versmainlibdirbi64}/libgcc_s.so.%{libgcc_s}
-%endif
-%endif
-%endif
 
-# Provide a defaults.spec file which adds a proper rpath
-%if 0%{?build_optional_compiler:1}
-cat > $RPM_BUILD_ROOT%{libsubdir}/defaults.spec << EOF
-*link:
-+ %%{!m32:%%{!m64:-rpath=%{libsubdir}}} %%{m32:-rpath=%{libsubdir}/32} %%{m64:-rpath=%{libsubdir}/64}
-EOF
-%endif
 # LIBJAVA-DELETE-END
 # LIBFFI-DELETE-END
 
@@ -1419,6 +1479,9 @@ crt32_list=$RPM_BUILD_ROOT%{versmainlibdirbi32}/crt*.o
 crt64_list=$RPM_BUILD_ROOT%{versmainlibdirbi64}/crt*.o
 %endif
 %endif
+for o in $crt_list $crt32_list $crt64_list; do
+  objcopy -R ".comment.SUSE.OPTs" $o
+done
 %endif
 
 %if 0%{?building_libjava:1}
@@ -1472,9 +1535,6 @@ rm -f $RPM_BUILD_ROOT%{_mandir}/man7/fsf-funding.7
 rm -f $RPM_BUILD_ROOT%{_mandir}/man7/gfdl.7
 rm -f $RPM_BUILD_ROOT%{_mandir}/man7/gpl.7
 rm -f $RPM_BUILD_ROOT%{_libdir}/libiberty.a
-%if %{build_nof}
-rm -f $RPM_BUILD_ROOT%{_prefix}/lib/nof/libiberty.a
-%endif
 %if %{biarch}
 %if %{build_primary_64bit}
 rm -f $RPM_BUILD_ROOT%{_prefix}/lib/libiberty.a
@@ -1498,6 +1558,9 @@ cp $RPM_SOURCE_DIR/ecj.jar $RPM_BUILD_ROOT%{libsubdir}
 # For regular build, some info files do not get renamed properly.
 # Do so here.
 mv $RPM_BUILD_ROOT%{_infodir}/libgomp.info $RPM_BUILD_ROOT%{_infodir}/libgomp%{binsuffix}.info
+%ifarch %itm_arch
+mv $RPM_BUILD_ROOT%{_infodir}/libitm.info $RPM_BUILD_ROOT%{_infodir}/libitm%{binsuffix}.info
+%endif
 %if %{build_fortran} 
 %ifarch %quadmath_arch
 mv $RPM_BUILD_ROOT%{_infodir}/libquadmath.info $RPM_BUILD_ROOT%{_infodir}/libquadmath%{binsuffix}.info
@@ -1512,7 +1575,10 @@ mv $RPM_BUILD_ROOT%{_infodir}/gnat_ugn.info $RPM_BUILD_ROOT%{_infodir}/gnat_ugn%
 
 # LIBJAVA-DELETE-BEGIN
 cd ..
-%find_lang gcc@base_ver@-locale --all-name
+%find_lang cpplib%{binsuffix}
+%find_lang gcc%{binsuffix}
+cat cpplib%{binsuffix}.lang gcc%{binsuffix}.lang > gcc@base_ver@-locale.lang
+
 
 %post info
 %install_info --info-dir=%{_infodir} %{_infodir}/cpp%{binsuffix}.info.gz
@@ -1533,7 +1599,7 @@ cd ..
 %if %{build_ada}
 %install_info --info-dir=%{_infodir} %{_infodir}/gnat-style%{binsuffix}.info.gz
 %install_info --info-dir=%{_infodir} %{_infodir}/gnat_rm%{binsuffix}.info.gz
-%install_info --info-dir=%{_infodir} --section="GNU Ada tools" --entry="* GNAT User's Guide: (gnat_ugn). GNAT User's Guide for Unix Platforms" %{_infodir}/gnat_ugn%{binsuffix}.info.gz
+%install_info --info-dir=%{_infodir} %{_infodir}/gnat_ugn%{binsuffix}.info.gz
 %endif
 
 %postun info
@@ -1558,9 +1624,7 @@ cd ..
 %install_info_delete --info-dir=%{_infodir} %{_infodir}/gnat_ugn%{binsuffix}.info.gz
 %endif
 
-
 %files
-%license COPYING  COPYING3  COPYING3.LIB  COPYING.LIB  COPYING.RUNTIME
 %defattr(-,root,root)
 %dir %{_libdir}/gcc
 %dir %{_libdir}/gcc/%{GCCDIST}
@@ -1574,9 +1638,6 @@ cd ..
 %dir %{libsubdir}/64
 %endif
 %endif
-%if %{build_nof}
-%dir %{libsubdir}/nof
-%endif
 %{_prefix}/bin/gcc%{binsuffix}
 %{_prefix}/bin/gcov%{binsuffix}
 %{_prefix}/bin/gcc-ar%{binsuffix}
@@ -1602,6 +1663,25 @@ cd ..
 %{libsubdir}/include/stdint-gcc.h
 %{libsubdir}/include/stdnoreturn.h
 %{libsubdir}/include/stdalign.h
+%ifarch %sparc
+%{libsubdir}/include/visintrin.h
+%endif
+%ifarch ppc ppc64
+%{libsubdir}/include/altivec.h
+%{libsubdir}/include/ppc-asm.h
+%{libsubdir}/include/paired.h
+%{libsubdir}/include/ppu_intrinsics.h
+%{libsubdir}/include/si2vmx.h
+%{libsubdir}/include/spe.h
+%{libsubdir}/include/spu2vmx.h
+%{libsubdir}/include/vec_types.h
+%endif
+%ifarch ia64
+%{libsubdir}/include/ia64intrin.h
+%endif
+%ifarch aarch64
+%{libsubdir}/include/arm_neon.h
+%endif
 %ifarch %arm
 %{libsubdir}/include/mmintrin.h
 %{libsubdir}/include/arm_neon.h
@@ -1637,6 +1717,14 @@ cd ..
 %{libsubdir}/include/fmaintrin.h
 %{libsubdir}/include/lzcntintrin.h
 %{libsubdir}/include/f16cintrin.h
+%{libsubdir}/include/adxintrin.h
+%{libsubdir}/include/fxsrintrin.h
+%{libsubdir}/include/prfchwintrin.h
+%{libsubdir}/include/rdseedintrin.h
+%{libsubdir}/include/rtmintrin.h
+%{libsubdir}/include/xsaveintrin.h
+%{libsubdir}/include/xsaveoptintrin.h
+%{libsubdir}/include/xtestintrin.h
 %endif
 %if %{build_with_mudflap}
 %{libsubdir}/include/mf-runtime.h
@@ -1654,11 +1742,26 @@ cd ..
 %versmainlib libgomp.so
 %versmainlib libgomp.a
 %versmainlib libgomp.spec
+%ifarch %itm_arch
+%versmainlib libitm.so
+%versmainlib libitm.a
+%versmainlib libitm.spec
+%endif
+%ifarch %atomic_arch
+%versmainlib libatomic.so
+%versmainlib libatomic.a
+%endif
+%ifarch %asan_arch
+%versmainlib libasan.so
+%versmainlib libasan.a
+%versmainlib libasan_preinit.o
+%endif
+%ifarch %tsan_arch
+%versmainlib libtsan.so
+%versmainlib libtsan.a
+%endif
 %doc %{_mandir}/man1/gcc%{binsuffix}.1.gz
 %doc %{_mandir}/man1/gcov%{binsuffix}.1.gz
-%if 0%{?build_optional_compiler:1}
-%{libsubdir}/defaults.spec
-%endif
 
 %if %{separate_biarch}
 %files -n gcc@base_ver@%{separate_biarch_suffix}
@@ -1676,10 +1779,32 @@ cd ..
 %versbiarchlib libgomp.so
 %versbiarchlib libgomp.a
 %versbiarchlib libgomp.spec
+%ifarch %itm_arch
+%versbiarchlib libitm.so
+%versbiarchlib libitm.a
+%versbiarchlib libitm.spec
+%endif
+%ifarch %atomic_arch
+%versbiarchlib libatomic.a
+%versbiarchlib libatomic.so
+%endif
+%ifarch %asan_arch
+%versbiarchlib libasan.a
+%versbiarchlib libasan.so
+%versbiarchlib libasan_preinit.o
+%endif
+%if 0
+%ifarch %tsan_arch
+%versbiarchlib libtsan.a
+%versbiarchlib libtsan.so
+%endif
+%endif
 %endif
 
 %files locale -f gcc@base_ver@-locale.lang
 
+%files -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}-locale
+
 %if %{build_cp}
 %files c++
 %defattr(-,root,root)
@@ -1690,17 +1815,14 @@ cd ..
 %doc %{_mandir}/man1/g++%{binsuffix}.1.gz
 %{libsubdir}/cc1plus
 
-%files -n libstdc++@base_ver@
+%files -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}
 %defattr(-,root,root)
-%if %{build_nof}
-%dir %{noflibdir}
-%endif
-%mainlib libstdc++.so.*
+%mainlib libstdc++.so.%{libstdcxx_sover}*
 
 %if %{separate_biarch}
-%files -n libstdc++@base_ver@%{separate_biarch_suffix}
+%files -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}%{separate_biarch_suffix}
 %defattr(-,root,root)
-%biarchlib libstdc++.so.*
+%biarchlib libstdc++.so.%{libstdcxx_sover}*
 %endif
 
 %files -n libstdc++@base_ver@-devel -f c++-headers
@@ -1730,14 +1852,9 @@ cd ..
 %doc libstdc++-v3/doc/html
 %endif
 
-%files -n libgcc@base_ver@
+%files -n libgcc_s%{libgcc_s}%{libgcc_s_suffix}
 %defattr(-,root,root)
-%if 0%{!?build_optional_compiler:1}
 /%{_lib}/libgcc_s.so.%{libgcc_s}
-%if %{build_nof}
-%dir /lib/nof
-/lib/nof/libgcc_s.so.%{libgcc_s}
-%endif
 %if %{biarch}
 %if %{build_primary_64bit}
 %if !%{separate_bi32}
@@ -1749,40 +1866,84 @@ cd ..
 %endif
 %endif
 %endif
-%else
-%versmainlib libgcc_s.so.%{libgcc_s}
-%endif
 
 %if %{separate_bi64}
-%files -n libgcc@base_ver@-64bit
+%files -n libgcc_s%{libgcc_s}%{libgcc_s_suffix}-64bit
 %defattr(-,root,root)
-%if 0%{!?build_optional_compiler:1}
 /lib64/libgcc_s.so.%{libgcc_s}
-%else
-%versbiarchlib libgcc_s.so.%{libgcc_s}
-%endif
 %endif
 
 %if %{separate_bi32}
-%files -n libgcc@base_ver@-32bit
+%files -n libgcc_s%{libgcc_s}%{libgcc_s_suffix}-32bit
 %defattr(-,root,root)
-%if 0%{!?build_optional_compiler:1}
 /lib/libgcc_s.so.%{libgcc_s}
-%else
-%versbiarchlib libgcc_s.so.%{libgcc_s}
+%endif
+
+
+%files -n libgomp%{libgomp_sover}%{libgomp_suffix}
+%defattr(-,root,root)
+%mainlib libgomp.so.%{libgomp_sover}*
+
+%if %{separate_biarch}
+%files -n libgomp%{libgomp_sover}%{libgomp_suffix}%{separate_biarch_suffix}
+%defattr(-,root,root)
+%biarchlib libgomp.so.%{libgomp_sover}*
+%endif
+
+
+%ifarch %asan_arch
+%files -n libasan%{libasan_sover}%{libasan_suffix}
+%defattr(-,root,root)
+%mainlib libasan.so.%{libasan_sover}*
+
+%if %{separate_biarch}
+%files -n libasan%{libasan_sover}%{libasan_suffix}%{separate_biarch_suffix}
+%defattr(-,root,root)
+%biarchlib libasan.so.%{libasan_sover}*
 %endif
 %endif
 
 
-%files -n libgomp@base_ver@
+%ifarch %tsan_arch
+%files -n libtsan%{libtsan_sover}%{libtsan_suffix}
 %defattr(-,root,root)
-%mainlib libgomp.so.1*
+%mainlib libtsan.so.%{libtsan_sover}*
 
+%if 0
 %if %{separate_biarch}
-%files -n libgomp@base_ver@%{separate_biarch_suffix}
+%files -n libtsan%{libtsan_sover}%{libtsan_suffix}%{separate_biarch_suffix}
 %defattr(-,root,root)
-%biarchlib libgomp.so.1*
+%biarchlib libtsan.so.%{libtsan_sover}*
+%endif
 %endif
+%endif
+
+
+%ifarch %atomic_arch
+%files -n libatomic%{libatomic_sover}%{libatomic_suffix}
+%defattr(-,root,root)
+%mainlib libatomic.so.%{libatomic_sover}*
+
+%if %{separate_biarch}
+%files -n libatomic%{libatomic_sover}%{libatomic_suffix}%{separate_biarch_suffix}
+%defattr(-,root,root)
+%biarchlib libatomic.so.%{libatomic_sover}*
+%endif
+%endif
+
+
+%ifarch %itm_arch
+%files -n libitm%{libitm_sover}%{libitm_suffix}
+%defattr(-,root,root)
+%mainlib libitm.so.%{libitm_sover}*
+
+%if %{separate_biarch}
+%files -n libitm%{libitm_sover}%{libitm_suffix}%{separate_biarch_suffix}
+%defattr(-,root,root)
+%biarchlib libitm.so.%{libitm_sover}*
+%endif
+%endif
+
 
 
 %if %{build_fortran}
@@ -1819,25 +1980,25 @@ cd ..
 %endif
 %endif
 
-%files -n libgfortran@base_ver@
+%files -n libgfortran%{libgfortran_sover}%{libgfortran_suffix}
 %defattr(-,root,root)
-%mainlib libgfortran.so.*
+%mainlib libgfortran.so.%{libgfortran_sover}*
 
 %if %{separate_biarch}
-%files -n libgfortran@base_ver@%{separate_biarch_suffix}
+%files -n libgfortran%{libgfortran_sover}%{libgfortran_suffix}%{separate_biarch_suffix}
 %defattr(-,root,root)
-%biarchlib libgfortran.so.*
+%biarchlib libgfortran.so.%{libgfortran_sover}*
 %endif
 
 %ifarch %quadmath_arch
-%files -n libquadmath@base_ver@
+%files -n libquadmath%{libquadmath_sover}%{libquadmath_suffix}
 %defattr(-,root,root)
-%mainlib libquadmath.so.*
+%mainlib libquadmath.so.%{libquadmath_sover}*
 
 %if %{separate_biarch}
-%files -n libquadmath@base_ver@%{separate_biarch_suffix}
+%files -n libquadmath%{libquadmath_sover}%{libquadmath_suffix}%{separate_biarch_suffix}
 %defattr(-,root,root)
-%biarchlib libquadmath.so.*
+%biarchlib libquadmath.so.%{libquadmath_sover}*
 %endif
 %endif
 %endif
@@ -1845,14 +2006,14 @@ cd ..
 %if %{build_with_mudflap}
 %files -n libmudflap@base_ver@
 %defattr(-,root,root)
-%mainlib libmudflap.so.0*
-%mainlib libmudflapth.so.0*
+%mainlib libmudflap.so.%{libmudflap_sover}*
+%mainlib libmudflapth.so.%{libmudflap_sover}*
 
 %if %{separate_biarch}
 %files -n libmudflap@base_ver@%{separate_biarch_suffix}
 %defattr(-,root,root)
-%biarchlib libmudflap.so.0*
-%biarchlib libmudflapth.so.0*
+%biarchlib libmudflap.so.%{libmudflap_sover}*
+%biarchlib libmudflapth.so.%{libmudflap_sover}*
 %endif
 %endif
 
@@ -1885,14 +2046,14 @@ cd ..
 %versbiarchlib libobjc.so
 %endif
 
-%files -n libobjc@base_ver@
+%files -n libobjc%{libobjc_sover}%{libobjc_suffix}
 %defattr(-,root,root)
-%mainlib libobjc.so.*
+%mainlib libobjc.so.%{libobjc_sover}*
 
 %if %{separate_biarch}
-%files -n libobjc@base_ver@%{separate_biarch_suffix}
+%files -n libobjc%{libobjc_sover}%{libobjc_suffix}%{separate_biarch_suffix}
 %defattr(-,root,root)
-%biarchlib libobjc.so.*
+%biarchlib libobjc.so.%{libobjc_sover}*
 %endif
 %endif
 
@@ -1978,11 +2139,11 @@ cd ..
 %if %{build_libjava}
 %files -n libgcj@base_ver@
 %defattr(-,root,root)
-%dir %{_libdir}/gcj-%{gcc_dir_version}-%{gcj_sover}
+%dir %{_libdir}/gcj-%{gcc_dir_version}-%{libgcj_sover}
 %dir %{_libdir}/gcc
 %dir %{_libdir}/gcc/%{GCCDIST}
 %dir %{libsubdir}
-%{_libdir}/gcj-%{gcc_dir_version}-%{gcj_sover}/classmap.db
+%{_libdir}/gcj-%{gcc_dir_version}-%{libgcj_sover}/classmap.db
 # We usually do not multilib libjava
 %if %{biarch_libjava}
 %versbiarchlib libgcj.la
@@ -1995,17 +2156,17 @@ cd ..
 %mainlib libgij.so.*
 %mainlib libgcj-tools.so.*
 %endif
-%{_libdir}/gcj-%{gcc_dir_version}-%{gcj_sover}/libjvm.la
-%{_libdir}/gcj-%{gcc_dir_version}-%{gcj_sover}/libjvm.so
-%{_libdir}/gcj-%{gcc_dir_version}-%{gcj_sover}/libjavamath.la
-%{_libdir}/gcj-%{gcc_dir_version}-%{gcj_sover}/libjavamath.so
+%{_libdir}/gcj-%{gcc_dir_version}-%{libgcj_sover}/libjvm.la
+%{_libdir}/gcj-%{gcc_dir_version}-%{libgcj_sover}/libjvm.so
+%{_libdir}/gcj-%{gcc_dir_version}-%{libgcj_sover}/libjavamath.la
+%{_libdir}/gcj-%{gcc_dir_version}-%{libgcj_sover}/libjavamath.so
 
-%files -n libgcj_bc@base_ver@
+%files -n libgcj_bc%{libgcj_bc_sover}%{libgcj_bc_suffix}
 %defattr(-,root,root)
 %if %{biarch_libjava}
-%biarchlib libgcj_bc.so.*
+%biarchlib libgcj_bc.so.%{libgcj_bc_sover}*
 %else
-%mainlib libgcj_bc.so.*
+%mainlib libgcj_bc.so.%{libgcj_bc_sover}*
 %endif
 
 %files -n libgcj@base_ver@-jar
@@ -2080,16 +2241,21 @@ cd ..
 
 %if %{build_java}
 %if 0%{?building_libffi:1}
-%files -n libffi@base_ver@
+%files -n libffi%{libffi_sover}%{libffi_suffix}
 %defattr(-,root,root)
-%mainlib libffi.so.*
+%mainlib libffi.so.%{libffi_sover}*
 
 %if %{separate_biarch}
-%files -n libffi@base_ver@%{separate_biarch_suffix}
+%files -n libffi%{libffi_sover}%{libffi_suffix}%{separate_biarch_suffix}
 %defattr(-,root,root)
-%biarchlib libffi.so.*
+%biarchlib libffi.so.%{libffi_sover}*
 %endif
 
+%post -n libffi@base_ver@-devel
+%install_info --info-dir=%{_infodir} %{_infodir}/libffi%{binsuffix}.info.gz
+%postun -n libffi@base_ver@-devel
+%install_info_delete --info-dir=%{_infodir} %{_infodir}/libffi%{binsuffix}.info.gz
+
 %files -n libffi@base_ver@-devel
 %defattr(-,root,root)
 %{_prefix}/include/ffi.h
@@ -2097,9 +2263,11 @@ cd ..
 %mainlib libffi.so
 %mainlib libffi.a
 %{_libdir}/pkgconfig/libffi.pc
+%doc %{_infodir}/libffi%{binsuffix}.info.gz
 %doc %{_mandir}/man3/ffi%{binsuffix}.3.gz
 %doc %{_mandir}/man3/ffi_call%{binsuffix}.3.gz
 %doc %{_mandir}/man3/ffi_prep_cif%{binsuffix}.3.gz
+%doc %{_mandir}/man3/ffi_prep_cif_var%{binsuffix}.3.gz
 
 %if %{separate_biarch}
 %files -n libffi@base_ver@-devel%{separate_biarch_suffix}
index 832999b..e3d04cc 100644 (file)
@@ -1,25 +1,41 @@
 %define building_testsuite 1
 %define run_tests 1
-%define fast_build 1
+#
+# spec file for package gcc48
+#
+# Copyright (c) 2009 SUSE LINUX Products GmbH, Nuernberg, Germany.
+#
+# All modifications and additions to the file contributed by third parties
+# remain the property of their copyright owners, unless otherwise agreed
+# upon. The license for this file, and modifications and additions to the
+# file, is the same license as for the pristine package itself (unless the
+# license for the pristine package is not an Open Source License, in which
+# case the license is the MIT License). An "Open Source License" is a
+# license that conforms to the Open Source Definition (Version 1.9)
+# published by the Open Source Initiative.
+
+# Please submit bugfixes or comments via http://bugs.opensuse.org/
+#
+
+# norootforbuild
+# icecream 0
+
 
-# Ada currently fails to build on a few platforms, enable it only
-# on those that work
-# Note that AdaCore only supports %ix86, x86_64 and ia64
-%ifarch %ix86 x86_64
-%define build_ada !0%{?building_libjava:1}%{?building_libffi:1}
-%else
 %define build_ada 0
-%endif
 
-%define quadmath_arch %ix86 x86_64 
+%define quadmath_arch %ix86 x86_64 ia64
+%define tsan_arch x86_64
+%define asan_arch x86_64 %ix86 ppc ppc64
+%define itm_arch x86_64 %ix86 %arm ppc ppc64
+%define atomic_arch x86_64 %ix86 %arm ppc ppc64 s390 s390x
 
 # We don't want to build java
-%define build_java 1
-%define build_libjava 0%{?building_libjava:1}%{?building_libffi:1}%{?building_testsuite:1}
+%define build_java 0
+%define build_libjava 0
 
 %define build_cp 1
-%define build_fortran 1
-%define build_objc 1
+%define build_fortran !0%{?building_libjava:1}%{?building_libffi:1}
+%define build_objc !0%{?building_libjava:1}%{?building_libffi:1}
 %define build_objcp !0%{?building_libjava:1}%{?building_libffi:1}
 %define build_with_mudflap 0
 
 %endif
 
 # For optional compilers only build C, C++ and Fortran
-##%if 0%{?build_optional_compiler:1}%{?build_optional_compiler_languages:1}
-%if 0%{!?building_libffi:1}
+%if 0%{?build_optional_compiler_languages:1}
 %define build_ada 0
 %define build_java 0
 %define build_libjava 0
-%define build_objc 1
-%define build_objcp 1
+%define build_objc 0
+%define build_objcp 0
+%endif
+
+# Shared library SONAME versions
+%ifarch hppa
+%define libgcc_s 4
+%else
+%define libgcc_s 1
 %endif
+%define libgcj_sover 14
+%define libgcj_bc_sover 1
+%define libffi_sover 4
+%define libmudflap_sover 0
+%define libgomp_sover 1
+%define libstdcxx_sover 6
+%define libobjc_sover 4
+%define libgfortran_sover 3
+%define libquadmath_sover 0
+%define libasan_sover 0
+%define libtsan_sover 0
+%define libatomic_sover 1
+%define libitm_sover 1
+
+# Shared library package suffix
+# This is used for the "non-standard" set of libraries, the standard
+# being defined by %product_libs_gcc_ver, the GCC version that should
+# provide un-suffixed shared library packages following the shared-library
+# policy.  Even suffixed variants should provide the shared-library policy
+# mandated names and ensure they conflict with each other.
+# Note that on SONAME changes of any library the %product_libs_gcc_ver
+# define needs to be either split or the newest GCC version still providing
+# the old SONAME needs to unconditionally produce an un-suffixed library
+# if %product_libs_gcc_ver is newer than it.  Similar the _oldest_ GCC
+# version first providing a new SONAME needs to unconditionally produce
+# an un-suffixed library if %product_libs_gcc_ver is lower that it.
+%if %{!?product_libs_gcc_ver:48}%{?product_libs_gcc_ver} != 48
+%define pne 1
+%endif
+%define libgcc_s_suffix %{?pne:-gcc48}
+# libgcj SONAME changes with every GCC version
+%define libgcj_suffix %nil
+%define libgcj_bc_suffix %{?pne:-gcc48}
+%define libffi_suffix %{?pne:-gcc48}
+%define libmudflap_suffix %{?pne:-gcc48}
+%define libgomp_suffix %{?pne:-gcc48}
+%define libstdcxx_suffix %{?pne:-gcc48}
+%define libobjc_suffix %{?pne:-gcc48}
+%define libgfortran_suffix %{?pne:-gcc48}
+%define libquadmath_suffix %{?pne:-gcc48}
+%define libasan_suffix %{?pne:-gcc48}
+%define libtsan_suffix %{?pne:-gcc48}
+%define libatomic_suffix %{?pne:-gcc48}
+%define libitm_suffix %{?pne:-gcc48}
+
+
 
 
 Name: gcc48-testresults
+BuildRequires: gcc-c++
 BuildRequires: bison
 BuildRequires: flex
-BuildRequires: gettext-tools
-BuildRequires: makeinfo
 BuildRequires: glibc-devel-32bit
 BuildRequires: mpc-devel
 BuildRequires: mpfr-devel
 BuildRequires: perl
-BuildRequires: texinfo
+BuildRequires: makeinfo
 BuildRequires: zlib-devel
-%ifarch %ix86 x86_64 %arm
-BuildRequires: cloog-devel
-BuildRequires: ppl-devel
+%ifarch %ix86 x86_64 ppc ppc64 s390 s390x ia64 %sparc hppa %arm
+BuildRequires: cloog-isl-devel
+BuildRequires: isl-devel
 %endif
 %if %{build_ada}
-%define hostsuffix -4.8
-BuildRequires: gcc48-ada
+%define hostsuffix -4.7
+BuildRequires: gcc47-ada
 %endif
 %if 0%{?building_libjava:1}%{?building_testsuite:1}
 BuildRequires: fastjar
-BuildRequires: unzip
 %endif
 %if 0%{?building_libffi:1}
 BuildRequires: pkg-config
 %endif
+%ifarch ia64
+BuildRequires: libunwind-devel
+%endif
 %if 0%{?run_tests:1}
 BuildRequires: dejagnu
 BuildRequires: expect
 BuildRequires: gdb
 %endif
 
-# Define version number of libgcc_s
-%define libgcc_s 1
-%define build_nof 0
-
 %define separate_bi32 0
 %define separate_bi64 0
-%ifarch x86_64 
+%ifarch ppc sparcv9
+# Beware, this does _not_ separate libgcj, as for that one multilibing
+# is inactive for the time being
+%define separate_bi64 1
+%endif
+%ifarch x86_64 s390x ppc64 sparc64
 %define separate_bi32 1
 %endif
 
@@ -96,7 +166,7 @@ BuildRequires: gdb
 %define separate_biarch_suffix -64bit
 %endif
 
-%ifarch x86_64
+%ifarch x86_64 ia64 s390x alpha ppc64 sparc64
 # 64-bit is primary build target
 %define build_primary_64bit 1
 %else
@@ -105,8 +175,7 @@ BuildRequires: gdb
 
 %define biarch_libjava 0
 
-# COMMON-BEGIN
-%define biarch_targets x86_64 
+%define biarch_targets x86_64 s390x powerpc64 powerpc sparc sparc64
 
 URL:          http://gcc.gnu.org/
 Version: 4.8.1
@@ -115,49 +184,47 @@ Release:      1
 %define gcc_dir_version %(echo %gcc_version | cut -d '.' -f 1-2)
 %define snapshot_date %(echo %version | sed 's/[34]\.[0-9]\.[0-6]//' | sed 's/_/-/')
 %define binsuffix -4.8
-# COMMON-END
 
 %if !0%{?building_libjava:1}%{?building_libffi:1}%{?building_testsuite:1}
 Requires: binutils glibc-devel
 Requires: cpp48 = %{version}-%{release}
-%if 0%{!?build_optional_compiler:1}
-Requires: libgcc%{libgcc_s} >= %{version}-%{release}
-Requires: libgomp1 >= %{version}-%{release}
+Requires: libgcc_s%{libgcc_s} >= %{version}-%{release}
+Requires: libgomp%{libgomp_sover} >= %{version}-%{release}
 %if %{build_with_mudflap}
-Requires: libmudflap0 >= %{version}-%{release}
-Requires: libmudflapth0 >= %{version}-%{release}
+Requires: libmudflap%{libmudflap_sover} >= %{version}-%{release}
+Requires: libmudflapth%{libmudflap_sover} >= %{version}-%{release}
 %endif
-%else
-Requires: libgcc48 = %{version}-%{release}
-Requires: libgomp48 = %{version}-%{release}
+%ifarch %asan_arch
+Requires: libasan%{libasan_sover} >= %{version}-%{release}
+%endif
+%ifarch %tsan_arch
+Requires: libtsan%{libtsan_sover} >= %{version}-%{release}
+%endif
+%ifarch %atomic_arch
+Requires: libatomic%{libatomic_sover} >= %{version}-%{release}
+%endif
+%ifarch %itm_arch
+Requires: libitm%{libitm_sover} >= %{version}-%{release}
 %endif
+Suggests: gcc48-info gcc48-locale
 %endif
 
-# COMMON-BEGIN
 BuildRoot:     %{_tmppath}/%{name}-%{version}-build
-#Source:               gcc-%{gcc_version}%{snapshot_date}.tar.bz2
-Source:     gcc-%{version}.tar.bz2
-
+Source:                gcc-%{gcc_version}%{snapshot_date}.tar.bz2
 Source1:       change_spec
-Source2:       libgcj48-rpmlintrc
 Source3:       gcc48-rpmlintrc
 Source4:       ecj.jar
 Source6:       baselibs.conf
-# Patches auto-generated by git-buildpackage:
-Patch0:     0001-dir-version.patch
-Patch1:     0002-textdomain.patch
-Patch2:     0003-rename-info-files.patch
-Patch3:     0004-ARM-linker.patch
+
 
 Summary:      Testsuite results
-License:       Public-Domain
-Group:        Development/Toolchain
+License:       SUSE-Public-Domain
+Group:        Development/Languages/C and C++
 
 %description 
 Results from running the gcc and target library testsuites.
 
 
-# COMMON-BEGIN
 
 # Define the canonical target and host architecture
 #   %gcc_target_arch  is supposed to be the full target triple
@@ -166,6 +233,12 @@ Results from running the gcc and target library testsuites.
 %if 0%{?gcc_target_arch:1}
 %define CONFIGURE_TARGET %{gcc_target_arch}
 %define TARGET_ARCH %(echo %{gcc_target_arch} | cut -d - -f 1 | sed -e "s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;")
+%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "powerpc"
+%define CONFIGURE_TARGET powerpc64-tizen-linux
+%endif
+%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "powerpc64"
+%define CONFIGURE_TARGET powerpc64-tizen-linux
+%endif
 %if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "i586"
 %define CONFIGURE_TARGET i586-tizen-linux
 %endif
@@ -175,11 +248,8 @@ Results from running the gcc and target library testsuites.
 %if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "armv7hl"
 %define CONFIGURE_TARGET armv7hl-tizen-linux-gnueabi
 %endif
-%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "armv7el"
-%define CONFIGURE_TARGET armv7el-tizen-linux-gnueabi
-%endif
-%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "armv5el"
-%define CONFIGURE_TARGET armv5el-tizen-linux-gnueabi
+%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "armv5tel"
+%define CONFIGURE_TARGET armv5tel-tizen-linux-gnueabi
 %endif
 %else
 %define TARGET_ARCH %(echo %{_target_cpu} | sed -e "s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;")
@@ -188,44 +258,46 @@ Results from running the gcc and target library testsuites.
 
 %define biarch %(case " %{biarch_targets} " in (*" %{TARGET_ARCH} "*) echo 1;; (*) echo 0;; esac)
 
+%ifarch ppc
+%define GCCDIST powerpc64-tizen-linux
+%else
+%ifarch %sparc
+%define GCCDIST sparc64-tizen-linux
+%else
 %ifarch %arm
 %define GCCDIST %{HOST_ARCH}-tizen-linux-gnueabi
 %else
 %define GCCDIST %{HOST_ARCH}-tizen-linux
 %endif
+%endif
+%endif
 
 %define libsubdir %{_libdir}/gcc/%{GCCDIST}/%{gcc_dir_version}
 %define gxxinclude %{_prefix}/include/c++/%{gcc_dir_version}
 
-# COMMON-END
 
 # Versionspecific directories
 %define versmainlibdir %{libsubdir}
 %define versmainlibdirbi32 %{libsubdir}/32
 %define versmainlibdirbi64 %{libsubdir}/64
+%ifarch ppc
+%define versmainlibdirbi32 %{libsubdir}
+%define versmainlibdirbi64 %{libsubdir}/64
+%endif
 %if %{build_primary_64bit}
 %define versmainlibdirbi %{versmainlibdirbi32}
 %else
 %define versmainlibdirbi %{versmainlibdirbi64}
 %endif
 
-%if 0%{?build_optional_compiler:1}
-%define mainlibdir %{versmainlibdir}
-%define mainlibdirbi32 %{versmainlibdirbi32}
-%define mainlibdirbi64 %{versmainlibdirbi64}
-%define noflibdir %{versnoflibdir}
-%define mainlibdirbi %{versmainlibdirbi}
-%else
 %define mainlibdir %{_libdir}
 %define mainlibdirbi32 %{_prefix}/lib
 %define mainlibdirbi64 %{_prefix}/lib64
-%define noflibdir %{_prefix}/lib/nof
 %if %{build_primary_64bit}
 %define mainlibdirbi %{mainlibdirbi32}
 %else
 %define mainlibdirbi %{mainlibdirbi64}
 %endif
-%endif
 
 
 # Now define a few macros that make it easy to package libs and
@@ -233,88 +305,51 @@ Results from running the gcc and target library testsuites.
 # exact path the files are in.
 #   %mainlib  package X from all dirs that belong to the main package
 #   %biarchlib   package X from all dirs that belong to the -32/64bit package
-# by default, nof libs go where the 32bit libs go.
-%if %{build_nof}
-%define mainlib() %{mainlibdir}/%1\
-%{noflibdir}/%1\
-%{nil}
-%else
 %define mainlib() %{mainlibdir}/%1\
 %{nil}
-%endif
 %define biarchlib() %{nil}
 %if %{biarch}
 %if !%{separate_biarch}
-%if %{build_nof}
 %define mainlib() %{mainlibdir}/%1\
 %{mainlibdirbi}/%1\
-%{noflibdir}/%1\
 %{nil}
 %else
-%define mainlib() %{mainlibdir}/%1\
-%{mainlibdirbi}/%1\
-%{nil}
-%endif
-%else
-%if %{build_nof}
 %define biarchlib() %{mainlibdirbi}/%1\
-%{noflibdir}/%1\
 %{nil}
-%define mainlib() %{mainlibdir}/%1\
-%{nil}
-%else
-%define biarchlib() %{mainlibdirbi}/%1\
-%{nil}
-%endif
 %endif
 %endif
 
-%if %{build_nof}
 %define versmainlib() %{versmainlibdir}/%1\
-%{versnoflibdir}/%1\
 %{nil}
-%else
-%define versmainlib() %{versmainlibdir}/%1\
-%{nil}
-%endif
 %define versbiarchlib() %{nil}
 %if %{biarch}
 %if !%{separate_biarch}
-%if %{build_nof}
-%define versmainlib() %{versmainlibdir}/%1\
-%{versmainlibdirbi}/%1\
-%{versnoflibdir}/%1\
-%{nil}
-%else
 %define versmainlib() %{versmainlibdir}/%1\
 %{versmainlibdirbi}/%1\
 %{nil}
-%endif
-%else
-%if %{build_nof}
-%define versbiarchlib() %{versmainlibdirbi}/%1\
-%{versnoflibdir}/%1\
-%{nil}
-%define versmainlib() %{versmainlibdir}/%1\
-%{nil}
 %else
 %define versbiarchlib() %{versmainlibdirbi}/%1\
 %{nil}
 %endif
 %endif
-%endif
 
 
-# COMMON-BEGIN
 
 %prep
-#%setup -q -n gcc-%{gcc_version}%{snapshot_date}
-%setup -q -n gcc-%{version}
-# 0001-dir-version.patch
-%patch0 -p1
-%patch1 -p1
-%patch2 -p1
-%patch3 -p1
+%setup -q -n gcc-%{gcc_version}%{snapshot_date}
+
+
+# We are configuring ppc as ppc64 but with switched multilibs.  Adjust
+# the libstdc++ abi testsuite baseline files accordingly
+%ifarch ppc
+if [ -d libstdc++-v3/config/abi/post/powerpc64-linux-gnu ]; then
+  mkdir -p libstdc++-v3/config/abi/post/powerpc64-linux-gnu/64
+  mv libstdc++-v3/config/abi/post/powerpc64-linux-gnu/baseline_symbols.txt \
+       libstdc++-v3/config/abi/post/powerpc64-linux-gnu/64/
+  mv libstdc++-v3/config/abi/post/powerpc64-linux-gnu/32/baseline_symbols.txt \
+       libstdc++-v3/config/abi/post/powerpc64-linux-gnu/
+fi
+%endif
 
 %build
 # Avoid rebuilding of generated files
@@ -345,6 +380,10 @@ RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-fno-rtti//g' -e 's/-fno-exceptions
 # default compiler settings now.
 RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-mcpu=i.86//g' -e 's/-march=i.86//g' -e 's/-mtune=i.86//g'`
 %endif
+%ifarch s390 s390x
+RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-fsigned-char//g'`
+RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-O1/-O2/g'`
+%endif
 %if 0%{?gcc_target_arch:1} && 0%{!?gcc_icecream:1}
 # Kill all -march/tune/cpu because that screws building the target libs
 RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-m\(arch\|tune\|cpu\)=[^ ]*//g'`
@@ -407,7 +446,7 @@ export _POSIX2_VERSION=199209
 # if glibc supports SSP.  When cross compiling we would need
 # to install a cross glibc, which we don't, or make the whole
 # thing point to the native glibc, which is in /, hence the
-# --with-sysroot=/
+# --with-build-sysroot=/
 
 %if %{build_ada}
 # Using the host gnatmake like
@@ -428,26 +467,27 @@ export PATH="`pwd`/host-tools/bin:$PATH"
 #      --enable-threads=posix \
 #%endif
 #      --enable-shared \
+%if "%{TARGET_ARCH}" == "armv7l" || "%{TARGET_ARCH}" == "armv7hl"
+# temporary workaround for a miscompilation of hash functions in java code
+GCJ_EXTRA_FLAGS="-marm"
+%endif
 CFLAGS="$RPM_OPT_FLAGS" CXXFLAGS="$RPM_OPT_FLAGS" XCFLAGS="$RPM_OPT_FLAGS" \
-TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
+TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS $GCJ_EXTRA_FLAGS" \
 ../configure \
        --prefix=%{_prefix} \
        --infodir=%{_infodir} \
        --mandir=%{_mandir} \
        --libdir=%{_libdir} \
        --libexecdir=%{_libdir} \
+    --disable-bootstrap \
        --enable-languages=$languages \
        $ENABLE_CHECKING \
        --with-gxx-include-dir=%{_prefix}/include/c++/%{gcc_dir_version} \
        --enable-ssp \
        --disable-libssp \
-       --disable-libitm \
-%if 0%{?fast_build}
-       --disable-bootstrap \
-%endif
        --disable-plugin \
        --with-bugurl="http://bugs.tizen.org/" \
-       --with-pkgversion="Tizen Linux" \
+       --with-pkgversion="Tizen" \
 %if !%{build_libjava}
         --disable-libgcj \
 %else
@@ -478,12 +518,14 @@ TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
 %if 0%{?canonical_target:1}
        --with-build-time-tools=/usr/%{canonical_target}-tizen-linux%{?canonical_target_abi:%canonical_target_abi}/bin \
 %endif
+%if 0%{?sysroot:1}
+       --with-sysroot=%sysroot \
+%endif
 %if 0%{?build_static:1}
        --disable-shared \
 %endif
 %if "%{TARGET_ARCH}" == "spu"
-       --with-sysroot=/usr/spu \
-       --with-gxx-include-dir=%{_prefix}/spu/include/c++/%{gcc_dir_version} \
+       --with-gxx-include-dir=%sysroot/include/c++/%{gcc_dir_version} \
        --with-newlib \
 %endif
        --disable-nls \
@@ -491,8 +533,12 @@ TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
 %else
        --program-suffix=%{binsuffix} \
        --enable-linux-futex \
+%ifarch ia64
+       --with-system-libunwind \
+%else
        --without-system-libunwind \
 %endif
+%endif
 %if "%{TARGET_ARCH}" == "armv5tel"
        --with-arch=armv5te \
        --with-float=soft \
@@ -500,15 +546,15 @@ TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
        --with-abi=aapcs-linux \
        --disable-sjlj-exceptions \
 %endif
-%if "%{TARGET_ARCH}" == "armv7el" 
+%if "%{TARGET_ARCH}" == "armv7l" 
        --with-arch=armv7-a \
        --with-tune=cortex-a9 \
-       --with-float=soft \
-       --with-abi=softfp \
-       --with-fpu=vfpv3 \
+       --with-float=hard \
+       --with-abi=aapcs-linux \
+       --with-fpu=vfpv3-d16 \
        --disable-sjlj-exceptions \
 %endif
-%if "%{TARGET_ARCH}" == "armv7l" || "%{TARGET_ARCH}" == "armv7hl"
+%if  "%{TARGET_ARCH}" == "armv7hl"
        --with-arch=armv7-a \
        --with-tune=cortex-a9 \
        --with-float=hard \
@@ -516,6 +562,22 @@ TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
        --with-fpu=vfpv3-d16 \
        --disable-sjlj-exceptions \
 %endif
+%if "%{TARGET_ARCH}" == "powerpc" || "%{TARGET_ARCH}" == "powerpc64"
+%if "%{TARGET_ARCH}" == "powerpc"
+       --with-cpu=default32 \
+%endif
+       --with-cpu-64=power4 \
+       --enable-secureplt \
+       --with-long-double-128 \
+%endif
+%if "%{TARGET_ARCH}" == "sparc64"
+       --with-cpu=ultrasparc \
+       --with-long-double-128 \
+%endif
+%if "%{TARGET_ARCH}" == "sparc"
+       --with-cpu=v8 \
+       --with-long-double-128 \
+%endif
 %if "%{TARGET_ARCH}" == "i586"
        --with-arch-32=i586 \
        --with-tune=generic \
@@ -524,23 +586,28 @@ TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
        --with-arch-32=i586 \
        --with-tune=generic \
 %endif
+%if "%{TARGET_ARCH}" == "s390"
+        --with-tune=z196 --with-arch=z10 \
+       --with-long-double-128 \
+       --enable-decimal-float \
+%endif
+%if "%{TARGET_ARCH}" == "s390x"
+        --with-tune=z196 --with-arch=z10 \
+       --with-long-double-128 \
+       --enable-decimal-float \
+%endif
        --build=%{GCCDIST}
 
-# COMMON-END
 
 %if 0%{?building_libffi:1}
 make stage1-bubble $PARALLEL
 make all-target-libffi $PARALLEL
 %else
+STAGE1_FLAGS="-g"
 # Only run profiled bootstrap on archs where it works
-#%ifarch %ix86 x86_64 
-#make profiledbootstrap-lean STAGE1_CFLAGS="-O -g" BOOT_CFLAGS="$RPM_OPT_FLAGS" $PARALLEL
+#%ifarch %ix86 x86_64 ppc ppc64 ia64
+#make profiledbootstrap-lean STAGE1_CFLAGS="$STAGE1_FLAGS" BOOT_CFLAGS="$RPM_OPT_FLAGS" $PARALLEL
 #%else
-%ifarch %arm
-STAGE1_FLAGS="-O0"
-%else
-STAGE1_FLAGS="-O -g"
-%endif
 #make bootstrap-lean STAGE1_CFLAGS="$STAGE1_FLAGS" BOOT_CFLAGS="$RPM_OPT_FLAGS" $PARALLEL
 make STAGE1_CFLAGS="$STAGE1_FLAGS" BOOT_CFLAGS="$RPM_OPT_FLAGS" $PARALLEL
 #%endif
@@ -551,6 +618,8 @@ echo "Run testsuite"
 (make -C %{GCCDIST}/libstdc++-v3 check-abi || true)
 mv %{GCCDIST}/libstdc++-v3/testsuite/libstdc++.log %{GCCDIST}/libstdc++-v3/testsuite/libstdc++-abi.log
 mv %{GCCDIST}/libstdc++-v3/testsuite/libstdc++.sum %{GCCDIST}/libstdc++-v3/testsuite/libstdc++-abi.sum
+# asan needs a whole shadow address space
+ulimit -v unlimited || true
 make -k check $PARALLEL || true
 mkdir ../testresults
 ../contrib/test_summary | tee ../testresults/test_summary.txt
index ba6f35c..e505116 100644 (file)
@@ -1,23 +1,39 @@
-%define fast_build 1
+#
+# spec file for package gcc48
+#
+# Copyright (c) 2009 SUSE LINUX Products GmbH, Nuernberg, Germany.
+#
+# All modifications and additions to the file contributed by third parties
+# remain the property of their copyright owners, unless otherwise agreed
+# upon. The license for this file, and modifications and additions to the
+# file, is the same license as for the pristine package itself (unless the
+# license for the pristine package is not an Open Source License, in which
+# case the license is the MIT License). An "Open Source License" is a
+# license that conforms to the Open Source Definition (Version 1.9)
+# published by the Open Source Initiative.
+
+# Please submit bugfixes or comments via http://bugs.opensuse.org/
+#
+
+# norootforbuild
+# icecream 0
+
 
-# Ada currently fails to build on a few platforms, enable it only
-# on those that work
-# Note that AdaCore only supports %ix86, x86_64 and ia64
-%ifarch %ix86 x86_64
-%define build_ada !0%{?building_libjava:1}%{?building_libffi:1}
-%else
 %define build_ada 0
-%endif
 
-%define quadmath_arch %ix86 x86_64 
+%define quadmath_arch %ix86 x86_64 ia64
+%define tsan_arch x86_64
+%define asan_arch x86_64 %ix86 ppc ppc64
+%define itm_arch x86_64 %ix86 %arm ppc ppc64
+%define atomic_arch x86_64 %ix86 %arm ppc ppc64 s390 s390x
 
 # We don't want to build java
-%define build_java 1
-%define build_libjava 0%{?building_libjava:1}%{?building_libffi:1}%{?building_testsuite:1}
+%define build_java 0
+%define build_libjava 0
 
 %define build_cp 1
-%define build_fortran 1
-%define build_objc 1
+%define build_fortran !0%{?building_libjava:1}%{?building_libffi:1}
+%define build_objc !0%{?building_libjava:1}%{?building_libffi:1}
 %define build_objcp !0%{?building_libjava:1}%{?building_libffi:1}
 %define build_with_mudflap 0
 
 %endif
 
 # For optional compilers only build C, C++ and Fortran
-##%if 0%{?build_optional_compiler:1}%{?build_optional_compiler_languages:1}
-%if 0%{!?building_libffi:1}
+%if 0%{?build_optional_compiler_languages:1}
 %define build_ada 0
 %define build_java 0
 %define build_libjava 0
-%define build_objc 1
-%define build_objcp 1
+%define build_objc 0
+%define build_objcp 0
 %endif
 
+# Shared library SONAME versions
+%ifarch hppa
+%define libgcc_s 4
+%else
+%define libgcc_s 1
+%endif
+%define libgcj_sover 14
+%define libgcj_bc_sover 1
+%define libffi_sover 4
+%define libmudflap_sover 0
+%define libgomp_sover 1
+%define libstdcxx_sover 6
+%define libobjc_sover 4
+%define libgfortran_sover 3
+%define libquadmath_sover 0
+%define libasan_sover 0
+%define libtsan_sover 0
+%define libatomic_sover 1
+%define libitm_sover 1
+
+# Shared library package suffix
+# This is used for the "non-standard" set of libraries, the standard
+# being defined by %product_libs_gcc_ver, the GCC version that should
+# provide un-suffixed shared library packages following the shared-library
+# policy.  Even suffixed variants should provide the shared-library policy
+# mandated names and ensure they conflict with each other.
+# Note that on SONAME changes of any library the %product_libs_gcc_ver
+# define needs to be either split or the newest GCC version still providing
+# the old SONAME needs to unconditionally produce an un-suffixed library
+# if %product_libs_gcc_ver is newer than it.  Similar the _oldest_ GCC
+# version first providing a new SONAME needs to unconditionally produce
+# an un-suffixed library if %product_libs_gcc_ver is lower that it.
+%if %{!?product_libs_gcc_ver:48}%{?product_libs_gcc_ver} != 48
+%define pne 1
+%endif
+%define libgcc_s_suffix %{?pne:-gcc48}
+# libgcj SONAME changes with every GCC version
+%define libgcj_suffix %nil
+%define libgcj_bc_suffix %{?pne:-gcc48}
+%define libffi_suffix %{?pne:-gcc48}
+%define libmudflap_suffix %{?pne:-gcc48}
+%define libgomp_suffix %{?pne:-gcc48}
+%define libstdcxx_suffix %{?pne:-gcc48}
+%define libobjc_suffix %{?pne:-gcc48}
+%define libgfortran_suffix %{?pne:-gcc48}
+%define libquadmath_suffix %{?pne:-gcc48}
+%define libasan_suffix %{?pne:-gcc48}
+%define libtsan_suffix %{?pne:-gcc48}
+%define libatomic_suffix %{?pne:-gcc48}
+%define libitm_suffix %{?pne:-gcc48}
+
+
+
 
 Name:         gcc48
+BuildRequires: gcc-c++
 BuildRequires: bison
 BuildRequires: flex
-BuildRequires: gettext-tools
-BuildRequires: makeinfo
 BuildRequires: glibc-devel-32bit
 BuildRequires: mpc-devel
 BuildRequires: mpfr-devel
 BuildRequires: perl
-BuildRequires: texinfo
+BuildRequires: makeinfo
 BuildRequires: zlib-devel
-%ifarch %ix86 x86_64 %arm
-BuildRequires: cloog-devel
-BuildRequires: ppl-devel
+%ifarch %ix86 x86_64 ppc ppc64 s390 s390x ia64 %sparc hppa %arm
+BuildRequires: cloog-isl-devel
+BuildRequires: isl-devel
 %endif
 %if %{build_ada}
-%define hostsuffix -4.8
-BuildRequires: gcc48-ada
+%define hostsuffix -4.7
+BuildRequires: gcc47-ada
 %endif
 %if 0%{?building_libjava:1}%{?building_testsuite:1}
 BuildRequires: fastjar
-BuildRequires: unzip
 %endif
 %if 0%{?building_libffi:1}
 BuildRequires: pkg-config
 %endif
+%ifarch ia64
+BuildRequires: libunwind-devel
+%endif
 %if 0%{?run_tests:1}
 BuildRequires: dejagnu
 BuildRequires: expect
 BuildRequires: gdb
 %endif
 
-# Define version number of libgcc_s
-%define libgcc_s 1
-%define build_nof 0
-
 %define separate_bi32 0
 %define separate_bi64 0
-%ifarch x86_64 
+%ifarch ppc sparcv9
+# Beware, this does _not_ separate libgcj, as for that one multilibing
+# is inactive for the time being
+%define separate_bi64 1
+%endif
+%ifarch x86_64 s390x ppc64 sparc64
 %define separate_bi32 1
 %endif
 
@@ -94,7 +164,7 @@ BuildRequires: gdb
 %define separate_biarch_suffix -64bit
 %endif
 
-%ifarch x86_64
+%ifarch x86_64 ia64 s390x alpha ppc64 sparc64
 # 64-bit is primary build target
 %define build_primary_64bit 1
 %else
@@ -103,8 +173,7 @@ BuildRequires: gdb
 
 %define biarch_libjava 0
 
-# COMMON-BEGIN
-%define biarch_targets x86_64 
+%define biarch_targets x86_64 s390x powerpc64 powerpc sparc sparc64
 
 URL:          http://gcc.gnu.org/
 Version: 4.8.1
@@ -113,44 +182,40 @@ Release:      1
 %define gcc_dir_version %(echo %gcc_version | cut -d '.' -f 1-2)
 %define snapshot_date %(echo %version | sed 's/[34]\.[0-9]\.[0-6]//' | sed 's/_/-/')
 %define binsuffix -4.8
-# COMMON-END
 
 %if !0%{?building_libjava:1}%{?building_libffi:1}%{?building_testsuite:1}
 Requires: binutils glibc-devel
 Requires: cpp48 = %{version}-%{release}
-%if 0%{!?build_optional_compiler:1}
-Requires: libgcc%{libgcc_s} >= %{version}-%{release}
-Requires: libgomp1 >= %{version}-%{release}
+Requires: libgcc_s%{libgcc_s} >= %{version}-%{release}
+Requires: libgomp%{libgomp_sover} >= %{version}-%{release}
 %if %{build_with_mudflap}
-Requires: libmudflap0 >= %{version}-%{release}
-Requires: libmudflapth0 >= %{version}-%{release}
+Requires: libmudflap%{libmudflap_sover} >= %{version}-%{release}
+Requires: libmudflapth%{libmudflap_sover} >= %{version}-%{release}
 %endif
-%else
-Requires: libgcc48 = %{version}-%{release}
-Requires: libgomp48 = %{version}-%{release}
+%ifarch %asan_arch
+Requires: libasan%{libasan_sover} >= %{version}-%{release}
 %endif
+%ifarch %tsan_arch
+Requires: libtsan%{libtsan_sover} >= %{version}-%{release}
+%endif
+%ifarch %atomic_arch
+Requires: libatomic%{libatomic_sover} >= %{version}-%{release}
+%endif
+%ifarch %itm_arch
+Requires: libitm%{libitm_sover} >= %{version}-%{release}
+%endif
+Suggests: gcc48-info gcc48-locale
 %endif
 
-# COMMON-BEGIN
 BuildRoot:     %{_tmppath}/%{name}-%{version}-build
-#Source:               gcc-%{gcc_version}%{snapshot_date}.tar.bz2
-Source:     gcc-%{version}.tar.bz2
-
+Source:                gcc-%{gcc_version}%{snapshot_date}.tar.bz2
 Source1:       change_spec
-Source2:       libgcj48-rpmlintrc
 Source3:       gcc48-rpmlintrc
 Source4:       ecj.jar
 Source6:       baselibs.conf
-# Patches auto-generated by git-buildpackage:
-Patch0:     0001-dir-version.patch
-Patch1:     0002-textdomain.patch
-Patch2:     0003-rename-info-files.patch
-Patch3:     0004-ARM-linker.patch
-
-# GCC-TESTSUITE-DELETE-BEGIN
-# LIBFFI-DELETE-BEGIN
-# LIBJAVA-DELETE-BEGIN
-Group:         Development/Toolchain
+
+
+Group:         Development/Languages/C and C++
 Summary:       The GNU C Compiler and Support Files
 License:        GPL-3.0+
 
@@ -164,21 +229,15 @@ gcc-obj-c++.
 
 
 
-# COMMON-END
 %package -n gcc48-32bit
 Summary:      The GNU C Compiler 32bit support
-Group:        Development/Toolchain
+Group:        Development/Languages/C and C++
 Requires: gcc48 = %{version}-%{release}
-%if 0%{!?build_optional_compiler:1}
-Requires: libgcc%{libgcc_s}-32bit >= %{version}-%{release}
-Requires: libgomp1-32bit >= %{version}-%{release}
+Requires: libgcc_s%{libgcc_s}-32bit >= %{version}-%{release}
+Requires: libgomp%{libgomp_sover}-32bit >= %{version}-%{release}
 %if %{build_with_mudflap}
-Requires: libmudflap0-32bit >= %{version}-%{release}
-Requires: libmudflapth0-32bit >= %{version}-%{release}
-%endif
-%else
-Requires: libgcc48-32bit = %{version}-%{release}
-Requires: libgomp48-32bit = %{version}-%{release}
+Requires: libmudflap%{libmudflap_sover}-32bit >= %{version}-%{release}
+Requires: libmudflapth%{libmudflap_sover}-32bit >= %{version}-%{release}
 %endif
 Requires: glibc-devel-32bit
 
@@ -187,18 +246,13 @@ This package contains 32bit support for the GNU Compiler Collection.
 
 %package -n gcc48-64bit
 Summary:      The GNU C Compiler 64bit support
-Group:        Development/Toolchain
+Group:        Development/Languages/C and C++
 Requires: gcc48 = %{version}-%{release}
-%if 0%{!?build_optional_compiler:1}
-Requires: libgcc%{libgcc_s}-64bit >= %{version}-%{release}
-Requires: libgomp1-64bit >= %{version}-%{release}
+Requires: libgcc_s%{libgcc_s}-64bit >= %{version}-%{release}
+Requires: libgomp%{libgomp_sover}-64bit >= %{version}-%{release}
 %if %{build_with_mudflap}
-Requires: libmudflap0-64bit >= %{version}-%{release}
-Requires: libmudflapth0-64bit >= %{version}-%{release}
-%endif
-%else
-Requires: libgcc48-64bit = %{version}-%{release}
-Requires: libgomp48-64bit = %{version}-%{release}
+Requires: libmudflap%{libmudflap_sover}-64bit >= %{version}-%{release}
+Requires: libmudflapth%{libmudflap_sover}-64bit >= %{version}-%{release}
 %endif
 Requires: glibc-devel-64bit
 
@@ -209,7 +263,7 @@ This package contains 64bit support for the GNU Compiler Collection.
 %package locale
 Summary:      Locale Data for the GNU Compiler Collection
 License:        GPL-3.0+
-Group:        Development/Toolchain
+Group:        Development/Languages/C and C++
 Requires: gcc48 = %{version}-%{release}
 
 %description locale
@@ -220,296 +274,224 @@ in the current locale.
 %package c++
 Summary:      The GNU C++ Compiler
 License:        GPL-3.0+
-Group:        Development/Toolchain
+Group:        Development/Languages/C and C++
 Requires: gcc48 = %{version}-%{release}
 Requires: libstdc++48-devel = %{version}-%{release}
 
 %description c++
 This package contains the GNU compiler for C++.
 
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
 %package -n libstdc++48-devel
 Summary:      Include Files and Libraries mandatory for Development
 License:        GPL-3.0-with-GCC-exception
-Group:        Development/Toolchain
-%if 0%{!?build_optional_compiler:1}
-Requires: libstdc++6 >= %{version}-%{release}
-%else
-Requires: libstdc++48 = %{version}-%{release}
-%endif
+Group:        Development/Languages/C and C++
+Requires: libstdc++%{libstdcxx_sover} >= %{version}-%{release}
 Requires: glibc-devel
+%ifarch ia64
+Requires: libunwind-devel
+%endif
 
 %description -n libstdc++48-devel
 This package contains all the headers and libraries of the standard C++
 library. It is needed for compiling C++ code.
-# PACKAGE-END
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
 %package -n libstdc++48-devel-32bit
 Summary:      Include Files and Libraries mandatory for Development
 License:        GPL-3.0-with-GCC-exception
-Group:        Development/Toolchain
-%if 0%{!?build_optional_compiler:1}
-Requires: libstdc++6-32bit >= %{version}-%{release}
-%else
-Requires: libstdc++48-32bit = %{version}-%{release}
-%endif
+Group:        Development/Languages/C and C++
+Requires: libstdc++%{libstdcxx_sover}-32bit >= %{version}-%{release}
 Requires: glibc-devel-32bit
+%ifarch ia64
+Requires: libunwind-devel
+%endif
 
 %description -n libstdc++48-devel-32bit
 This package contains all the headers and libraries of the standard C++
 library. It is needed for compiling C++ code.
-# PACKAGE-END
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
 %package -n libstdc++48-devel-64bit
 Summary:      Include Files and Libraries mandatory for Development
 License:        GPL-3.0-with-GCC-exception
-Group:        Development/Toolchain
-%if 0%{!?build_optional_compiler:1}
-Requires: libstdc++6-64bit >= %{version}-%{release}
-%else
-Requires: libstdc++48-64bit = %{version}-%{release}
-%endif
+Group:        Development/Languages/C and C++
+Requires: libstdc++%{libstdcxx_sover}-64bit >= %{version}-%{release}
 Requires: glibc-devel-64bit
+%ifarch ia64
+Requires: libunwind-devel
+%endif
 
 %description -n libstdc++48-devel-64bit
 This package contains all the headers and libraries of the standard C++
 library. It is needed for compiling C++ code.
-# PACKAGE-END
 
 %package -n libstdc++48-doc
 Summary:      Documentation for the GNU C++ standard library
 License:        GPL-3.0+
-Group:        Documentation
+Group:        Documentation/HTML
 BuildArch:    noarch
 
 %description -n libstdc++48-doc
 Extensive HTML documentation for the GNU C++ standard library.
 
 
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
-%package -n libgcc48
+%package -n libgcc_s%{libgcc_s}%{libgcc_s_suffix}
 Summary:      C compiler runtime library
 License:        GPL-3.0-with-GCC-exception
-Group:        Base/Libraries
-%if 0%{!?build_optional_compiler:1}
-Provides: libgcc%{libgcc_s} = %{version}-%{release}
-Conflicts: libgcc%{libgcc_s} < %{version}-%{release}
-%else
-Autoprov: no
-%endif
+Group:        System/Base
+Provides:      libgcc_s%{libgcc_s} = %{version}-%{release}
 
-%description -n libgcc48
+%description -n libgcc_s%{libgcc_s}%{libgcc_s_suffix}
 Libgcc is needed for dynamically linked C programs.
 
-%post -n libgcc48
+%post -n libgcc_s%{libgcc_s}%{libgcc_s_suffix}
 /sbin/ldconfig
 
-%postun -n libgcc48
+%postun -n libgcc_s%{libgcc_s}%{libgcc_s_suffix}
 /sbin/ldconfig
-# PACKAGE-END
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
-%package -n libgcc48-32bit
+%package -n libgcc_s%{libgcc_s}%{libgcc_s_suffix}-32bit
 Summary:      C compiler runtime library
 License:        GPL-3.0-with-GCC-exception
-Group:        Base/Libraries
-%if 0%{!?build_optional_compiler:1}
-Provides: libgcc%{libgcc_s}-32bit = %{version}-%{release}
-Conflicts: libgcc%{libgcc_s}-32bit < %{version}-%{release}
-%else
-Autoprov: no
-%endif
+Group:        System/Base
+Provides:      libgcc_s%{libgcc_s}-32bit = %{version}-%{release}
 
-%description -n libgcc48-32bit
+%description -n libgcc_s%{libgcc_s}%{libgcc_s_suffix}-32bit
 Libgcc is needed for dynamically linked C programs.
 
-%post -n libgcc48-32bit
+%post -n libgcc_s%{libgcc_s}%{libgcc_s_suffix}-32bit
 /sbin/ldconfig
 
-%postun -n libgcc48-32bit
+%postun -n libgcc_s%{libgcc_s}%{libgcc_s_suffix}-32bit
 /sbin/ldconfig
-# PACKAGE-END
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
-%package -n libgcc48-64bit
+%package -n libgcc_s%{libgcc_s}%{libgcc_s_suffix}-64bit
 Summary:      C compiler runtime library
 License:        GPL-3.0-with-GCC-exception
-Group:        Base/Libraries
-%if 0%{!?build_optional_compiler:1}
-Provides: libgcc%{libgcc_s}-64bit = %{version}-%{release}
-Conflicts: libgcc%{libgcc_s}-64bit < %{version}-%{release}
-%else
-Autoprov: no
-%endif
+Group:        System/Base
+Provides:      libgcc_s%{libgcc_s}-64bit = %{version}-%{release}
 
-%description -n libgcc48-64bit
+%description -n libgcc_s%{libgcc_s}%{libgcc_s_suffix}-64bit
 Libgcc is needed for dynamically linked C programs.
 
-%post -n libgcc48-64bit
+%post -n libgcc_s%{libgcc_s}%{libgcc_s_suffix}-64bit
 /sbin/ldconfig
 
-%postun -n libgcc48-64bit
+%postun -n libgcc_s%{libgcc_s}%{libgcc_s_suffix}-64bit
 /sbin/ldconfig
-# PACKAGE-END
 
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
-%package -n libgomp48
+%package -n libgomp%{libgomp_sover}%{libgomp_suffix}
 Summary:      The GNU compiler collection OpenMP runtime library
 License:        GPL-3.0-with-GCC-exception
-Group:        Base/Libraries
-%if 0%{!?build_optional_compiler:1}
-Provides: libgomp1 = %{version}-%{release}
-Conflicts: libgomp1 < %{version}-%{release}
-%else
-Autoprov: no
-%endif
+Group:        System/Base
+Provides:      libgomp%{libgomp_sover} = %{version}-%{release}
 
-%description -n libgomp48
+%description -n libgomp%{libgomp_sover}%{libgomp_suffix}
 This is the OpenMP runtime library needed by OpenMP enabled programs
 that were built with the -fopenmp compiler option and by programs that
 were auto-parallelized via the -ftree-parallelize-loops compiler
 option.
 
 
-%post -n libgomp48
+%post -n libgomp%{libgomp_sover}%{libgomp_suffix}
 /sbin/ldconfig
 
-%postun -n libgomp48
+%postun -n libgomp%{libgomp_sover}%{libgomp_suffix}
 /sbin/ldconfig
-# PACKAGE-END
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
-%package -n libgomp48-32bit
+%package -n libgomp%{libgomp_sover}%{libgomp_suffix}-32bit
 Summary:      The GNU compiler collection OpenMP runtime library
 License:        GPL-3.0-with-GCC-exception
-Group:        Base/Libraries
-%if 0%{!?build_optional_compiler:1}
-Provides: libgomp1-32bit = %{version}-%{release}
-Conflicts: libgomp1-32bit < %{version}-%{release}
-%else
-Autoprov: no
-%endif
+Group:        System/Base
+Provides:      libgomp%{libgomp_sover}-32bit = %{version}-%{release}
 
-%description -n libgomp48-32bit
+%description -n libgomp%{libgomp_sover}%{libgomp_suffix}-32bit
 This is the OpenMP runtime library needed by OpenMP enabled programs
 that were built with the -fopenmp compiler option and by programs that
 were auto-parallelized via the -ftree-parallelize-loops compiler
 option.
 
 
-%post -n libgomp48-32bit
+%post -n libgomp%{libgomp_sover}%{libgomp_suffix}-32bit
 /sbin/ldconfig
 
-%postun -n libgomp48-32bit
+%postun -n libgomp%{libgomp_sover}%{libgomp_suffix}-32bit
 /sbin/ldconfig
-# PACKAGE-END
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
-%package -n libgomp48-64bit
+%package -n libgomp%{libgomp_sover}%{libgomp_suffix}-64bit
 Summary:      The GNU compiler collection OpenMP runtime library
 License:        GPL-3.0-with-GCC-exception
-Group:        Base/Libraries
-%if 0%{!?build_optional_compiler:1}
-Provides: libgomp1-64bit = %{version}-%{release}
-Conflicts: libgomp1-64bit < %{version}-%{release}
-%else
-Autoprov: no
-%endif
+Group:        System/Base
+Provides:      libgomp%{libgomp_sover}-64bit = %{version}-%{release}
 
-%description -n libgomp48-64bit
+%description -n libgomp%{libgomp_sover}%{libgomp_suffix}-64bit
 This is the OpenMP runtime library needed by OpenMP enabled programs
 that were built with the -fopenmp compiler option and by programs that
 were auto-parallelized via the -ftree-parallelize-loops compiler
 option.
 
 
-%post -n libgomp48-64bit
+%post -n libgomp%{libgomp_sover}%{libgomp_suffix}-64bit
 /sbin/ldconfig
 
-%postun -n libgomp48-64bit
+%postun -n libgomp%{libgomp_sover}%{libgomp_suffix}-64bit
 /sbin/ldconfig
-# PACKAGE-END
 
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
-%package -n libstdc++48
+%package -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}
 Summary:      The standard C++ shared library
 License:        GPL-3.0-with-GCC-exception
-Group:        Base/Libraries
-%if 0%{!?build_optional_compiler:1}
-Provides: libstdc++6 = %{version}-%{release}
-Conflicts: libstdc++6 < %{version}-%{release}
-%else
-Autoprov: no
-%endif
+Group:        System/Libraries
+Suggests:      libstdc++%{libstdcxx_sover}-locale
+Provides:      libstdc++%{libstdcxx_sover} = %{version}-%{release}
 
-%description -n libstdc++48
+%description -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}
 The standard C++ library, needed for dynamically linked C++ programs.
 
 
-%post -n libstdc++48
+%post -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}
 /sbin/ldconfig
 
-%postun -n libstdc++48
+%postun -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}
 /sbin/ldconfig
-# PACKAGE-END
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
-%package -n libstdc++48-32bit
+%package -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}-32bit
 Summary:      The standard C++ shared library
 License:        GPL-3.0-with-GCC-exception
-Group:        Base/Libraries
-%if 0%{!?build_optional_compiler:1}
-Provides: libstdc++6-32bit = %{version}-%{release}
-Conflicts: libstdc++6-32bit < %{version}-%{release}
-%else
-Autoprov: no
-%endif
+Group:        System/Libraries
+Suggests:      libstdc++%{libstdcxx_sover}-locale
+Provides:      libstdc++%{libstdcxx_sover}-32bit = %{version}-%{release}
 
-%description -n libstdc++48-32bit
+%description -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}-32bit
 The standard C++ library, needed for dynamically linked C++ programs.
 
 
-%post -n libstdc++48-32bit
+%post -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}-32bit
 /sbin/ldconfig
 
-%postun -n libstdc++48-32bit
+%postun -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}-32bit
 /sbin/ldconfig
-# PACKAGE-END
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
-%package -n libstdc++48-64bit
+%package -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}-64bit
 Summary:      The standard C++ shared library
 License:        GPL-3.0-with-GCC-exception
-Group:        Base/Libraries
-%if 0%{!?build_optional_compiler:1}
-Provides: libstdc++6-64bit = %{version}-%{release}
-Conflicts: libstdc++6-64bit < %{version}-%{release}
-%else
-Autoprov: no
-%endif
+Group:        System/Libraries
+Suggests:      libstdc++%{libstdcxx_sover}-locale
+Provides:      libstdc++%{libstdcxx_sover}-64bit = %{version}-%{release}
 
-%description -n libstdc++48-64bit
+%description -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}-64bit
 The standard C++ library, needed for dynamically linked C++ programs.
 
 
-%post -n libstdc++48-64bit
+%post -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}-64bit
 /sbin/ldconfig
 
-%postun -n libstdc++48-64bit
+%postun -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}-64bit
 /sbin/ldconfig
-# PACKAGE-END
+
+%package -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}-locale
+Summary:       Locale Data for the standard C++ shared library
+License:       GPL-3.0-with-GCC-exception
+Group:         System/Libraries
+Provides:      libstdc++%{libstdcxx_sover}-locale = %{version}-%{release}
+
+%description -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}-locale
+The standard C++ library locale data.
 
 
 %package info
 Summary:      Documentation for the GNU compiler collection
 License:      GFDL-1.2
-Group:        Documentation
+Group:        Documentation/Other
 BuildArch:    noarch
 
 %description info
@@ -517,108 +499,87 @@ GNU info-pages for the GNU compiler collection covering both user-level
 and internals documentation.
 
 
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
 %package objc
 Summary:      GNU Objective C Compiler
 License:        GPL-3.0+
-Group:        Development/Toolchain
+Group:        Development/Languages/Other
 Requires: gcc48 = %{version}-%{release}
-Requires: libobjc2 >= %{version}-%{release}
+Requires: libobjc%{libobjc_sover} >= %{version}-%{release}
 
 %description objc
 This package contains the GNU Objective C compiler. Objective C is an
 object oriented language, created by Next Inc. and used in their
 Nextstep OS. The source code is available in the gcc package.
-# PACKAGE-END
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
 %package objc-32bit
 Summary:      GNU Objective C Compiler
 License:        GPL-3.0+
-Group:        Development/Toolchain
+Group:        Development/Languages/Other
 Requires: gcc48 = %{version}-%{release}
-Requires: libobjc2-32bit >= %{version}-%{release}
+Requires: libobjc%{libobjc_sover}-32bit >= %{version}-%{release}
 
 %description objc-32bit
 This package contains the GNU Objective C compiler. Objective C is an
 object oriented language, created by Next Inc. and used in their
 Nextstep OS. The source code is available in the gcc package.
-# PACKAGE-END
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
 %package objc-64bit
 Summary:      GNU Objective C Compiler
 License:        GPL-3.0+
-Group:        Development/Toolchain
+Group:        Development/Languages/Other
 Requires: gcc48 = %{version}-%{release}
-Requires: libobjc2-64bit >= %{version}-%{release}
+Requires: libobjc%{libobjc_sover}-64bit >= %{version}-%{release}
 
 %description objc-64bit
 This package contains the GNU Objective C compiler. Objective C is an
 object oriented language, created by Next Inc. and used in their
 Nextstep OS. The source code is available in the gcc package.
-# PACKAGE-END
 
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
-%package -n libobjc48
+%package -n libobjc%{libobjc_sover}%{libobjc_suffix}
 Summary:      Library for the GNU Objective C Compiler
 License:        GPL-3.0-with-GCC-exception
 Group:        Development/Libraries/Other
-Provides: libobjc2 = %{version}-%{release}
-Conflicts: libobjc2 < %{version}-%{release}
+Provides:      libobjc%{libobjc_sover} = %{version}-%{release}
 
-%description -n libobjc48
+%description -n libobjc%{libobjc_sover}%{libobjc_suffix}
 The library for the GNU Objective C compiler.
 
-%post -n libobjc48
+%post -n libobjc%{libobjc_sover}%{libobjc_suffix}
 /sbin/ldconfig
 
-%postun -n libobjc48
+%postun -n libobjc%{libobjc_sover}%{libobjc_suffix}
 /sbin/ldconfig
-# PACKAGE-END
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
-%package -n libobjc48-32bit
+%package -n libobjc%{libobjc_sover}%{libobjc_suffix}-32bit
 Summary:      Library for the GNU Objective C Compiler
 License:        GPL-3.0-with-GCC-exception
 Group:        Development/Libraries/Other
-Provides: libobjc2-32bit = %{version}-%{release}
-Conflicts: libobjc2-32bit < %{version}-%{release}
+Provides:      libobjc%{libobjc_sover}-32bit = %{version}-%{release}
 
-%description -n libobjc48-32bit
+%description -n libobjc%{libobjc_sover}%{libobjc_suffix}-32bit
 The library for the GNU Objective C compiler.
 
-%post -n libobjc48-32bit
+%post -n libobjc%{libobjc_sover}%{libobjc_suffix}-32bit
 /sbin/ldconfig
 
-%postun -n libobjc48-32bit
+%postun -n libobjc%{libobjc_sover}%{libobjc_suffix}-32bit
 /sbin/ldconfig
-# PACKAGE-END
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
-%package -n libobjc48-64bit
+%package -n libobjc%{libobjc_sover}%{libobjc_suffix}-64bit
 Summary:      Library for the GNU Objective C Compiler
 License:        GPL-3.0-with-GCC-exception
 Group:        Development/Libraries/Other
-Provides: libobjc2-64bit = %{version}-%{release}
-Conflicts: libobjc2-64bit < %{version}-%{release}
+Provides:      libobjc%{libobjc_sover}-64bit = %{version}-%{release}
 
-%description -n libobjc48-64bit
+%description -n libobjc%{libobjc_sover}%{libobjc_suffix}-64bit
 The library for the GNU Objective C compiler.
 
-%post -n libobjc48-64bit
+%post -n libobjc%{libobjc_sover}%{libobjc_suffix}-64bit
 /sbin/ldconfig
 
-%postun -n libobjc48-64bit
+%postun -n libobjc%{libobjc_sover}%{libobjc_suffix}-64bit
 /sbin/ldconfig
-# PACKAGE-END
 
 %package obj-c++
 Summary:      GNU Objective C++ Compiler
 License:        GPL-3.0+
-Group:        Development/Toolchain
+Group:        Development/Languages/Other
 Requires: gcc48-objc = %{version}-%{release}
 Requires: gcc48-c++ = %{version}-%{release}
 
@@ -631,19 +592,17 @@ Nextstep OS. The source code is available in the gcc package.
 %package -n cpp48
 Summary:      The GCC Preprocessor
 License:        GPL-3.0+
-Group:        Development/Toolchain
+Group:        Development/Languages/C and C++
 
 %description -n cpp48
 This Package contains just the preprocessor that is used by the X11
 packages.
 
 
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
 %package ada
 Summary:      GNU Ada95 Compiler Based on GCC (GNAT)
 License:        GPL-3.0+
-Group:        Development/Toolchain
+Group:        Development/Languages/Other
 Requires: gcc48 = %{version}-%{release}
 Requires: libada48 = %{version}-%{release}
 
@@ -652,13 +611,10 @@ This package contains an Ada95 compiler and associated development
 tools based on the GNU GCC technology. Ada95 is the object oriented
 successor of the Ada83 language. To build this package from source you
 must have installed a binary version to bootstrap the compiler.
-# PACKAGE-END
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
 %package ada-32bit
 Summary:      GNU Ada95 Compiler Based on GCC (GNAT)
 License:        GPL-3.0+
-Group:        Development/Toolchain
+Group:        Development/Languages/Other
 Requires: gcc48-32bit = %{version}-%{release}
 Requires: libada48-32bit = %{version}-%{release}
 
@@ -667,13 +623,10 @@ This package contains an Ada95 compiler and associated development
 tools based on the GNU GCC technology. Ada95 is the object oriented
 successor of the Ada83 language. To build this package from source you
 must have installed a binary version to bootstrap the compiler.
-# PACKAGE-END
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
 %package ada-64bit
 Summary:      GNU Ada95 Compiler Based on GCC (GNAT)
 License:        GPL-3.0+
-Group:        Development/Toolchain
+Group:        Development/Languages/Other
 Requires: gcc48-64bit = %{version}-%{release}
 Requires: libada48-64bit = %{version}-%{release}
 
@@ -682,19 +635,11 @@ This package contains an Ada95 compiler and associated development
 tools based on the GNU GCC technology. Ada95 is the object oriented
 successor of the Ada83 language. To build this package from source you
 must have installed a binary version to bootstrap the compiler.
-# PACKAGE-END
 
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
 %package -n libada48
 Summary:      GNU Ada Runtime Libraries
 License:      GPL-3.0-with-GCC-exception
 Group:        System/Libraries
-Provides: libgnarl-4_8 = %{version}-%{release}
-Conflicts: libgnarl-4_8 < %{version}-%{release}
-Provides: libgnat-4_8 = %{version}-%{release}
-Conflicts: libgnat-4_8 < %{version}-%{release}
-
 %description -n libada48
 This package contains the shared libraries required to run programs
 compiled with the GNU Ada compiler (GNAT) if they are compiled to use
@@ -708,18 +653,10 @@ implementation of Distributed Systems Programming (GLADE) and the Posix
 
 %postun -n libada48
 /sbin/ldconfig
-# PACKAGE-END
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
 %package -n libada48-32bit
 Summary:      GNU Ada Runtime Libraries
 License:      GPL-3.0-with-GCC-exception
 Group:        System/Libraries
-Provides: libgnarl-4_8-32bit = %{version}-%{release}
-Conflicts: libgnarl-4_8-32bit < %{version}-%{release}
-Provides: libgnat-4_8-32bit = %{version}-%{release}
-Conflicts: libgnat-4_8-32bit < %{version}-%{release}
-
 %description -n libada48-32bit
 This package contains the shared libraries required to run programs
 compiled with the GNU Ada compiler (GNAT) if they are compiled to use
@@ -733,18 +670,10 @@ implementation of Distributed Systems Programming (GLADE) and the Posix
 
 %postun -n libada48-32bit
 /sbin/ldconfig
-# PACKAGE-END
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
 %package -n libada48-64bit
 Summary:      GNU Ada Runtime Libraries
 License:      GPL-3.0-with-GCC-exception
 Group:        System/Libraries
-Provides: libgnarl-4_8-64bit = %{version}-%{release}
-Conflicts: libgnarl-4_8-64bit < %{version}-%{release}
-Provides: libgnat-4_8-64bit = %{version}-%{release}
-Conflicts: libgnat-4_8-64bit < %{version}-%{release}
-
 %description -n libada48-64bit
 This package contains the shared libraries required to run programs
 compiled with the GNU Ada compiler (GNAT) if they are compiled to use
@@ -758,246 +687,152 @@ implementation of Distributed Systems Programming (GLADE) and the Posix
 
 %postun -n libada48-64bit
 /sbin/ldconfig
-# PACKAGE-END
 
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
 %package fortran
 Summary:      The GNU Fortran Compiler and Support Files
 License:        GPL-3.0+
 Group:        Development/Languages/Fortran
 Requires: gcc48 = %{version}-%{release}
-%if 0%{!?build_optional_compiler:1}
-Requires: libgfortran3 >= %{version}-%{release}
-%ifarch %quadmath_arch
-Requires: libquadmath0 >= %{version}-%{release}
-%endif
-%else
-Requires: libgfortran48 = %{version}-%{release}
+Requires: libgfortran%{libgfortran_sover} >= %{version}-%{release}
 %ifarch %quadmath_arch
-Requires: libquadmath48 = %{version}-%{release}
-%endif
+Requires: libquadmath%{libquadmath_sover} >= %{version}-%{release}
 %endif
 
 %description fortran
 This is the Fortran compiler of the GNU Compiler Collection (GCC).
-# PACKAGE-END
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
 %package fortran-32bit
 Summary:      The GNU Fortran Compiler and Support Files
 License:        GPL-3.0+
 Group:        Development/Languages/Fortran
 Requires: gcc48 = %{version}-%{release}
-%if 0%{!?build_optional_compiler:1}
-Requires: libgfortran3-32bit >= %{version}-%{release}
-%ifarch %quadmath_arch
-Requires: libquadmath0-32bit >= %{version}-%{release}
-%endif
-%else
-Requires: libgfortran48-32bit = %{version}-%{release}
+Requires: libgfortran%{libgfortran_sover}-32bit >= %{version}-%{release}
 %ifarch %quadmath_arch
-Requires: libquadmath48-32bit = %{version}-%{release}
-%endif
+Requires: libquadmath%{libquadmath_sover}-32bit >= %{version}-%{release}
 %endif
 
 %description fortran-32bit
 This is the Fortran compiler of the GNU Compiler Collection (GCC).
-# PACKAGE-END
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
 %package fortran-64bit
 Summary:      The GNU Fortran Compiler and Support Files
 License:        GPL-3.0+
 Group:        Development/Languages/Fortran
 Requires: gcc48 = %{version}-%{release}
-%if 0%{!?build_optional_compiler:1}
-Requires: libgfortran3-64bit >= %{version}-%{release}
-%ifarch %quadmath_arch
-Requires: libquadmath0-64bit >= %{version}-%{release}
-%endif
-%else
-Requires: libgfortran48-64bit = %{version}-%{release}
+Requires: libgfortran%{libgfortran_sover}-64bit >= %{version}-%{release}
 %ifarch %quadmath_arch
-Requires: libquadmath48-64bit = %{version}-%{release}
-%endif
+Requires: libquadmath%{libquadmath_sover}-64bit >= %{version}-%{release}
 %endif
 
 %description fortran-64bit
 This is the Fortran compiler of the GNU Compiler Collection (GCC).
-# PACKAGE-END
 
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
-%package -n libgfortran48
+%package -n libgfortran%{libgfortran_sover}%{libgfortran_suffix}
 Summary:      The GNU Fortran Compiler Runtime Library
 License:        GPL-3.0-with-GCC-exception
 Group:        Development/Languages/Fortran
-%if 0%{!?build_optional_compiler:1}
-Provides: libgfortran3 = %{version}-%{release}
-Conflicts: libgfortran3 < %{version}-%{release}
 %ifarch %quadmath_arch
-Requires: libquadmath0 >= %{version}-%{release}
-%endif
-%else
-%ifarch %quadmath_arch
-Requires: libquadmath48 = %{version}-%{release}
-%endif
-Autoprov: no
+Requires: libquadmath%{libquadmath_sover} >= %{version}-%{release}
 %endif
+Provides:      libgfortran%{libgfortran_sover} = %{version}-%{release}
 
-%description -n libgfortran48
+%description -n libgfortran%{libgfortran_sover}%{libgfortran_suffix}
 The runtime library needed to run programs compiled with the Fortran compiler
 of the GNU Compiler Collection (GCC).
 
-%post -n libgfortran48
+%post -n libgfortran%{libgfortran_sover}%{libgfortran_suffix}
 /sbin/ldconfig
 
-%postun -n libgfortran48
+%postun -n libgfortran%{libgfortran_sover}%{libgfortran_suffix}
 /sbin/ldconfig
-# PACKAGE-END
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
-%package -n libgfortran48-32bit
+%package -n libgfortran%{libgfortran_sover}%{libgfortran_suffix}-32bit
 Summary:      The GNU Fortran Compiler Runtime Library
 License:        GPL-3.0-with-GCC-exception
 Group:        Development/Languages/Fortran
-%if 0%{!?build_optional_compiler:1}
-Provides: libgfortran3-32bit = %{version}-%{release}
-Conflicts: libgfortran3-32bit < %{version}-%{release}
 %ifarch %quadmath_arch
-Requires: libquadmath0-32bit >= %{version}-%{release}
-%endif
-%else
-%ifarch %quadmath_arch
-Requires: libquadmath48-32bit = %{version}-%{release}
-%endif
-Autoprov: no
+Requires: libquadmath%{libquadmath_sover}-32bit >= %{version}-%{release}
 %endif
+Provides:      libgfortran%{libgfortran_sover}-32bit = %{version}-%{release}
 
-%description -n libgfortran48-32bit
+%description -n libgfortran%{libgfortran_sover}%{libgfortran_suffix}-32bit
 The runtime library needed to run programs compiled with the Fortran compiler
 of the GNU Compiler Collection (GCC).
 
-%post -n libgfortran48-32bit
+%post -n libgfortran%{libgfortran_sover}%{libgfortran_suffix}-32bit
 /sbin/ldconfig
 
-%postun -n libgfortran48-32bit
+%postun -n libgfortran%{libgfortran_sover}%{libgfortran_suffix}-32bit
 /sbin/ldconfig
-# PACKAGE-END
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
-%package -n libgfortran48-64bit
+%package -n libgfortran%{libgfortran_sover}%{libgfortran_suffix}-64bit
 Summary:      The GNU Fortran Compiler Runtime Library
 License:        GPL-3.0-with-GCC-exception
 Group:        Development/Languages/Fortran
-%if 0%{!?build_optional_compiler:1}
-Provides: libgfortran3-64bit = %{version}-%{release}
-Conflicts: libgfortran3-64bit < %{version}-%{release}
 %ifarch %quadmath_arch
-Requires: libquadmath0-64bit >= %{version}-%{release}
-%endif
-%else
-%ifarch %quadmath_arch
-Requires: libquadmath48-64bit = %{version}-%{release}
-%endif
-Autoprov: no
+Requires: libquadmath%{libquadmath_sover}-64bit >= %{version}-%{release}
 %endif
+Provides:      libgfortran%{libgfortran_sover}-64bit = %{version}-%{release}
 
-%description -n libgfortran48-64bit
+%description -n libgfortran%{libgfortran_sover}%{libgfortran_suffix}-64bit
 The runtime library needed to run programs compiled with the Fortran compiler
 of the GNU Compiler Collection (GCC).
 
-%post -n libgfortran48-64bit
+%post -n libgfortran%{libgfortran_sover}%{libgfortran_suffix}-64bit
 /sbin/ldconfig
 
-%postun -n libgfortran48-64bit
+%postun -n libgfortran%{libgfortran_sover}%{libgfortran_suffix}-64bit
 /sbin/ldconfig
-# PACKAGE-END
 
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
-%package -n libquadmath48
+%package -n libquadmath%{libquadmath_sover}%{libquadmath_suffix}
 Summary:      The GNU Fortran Compiler Quadmath Runtime Library
 License:        LGPL-2.1
 Group:        Development/Languages/Fortran
-%if 0%{!?build_optional_compiler:1}
-Provides: libquadmath0 = %{version}-%{release}
-Conflicts: libquadmath0 < %{version}-%{release}
-%else
-Autoprov: no
-%endif
+Provides:      libquadmath%{libquadmath_sover} = %{version}-%{release}
 
-%description -n libquadmath48
+%description -n libquadmath%{libquadmath_sover}%{libquadmath_suffix}
 The runtime library needed to run programs compiled with the Fortran compiler
 of the GNU Compiler Collection (GCC) and quadruple precision floating point
 operations.
 
-%post -n libquadmath48
+%post -n libquadmath%{libquadmath_sover}%{libquadmath_suffix}
 /sbin/ldconfig
 
-%postun -n libquadmath48
+%postun -n libquadmath%{libquadmath_sover}%{libquadmath_suffix}
 /sbin/ldconfig
-# PACKAGE-END
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
-%package -n libquadmath48-32bit
+%package -n libquadmath%{libquadmath_sover}%{libquadmath_suffix}-32bit
 Summary:      The GNU Fortran Compiler Quadmath Runtime Library
 License:        LGPL-2.1
 Group:        Development/Languages/Fortran
-%if 0%{!?build_optional_compiler:1}
-Provides: libquadmath0-32bit = %{version}-%{release}
-Conflicts: libquadmath0-32bit < %{version}-%{release}
-%else
-Autoprov: no
-%endif
+Provides:      libquadmath%{libquadmath_sover}-32bit = %{version}-%{release}
 
-%description -n libquadmath48-32bit
+%description -n libquadmath%{libquadmath_sover}%{libquadmath_suffix}-32bit
 The runtime library needed to run programs compiled with the Fortran compiler
 of the GNU Compiler Collection (GCC) and quadruple precision floating point
 operations.
 
-%post -n libquadmath48-32bit
+%post -n libquadmath%{libquadmath_sover}%{libquadmath_suffix}-32bit
 /sbin/ldconfig
 
-%postun -n libquadmath48-32bit
+%postun -n libquadmath%{libquadmath_sover}%{libquadmath_suffix}-32bit
 /sbin/ldconfig
-# PACKAGE-END
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
-%package -n libquadmath48-64bit
+%package -n libquadmath%{libquadmath_sover}%{libquadmath_suffix}-64bit
 Summary:      The GNU Fortran Compiler Quadmath Runtime Library
 License:        LGPL-2.1
 Group:        Development/Languages/Fortran
-%if 0%{!?build_optional_compiler:1}
-Provides: libquadmath0-64bit = %{version}-%{release}
-Conflicts: libquadmath0-64bit < %{version}-%{release}
-%else
-Autoprov: no
-%endif
+Provides:      libquadmath%{libquadmath_sover}-64bit = %{version}-%{release}
 
-%description -n libquadmath48-64bit
+%description -n libquadmath%{libquadmath_sover}%{libquadmath_suffix}-64bit
 The runtime library needed to run programs compiled with the Fortran compiler
 of the GNU Compiler Collection (GCC) and quadruple precision floating point
 operations.
 
-%post -n libquadmath48-64bit
+%post -n libquadmath%{libquadmath_sover}%{libquadmath_suffix}-64bit
 /sbin/ldconfig
 
-%postun -n libquadmath48-64bit
+%postun -n libquadmath%{libquadmath_sover}%{libquadmath_suffix}-64bit
 /sbin/ldconfig
-# PACKAGE-END
 
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
 %package -n libmudflap48
 Summary:      The Mudflap Extension Runtime Library
 License:        GPL-3.0-with-GCC-exception
-Group:        Development/Toolchain
-Provides: libmudflap0 = %{version}-%{release}
-Conflicts: libmudflap0 < %{version}-%{release}
-Provides: libmudflapth0 = %{version}-%{release}
-Conflicts: libmudflapth0 < %{version}-%{release}
+Group:        Development/Languages/C and C++
 
 %description -n libmudflap48
 This is the Mudflap Extension Runtime Library.
@@ -1007,17 +842,10 @@ This is the Mudflap Extension Runtime Library.
 
 %postun -n libmudflap48
 /sbin/ldconfig
-# PACKAGE-END
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
 %package -n libmudflap48-32bit
 Summary:      The Mudflap Extension Runtime Library
 License:        GPL-3.0-with-GCC-exception
-Group:        Development/Toolchain
-Provides: libmudflap0-32bit = %{version}-%{release}
-Conflicts: libmudflap0-32bit < %{version}-%{release}
-Provides: libmudflapth0-32bit = %{version}-%{release}
-Conflicts: libmudflapth0-32bit < %{version}-%{release}
+Group:        Development/Languages/C and C++
 
 %description -n libmudflap48-32bit
 This is the Mudflap Extension Runtime Library.
@@ -1027,17 +855,10 @@ This is the Mudflap Extension Runtime Library.
 
 %postun -n libmudflap48-32bit
 /sbin/ldconfig
-# PACKAGE-END
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
 %package -n libmudflap48-64bit
 Summary:      The Mudflap Extension Runtime Library
 License:        GPL-3.0-with-GCC-exception
-Group:        Development/Toolchain
-Provides: libmudflap0-64bit = %{version}-%{release}
-Conflicts: libmudflap0-64bit < %{version}-%{release}
-Provides: libmudflapth0-64bit = %{version}-%{release}
-Conflicts: libmudflapth0-64bit < %{version}-%{release}
+Group:        Development/Languages/C and C++
 
 %description -n libmudflap48-64bit
 This is the Mudflap Extension Runtime Library.
@@ -1047,21 +868,181 @@ This is the Mudflap Extension Runtime Library.
 
 %postun -n libmudflap48-64bit
 /sbin/ldconfig
-# PACKAGE-END
+
+%package -n libitm%{libitm_sover}%{libitm_suffix}
+Summary:      The GNU Compiler Transactional Memory Runtime Library
+License:        MIT
+Group:        Development/Languages/C and C++
+
+%description -n libitm%{libitm_sover}%{libitm_suffix}
+The runtime library needed to run programs compiled with the
+-fgnu-tm option of the GNU Compiler Collection (GCC).
+
+%post -n libitm%{libitm_sover}%{libitm_suffix}
+/sbin/ldconfig
+
+%postun -n libitm%{libitm_sover}%{libitm_suffix}
+/sbin/ldconfig
+%package -n libitm%{libitm_sover}%{libitm_suffix}-32bit
+Summary:      The GNU Compiler Transactional Memory Runtime Library
+License:        MIT
+Group:        Development/Languages/C and C++
+
+%description -n libitm%{libitm_sover}%{libitm_suffix}-32bit
+The runtime library needed to run programs compiled with the
+-fgnu-tm option of the GNU Compiler Collection (GCC).
+
+%post -n libitm%{libitm_sover}%{libitm_suffix}-32bit
+/sbin/ldconfig
+
+%postun -n libitm%{libitm_sover}%{libitm_suffix}-32bit
+/sbin/ldconfig
+%package -n libitm%{libitm_sover}%{libitm_suffix}-64bit
+Summary:      The GNU Compiler Transactional Memory Runtime Library
+License:        MIT
+Group:        Development/Languages/C and C++
+
+%description -n libitm%{libitm_sover}%{libitm_suffix}-64bit
+The runtime library needed to run programs compiled with the
+-fgnu-tm option of the GNU Compiler Collection (GCC).
+
+%post -n libitm%{libitm_sover}%{libitm_suffix}-64bit
+/sbin/ldconfig
+
+%postun -n libitm%{libitm_sover}%{libitm_suffix}-64bit
+/sbin/ldconfig
+
+%package -n libasan%{libasan_sover}%{libasan_suffix}
+Summary:      The GNU Compiler Address Sanitizer Runtime Library
+License:        MIT
+Group:        Development/Languages/C and C++
+
+%description -n libasan%{libasan_sover}%{libasan_suffix}
+The runtime library needed to run programs compiled with the
+-fsanitize=address option of the GNU Compiler Collection (GCC).
+
+%post -n libasan%{libasan_sover}%{libasan_suffix}
+/sbin/ldconfig
+
+%postun -n libasan%{libasan_sover}%{libasan_suffix}
+/sbin/ldconfig
+%package -n libasan%{libasan_sover}%{libasan_suffix}-32bit
+Summary:      The GNU Compiler Address Sanitizer Runtime Library
+License:        MIT
+Group:        Development/Languages/C and C++
+
+%description -n libasan%{libasan_sover}%{libasan_suffix}-32bit
+The runtime library needed to run programs compiled with the
+-fsanitize=address option of the GNU Compiler Collection (GCC).
+
+%post -n libasan%{libasan_sover}%{libasan_suffix}-32bit
+/sbin/ldconfig
+
+%postun -n libasan%{libasan_sover}%{libasan_suffix}-32bit
+/sbin/ldconfig
+%package -n libasan%{libasan_sover}%{libasan_suffix}-64bit
+Summary:      The GNU Compiler Address Sanitizer Runtime Library
+License:        MIT
+Group:        Development/Languages/C and C++
+
+%description -n libasan%{libasan_sover}%{libasan_suffix}-64bit
+The runtime library needed to run programs compiled with the
+-fsanitize=address option of the GNU Compiler Collection (GCC).
+
+%post -n libasan%{libasan_sover}%{libasan_suffix}-64bit
+/sbin/ldconfig
+
+%postun -n libasan%{libasan_sover}%{libasan_suffix}-64bit
+/sbin/ldconfig
+
+%package -n libtsan%{libtsan_sover}%{libtsan_suffix}
+Summary:      The GNU Compiler Thread Sanitizer Runtime Library
+License:        MIT
+Group:        Development/Languages/C and C++
+
+%description -n libtsan%{libtsan_sover}%{libtsan_suffix}
+The runtime library needed to run programs compiled with the
+-fsanitize=thread option of the GNU Compiler Collection (GCC).
+
+%post -n libtsan%{libtsan_sover}%{libtsan_suffix}
+/sbin/ldconfig
+
+%postun -n libtsan%{libtsan_sover}%{libtsan_suffix}
+/sbin/ldconfig
+%package -n libtsan%{libtsan_sover}%{libtsan_suffix}-32bit
+Summary:      The GNU Compiler Thread Sanitizer Runtime Library
+License:        MIT
+Group:        Development/Languages/C and C++
+
+%description -n libtsan%{libtsan_sover}%{libtsan_suffix}-32bit
+The runtime library needed to run programs compiled with the
+-fsanitize=thread option of the GNU Compiler Collection (GCC).
+
+%post -n libtsan%{libtsan_sover}%{libtsan_suffix}-32bit
+/sbin/ldconfig
+
+%postun -n libtsan%{libtsan_sover}%{libtsan_suffix}-32bit
+/sbin/ldconfig
+%package -n libtsan%{libtsan_sover}%{libtsan_suffix}-64bit
+Summary:      The GNU Compiler Thread Sanitizer Runtime Library
+License:        MIT
+Group:        Development/Languages/C and C++
+
+%description -n libtsan%{libtsan_sover}%{libtsan_suffix}-64bit
+The runtime library needed to run programs compiled with the
+-fsanitize=thread option of the GNU Compiler Collection (GCC).
+
+%post -n libtsan%{libtsan_sover}%{libtsan_suffix}-64bit
+/sbin/ldconfig
+
+%postun -n libtsan%{libtsan_sover}%{libtsan_suffix}-64bit
+/sbin/ldconfig
+
+%package -n libatomic%{libatomic_sover}%{libatomic_suffix}
+Summary:      The GNU Compiler Atomic Operations Runtime Library
+License:      GPL-3.0-with-GCC-exception
+Group:        Development/Languages/C and C++
+
+%description -n libatomic%{libatomic_sover}%{libatomic_suffix}
+The runtime library for atomic operations of the GNU Compiler Collection (GCC).
+
+%post -n libatomic%{libatomic_sover}%{libatomic_suffix}
+/sbin/ldconfig
+
+%postun -n libatomic%{libatomic_sover}%{libatomic_suffix}
+/sbin/ldconfig
+%package -n libatomic%{libatomic_sover}%{libatomic_suffix}-32bit
+Summary:      The GNU Compiler Atomic Operations Runtime Library
+License:      GPL-3.0-with-GCC-exception
+Group:        Development/Languages/C and C++
+
+%description -n libatomic%{libatomic_sover}%{libatomic_suffix}-32bit
+The runtime library for atomic operations of the GNU Compiler Collection (GCC).
+
+%post -n libatomic%{libatomic_sover}%{libatomic_suffix}-32bit
+/sbin/ldconfig
+
+%postun -n libatomic%{libatomic_sover}%{libatomic_suffix}-32bit
+/sbin/ldconfig
+%package -n libatomic%{libatomic_sover}%{libatomic_suffix}-64bit
+Summary:      The GNU Compiler Atomic Operations Runtime Library
+License:      GPL-3.0-with-GCC-exception
+Group:        Development/Languages/C and C++
+
+%description -n libatomic%{libatomic_sover}%{libatomic_suffix}-64bit
+The runtime library for atomic operations of the GNU Compiler Collection (GCC).
+
+%post -n libatomic%{libatomic_sover}%{libatomic_suffix}-64bit
+/sbin/ldconfig
+
+%postun -n libatomic%{libatomic_sover}%{libatomic_suffix}-64bit
+/sbin/ldconfig
 
 
 %package -n libgcj48
-# LIBJAVA-DELETE-END
 Summary:      Java Runtime Library for gcc
 License:      GPL-2.0-with-classpath-exception
 Group:        System/Libraries
-%define gcj_sover 13
-Provides: libgcj%{gcj_sover} = %{version}-%{release}
-Conflicts: libgcj%{gcj_sover} < %{version}-%{release}
-Provides: libgij%{gcj_sover} = %{version}-%{release}
-Conflicts: libgij%{gcj_sover} < %{version}-%{release}
-Provides: libgcj-tools%{gcj_sover} = %{version}-%{release}
-Conflicts: libgcj-tools%{gcj_sover} < %{version}-%{release}
 
 %description -n libgcj48
 This library is needed if you want to use the GNU Java compiler, gcj.
@@ -1077,7 +1058,7 @@ Source code for this package is in gcc.
 %package -n gcc48-java
 Summary:      The GNU Java Compiler
 License:        GPL-3.0+
-Group:        Development/Languages
+Group:        Development/Languages/Java
 Requires: gcc48 = %{version}
 Requires: libgcj48-devel = %{version}-%{release}
 
@@ -1085,24 +1066,21 @@ Requires: libgcj48-devel = %{version}-%{release}
 The Java compiler from the GCC-tools-suite.
 
 
-%package -n libgcj_bc48
+%package -n libgcj_bc%{libgcj_bc_sover}%{libgcj_bc_suffix}
 Summary:      Fake library for BC-ABI compatibility.
 License:        GPL-2.0-with-classpath-exception
-Group:        Development/Libraries
-Provides: libgcj_bc1 = %{version}-%{release}
-Conflicts: libgcj_bc1 < %{version}-%{release}
+Group:        Development/Libraries/Java
 # libgcj_bc is special in that it just contains a symlink to
 # a proper libgcj version.  So require that library and add
 # provides for the shlib version as created at link time
-Requires: libgcj%{gcj_sover}
-%ifarch x86_64 
-Provides: libgcj_bc.so.1()(64bit)
+Requires: libgcj%{libgcj_sover} >= %{version}-%{release}
+%ifarch x86_64 ia64 ppc64 s390x sparc64 aarch64
+Provides: libgcj_bc.so.%{libgcj_bc_sover}()(64bit)
 %else
-Provides: libgcj_bc.so.1
+Provides: libgcj_bc.so.%{libgcj_bc_sover}
 %endif
 
-
-%description -n libgcj_bc48
+%description -n libgcj_bc%{libgcj_bc_sover}%{libgcj_bc_suffix}
 A fake library that is used at link time only. It ensures that
 binaries built with the BC-ABI link against a constant SONAME.
 This way, BC-ABI binaries continue to work if the SONAME underlying
@@ -1121,15 +1099,18 @@ These are the jar files that go along with the gcj front end to gcc.
 %package -n libgcj48-devel
 Summary:      Include Files and Libraries mandatory for Development.
 License:        GPL-2.0-with-classpath-exception
-Group:        Development/Libraries
+Group:        Development/Libraries/Java
 Requires: libstdc++48-devel = %{version}
-Requires: libgcj%{gcj_sover} >= %{version}-%{release}
-Requires: libgcj_bc1 >= %{version}-%{release}
+Requires: libgcj%{libgcj_sover} >= %{version}-%{release}
+Requires: libgcj_bc%{libgcj_bc_sover} >= %{version}-%{release}
 Requires: libgcj48-jar = %{version}-%{release}
 Requires: gtk2-devel
 Requires: libart_lgpl-devel
 Requires: glibc-devel
 Requires: zlib-devel
+%ifarch ia64
+Requires: libunwind-devel
+%endif
 
 %description -n libgcj48-devel
 This package contains all necessary include files and libraries needed
@@ -1139,122 +1120,86 @@ to develop applications that require these.
 %package -n gcc48-gij
 Summary:      Java Bytecode Interpreter for gcc
 License:      GPL-2.0-with-classpath-exception
-Group:        Development/Libraries
-Requires: libgcj%{gcj_sover} >= %{version}-%{release}
+Group:        Development/Libraries/Java
+Requires: libgcj%{libgcj_sover} >= %{version}-%{release}
 
 %description -n gcc48-gij
 This package contains the java bytecode interpreter gij and related tools.
 
-# LIBFFI-DELETE-END
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
-%package -n libffi48
+%package -n libffi%{libffi_sover}%{libffi_suffix}
 Summary:      Foreign Function Interface library
 License:        BSD-3-Clause
-Group:        Base/Libraries
-Provides: g-wrap:/usr/lib/libffi.so.4
-Provides: libffi4 = %{version}-%{release}
-Conflicts: libffi4 < %{version}-%{release}
+Group:        Development/Languages/C and C++
 
-%description -n libffi48
+%description -n libffi%{libffi_sover}%{libffi_suffix}
 A foreign function interface is the popular name for the interface that allows code written in one language to call code written in another language.
 
-%post -n libffi48
+%post -n libffi%{libffi_sover}%{libffi_suffix}
 /sbin/ldconfig
 
-%postun -n libffi48
+%postun -n libffi%{libffi_sover}%{libffi_suffix}
 /sbin/ldconfig
-# PACKAGE-END
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
-%package -n libffi48-32bit
+%package -n libffi%{libffi_sover}%{libffi_suffix}-32bit
 Summary:      Foreign Function Interface library
 License:        BSD-3-Clause
-Group:        Base/Libraries
-Provides: g-wrap:/usr/lib/libffi.so.4
-Provides: libffi4-32bit = %{version}-%{release}
-Conflicts: libffi4-32bit < %{version}-%{release}
+Group:        Development/Languages/C and C++
 
-%description -n libffi48-32bit
+%description -n libffi%{libffi_sover}%{libffi_suffix}-32bit
 A foreign function interface is the popular name for the interface that allows code written in one language to call code written in another language.
 
-%post -n libffi48-32bit
+%post -n libffi%{libffi_sover}%{libffi_suffix}-32bit
 /sbin/ldconfig
 
-%postun -n libffi48-32bit
+%postun -n libffi%{libffi_sover}%{libffi_suffix}-32bit
 /sbin/ldconfig
-# PACKAGE-END
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
-%package -n libffi48-64bit
+%package -n libffi%{libffi_sover}%{libffi_suffix}-64bit
 Summary:      Foreign Function Interface library
 License:        BSD-3-Clause
-Group:        Base/Libraries
-Provides: g-wrap:/usr/lib/libffi.so.4
-Provides: libffi4-64bit = %{version}-%{release}
-Conflicts: libffi4-64bit < %{version}-%{release}
+Group:        Development/Languages/C and C++
 
-%description -n libffi48-64bit
+%description -n libffi%{libffi_sover}%{libffi_suffix}-64bit
 A foreign function interface is the popular name for the interface that allows code written in one language to call code written in another language.
 
-%post -n libffi48-64bit
+%post -n libffi%{libffi_sover}%{libffi_suffix}-64bit
 /sbin/ldconfig
 
-%postun -n libffi48-64bit
+%postun -n libffi%{libffi_sover}%{libffi_suffix}-64bit
 /sbin/ldconfig
-# PACKAGE-END
 
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
 %package -n libffi48-devel
 Summary:      Foreign Function Interface library development files
 License:        BSD 3-Clause
-Group:        Development/Toolchain
-Requires: libffi4 >= %{version}-%{release}
-Provides: libffi-devel = %{version}-%{release}
-Conflicts: libffi-devel < %{version}-%{release}
+Group:        Development/Languages/C and C++
+Requires: libffi%{libffi_sover} >= %{version}-%{release}
 
 %description -n libffi48-devel
 A foreign function interface is the popular name for the interface that allows code written in one language to call code written in another language.
-# PACKAGE-END
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
 %package -n libffi48-devel-32bit
 Summary:      Foreign Function Interface library development files
 License:        BSD 3-Clause
-Group:        Development/Toolchain
-Requires: libffi4-32bit >= %{version}-%{release}
-Provides: libffi-devel-32bit = %{version}-%{release}
-Conflicts: libffi-devel-32bit < %{version}-%{release}
+Group:        Development/Languages/C and C++
+Requires: libffi%{libffi_sover}-32bit >= %{version}-%{release}
 
 %description -n libffi48-devel-32bit
 A foreign function interface is the popular name for the interface that allows code written in one language to call code written in another language.
-# PACKAGE-END
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
 %package -n libffi48-devel-64bit
 Summary:      Foreign Function Interface library development files
 License:        BSD 3-Clause
-Group:        Development/Toolchain
-Requires: libffi4-64bit >= %{version}-%{release}
-Provides: libffi-devel-64bit = %{version}-%{release}
-Conflicts: libffi-devel-64bit < %{version}-%{release}
+Group:        Development/Languages/C and C++
+Requires: libffi%{libffi_sover}-64bit >= %{version}-%{release}
 
 %description -n libffi48-devel-64bit
 A foreign function interface is the popular name for the interface that allows code written in one language to call code written in another language.
-# PACKAGE-END
 
 %package -n gcc48-testresults
-# GCC-TESTSUITE-DELETE-END
 Summary:      Testsuite results
-License:       Public-Domain
-Group:        Development/Toolchain
+License:       SUSE-Public-Domain
+Group:        Development/Languages/C and C++
 
 %description -n gcc48-testresults
 Results from running the gcc and target library testsuites.
 
 
-# COMMON-BEGIN
 
 # Define the canonical target and host architecture
 #   %gcc_target_arch  is supposed to be the full target triple
@@ -1263,6 +1208,12 @@ Results from running the gcc and target library testsuites.
 %if 0%{?gcc_target_arch:1}
 %define CONFIGURE_TARGET %{gcc_target_arch}
 %define TARGET_ARCH %(echo %{gcc_target_arch} | cut -d - -f 1 | sed -e "s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;")
+%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "powerpc"
+%define CONFIGURE_TARGET powerpc64-tizen-linux
+%endif
+%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "powerpc64"
+%define CONFIGURE_TARGET powerpc64-tizen-linux
+%endif
 %if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "i586"
 %define CONFIGURE_TARGET i586-tizen-linux
 %endif
@@ -1272,11 +1223,8 @@ Results from running the gcc and target library testsuites.
 %if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "armv7hl"
 %define CONFIGURE_TARGET armv7hl-tizen-linux-gnueabi
 %endif
-%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "armv7el"
-%define CONFIGURE_TARGET armv7el-tizen-linux-gnueabi
-%endif
-%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "armv5el"
-%define CONFIGURE_TARGET armv5el-tizen-linux-gnueabi
+%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "armv5tel"
+%define CONFIGURE_TARGET armv5tel-tizen-linux-gnueabi
 %endif
 %else
 %define TARGET_ARCH %(echo %{_target_cpu} | sed -e "s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;")
@@ -1285,44 +1233,46 @@ Results from running the gcc and target library testsuites.
 
 %define biarch %(case " %{biarch_targets} " in (*" %{TARGET_ARCH} "*) echo 1;; (*) echo 0;; esac)
 
+%ifarch ppc
+%define GCCDIST powerpc64-tizen-linux
+%else
+%ifarch %sparc
+%define GCCDIST sparc64-tizen-linux
+%else
 %ifarch %arm
 %define GCCDIST %{HOST_ARCH}-tizen-linux-gnueabi
 %else
 %define GCCDIST %{HOST_ARCH}-tizen-linux
 %endif
+%endif
+%endif
 
 %define libsubdir %{_libdir}/gcc/%{GCCDIST}/%{gcc_dir_version}
 %define gxxinclude %{_prefix}/include/c++/%{gcc_dir_version}
 
-# COMMON-END
 
 # Versionspecific directories
 %define versmainlibdir %{libsubdir}
 %define versmainlibdirbi32 %{libsubdir}/32
 %define versmainlibdirbi64 %{libsubdir}/64
+%ifarch ppc
+%define versmainlibdirbi32 %{libsubdir}
+%define versmainlibdirbi64 %{libsubdir}/64
+%endif
 %if %{build_primary_64bit}
 %define versmainlibdirbi %{versmainlibdirbi32}
 %else
 %define versmainlibdirbi %{versmainlibdirbi64}
 %endif
 
-%if 0%{?build_optional_compiler:1}
-%define mainlibdir %{versmainlibdir}
-%define mainlibdirbi32 %{versmainlibdirbi32}
-%define mainlibdirbi64 %{versmainlibdirbi64}
-%define noflibdir %{versnoflibdir}
-%define mainlibdirbi %{versmainlibdirbi}
-%else
 %define mainlibdir %{_libdir}
 %define mainlibdirbi32 %{_prefix}/lib
 %define mainlibdirbi64 %{_prefix}/lib64
-%define noflibdir %{_prefix}/lib/nof
 %if %{build_primary_64bit}
 %define mainlibdirbi %{mainlibdirbi32}
 %else
 %define mainlibdirbi %{mainlibdirbi64}
 %endif
-%endif
 
 
 # Now define a few macros that make it easy to package libs and
@@ -1330,88 +1280,51 @@ Results from running the gcc and target library testsuites.
 # exact path the files are in.
 #   %mainlib  package X from all dirs that belong to the main package
 #   %biarchlib   package X from all dirs that belong to the -32/64bit package
-# by default, nof libs go where the 32bit libs go.
-%if %{build_nof}
-%define mainlib() %{mainlibdir}/%1\
-%{noflibdir}/%1\
-%{nil}
-%else
 %define mainlib() %{mainlibdir}/%1\
 %{nil}
-%endif
 %define biarchlib() %{nil}
 %if %{biarch}
 %if !%{separate_biarch}
-%if %{build_nof}
 %define mainlib() %{mainlibdir}/%1\
 %{mainlibdirbi}/%1\
-%{noflibdir}/%1\
-%{nil}
-%else
-%define mainlib() %{mainlibdir}/%1\
-%{mainlibdirbi}/%1\
-%{nil}
-%endif
-%else
-%if %{build_nof}
-%define biarchlib() %{mainlibdirbi}/%1\
-%{noflibdir}/%1\
-%{nil}
-%define mainlib() %{mainlibdir}/%1\
 %{nil}
 %else
 %define biarchlib() %{mainlibdirbi}/%1\
 %{nil}
 %endif
 %endif
-%endif
 
-%if %{build_nof}
-%define versmainlib() %{versmainlibdir}/%1\
-%{versnoflibdir}/%1\
-%{nil}
-%else
 %define versmainlib() %{versmainlibdir}/%1\
 %{nil}
-%endif
 %define versbiarchlib() %{nil}
 %if %{biarch}
 %if !%{separate_biarch}
-%if %{build_nof}
-%define versmainlib() %{versmainlibdir}/%1\
-%{versmainlibdirbi}/%1\
-%{versnoflibdir}/%1\
-%{nil}
-%else
 %define versmainlib() %{versmainlibdir}/%1\
 %{versmainlibdirbi}/%1\
 %{nil}
-%endif
-%else
-%if %{build_nof}
-%define versbiarchlib() %{versmainlibdirbi}/%1\
-%{versnoflibdir}/%1\
-%{nil}
-%define versmainlib() %{versmainlibdir}/%1\
-%{nil}
 %else
 %define versbiarchlib() %{versmainlibdirbi}/%1\
 %{nil}
 %endif
 %endif
-%endif
 
 
-# COMMON-BEGIN
 
 %prep
-#%setup -q -n gcc-%{gcc_version}%{snapshot_date}
-%setup -q -n gcc-%{version}
-# 0001-dir-version.patch
-%patch0 -p1
-%patch1 -p1
-%patch2 -p1
-%patch3 -p1
+%setup -q -n gcc-%{gcc_version}%{snapshot_date}
+
+
+# We are configuring ppc as ppc64 but with switched multilibs.  Adjust
+# the libstdc++ abi testsuite baseline files accordingly
+%ifarch ppc
+if [ -d libstdc++-v3/config/abi/post/powerpc64-linux-gnu ]; then
+  mkdir -p libstdc++-v3/config/abi/post/powerpc64-linux-gnu/64
+  mv libstdc++-v3/config/abi/post/powerpc64-linux-gnu/baseline_symbols.txt \
+       libstdc++-v3/config/abi/post/powerpc64-linux-gnu/64/
+  mv libstdc++-v3/config/abi/post/powerpc64-linux-gnu/32/baseline_symbols.txt \
+       libstdc++-v3/config/abi/post/powerpc64-linux-gnu/
+fi
+%endif
 
 %build
 # Avoid rebuilding of generated files
@@ -1442,6 +1355,10 @@ RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-fno-rtti//g' -e 's/-fno-exceptions
 # default compiler settings now.
 RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-mcpu=i.86//g' -e 's/-march=i.86//g' -e 's/-mtune=i.86//g'`
 %endif
+%ifarch s390 s390x
+RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-fsigned-char//g'`
+RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-O1/-O2/g'`
+%endif
 %if 0%{?gcc_target_arch:1} && 0%{!?gcc_icecream:1}
 # Kill all -march/tune/cpu because that screws building the target libs
 RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-m\(arch\|tune\|cpu\)=[^ ]*//g'`
@@ -1504,7 +1421,7 @@ export _POSIX2_VERSION=199209
 # if glibc supports SSP.  When cross compiling we would need
 # to install a cross glibc, which we don't, or make the whole
 # thing point to the native glibc, which is in /, hence the
-# --with-sysroot=/
+# --with-build-sysroot=/
 
 %if %{build_ada}
 # Using the host gnatmake like
@@ -1525,26 +1442,27 @@ export PATH="`pwd`/host-tools/bin:$PATH"
 #      --enable-threads=posix \
 #%endif
 #      --enable-shared \
+%if "%{TARGET_ARCH}" == "armv7l" || "%{TARGET_ARCH}" == "armv7hl"
+# temporary workaround for a miscompilation of hash functions in java code
+GCJ_EXTRA_FLAGS="-marm"
+%endif
 CFLAGS="$RPM_OPT_FLAGS" CXXFLAGS="$RPM_OPT_FLAGS" XCFLAGS="$RPM_OPT_FLAGS" \
-TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
+TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS $GCJ_EXTRA_FLAGS" \
 ../configure \
        --prefix=%{_prefix} \
        --infodir=%{_infodir} \
        --mandir=%{_mandir} \
        --libdir=%{_libdir} \
        --libexecdir=%{_libdir} \
+    --disable-bootstrap \
        --enable-languages=$languages \
        $ENABLE_CHECKING \
        --with-gxx-include-dir=%{_prefix}/include/c++/%{gcc_dir_version} \
        --enable-ssp \
        --disable-libssp \
-       --disable-libitm \
-%if 0%{?fast_build}
-       --disable-bootstrap \
-%endif
        --disable-plugin \
        --with-bugurl="http://bugs.tizen.org/" \
-       --with-pkgversion="Tizen Linux" \
+       --with-pkgversion="Tizen" \
 %if !%{build_libjava}
         --disable-libgcj \
 %else
@@ -1575,12 +1493,14 @@ TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
 %if 0%{?canonical_target:1}
        --with-build-time-tools=/usr/%{canonical_target}-tizen-linux%{?canonical_target_abi:%canonical_target_abi}/bin \
 %endif
+%if 0%{?sysroot:1}
+       --with-sysroot=%sysroot \
+%endif
 %if 0%{?build_static:1}
        --disable-shared \
 %endif
 %if "%{TARGET_ARCH}" == "spu"
-       --with-sysroot=/usr/spu \
-       --with-gxx-include-dir=%{_prefix}/spu/include/c++/%{gcc_dir_version} \
+       --with-gxx-include-dir=%sysroot/include/c++/%{gcc_dir_version} \
        --with-newlib \
 %endif
        --disable-nls \
@@ -1588,8 +1508,12 @@ TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
 %else
        --program-suffix=%{binsuffix} \
        --enable-linux-futex \
+%ifarch ia64
+       --with-system-libunwind \
+%else
        --without-system-libunwind \
 %endif
+%endif
 %if "%{TARGET_ARCH}" == "armv5tel"
        --with-arch=armv5te \
        --with-float=soft \
@@ -1597,15 +1521,15 @@ TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
        --with-abi=aapcs-linux \
        --disable-sjlj-exceptions \
 %endif
-%if "%{TARGET_ARCH}" == "armv7el" 
+%if "%{TARGET_ARCH}" == "armv7l" 
        --with-arch=armv7-a \
        --with-tune=cortex-a9 \
-       --with-float=soft \
-       --with-abi=softfp \
-       --with-fpu=vfpv3 \
+       --with-float=hard \
+       --with-abi=aapcs-linux \
+       --with-fpu=vfpv3-d16 \
        --disable-sjlj-exceptions \
 %endif
-%if "%{TARGET_ARCH}" == "armv7l" || "%{TARGET_ARCH}" == "armv7hl"
+%if  "%{TARGET_ARCH}" == "armv7hl"
        --with-arch=armv7-a \
        --with-tune=cortex-a9 \
        --with-float=hard \
@@ -1613,6 +1537,22 @@ TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
        --with-fpu=vfpv3-d16 \
        --disable-sjlj-exceptions \
 %endif
+%if "%{TARGET_ARCH}" == "powerpc" || "%{TARGET_ARCH}" == "powerpc64"
+%if "%{TARGET_ARCH}" == "powerpc"
+       --with-cpu=default32 \
+%endif
+       --with-cpu-64=power4 \
+       --enable-secureplt \
+       --with-long-double-128 \
+%endif
+%if "%{TARGET_ARCH}" == "sparc64"
+       --with-cpu=ultrasparc \
+       --with-long-double-128 \
+%endif
+%if "%{TARGET_ARCH}" == "sparc"
+       --with-cpu=v8 \
+       --with-long-double-128 \
+%endif
 %if "%{TARGET_ARCH}" == "i586"
        --with-arch-32=i586 \
        --with-tune=generic \
@@ -1621,23 +1561,28 @@ TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
        --with-arch-32=i586 \
        --with-tune=generic \
 %endif
+%if "%{TARGET_ARCH}" == "s390"
+        --with-tune=z196 --with-arch=z10 \
+       --with-long-double-128 \
+       --enable-decimal-float \
+%endif
+%if "%{TARGET_ARCH}" == "s390x"
+        --with-tune=z196 --with-arch=z10 \
+       --with-long-double-128 \
+       --enable-decimal-float \
+%endif
        --build=%{GCCDIST}
 
-# COMMON-END
 
 %if 0%{?building_libffi:1}
 make stage1-bubble $PARALLEL
 make all-target-libffi $PARALLEL
 %else
+STAGE1_FLAGS="-g"
 # Only run profiled bootstrap on archs where it works
-#%ifarch %ix86 x86_64 
-#make profiledbootstrap-lean STAGE1_CFLAGS="-O -g" BOOT_CFLAGS="$RPM_OPT_FLAGS" $PARALLEL
+#%ifarch %ix86 x86_64 ppc ppc64 ia64
+#make profiledbootstrap-lean STAGE1_CFLAGS="$STAGE1_FLAGS" BOOT_CFLAGS="$RPM_OPT_FLAGS" $PARALLEL
 #%else
-%ifarch %arm
-STAGE1_FLAGS="-O0"
-%else
-STAGE1_FLAGS="-O -g"
-%endif
 #make bootstrap-lean STAGE1_CFLAGS="$STAGE1_FLAGS" BOOT_CFLAGS="$RPM_OPT_FLAGS" $PARALLEL
 make STAGE1_CFLAGS="$STAGE1_FLAGS" BOOT_CFLAGS="$RPM_OPT_FLAGS" $PARALLEL
 #%endif
@@ -1648,6 +1593,8 @@ echo "Run testsuite"
 (make -C %{GCCDIST}/libstdc++-v3 check-abi || true)
 mv %{GCCDIST}/libstdc++-v3/testsuite/libstdc++.log %{GCCDIST}/libstdc++-v3/testsuite/libstdc++-abi.log
 mv %{GCCDIST}/libstdc++-v3/testsuite/libstdc++.sum %{GCCDIST}/libstdc++-v3/testsuite/libstdc++-abi.sum
+# asan needs a whole shadow address space
+ulimit -v unlimited || true
 make -k check $PARALLEL || true
 mkdir ../testresults
 ../contrib/test_summary | tee ../testresults/test_summary.txt
@@ -1657,7 +1604,6 @@ mkdir ../testresults
 %install
 export NO_BRP_CHECK_BYTECODE_VERSION=true
 cd obj-%{GCCDIST}
-# GCC-TESTSUITE-DELETE-BEGIN
 # Work around tail/head -1 changes
 export _POSIX2_VERSION=199209
 export LIBRARY_PATH=$RPM_BUILD_ROOT%{libsubdir}:$RPM_BUILD_ROOT%{mainlibdirbi}
@@ -1702,11 +1648,13 @@ rm -f $RPM_BUILD_ROOT%{libsubdir}/include/ffitarget.h
 rm -f $RPM_BUILD_ROOT%{_mandir}/man3/ffi%{binsuffix}.3*
 rm -f $RPM_BUILD_ROOT%{_mandir}/man3/ffi_call%{binsuffix}.3*
 rm -f $RPM_BUILD_ROOT%{_mandir}/man3/ffi_prep_cif%{binsuffix}.3*
+rm -f $RPM_BUILD_ROOT%{_mandir}/man3/ffi_prep_cif_var%{binsuffix}.3*
 %endif
 
 # Remove some useless .la files
 for lib in libobjc libgfortran libgfortranbegin libquadmath libcaf_single \
-    libmudflap libmudflapth libgomp libstdc++ libsupc++ libgcj-tools libgij; do
+    libmudflap libmudflapth libgomp libstdc++ libsupc++ libgcj-tools libgij \
+    libasan libatomic libitm libtsan; do
   rm -f $RPM_BUILD_ROOT%{versmainlibdir}/$lib.la
 %if %{biarch}
   rm -f $RPM_BUILD_ROOT%{versmainlibdirbi}/$lib.la
@@ -1722,8 +1670,6 @@ mkdir -p $RPM_BUILD_ROOT%{_prefix}/lib64
 %endif
 %endif
 
-# LIBFFI-DELETE-BEGIN
-# LIBJAVA-DELETE-BEGIN
 %if %{build_cp}
 # Merge multilib c++config.h to allow omitting the duplicate and
 # identical other arch specific headers
@@ -1769,9 +1715,7 @@ if ! test -z "$dir_ml"; then
   ln -s . $RPM_BUILD_ROOT%{_prefix}/include/c++/%{gcc_dir_version}/%{GCCDIST}/$dir_ml
 fi
 %endif
-# LIBJAVA-DELETE-END
 
-%if 0%{!?build_optional_compiler:1}
 # move shared libs from versionspecific dir to main libdir
 for libname in \
 %if 0%{?building_libjava:1}
@@ -1790,6 +1734,18 @@ for libname in \
   libstdc++ \
 %endif
   libgomp \
+%ifarch %atomic_arch
+  libatomic \
+%endif
+%ifarch %itm_arch
+  libitm \
+%endif
+%ifarch %asan_arch
+  libasan \
+%endif
+%ifarch %tsan_arch
+  libtsan \
+%endif
 %if %{build_with_mudflap}
   libmudflap libmudflapth \
 %endif
@@ -1810,6 +1766,12 @@ for libname in \
   fi
 %endif
 done
+# FIXME, tsan is not multilib
+%ifarch %tsan_arch
+%if %{biarch}
+rm -f $RPM_BUILD_ROOT%{versmainlibdirbi}/libtsan.so
+%endif
+%endif
 %if %{build_cp}
 %if !0%{?building_libjava:1}
 # And we want to move the shlib gdb pretty printers to a more sane
@@ -1833,18 +1795,15 @@ sed -i -e '/^libdir/s/\/gcc\/%{GCCDIST}\/%{gcc_dir_version}//g' $RPM_BUILD_ROOT%
 for lib in `find $RPM_BUILD_ROOT%{versmainlibdir} -maxdepth 1 -name libgcj_bc.so.*`; do
   rm $lib
 done
-ln -s libgcj.so.%{gcj_sover} $RPM_BUILD_ROOT%{mainlibdir}/libgcj_bc.so.1
+ln -s libgcj.so.%{libgcj_sover} $RPM_BUILD_ROOT%{mainlibdir}/libgcj_bc.so.%{libgcj_bc_sover}
 %if %{biarch_libjava}
 for lib in `find $RPM_BUILD_ROOT%{versmainlibdirbi} -maxdepth 1 -name libgcj_bc.so.*`; do
   rm $lib
 done
-ln -s libgcj.so.%{gcj_sover} $RPM_BUILD_ROOT%{mainlibdirbi}/libgcj_bc.so.1
-%endif
+ln -s libgcj.so.%{libgcj_sover} $RPM_BUILD_ROOT%{mainlibdirbi}/libgcj_bc.so.%{libgcj_bc_sover}
 %endif
 %endif
 
-# LIBJAVA-DELETE-BEGIN
-%if 0%{!?build_optional_compiler:1}
 # Move libgcc_s around
 if test -L $RPM_BUILD_ROOT/%{_lib}/libgcc_s.so; then
   rm -f $RPM_BUILD_ROOT/%{_lib}/libgcc_s.so
@@ -1875,51 +1834,7 @@ ln -sf %{versmainlibdirbi64}/libgcc_s.so $RPM_BUILD_ROOT%{versmainlibdirbi64}/li
 chmod a+x $RPM_BUILD_ROOT/lib64/libgcc_s.so.%{libgcc_s}
 %endif
 %endif
-%else
-# Move libgcc_s around
-mv $RPM_BUILD_ROOT/%{_lib}/libgcc_s.so.%{libgcc_s} $RPM_BUILD_ROOT%{versmainlibdir}/
-if test -L $RPM_BUILD_ROOT/%{_lib}/libgcc_s.so; then
-  rm -f $RPM_BUILD_ROOT/%{_lib}/libgcc_s.so
-  ln -sf %{versmainlibdir}/libgcc_s.so.%{libgcc_s} $RPM_BUILD_ROOT%{versmainlibdir}/libgcc_s.so
-else
-  mv $RPM_BUILD_ROOT/%{_lib}/libgcc_s.so $RPM_BUILD_ROOT%{versmainlibdir}/
-fi
-chmod a+x $RPM_BUILD_ROOT%{versmainlibdir}/libgcc_s.so.%{libgcc_s}
-%if %{biarch}
-%if %{build_primary_64bit}
-mv $RPM_BUILD_ROOT/lib/libgcc_s.so.%{libgcc_s} $RPM_BUILD_ROOT%{versmainlibdirbi32}/
-if test -L $RPM_BUILD_ROOT/lib/libgcc_s.so; then
-  rm -f $RPM_BUILD_ROOT/lib/libgcc_s.so
-  ln -sf %{versmainlibdirbi32}/libgcc_s.so.%{libgcc_s} $RPM_BUILD_ROOT%{versmainlibdirbi32}/libgcc_s.so
-else
-  mv $RPM_BUILD_ROOT/lib/libgcc_s.so $RPM_BUILD_ROOT%{versmainlibdirbi32}/
-fi
-ln -sf %{versmainlibdirbi32}/libgcc_s.so $RPM_BUILD_ROOT%{versmainlibdirbi32}/libgcc_s_32.so
-chmod a+x $RPM_BUILD_ROOT%{versmainlibdirbi32}/libgcc_s.so.%{libgcc_s}
-%else
-# 32-bit biarch systems
-mv $RPM_BUILD_ROOT/lib64/libgcc_s.so.%{libgcc_s} $RPM_BUILD_ROOT%{versmainlibdirbi64}/
-if test -L $RPM_BUILD_ROOT/lib64/libgcc_s.so; then
-  rm -f $RPM_BUILD_ROOT/lib64/libgcc_s.so
-  ln -sf %{versmainlibdirbi64}/libgcc_s.so.%{libgcc_s} $RPM_BUILD_ROOT%{versmainlibdirbi64}/libgcc_s.so
-else
-  mv $RPM_BUILD_ROOT/lib64/libgcc_s.so $RPM_BUILD_ROOT%{versmainlibdirbi64}/
-fi
-ln -sf %{versmainlibdirbi64}/libgcc_s.so $RPM_BUILD_ROOT%{versmainlibdirbi64}/libgcc_s_64.so
-chmod a+x $RPM_BUILD_ROOT%{versmainlibdirbi64}/libgcc_s.so.%{libgcc_s}
-%endif
-%endif
-%endif
 
-# Provide a defaults.spec file which adds a proper rpath
-%if 0%{?build_optional_compiler:1}
-cat > $RPM_BUILD_ROOT%{libsubdir}/defaults.spec << EOF
-*link:
-+ %%{!m32:%%{!m64:-rpath=%{libsubdir}}} %%{m32:-rpath=%{libsubdir}/32} %%{m64:-rpath=%{libsubdir}/64}
-EOF
-%endif
-# LIBJAVA-DELETE-END
-# LIBFFI-DELETE-END
 
 %if %{build_ada}
 mv $RPM_BUILD_ROOT%{libsubdir}/adalib/lib*-*.so $RPM_BUILD_ROOT%{_libdir}
@@ -1956,14 +1871,11 @@ for l in `find $RPM_BUILD_ROOT -name '*.la'`; do
   mv $l.new $l
 done
 
-# GCC-TESTSUITE-DELETE-END
 %if 0%{?run_tests:1} 
 cp `find . -name "*.sum"` ../testresults/
 cp `find . -name "*.log"  \! -name "config.log" | grep -v 'acats.\?/tests' ` ../testresults/
 chmod 644 ../testresults/*
 %endif
-# GCC-TESTSUITE-DELETE-BEGIN
-# LIBFFI-DELETE-BEGIN
 %if %{build_cp}
 # Find C++ and Java headers
 find $RPM_BUILD_ROOT%{_prefix}/include/c++ \
@@ -1971,7 +1883,6 @@ find $RPM_BUILD_ROOT%{_prefix}/include/c++ \
   -o \( -type d -printf "%%%%dir " , \
         -printf "%{_prefix}/include/c++/%%P\n" \) > ../c++-headers
 %endif
-# LIBFFI-DELETE-END
 # Remove files that we do not need to clean up filelist
 rm -f $RPM_BUILD_ROOT%{_prefix}/bin/%{GCCDIST}-*
 rm -rf $RPM_BUILD_ROOT%{libsubdir}/install-tools
@@ -2007,6 +1918,9 @@ crt32_list=$RPM_BUILD_ROOT%{versmainlibdirbi32}/crt*.o
 crt64_list=$RPM_BUILD_ROOT%{versmainlibdirbi64}/crt*.o
 %endif
 %endif
+for o in $crt_list $crt32_list $crt64_list; do
+  objcopy -R ".comment.SUSE.OPTs" $o
+done
 %endif
 
 %if 0%{?building_libjava:1}
@@ -2060,9 +1974,6 @@ rm -f $RPM_BUILD_ROOT%{_mandir}/man7/fsf-funding.7
 rm -f $RPM_BUILD_ROOT%{_mandir}/man7/gfdl.7
 rm -f $RPM_BUILD_ROOT%{_mandir}/man7/gpl.7
 rm -f $RPM_BUILD_ROOT%{_libdir}/libiberty.a
-%if %{build_nof}
-rm -f $RPM_BUILD_ROOT%{_prefix}/lib/nof/libiberty.a
-%endif
 %if %{biarch}
 %if %{build_primary_64bit}
 rm -f $RPM_BUILD_ROOT%{_prefix}/lib/libiberty.a
@@ -2073,7 +1984,6 @@ rm -f $RPM_BUILD_ROOT%{_prefix}/lib64/libiberty.a
 rm -f $RPM_BUILD_ROOT%{libsubdir}/liblto_plugin.a
 rm -f $RPM_BUILD_ROOT%{libsubdir}/liblto_plugin.la
 
-# LIBFFI-DELETE-BEGIN
 %if 0%{?building_libjava:1}
 # For building libjava only we need to delete other info docs
 rm $RPM_BUILD_ROOT%{_infodir}/cp-tools.info*
@@ -2086,6 +1996,9 @@ cp $RPM_SOURCE_DIR/ecj.jar $RPM_BUILD_ROOT%{libsubdir}
 # For regular build, some info files do not get renamed properly.
 # Do so here.
 mv $RPM_BUILD_ROOT%{_infodir}/libgomp.info $RPM_BUILD_ROOT%{_infodir}/libgomp%{binsuffix}.info
+%ifarch %itm_arch
+mv $RPM_BUILD_ROOT%{_infodir}/libitm.info $RPM_BUILD_ROOT%{_infodir}/libitm%{binsuffix}.info
+%endif
 %if %{build_fortran} 
 %ifarch %quadmath_arch
 mv $RPM_BUILD_ROOT%{_infodir}/libquadmath.info $RPM_BUILD_ROOT%{_infodir}/libquadmath%{binsuffix}.info
@@ -2098,9 +2011,11 @@ mv $RPM_BUILD_ROOT%{_infodir}/gnat_ugn.info $RPM_BUILD_ROOT%{_infodir}/gnat_ugn%
 %endif
 %endif
 
-# LIBJAVA-DELETE-BEGIN
 cd ..
-%find_lang gcc48-locale --all-name
+%find_lang cpplib%{binsuffix}
+%find_lang gcc%{binsuffix}
+cat cpplib%{binsuffix}.lang gcc%{binsuffix}.lang > gcc48-locale.lang
+
 
 %post info
 %install_info --info-dir=%{_infodir} %{_infodir}/cpp%{binsuffix}.info.gz
@@ -2121,7 +2036,7 @@ cd ..
 %if %{build_ada}
 %install_info --info-dir=%{_infodir} %{_infodir}/gnat-style%{binsuffix}.info.gz
 %install_info --info-dir=%{_infodir} %{_infodir}/gnat_rm%{binsuffix}.info.gz
-%install_info --info-dir=%{_infodir} --section="GNU Ada tools" --entry="* GNAT User's Guide: (gnat_ugn). GNAT User's Guide for Unix Platforms" %{_infodir}/gnat_ugn%{binsuffix}.info.gz
+%install_info --info-dir=%{_infodir} %{_infodir}/gnat_ugn%{binsuffix}.info.gz
 %endif
 
 %postun info
@@ -2146,9 +2061,7 @@ cd ..
 %install_info_delete --info-dir=%{_infodir} %{_infodir}/gnat_ugn%{binsuffix}.info.gz
 %endif
 
-
 %files
-%license COPYING  COPYING3  COPYING3.LIB  COPYING.LIB  COPYING.RUNTIME
 %defattr(-,root,root)
 %dir %{_libdir}/gcc
 %dir %{_libdir}/gcc/%{GCCDIST}
@@ -2162,9 +2075,6 @@ cd ..
 %dir %{libsubdir}/64
 %endif
 %endif
-%if %{build_nof}
-%dir %{libsubdir}/nof
-%endif
 %{_prefix}/bin/gcc%{binsuffix}
 %{_prefix}/bin/gcov%{binsuffix}
 %{_prefix}/bin/gcc-ar%{binsuffix}
@@ -2190,6 +2100,25 @@ cd ..
 %{libsubdir}/include/stdint-gcc.h
 %{libsubdir}/include/stdnoreturn.h
 %{libsubdir}/include/stdalign.h
+%ifarch %sparc
+%{libsubdir}/include/visintrin.h
+%endif
+%ifarch ppc ppc64
+%{libsubdir}/include/altivec.h
+%{libsubdir}/include/ppc-asm.h
+%{libsubdir}/include/paired.h
+%{libsubdir}/include/ppu_intrinsics.h
+%{libsubdir}/include/si2vmx.h
+%{libsubdir}/include/spe.h
+%{libsubdir}/include/spu2vmx.h
+%{libsubdir}/include/vec_types.h
+%endif
+%ifarch ia64
+%{libsubdir}/include/ia64intrin.h
+%endif
+%ifarch aarch64
+%{libsubdir}/include/arm_neon.h
+%endif
 %ifarch %arm
 %{libsubdir}/include/mmintrin.h
 %{libsubdir}/include/arm_neon.h
@@ -2225,6 +2154,14 @@ cd ..
 %{libsubdir}/include/fmaintrin.h
 %{libsubdir}/include/lzcntintrin.h
 %{libsubdir}/include/f16cintrin.h
+%{libsubdir}/include/adxintrin.h
+%{libsubdir}/include/fxsrintrin.h
+%{libsubdir}/include/prfchwintrin.h
+%{libsubdir}/include/rdseedintrin.h
+%{libsubdir}/include/rtmintrin.h
+%{libsubdir}/include/xsaveintrin.h
+%{libsubdir}/include/xsaveoptintrin.h
+%{libsubdir}/include/xtestintrin.h
 %endif
 %if %{build_with_mudflap}
 %{libsubdir}/include/mf-runtime.h
@@ -2242,11 +2179,26 @@ cd ..
 %versmainlib libgomp.so
 %versmainlib libgomp.a
 %versmainlib libgomp.spec
+%ifarch %itm_arch
+%versmainlib libitm.so
+%versmainlib libitm.a
+%versmainlib libitm.spec
+%endif
+%ifarch %atomic_arch
+%versmainlib libatomic.so
+%versmainlib libatomic.a
+%endif
+%ifarch %asan_arch
+%versmainlib libasan.so
+%versmainlib libasan.a
+%versmainlib libasan_preinit.o
+%endif
+%ifarch %tsan_arch
+%versmainlib libtsan.so
+%versmainlib libtsan.a
+%endif
 %doc %{_mandir}/man1/gcc%{binsuffix}.1.gz
 %doc %{_mandir}/man1/gcov%{binsuffix}.1.gz
-%if 0%{?build_optional_compiler:1}
-%{libsubdir}/defaults.spec
-%endif
 
 %if %{separate_biarch}
 %files -n gcc48%{separate_biarch_suffix}
@@ -2264,10 +2216,32 @@ cd ..
 %versbiarchlib libgomp.so
 %versbiarchlib libgomp.a
 %versbiarchlib libgomp.spec
+%ifarch %itm_arch
+%versbiarchlib libitm.so
+%versbiarchlib libitm.a
+%versbiarchlib libitm.spec
+%endif
+%ifarch %atomic_arch
+%versbiarchlib libatomic.a
+%versbiarchlib libatomic.so
+%endif
+%ifarch %asan_arch
+%versbiarchlib libasan.a
+%versbiarchlib libasan.so
+%versbiarchlib libasan_preinit.o
+%endif
+%if 0
+%ifarch %tsan_arch
+%versbiarchlib libtsan.a
+%versbiarchlib libtsan.so
+%endif
+%endif
 %endif
 
 %files locale -f gcc48-locale.lang
 
+%files -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}-locale
+
 %if %{build_cp}
 %files c++
 %defattr(-,root,root)
@@ -2278,17 +2252,14 @@ cd ..
 %doc %{_mandir}/man1/g++%{binsuffix}.1.gz
 %{libsubdir}/cc1plus
 
-%files -n libstdc++48
+%files -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}
 %defattr(-,root,root)
-%if %{build_nof}
-%dir %{noflibdir}
-%endif
-%mainlib libstdc++.so.*
+%mainlib libstdc++.so.%{libstdcxx_sover}*
 
 %if %{separate_biarch}
-%files -n libstdc++48%{separate_biarch_suffix}
+%files -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}%{separate_biarch_suffix}
 %defattr(-,root,root)
-%biarchlib libstdc++.so.*
+%biarchlib libstdc++.so.%{libstdcxx_sover}*
 %endif
 
 %files -n libstdc++48-devel -f c++-headers
@@ -2318,14 +2289,9 @@ cd ..
 %doc libstdc++-v3/doc/html
 %endif
 
-%files -n libgcc48
+%files -n libgcc_s%{libgcc_s}%{libgcc_s_suffix}
 %defattr(-,root,root)
-%if 0%{!?build_optional_compiler:1}
 /%{_lib}/libgcc_s.so.%{libgcc_s}
-%if %{build_nof}
-%dir /lib/nof
-/lib/nof/libgcc_s.so.%{libgcc_s}
-%endif
 %if %{biarch}
 %if %{build_primary_64bit}
 %if !%{separate_bi32}
@@ -2337,42 +2303,86 @@ cd ..
 %endif
 %endif
 %endif
-%else
-%versmainlib libgcc_s.so.%{libgcc_s}
-%endif
 
 %if %{separate_bi64}
-%files -n libgcc48-64bit
+%files -n libgcc_s%{libgcc_s}%{libgcc_s_suffix}-64bit
 %defattr(-,root,root)
-%if 0%{!?build_optional_compiler:1}
 /lib64/libgcc_s.so.%{libgcc_s}
-%else
-%versbiarchlib libgcc_s.so.%{libgcc_s}
-%endif
 %endif
 
 %if %{separate_bi32}
-%files -n libgcc48-32bit
+%files -n libgcc_s%{libgcc_s}%{libgcc_s_suffix}-32bit
 %defattr(-,root,root)
-%if 0%{!?build_optional_compiler:1}
 /lib/libgcc_s.so.%{libgcc_s}
-%else
-%versbiarchlib libgcc_s.so.%{libgcc_s}
 %endif
+
+
+%files -n libgomp%{libgomp_sover}%{libgomp_suffix}
+%defattr(-,root,root)
+%mainlib libgomp.so.%{libgomp_sover}*
+
+%if %{separate_biarch}
+%files -n libgomp%{libgomp_sover}%{libgomp_suffix}%{separate_biarch_suffix}
+%defattr(-,root,root)
+%biarchlib libgomp.so.%{libgomp_sover}*
 %endif
 
 
-%files -n libgomp48
+%ifarch %asan_arch
+%files -n libasan%{libasan_sover}%{libasan_suffix}
 %defattr(-,root,root)
-%mainlib libgomp.so.1*
+%mainlib libasan.so.%{libasan_sover}*
 
 %if %{separate_biarch}
-%files -n libgomp48%{separate_biarch_suffix}
+%files -n libasan%{libasan_sover}%{libasan_suffix}%{separate_biarch_suffix}
 %defattr(-,root,root)
-%biarchlib libgomp.so.1*
+%biarchlib libasan.so.%{libasan_sover}*
+%endif
 %endif
 
 
+%ifarch %tsan_arch
+%files -n libtsan%{libtsan_sover}%{libtsan_suffix}
+%defattr(-,root,root)
+%mainlib libtsan.so.%{libtsan_sover}*
+
+%if 0
+%if %{separate_biarch}
+%files -n libtsan%{libtsan_sover}%{libtsan_suffix}%{separate_biarch_suffix}
+%defattr(-,root,root)
+%biarchlib libtsan.so.%{libtsan_sover}*
+%endif
+%endif
+%endif
+
+
+%ifarch %atomic_arch
+%files -n libatomic%{libatomic_sover}%{libatomic_suffix}
+%defattr(-,root,root)
+%mainlib libatomic.so.%{libatomic_sover}*
+
+%if %{separate_biarch}
+%files -n libatomic%{libatomic_sover}%{libatomic_suffix}%{separate_biarch_suffix}
+%defattr(-,root,root)
+%biarchlib libatomic.so.%{libatomic_sover}*
+%endif
+%endif
+
+
+%ifarch %itm_arch
+%files -n libitm%{libitm_sover}%{libitm_suffix}
+%defattr(-,root,root)
+%mainlib libitm.so.%{libitm_sover}*
+
+%if %{separate_biarch}
+%files -n libitm%{libitm_sover}%{libitm_suffix}%{separate_biarch_suffix}
+%defattr(-,root,root)
+%biarchlib libitm.so.%{libitm_sover}*
+%endif
+%endif
+
+
+
 %if %{build_fortran}
 %files fortran
 %defattr(-,root,root)
@@ -2407,25 +2417,25 @@ cd ..
 %endif
 %endif
 
-%files -n libgfortran48
+%files -n libgfortran%{libgfortran_sover}%{libgfortran_suffix}
 %defattr(-,root,root)
-%mainlib libgfortran.so.*
+%mainlib libgfortran.so.%{libgfortran_sover}*
 
 %if %{separate_biarch}
-%files -n libgfortran48%{separate_biarch_suffix}
+%files -n libgfortran%{libgfortran_sover}%{libgfortran_suffix}%{separate_biarch_suffix}
 %defattr(-,root,root)
-%biarchlib libgfortran.so.*
+%biarchlib libgfortran.so.%{libgfortran_sover}*
 %endif
 
 %ifarch %quadmath_arch
-%files -n libquadmath48
+%files -n libquadmath%{libquadmath_sover}%{libquadmath_suffix}
 %defattr(-,root,root)
-%mainlib libquadmath.so.*
+%mainlib libquadmath.so.%{libquadmath_sover}*
 
 %if %{separate_biarch}
-%files -n libquadmath48%{separate_biarch_suffix}
+%files -n libquadmath%{libquadmath_sover}%{libquadmath_suffix}%{separate_biarch_suffix}
 %defattr(-,root,root)
-%biarchlib libquadmath.so.*
+%biarchlib libquadmath.so.%{libquadmath_sover}*
 %endif
 %endif
 %endif
@@ -2433,14 +2443,14 @@ cd ..
 %if %{build_with_mudflap}
 %files -n libmudflap48
 %defattr(-,root,root)
-%mainlib libmudflap.so.0*
-%mainlib libmudflapth.so.0*
+%mainlib libmudflap.so.%{libmudflap_sover}*
+%mainlib libmudflapth.so.%{libmudflap_sover}*
 
 %if %{separate_biarch}
 %files -n libmudflap48%{separate_biarch_suffix}
 %defattr(-,root,root)
-%biarchlib libmudflap.so.0*
-%biarchlib libmudflapth.so.0*
+%biarchlib libmudflap.so.%{libmudflap_sover}*
+%biarchlib libmudflapth.so.%{libmudflap_sover}*
 %endif
 %endif
 
@@ -2473,14 +2483,14 @@ cd ..
 %versbiarchlib libobjc.so
 %endif
 
-%files -n libobjc48
+%files -n libobjc%{libobjc_sover}%{libobjc_suffix}
 %defattr(-,root,root)
-%mainlib libobjc.so.*
+%mainlib libobjc.so.%{libobjc_sover}*
 
 %if %{separate_biarch}
-%files -n libobjc48%{separate_biarch_suffix}
+%files -n libobjc%{libobjc_sover}%{libobjc_suffix}%{separate_biarch_suffix}
 %defattr(-,root,root)
-%biarchlib libobjc.so.*
+%biarchlib libobjc.so.%{libobjc_sover}*
 %endif
 %endif
 
@@ -2532,7 +2542,6 @@ cd ..
 %biarchlib libgnat-*.so
 %endif
 %endif
-# LIBJAVA-DELETE-END
 
 
 %if %{build_java}
@@ -2566,11 +2575,11 @@ cd ..
 %if %{build_libjava}
 %files -n libgcj48
 %defattr(-,root,root)
-%dir %{_libdir}/gcj-%{gcc_dir_version}-%{gcj_sover}
+%dir %{_libdir}/gcj-%{gcc_dir_version}-%{libgcj_sover}
 %dir %{_libdir}/gcc
 %dir %{_libdir}/gcc/%{GCCDIST}
 %dir %{libsubdir}
-%{_libdir}/gcj-%{gcc_dir_version}-%{gcj_sover}/classmap.db
+%{_libdir}/gcj-%{gcc_dir_version}-%{libgcj_sover}/classmap.db
 # We usually do not multilib libjava
 %if %{biarch_libjava}
 %versbiarchlib libgcj.la
@@ -2583,17 +2592,17 @@ cd ..
 %mainlib libgij.so.*
 %mainlib libgcj-tools.so.*
 %endif
-%{_libdir}/gcj-%{gcc_dir_version}-%{gcj_sover}/libjvm.la
-%{_libdir}/gcj-%{gcc_dir_version}-%{gcj_sover}/libjvm.so
-%{_libdir}/gcj-%{gcc_dir_version}-%{gcj_sover}/libjavamath.la
-%{_libdir}/gcj-%{gcc_dir_version}-%{gcj_sover}/libjavamath.so
+%{_libdir}/gcj-%{gcc_dir_version}-%{libgcj_sover}/libjvm.la
+%{_libdir}/gcj-%{gcc_dir_version}-%{libgcj_sover}/libjvm.so
+%{_libdir}/gcj-%{gcc_dir_version}-%{libgcj_sover}/libjavamath.la
+%{_libdir}/gcj-%{gcc_dir_version}-%{libgcj_sover}/libjavamath.so
 
-%files -n libgcj_bc48
+%files -n libgcj_bc%{libgcj_bc_sover}%{libgcj_bc_suffix}
 %defattr(-,root,root)
 %if %{biarch_libjava}
-%biarchlib libgcj_bc.so.*
+%biarchlib libgcj_bc.so.%{libgcj_bc_sover}*
 %else
-%mainlib libgcj_bc.so.*
+%mainlib libgcj_bc.so.%{libgcj_bc_sover}*
 %endif
 
 %files -n libgcj48-jar
@@ -2664,20 +2673,24 @@ cd ..
 %doc %{_mandir}/man1/gtnameserv%{binsuffix}.1.gz
 %endif
 %endif
-# LIBFFI-DELETE-END
 
 %if %{build_java}
 %if 0%{?building_libffi:1}
-%files -n libffi48
+%files -n libffi%{libffi_sover}%{libffi_suffix}
 %defattr(-,root,root)
-%mainlib libffi.so.*
+%mainlib libffi.so.%{libffi_sover}*
 
 %if %{separate_biarch}
-%files -n libffi48%{separate_biarch_suffix}
+%files -n libffi%{libffi_sover}%{libffi_suffix}%{separate_biarch_suffix}
 %defattr(-,root,root)
-%biarchlib libffi.so.*
+%biarchlib libffi.so.%{libffi_sover}*
 %endif
 
+%post -n libffi48-devel
+%install_info --info-dir=%{_infodir} %{_infodir}/libffi%{binsuffix}.info.gz
+%postun -n libffi48-devel
+%install_info_delete --info-dir=%{_infodir} %{_infodir}/libffi%{binsuffix}.info.gz
+
 %files -n libffi48-devel
 %defattr(-,root,root)
 %{_prefix}/include/ffi.h
@@ -2685,9 +2698,11 @@ cd ..
 %mainlib libffi.so
 %mainlib libffi.a
 %{_libdir}/pkgconfig/libffi.pc
+%doc %{_infodir}/libffi%{binsuffix}.info.gz
 %doc %{_mandir}/man3/ffi%{binsuffix}.3.gz
 %doc %{_mandir}/man3/ffi_call%{binsuffix}.3.gz
 %doc %{_mandir}/man3/ffi_prep_cif%{binsuffix}.3.gz
+%doc %{_mandir}/man3/ffi_prep_cif_var%{binsuffix}.3.gz
 
 %if %{separate_biarch}
 %files -n libffi48-devel%{separate_biarch_suffix}
@@ -2697,7 +2712,6 @@ cd ..
 %endif
 %endif
 %endif
-# GCC-TESTSUITE-DELETE-END
 
 %if 0%{?run_tests:1}
 %files -n gcc48-testresults
index 93963b8..9dceb80 100644 (file)
@@ -1,24 +1,40 @@
 %define building_libffi 1
-%define fast_build 1
+#
+# spec file for package gcc48
+#
+# Copyright (c) 2009 SUSE LINUX Products GmbH, Nuernberg, Germany.
+#
+# All modifications and additions to the file contributed by third parties
+# remain the property of their copyright owners, unless otherwise agreed
+# upon. The license for this file, and modifications and additions to the
+# file, is the same license as for the pristine package itself (unless the
+# license for the pristine package is not an Open Source License, in which
+# case the license is the MIT License). An "Open Source License" is a
+# license that conforms to the Open Source Definition (Version 1.9)
+# published by the Open Source Initiative.
+
+# Please submit bugfixes or comments via http://bugs.opensuse.org/
+#
+
+# norootforbuild
+# icecream 0
+
 
-# Ada currently fails to build on a few platforms, enable it only
-# on those that work
-# Note that AdaCore only supports %ix86, x86_64 and ia64
-%ifarch %ix86 x86_64
-%define build_ada !0%{?building_libjava:1}%{?building_libffi:1}
-%else
 %define build_ada 0
-%endif
 
-%define quadmath_arch %ix86 x86_64 
+%define quadmath_arch %ix86 x86_64 ia64
+%define tsan_arch x86_64
+%define asan_arch x86_64 %ix86 ppc ppc64
+%define itm_arch x86_64 %ix86 %arm ppc ppc64
+%define atomic_arch x86_64 %ix86 %arm ppc ppc64 s390 s390x
 
 # We don't want to build java
-%define build_java 1
-%define build_libjava 0%{?building_libjava:1}%{?building_libffi:1}%{?building_testsuite:1}
+%define build_java 0
+%define build_libjava 0
 
 %define build_cp 1
-%define build_fortran 1
-%define build_objc 1
+%define build_fortran !0%{?building_libjava:1}%{?building_libffi:1}
+%define build_objc !0%{?building_libjava:1}%{?building_libffi:1}
 %define build_objcp !0%{?building_libjava:1}%{?building_libffi:1}
 %define build_with_mudflap 0
 
 %endif
 
 # For optional compilers only build C, C++ and Fortran
-##%if 0%{?build_optional_compiler:1}%{?build_optional_compiler_languages:1}
-%if 0%{!?building_libffi:1}
+%if 0%{?build_optional_compiler_languages:1}
 %define build_ada 0
 %define build_java 0
 %define build_libjava 0
-%define build_objc 1
-%define build_objcp 1
+%define build_objc 0
+%define build_objcp 0
+%endif
+
+# Shared library SONAME versions
+%ifarch hppa
+%define libgcc_s 4
+%else
+%define libgcc_s 1
 %endif
+%define libgcj_sover 14
+%define libgcj_bc_sover 1
+%define libffi_sover 4
+%define libmudflap_sover 0
+%define libgomp_sover 1
+%define libstdcxx_sover 6
+%define libobjc_sover 4
+%define libgfortran_sover 3
+%define libquadmath_sover 0
+%define libasan_sover 0
+%define libtsan_sover 0
+%define libatomic_sover 1
+%define libitm_sover 1
+
+# Shared library package suffix
+# This is used for the "non-standard" set of libraries, the standard
+# being defined by %product_libs_gcc_ver, the GCC version that should
+# provide un-suffixed shared library packages following the shared-library
+# policy.  Even suffixed variants should provide the shared-library policy
+# mandated names and ensure they conflict with each other.
+# Note that on SONAME changes of any library the %product_libs_gcc_ver
+# define needs to be either split or the newest GCC version still providing
+# the old SONAME needs to unconditionally produce an un-suffixed library
+# if %product_libs_gcc_ver is newer than it.  Similar the _oldest_ GCC
+# version first providing a new SONAME needs to unconditionally produce
+# an un-suffixed library if %product_libs_gcc_ver is lower that it.
+%if %{!?product_libs_gcc_ver:48}%{?product_libs_gcc_ver} != 48
+%define pne 1
+%endif
+%define libgcc_s_suffix %{?pne:-gcc48}
+# libgcj SONAME changes with every GCC version
+%define libgcj_suffix %nil
+%define libgcj_bc_suffix %{?pne:-gcc48}
+%define libffi_suffix %{?pne:-gcc48}
+%define libmudflap_suffix %{?pne:-gcc48}
+%define libgomp_suffix %{?pne:-gcc48}
+%define libstdcxx_suffix %{?pne:-gcc48}
+%define libobjc_suffix %{?pne:-gcc48}
+%define libgfortran_suffix %{?pne:-gcc48}
+%define libquadmath_suffix %{?pne:-gcc48}
+%define libasan_suffix %{?pne:-gcc48}
+%define libtsan_suffix %{?pne:-gcc48}
+%define libatomic_suffix %{?pne:-gcc48}
+%define libitm_suffix %{?pne:-gcc48}
+
+
 
 
 Name: libffi48
+BuildRequires: gcc-c++
 BuildRequires: bison
 BuildRequires: flex
-BuildRequires: gettext-tools
-BuildRequires: makeinfo
 BuildRequires: glibc-devel-32bit
 BuildRequires: mpc-devel
 BuildRequires: mpfr-devel
 BuildRequires: perl
-BuildRequires: texinfo
+BuildRequires: makeinfo
 BuildRequires: zlib-devel
-%ifarch %ix86 x86_64 %arm
-BuildRequires: cloog-devel
-BuildRequires: ppl-devel
+%ifarch %ix86 x86_64 ppc ppc64 s390 s390x ia64 %sparc hppa %arm
+BuildRequires: cloog-isl-devel
+BuildRequires: isl-devel
 %endif
 %if %{build_ada}
-%define hostsuffix -4.8
-BuildRequires: gcc48-ada
+%define hostsuffix -4.7
+BuildRequires: gcc47-ada
 %endif
 %if 0%{?building_libjava:1}%{?building_testsuite:1}
 BuildRequires: fastjar
-BuildRequires: unzip
 %endif
 %if 0%{?building_libffi:1}
 BuildRequires: pkg-config
 %endif
+%ifarch ia64
+BuildRequires: libunwind-devel
+%endif
 %if 0%{?run_tests:1}
 BuildRequires: dejagnu
 BuildRequires: expect
 BuildRequires: gdb
 %endif
 
-# Define version number of libgcc_s
-%define libgcc_s 1
-%define build_nof 0
-
 %define separate_bi32 0
 %define separate_bi64 0
-%ifarch x86_64 
+%ifarch ppc sparcv9
+# Beware, this does _not_ separate libgcj, as for that one multilibing
+# is inactive for the time being
+%define separate_bi64 1
+%endif
+%ifarch x86_64 s390x ppc64 sparc64
 %define separate_bi32 1
 %endif
 
@@ -95,7 +165,7 @@ BuildRequires: gdb
 %define separate_biarch_suffix -64bit
 %endif
 
-%ifarch x86_64
+%ifarch x86_64 ia64 s390x alpha ppc64 sparc64
 # 64-bit is primary build target
 %define build_primary_64bit 1
 %else
@@ -104,8 +174,7 @@ BuildRequires: gdb
 
 %define biarch_libjava 0
 
-# COMMON-BEGIN
-%define biarch_targets x86_64 
+%define biarch_targets x86_64 s390x powerpc64 powerpc sparc sparc64
 
 URL:          http://gcc.gnu.org/
 Version: 4.8.1
@@ -114,149 +183,124 @@ Release:      1
 %define gcc_dir_version %(echo %gcc_version | cut -d '.' -f 1-2)
 %define snapshot_date %(echo %version | sed 's/[34]\.[0-9]\.[0-6]//' | sed 's/_/-/')
 %define binsuffix -4.8
-# COMMON-END
 
 %if !0%{?building_libjava:1}%{?building_libffi:1}%{?building_testsuite:1}
 Requires: binutils glibc-devel
 Requires: cpp48 = %{version}-%{release}
-%if 0%{!?build_optional_compiler:1}
-Requires: libgcc%{libgcc_s} >= %{version}-%{release}
-Requires: libgomp1 >= %{version}-%{release}
+Requires: libgcc_s%{libgcc_s} >= %{version}-%{release}
+Requires: libgomp%{libgomp_sover} >= %{version}-%{release}
 %if %{build_with_mudflap}
-Requires: libmudflap0 >= %{version}-%{release}
-Requires: libmudflapth0 >= %{version}-%{release}
+Requires: libmudflap%{libmudflap_sover} >= %{version}-%{release}
+Requires: libmudflapth%{libmudflap_sover} >= %{version}-%{release}
 %endif
-%else
-Requires: libgcc48 = %{version}-%{release}
-Requires: libgomp48 = %{version}-%{release}
+%ifarch %asan_arch
+Requires: libasan%{libasan_sover} >= %{version}-%{release}
+%endif
+%ifarch %tsan_arch
+Requires: libtsan%{libtsan_sover} >= %{version}-%{release}
 %endif
+%ifarch %atomic_arch
+Requires: libatomic%{libatomic_sover} >= %{version}-%{release}
+%endif
+%ifarch %itm_arch
+Requires: libitm%{libitm_sover} >= %{version}-%{release}
+%endif
+Suggests: gcc48-info gcc48-locale
 %endif
 
-# COMMON-BEGIN
 BuildRoot:     %{_tmppath}/%{name}-%{version}-build
-#Source:               gcc-%{gcc_version}%{snapshot_date}.tar.bz2
-Source:     gcc-%{version}.tar.bz2
-
+Source:                gcc-%{gcc_version}%{snapshot_date}.tar.bz2
 Source1:       change_spec
-Source2:       libgcj48-rpmlintrc
 Source3:       gcc48-rpmlintrc
 Source4:       ecj.jar
 Source6:       baselibs.conf
-# Patches auto-generated by git-buildpackage:
-Patch0:     0001-dir-version.patch
-Patch1:     0002-textdomain.patch
-Patch2:     0003-rename-info-files.patch
-Patch3:     0004-ARM-linker.patch
-
-# GCC-TESTSUITE-DELETE-BEGIN
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
+
+
+Group:         Development/Languages/C and C++
+Summary:       The GNU C Compiler and Support Files
+License:        GPL-3.0+
+
+%description
+Core package for the GNU Compiler Collection, including the C language
+frontend.
+
+Language frontends other than C are split to different sub-packages,
+namely gcc-ada, gcc-c++, gcc-fortran, gcc-java, gcc-objc and
+gcc-obj-c++.
+%package -n libffi%{libffi_sover}%{libffi_suffix}
 Summary:      Foreign Function Interface library
 License:        BSD-3-Clause
-Group:        Base/Libraries
-Provides: g-wrap:/usr/lib/libffi.so.4
-Provides: libffi4 = %{version}-%{release}
-Conflicts: libffi4 < %{version}-%{release}
+Group:        Development/Languages/C and C++
 
-%description 
+%description -n libffi%{libffi_sover}%{libffi_suffix}
 A foreign function interface is the popular name for the interface that allows code written in one language to call code written in another language.
 
-%post 
+%post -n libffi%{libffi_sover}%{libffi_suffix}
 /sbin/ldconfig
 
-%postun 
+%postun -n libffi%{libffi_sover}%{libffi_suffix}
 /sbin/ldconfig
-# PACKAGE-END
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
-%package -n libffi48-32bit
+%package -n libffi%{libffi_sover}%{libffi_suffix}-32bit
 Summary:      Foreign Function Interface library
 License:        BSD-3-Clause
-Group:        Base/Libraries
-Provides: g-wrap:/usr/lib/libffi.so.4
-Provides: libffi4-32bit = %{version}-%{release}
-Conflicts: libffi4-32bit < %{version}-%{release}
+Group:        Development/Languages/C and C++
 
-%description -n libffi48-32bit
+%description -n libffi%{libffi_sover}%{libffi_suffix}-32bit
 A foreign function interface is the popular name for the interface that allows code written in one language to call code written in another language.
 
-%post -n libffi48-32bit
+%post -n libffi%{libffi_sover}%{libffi_suffix}-32bit
 /sbin/ldconfig
 
-%postun -n libffi48-32bit
+%postun -n libffi%{libffi_sover}%{libffi_suffix}-32bit
 /sbin/ldconfig
-# PACKAGE-END
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
-%package -n libffi48-64bit
+%package -n libffi%{libffi_sover}%{libffi_suffix}-64bit
 Summary:      Foreign Function Interface library
 License:        BSD-3-Clause
-Group:        Base/Libraries
-Provides: g-wrap:/usr/lib/libffi.so.4
-Provides: libffi4-64bit = %{version}-%{release}
-Conflicts: libffi4-64bit < %{version}-%{release}
+Group:        Development/Languages/C and C++
 
-%description -n libffi48-64bit
+%description -n libffi%{libffi_sover}%{libffi_suffix}-64bit
 A foreign function interface is the popular name for the interface that allows code written in one language to call code written in another language.
 
-%post -n libffi48-64bit
+%post -n libffi%{libffi_sover}%{libffi_suffix}-64bit
 /sbin/ldconfig
 
-%postun -n libffi48-64bit
+%postun -n libffi%{libffi_sover}%{libffi_suffix}-64bit
 /sbin/ldconfig
-# PACKAGE-END
 
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
 %package -n libffi48-devel
 Summary:      Foreign Function Interface library development files
 License:        BSD 3-Clause
-Group:        Development/Toolchain
-Requires: libffi4 >= %{version}-%{release}
-Provides: libffi-devel = %{version}-%{release}
-Conflicts: libffi-devel < %{version}-%{release}
+Group:        Development/Languages/C and C++
+Requires: libffi%{libffi_sover} >= %{version}-%{release}
 
 %description -n libffi48-devel
 A foreign function interface is the popular name for the interface that allows code written in one language to call code written in another language.
-# PACKAGE-END
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
 %package -n libffi48-devel-32bit
 Summary:      Foreign Function Interface library development files
 License:        BSD 3-Clause
-Group:        Development/Toolchain
-Requires: libffi4-32bit >= %{version}-%{release}
-Provides: libffi-devel-32bit = %{version}-%{release}
-Conflicts: libffi-devel-32bit < %{version}-%{release}
+Group:        Development/Languages/C and C++
+Requires: libffi%{libffi_sover}-32bit >= %{version}-%{release}
 
 %description -n libffi48-devel-32bit
 A foreign function interface is the popular name for the interface that allows code written in one language to call code written in another language.
-# PACKAGE-END
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
 %package -n libffi48-devel-64bit
 Summary:      Foreign Function Interface library development files
 License:        BSD 3-Clause
-Group:        Development/Toolchain
-Requires: libffi4-64bit >= %{version}-%{release}
-Provides: libffi-devel-64bit = %{version}-%{release}
-Conflicts: libffi-devel-64bit < %{version}-%{release}
+Group:        Development/Languages/C and C++
+Requires: libffi%{libffi_sover}-64bit >= %{version}-%{release}
 
 %description -n libffi48-devel-64bit
 A foreign function interface is the popular name for the interface that allows code written in one language to call code written in another language.
-# PACKAGE-END
 
 %package -n gcc48-testresults
-# GCC-TESTSUITE-DELETE-END
 Summary:      Testsuite results
-License:       Public-Domain
-Group:        Development/Toolchain
+License:       SUSE-Public-Domain
+Group:        Development/Languages/C and C++
 
 %description -n gcc48-testresults
 Results from running the gcc and target library testsuites.
 
 
-# COMMON-BEGIN
 
 # Define the canonical target and host architecture
 #   %gcc_target_arch  is supposed to be the full target triple
@@ -265,6 +309,12 @@ Results from running the gcc and target library testsuites.
 %if 0%{?gcc_target_arch:1}
 %define CONFIGURE_TARGET %{gcc_target_arch}
 %define TARGET_ARCH %(echo %{gcc_target_arch} | cut -d - -f 1 | sed -e "s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;")
+%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "powerpc"
+%define CONFIGURE_TARGET powerpc64-tizen-linux
+%endif
+%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "powerpc64"
+%define CONFIGURE_TARGET powerpc64-tizen-linux
+%endif
 %if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "i586"
 %define CONFIGURE_TARGET i586-tizen-linux
 %endif
@@ -274,11 +324,8 @@ Results from running the gcc and target library testsuites.
 %if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "armv7hl"
 %define CONFIGURE_TARGET armv7hl-tizen-linux-gnueabi
 %endif
-%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "armv7el"
-%define CONFIGURE_TARGET armv7el-tizen-linux-gnueabi
-%endif
-%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "armv5el"
-%define CONFIGURE_TARGET armv5el-tizen-linux-gnueabi
+%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "armv5tel"
+%define CONFIGURE_TARGET armv5tel-tizen-linux-gnueabi
 %endif
 %else
 %define TARGET_ARCH %(echo %{_target_cpu} | sed -e "s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;")
@@ -287,44 +334,46 @@ Results from running the gcc and target library testsuites.
 
 %define biarch %(case " %{biarch_targets} " in (*" %{TARGET_ARCH} "*) echo 1;; (*) echo 0;; esac)
 
+%ifarch ppc
+%define GCCDIST powerpc64-tizen-linux
+%else
+%ifarch %sparc
+%define GCCDIST sparc64-tizen-linux
+%else
 %ifarch %arm
 %define GCCDIST %{HOST_ARCH}-tizen-linux-gnueabi
 %else
 %define GCCDIST %{HOST_ARCH}-tizen-linux
 %endif
+%endif
+%endif
 
 %define libsubdir %{_libdir}/gcc/%{GCCDIST}/%{gcc_dir_version}
 %define gxxinclude %{_prefix}/include/c++/%{gcc_dir_version}
 
-# COMMON-END
 
 # Versionspecific directories
 %define versmainlibdir %{libsubdir}
 %define versmainlibdirbi32 %{libsubdir}/32
 %define versmainlibdirbi64 %{libsubdir}/64
+%ifarch ppc
+%define versmainlibdirbi32 %{libsubdir}
+%define versmainlibdirbi64 %{libsubdir}/64
+%endif
 %if %{build_primary_64bit}
 %define versmainlibdirbi %{versmainlibdirbi32}
 %else
 %define versmainlibdirbi %{versmainlibdirbi64}
 %endif
 
-%if 0%{?build_optional_compiler:1}
-%define mainlibdir %{versmainlibdir}
-%define mainlibdirbi32 %{versmainlibdirbi32}
-%define mainlibdirbi64 %{versmainlibdirbi64}
-%define noflibdir %{versnoflibdir}
-%define mainlibdirbi %{versmainlibdirbi}
-%else
 %define mainlibdir %{_libdir}
 %define mainlibdirbi32 %{_prefix}/lib
 %define mainlibdirbi64 %{_prefix}/lib64
-%define noflibdir %{_prefix}/lib/nof
 %if %{build_primary_64bit}
 %define mainlibdirbi %{mainlibdirbi32}
 %else
 %define mainlibdirbi %{mainlibdirbi64}
 %endif
-%endif
 
 
 # Now define a few macros that make it easy to package libs and
@@ -332,88 +381,51 @@ Results from running the gcc and target library testsuites.
 # exact path the files are in.
 #   %mainlib  package X from all dirs that belong to the main package
 #   %biarchlib   package X from all dirs that belong to the -32/64bit package
-# by default, nof libs go where the 32bit libs go.
-%if %{build_nof}
-%define mainlib() %{mainlibdir}/%1\
-%{noflibdir}/%1\
-%{nil}
-%else
 %define mainlib() %{mainlibdir}/%1\
 %{nil}
-%endif
 %define biarchlib() %{nil}
 %if %{biarch}
 %if !%{separate_biarch}
-%if %{build_nof}
-%define mainlib() %{mainlibdir}/%1\
-%{mainlibdirbi}/%1\
-%{noflibdir}/%1\
-%{nil}
-%else
 %define mainlib() %{mainlibdir}/%1\
 %{mainlibdirbi}/%1\
 %{nil}
-%endif
 %else
-%if %{build_nof}
 %define biarchlib() %{mainlibdirbi}/%1\
-%{noflibdir}/%1\
 %{nil}
-%define mainlib() %{mainlibdir}/%1\
-%{nil}
-%else
-%define biarchlib() %{mainlibdirbi}/%1\
-%{nil}
-%endif
 %endif
 %endif
 
-%if %{build_nof}
 %define versmainlib() %{versmainlibdir}/%1\
-%{versnoflibdir}/%1\
 %{nil}
-%else
-%define versmainlib() %{versmainlibdir}/%1\
-%{nil}
-%endif
 %define versbiarchlib() %{nil}
 %if %{biarch}
 %if !%{separate_biarch}
-%if %{build_nof}
-%define versmainlib() %{versmainlibdir}/%1\
-%{versmainlibdirbi}/%1\
-%{versnoflibdir}/%1\
-%{nil}
-%else
 %define versmainlib() %{versmainlibdir}/%1\
 %{versmainlibdirbi}/%1\
 %{nil}
-%endif
-%else
-%if %{build_nof}
-%define versbiarchlib() %{versmainlibdirbi}/%1\
-%{versnoflibdir}/%1\
-%{nil}
-%define versmainlib() %{versmainlibdir}/%1\
-%{nil}
 %else
 %define versbiarchlib() %{versmainlibdirbi}/%1\
 %{nil}
 %endif
 %endif
-%endif
 
 
-# COMMON-BEGIN
 
 %prep
-#%setup -q -n gcc-%{gcc_version}%{snapshot_date}
-%setup -q -n gcc-%{version}
-# 0001-dir-version.patch
-%patch0 -p1
-%patch1 -p1
-%patch2 -p1
-%patch3 -p1
+%setup -q -n gcc-%{gcc_version}%{snapshot_date}
+
+
+# We are configuring ppc as ppc64 but with switched multilibs.  Adjust
+# the libstdc++ abi testsuite baseline files accordingly
+%ifarch ppc
+if [ -d libstdc++-v3/config/abi/post/powerpc64-linux-gnu ]; then
+  mkdir -p libstdc++-v3/config/abi/post/powerpc64-linux-gnu/64
+  mv libstdc++-v3/config/abi/post/powerpc64-linux-gnu/baseline_symbols.txt \
+       libstdc++-v3/config/abi/post/powerpc64-linux-gnu/64/
+  mv libstdc++-v3/config/abi/post/powerpc64-linux-gnu/32/baseline_symbols.txt \
+       libstdc++-v3/config/abi/post/powerpc64-linux-gnu/
+fi
+%endif
 
 %build
 # Avoid rebuilding of generated files
@@ -444,6 +456,10 @@ RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-fno-rtti//g' -e 's/-fno-exceptions
 # default compiler settings now.
 RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-mcpu=i.86//g' -e 's/-march=i.86//g' -e 's/-mtune=i.86//g'`
 %endif
+%ifarch s390 s390x
+RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-fsigned-char//g'`
+RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-O1/-O2/g'`
+%endif
 %if 0%{?gcc_target_arch:1} && 0%{!?gcc_icecream:1}
 # Kill all -march/tune/cpu because that screws building the target libs
 RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-m\(arch\|tune\|cpu\)=[^ ]*//g'`
@@ -506,7 +522,7 @@ export _POSIX2_VERSION=199209
 # if glibc supports SSP.  When cross compiling we would need
 # to install a cross glibc, which we don't, or make the whole
 # thing point to the native glibc, which is in /, hence the
-# --with-sysroot=/
+# --with-build-sysroot=/
 
 %if %{build_ada}
 # Using the host gnatmake like
@@ -527,26 +543,27 @@ export PATH="`pwd`/host-tools/bin:$PATH"
 #      --enable-threads=posix \
 #%endif
 #      --enable-shared \
+%if "%{TARGET_ARCH}" == "armv7l" || "%{TARGET_ARCH}" == "armv7hl"
+# temporary workaround for a miscompilation of hash functions in java code
+GCJ_EXTRA_FLAGS="-marm"
+%endif
 CFLAGS="$RPM_OPT_FLAGS" CXXFLAGS="$RPM_OPT_FLAGS" XCFLAGS="$RPM_OPT_FLAGS" \
-TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
+TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS $GCJ_EXTRA_FLAGS" \
 ../configure \
        --prefix=%{_prefix} \
        --infodir=%{_infodir} \
        --mandir=%{_mandir} \
        --libdir=%{_libdir} \
        --libexecdir=%{_libdir} \
+    --disable-bootstrap \
        --enable-languages=$languages \
        $ENABLE_CHECKING \
        --with-gxx-include-dir=%{_prefix}/include/c++/%{gcc_dir_version} \
        --enable-ssp \
        --disable-libssp \
-       --disable-libitm \
-%if 0%{?fast_build}
-       --disable-bootstrap \
-%endif
        --disable-plugin \
        --with-bugurl="http://bugs.tizen.org/" \
-       --with-pkgversion="Tizen Linux" \
+       --with-pkgversion="Tizen" \
 %if !%{build_libjava}
         --disable-libgcj \
 %else
@@ -577,12 +594,14 @@ TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
 %if 0%{?canonical_target:1}
        --with-build-time-tools=/usr/%{canonical_target}-tizen-linux%{?canonical_target_abi:%canonical_target_abi}/bin \
 %endif
+%if 0%{?sysroot:1}
+       --with-sysroot=%sysroot \
+%endif
 %if 0%{?build_static:1}
        --disable-shared \
 %endif
 %if "%{TARGET_ARCH}" == "spu"
-       --with-sysroot=/usr/spu \
-       --with-gxx-include-dir=%{_prefix}/spu/include/c++/%{gcc_dir_version} \
+       --with-gxx-include-dir=%sysroot/include/c++/%{gcc_dir_version} \
        --with-newlib \
 %endif
        --disable-nls \
@@ -590,8 +609,12 @@ TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
 %else
        --program-suffix=%{binsuffix} \
        --enable-linux-futex \
+%ifarch ia64
+       --with-system-libunwind \
+%else
        --without-system-libunwind \
 %endif
+%endif
 %if "%{TARGET_ARCH}" == "armv5tel"
        --with-arch=armv5te \
        --with-float=soft \
@@ -599,15 +622,15 @@ TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
        --with-abi=aapcs-linux \
        --disable-sjlj-exceptions \
 %endif
-%if "%{TARGET_ARCH}" == "armv7el" 
+%if "%{TARGET_ARCH}" == "armv7l" 
        --with-arch=armv7-a \
        --with-tune=cortex-a9 \
-       --with-float=soft \
-       --with-abi=softfp \
-       --with-fpu=vfpv3 \
+       --with-float=hard \
+       --with-abi=aapcs-linux \
+       --with-fpu=vfpv3-d16 \
        --disable-sjlj-exceptions \
 %endif
-%if "%{TARGET_ARCH}" == "armv7l" || "%{TARGET_ARCH}" == "armv7hl"
+%if  "%{TARGET_ARCH}" == "armv7hl"
        --with-arch=armv7-a \
        --with-tune=cortex-a9 \
        --with-float=hard \
@@ -615,6 +638,22 @@ TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
        --with-fpu=vfpv3-d16 \
        --disable-sjlj-exceptions \
 %endif
+%if "%{TARGET_ARCH}" == "powerpc" || "%{TARGET_ARCH}" == "powerpc64"
+%if "%{TARGET_ARCH}" == "powerpc"
+       --with-cpu=default32 \
+%endif
+       --with-cpu-64=power4 \
+       --enable-secureplt \
+       --with-long-double-128 \
+%endif
+%if "%{TARGET_ARCH}" == "sparc64"
+       --with-cpu=ultrasparc \
+       --with-long-double-128 \
+%endif
+%if "%{TARGET_ARCH}" == "sparc"
+       --with-cpu=v8 \
+       --with-long-double-128 \
+%endif
 %if "%{TARGET_ARCH}" == "i586"
        --with-arch-32=i586 \
        --with-tune=generic \
@@ -623,23 +662,28 @@ TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
        --with-arch-32=i586 \
        --with-tune=generic \
 %endif
+%if "%{TARGET_ARCH}" == "s390"
+        --with-tune=z196 --with-arch=z10 \
+       --with-long-double-128 \
+       --enable-decimal-float \
+%endif
+%if "%{TARGET_ARCH}" == "s390x"
+        --with-tune=z196 --with-arch=z10 \
+       --with-long-double-128 \
+       --enable-decimal-float \
+%endif
        --build=%{GCCDIST}
 
-# COMMON-END
 
 %if 0%{?building_libffi:1}
 make stage1-bubble $PARALLEL
 make all-target-libffi $PARALLEL
 %else
+STAGE1_FLAGS="-g"
 # Only run profiled bootstrap on archs where it works
-#%ifarch %ix86 x86_64 
-#make profiledbootstrap-lean STAGE1_CFLAGS="-O -g" BOOT_CFLAGS="$RPM_OPT_FLAGS" $PARALLEL
+#%ifarch %ix86 x86_64 ppc ppc64 ia64
+#make profiledbootstrap-lean STAGE1_CFLAGS="$STAGE1_FLAGS" BOOT_CFLAGS="$RPM_OPT_FLAGS" $PARALLEL
 #%else
-%ifarch %arm
-STAGE1_FLAGS="-O0"
-%else
-STAGE1_FLAGS="-O -g"
-%endif
 #make bootstrap-lean STAGE1_CFLAGS="$STAGE1_FLAGS" BOOT_CFLAGS="$RPM_OPT_FLAGS" $PARALLEL
 make STAGE1_CFLAGS="$STAGE1_FLAGS" BOOT_CFLAGS="$RPM_OPT_FLAGS" $PARALLEL
 #%endif
@@ -650,6 +694,8 @@ echo "Run testsuite"
 (make -C %{GCCDIST}/libstdc++-v3 check-abi || true)
 mv %{GCCDIST}/libstdc++-v3/testsuite/libstdc++.log %{GCCDIST}/libstdc++-v3/testsuite/libstdc++-abi.log
 mv %{GCCDIST}/libstdc++-v3/testsuite/libstdc++.sum %{GCCDIST}/libstdc++-v3/testsuite/libstdc++-abi.sum
+# asan needs a whole shadow address space
+ulimit -v unlimited || true
 make -k check $PARALLEL || true
 mkdir ../testresults
 ../contrib/test_summary | tee ../testresults/test_summary.txt
@@ -659,7 +705,6 @@ mkdir ../testresults
 %install
 export NO_BRP_CHECK_BYTECODE_VERSION=true
 cd obj-%{GCCDIST}
-# GCC-TESTSUITE-DELETE-BEGIN
 # Work around tail/head -1 changes
 export _POSIX2_VERSION=199209
 export LIBRARY_PATH=$RPM_BUILD_ROOT%{libsubdir}:$RPM_BUILD_ROOT%{mainlibdirbi}
@@ -704,11 +749,13 @@ rm -f $RPM_BUILD_ROOT%{libsubdir}/include/ffitarget.h
 rm -f $RPM_BUILD_ROOT%{_mandir}/man3/ffi%{binsuffix}.3*
 rm -f $RPM_BUILD_ROOT%{_mandir}/man3/ffi_call%{binsuffix}.3*
 rm -f $RPM_BUILD_ROOT%{_mandir}/man3/ffi_prep_cif%{binsuffix}.3*
+rm -f $RPM_BUILD_ROOT%{_mandir}/man3/ffi_prep_cif_var%{binsuffix}.3*
 %endif
 
 # Remove some useless .la files
 for lib in libobjc libgfortran libgfortranbegin libquadmath libcaf_single \
-    libmudflap libmudflapth libgomp libstdc++ libsupc++ libgcj-tools libgij; do
+    libmudflap libmudflapth libgomp libstdc++ libsupc++ libgcj-tools libgij \
+    libasan libatomic libitm libtsan; do
   rm -f $RPM_BUILD_ROOT%{versmainlibdir}/$lib.la
 %if %{biarch}
   rm -f $RPM_BUILD_ROOT%{versmainlibdirbi}/$lib.la
@@ -760,13 +807,11 @@ for l in `find $RPM_BUILD_ROOT -name '*.la'`; do
   mv $l.new $l
 done
 
-# GCC-TESTSUITE-DELETE-END
 %if 0%{?run_tests:1} 
 cp `find . -name "*.sum"` ../testresults/
 cp `find . -name "*.log"  \! -name "config.log" | grep -v 'acats.\?/tests' ` ../testresults/
 chmod 644 ../testresults/*
 %endif
-# GCC-TESTSUITE-DELETE-BEGIN
 # Remove files that we do not need to clean up filelist
 rm -f $RPM_BUILD_ROOT%{_prefix}/bin/%{GCCDIST}-*
 rm -rf $RPM_BUILD_ROOT%{libsubdir}/install-tools
@@ -802,6 +847,9 @@ crt32_list=$RPM_BUILD_ROOT%{versmainlibdirbi32}/crt*.o
 crt64_list=$RPM_BUILD_ROOT%{versmainlibdirbi64}/crt*.o
 %endif
 %endif
+for o in $crt_list $crt32_list $crt64_list; do
+  objcopy -R ".comment.SUSE.OPTs" $o
+done
 %endif
 
 %if 0%{?building_libjava:1}
@@ -855,9 +903,6 @@ rm -f $RPM_BUILD_ROOT%{_mandir}/man7/fsf-funding.7
 rm -f $RPM_BUILD_ROOT%{_mandir}/man7/gfdl.7
 rm -f $RPM_BUILD_ROOT%{_mandir}/man7/gpl.7
 rm -f $RPM_BUILD_ROOT%{_libdir}/libiberty.a
-%if %{build_nof}
-rm -f $RPM_BUILD_ROOT%{_prefix}/lib/nof/libiberty.a
-%endif
 %if %{biarch}
 %if %{build_primary_64bit}
 rm -f $RPM_BUILD_ROOT%{_prefix}/lib/libiberty.a
@@ -871,16 +916,21 @@ rm -f $RPM_BUILD_ROOT%{libsubdir}/liblto_plugin.la
 
 %if %{build_java}
 %if 0%{?building_libffi:1}
-%files 
+%files -n libffi%{libffi_sover}%{libffi_suffix}
 %defattr(-,root,root)
-%mainlib libffi.so.*
+%mainlib libffi.so.%{libffi_sover}*
 
 %if %{separate_biarch}
-%files -n libffi48%{separate_biarch_suffix}
+%files -n libffi%{libffi_sover}%{libffi_suffix}%{separate_biarch_suffix}
 %defattr(-,root,root)
-%biarchlib libffi.so.*
+%biarchlib libffi.so.%{libffi_sover}*
 %endif
 
+%post -n libffi48-devel
+%install_info --info-dir=%{_infodir} %{_infodir}/libffi%{binsuffix}.info.gz
+%postun -n libffi48-devel
+%install_info_delete --info-dir=%{_infodir} %{_infodir}/libffi%{binsuffix}.info.gz
+
 %files -n libffi48-devel
 %defattr(-,root,root)
 %{_prefix}/include/ffi.h
@@ -888,9 +938,11 @@ rm -f $RPM_BUILD_ROOT%{libsubdir}/liblto_plugin.la
 %mainlib libffi.so
 %mainlib libffi.a
 %{_libdir}/pkgconfig/libffi.pc
+%doc %{_infodir}/libffi%{binsuffix}.info.gz
 %doc %{_mandir}/man3/ffi%{binsuffix}.3.gz
 %doc %{_mandir}/man3/ffi_call%{binsuffix}.3.gz
 %doc %{_mandir}/man3/ffi_prep_cif%{binsuffix}.3.gz
+%doc %{_mandir}/man3/ffi_prep_cif_var%{binsuffix}.3.gz
 
 %if %{separate_biarch}
 %files -n libffi48-devel%{separate_biarch_suffix}
@@ -900,7 +952,6 @@ rm -f $RPM_BUILD_ROOT%{libsubdir}/liblto_plugin.la
 %endif
 %endif
 %endif
-# GCC-TESTSUITE-DELETE-END
 
 %if 0%{?run_tests:1}
 %files -n gcc48-testresults
index 62b706c..17ebf0f 100644 (file)
@@ -1,24 +1,40 @@
 %define building_libjava 1
-%define fast_build 1
+#
+# spec file for package gcc48
+#
+# Copyright (c) 2009 SUSE LINUX Products GmbH, Nuernberg, Germany.
+#
+# All modifications and additions to the file contributed by third parties
+# remain the property of their copyright owners, unless otherwise agreed
+# upon. The license for this file, and modifications and additions to the
+# file, is the same license as for the pristine package itself (unless the
+# license for the pristine package is not an Open Source License, in which
+# case the license is the MIT License). An "Open Source License" is a
+# license that conforms to the Open Source Definition (Version 1.9)
+# published by the Open Source Initiative.
+
+# Please submit bugfixes or comments via http://bugs.opensuse.org/
+#
+
+# norootforbuild
+# icecream 0
+
 
-# Ada currently fails to build on a few platforms, enable it only
-# on those that work
-# Note that AdaCore only supports %ix86, x86_64 and ia64
-%ifarch %ix86 x86_64
-%define build_ada !0%{?building_libjava:1}%{?building_libffi:1}
-%else
 %define build_ada 0
-%endif
 
-%define quadmath_arch %ix86 x86_64 
+%define quadmath_arch %ix86 x86_64 ia64
+%define tsan_arch x86_64
+%define asan_arch x86_64 %ix86 ppc ppc64
+%define itm_arch x86_64 %ix86 %arm ppc ppc64
+%define atomic_arch x86_64 %ix86 %arm ppc ppc64 s390 s390x
 
 # We don't want to build java
-%define build_java 1
-%define build_libjava 0%{?building_libjava:1}%{?building_libffi:1}%{?building_testsuite:1}
+%define build_java 0
+%define build_libjava 0
 
 %define build_cp 1
-%define build_fortran 1
-%define build_objc 1
+%define build_fortran !0%{?building_libjava:1}%{?building_libffi:1}
+%define build_objc !0%{?building_libjava:1}%{?building_libffi:1}
 %define build_objcp !0%{?building_libjava:1}%{?building_libffi:1}
 %define build_with_mudflap 0
 
 %endif
 
 # For optional compilers only build C, C++ and Fortran
-##%if 0%{?build_optional_compiler:1}%{?build_optional_compiler_languages:1}
-%if 0%{!?building_libffi:1}
+%if 0%{?build_optional_compiler_languages:1}
 %define build_ada 0
 %define build_java 0
 %define build_libjava 0
-%define build_objc 1
-%define build_objcp 1
+%define build_objc 0
+%define build_objcp 0
 %endif
 
+# Shared library SONAME versions
+%ifarch hppa
+%define libgcc_s 4
+%else
+%define libgcc_s 1
+%endif
+%define libgcj_sover 14
+%define libgcj_bc_sover 1
+%define libffi_sover 4
+%define libmudflap_sover 0
+%define libgomp_sover 1
+%define libstdcxx_sover 6
+%define libobjc_sover 4
+%define libgfortran_sover 3
+%define libquadmath_sover 0
+%define libasan_sover 0
+%define libtsan_sover 0
+%define libatomic_sover 1
+%define libitm_sover 1
+
+# Shared library package suffix
+# This is used for the "non-standard" set of libraries, the standard
+# being defined by %product_libs_gcc_ver, the GCC version that should
+# provide un-suffixed shared library packages following the shared-library
+# policy.  Even suffixed variants should provide the shared-library policy
+# mandated names and ensure they conflict with each other.
+# Note that on SONAME changes of any library the %product_libs_gcc_ver
+# define needs to be either split or the newest GCC version still providing
+# the old SONAME needs to unconditionally produce an un-suffixed library
+# if %product_libs_gcc_ver is newer than it.  Similar the _oldest_ GCC
+# version first providing a new SONAME needs to unconditionally produce
+# an un-suffixed library if %product_libs_gcc_ver is lower that it.
+%if %{!?product_libs_gcc_ver:48}%{?product_libs_gcc_ver} != 48
+%define pne 1
+%endif
+%define libgcc_s_suffix %{?pne:-gcc48}
+# libgcj SONAME changes with every GCC version
+%define libgcj_suffix %nil
+%define libgcj_bc_suffix %{?pne:-gcc48}
+%define libffi_suffix %{?pne:-gcc48}
+%define libmudflap_suffix %{?pne:-gcc48}
+%define libgomp_suffix %{?pne:-gcc48}
+%define libstdcxx_suffix %{?pne:-gcc48}
+%define libobjc_suffix %{?pne:-gcc48}
+%define libgfortran_suffix %{?pne:-gcc48}
+%define libquadmath_suffix %{?pne:-gcc48}
+%define libasan_suffix %{?pne:-gcc48}
+%define libtsan_suffix %{?pne:-gcc48}
+%define libatomic_suffix %{?pne:-gcc48}
+%define libitm_suffix %{?pne:-gcc48}
+
+
+
 
 Name: libgcj48
+BuildRequires: gcc-c++
 BuildRequires: bison
 BuildRequires: flex
-BuildRequires: gettext-tools
-BuildRequires: makeinfo
 BuildRequires: glibc-devel-32bit
 BuildRequires: mpc-devel
 BuildRequires: mpfr-devel
 BuildRequires: perl
-BuildRequires: texinfo
+BuildRequires: makeinfo
 BuildRequires: zlib-devel
-%ifarch %ix86 x86_64 %arm
-BuildRequires: cloog-devel
-BuildRequires: ppl-devel
+%ifarch %ix86 x86_64 ppc ppc64 s390 s390x ia64 %sparc hppa %arm
+BuildRequires: cloog-isl-devel
+BuildRequires: isl-devel
 %endif
 %if %{build_ada}
-%define hostsuffix -4.8
-BuildRequires: gcc48-ada
+%define hostsuffix -4.7
+BuildRequires: gcc47-ada
 %endif
 %if 0%{?building_libjava:1}%{?building_testsuite:1}
 BuildRequires: fastjar
-BuildRequires: unzip
 %endif
 %if 0%{?building_libffi:1}
 BuildRequires: pkg-config
 %endif
+%ifarch ia64
+BuildRequires: libunwind-devel
+%endif
 %if 0%{?run_tests:1}
 BuildRequires: dejagnu
 BuildRequires: expect
 BuildRequires: gdb
 %endif
 
-# Define version number of libgcc_s
-%define libgcc_s 1
-%define build_nof 0
-
 %define separate_bi32 0
 %define separate_bi64 0
-%ifarch x86_64 
+%ifarch ppc sparcv9
+# Beware, this does _not_ separate libgcj, as for that one multilibing
+# is inactive for the time being
+%define separate_bi64 1
+%endif
+%ifarch x86_64 s390x ppc64 sparc64
 %define separate_bi32 1
 %endif
 
@@ -95,7 +165,7 @@ BuildRequires: gdb
 %define separate_biarch_suffix -64bit
 %endif
 
-%ifarch x86_64
+%ifarch x86_64 ia64 s390x alpha ppc64 sparc64
 # 64-bit is primary build target
 %define build_primary_64bit 1
 %else
@@ -104,8 +174,7 @@ BuildRequires: gdb
 
 %define biarch_libjava 0
 
-# COMMON-BEGIN
-%define biarch_targets x86_64 
+%define biarch_targets x86_64 s390x powerpc64 powerpc sparc sparc64
 
 URL:          http://gcc.gnu.org/
 Version: 4.8.1
@@ -114,52 +183,42 @@ Release:      1
 %define gcc_dir_version %(echo %gcc_version | cut -d '.' -f 1-2)
 %define snapshot_date %(echo %version | sed 's/[34]\.[0-9]\.[0-6]//' | sed 's/_/-/')
 %define binsuffix -4.8
-# COMMON-END
 
 %if !0%{?building_libjava:1}%{?building_libffi:1}%{?building_testsuite:1}
 Requires: binutils glibc-devel
 Requires: cpp48 = %{version}-%{release}
-%if 0%{!?build_optional_compiler:1}
-Requires: libgcc%{libgcc_s} >= %{version}-%{release}
-Requires: libgomp1 >= %{version}-%{release}
+Requires: libgcc_s%{libgcc_s} >= %{version}-%{release}
+Requires: libgomp%{libgomp_sover} >= %{version}-%{release}
 %if %{build_with_mudflap}
-Requires: libmudflap0 >= %{version}-%{release}
-Requires: libmudflapth0 >= %{version}-%{release}
+Requires: libmudflap%{libmudflap_sover} >= %{version}-%{release}
+Requires: libmudflapth%{libmudflap_sover} >= %{version}-%{release}
 %endif
-%else
-Requires: libgcc48 = %{version}-%{release}
-Requires: libgomp48 = %{version}-%{release}
+%ifarch %asan_arch
+Requires: libasan%{libasan_sover} >= %{version}-%{release}
+%endif
+%ifarch %tsan_arch
+Requires: libtsan%{libtsan_sover} >= %{version}-%{release}
 %endif
+%ifarch %atomic_arch
+Requires: libatomic%{libatomic_sover} >= %{version}-%{release}
+%endif
+%ifarch %itm_arch
+Requires: libitm%{libitm_sover} >= %{version}-%{release}
+%endif
+Suggests: gcc48-info gcc48-locale
 %endif
 
-# COMMON-BEGIN
 BuildRoot:     %{_tmppath}/%{name}-%{version}-build
-#Source:               gcc-%{gcc_version}%{snapshot_date}.tar.bz2
-Source:     gcc-%{version}.tar.bz2
-
+Source:                gcc-%{gcc_version}%{snapshot_date}.tar.bz2
 Source1:       change_spec
-Source2:       libgcj48-rpmlintrc
 Source3:       gcc48-rpmlintrc
 Source4:       ecj.jar
 Source6:       baselibs.conf
-# Patches auto-generated by git-buildpackage:
-Patch0:     0001-dir-version.patch
-Patch1:     0002-textdomain.patch
-Patch2:     0003-rename-info-files.patch
-Patch3:     0004-ARM-linker.patch
-
-# GCC-TESTSUITE-DELETE-BEGIN
-# LIBFFI-DELETE-BEGIN
+
+
 Summary:      Java Runtime Library for gcc
 License:      GPL-2.0-with-classpath-exception
 Group:        System/Libraries
-%define gcj_sover 13
-Provides: libgcj%{gcj_sover} = %{version}-%{release}
-Conflicts: libgcj%{gcj_sover} < %{version}-%{release}
-Provides: libgij%{gcj_sover} = %{version}-%{release}
-Conflicts: libgij%{gcj_sover} < %{version}-%{release}
-Provides: libgcj-tools%{gcj_sover} = %{version}-%{release}
-Conflicts: libgcj-tools%{gcj_sover} < %{version}-%{release}
 
 %description 
 This library is needed if you want to use the GNU Java compiler, gcj.
@@ -175,7 +234,7 @@ Source code for this package is in gcc.
 %package -n gcc48-java
 Summary:      The GNU Java Compiler
 License:        GPL-3.0+
-Group:        Development/Languages
+Group:        Development/Languages/Java
 Requires: gcc48 = %{version}
 Requires: libgcj48-devel = %{version}-%{release}
 
@@ -183,24 +242,21 @@ Requires: libgcj48-devel = %{version}-%{release}
 The Java compiler from the GCC-tools-suite.
 
 
-%package -n libgcj_bc48
+%package -n libgcj_bc%{libgcj_bc_sover}%{libgcj_bc_suffix}
 Summary:      Fake library for BC-ABI compatibility.
 License:        GPL-2.0-with-classpath-exception
-Group:        Development/Libraries
-Provides: libgcj_bc1 = %{version}-%{release}
-Conflicts: libgcj_bc1 < %{version}-%{release}
+Group:        Development/Libraries/Java
 # libgcj_bc is special in that it just contains a symlink to
 # a proper libgcj version.  So require that library and add
 # provides for the shlib version as created at link time
-Requires: libgcj%{gcj_sover}
-%ifarch x86_64 
-Provides: libgcj_bc.so.1()(64bit)
+Requires: libgcj%{libgcj_sover} >= %{version}-%{release}
+%ifarch x86_64 ia64 ppc64 s390x sparc64 aarch64
+Provides: libgcj_bc.so.%{libgcj_bc_sover}()(64bit)
 %else
-Provides: libgcj_bc.so.1
+Provides: libgcj_bc.so.%{libgcj_bc_sover}
 %endif
 
-
-%description -n libgcj_bc48
+%description -n libgcj_bc%{libgcj_bc_sover}%{libgcj_bc_suffix}
 A fake library that is used at link time only. It ensures that
 binaries built with the BC-ABI link against a constant SONAME.
 This way, BC-ABI binaries continue to work if the SONAME underlying
@@ -219,15 +275,18 @@ These are the jar files that go along with the gcj front end to gcc.
 %package -n libgcj48-devel
 Summary:      Include Files and Libraries mandatory for Development.
 License:        GPL-2.0-with-classpath-exception
-Group:        Development/Libraries
+Group:        Development/Libraries/Java
 Requires: libstdc++48-devel = %{version}
-Requires: libgcj%{gcj_sover} >= %{version}-%{release}
-Requires: libgcj_bc1 >= %{version}-%{release}
+Requires: libgcj%{libgcj_sover} >= %{version}-%{release}
+Requires: libgcj_bc%{libgcj_bc_sover} >= %{version}-%{release}
 Requires: libgcj48-jar = %{version}-%{release}
 Requires: gtk2-devel
 Requires: libart_lgpl-devel
 Requires: glibc-devel
 Requires: zlib-devel
+%ifarch ia64
+Requires: libunwind-devel
+%endif
 
 %description -n libgcj48-devel
 This package contains all necessary include files and libraries needed
@@ -237,122 +296,86 @@ to develop applications that require these.
 %package -n gcc48-gij
 Summary:      Java Bytecode Interpreter for gcc
 License:      GPL-2.0-with-classpath-exception
-Group:        Development/Libraries
-Requires: libgcj%{gcj_sover} >= %{version}-%{release}
+Group:        Development/Libraries/Java
+Requires: libgcj%{libgcj_sover} >= %{version}-%{release}
 
 %description -n gcc48-gij
 This package contains the java bytecode interpreter gij and related tools.
 
-# LIBFFI-DELETE-END
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
-%package -n libffi48
+%package -n libffi%{libffi_sover}%{libffi_suffix}
 Summary:      Foreign Function Interface library
 License:        BSD-3-Clause
-Group:        Base/Libraries
-Provides: g-wrap:/usr/lib/libffi.so.4
-Provides: libffi4 = %{version}-%{release}
-Conflicts: libffi4 < %{version}-%{release}
+Group:        Development/Languages/C and C++
 
-%description -n libffi48
+%description -n libffi%{libffi_sover}%{libffi_suffix}
 A foreign function interface is the popular name for the interface that allows code written in one language to call code written in another language.
 
-%post -n libffi48
+%post -n libffi%{libffi_sover}%{libffi_suffix}
 /sbin/ldconfig
 
-%postun -n libffi48
+%postun -n libffi%{libffi_sover}%{libffi_suffix}
 /sbin/ldconfig
-# PACKAGE-END
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
-%package -n libffi48-32bit
+%package -n libffi%{libffi_sover}%{libffi_suffix}-32bit
 Summary:      Foreign Function Interface library
 License:        BSD-3-Clause
-Group:        Base/Libraries
-Provides: g-wrap:/usr/lib/libffi.so.4
-Provides: libffi4-32bit = %{version}-%{release}
-Conflicts: libffi4-32bit < %{version}-%{release}
+Group:        Development/Languages/C and C++
 
-%description -n libffi48-32bit
+%description -n libffi%{libffi_sover}%{libffi_suffix}-32bit
 A foreign function interface is the popular name for the interface that allows code written in one language to call code written in another language.
 
-%post -n libffi48-32bit
+%post -n libffi%{libffi_sover}%{libffi_suffix}-32bit
 /sbin/ldconfig
 
-%postun -n libffi48-32bit
+%postun -n libffi%{libffi_sover}%{libffi_suffix}-32bit
 /sbin/ldconfig
-# PACKAGE-END
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
-%package -n libffi48-64bit
+%package -n libffi%{libffi_sover}%{libffi_suffix}-64bit
 Summary:      Foreign Function Interface library
 License:        BSD-3-Clause
-Group:        Base/Libraries
-Provides: g-wrap:/usr/lib/libffi.so.4
-Provides: libffi4-64bit = %{version}-%{release}
-Conflicts: libffi4-64bit < %{version}-%{release}
+Group:        Development/Languages/C and C++
 
-%description -n libffi48-64bit
+%description -n libffi%{libffi_sover}%{libffi_suffix}-64bit
 A foreign function interface is the popular name for the interface that allows code written in one language to call code written in another language.
 
-%post -n libffi48-64bit
+%post -n libffi%{libffi_sover}%{libffi_suffix}-64bit
 /sbin/ldconfig
 
-%postun -n libffi48-64bit
+%postun -n libffi%{libffi_sover}%{libffi_suffix}-64bit
 /sbin/ldconfig
-# PACKAGE-END
 
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
 %package -n libffi48-devel
 Summary:      Foreign Function Interface library development files
 License:        BSD 3-Clause
-Group:        Development/Toolchain
-Requires: libffi4 >= %{version}-%{release}
-Provides: libffi-devel = %{version}-%{release}
-Conflicts: libffi-devel < %{version}-%{release}
+Group:        Development/Languages/C and C++
+Requires: libffi%{libffi_sover} >= %{version}-%{release}
 
 %description -n libffi48-devel
 A foreign function interface is the popular name for the interface that allows code written in one language to call code written in another language.
-# PACKAGE-END
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
 %package -n libffi48-devel-32bit
 Summary:      Foreign Function Interface library development files
 License:        BSD 3-Clause
-Group:        Development/Toolchain
-Requires: libffi4-32bit >= %{version}-%{release}
-Provides: libffi-devel-32bit = %{version}-%{release}
-Conflicts: libffi-devel-32bit < %{version}-%{release}
+Group:        Development/Languages/C and C++
+Requires: libffi%{libffi_sover}-32bit >= %{version}-%{release}
 
 %description -n libffi48-devel-32bit
 A foreign function interface is the popular name for the interface that allows code written in one language to call code written in another language.
-# PACKAGE-END
-# PACKAGE-BEGIN
-# PACKAGE-BEGIN
 %package -n libffi48-devel-64bit
 Summary:      Foreign Function Interface library development files
 License:        BSD 3-Clause
-Group:        Development/Toolchain
-Requires: libffi4-64bit >= %{version}-%{release}
-Provides: libffi-devel-64bit = %{version}-%{release}
-Conflicts: libffi-devel-64bit < %{version}-%{release}
+Group:        Development/Languages/C and C++
+Requires: libffi%{libffi_sover}-64bit >= %{version}-%{release}
 
 %description -n libffi48-devel-64bit
 A foreign function interface is the popular name for the interface that allows code written in one language to call code written in another language.
-# PACKAGE-END
 
 %package -n gcc48-testresults
-# GCC-TESTSUITE-DELETE-END
 Summary:      Testsuite results
-License:       Public-Domain
-Group:        Development/Toolchain
+License:       SUSE-Public-Domain
+Group:        Development/Languages/C and C++
 
 %description -n gcc48-testresults
 Results from running the gcc and target library testsuites.
 
 
-# COMMON-BEGIN
 
 # Define the canonical target and host architecture
 #   %gcc_target_arch  is supposed to be the full target triple
@@ -361,6 +384,12 @@ Results from running the gcc and target library testsuites.
 %if 0%{?gcc_target_arch:1}
 %define CONFIGURE_TARGET %{gcc_target_arch}
 %define TARGET_ARCH %(echo %{gcc_target_arch} | cut -d - -f 1 | sed -e "s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;")
+%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "powerpc"
+%define CONFIGURE_TARGET powerpc64-tizen-linux
+%endif
+%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "powerpc64"
+%define CONFIGURE_TARGET powerpc64-tizen-linux
+%endif
 %if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "i586"
 %define CONFIGURE_TARGET i586-tizen-linux
 %endif
@@ -370,11 +399,8 @@ Results from running the gcc and target library testsuites.
 %if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "armv7hl"
 %define CONFIGURE_TARGET armv7hl-tizen-linux-gnueabi
 %endif
-%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "armv7el"
-%define CONFIGURE_TARGET armv7el-tizen-linux-gnueabi
-%endif
-%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "armv5el"
-%define CONFIGURE_TARGET armv5el-tizen-linux-gnueabi
+%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "armv5tel"
+%define CONFIGURE_TARGET armv5tel-tizen-linux-gnueabi
 %endif
 %else
 %define TARGET_ARCH %(echo %{_target_cpu} | sed -e "s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;")
@@ -383,44 +409,46 @@ Results from running the gcc and target library testsuites.
 
 %define biarch %(case " %{biarch_targets} " in (*" %{TARGET_ARCH} "*) echo 1;; (*) echo 0;; esac)
 
+%ifarch ppc
+%define GCCDIST powerpc64-tizen-linux
+%else
+%ifarch %sparc
+%define GCCDIST sparc64-tizen-linux
+%else
 %ifarch %arm
 %define GCCDIST %{HOST_ARCH}-tizen-linux-gnueabi
 %else
 %define GCCDIST %{HOST_ARCH}-tizen-linux
 %endif
+%endif
+%endif
 
 %define libsubdir %{_libdir}/gcc/%{GCCDIST}/%{gcc_dir_version}
 %define gxxinclude %{_prefix}/include/c++/%{gcc_dir_version}
 
-# COMMON-END
 
 # Versionspecific directories
 %define versmainlibdir %{libsubdir}
 %define versmainlibdirbi32 %{libsubdir}/32
 %define versmainlibdirbi64 %{libsubdir}/64
+%ifarch ppc
+%define versmainlibdirbi32 %{libsubdir}
+%define versmainlibdirbi64 %{libsubdir}/64
+%endif
 %if %{build_primary_64bit}
 %define versmainlibdirbi %{versmainlibdirbi32}
 %else
 %define versmainlibdirbi %{versmainlibdirbi64}
 %endif
 
-%if 0%{?build_optional_compiler:1}
-%define mainlibdir %{versmainlibdir}
-%define mainlibdirbi32 %{versmainlibdirbi32}
-%define mainlibdirbi64 %{versmainlibdirbi64}
-%define noflibdir %{versnoflibdir}
-%define mainlibdirbi %{versmainlibdirbi}
-%else
 %define mainlibdir %{_libdir}
 %define mainlibdirbi32 %{_prefix}/lib
 %define mainlibdirbi64 %{_prefix}/lib64
-%define noflibdir %{_prefix}/lib/nof
 %if %{build_primary_64bit}
 %define mainlibdirbi %{mainlibdirbi32}
 %else
 %define mainlibdirbi %{mainlibdirbi64}
 %endif
-%endif
 
 
 # Now define a few macros that make it easy to package libs and
@@ -428,88 +456,51 @@ Results from running the gcc and target library testsuites.
 # exact path the files are in.
 #   %mainlib  package X from all dirs that belong to the main package
 #   %biarchlib   package X from all dirs that belong to the -32/64bit package
-# by default, nof libs go where the 32bit libs go.
-%if %{build_nof}
-%define mainlib() %{mainlibdir}/%1\
-%{noflibdir}/%1\
-%{nil}
-%else
 %define mainlib() %{mainlibdir}/%1\
 %{nil}
-%endif
 %define biarchlib() %{nil}
 %if %{biarch}
 %if !%{separate_biarch}
-%if %{build_nof}
 %define mainlib() %{mainlibdir}/%1\
 %{mainlibdirbi}/%1\
-%{noflibdir}/%1\
-%{nil}
-%else
-%define mainlib() %{mainlibdir}/%1\
-%{mainlibdirbi}/%1\
-%{nil}
-%endif
-%else
-%if %{build_nof}
-%define biarchlib() %{mainlibdirbi}/%1\
-%{noflibdir}/%1\
-%{nil}
-%define mainlib() %{mainlibdir}/%1\
 %{nil}
 %else
 %define biarchlib() %{mainlibdirbi}/%1\
 %{nil}
 %endif
 %endif
-%endif
 
-%if %{build_nof}
 %define versmainlib() %{versmainlibdir}/%1\
-%{versnoflibdir}/%1\
 %{nil}
-%else
-%define versmainlib() %{versmainlibdir}/%1\
-%{nil}
-%endif
 %define versbiarchlib() %{nil}
 %if %{biarch}
 %if !%{separate_biarch}
-%if %{build_nof}
 %define versmainlib() %{versmainlibdir}/%1\
 %{versmainlibdirbi}/%1\
-%{versnoflibdir}/%1\
 %{nil}
 %else
-%define versmainlib() %{versmainlibdir}/%1\
-%{versmainlibdirbi}/%1\
-%{nil}
-%endif
-%else
-%if %{build_nof}
 %define versbiarchlib() %{versmainlibdirbi}/%1\
-%{versnoflibdir}/%1\
-%{nil}
-%define versmainlib() %{versmainlibdir}/%1\
 %{nil}
-%else
-%define versbiarchlib() %{versmainlibdirbi}/%1\
-%{nil}
-%endif
 %endif
 %endif
 
 
-# COMMON-BEGIN
 
 %prep
-#%setup -q -n gcc-%{gcc_version}%{snapshot_date}
-%setup -q -n gcc-%{version}
-# 0001-dir-version.patch
-%patch0 -p1
-%patch1 -p1
-%patch2 -p1
-%patch3 -p1
+%setup -q -n gcc-%{gcc_version}%{snapshot_date}
+
+
+# We are configuring ppc as ppc64 but with switched multilibs.  Adjust
+# the libstdc++ abi testsuite baseline files accordingly
+%ifarch ppc
+if [ -d libstdc++-v3/config/abi/post/powerpc64-linux-gnu ]; then
+  mkdir -p libstdc++-v3/config/abi/post/powerpc64-linux-gnu/64
+  mv libstdc++-v3/config/abi/post/powerpc64-linux-gnu/baseline_symbols.txt \
+       libstdc++-v3/config/abi/post/powerpc64-linux-gnu/64/
+  mv libstdc++-v3/config/abi/post/powerpc64-linux-gnu/32/baseline_symbols.txt \
+       libstdc++-v3/config/abi/post/powerpc64-linux-gnu/
+fi
+%endif
 
 %build
 # Avoid rebuilding of generated files
@@ -540,6 +531,10 @@ RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-fno-rtti//g' -e 's/-fno-exceptions
 # default compiler settings now.
 RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-mcpu=i.86//g' -e 's/-march=i.86//g' -e 's/-mtune=i.86//g'`
 %endif
+%ifarch s390 s390x
+RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-fsigned-char//g'`
+RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-O1/-O2/g'`
+%endif
 %if 0%{?gcc_target_arch:1} && 0%{!?gcc_icecream:1}
 # Kill all -march/tune/cpu because that screws building the target libs
 RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-m\(arch\|tune\|cpu\)=[^ ]*//g'`
@@ -602,7 +597,7 @@ export _POSIX2_VERSION=199209
 # if glibc supports SSP.  When cross compiling we would need
 # to install a cross glibc, which we don't, or make the whole
 # thing point to the native glibc, which is in /, hence the
-# --with-sysroot=/
+# --with-build-sysroot=/
 
 %if %{build_ada}
 # Using the host gnatmake like
@@ -623,26 +618,27 @@ export PATH="`pwd`/host-tools/bin:$PATH"
 #      --enable-threads=posix \
 #%endif
 #      --enable-shared \
+%if "%{TARGET_ARCH}" == "armv7l" || "%{TARGET_ARCH}" == "armv7hl"
+# temporary workaround for a miscompilation of hash functions in java code
+GCJ_EXTRA_FLAGS="-marm"
+%endif
 CFLAGS="$RPM_OPT_FLAGS" CXXFLAGS="$RPM_OPT_FLAGS" XCFLAGS="$RPM_OPT_FLAGS" \
-TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
+TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS $GCJ_EXTRA_FLAGS" \
 ../configure \
        --prefix=%{_prefix} \
        --infodir=%{_infodir} \
        --mandir=%{_mandir} \
        --libdir=%{_libdir} \
        --libexecdir=%{_libdir} \
+    --disable-bootstrap \
        --enable-languages=$languages \
        $ENABLE_CHECKING \
        --with-gxx-include-dir=%{_prefix}/include/c++/%{gcc_dir_version} \
        --enable-ssp \
        --disable-libssp \
-       --disable-libitm \
-%if 0%{?fast_build}
-       --disable-bootstrap \
-%endif
        --disable-plugin \
        --with-bugurl="http://bugs.tizen.org/" \
-       --with-pkgversion="Tizen Linux" \
+       --with-pkgversion="Tizen" \
 %if !%{build_libjava}
         --disable-libgcj \
 %else
@@ -673,12 +669,14 @@ TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
 %if 0%{?canonical_target:1}
        --with-build-time-tools=/usr/%{canonical_target}-tizen-linux%{?canonical_target_abi:%canonical_target_abi}/bin \
 %endif
+%if 0%{?sysroot:1}
+       --with-sysroot=%sysroot \
+%endif
 %if 0%{?build_static:1}
        --disable-shared \
 %endif
 %if "%{TARGET_ARCH}" == "spu"
-       --with-sysroot=/usr/spu \
-       --with-gxx-include-dir=%{_prefix}/spu/include/c++/%{gcc_dir_version} \
+       --with-gxx-include-dir=%sysroot/include/c++/%{gcc_dir_version} \
        --with-newlib \
 %endif
        --disable-nls \
@@ -686,8 +684,12 @@ TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
 %else
        --program-suffix=%{binsuffix} \
        --enable-linux-futex \
+%ifarch ia64
+       --with-system-libunwind \
+%else
        --without-system-libunwind \
 %endif
+%endif
 %if "%{TARGET_ARCH}" == "armv5tel"
        --with-arch=armv5te \
        --with-float=soft \
@@ -695,15 +697,15 @@ TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
        --with-abi=aapcs-linux \
        --disable-sjlj-exceptions \
 %endif
-%if "%{TARGET_ARCH}" == "armv7el" 
+%if "%{TARGET_ARCH}" == "armv7l" 
        --with-arch=armv7-a \
        --with-tune=cortex-a9 \
-       --with-float=soft \
-       --with-abi=softfp \
-       --with-fpu=vfpv3 \
+       --with-float=hard \
+       --with-abi=aapcs-linux \
+       --with-fpu=vfpv3-d16 \
        --disable-sjlj-exceptions \
 %endif
-%if "%{TARGET_ARCH}" == "armv7l" || "%{TARGET_ARCH}" == "armv7hl"
+%if  "%{TARGET_ARCH}" == "armv7hl"
        --with-arch=armv7-a \
        --with-tune=cortex-a9 \
        --with-float=hard \
@@ -711,6 +713,22 @@ TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
        --with-fpu=vfpv3-d16 \
        --disable-sjlj-exceptions \
 %endif
+%if "%{TARGET_ARCH}" == "powerpc" || "%{TARGET_ARCH}" == "powerpc64"
+%if "%{TARGET_ARCH}" == "powerpc"
+       --with-cpu=default32 \
+%endif
+       --with-cpu-64=power4 \
+       --enable-secureplt \
+       --with-long-double-128 \
+%endif
+%if "%{TARGET_ARCH}" == "sparc64"
+       --with-cpu=ultrasparc \
+       --with-long-double-128 \
+%endif
+%if "%{TARGET_ARCH}" == "sparc"
+       --with-cpu=v8 \
+       --with-long-double-128 \
+%endif
 %if "%{TARGET_ARCH}" == "i586"
        --with-arch-32=i586 \
        --with-tune=generic \
@@ -719,23 +737,28 @@ TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
        --with-arch-32=i586 \
        --with-tune=generic \
 %endif
+%if "%{TARGET_ARCH}" == "s390"
+        --with-tune=z196 --with-arch=z10 \
+       --with-long-double-128 \
+       --enable-decimal-float \
+%endif
+%if "%{TARGET_ARCH}" == "s390x"
+        --with-tune=z196 --with-arch=z10 \
+       --with-long-double-128 \
+       --enable-decimal-float \
+%endif
        --build=%{GCCDIST}
 
-# COMMON-END
 
 %if 0%{?building_libffi:1}
 make stage1-bubble $PARALLEL
 make all-target-libffi $PARALLEL
 %else
+STAGE1_FLAGS="-g"
 # Only run profiled bootstrap on archs where it works
-#%ifarch %ix86 x86_64 
-#make profiledbootstrap-lean STAGE1_CFLAGS="-O -g" BOOT_CFLAGS="$RPM_OPT_FLAGS" $PARALLEL
+#%ifarch %ix86 x86_64 ppc ppc64 ia64
+#make profiledbootstrap-lean STAGE1_CFLAGS="$STAGE1_FLAGS" BOOT_CFLAGS="$RPM_OPT_FLAGS" $PARALLEL
 #%else
-%ifarch %arm
-STAGE1_FLAGS="-O0"
-%else
-STAGE1_FLAGS="-O -g"
-%endif
 #make bootstrap-lean STAGE1_CFLAGS="$STAGE1_FLAGS" BOOT_CFLAGS="$RPM_OPT_FLAGS" $PARALLEL
 make STAGE1_CFLAGS="$STAGE1_FLAGS" BOOT_CFLAGS="$RPM_OPT_FLAGS" $PARALLEL
 #%endif
@@ -746,6 +769,8 @@ echo "Run testsuite"
 (make -C %{GCCDIST}/libstdc++-v3 check-abi || true)
 mv %{GCCDIST}/libstdc++-v3/testsuite/libstdc++.log %{GCCDIST}/libstdc++-v3/testsuite/libstdc++-abi.log
 mv %{GCCDIST}/libstdc++-v3/testsuite/libstdc++.sum %{GCCDIST}/libstdc++-v3/testsuite/libstdc++-abi.sum
+# asan needs a whole shadow address space
+ulimit -v unlimited || true
 make -k check $PARALLEL || true
 mkdir ../testresults
 ../contrib/test_summary | tee ../testresults/test_summary.txt
@@ -755,7 +780,6 @@ mkdir ../testresults
 %install
 export NO_BRP_CHECK_BYTECODE_VERSION=true
 cd obj-%{GCCDIST}
-# GCC-TESTSUITE-DELETE-BEGIN
 # Work around tail/head -1 changes
 export _POSIX2_VERSION=199209
 export LIBRARY_PATH=$RPM_BUILD_ROOT%{libsubdir}:$RPM_BUILD_ROOT%{mainlibdirbi}
@@ -800,11 +824,13 @@ rm -f $RPM_BUILD_ROOT%{libsubdir}/include/ffitarget.h
 rm -f $RPM_BUILD_ROOT%{_mandir}/man3/ffi%{binsuffix}.3*
 rm -f $RPM_BUILD_ROOT%{_mandir}/man3/ffi_call%{binsuffix}.3*
 rm -f $RPM_BUILD_ROOT%{_mandir}/man3/ffi_prep_cif%{binsuffix}.3*
+rm -f $RPM_BUILD_ROOT%{_mandir}/man3/ffi_prep_cif_var%{binsuffix}.3*
 %endif
 
 # Remove some useless .la files
 for lib in libobjc libgfortran libgfortranbegin libquadmath libcaf_single \
-    libmudflap libmudflapth libgomp libstdc++ libsupc++ libgcj-tools libgij; do
+    libmudflap libmudflapth libgomp libstdc++ libsupc++ libgcj-tools libgij \
+    libasan libatomic libitm libtsan; do
   rm -f $RPM_BUILD_ROOT%{versmainlibdir}/$lib.la
 %if %{biarch}
   rm -f $RPM_BUILD_ROOT%{versmainlibdirbi}/$lib.la
@@ -820,9 +846,7 @@ mkdir -p $RPM_BUILD_ROOT%{_prefix}/lib64
 %endif
 %endif
 
-# LIBFFI-DELETE-BEGIN
 
-%if 0%{!?build_optional_compiler:1}
 # move shared libs from versionspecific dir to main libdir
 for libname in \
 %if 0%{?building_libjava:1}
@@ -841,6 +865,18 @@ for libname in \
   libstdc++ \
 %endif
   libgomp \
+%ifarch %atomic_arch
+  libatomic \
+%endif
+%ifarch %itm_arch
+  libitm \
+%endif
+%ifarch %asan_arch
+  libasan \
+%endif
+%ifarch %tsan_arch
+  libtsan \
+%endif
 %if %{build_with_mudflap}
   libmudflap libmudflapth \
 %endif
@@ -861,6 +897,12 @@ for libname in \
   fi
 %endif
 done
+# FIXME, tsan is not multilib
+%ifarch %tsan_arch
+%if %{biarch}
+rm -f $RPM_BUILD_ROOT%{versmainlibdirbi}/libtsan.so
+%endif
+%endif
 %if %{build_cp}
 %if !0%{?building_libjava:1}
 # And we want to move the shlib gdb pretty printers to a more sane
@@ -884,17 +926,15 @@ sed -i -e '/^libdir/s/\/gcc\/%{GCCDIST}\/%{gcc_dir_version}//g' $RPM_BUILD_ROOT%
 for lib in `find $RPM_BUILD_ROOT%{versmainlibdir} -maxdepth 1 -name libgcj_bc.so.*`; do
   rm $lib
 done
-ln -s libgcj.so.%{gcj_sover} $RPM_BUILD_ROOT%{mainlibdir}/libgcj_bc.so.1
+ln -s libgcj.so.%{libgcj_sover} $RPM_BUILD_ROOT%{mainlibdir}/libgcj_bc.so.%{libgcj_bc_sover}
 %if %{biarch_libjava}
 for lib in `find $RPM_BUILD_ROOT%{versmainlibdirbi} -maxdepth 1 -name libgcj_bc.so.*`; do
   rm $lib
 done
-ln -s libgcj.so.%{gcj_sover} $RPM_BUILD_ROOT%{mainlibdirbi}/libgcj_bc.so.1
-%endif
+ln -s libgcj.so.%{libgcj_sover} $RPM_BUILD_ROOT%{mainlibdirbi}/libgcj_bc.so.%{libgcj_bc_sover}
 %endif
 %endif
 
-# LIBFFI-DELETE-END
 
 %if %{build_ada}
 mv $RPM_BUILD_ROOT%{libsubdir}/adalib/lib*-*.so $RPM_BUILD_ROOT%{_libdir}
@@ -931,14 +971,11 @@ for l in `find $RPM_BUILD_ROOT -name '*.la'`; do
   mv $l.new $l
 done
 
-# GCC-TESTSUITE-DELETE-END
 %if 0%{?run_tests:1} 
 cp `find . -name "*.sum"` ../testresults/
 cp `find . -name "*.log"  \! -name "config.log" | grep -v 'acats.\?/tests' ` ../testresults/
 chmod 644 ../testresults/*
 %endif
-# GCC-TESTSUITE-DELETE-BEGIN
-# LIBFFI-DELETE-BEGIN
 %if %{build_cp}
 # Find C++ and Java headers
 find $RPM_BUILD_ROOT%{_prefix}/include/c++ \
@@ -946,7 +983,6 @@ find $RPM_BUILD_ROOT%{_prefix}/include/c++ \
   -o \( -type d -printf "%%%%dir " , \
         -printf "%{_prefix}/include/c++/%%P\n" \) > ../c++-headers
 %endif
-# LIBFFI-DELETE-END
 # Remove files that we do not need to clean up filelist
 rm -f $RPM_BUILD_ROOT%{_prefix}/bin/%{GCCDIST}-*
 rm -rf $RPM_BUILD_ROOT%{libsubdir}/install-tools
@@ -982,6 +1018,9 @@ crt32_list=$RPM_BUILD_ROOT%{versmainlibdirbi32}/crt*.o
 crt64_list=$RPM_BUILD_ROOT%{versmainlibdirbi64}/crt*.o
 %endif
 %endif
+for o in $crt_list $crt32_list $crt64_list; do
+  objcopy -R ".comment.SUSE.OPTs" $o
+done
 %endif
 
 %if 0%{?building_libjava:1}
@@ -1035,9 +1074,6 @@ rm -f $RPM_BUILD_ROOT%{_mandir}/man7/fsf-funding.7
 rm -f $RPM_BUILD_ROOT%{_mandir}/man7/gfdl.7
 rm -f $RPM_BUILD_ROOT%{_mandir}/man7/gpl.7
 rm -f $RPM_BUILD_ROOT%{_libdir}/libiberty.a
-%if %{build_nof}
-rm -f $RPM_BUILD_ROOT%{_prefix}/lib/nof/libiberty.a
-%endif
 %if %{biarch}
 %if %{build_primary_64bit}
 rm -f $RPM_BUILD_ROOT%{_prefix}/lib/libiberty.a
@@ -1048,7 +1084,6 @@ rm -f $RPM_BUILD_ROOT%{_prefix}/lib64/libiberty.a
 rm -f $RPM_BUILD_ROOT%{libsubdir}/liblto_plugin.a
 rm -f $RPM_BUILD_ROOT%{libsubdir}/liblto_plugin.la
 
-# LIBFFI-DELETE-BEGIN
 %if 0%{?building_libjava:1}
 # For building libjava only we need to delete other info docs
 rm $RPM_BUILD_ROOT%{_infodir}/cp-tools.info*
@@ -1061,6 +1096,9 @@ cp $RPM_SOURCE_DIR/ecj.jar $RPM_BUILD_ROOT%{libsubdir}
 # For regular build, some info files do not get renamed properly.
 # Do so here.
 mv $RPM_BUILD_ROOT%{_infodir}/libgomp.info $RPM_BUILD_ROOT%{_infodir}/libgomp%{binsuffix}.info
+%ifarch %itm_arch
+mv $RPM_BUILD_ROOT%{_infodir}/libitm.info $RPM_BUILD_ROOT%{_infodir}/libitm%{binsuffix}.info
+%endif
 %if %{build_fortran} 
 %ifarch %quadmath_arch
 mv $RPM_BUILD_ROOT%{_infodir}/libquadmath.info $RPM_BUILD_ROOT%{_infodir}/libquadmath%{binsuffix}.info
@@ -1106,11 +1144,11 @@ mv $RPM_BUILD_ROOT%{_infodir}/gnat_ugn.info $RPM_BUILD_ROOT%{_infodir}/gnat_ugn%
 %if %{build_libjava}
 %files 
 %defattr(-,root,root)
-%dir %{_libdir}/gcj-%{gcc_dir_version}-%{gcj_sover}
+%dir %{_libdir}/gcj-%{gcc_dir_version}-%{libgcj_sover}
 %dir %{_libdir}/gcc
 %dir %{_libdir}/gcc/%{GCCDIST}
 %dir %{libsubdir}
-%{_libdir}/gcj-%{gcc_dir_version}-%{gcj_sover}/classmap.db
+%{_libdir}/gcj-%{gcc_dir_version}-%{libgcj_sover}/classmap.db
 # We usually do not multilib libjava
 %if %{biarch_libjava}
 %versbiarchlib libgcj.la
@@ -1123,17 +1161,17 @@ mv $RPM_BUILD_ROOT%{_infodir}/gnat_ugn.info $RPM_BUILD_ROOT%{_infodir}/gnat_ugn%
 %mainlib libgij.so.*
 %mainlib libgcj-tools.so.*
 %endif
-%{_libdir}/gcj-%{gcc_dir_version}-%{gcj_sover}/libjvm.la
-%{_libdir}/gcj-%{gcc_dir_version}-%{gcj_sover}/libjvm.so
-%{_libdir}/gcj-%{gcc_dir_version}-%{gcj_sover}/libjavamath.la
-%{_libdir}/gcj-%{gcc_dir_version}-%{gcj_sover}/libjavamath.so
+%{_libdir}/gcj-%{gcc_dir_version}-%{libgcj_sover}/libjvm.la
+%{_libdir}/gcj-%{gcc_dir_version}-%{libgcj_sover}/libjvm.so
+%{_libdir}/gcj-%{gcc_dir_version}-%{libgcj_sover}/libjavamath.la
+%{_libdir}/gcj-%{gcc_dir_version}-%{libgcj_sover}/libjavamath.so
 
-%files -n libgcj_bc48
+%files -n libgcj_bc%{libgcj_bc_sover}%{libgcj_bc_suffix}
 %defattr(-,root,root)
 %if %{biarch_libjava}
-%biarchlib libgcj_bc.so.*
+%biarchlib libgcj_bc.so.%{libgcj_bc_sover}*
 %else
-%mainlib libgcj_bc.so.*
+%mainlib libgcj_bc.so.%{libgcj_bc_sover}*
 %endif
 
 %files -n libgcj48-jar
@@ -1204,20 +1242,24 @@ mv $RPM_BUILD_ROOT%{_infodir}/gnat_ugn.info $RPM_BUILD_ROOT%{_infodir}/gnat_ugn%
 %doc %{_mandir}/man1/gtnameserv%{binsuffix}.1.gz
 %endif
 %endif
-# LIBFFI-DELETE-END
 
 %if %{build_java}
 %if 0%{?building_libffi:1}
-%files -n libffi48
+%files -n libffi%{libffi_sover}%{libffi_suffix}
 %defattr(-,root,root)
-%mainlib libffi.so.*
+%mainlib libffi.so.%{libffi_sover}*
 
 %if %{separate_biarch}
-%files -n libffi48%{separate_biarch_suffix}
+%files -n libffi%{libffi_sover}%{libffi_suffix}%{separate_biarch_suffix}
 %defattr(-,root,root)
-%biarchlib libffi.so.*
+%biarchlib libffi.so.%{libffi_sover}*
 %endif
 
+%post -n libffi48-devel
+%install_info --info-dir=%{_infodir} %{_infodir}/libffi%{binsuffix}.info.gz
+%postun -n libffi48-devel
+%install_info_delete --info-dir=%{_infodir} %{_infodir}/libffi%{binsuffix}.info.gz
+
 %files -n libffi48-devel
 %defattr(-,root,root)
 %{_prefix}/include/ffi.h
@@ -1225,9 +1267,11 @@ mv $RPM_BUILD_ROOT%{_infodir}/gnat_ugn.info $RPM_BUILD_ROOT%{_infodir}/gnat_ugn%
 %mainlib libffi.so
 %mainlib libffi.a
 %{_libdir}/pkgconfig/libffi.pc
+%doc %{_infodir}/libffi%{binsuffix}.info.gz
 %doc %{_mandir}/man3/ffi%{binsuffix}.3.gz
 %doc %{_mandir}/man3/ffi_call%{binsuffix}.3.gz
 %doc %{_mandir}/man3/ffi_prep_cif%{binsuffix}.3.gz
+%doc %{_mandir}/man3/ffi_prep_cif_var%{binsuffix}.3.gz
 
 %if %{separate_biarch}
 %files -n libffi48-devel%{separate_biarch_suffix}
@@ -1237,7 +1281,6 @@ mv $RPM_BUILD_ROOT%{_infodir}/gnat_ugn.info $RPM_BUILD_ROOT%{_infodir}/gnat_ugn%
 %endif
 %endif
 %endif
-# GCC-TESTSUITE-DELETE-END
 
 %if 0%{?run_tests:1}
 %files -n gcc48-testresults