packaging: add packaging files
authorChanho Park <chanho61.park@samsung.com>
Mon, 21 Jul 2014 08:32:35 +0000 (17:32 +0900)
committerChanho Park <chanho61.park@samsung.com>
Thu, 30 Oct 2014 13:46:30 +0000 (22:46 +0900)
Signed-off-by: Chanho Park <chanho61.park@samsung.com>
18 files changed:
packaging/baselibs.conf [new file with mode: 0644]
packaging/change_spec [new file with mode: 0644]
packaging/check-build.sh [new file with mode: 0644]
packaging/cross-aarch64-gcc49.spec [new file with mode: 0644]
packaging/cross-armv7hl-gcc49.spec [new file with mode: 0644]
packaging/cross-armv7l-gcc49.spec [new file with mode: 0644]
packaging/cross-x86_64-gcc49.spec [new file with mode: 0644]
packaging/cross.spec.in [new file with mode: 0644]
packaging/ecj.jar [new file with mode: 0644]
packaging/gcc.spec.in [new file with mode: 0644]
packaging/gcc49-rpmlintrc [new file with mode: 0644]
packaging/gcc49-testresults.spec [new file with mode: 0644]
packaging/gcc49.spec [new file with mode: 0644]
packaging/libffi49-rpmlintrc [new file with mode: 0644]
packaging/libffi49.spec [new file with mode: 0644]
packaging/libgcj49-rpmlintrc [new file with mode: 0644]
packaging/libgcj49.spec [new file with mode: 0644]
packaging/pre_checkin.sh [new file with mode: 0755]

diff --git a/packaging/baselibs.conf b/packaging/baselibs.conf
new file mode 100644 (file)
index 0000000..0acfb6e
--- /dev/null
@@ -0,0 +1,9 @@
+targettype x86 package libgcc47
+targettype x86 package libstdc++47
+libgcj47
+  requires "libgcj47"
+libgcj47-devel
+gcc47-gij
+  requires "libgcj47-<targettype>"
+  +/usr/bin/gij-4.7 -> /usr/bin/gij<extension>-4.7
+  +/usr/bin/grmiregistry-4.7 -> /usr/bin/grmiregistry<extension>-4.7
diff --git a/packaging/change_spec b/packaging/change_spec
new file mode 100644 (file)
index 0000000..2a8f28d
--- /dev/null
@@ -0,0 +1,143 @@
+#!/bin/bash
+
+do_icecream=1
+do_cross_static=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
+
+# Default is to generate the normal gcc package
+# unless a parameter is given.  In case that it is '-*',
+# that parameter will be used as suffix for the package name
+# and as suffix for the install path (/opt/gccSUFFIX)
+# In case that it is '[0-9]*', that parameter will be used
+# as a suffix for a versioned package name.
+
+if [ $# -lt 1 ]; then
+       outfile=gcc.spec
+else
+       case $1 in
+       [0-9]*)
+         base_ver=$1
+         outfile=gcc$1.spec
+       ;;
+       *)
+         exit 1
+       ;;
+       esac
+fi
+
+       : > $outfile
+       if test "$do_optional_compiler_languages" = "1"; then
+           echo '%define run_tests 1' >> $outfile
+           echo '%define build_optional_compiler_languages 1' >> $outfile
+       fi
+       sed -e 's%@base_ver@%'$base_ver'%g' \
+           gcc.spec.in \
+       | sed -n -e '{
+/^# PACKAGE-BEGIN/h
+/^# PACKAGE-BEGIN/,/^# PACKAGE-END/H
+/^# PACKAGE-BEGIN/,/^# PACKAGE-END/!p
+/^# PACKAGE-END/{g
+s/@variant@//g
+p
+g
+s/@variant@/-32bit/g
+p
+g
+s/@variant@/-64bit/g
+p
+}
+}' >> $outfile
+       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' \
+           gcc.spec.in \
+       | sed -e 's%@base_ver@%'$base_ver'%g' \
+       | sed -n -e '{
+/^# PACKAGE-BEGIN/h
+/^# PACKAGE-BEGIN/,/^# PACKAGE-END/H
+/^# PACKAGE-BEGIN/,/^# PACKAGE-END/!p
+/^# PACKAGE-END/{g
+s/@variant@//g
+p
+g
+s/@variant@/-32bit/g
+p
+g
+s/@variant@/-64bit/g
+p
+}
+}' >> libgcj$base_ver.spec
+       echo '%define building_testsuite 0' > gcc$base_ver-testresults.spec
+       echo '%define run_tests 0' >> gcc$base_ver-testresults.spec
+       sed -e '/^# GCC-TESTSUITE-DELETE-BEGIN/,/^# GCC-TESTSUITE-DELETE-END/d;s/-n gcc@base_ver@-testresults$//g;s/^Name:[[:space:]]*gcc@base_ver@/Name: gcc@base_ver@-testresults/g' \
+           gcc.spec.in \
+       | sed -e 's%@base_ver@%'$base_ver'%g' \
+>> gcc$base_ver-testresults.spec
+       echo '%define building_libffi 1' > libffi$base_ver.spec
+       sed -e '/^# LIBFFI-DELETE-BEGIN/,/^# LIBFFI-DELETE-END/d;s/^Name:[[:space:]]*gcc/Name: libffi/g' \
+           gcc.spec.in \
+       | sed -e 's%@base_ver@%'$base_ver'%g' \
+       | sed -n -e '{
+/^# PACKAGE-BEGIN/h
+/^# PACKAGE-BEGIN/,/^# PACKAGE-END/H
+/^# PACKAGE-BEGIN/,/^# PACKAGE-END/!p
+/^# PACKAGE-END/{g
+s/@variant@//g
+p
+g
+s/@variant@/-32bit/g
+p
+g
+s/@variant@/-64bit/g
+p
+}
+}' \
+>> 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
+
+
+
+add_cross() {
+  local pkgname="$1"; shift
+  local rpmtarget="$1"; shift
+  local triplet="$1"; shift
+
+  exclarch=`echo $rpmtarget | sed -e 's/ppc$/ppc64/'`
+  echo "%define pkgname $pkgname" > $pkgname.spec
+  echo "%define cross_arch $rpmtarget" >> $pkgname.spec
+  echo "%define gcc_target_arch $triplet" >> $pkgname.spec
+  echo "$@" >> $pkgname.spec
+  { sed -n -e '1,/COMMON-BEGIN/p' cross.spec.in
+    sed -n -e '/COMMON-BEGIN/,/COMMON-END/p' $outfile
+    sed -n -e '/COMMON-END/,$p' cross.spec.in; } |
+    sed -e "s#@base_ver@#$base_ver#" \
+       -e "s/^\(ExclusiveArch.*\) $exclarch /\1 /" \
+      >> $pkgname.spec
+  test -f gcc$base_ver.changes && ln -f gcc$base_ver.changes $pkgname.changes
+}
+
+# We now support "proper" cross-compilers to suse targets via a
+# cross-glibc package, enable that via for example
+#
+# add_cross cross-aarch64-gcc$base_ver aarch64 aarch64-tizen-linux
+#
+# For now keep the old way of doing things
+if test "$do_icecream" = 1 ; then
+add_cross cross-aarch64-gcc$base_ver aarch64 aarch64-tizen-linux %define gcc_icecream 1
+add_cross cross-armv7l-gcc$base_ver armv7l armv7l-tizen-linux-gnueabi %define gcc_icecream 1
+add_cross cross-armv7hl-gcc$base_ver armv7hl armv7hl-tizen-linux-gnueabi %define gcc_icecream 1
+add_cross cross-x86_64-gcc$base_ver x86_64 x86_64-tizen-linux %define gcc_icecream 1
+fi
+
+for f in *.spec; do
+  sed -i -e '/^# .*-\(BEGIN\|END\)$/d' $f
+done
+
+exit 0
diff --git a/packaging/check-build.sh b/packaging/check-build.sh
new file mode 100644 (file)
index 0000000..a75c617
--- /dev/null
@@ -0,0 +1,38 @@
+#!/bin/bash
+# Copyright (c) 2003,2005 SUSE Linux Products GmbH, Germany.  All rights reserved.
+#
+# Authors: Thorsten Kukuk <kukuk@suse.de>
+#
+# this script use the following variable(s):
+# 
+# - $BUILD_BASENAME
+#
+
+case $BUILD_BASENAME in
+   *ppc*)
+       # Our biarch 32-bit compiler needs to be build on a 64-bit machine,
+       # otherwise some configure checks fail.
+       # Note that we cannot use uname here since powerpc32 was invoked
+       # already.
+       grep 'series64\|ppc64' /proc/version > /dev/null
+       if [ $? -ne 0 ] ; then
+         echo "build does not work on `hostname` for gcc"
+         exit 1
+       fi
+       ;;
+   *x86_64*)
+       #if [ `ulimit -v` -le 740000 ] ; then
+       #  echo "build does not work on ("`hostname`" for gcc)"
+       #  exit 1
+       #fi
+       if [ `getconf _NPROCESSORS_CONF` -lt  2 ] ; then
+         echo "build does not work on `hostname` for gcc"
+         exit 1
+       fi
+       ;;
+   *)
+       ;;
+esac
+
+exit 0
+
diff --git a/packaging/cross-aarch64-gcc49.spec b/packaging/cross-aarch64-gcc49.spec
new file mode 100644 (file)
index 0000000..42d77c3
--- /dev/null
@@ -0,0 +1,555 @@
+%define pkgname cross-aarch64-gcc49
+%define cross_arch aarch64
+%define gcc_target_arch aarch64-tizen-linux
+%define gcc_icecream 1
+#! /bin/sh
+
+#
+# call this via pre_checkin.sh
+#
+# 2005-05-09, jw@suse.de
+
+test -z "$cross_arch" && echo 1>&2 "Error: $0 needs environment variable 'cross_arch'"
+test -z "$outfile" && echo 1>&2 "Error: $0 needs environment variable 'outfile'"
+cross_arch_cpu=`echo $cross_arch | sed -e 's/\([^-]*\)-\?.*/\1/'`
+
+cat << EOF
+#
+# spec file for package gcc (Version 4.8.2)
+#
+# 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_go 0
+%define gcc_target_arch $cross_arch
+
+%define binutils_target %{cross_arch}
+%if %{cross_arch} == "armv7l" || %{cross_arch} == "armv7hl"
+%define binutils_target arm
+%endif
+%if %{cross_arch} == "armv6l" || %{cross_arch} == "armv6hl"
+%define binutils_target arm
+%endif
+%if %{cross_arch} == "armv5tel"
+%define binutils_target arm
+%endif
+%if %{cross_arch} == "aarch64"
+%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
+
+%if 0%{?gcc_icecream:1}
+%define build_sysroot /
+%endif
+
+
+Name:         %{pkgname}
+BuildRequires: cross-%{binutils_target}-binutils
+BuildRequires: gcc-c++
+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 ppc ppc64 s390 s390x ia64 %sparc hppa %arm
+BuildRequires: cloog-devel
+BuildRequires: ppl-devel
+%endif
+BuildRequires: cross-$cross_arch_cpu-binutils
+%ifarch ia64
+BuildRequires: libunwind-devel
+%endif
+%if 0%{!?gcc_icecream:1}
+BuildRequires: cross-%cross_arch-glibc-devel
+%endif
+
+%define biarch_targets x86_64 s390x powerpc64 powerpc sparc sparc64
+
+URL:          http://gcc.gnu.org/
+Version: 4.9.1
+Release:      1
+%define gcc_dir_version 4.9
+%define binsuffix -4.9
+BuildRoot:     %{_tmppath}/%{name}-%{version}-build
+Source:                gcc-%{version}.tar.bz2
+Source1:       change_spec
+Source2:       libffi49-rpmlintrc
+Source3:       gcc49-rpmlintrc
+Source4:       ecj.jar
+Source5:       baselibs.conf
+Source6:       libgcj49-rpmlintrc
+
+Group:          Development/Building
+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++.
+
+
+
+
+# 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} == "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
+%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "aarch64"
+%define CONFIGURE_TARGET aarch64-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} == "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/;")
+%endif
+%define biarch %(case " %{biarch_targets} " in (*" %{TARGET_ARCH} "*) echo 1;; (*) echo 0;; esac)
+
+%define HOST_ARCH %(echo %{_host_cpu} | sed -e "s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;")
+%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}
+
+
+%prep
+%setup -q -n gcc-%{version}
+
+# 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
+contrib/gcc_update --touch
+# Avoid fucking up testsuite results with Java and indirect dispatch
+export LD_ASNEEDED=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 possible and remove
+# the 'prerelease' tagging in this case
+if test `cat gcc/DEV-PHASE` == "prerelease"; then
+  if test `cat gcc/BASE-VER | cut -d '.' -f 3` != "0"; then
+    : > gcc/DEV-PHASE
+  fi
+  ( 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
+%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'`
+%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
+%if %{build_go}
+languages=$languages,go
+%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
+
+%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 \
+%if "%{TARGET_ARCH}" == "armv7l" || "%{TARGET_ARCH}" == "armv7hl"
+# temporary workaround for a miscompilation of hash functions in java code
+GCJ_EXTRA_FLAGS="-marm"
+%endif
+
+export RPM_OPT_FLAGS="`echo $RPM_OPT_FLAGS | sed -e "s/ -Wp,-D_FORTIFY_SOURCE=2 / /g"`"
+
+CFLAGS="$RPM_OPT_FLAGS" CXXFLAGS="$RPM_OPT_FLAGS" XCFLAGS="$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 \
+%if 0%{!?build_libvtv:1}
+       --disable-libvtv \
+%endif
+       --disable-plugin \
+       --with-bugurl="http://bugs.tizen.org/" \
+       --with-pkgversion="Tizen" \
+%if !%{build_fortran}
+       --disable-libquadmath \
+%endif
+%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
+       --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 \
+       --enable-linux-futex \
+       --program-suffix=%{binsuffix} \
+%if 0%{!?gcc_target_arch:1}
+%ifarch ia64
+       --with-system-libunwind \
+%else
+       --without-system-libunwind \
+%endif
+%endif
+%if 0%{?gcc_target_arch:1}
+       --program-prefix=%{gcc_target_arch}- \
+       --target=%{gcc_target_arch} \
+       --disable-nls \
+%if 0%{?sysroot:1}
+       --with-sysroot=%sysroot \
+%else
+       --with-sysroot=%{_prefix}/%{gcc_target_arch} \
+%endif
+%if 0%{?build_sysroot:1}
+       --with-build-sysroot=%{build_sysroot} \
+%else
+%if 0%{?sysroot:1}
+       --with-build-sysroot=%{sysroot} \
+%else
+       --with-build-sysroot=%{_prefix}/%{gcc_target_arch} \
+%endif
+%endif
+%if 0%{?canonical_target:1}
+       --with-build-time-tools=/usr/%{canonical_target}-tizen-linux%{?canonical_target_abi:%canonical_target_abi}/bin \
+%endif
+%if "%{TARGET_ARCH}" == "spu"
+       --with-gxx-include-dir=%sysroot/include/c++/%{gcc_dir_version} \
+       --with-newlib \
+%endif
+%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}" == "armv7l" 
+       --with-arch=armv7-a \
+       --with-tune=cortex-a8 \
+       --with-float=softfp \
+       --with-fpu=vfpv3 \
+       --with-mode=thumb \
+       --disable-sjlj-exceptions \
+%endif
+%if "%{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}" == "aarch64"
+       --with-arch=armv8-a \
+       --disable-sjlj-exceptions \
+%endif
+%if "%{TARGET_ARCH}" == "powerpc" || "%{TARGET_ARCH}" == "powerpc64"
+%if "%{TARGET_ARCH}" == "powerpc"
+        --with-cpu=default32 \
+%endif
+%if "%{TARGET_ARCH}" == "powerpc64le"
+       --with-cpu=power7 \
+%else
+       --with-cpu-64=power4 \
+%endif
+       --enable-secureplt \
+       --with-long-double-128 \
+%if "%{TARGET_ARCH}" == "powerpc64le"
+       --disable-multilib \
+%endif
+%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 \
+%endif
+%if "%{TARGET_ARCH}" == "x86_64"
+       --with-arch-32=i586 \
+       --with-tune=generic \
+       --disable-multilib \
+%endif
+%if "%{TARGET_ARCH}" == "s390"
+        --with-tune=zEC12 --with-arch=z196 \
+       --with-long-double-128 \
+       --enable-decimal-float \
+%endif
+%if "%{TARGET_ARCH}" == "s390x"
+        --with-tune=zEC12 --with-arch=z196 \
+       --with-long-double-128 \
+       --enable-decimal-float \
+%endif
+%if "%{TARGET_ARCH}" == "m68k"
+       --disable-multilib \
+%endif
+       --build=%{GCCDIST} \
+       --host=%{GCCDIST}
+
+
+%if 0%{!?gcc_icecream:1}
+make %{?jobs:-j%jobs}
+%else
+make %{?jobs:-j%jobs} all-host
+%endif
+
+%define _prefix /opt/cross
+
+%package -n cross-%cross_arch-gcc49-icecream-backend
+Summary: Icecream backend for the GNU C Compiler
+Group: Development/Languages/C and C++
+
+%description -n cross-%cross_arch-gcc49-icecream-backend
+This package contains the icecream environment for the GNU C Compiler
+
+
+%define targetlibsubdir %{_libdir}/gcc/%{gcc_target_arch}/%{gcc_dir_version}
+
+%install
+cd obj-%{GCCDIST}
+
+# install and fixup host parts
+make DESTDIR=$RPM_BUILD_ROOT install-host
+# with the present setup fixincludes are for the build includes which
+# is wrong - get rid of them
+rm -rf $RPM_BUILD_ROOT/%{targetlibsubdir}/include-fixed
+rm -f $RPM_BUILD_ROOT/%{targetlibsubdir}/liblto_plugin.la
+# common fixup
+rm -f $RPM_BUILD_ROOT%{_libdir}/libiberty.a
+# remove docs
+rm -rf $RPM_BUILD_ROOT%{_mandir}
+rm -rf $RPM_BUILD_ROOT%{_infodir}
+
+
+# install and fixup target parts
+# ???  don't do this - debugedit is not prepared for this and crashes
+# so expect the sysroot to be populated from natively built binaries
+#%if 0%{?sysroot:1}
+#make DESTDIR=$RPM_BUILD_ROOT/%{sysroot} install-target
+#%else
+#make DESTDIR=$RPM_BUILD_ROOT/%{_prefix}/%{gcc_target_arch} install-target
+#%endif
+
+
+# Build an icecream environment
+# 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/%{_prefix}/bin/%{gcc_target_arch}-g++%{binsuffix} \
+       $RPM_BUILD_ROOT/env/usr/bin/g++
+install -s $RPM_BUILD_ROOT/%{_prefix}/bin/%{gcc_target_arch}-gcc%{binsuffix} \
+       $RPM_BUILD_ROOT/env/usr/bin/gcc
+
+for back in cc1 cc1plus; do 
+       install -s -D $RPM_BUILD_ROOT/%{targetlibsubdir}/$back \
+               $RPM_BUILD_ROOT/env%{targetlibsubdir}/$back
+done
+if test -f $RPM_BUILD_ROOT/%{targetlibsubdir}/liblto_plugin.so; then
+  install -s -D $RPM_BUILD_ROOT/%{targetlibsubdir}/liblto_plugin.so \
+               $RPM_BUILD_ROOT/env%{targetlibsubdir}/liblto_plugin.so
+fi
+
+# Make sure to also pull in all shared library requirements for the
+# binaries we put into the environment which is operated by chrooting
+# into it and execing the compiler
+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
+
+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
+
+%files
+%defattr(-,root,root)
+%{_prefix}/bin
+%dir %{targetlibsubdir}
+%dir %{_libdir}/gcc/%{gcc_target_arch}
+%{targetlibsubdir}
+
+%files -n cross-%cross_arch-gcc49-icecream-backend
+%defattr(-,root,root)
+/usr/share/icecream-envs
+
+EOF
diff --git a/packaging/cross-armv7hl-gcc49.spec b/packaging/cross-armv7hl-gcc49.spec
new file mode 100644 (file)
index 0000000..33c6332
--- /dev/null
@@ -0,0 +1,555 @@
+%define pkgname cross-armv7hl-gcc49
+%define cross_arch armv7hl
+%define gcc_target_arch armv7hl-tizen-linux-gnueabi
+%define gcc_icecream 1
+#! /bin/sh
+
+#
+# call this via pre_checkin.sh
+#
+# 2005-05-09, jw@suse.de
+
+test -z "$cross_arch" && echo 1>&2 "Error: $0 needs environment variable 'cross_arch'"
+test -z "$outfile" && echo 1>&2 "Error: $0 needs environment variable 'outfile'"
+cross_arch_cpu=`echo $cross_arch | sed -e 's/\([^-]*\)-\?.*/\1/'`
+
+cat << EOF
+#
+# spec file for package gcc (Version 4.8.2)
+#
+# 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_go 0
+%define gcc_target_arch $cross_arch
+
+%define binutils_target %{cross_arch}
+%if %{cross_arch} == "armv7l" || %{cross_arch} == "armv7hl"
+%define binutils_target arm
+%endif
+%if %{cross_arch} == "armv6l" || %{cross_arch} == "armv6hl"
+%define binutils_target arm
+%endif
+%if %{cross_arch} == "armv5tel"
+%define binutils_target arm
+%endif
+%if %{cross_arch} == "aarch64"
+%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
+
+%if 0%{?gcc_icecream:1}
+%define build_sysroot /
+%endif
+
+
+Name:         %{pkgname}
+BuildRequires: cross-%{binutils_target}-binutils
+BuildRequires: gcc-c++
+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 ppc ppc64 s390 s390x ia64 %sparc hppa %arm
+BuildRequires: cloog-devel
+BuildRequires: ppl-devel
+%endif
+BuildRequires: cross-$cross_arch_cpu-binutils
+%ifarch ia64
+BuildRequires: libunwind-devel
+%endif
+%if 0%{!?gcc_icecream:1}
+BuildRequires: cross-%cross_arch-glibc-devel
+%endif
+
+%define biarch_targets x86_64 s390x powerpc64 powerpc sparc sparc64
+
+URL:          http://gcc.gnu.org/
+Version: 4.9.1
+Release:      1
+%define gcc_dir_version 4.9
+%define binsuffix -4.9
+BuildRoot:     %{_tmppath}/%{name}-%{version}-build
+Source:                gcc-%{version}.tar.bz2
+Source1:       change_spec
+Source2:       libffi49-rpmlintrc
+Source3:       gcc49-rpmlintrc
+Source4:       ecj.jar
+Source5:       baselibs.conf
+Source6:       libgcj49-rpmlintrc
+
+Group:          Development/Building
+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++.
+
+
+
+
+# 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} == "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
+%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "aarch64"
+%define CONFIGURE_TARGET aarch64-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} == "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/;")
+%endif
+%define biarch %(case " %{biarch_targets} " in (*" %{TARGET_ARCH} "*) echo 1;; (*) echo 0;; esac)
+
+%define HOST_ARCH %(echo %{_host_cpu} | sed -e "s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;")
+%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}
+
+
+%prep
+%setup -q -n gcc-%{version}
+
+# 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
+contrib/gcc_update --touch
+# Avoid fucking up testsuite results with Java and indirect dispatch
+export LD_ASNEEDED=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 possible and remove
+# the 'prerelease' tagging in this case
+if test `cat gcc/DEV-PHASE` == "prerelease"; then
+  if test `cat gcc/BASE-VER | cut -d '.' -f 3` != "0"; then
+    : > gcc/DEV-PHASE
+  fi
+  ( 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
+%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'`
+%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
+%if %{build_go}
+languages=$languages,go
+%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
+
+%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 \
+%if "%{TARGET_ARCH}" == "armv7l" || "%{TARGET_ARCH}" == "armv7hl"
+# temporary workaround for a miscompilation of hash functions in java code
+GCJ_EXTRA_FLAGS="-marm"
+%endif
+
+export RPM_OPT_FLAGS="`echo $RPM_OPT_FLAGS | sed -e "s/ -Wp,-D_FORTIFY_SOURCE=2 / /g"`"
+
+CFLAGS="$RPM_OPT_FLAGS" CXXFLAGS="$RPM_OPT_FLAGS" XCFLAGS="$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 \
+%if 0%{!?build_libvtv:1}
+       --disable-libvtv \
+%endif
+       --disable-plugin \
+       --with-bugurl="http://bugs.tizen.org/" \
+       --with-pkgversion="Tizen" \
+%if !%{build_fortran}
+       --disable-libquadmath \
+%endif
+%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
+       --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 \
+       --enable-linux-futex \
+       --program-suffix=%{binsuffix} \
+%if 0%{!?gcc_target_arch:1}
+%ifarch ia64
+       --with-system-libunwind \
+%else
+       --without-system-libunwind \
+%endif
+%endif
+%if 0%{?gcc_target_arch:1}
+       --program-prefix=%{gcc_target_arch}- \
+       --target=%{gcc_target_arch} \
+       --disable-nls \
+%if 0%{?sysroot:1}
+       --with-sysroot=%sysroot \
+%else
+       --with-sysroot=%{_prefix}/%{gcc_target_arch} \
+%endif
+%if 0%{?build_sysroot:1}
+       --with-build-sysroot=%{build_sysroot} \
+%else
+%if 0%{?sysroot:1}
+       --with-build-sysroot=%{sysroot} \
+%else
+       --with-build-sysroot=%{_prefix}/%{gcc_target_arch} \
+%endif
+%endif
+%if 0%{?canonical_target:1}
+       --with-build-time-tools=/usr/%{canonical_target}-tizen-linux%{?canonical_target_abi:%canonical_target_abi}/bin \
+%endif
+%if "%{TARGET_ARCH}" == "spu"
+       --with-gxx-include-dir=%sysroot/include/c++/%{gcc_dir_version} \
+       --with-newlib \
+%endif
+%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}" == "armv7l" 
+       --with-arch=armv7-a \
+       --with-tune=cortex-a8 \
+       --with-float=softfp \
+       --with-fpu=vfpv3 \
+       --with-mode=thumb \
+       --disable-sjlj-exceptions \
+%endif
+%if "%{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}" == "aarch64"
+       --with-arch=armv8-a \
+       --disable-sjlj-exceptions \
+%endif
+%if "%{TARGET_ARCH}" == "powerpc" || "%{TARGET_ARCH}" == "powerpc64"
+%if "%{TARGET_ARCH}" == "powerpc"
+        --with-cpu=default32 \
+%endif
+%if "%{TARGET_ARCH}" == "powerpc64le"
+       --with-cpu=power7 \
+%else
+       --with-cpu-64=power4 \
+%endif
+       --enable-secureplt \
+       --with-long-double-128 \
+%if "%{TARGET_ARCH}" == "powerpc64le"
+       --disable-multilib \
+%endif
+%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 \
+%endif
+%if "%{TARGET_ARCH}" == "x86_64"
+       --with-arch-32=i586 \
+       --with-tune=generic \
+       --disable-multilib \
+%endif
+%if "%{TARGET_ARCH}" == "s390"
+        --with-tune=zEC12 --with-arch=z196 \
+       --with-long-double-128 \
+       --enable-decimal-float \
+%endif
+%if "%{TARGET_ARCH}" == "s390x"
+        --with-tune=zEC12 --with-arch=z196 \
+       --with-long-double-128 \
+       --enable-decimal-float \
+%endif
+%if "%{TARGET_ARCH}" == "m68k"
+       --disable-multilib \
+%endif
+       --build=%{GCCDIST} \
+       --host=%{GCCDIST}
+
+
+%if 0%{!?gcc_icecream:1}
+make %{?jobs:-j%jobs}
+%else
+make %{?jobs:-j%jobs} all-host
+%endif
+
+%define _prefix /opt/cross
+
+%package -n cross-%cross_arch-gcc49-icecream-backend
+Summary: Icecream backend for the GNU C Compiler
+Group: Development/Languages/C and C++
+
+%description -n cross-%cross_arch-gcc49-icecream-backend
+This package contains the icecream environment for the GNU C Compiler
+
+
+%define targetlibsubdir %{_libdir}/gcc/%{gcc_target_arch}/%{gcc_dir_version}
+
+%install
+cd obj-%{GCCDIST}
+
+# install and fixup host parts
+make DESTDIR=$RPM_BUILD_ROOT install-host
+# with the present setup fixincludes are for the build includes which
+# is wrong - get rid of them
+rm -rf $RPM_BUILD_ROOT/%{targetlibsubdir}/include-fixed
+rm -f $RPM_BUILD_ROOT/%{targetlibsubdir}/liblto_plugin.la
+# common fixup
+rm -f $RPM_BUILD_ROOT%{_libdir}/libiberty.a
+# remove docs
+rm -rf $RPM_BUILD_ROOT%{_mandir}
+rm -rf $RPM_BUILD_ROOT%{_infodir}
+
+
+# install and fixup target parts
+# ???  don't do this - debugedit is not prepared for this and crashes
+# so expect the sysroot to be populated from natively built binaries
+#%if 0%{?sysroot:1}
+#make DESTDIR=$RPM_BUILD_ROOT/%{sysroot} install-target
+#%else
+#make DESTDIR=$RPM_BUILD_ROOT/%{_prefix}/%{gcc_target_arch} install-target
+#%endif
+
+
+# Build an icecream environment
+# 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/%{_prefix}/bin/%{gcc_target_arch}-g++%{binsuffix} \
+       $RPM_BUILD_ROOT/env/usr/bin/g++
+install -s $RPM_BUILD_ROOT/%{_prefix}/bin/%{gcc_target_arch}-gcc%{binsuffix} \
+       $RPM_BUILD_ROOT/env/usr/bin/gcc
+
+for back in cc1 cc1plus; do 
+       install -s -D $RPM_BUILD_ROOT/%{targetlibsubdir}/$back \
+               $RPM_BUILD_ROOT/env%{targetlibsubdir}/$back
+done
+if test -f $RPM_BUILD_ROOT/%{targetlibsubdir}/liblto_plugin.so; then
+  install -s -D $RPM_BUILD_ROOT/%{targetlibsubdir}/liblto_plugin.so \
+               $RPM_BUILD_ROOT/env%{targetlibsubdir}/liblto_plugin.so
+fi
+
+# Make sure to also pull in all shared library requirements for the
+# binaries we put into the environment which is operated by chrooting
+# into it and execing the compiler
+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
+
+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
+
+%files
+%defattr(-,root,root)
+%{_prefix}/bin
+%dir %{targetlibsubdir}
+%dir %{_libdir}/gcc/%{gcc_target_arch}
+%{targetlibsubdir}
+
+%files -n cross-%cross_arch-gcc49-icecream-backend
+%defattr(-,root,root)
+/usr/share/icecream-envs
+
+EOF
diff --git a/packaging/cross-armv7l-gcc49.spec b/packaging/cross-armv7l-gcc49.spec
new file mode 100644 (file)
index 0000000..3a4b5a5
--- /dev/null
@@ -0,0 +1,555 @@
+%define pkgname cross-armv7l-gcc49
+%define cross_arch armv7l
+%define gcc_target_arch armv7l-tizen-linux-gnueabi
+%define gcc_icecream 1
+#! /bin/sh
+
+#
+# call this via pre_checkin.sh
+#
+# 2005-05-09, jw@suse.de
+
+test -z "$cross_arch" && echo 1>&2 "Error: $0 needs environment variable 'cross_arch'"
+test -z "$outfile" && echo 1>&2 "Error: $0 needs environment variable 'outfile'"
+cross_arch_cpu=`echo $cross_arch | sed -e 's/\([^-]*\)-\?.*/\1/'`
+
+cat << EOF
+#
+# spec file for package gcc (Version 4.8.2)
+#
+# 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_go 0
+%define gcc_target_arch $cross_arch
+
+%define binutils_target %{cross_arch}
+%if %{cross_arch} == "armv7l" || %{cross_arch} == "armv7hl"
+%define binutils_target arm
+%endif
+%if %{cross_arch} == "armv6l" || %{cross_arch} == "armv6hl"
+%define binutils_target arm
+%endif
+%if %{cross_arch} == "armv5tel"
+%define binutils_target arm
+%endif
+%if %{cross_arch} == "aarch64"
+%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
+
+%if 0%{?gcc_icecream:1}
+%define build_sysroot /
+%endif
+
+
+Name:         %{pkgname}
+BuildRequires: cross-%{binutils_target}-binutils
+BuildRequires: gcc-c++
+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 ppc ppc64 s390 s390x ia64 %sparc hppa %arm
+BuildRequires: cloog-devel
+BuildRequires: ppl-devel
+%endif
+BuildRequires: cross-$cross_arch_cpu-binutils
+%ifarch ia64
+BuildRequires: libunwind-devel
+%endif
+%if 0%{!?gcc_icecream:1}
+BuildRequires: cross-%cross_arch-glibc-devel
+%endif
+
+%define biarch_targets x86_64 s390x powerpc64 powerpc sparc sparc64
+
+URL:          http://gcc.gnu.org/
+Version: 4.9.1
+Release:      1
+%define gcc_dir_version 4.9
+%define binsuffix -4.9
+BuildRoot:     %{_tmppath}/%{name}-%{version}-build
+Source:                gcc-%{version}.tar.bz2
+Source1:       change_spec
+Source2:       libffi49-rpmlintrc
+Source3:       gcc49-rpmlintrc
+Source4:       ecj.jar
+Source5:       baselibs.conf
+Source6:       libgcj49-rpmlintrc
+
+Group:          Development/Building
+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++.
+
+
+
+
+# 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} == "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
+%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "aarch64"
+%define CONFIGURE_TARGET aarch64-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} == "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/;")
+%endif
+%define biarch %(case " %{biarch_targets} " in (*" %{TARGET_ARCH} "*) echo 1;; (*) echo 0;; esac)
+
+%define HOST_ARCH %(echo %{_host_cpu} | sed -e "s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;")
+%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}
+
+
+%prep
+%setup -q -n gcc-%{version}
+
+# 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
+contrib/gcc_update --touch
+# Avoid fucking up testsuite results with Java and indirect dispatch
+export LD_ASNEEDED=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 possible and remove
+# the 'prerelease' tagging in this case
+if test `cat gcc/DEV-PHASE` == "prerelease"; then
+  if test `cat gcc/BASE-VER | cut -d '.' -f 3` != "0"; then
+    : > gcc/DEV-PHASE
+  fi
+  ( 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
+%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'`
+%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
+%if %{build_go}
+languages=$languages,go
+%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
+
+%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 \
+%if "%{TARGET_ARCH}" == "armv7l" || "%{TARGET_ARCH}" == "armv7hl"
+# temporary workaround for a miscompilation of hash functions in java code
+GCJ_EXTRA_FLAGS="-marm"
+%endif
+
+export RPM_OPT_FLAGS="`echo $RPM_OPT_FLAGS | sed -e "s/ -Wp,-D_FORTIFY_SOURCE=2 / /g"`"
+
+CFLAGS="$RPM_OPT_FLAGS" CXXFLAGS="$RPM_OPT_FLAGS" XCFLAGS="$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 \
+%if 0%{!?build_libvtv:1}
+       --disable-libvtv \
+%endif
+       --disable-plugin \
+       --with-bugurl="http://bugs.tizen.org/" \
+       --with-pkgversion="Tizen" \
+%if !%{build_fortran}
+       --disable-libquadmath \
+%endif
+%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
+       --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 \
+       --enable-linux-futex \
+       --program-suffix=%{binsuffix} \
+%if 0%{!?gcc_target_arch:1}
+%ifarch ia64
+       --with-system-libunwind \
+%else
+       --without-system-libunwind \
+%endif
+%endif
+%if 0%{?gcc_target_arch:1}
+       --program-prefix=%{gcc_target_arch}- \
+       --target=%{gcc_target_arch} \
+       --disable-nls \
+%if 0%{?sysroot:1}
+       --with-sysroot=%sysroot \
+%else
+       --with-sysroot=%{_prefix}/%{gcc_target_arch} \
+%endif
+%if 0%{?build_sysroot:1}
+       --with-build-sysroot=%{build_sysroot} \
+%else
+%if 0%{?sysroot:1}
+       --with-build-sysroot=%{sysroot} \
+%else
+       --with-build-sysroot=%{_prefix}/%{gcc_target_arch} \
+%endif
+%endif
+%if 0%{?canonical_target:1}
+       --with-build-time-tools=/usr/%{canonical_target}-tizen-linux%{?canonical_target_abi:%canonical_target_abi}/bin \
+%endif
+%if "%{TARGET_ARCH}" == "spu"
+       --with-gxx-include-dir=%sysroot/include/c++/%{gcc_dir_version} \
+       --with-newlib \
+%endif
+%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}" == "armv7l" 
+       --with-arch=armv7-a \
+       --with-tune=cortex-a8 \
+       --with-float=softfp \
+       --with-fpu=vfpv3 \
+       --with-mode=thumb \
+       --disable-sjlj-exceptions \
+%endif
+%if "%{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}" == "aarch64"
+       --with-arch=armv8-a \
+       --disable-sjlj-exceptions \
+%endif
+%if "%{TARGET_ARCH}" == "powerpc" || "%{TARGET_ARCH}" == "powerpc64"
+%if "%{TARGET_ARCH}" == "powerpc"
+        --with-cpu=default32 \
+%endif
+%if "%{TARGET_ARCH}" == "powerpc64le"
+       --with-cpu=power7 \
+%else
+       --with-cpu-64=power4 \
+%endif
+       --enable-secureplt \
+       --with-long-double-128 \
+%if "%{TARGET_ARCH}" == "powerpc64le"
+       --disable-multilib \
+%endif
+%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 \
+%endif
+%if "%{TARGET_ARCH}" == "x86_64"
+       --with-arch-32=i586 \
+       --with-tune=generic \
+       --disable-multilib \
+%endif
+%if "%{TARGET_ARCH}" == "s390"
+        --with-tune=zEC12 --with-arch=z196 \
+       --with-long-double-128 \
+       --enable-decimal-float \
+%endif
+%if "%{TARGET_ARCH}" == "s390x"
+        --with-tune=zEC12 --with-arch=z196 \
+       --with-long-double-128 \
+       --enable-decimal-float \
+%endif
+%if "%{TARGET_ARCH}" == "m68k"
+       --disable-multilib \
+%endif
+       --build=%{GCCDIST} \
+       --host=%{GCCDIST}
+
+
+%if 0%{!?gcc_icecream:1}
+make %{?jobs:-j%jobs}
+%else
+make %{?jobs:-j%jobs} all-host
+%endif
+
+%define _prefix /opt/cross
+
+%package -n cross-%cross_arch-gcc49-icecream-backend
+Summary: Icecream backend for the GNU C Compiler
+Group: Development/Languages/C and C++
+
+%description -n cross-%cross_arch-gcc49-icecream-backend
+This package contains the icecream environment for the GNU C Compiler
+
+
+%define targetlibsubdir %{_libdir}/gcc/%{gcc_target_arch}/%{gcc_dir_version}
+
+%install
+cd obj-%{GCCDIST}
+
+# install and fixup host parts
+make DESTDIR=$RPM_BUILD_ROOT install-host
+# with the present setup fixincludes are for the build includes which
+# is wrong - get rid of them
+rm -rf $RPM_BUILD_ROOT/%{targetlibsubdir}/include-fixed
+rm -f $RPM_BUILD_ROOT/%{targetlibsubdir}/liblto_plugin.la
+# common fixup
+rm -f $RPM_BUILD_ROOT%{_libdir}/libiberty.a
+# remove docs
+rm -rf $RPM_BUILD_ROOT%{_mandir}
+rm -rf $RPM_BUILD_ROOT%{_infodir}
+
+
+# install and fixup target parts
+# ???  don't do this - debugedit is not prepared for this and crashes
+# so expect the sysroot to be populated from natively built binaries
+#%if 0%{?sysroot:1}
+#make DESTDIR=$RPM_BUILD_ROOT/%{sysroot} install-target
+#%else
+#make DESTDIR=$RPM_BUILD_ROOT/%{_prefix}/%{gcc_target_arch} install-target
+#%endif
+
+
+# Build an icecream environment
+# 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/%{_prefix}/bin/%{gcc_target_arch}-g++%{binsuffix} \
+       $RPM_BUILD_ROOT/env/usr/bin/g++
+install -s $RPM_BUILD_ROOT/%{_prefix}/bin/%{gcc_target_arch}-gcc%{binsuffix} \
+       $RPM_BUILD_ROOT/env/usr/bin/gcc
+
+for back in cc1 cc1plus; do 
+       install -s -D $RPM_BUILD_ROOT/%{targetlibsubdir}/$back \
+               $RPM_BUILD_ROOT/env%{targetlibsubdir}/$back
+done
+if test -f $RPM_BUILD_ROOT/%{targetlibsubdir}/liblto_plugin.so; then
+  install -s -D $RPM_BUILD_ROOT/%{targetlibsubdir}/liblto_plugin.so \
+               $RPM_BUILD_ROOT/env%{targetlibsubdir}/liblto_plugin.so
+fi
+
+# Make sure to also pull in all shared library requirements for the
+# binaries we put into the environment which is operated by chrooting
+# into it and execing the compiler
+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
+
+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
+
+%files
+%defattr(-,root,root)
+%{_prefix}/bin
+%dir %{targetlibsubdir}
+%dir %{_libdir}/gcc/%{gcc_target_arch}
+%{targetlibsubdir}
+
+%files -n cross-%cross_arch-gcc49-icecream-backend
+%defattr(-,root,root)
+/usr/share/icecream-envs
+
+EOF
diff --git a/packaging/cross-x86_64-gcc49.spec b/packaging/cross-x86_64-gcc49.spec
new file mode 100644 (file)
index 0000000..e1d0f3a
--- /dev/null
@@ -0,0 +1,555 @@
+%define pkgname cross-x86_64-gcc49
+%define cross_arch x86_64
+%define gcc_target_arch x86_64-tizen-linux
+%define gcc_icecream 1
+#! /bin/sh
+
+#
+# call this via pre_checkin.sh
+#
+# 2005-05-09, jw@suse.de
+
+test -z "$cross_arch" && echo 1>&2 "Error: $0 needs environment variable 'cross_arch'"
+test -z "$outfile" && echo 1>&2 "Error: $0 needs environment variable 'outfile'"
+cross_arch_cpu=`echo $cross_arch | sed -e 's/\([^-]*\)-\?.*/\1/'`
+
+cat << EOF
+#
+# spec file for package gcc (Version 4.8.2)
+#
+# 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_go 0
+%define gcc_target_arch $cross_arch
+
+%define binutils_target %{cross_arch}
+%if %{cross_arch} == "armv7l" || %{cross_arch} == "armv7hl"
+%define binutils_target arm
+%endif
+%if %{cross_arch} == "armv6l" || %{cross_arch} == "armv6hl"
+%define binutils_target arm
+%endif
+%if %{cross_arch} == "armv5tel"
+%define binutils_target arm
+%endif
+%if %{cross_arch} == "aarch64"
+%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
+
+%if 0%{?gcc_icecream:1}
+%define build_sysroot /
+%endif
+
+
+Name:         %{pkgname}
+BuildRequires: cross-%{binutils_target}-binutils
+BuildRequires: gcc-c++
+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 ppc ppc64 s390 s390x ia64 %sparc hppa %arm
+BuildRequires: cloog-devel
+BuildRequires: ppl-devel
+%endif
+BuildRequires: cross-$cross_arch_cpu-binutils
+%ifarch ia64
+BuildRequires: libunwind-devel
+%endif
+%if 0%{!?gcc_icecream:1}
+BuildRequires: cross-%cross_arch-glibc-devel
+%endif
+
+%define biarch_targets x86_64 s390x powerpc64 powerpc sparc sparc64
+
+URL:          http://gcc.gnu.org/
+Version: 4.9.1
+Release:      1
+%define gcc_dir_version 4.9
+%define binsuffix -4.9
+BuildRoot:     %{_tmppath}/%{name}-%{version}-build
+Source:                gcc-%{version}.tar.bz2
+Source1:       change_spec
+Source2:       libffi49-rpmlintrc
+Source3:       gcc49-rpmlintrc
+Source4:       ecj.jar
+Source5:       baselibs.conf
+Source6:       libgcj49-rpmlintrc
+
+Group:          Development/Building
+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++.
+
+
+
+
+# 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} == "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
+%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "aarch64"
+%define CONFIGURE_TARGET aarch64-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} == "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/;")
+%endif
+%define biarch %(case " %{biarch_targets} " in (*" %{TARGET_ARCH} "*) echo 1;; (*) echo 0;; esac)
+
+%define HOST_ARCH %(echo %{_host_cpu} | sed -e "s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;")
+%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}
+
+
+%prep
+%setup -q -n gcc-%{version}
+
+# 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
+contrib/gcc_update --touch
+# Avoid fucking up testsuite results with Java and indirect dispatch
+export LD_ASNEEDED=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 possible and remove
+# the 'prerelease' tagging in this case
+if test `cat gcc/DEV-PHASE` == "prerelease"; then
+  if test `cat gcc/BASE-VER | cut -d '.' -f 3` != "0"; then
+    : > gcc/DEV-PHASE
+  fi
+  ( 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
+%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'`
+%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
+%if %{build_go}
+languages=$languages,go
+%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
+
+%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 \
+%if "%{TARGET_ARCH}" == "armv7l" || "%{TARGET_ARCH}" == "armv7hl"
+# temporary workaround for a miscompilation of hash functions in java code
+GCJ_EXTRA_FLAGS="-marm"
+%endif
+
+export RPM_OPT_FLAGS="`echo $RPM_OPT_FLAGS | sed -e "s/ -Wp,-D_FORTIFY_SOURCE=2 / /g"`"
+
+CFLAGS="$RPM_OPT_FLAGS" CXXFLAGS="$RPM_OPT_FLAGS" XCFLAGS="$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 \
+%if 0%{!?build_libvtv:1}
+       --disable-libvtv \
+%endif
+       --disable-plugin \
+       --with-bugurl="http://bugs.tizen.org/" \
+       --with-pkgversion="Tizen" \
+%if !%{build_fortran}
+       --disable-libquadmath \
+%endif
+%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
+       --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 \
+       --enable-linux-futex \
+       --program-suffix=%{binsuffix} \
+%if 0%{!?gcc_target_arch:1}
+%ifarch ia64
+       --with-system-libunwind \
+%else
+       --without-system-libunwind \
+%endif
+%endif
+%if 0%{?gcc_target_arch:1}
+       --program-prefix=%{gcc_target_arch}- \
+       --target=%{gcc_target_arch} \
+       --disable-nls \
+%if 0%{?sysroot:1}
+       --with-sysroot=%sysroot \
+%else
+       --with-sysroot=%{_prefix}/%{gcc_target_arch} \
+%endif
+%if 0%{?build_sysroot:1}
+       --with-build-sysroot=%{build_sysroot} \
+%else
+%if 0%{?sysroot:1}
+       --with-build-sysroot=%{sysroot} \
+%else
+       --with-build-sysroot=%{_prefix}/%{gcc_target_arch} \
+%endif
+%endif
+%if 0%{?canonical_target:1}
+       --with-build-time-tools=/usr/%{canonical_target}-tizen-linux%{?canonical_target_abi:%canonical_target_abi}/bin \
+%endif
+%if "%{TARGET_ARCH}" == "spu"
+       --with-gxx-include-dir=%sysroot/include/c++/%{gcc_dir_version} \
+       --with-newlib \
+%endif
+%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}" == "armv7l" 
+       --with-arch=armv7-a \
+       --with-tune=cortex-a8 \
+       --with-float=softfp \
+       --with-fpu=vfpv3 \
+       --with-mode=thumb \
+       --disable-sjlj-exceptions \
+%endif
+%if "%{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}" == "aarch64"
+       --with-arch=armv8-a \
+       --disable-sjlj-exceptions \
+%endif
+%if "%{TARGET_ARCH}" == "powerpc" || "%{TARGET_ARCH}" == "powerpc64"
+%if "%{TARGET_ARCH}" == "powerpc"
+        --with-cpu=default32 \
+%endif
+%if "%{TARGET_ARCH}" == "powerpc64le"
+       --with-cpu=power7 \
+%else
+       --with-cpu-64=power4 \
+%endif
+       --enable-secureplt \
+       --with-long-double-128 \
+%if "%{TARGET_ARCH}" == "powerpc64le"
+       --disable-multilib \
+%endif
+%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 \
+%endif
+%if "%{TARGET_ARCH}" == "x86_64"
+       --with-arch-32=i586 \
+       --with-tune=generic \
+       --disable-multilib \
+%endif
+%if "%{TARGET_ARCH}" == "s390"
+        --with-tune=zEC12 --with-arch=z196 \
+       --with-long-double-128 \
+       --enable-decimal-float \
+%endif
+%if "%{TARGET_ARCH}" == "s390x"
+        --with-tune=zEC12 --with-arch=z196 \
+       --with-long-double-128 \
+       --enable-decimal-float \
+%endif
+%if "%{TARGET_ARCH}" == "m68k"
+       --disable-multilib \
+%endif
+       --build=%{GCCDIST} \
+       --host=%{GCCDIST}
+
+
+%if 0%{!?gcc_icecream:1}
+make %{?jobs:-j%jobs}
+%else
+make %{?jobs:-j%jobs} all-host
+%endif
+
+%define _prefix /opt/cross
+
+%package -n cross-%cross_arch-gcc49-icecream-backend
+Summary: Icecream backend for the GNU C Compiler
+Group: Development/Languages/C and C++
+
+%description -n cross-%cross_arch-gcc49-icecream-backend
+This package contains the icecream environment for the GNU C Compiler
+
+
+%define targetlibsubdir %{_libdir}/gcc/%{gcc_target_arch}/%{gcc_dir_version}
+
+%install
+cd obj-%{GCCDIST}
+
+# install and fixup host parts
+make DESTDIR=$RPM_BUILD_ROOT install-host
+# with the present setup fixincludes are for the build includes which
+# is wrong - get rid of them
+rm -rf $RPM_BUILD_ROOT/%{targetlibsubdir}/include-fixed
+rm -f $RPM_BUILD_ROOT/%{targetlibsubdir}/liblto_plugin.la
+# common fixup
+rm -f $RPM_BUILD_ROOT%{_libdir}/libiberty.a
+# remove docs
+rm -rf $RPM_BUILD_ROOT%{_mandir}
+rm -rf $RPM_BUILD_ROOT%{_infodir}
+
+
+# install and fixup target parts
+# ???  don't do this - debugedit is not prepared for this and crashes
+# so expect the sysroot to be populated from natively built binaries
+#%if 0%{?sysroot:1}
+#make DESTDIR=$RPM_BUILD_ROOT/%{sysroot} install-target
+#%else
+#make DESTDIR=$RPM_BUILD_ROOT/%{_prefix}/%{gcc_target_arch} install-target
+#%endif
+
+
+# Build an icecream environment
+# 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/%{_prefix}/bin/%{gcc_target_arch}-g++%{binsuffix} \
+       $RPM_BUILD_ROOT/env/usr/bin/g++
+install -s $RPM_BUILD_ROOT/%{_prefix}/bin/%{gcc_target_arch}-gcc%{binsuffix} \
+       $RPM_BUILD_ROOT/env/usr/bin/gcc
+
+for back in cc1 cc1plus; do 
+       install -s -D $RPM_BUILD_ROOT/%{targetlibsubdir}/$back \
+               $RPM_BUILD_ROOT/env%{targetlibsubdir}/$back
+done
+if test -f $RPM_BUILD_ROOT/%{targetlibsubdir}/liblto_plugin.so; then
+  install -s -D $RPM_BUILD_ROOT/%{targetlibsubdir}/liblto_plugin.so \
+               $RPM_BUILD_ROOT/env%{targetlibsubdir}/liblto_plugin.so
+fi
+
+# Make sure to also pull in all shared library requirements for the
+# binaries we put into the environment which is operated by chrooting
+# into it and execing the compiler
+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
+
+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
+
+%files
+%defattr(-,root,root)
+%{_prefix}/bin
+%dir %{targetlibsubdir}
+%dir %{_libdir}/gcc/%{gcc_target_arch}
+%{targetlibsubdir}
+
+%files -n cross-%cross_arch-gcc49-icecream-backend
+%defattr(-,root,root)
+/usr/share/icecream-envs
+
+EOF
diff --git a/packaging/cross.spec.in b/packaging/cross.spec.in
new file mode 100644 (file)
index 0000000..eca2eb4
--- /dev/null
@@ -0,0 +1,181 @@
+#! /bin/sh
+
+#
+# call this via pre_checkin.sh
+#
+# 2005-05-09, jw@suse.de
+
+test -z "$cross_arch" && echo 1>&2 "Error: $0 needs environment variable 'cross_arch'"
+test -z "$outfile" && echo 1>&2 "Error: $0 needs environment variable 'outfile'"
+cross_arch_cpu=`echo $cross_arch | sed -e 's/\([^-]*\)-\?.*/\1/'`
+
+cat << EOF
+#
+# spec file for package gcc (Version 4.8.2)
+#
+# 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_go 0
+%define gcc_target_arch $cross_arch
+
+%define binutils_target %{cross_arch}
+%if %{cross_arch} == "armv7l" || %{cross_arch} == "armv7hl"
+%define binutils_target arm
+%endif
+%if %{cross_arch} == "armv6l" || %{cross_arch} == "armv6hl"
+%define binutils_target arm
+%endif
+%if %{cross_arch} == "armv5tel"
+%define binutils_target arm
+%endif
+%if %{cross_arch} == "aarch64"
+%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
+
+%if 0%{?gcc_icecream:1}
+%define build_sysroot /
+%endif
+
+
+Name:         %{pkgname}
+BuildRequires: cross-%{binutils_target}-binutils
+BuildRequires: gcc-c++
+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 ppc ppc64 s390 s390x ia64 %sparc hppa %arm
+BuildRequires: cloog-devel
+BuildRequires: ppl-devel
+%endif
+BuildRequires: cross-$cross_arch_cpu-binutils
+%ifarch ia64
+BuildRequires: libunwind-devel
+%endif
+%if 0%{!?gcc_icecream:1}
+BuildRequires: cross-%cross_arch-glibc-devel
+%endif
+
+# COMMON-BEGIN
+# COMMON-END
+
+%if 0%{!?gcc_icecream:1}
+make %{?jobs:-j%jobs}
+%else
+make %{?jobs:-j%jobs} all-host
+%endif
+
+%define _prefix /opt/cross
+
+%package -n cross-%cross_arch-gcc@base_ver@-icecream-backend
+Summary: Icecream backend for the GNU C Compiler
+Group: Development/Languages/C and C++
+
+%description -n cross-%cross_arch-gcc@base_ver@-icecream-backend
+This package contains the icecream environment for the GNU C Compiler
+
+
+%define targetlibsubdir %{_libdir}/gcc/%{gcc_target_arch}/%{gcc_dir_version}
+
+%install
+cd obj-%{GCCDIST}
+
+# install and fixup host parts
+make DESTDIR=$RPM_BUILD_ROOT install-host
+# with the present setup fixincludes are for the build includes which
+# is wrong - get rid of them
+rm -rf $RPM_BUILD_ROOT/%{targetlibsubdir}/include-fixed
+rm -f $RPM_BUILD_ROOT/%{targetlibsubdir}/liblto_plugin.la
+# common fixup
+rm -f $RPM_BUILD_ROOT%{_libdir}/libiberty.a
+# remove docs
+rm -rf $RPM_BUILD_ROOT%{_mandir}
+rm -rf $RPM_BUILD_ROOT%{_infodir}
+
+
+# install and fixup target parts
+# ???  don't do this - debugedit is not prepared for this and crashes
+# so expect the sysroot to be populated from natively built binaries
+#%if 0%{?sysroot:1}
+#make DESTDIR=$RPM_BUILD_ROOT/%{sysroot} install-target
+#%else
+#make DESTDIR=$RPM_BUILD_ROOT/%{_prefix}/%{gcc_target_arch} install-target
+#%endif
+
+
+# Build an icecream environment
+# 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/%{_prefix}/bin/%{gcc_target_arch}-g++%{binsuffix} \
+       $RPM_BUILD_ROOT/env/usr/bin/g++
+install -s $RPM_BUILD_ROOT/%{_prefix}/bin/%{gcc_target_arch}-gcc%{binsuffix} \
+       $RPM_BUILD_ROOT/env/usr/bin/gcc
+
+for back in cc1 cc1plus; do 
+       install -s -D $RPM_BUILD_ROOT/%{targetlibsubdir}/$back \
+               $RPM_BUILD_ROOT/env%{targetlibsubdir}/$back
+done
+if test -f $RPM_BUILD_ROOT/%{targetlibsubdir}/liblto_plugin.so; then
+  install -s -D $RPM_BUILD_ROOT/%{targetlibsubdir}/liblto_plugin.so \
+               $RPM_BUILD_ROOT/env%{targetlibsubdir}/liblto_plugin.so
+fi
+
+# Make sure to also pull in all shared library requirements for the
+# binaries we put into the environment which is operated by chrooting
+# into it and execing the compiler
+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
+
+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
+
+%files
+%defattr(-,root,root)
+%{_prefix}/bin
+%dir %{targetlibsubdir}
+%dir %{_libdir}/gcc/%{gcc_target_arch}
+%{targetlibsubdir}
+
+%files -n cross-%cross_arch-gcc@base_ver@-icecream-backend
+%defattr(-,root,root)
+/usr/share/icecream-envs
+
+EOF
diff --git a/packaging/ecj.jar b/packaging/ecj.jar
new file mode 100644 (file)
index 0000000..8d5ed17
Binary files /dev/null and b/packaging/ecj.jar differ
diff --git a/packaging/gcc.spec.in b/packaging/gcc.spec.in
new file mode 100644 (file)
index 0000000..c5b7f1d
--- /dev/null
@@ -0,0 +1,2604 @@
+#
+# spec file for package gcc49
+#
+# 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
+
+
+%define build_ada 0
+
+%define quadmath_arch %ix86 x86_64 ia64 aarch64
+%define tsan_arch x86_64
+%define asan_arch x86_64 %ix86 ppc ppc64 %sparc %arm
+%define itm_arch x86_64 %ix86 %arm ppc ppc64 ppc64le s390 s390x %sparc
+%define atomic_arch x86_64 %ix86 %arm aarch64 ppc ppc64 ppc64le s390 s390x %sparc m68k
+%define lsan_arch x86_64
+%define ubsan_arch x86_64 %ix86 ppc ppc64 %arm
+%if 0%{?build_libvtv:1}
+%define vtv_arch x86_64 %ix86
+%endif
+%define cilkrts_arch x86_64 %ix86
+
+# We don't want to build java
+%define build_java 0
+%define build_libjava 0
+
+%define build_cp 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_go !0%{?building_libjava:1}%{?building_libffi:1}
+
+%if %{build_objcp}
+%define build_cp 1
+%define build_objc 1
+%endif
+
+%if %{build_libjava}
+%define build_cp 1
+%endif
+
+# For optional compilers only build C, C++ and Fortran
+%if 0%{?build_optional_compiler_languages:1}
+%define build_ada 0
+%define build_java 0
+%define build_libjava 0
+%define build_objc 0
+%define build_objcp 0
+%define build_go 0
+%endif
+
+# Shared library SONAME versions
+%ifarch hppa
+%define libgcc_s 4
+%else
+%ifarch m68k
+%define libgcc_s 2
+%else
+%define libgcc_s 1
+%endif
+%endif
+%define libgcj_sover %{nil}
+%define libgcj_bc_sover %{nil}
+%define libffi_sover %{nil}
+%define libgomp_sover %{nil}
+%define libstdcxx_sover %{nil}
+%define libobjc_sover %{nil}
+%define libgfortran_sover %{nil}
+%define libquadmath_sover %{nil}
+%define libasan_sover %{nil}
+%define libtsan_sover %{nil}
+%define libatomic_sover %{nil}
+%define libitm_sover %{nil}
+%define libubsan_sover %{nil}
+%define liblsan_sover %{nil}
+%define libvtv_sover %{nil}
+%define libcilkrts_sover %{nil}
+%define libgo_sover %{nil}
+
+# 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 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@}
+
+
+%define libubsan_suffix %{?pne:-gcc@base_ver@}
+%define liblsan_suffix %{?pne:-gcc@base_ver@}
+%define libvtv_suffix %{?pne:-gcc@base_ver@}
+%define libcilkrts_suffix %{?pne:-gcc@base_ver@}
+%define libgo_suffix %{?pne:-gcc@base_ver@}
+
+%define selfconflict() %1
+
+Name:         gcc@base_ver@
+# With generated files in src we could drop the following
+BuildRequires: bison
+BuildRequires: flex
+BuildRequires: gettext-devel
+BuildRequires: makeinfo
+# until here, but at least renaming and patching info files breaks this
+BuildRequires: gcc-c++
+BuildRequires: glibc-devel
+BuildRequires: mpc-devel
+BuildRequires: mpfr-devel
+BuildRequires: perl
+BuildRequires: zlib-devel
+%ifarch %ix86 x86_64 ppc ppc64 s390 s390x ia64 %sparc hppa %arm aarch64
+BuildRequires: cloog-isl-devel
+BuildRequires: isl-devel
+%endif
+%if %{build_ada}
+%define hostsuffix -4.9
+BuildRequires: gcc49-ada
+%endif
+%if 0%{?building_libjava:1}%{?building_testsuite:1}
+BuildRequires: fastjar
+%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 separate_bi32 0
+%define separate_bi64 0
+%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
+
+# Define two macros to trigger -32bit or -64bit package variants
+%define separate_biarch 0
+%if %{separate_bi32}
+%define separate_biarch 1
+%define separate_biarch_suffix -32bit
+%endif
+%if %{separate_bi64}
+%define separate_biarch 1
+%define separate_biarch_suffix -64bit
+%endif
+
+%ifarch x86_64 ia64 s390x alpha ppc64 sparc64 aarch64
+# 64-bit is primary build target
+%define build_primary_64bit 1
+%else
+%define build_primary_64bit 0
+%endif
+
+%define biarch_libjava 0
+
+# COMMON-BEGIN
+%define biarch_targets x86_64 s390x powerpc64 powerpc sparc sparc64
+
+URL:          http://gcc.gnu.org/
+Version: 4.9.1
+Release:      1
+%define gcc_dir_version 4.9
+%define binsuffix -4.9
+# COMMON-END
+
+%if !0%{?building_libjava:1}%{?building_libffi:1}%{?building_testsuite:1}
+Requires: binutils glibc-devel
+Requires: cpp@base_ver@ = %{version}-%{release}
+Requires: libgcc_s%{libgcc_s} >= %{version}-%{release}
+Requires: libgomp%{libgomp_sover} >= %{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
+%ifarch %cilkrts_arch
+Requires: libcilkrts%{libcilkrts_sover} >= %{version}-%{release}
+%endif
+%ifarch %lsan_arch
+Requires: liblsan%{liblsan_sover} >= %{version}-%{release}
+%endif
+%ifarch %ubsan_arch
+Requires: libubsan%{libubsan_sover} >= %{version}-%{release}
+%endif
+%ifarch %vtv_arch
+Requires: libvtv%{libvtv_sover} >= %{version}-%{release}
+%endif
+Suggests: gcc@base_ver@-info gcc@base_ver@-locale
+%endif
+
+# COMMON-BEGIN
+BuildRoot:     %{_tmppath}/%{name}-%{version}-build
+Source:                gcc-%{version}.tar.bz2
+Source1:       change_spec
+Source2:       libffi49-rpmlintrc
+Source3:       gcc49-rpmlintrc
+Source4:       ecj.jar
+Source5:       baselibs.conf
+Source6:       libgcj49-rpmlintrc
+
+# GCC-TESTSUITE-DELETE-BEGIN
+# LIBJAVA-DELETE-BEGIN
+Group:          Development/Building
+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++.
+# LIBFFI-DELETE-BEGIN
+
+
+
+# COMMON-END
+%package -n gcc@base_ver@-32bit
+Summary:      The GNU C Compiler 32bit support
+Group:          Development/Building
+Requires: gcc@base_ver@ = %{version}-%{release}
+Requires: libgcc_s%{libgcc_s}-32bit >= %{version}-%{release}
+Requires: libgomp%{libgomp_sover}-32bit >= %{version}-%{release}
+%ifarch %asan_arch
+Requires: libasan%{libasan_sover}-32bit >= %{version}-%{release}
+%endif
+%ifarch %tsan_arch
+# tsan on x86_64 has no multilib
+%ifarch x86_64
+%else
+Requires: libtsan%{libtsan_sover}-32bit >= %{version}-%{release}
+%endif
+%endif
+%ifarch %atomic_arch
+Requires: libatomic%{libatomic_sover}-32bit >= %{version}-%{release}
+%endif
+%ifarch %itm_arch
+Requires: libitm%{libitm_sover}-32bit >= %{version}-%{release}
+%endif
+%ifarch %cilkrts_arch
+Requires: libcilkrts%{libcilkrts_sover}-32bit >= %{version}-%{release}
+%endif
+# lsan on x86_64 has no multilib
+%ifarch x86_64
+%else
+%ifarch %lsan_arch
+Requires: liblsan%{liblsan_sover} >= %{version}-%{release}
+%endif
+%endif
+%ifarch %ubsan_arch
+Requires: libubsan%{libubsan_sover}-32bit >= %{version}-%{release}
+%endif
+%ifarch %vtv_arch
+Requires: libvtv%{libvtv_sover}-32bit >= %{version}-%{release}
+%endif
+Requires: glibc-devel-32bit
+
+%description -n gcc@base_ver@-32bit
+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/Building
+Requires: gcc@base_ver@ = %{version}-%{release}
+Requires: libgcc_s%{libgcc_s}-64bit >= %{version}-%{release}
+Requires: libgomp%{libgomp_sover}-64bit >= %{version}-%{release}
+%ifarch %asan_arch
+Requires: libasan%{libasan_sover}-64bit >= %{version}-%{release}
+%endif
+%ifarch %tsan_arch
+Requires: libtsan%{libtsan_sover}-64bit >= %{version}-%{release}
+%endif
+%ifarch %atomic_arch
+Requires: libatomic%{libatomic_sover}-64bit >= %{version}-%{release}
+%endif
+%ifarch %itm_arch
+Requires: libitm%{libitm_sover}-64bit >= %{version}-%{release}
+%endif
+%ifarch %cilkrts_arch
+Requires: libcilkrts%{libcilkrts_sover}-64bit >= %{version}-%{release}
+%endif
+%ifarch %lsan_arch
+Requires: liblsan%{liblsan_sover}-64bit >= %{version}-%{release}
+%endif
+%ifarch %ubsan_arch
+Requires: libubsan%{libubsan_sover}-64bit >= %{version}-%{release}
+%endif
+%ifarch %vtv_arch
+Requires: libvtv%{libvtv_sover}-64bit >= %{version}-%{release}
+%endif
+Requires: glibc-devel-64bit
+
+%description -n gcc@base_ver@-64bit
+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/Building
+Requires: gcc@base_ver@ = %{version}-%{release}
+
+%description locale
+Locale data for the GNU Compiler Collection (GCC) to give error message
+in the current locale.
+
+
+%package c++
+Summary:      The GNU C++ Compiler
+License:        GPL-3.0+
+Group:        Development/Languages
+Requires: gcc@base_ver@ = %{version}-%{release}
+Requires: libstdc++@base_ver@-devel = %{version}-%{release}
+
+%description c++
+This package contains the GNU compiler for C++.
+
+# PACKAGE-BEGIN
+%package -n libstdc++@base_ver@-devel@variant@
+Summary:      Include Files and Libraries mandatory for Development
+License:        GPL-3.0-with-GCC-exception
+Group:          Development/Building
+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++
+library. It is needed for compiling C++ code.
+# PACKAGE-END
+
+
+# PACKAGE-BEGIN
+%package -n libgcc_s%{libgcc_s}%{libgcc_s_suffix}@variant@
+Summary:      C compiler runtime library
+License:        GPL-3.0-with-GCC-exception
+Group:          Development/Building
+Provides:      libgcc_s%{libgcc_s}@variant@ = %{version}-%{release}
+
+%description -n libgcc_s%{libgcc_s}%{libgcc_s_suffix}@variant@
+Libgcc is needed for dynamically linked C programs.
+
+%post -n libgcc_s%{libgcc_s}%{libgcc_s_suffix}@variant@ -p /sbin/ldconfig
+
+%postun -n libgcc_s%{libgcc_s}%{libgcc_s_suffix}@variant@ -p /sbin/ldconfig
+# PACKAGE-END
+
+# PACKAGE-BEGIN
+%package -n libgomp%{libgomp_sover}%{libgomp_suffix}@variant@
+Summary:      The GNU compiler collection OpenMP runtime library
+License:        GPL-3.0-with-GCC-exception
+Group:          Development/Building
+Provides:      libgomp%{libgomp_sover}@variant@ = %{version}-%{release}
+
+%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%{libgomp_sover}%{libgomp_suffix}@variant@ -p /sbin/ldconfig
+
+%postun -n libgomp%{libgomp_sover}%{libgomp_suffix}@variant@ -p /sbin/ldconfig
+# PACKAGE-END
+
+# PACKAGE-BEGIN
+%package -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}@variant@
+Summary:      The standard C++ shared library
+License:        GPL-3.0-with-GCC-exception
+Group:          Development/Building
+Suggests:      libstdc++%{libstdcxx_sover}-locale
+Provides:      libstdc++%{libstdcxx_sover}@variant@ = %{version}-%{release}
+
+%description -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}@variant@
+The standard C++ library, needed for dynamically linked C++ programs.
+
+
+%post -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}@variant@ -p /sbin/ldconfig
+
+%postun -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}@variant@ -p /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:          Development/Building
+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:        Development/Building
+BuildArch:    noarch
+
+%description info
+GNU info-pages for the GNU compiler collection covering both user-level
+and internals documentation.
+
+
+# PACKAGE-BEGIN
+%package objc@variant@
+Summary:      GNU Objective C Compiler
+License:        GPL-3.0+
+Group:        Development/Languages
+Requires: gcc@base_ver@ = %{version}-%{release}
+Requires: libobjc%{libobjc_sover}@variant@ >= %{version}-%{release}
+
+%description objc@variant@
+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 -n libobjc%{libobjc_sover}%{libobjc_suffix}@variant@
+Summary:      Library for the GNU Objective C Compiler
+License:        GPL-3.0-with-GCC-exception
+Group:        Development/Building
+Provides:      libobjc%{libobjc_sover}@variant@ = %{version}-%{release}
+
+%description -n libobjc%{libobjc_sover}%{libobjc_suffix}@variant@
+The library for the GNU Objective C compiler.
+
+%post -n libobjc%{libobjc_sover}%{libobjc_suffix}@variant@ -p /sbin/ldconfig
+
+%postun -n libobjc%{libobjc_sover}%{libobjc_suffix}@variant@ -p /sbin/ldconfig
+# PACKAGE-END
+
+%package obj-c++
+Summary:      GNU Objective C++ Compiler
+License:        GPL-3.0+
+Group:        Development/Languages
+Requires: gcc@base_ver@-objc = %{version}-%{release}
+Requires: gcc@base_ver@-c++ = %{version}-%{release}
+
+%description obj-c++
+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 -n cpp@base_ver@
+Summary:      The GCC Preprocessor
+License:        GPL-3.0+
+Group:        Development/Languages
+
+%description -n cpp@base_ver@
+This Package contains just the preprocessor that is used by the X11
+packages.
+
+
+# PACKAGE-BEGIN
+%package ada@variant@
+Summary:      GNU Ada95 Compiler Based on GCC (GNAT)
+License:        GPL-3.0+
+Group:        Development/Languages
+Requires: gcc@base_ver@@variant@ = %{version}-%{release}
+Requires: libada@base_ver@@variant@ = %{version}-%{release}
+
+%description ada@variant@
+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 -n libada@base_ver@@variant@
+Summary:      GNU Ada Runtime Libraries
+License:      GPL-3.0-with-GCC-exception
+Group:        Development/Languages
+Provides: libgnarl-4_9@variant@ = %{version}-%{release}
+Provides: libgnat-4_9@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
+shared libraries. It also contains the shared libraries for the
+Implementation of the Ada Semantic Interface Specification (ASIS), the
+implementation of Distributed Systems Programming (GLADE) and the Posix
+1003.5 Binding (Florist).
+
+%post -n libada@base_ver@@variant@ -p /sbin/ldconfig
+
+%postun -n libada@base_ver@@variant@ -p /sbin/ldconfig
+# PACKAGE-END
+
+# PACKAGE-BEGIN
+%package fortran@variant@
+Summary:      The GNU Fortran Compiler and Support Files
+License:        GPL-3.0+
+Group:        Development/Languages
+Requires: gcc@base_ver@ = %{version}-%{release}
+Requires: libgfortran%{libgfortran_sover}@variant@ >= %{version}-%{release}
+%ifarch %quadmath_arch
+Requires: libquadmath%{libquadmath_sover}@variant@ >= %{version}-%{release}
+%endif
+
+%description fortran@variant@
+This is the Fortran compiler of the GNU Compiler Collection (GCC).
+# PACKAGE-END
+
+# PACKAGE-BEGIN
+%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
+%ifarch %quadmath_arch
+Requires: libquadmath%{libquadmath_sover}@variant@ >= %{version}-%{release}
+%endif
+Provides:      libgfortran%{libgfortran_sover}@variant@ = %{version}-%{release}
+
+%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%{libgfortran_sover}%{libgfortran_suffix}@variant@ -p /sbin/ldconfig
+
+%postun -n libgfortran%{libgfortran_sover}%{libgfortran_suffix}@variant@ -p /sbin/ldconfig
+# PACKAGE-END
+
+# PACKAGE-BEGIN
+%package -n libquadmath%{libquadmath_sover}%{libquadmath_suffix}@variant@
+Summary:      The GNU Fortran Compiler Quadmath Runtime Library
+License:        LGPL-2.1
+Group:        Development/Languages
+Provides:      libquadmath%{libquadmath_sover}@variant@ = %{version}-%{release}
+
+%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%{libquadmath_sover}%{libquadmath_suffix}@variant@ -p /sbin/ldconfig
+
+%postun -n libquadmath%{libquadmath_sover}%{libquadmath_suffix}@variant@ -p /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
+Provides:      libitm%{libitm_sover}@variant@ = %{version}-%{release}
+
+%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@ -p /sbin/ldconfig
+
+%postun -n libitm%{libitm_sover}%{libitm_suffix}@variant@ -p /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
+Provides:      libasan%{libasan_sover}@variant@ = %{version}-%{release}
+
+%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@ -p /sbin/ldconfig
+
+%postun -n libasan%{libasan_sover}%{libasan_suffix}@variant@ -p /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
+Provides:      libtsan%{libtsan_sover}@variant@ = %{version}-%{release}
+
+%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@ -p /sbin/ldconfig
+
+%postun -n libtsan%{libtsan_sover}%{libtsan_suffix}@variant@ -p /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
+Provides:      libatomic%{libatomic_sover}@variant@ = %{version}-%{release}
+
+%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@ -p /sbin/ldconfig
+
+%postun -n libatomic%{libatomic_sover}%{libatomic_suffix}@variant@ -p /sbin/ldconfig
+# PACKAGE-END
+
+# PACKAGE-BEGIN
+%package -n libcilkrts%{libcilkrts_sover}%{libcilkrts_suffix}@variant@
+Summary:      The GNU Compiler Cilk+ Runtime Library
+License:        MIT
+Group:        Development/Languages
+Provides:      libcilkrts%{libcilkrts_sover}@variant@ = %{version}-%{release}
+
+%description -n libcilkrts%{libcilkrts_sover}%{libcilkrts_suffix}@variant@
+The runtime library needed to run programs compiled with the
+-fcilkplus option of the GNU Compiler Collection (GCC).
+
+%post -n libcilkrts%{libcilkrts_sover}%{libcilkrts_suffix}@variant@ -p /sbin/ldconfig
+
+%postun -n libcilkrts%{libcilkrts_sover}%{libcilkrts_suffix}@variant@ -p /sbin/ldconfig
+# PACKAGE-END
+
+# PACKAGE-BEGIN
+%package -n liblsan%{liblsan_sover}%{liblsan_suffix}@variant@
+Summary:      The GNU Compiler Leak Sanitizer Runtime Library
+License:        MIT
+Group:        Development/Languages
+Provides:      liblsan%{liblsan_sover}@variant@ = %{version}-%{release}
+
+%description -n liblsan%{liblsan_sover}%{liblsan_suffix}@variant@
+The runtime library needed to run programs compiled with the
+-fsanitize=leak option of the GNU Compiler Collection (GCC).
+
+%post -n liblsan%{liblsan_sover}%{liblsan_suffix}@variant@ -p /sbin/ldconfig
+
+%postun -n liblsan%{liblsan_sover}%{liblsan_suffix}@variant@ -p /sbin/ldconfig
+# PACKAGE-END
+
+# PACKAGE-BEGIN
+%package -n libubsan%{libubsan_sover}%{libubsan_suffix}@variant@
+Summary:      The GNU Compiler Undefined Sanitizer Runtime Library
+License:        MIT
+Group:        Development/Languages
+Provides:      libubsan%{libubsan_sover}@variant@ = %{version}-%{release}
+
+%description -n libubsan%{libubsan_sover}%{libubsan_suffix}@variant@
+The runtime library needed to run programs compiled with the
+-fsanitize=undefined option of the GNU Compiler Collection (GCC).
+
+%post -n libubsan%{libubsan_sover}%{libubsan_suffix}@variant@ -p /sbin/ldconfig
+
+%postun -n libubsan%{libubsan_sover}%{libubsan_suffix}@variant@ -p /sbin/ldconfig
+# PACKAGE-END
+
+# PACKAGE-BEGIN
+%package -n libvtv%{libvtv_sover}%{libvtv_suffix}@variant@
+Summary:      The GNU Compiler Vtable Verifier Runtime Library
+License:        MIT
+Group:        Development/Languages
+Provides:      libvtv%{libvtv_sover}@variant@ = %{version}-%{release}
+
+%description -n libvtv%{libvtv_sover}%{libvtv_suffix}@variant@
+The runtime library needed to run programs compiled with the
+-fvtable-verify option of the GNU Compiler Collection (GCC).
+
+%post -n libvtv%{libvtv_sover}%{libvtv_suffix}@variant@ -p /sbin/ldconfig
+
+%postun -n libvtv%{libvtv_sover}%{libvtv_suffix}@variant@ -p /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:        Development/Building
+Recommends:   libgcj@base_ver@-jar = %{version}-%{release}
+Provides: libgcj%{libgcj_sover} = %{version}-%{release}
+Provides: libgij%{libgcj_sover} = %{version}-%{release}
+Provides: libgcj-tools%{libgcj_sover} = %{version}-%{release}
+
+%description -n libgcj@base_ver@
+This library is needed if you want to use the GNU Java compiler, gcj.
+Source code for this package is in gcc.
+
+%post -n libgcj@base_ver@ -p /sbin/ldconfig
+
+%postun -n libgcj@base_ver@ -p /sbin/ldconfig
+
+
+%package -n gcc@base_ver@-java
+Summary:      The GNU Java Compiler
+License:        GPL-3.0+
+Group:        Development/Languages
+Requires: gcc@base_ver@ = %{version}
+Requires: libgcj@base_ver@-devel = %{version}-%{release}
+
+%description -n gcc@base_ver@-java
+The Java compiler from the GCC-tools-suite.
+
+
+%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/Languages
+# 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%{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.%{libgcj_bc_sover}
+%endif
+Provides:      libgcj_bc%{libgcj_bc_sover} = %{version}-%{release}
+
+%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
+libgcj.so changes.
+
+
+%package -n libgcj@base_ver@-jar
+Summary:      Java runtime library (jar files).
+License:        GPL-2.0-with-classpath-exception
+Group:        Development/Languages
+
+%description -n libgcj@base_ver@-jar
+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/Languages
+Requires: libgcj%{libgcj_sover} >= %{version}-%{release}
+Requires: libgcj_bc%{libgcj_bc_sover} >= %{version}-%{release}
+Requires: libgcj@base_ver@-jar = %{version}-%{release}
+
+%description -n libgcj@base_ver@-devel
+This package contains all necessary include files and libraries needed
+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/Languages
+Requires: libgcj%{libgcj_sover} >= %{version}-%{release}
+
+%description -n gcc@base_ver@-gij
+This package contains the java bytecode interpreter gij and related tools.
+
+
+%package -n libstdc++@base_ver@-doc
+Summary:      Documentation for the GNU C++ standard library
+License:        GPL-3.0+
+Group:        Development/Building
+BuildArch:    noarch
+
+%description -n libstdc++@base_ver@-doc
+Extensive HTML documentation for the GNU C++ standard library.
+
+
+# LIBFFI-DELETE-END
+# PACKAGE-BEGIN
+%package -n libffi%{libffi_sover}%{libffi_suffix}@variant@
+Summary:      Foreign Function Interface library
+License:        BSD-3-Clause
+Group:        Development/Building
+Provides:      libffi%{libffi_sover}@variant@ = %{version}-%{release}
+
+%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%{libffi_sover}%{libffi_suffix}@variant@ -p /sbin/ldconfig
+
+%postun -n libffi%{libffi_sover}%{libffi_suffix}@variant@ -p /sbin/ldconfig
+# PACKAGE-END
+
+# PACKAGE-BEGIN
+%package -n libffi@base_ver@-devel@variant@
+Summary:      Foreign Function Interface library development files
+License:        BSD 3-Clause
+Group:        Development/Building
+Requires: libffi%{libffi_sover}@variant@ >= %{version}-%{release}
+Provides: libffi-devel@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.
+# PACKAGE-END
+
+# PACKAGE-BEGIN
+%package go@variant@
+Summary:      GNU Go Compiler
+License:        GPL-3.0+ 
+Group:        Development/Languages
+Requires: gcc@base_ver@@variant@ = %{version}-%{release}
+Requires: libgo%{libgo_sover}@variant@ >= %{version}-%{release}
+
+%description go@variant@
+This package contains a Go compiler and associated development
+files based on the GNU GCC technology.
+# PACKAGE-END
+
+# PACKAGE-BEGIN
+%package -n libgo%{libgo_sover}%{libgo_suffix}@variant@
+Summary:      GNU Go compiler runtime library
+License:        BSD-3-Clause
+Group:        Development/Languages
+Provides:      libgo%{libgo_sover}@variant@ = %{version}-%{release}
+
+%description -n libgo%{libgo_sover}%{libgo_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 libgo%{libgo_sover}%{libgo_suffix}@variant@ -p /sbin/ldconfig
+
+%postun -n libgo%{libgo_sover}%{libgo_suffix}@variant@ -p /sbin/ldconfig
+# PACKAGE-END
+
+
+%package -n gcc@base_ver@-testresults
+# GCC-TESTSUITE-DELETE-END
+Summary:      Testsuite results
+License:       SUSE-Public-Domain
+Group:        Development/Languages
+
+%description -n gcc@base_ver@-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
+#   %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} == "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
+%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "aarch64"
+%define CONFIGURE_TARGET aarch64-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} == "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/;")
+%endif
+%define biarch %(case " %{biarch_targets} " in (*" %{TARGET_ARCH} "*) echo 1;; (*) echo 0;; esac)
+
+%define HOST_ARCH %(echo %{_host_cpu} | sed -e "s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;")
+%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
+
+%define mainlibdir %{_libdir}
+%define mainlibdirbi32 %{_prefix}/lib
+%define mainlibdirbi64 %{_prefix}/lib64
+%if %{build_primary_64bit}
+%define mainlibdirbi %{mainlibdirbi32}
+%else
+%define mainlibdirbi %{mainlibdirbi64}
+%endif
+
+
+# Now define a few macros that make it easy to package libs and
+# related files just to the right package, without caring for the
+# 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
+%define mainlib() %{mainlibdir}/%1\
+%{nil}
+%define biarchlib() %{nil}
+%if %{biarch}
+%if !%{separate_biarch}
+%define mainlib() %{mainlibdir}/%1\
+%{mainlibdirbi}/%1\
+%{nil}
+%else
+%define biarchlib() %{mainlibdirbi}/%1\
+%{nil}
+%endif
+%endif
+
+%define versmainlib() %{versmainlibdir}/%1\
+%{nil}
+%define versbiarchlib() %{nil}
+%if %{biarch}
+%if !%{separate_biarch}
+%define versmainlib() %{versmainlibdir}/%1\
+%{versmainlibdirbi}/%1\
+%{nil}
+%else
+%define versbiarchlib() %{versmainlibdirbi}/%1\
+%{nil}
+%endif
+%endif
+
+
+# COMMON-BEGIN
+
+%prep
+%setup -q -n gcc-%{version}
+
+# 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
+contrib/gcc_update --touch
+# Avoid fucking up testsuite results with Java and indirect dispatch
+export LD_ASNEEDED=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 possible and remove
+# the 'prerelease' tagging in this case
+if test `cat gcc/DEV-PHASE` == "prerelease"; then
+  if test `cat gcc/BASE-VER | cut -d '.' -f 3` != "0"; then
+    : > gcc/DEV-PHASE
+  fi
+  ( 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
+%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'`
+%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
+%if %{build_go}
+languages=$languages,go
+%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
+
+%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 \
+%if "%{TARGET_ARCH}" == "armv7l" || "%{TARGET_ARCH}" == "armv7hl"
+# temporary workaround for a miscompilation of hash functions in java code
+GCJ_EXTRA_FLAGS="-marm"
+%endif
+
+export RPM_OPT_FLAGS="`echo $RPM_OPT_FLAGS | sed -e "s/ -Wp,-D_FORTIFY_SOURCE=2 / /g"`"
+
+CFLAGS="$RPM_OPT_FLAGS" CXXFLAGS="$RPM_OPT_FLAGS" XCFLAGS="$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 \
+%if 0%{!?build_libvtv:1}
+       --disable-libvtv \
+%endif
+       --disable-plugin \
+       --with-bugurl="http://bugs.tizen.org/" \
+       --with-pkgversion="Tizen" \
+%if !%{build_fortran}
+       --disable-libquadmath \
+%endif
+%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
+       --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 \
+       --enable-linux-futex \
+       --program-suffix=%{binsuffix} \
+%if 0%{!?gcc_target_arch:1}
+%ifarch ia64
+       --with-system-libunwind \
+%else
+       --without-system-libunwind \
+%endif
+%endif
+%if 0%{?gcc_target_arch:1}
+       --program-prefix=%{gcc_target_arch}- \
+       --target=%{gcc_target_arch} \
+       --disable-nls \
+%if 0%{?sysroot:1}
+       --with-sysroot=%sysroot \
+%else
+       --with-sysroot=%{_prefix}/%{gcc_target_arch} \
+%endif
+%if 0%{?build_sysroot:1}
+       --with-build-sysroot=%{build_sysroot} \
+%else
+%if 0%{?sysroot:1}
+       --with-build-sysroot=%{sysroot} \
+%else
+       --with-build-sysroot=%{_prefix}/%{gcc_target_arch} \
+%endif
+%endif
+%if 0%{?canonical_target:1}
+       --with-build-time-tools=/usr/%{canonical_target}-tizen-linux%{?canonical_target_abi:%canonical_target_abi}/bin \
+%endif
+%if "%{TARGET_ARCH}" == "spu"
+       --with-gxx-include-dir=%sysroot/include/c++/%{gcc_dir_version} \
+       --with-newlib \
+%endif
+%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}" == "armv7l" 
+       --with-arch=armv7-a \
+       --with-tune=cortex-a8 \
+       --with-float=softfp \
+       --with-fpu=vfpv3 \
+       --with-mode=thumb \
+       --disable-sjlj-exceptions \
+%endif
+%if "%{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}" == "aarch64"
+       --with-arch=armv8-a \
+       --disable-sjlj-exceptions \
+%endif
+%if "%{TARGET_ARCH}" == "powerpc" || "%{TARGET_ARCH}" == "powerpc64"
+%if "%{TARGET_ARCH}" == "powerpc"
+        --with-cpu=default32 \
+%endif
+%if "%{TARGET_ARCH}" == "powerpc64le"
+       --with-cpu=power7 \
+%else
+       --with-cpu-64=power4 \
+%endif
+       --enable-secureplt \
+       --with-long-double-128 \
+%if "%{TARGET_ARCH}" == "powerpc64le"
+       --disable-multilib \
+%endif
+%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 \
+%endif
+%if "%{TARGET_ARCH}" == "x86_64"
+       --with-arch-32=i586 \
+       --with-tune=generic \
+       --disable-multilib \
+%endif
+%if "%{TARGET_ARCH}" == "s390"
+        --with-tune=zEC12 --with-arch=z196 \
+       --with-long-double-128 \
+       --enable-decimal-float \
+%endif
+%if "%{TARGET_ARCH}" == "s390x"
+        --with-tune=zEC12 --with-arch=z196 \
+       --with-long-double-128 \
+       --enable-decimal-float \
+%endif
+%if "%{TARGET_ARCH}" == "m68k"
+       --disable-multilib \
+%endif
+       --build=%{GCCDIST} \
+       --host=%{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 and matters
+#%ifarch x86_64 ppc64le s390x
+#make profiledbootstrap STAGE1_CFLAGS="$STAGE1_FLAGS" BOOT_CFLAGS="$RPM_OPT_FLAGS" $PARALLEL
+#%else
+make STAGE1_CFLAGS="$STAGE1_FLAGS" BOOT_CFLAGS="$RPM_OPT_FLAGS" $PARALLEL
+#%endif
+make info
+%if 0%{?building_libjava:1}
+make -C %{GCCDIST}/libstdc++-v3/doc doc-html-doxygen
+%endif
+%if 0%{?run_tests:1}
+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
+%endif
+%endif
+
+%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}
+%if 0%{?building_libffi:1}
+make -C %{GCCDIST}/libffi install DESTDIR=$RPM_BUILD_ROOT
+%else
+%if 0%{?building_libjava:1}
+make -C %{GCCDIST}/libjava install DESTDIR=$RPM_BUILD_ROOT
+make -C gcc java.install-man DESTDIR=$RPM_BUILD_ROOT
+make -C gcc java.install-common DESTDIR=$RPM_BUILD_ROOT
+make -C gcc install-common DESTDIR=$RPM_BUILD_ROOT COMPILERS='jc1$(exeext) jvgenmain$(exeext)'
+# copy the libstdc++ API reference
+cp -r %{GCCDIST}/libstdc++-v3/doc/doxygen/html ../libstdc++-v3/doc/html/api
+# install-common also installs collect2, gcov and the g++ and gfortran driver
+%if %{build_cp}
+rm $RPM_BUILD_ROOT%{_prefix}/bin/g++%{binsuffix}
+%endif
+%if %{build_fortran}
+rm $RPM_BUILD_ROOT%{_prefix}/bin/gfortran%{binsuffix}
+%endif
+rm $RPM_BUILD_ROOT%{_prefix}/bin/gcov%{binsuffix}
+rm $RPM_BUILD_ROOT%{libsubdir}/collect2
+%else
+make install DESTDIR=$RPM_BUILD_ROOT
+%if %{build_java}
+make -C gcc java.uninstall DESTDIR=$RPM_BUILD_ROOT
+make -C gcc java.install-info DESTDIR=$RPM_BUILD_ROOT
+rm $RPM_BUILD_ROOT%{_prefix}/bin/jcf-dump%{binsuffix}
+rm $RPM_BUILD_ROOT%{_mandir}/man1/jcf-dump%{binsuffix}.1
+rm $RPM_BUILD_ROOT%{libsubdir}/jc1
+rm $RPM_BUILD_ROOT%{libsubdir}/jvgenmain
+%endif
+%endif
+%endif
+
+# Remove libffi installed files if we did not want to build it
+%if !0%{?building_libffi:1}
+rm -f $RPM_BUILD_ROOT%{mainlibdir}/libffi.*
+%if %{biarch}
+  rm -f $RPM_BUILD_ROOT%{mainlibdirbi}/libffi.*
+%endif
+rm -f $RPM_BUILD_ROOT%{libsubdir}/include/ffi.h
+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 \
+    libgomp libstdc++ libsupc++ libgcj-tools libgij libgo \
+    libasan libatomic libitm libtsan libcilkrts liblsan libubsan libvtv; do
+  rm -f $RPM_BUILD_ROOT%{versmainlibdir}/$lib.la
+%if %{biarch}
+  rm -f $RPM_BUILD_ROOT%{versmainlibdirbi}/$lib.la
+%endif
+done
+
+mkdir -p $RPM_BUILD_ROOT%{_libdir}
+%if %{biarch}
+%if %{build_primary_64bit}
+mkdir -p $RPM_BUILD_ROOT%{_prefix}/lib
+%else
+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
+dir_ml=
+cxxconfig="`find %{GCCDIST}/libstdc++-v3/include -name c++config.h`"
+for i in `find %{GCCDIST}/[36]*/libstdc++-v3/include -name c++config.h 2>/dev/null`; do
+  if ! diff -up $cxxconfig $i; then
+    file_32=x
+    file_64=x
+    case $i in
+      %{GCCDIST}/32/*)
+        file_32=$i
+        file_64=$cxxconfig
+        dir_ml=32
+       ;;
+      %{GCCDIST}/64/*)
+        file_32=$cxxconfig
+       file_64=$i
+        dir_ml=64
+       ;;
+    esac
+    if ! ( test -f "$file_32" && test -f "$file_64" ); then
+      echo "Urgs?"
+      exit 1
+    fi
+    
+    cat > $RPM_BUILD_ROOT%{_prefix}/include/c++/%{gcc_dir_version}/%{GCCDIST}/bits/c++config.h <<EOF
+#ifndef _CPP_CPPCONFIG_WRAPPER
+#define _CPP_CPPCONFIG_WRAPPER 1
+#include <bits/wordsize.h>
+#if __WORDSIZE == 32
+`cat $file_32`
+#else
+`cat $file_64`
+#endif
+#endif
+EOF
+    break
+  fi
+done
+rm -rf $RPM_BUILD_ROOT%{_prefix}/include/c++/%{gcc_dir_version}/%{GCCDIST}/[36]*
+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
+
+# move shared libs from versionspecific dir to main libdir
+for libname in \
+%if 0%{?building_libjava:1}
+  libgcj libgij libgcj-tools \
+%else
+%if %{build_fortran}
+  libgfortran \
+%ifarch %quadmath_arch
+  libquadmath \
+%endif
+%endif
+%if %{build_objc}
+  libobjc \
+%endif
+%if %{build_cp}
+  libstdc++ \
+%endif
+%if %{build_go}
+  libgo \
+%endif
+  libgomp \
+%ifarch %atomic_arch
+  libatomic \
+%endif
+%ifarch %itm_arch
+  libitm \
+%endif
+%ifarch %asan_arch
+  libasan \
+%endif
+%ifarch %tsan_arch
+  libtsan \
+%endif
+%ifarch %cilkrts_arch
+  libcilkrts \
+%endif
+%ifarch %lsan_arch
+  liblsan \
+%endif
+%ifarch %ubsan_arch
+  libubsan \
+%endif
+%ifarch %vtv_arch
+  libvtv \
+%endif
+%endif
+    ; do
+  for lib in `find $RPM_BUILD_ROOT%{versmainlibdir} -maxdepth 1 -name $libname.so.*`; do
+    mv $lib $RPM_BUILD_ROOT%{mainlibdir}/
+  done
+  ln -sf %{mainlibdir}/`readlink $RPM_BUILD_ROOT%{versmainlibdir}/$libname.so | sed -e 's/\(.*\.so\.[^\.]*\).*/\1/'`  \
+         $RPM_BUILD_ROOT%{versmainlibdir}/$libname.so
+%if %{biarch}
+  if test -d $RPM_BUILD_ROOT%{versmainlibdirbi}; then
+    for lib in `find $RPM_BUILD_ROOT%{versmainlibdirbi} -maxdepth 1 -name "$libname.so.*"`; do
+      mv $lib $RPM_BUILD_ROOT%{mainlibdirbi}/
+    done
+    ln -sf %{mainlibdirbi}/`readlink $RPM_BUILD_ROOT%{versmainlibdirbi}/$libname.so | sed -e 's/\(.*\.so\.[^\.]*\).*/\1/'`  \
+         $RPM_BUILD_ROOT%{versmainlibdirbi}/$libname.so
+  fi
+%endif
+done
+# FIXME, tsan and lsan are not multilib
+%ifarch %tsan_arch
+%if %{biarch}
+rm -f $RPM_BUILD_ROOT%{versmainlibdirbi}/libtsan.so
+%endif
+%endif
+%ifarch %lsan_arch
+%if %{biarch}
+rm -f $RPM_BUILD_ROOT%{versmainlibdirbi}/liblsan.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
+# place so ldconfig does not complain
+mkdir -p $RPM_BUILD_ROOT%{_datadir}/gdb/auto-load%{mainlibdir}
+mv $RPM_BUILD_ROOT%{mainlibdir}/libstdc++.so.*-gdb.py $RPM_BUILD_ROOT%{_datadir}/gdb/auto-load%{mainlibdir}/
+sed -i -e '/^libdir/s/\/gcc\/%{GCCDIST}\/%{gcc_dir_version}//g' $RPM_BUILD_ROOT%{_datadir}/gdb/auto-load%{mainlibdir}/libstdc++.so.*-gdb.py
+%if %{biarch}
+  if test -d $RPM_BUILD_ROOT%{versmainlibdirbi}; then
+    mkdir -p $RPM_BUILD_ROOT%{_datadir}/gdb/auto-load%{mainlibdirbi}
+    mv $RPM_BUILD_ROOT%{mainlibdirbi}/libstdc++.so.*-gdb.py $RPM_BUILD_ROOT%{_datadir}/gdb/auto-load%{mainlibdirbi}/
+    sed -i -e '/^libdir/s/\/gcc\/%{GCCDIST}\/%{gcc_dir_version}//g' $RPM_BUILD_ROOT%{_datadir}/gdb/auto-load%{mainlibdirbi}/libstdc++.so.*-gdb.py
+  fi
+%endif
+%endif
+%endif
+%if 0%{?building_libjava:1}
+# libgcj_bc is special as the .so file is actually a different
+# library as the library refered to by the SONAME which should
+# be a simple link to our libgcj.
+for lib in `find $RPM_BUILD_ROOT%{versmainlibdir} -maxdepth 1 -name libgcj_bc.so.*`; do
+  rm $lib
+done
+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.%{libgcj_sover} $RPM_BUILD_ROOT%{mainlibdirbi}/libgcj_bc.so.%{libgcj_bc_sover}
+%endif
+mv $RPM_BUILD_ROOT%{libsubdir}/pkgconfig $RPM_BUILD_ROOT%{_libdir}/
+%endif
+
+# LIBJAVA-DELETE-BEGIN
+# Move libgcc_s around
+%ifarch aarch64
+if test -L $RPM_BUILD_ROOT/lib64/libgcc_s.so; then
+  rm -f $RPM_BUILD_ROOT/lib64/libgcc_s.so
+  ln -sf /lib64/libgcc_s.so.%{libgcc_s} $RPM_BUILD_ROOT%{versmainlibdir}/libgcc_s.so
+else
+  mv $RPM_BUILD_ROOT/lib64/libgcc_s.so $RPM_BUILD_ROOT%{versmainlibdir}/
+fi
+chmod a+x $RPM_BUILD_ROOT/lib64/libgcc_s.so.%{libgcc_s}
+%else
+if test -L $RPM_BUILD_ROOT/%{_lib}/libgcc_s.so; then
+  rm -f $RPM_BUILD_ROOT/%{_lib}/libgcc_s.so
+  ln -sf /%{_lib}/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/%{_lib}/libgcc_s.so.%{libgcc_s}
+%endif
+
+%if %{biarch}
+%if %{build_primary_64bit}
+if test -L $RPM_BUILD_ROOT/lib/libgcc_s.so; then
+  rm -f $RPM_BUILD_ROOT/lib/libgcc_s.so
+  ln -sf /lib/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/lib/libgcc_s.so.%{libgcc_s}
+%else
+# 32-bit biarch systems
+if test -L $RPM_BUILD_ROOT/lib64/libgcc_s.so; then
+  rm -f $RPM_BUILD_ROOT/lib64/libgcc_s.so
+  ln -sf /lib64/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/lib64/libgcc_s.so.%{libgcc_s}
+%endif
+%endif
+
+# LIBJAVA-DELETE-END
+# LIBFFI-DELETE-END
+
+%if %{build_ada}
+mv $RPM_BUILD_ROOT%{libsubdir}/adalib/lib*-*.so $RPM_BUILD_ROOT%{_libdir}
+ln -sf %{_libdir}/libgnarl%{binsuffix}.so $RPM_BUILD_ROOT%{libsubdir}/adalib/libgnarl.so
+ln -sf %{_libdir}/libgnat%{binsuffix}.so $RPM_BUILD_ROOT%{libsubdir}/adalib/libgnat.so
+chmod a+x $RPM_BUILD_ROOT%{_libdir}/libgna*-*.so
+%if %{biarch}
+mv $RPM_BUILD_ROOT%{versmainlibdirbi}/adalib/lib*-*.so $RPM_BUILD_ROOT%{mainlibdirbi}/
+ln -sf %{mainlibdirbi}/libgnarl%{binsuffix}.so $RPM_BUILD_ROOT%{versmainlibdirbi}/adalib/libgnarl.so
+ln -sf %{mainlibdirbi}/libgnat%{binsuffix}.so $RPM_BUILD_ROOT%{versmainlibdirbi}/adalib/libgnarl.so
+chmod a+x $RPM_BUILD_ROOT%{mainlibdirbi}/libgna*-*.so
+%endif
+%endif
+
+rm -f $RPM_BUILD_ROOT%{_prefix}/bin/c++%{binsuffix}
+
+# Remove some crap from the .la files:
+for l in `find $RPM_BUILD_ROOT -name '*.la'`; do
+  echo "changing $l"
+# -e '/^dependency_libs/s|%{libsubdir}/\([^.]*\)\.la |%{_libdir}/\1\.la |g'
+  sed -e '/^dependency_libs/s| -L%{_builddir}/[^ ]*||g' \
+      -e '/^dependency_libs/s| -L/usr/%{GCCDIST}/bin||g' \
+      -e '/^dependency_libs/s|-lm \(-lm \)*|-lm |' \
+      -e '/^dependency_libs/s|-L[^ ]* ||g' \
+%if %{biarch}
+%if %{build_primary_64bit}
+      -e '/^libdir/s|%{_libdir}/32|%{_prefix}/lib|' \
+      -e '/^libdir/s|lib64/\.\./||' \
+%else
+      -e '/^libdir/s|%{_libdir}/64|%{_prefix}/lib64|' \
+%endif
+%endif
+      < $l  > $l.new
+  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++ \
+  -regex ".*/\(org\|gcj\|gnu\|java\|javax\)" -prune \
+  -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
+#rm -rf $RPM_BUILD_ROOT%{_libdir}/pkgconfig/libgcj%{binsuffix}.pc
+rm -f $RPM_BUILD_ROOT%{libsubdir}/include-fixed/zutil.h
+rm -f $RPM_BUILD_ROOT%{libsubdir}/include-fixed/linux/a.out.h
+rm -f $RPM_BUILD_ROOT%{libsubdir}/include-fixed/asm-generic/socket.h
+# no plugins
+rm -rf $RPM_BUILD_ROOT%{libsubdir}/plugin
+rm -f  $RPM_BUILD_ROOT%{_infodir}/dir
+
+
+%if 0%{?building_libjava:1}
+# gcj -static doesn't work properly anyway, unless using --whole-archive
+# let's save the space instead.
+find $RPM_BUILD_ROOT -name libgcj.a \
+       -o -name libgcj-tools.a \
+       -o -name libgij.a \
+       -o -name libjvm.a \
+       -o -name libgcj_bc.a \
+  | xargs rm -f
+
+find $RPM_BUILD_ROOT -name libgcj.spec | xargs \
+  sed -i -e 's/lib: /&%%{static:%%eJava programs cannot be linked statically}/'
+
+# security files have broken install locations, also they cause conflicts
+# between libgcj versions.  Simply delete them here, libgcj will use its
+# defaults in this case (which is what these files contain anyway).
+rm -f $RPM_BUILD_ROOT%{libsubdir}/logging.properties
+rm -r $RPM_BUILD_ROOT%{libsubdir}/security
+%endif
+
+%if 0%{?building_libffi:1}
+# Move libffi headers, remove empty libffi libtool file
+mkdir -p $RPM_BUILD_ROOT%{_prefix}/include
+mv $RPM_BUILD_ROOT%{libsubdir}/include/ffitarget.h $RPM_BUILD_ROOT%{_prefix}/include/
+mv $RPM_BUILD_ROOT%{libsubdir}/include/ffi.h $RPM_BUILD_ROOT%{_prefix}/include/
+rm -f $RPM_BUILD_ROOT%{mainlibdir}/libffi.la
+%if %{biarch}
+rm -f $RPM_BUILD_ROOT%{mainlibdirbi}/libffi.la
+%endif
+# Generate a simple pkg-config file
+mkdir -p $RPM_BUILD_ROOT%{_libdir}/pkgconfig
+echo -e 'Name: libffi\nVersion: 3.0.9\nDescription: libffi\nLibs: -lffi' > $RPM_BUILD_ROOT%{_libdir}/pkgconfig/libffi.pc
+%endif
+
+%if %{build_java}
+%if !%{build_libjava}
+rm $RPM_BUILD_ROOT%{_mandir}/man1/jv-convert%{binsuffix}.1
+rm $RPM_BUILD_ROOT%{_mandir}/man1/gcj-dbtool%{binsuffix}.1
+rm $RPM_BUILD_ROOT%{_mandir}/man1/gij%{binsuffix}.1
+rm $RPM_BUILD_ROOT%{_mandir}/man1/grmic%{binsuffix}.1
+rm $RPM_BUILD_ROOT%{_mandir}/man1/gc-analyze%{binsuffix}.1
+rm $RPM_BUILD_ROOT%{_mandir}/man1/aot-compile%{binsuffix}.1
+rm $RPM_BUILD_ROOT%{_mandir}/man1/rebuild-gcj-db%{binsuffix}.1
+%endif
+rm -f $RPM_BUILD_ROOT%{_datadir}/gcc%{binsuffix}/python/libjava/aotcompile.py
+rm -f $RPM_BUILD_ROOT%{_datadir}/gcc%{binsuffix}/python/libjava/classfile.py
+%endif
+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 %{biarch}
+%if %{build_primary_64bit}
+rm -f $RPM_BUILD_ROOT%{_prefix}/lib/libiberty.a
+%else
+rm -f $RPM_BUILD_ROOT%{_prefix}/lib64/libiberty.a
+%endif
+%endif
+rm -f $RPM_BUILD_ROOT%{libsubdir}/liblto_plugin.a
+rm -f $RPM_BUILD_ROOT%{libsubdir}/liblto_plugin.la
+%if %{build_go}
+# gccgo.info isn't properly versioned
+rm $RPM_BUILD_ROOT%{_infodir}/gccgo.info*
+%endif
+
+# 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*
+# Remove stale manpages for binaries we do not build
+rm $RPM_BUILD_ROOT%{_mandir}/man1/gjdoc%{binsuffix}.1
+# For building the java frontend we need to copy the ecj jar
+mkdir -p $RPM_BUILD_ROOT%{libsubdir}
+cp $RPM_SOURCE_DIR/ecj.jar $RPM_BUILD_ROOT%{libsubdir}
+%else
+# 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
+%endif
+%endif
+%if %{build_ada}
+mv $RPM_BUILD_ROOT%{_infodir}/gnat-style.info $RPM_BUILD_ROOT%{_infodir}/gnat-style%{binsuffix}.info
+mv $RPM_BUILD_ROOT%{_infodir}/gnat_rm.info $RPM_BUILD_ROOT%{_infodir}/gnat_rm%{binsuffix}.info
+mv $RPM_BUILD_ROOT%{_infodir}/gnat_ugn.info $RPM_BUILD_ROOT%{_infodir}/gnat_ugn%{binsuffix}.info
+%endif
+%endif
+
+# LIBJAVA-DELETE-BEGIN
+cd ..
+%find_lang cpplib%{binsuffix}
+%find_lang gcc%{binsuffix}
+%find_lang libstdc++
+cat cpplib%{binsuffix}.lang gcc%{binsuffix}.lang > gcc@base_ver@-locale.lang
+
+%post info
+%install_info --info-dir=%{_infodir} %{_infodir}/cpp%{binsuffix}.info.gz
+%install_info --info-dir=%{_infodir} %{_infodir}/cppinternals%{binsuffix}.info.gz
+%install_info --info-dir=%{_infodir} %{_infodir}/gcc%{binsuffix}.info.gz
+%install_info --info-dir=%{_infodir} %{_infodir}/gccint%{binsuffix}.info.gz
+%install_info --info-dir=%{_infodir} %{_infodir}/gccinstall%{binsuffix}.info.gz
+%install_info --info-dir=%{_infodir} %{_infodir}/libgomp%{binsuffix}.info.gz
+%if %{build_fortran} 
+%install_info --info-dir=%{_infodir} %{_infodir}/gfortran%{binsuffix}.info.gz
+%ifarch %quadmath_arch
+%install_info --info-dir=%{_infodir} %{_infodir}/libquadmath%{binsuffix}.info.gz
+%endif
+%endif
+%if %{build_java}
+%install_info --info-dir=%{_infodir} %{_infodir}/gcj%{binsuffix}.info.gz
+%endif
+%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} %{_infodir}/gnat_ugn%{binsuffix}.info.gz
+%endif
+
+%postun info
+%install_info_delete --info-dir=%{_infodir} %{_infodir}/cpp%{binsuffix}.info.gz
+%install_info_delete --info-dir=%{_infodir} %{_infodir}/cppinternals%{binsuffix}.info.gz
+%install_info_delete --info-dir=%{_infodir} %{_infodir}/gcc%{binsuffix}.info.gz
+%install_info_delete --info-dir=%{_infodir} %{_infodir}/gccint%{binsuffix}.info.gz
+%install_info_delete --info-dir=%{_infodir} %{_infodir}/gccinstall%{binsuffix}.info.gz
+%install_info_delete --info-dir=%{_infodir} %{_infodir}/libgomp%{binsuffix}.info.gz
+%if %{build_fortran}
+%install_info_delete --info-dir=%{_infodir} %{_infodir}/gfortran%{binsuffix}.info.gz
+%ifarch %quadmath_arch
+%install_info_delete --info-dir=%{_infodir} %{_infodir}/libquadmath%{binsuffix}.info.gz
+%endif
+%endif
+%if %{build_java}
+%install_info_delete --info-dir=%{_infodir} %{_infodir}/gcj%{binsuffix}.info.gz
+%endif
+%if %{build_ada}
+%install_info_delete --info-dir=%{_infodir} %{_infodir}/gnat-style%{binsuffix}.info.gz
+%install_info_delete --info-dir=%{_infodir} %{_infodir}/gnat_rm%{binsuffix}.info.gz
+%install_info_delete --info-dir=%{_infodir} %{_infodir}/gnat_ugn%{binsuffix}.info.gz
+%endif
+
+%files
+%defattr(-,root,root)
+%dir %{_libdir}/gcc
+%dir %{_libdir}/gcc/%{GCCDIST}
+%dir %{libsubdir}
+%dir %{libsubdir}/include
+%dir %{libsubdir}/include-fixed
+%if %{biarch}
+%if %{build_primary_64bit}
+%dir %{libsubdir}/32
+%else
+%dir %{libsubdir}/64
+%endif
+%endif
+%{_prefix}/bin/gcc%{binsuffix}
+%{_prefix}/bin/gcov%{binsuffix}
+%{_prefix}/bin/gcc-ar%{binsuffix}
+%{_prefix}/bin/gcc-nm%{binsuffix}
+%{_prefix}/bin/gcc-ranlib%{binsuffix}
+%{libsubdir}/collect2
+%{libsubdir}/lto1
+%{libsubdir}/lto-wrapper
+%{libsubdir}/liblto_plugin.so*
+%{libsubdir}/include-fixed/README
+%{libsubdir}/include-fixed/limits.h
+%{libsubdir}/include-fixed/syslimits.h
+%{libsubdir}/include/omp.h
+%{libsubdir}/include/float.h
+%{libsubdir}/include/iso646.h
+%{libsubdir}/include/stdarg.h
+%{libsubdir}/include/stdbool.h
+%{libsubdir}/include/stdfix.h
+%{libsubdir}/include/stddef.h
+%{libsubdir}/include/unwind.h
+%{libsubdir}/include/varargs.h
+%{libsubdir}/include/stdint.h
+%{libsubdir}/include/stdint-gcc.h
+%{libsubdir}/include/stdnoreturn.h
+%{libsubdir}/include/stdalign.h
+%{libsubdir}/include/stdatomic.h
+%ifarch %sparc
+%{libsubdir}/include/visintrin.h
+%endif
+%ifarch ppc ppc64 ppc64le
+%{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
+%{libsubdir}/include/htmintrin.h
+%{libsubdir}/include/htmxlintrin.h
+%endif
+%ifarch s390 s390x
+%{libsubdir}/include/htmintrin.h
+%{libsubdir}/include/htmxlintrin.h
+%{libsubdir}/include/s390intrin.h
+%endif
+%ifarch ia64
+%{libsubdir}/include/ia64intrin.h
+%endif
+%ifarch %arm aarch64
+%{libsubdir}/include/arm_neon.h
+%endif
+%ifarch %arm
+%{libsubdir}/include/mmintrin.h
+%{libsubdir}/include/arm_neon.h
+%{libsubdir}/include/unwind-arm-common.h
+%{libsubdir}/include/arm_acle.h
+%endif
+%ifarch %ix86 x86_64
+%{libsubdir}/include/cross-stdarg.h
+%{libsubdir}/include/cpuid.h
+%{libsubdir}/include/mm3dnow.h
+%{libsubdir}/include/mmintrin.h
+%{libsubdir}/include/ammintrin.h
+%{libsubdir}/include/bmmintrin.h
+%{libsubdir}/include/emmintrin.h
+%{libsubdir}/include/immintrin.h
+%{libsubdir}/include/avxintrin.h
+%{libsubdir}/include/pmmintrin.h
+%{libsubdir}/include/xmmintrin.h
+%{libsubdir}/include/tmmintrin.h
+%{libsubdir}/include/nmmintrin.h
+%{libsubdir}/include/smmintrin.h
+%{libsubdir}/include/wmmintrin.h
+%{libsubdir}/include/x86intrin.h
+%{libsubdir}/include/ia32intrin.h
+%{libsubdir}/include/mm_malloc.h
+%{libsubdir}/include/fma4intrin.h
+%{libsubdir}/include/xopintrin.h
+%{libsubdir}/include/lwpintrin.h
+%{libsubdir}/include/popcntintrin.h
+%{libsubdir}/include/bmiintrin.h
+%{libsubdir}/include/tbmintrin.h
+%{libsubdir}/include/avx2intrin.h
+%{libsubdir}/include/bmi2intrin.h
+%{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
+%{libsubdir}/include/avx512cdintrin.h
+%{libsubdir}/include/avx512erintrin.h
+%{libsubdir}/include/avx512fintrin.h
+%{libsubdir}/include/avx512pfintrin.h
+%{libsubdir}/include/shaintrin.h
+%endif
+%ifarch m68k
+%{libsubdir}/include/math-68881.h
+%endif
+%ifarch %cilkrts_arch
+%{libsubdir}/include/cilk
+%endif
+%versmainlib *crt*.o
+%versmainlib libgcc*.a
+%versmainlib libgcov.a
+%versmainlib libgcc_s*.so
+%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
+%ifarch %cilkrts_arch
+%versmainlib libcilkrts.so
+%versmainlib libcilkrts.a
+%versmainlib libcilkrts.spec
+%endif
+%ifarch %lsan_arch
+%versmainlib liblsan.so
+%versmainlib liblsan.a
+%endif
+%ifarch %ubsan_arch
+%versmainlib libubsan.so
+%versmainlib libubsan.a
+%endif
+%ifarch %asan_arch %ubsan_arch %tsan_arch %lsan_arch
+%versmainlib libsanitizer.spec
+%endif
+%ifarch %vtv_arch
+%versmainlib libvtv.so
+%versmainlib libvtv.a
+%endif
+%doc %{_mandir}/man1/gcc%{binsuffix}.1.gz
+%doc %{_mandir}/man1/gcov%{binsuffix}.1.gz
+
+%if %{separate_biarch}
+%files -n gcc@base_ver@%{separate_biarch_suffix}
+%defattr(-,root,root)
+%versbiarchlib *crt*.o
+%versbiarchlib libgcc*.a
+%versbiarchlib libgcov.a
+%versbiarchlib libgcc_s*.so
+%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
+%ifarch %ubsan_arch
+%versbiarchlib libubsan.a
+%versbiarchlib libubsan.so
+%endif
+%ifarch %cilkrts_arch
+%versbiarchlib libcilkrts.a
+%versbiarchlib libcilkrts.so
+%versbiarchlib libcilkrts.spec
+%endif
+%if 0
+%ifarch %tsan_arch
+%versbiarchlib libtsan.a
+%versbiarchlib libtsan.so
+%endif
+%ifarch %lsan_arch
+%versbiarchlib liblsan.a
+%versbiarchlib liblsan.so
+%endif
+%endif
+%ifarch %asan_arch %ubsan_arch %tsan_arch %lsan_arch
+%versbiarchlib libsanitizer.spec
+%endif
+%ifarch %vtv_arch
+%versbiarchlib libvtv.a
+%versbiarchlib libvtv.so
+%endif
+%endif
+
+%files locale -f gcc@base_ver@-locale.lang
+
+%files -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}-locale -f libstdc++.lang
+
+%if %{build_cp}
+%files c++
+%defattr(-,root,root)
+%dir %{_libdir}/gcc
+%dir %{_libdir}/gcc/%{GCCDIST}
+%dir %{libsubdir}
+%{_prefix}/bin/g++%{binsuffix}
+%doc %{_mandir}/man1/g++%{binsuffix}.1.gz
+%{libsubdir}/cc1plus
+
+%files -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}
+%defattr(-,root,root)
+%mainlib libstdc++.so.%{libstdcxx_sover}*
+
+%if %{separate_biarch}
+%files -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}%{separate_biarch_suffix}
+%defattr(-,root,root)
+%biarchlib libstdc++.so.%{libstdcxx_sover}*
+%endif
+
+%files -n libstdc++@base_ver@-devel -f c++-headers
+%defattr(-,root,root)
+%versmainlib libstdc++.a
+%versmainlib libstdc++.so
+%versmainlib libsupc++.a
+%dir %{_datadir}/gdb
+%dir %{_datadir}/gdb/auto-load
+%dir %{_datadir}/gdb/auto-load%{_prefix}
+%dir %{_datadir}/gdb/auto-load/%{mainlibdir}
+%{_datadir}/gdb/auto-load/%{mainlibdir}/libstdc++.so.*-gdb.py
+%{_datadir}/gcc%{binsuffix}
+
+%if %{separate_biarch}
+%files -n libstdc++@base_ver@-devel%{separate_biarch_suffix}
+%defattr(-,root,root)
+%versbiarchlib libstdc++.a
+%versbiarchlib libstdc++.so
+%versbiarchlib libsupc++.a
+%dir %{_datadir}/gdb/auto-load/%{mainlibdirbi}
+%{_datadir}/gdb/auto-load/%{mainlibdirbi}/libstdc++.so.*-gdb.py
+%endif
+%endif
+
+%files -n libgcc_s%{libgcc_s}%{libgcc_s_suffix}
+%defattr(-,root,root)
+/%{_lib}/libgcc_s.so.%{libgcc_s}
+%if %{biarch}
+%if %{build_primary_64bit}
+%if !%{separate_bi32}
+/lib/libgcc_s.so.%{libgcc_s}
+%endif
+%else
+%if !%{separate_bi64}
+/lib64/libgcc_s.so.%{libgcc_s}
+%endif
+%endif
+%endif
+
+%if %{separate_bi64}
+%files -n libgcc_s%{libgcc_s}%{libgcc_s_suffix}-64bit
+%defattr(-,root,root)
+/lib64/libgcc_s.so.%{libgcc_s}
+%endif
+
+%if %{separate_bi32}
+%files -n libgcc_s%{libgcc_s}%{libgcc_s_suffix}-32bit
+%defattr(-,root,root)
+/lib/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
+
+
+%ifarch %lsan_arch
+%files -n liblsan%{liblsan_sover}%{liblsan_suffix}
+%defattr(-,root,root)
+%mainlib liblsan.so.%{liblsan_sover}*
+
+%if 0
+%if %{separate_biarch}
+%files -n liblsan%{liblsan_sover}%{liblsan_suffix}%{separate_biarch_suffix}
+%defattr(-,root,root)
+%biarchlib liblsan.so.%{liblsan_sover}*
+%endif
+%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
+
+
+%ifarch %cilkrts_arch
+%files -n libcilkrts%{libcilkrts_sover}%{libcilkrts_suffix}
+%defattr(-,root,root)
+%mainlib libcilkrts.so.%{libcilkrts_sover}*
+
+%if %{separate_biarch}
+%files -n libcilkrts%{libcilkrts_sover}%{libcilkrts_suffix}%{separate_biarch_suffix}
+%defattr(-,root,root)
+%biarchlib libcilkrts.so.%{libcilkrts_sover}*
+%endif
+%endif
+
+
+%ifarch %ubsan_arch
+%files -n libubsan%{libubsan_sover}%{libubsan_suffix}
+%defattr(-,root,root)
+%mainlib libubsan.so.%{libubsan_sover}*
+
+%if %{separate_biarch}
+%files -n libubsan%{libubsan_sover}%{libubsan_suffix}%{separate_biarch_suffix}
+%defattr(-,root,root)
+%biarchlib libubsan.so.%{libubsan_sover}*
+%endif
+%endif
+
+
+%ifarch %vtv_arch
+%files -n libvtv%{libvtv_sover}%{libvtv_suffix}
+%defattr(-,root,root)
+%mainlib libvtv.so.%{libvtv_sover}*
+
+%if %{separate_biarch}
+%files -n libvtv%{libvtv_sover}%{libvtv_suffix}%{separate_biarch_suffix}
+%defattr(-,root,root)
+%biarchlib libvtv.so.%{libvtv_sover}*
+%endif
+%endif
+
+
+%if %{build_fortran}
+%files fortran
+%defattr(-,root,root)
+%dir %{libsubdir}/finclude
+%{_prefix}/bin/gfortran%{binsuffix}
+%{libsubdir}/f951
+%{libsubdir}/finclude/*
+%versmainlib libgfortran.a
+%versmainlib libgfortran.so
+%versmainlib libgfortran.spec
+%versmainlib libgfortranbegin.a
+%versmainlib libcaf_single.a
+%ifarch %quadmath_arch
+%{libsubdir}/include/quadmath.h
+%{libsubdir}/include/quadmath_weak.h
+%versmainlib libquadmath.a
+%versmainlib libquadmath.so
+%endif
+%doc %{_mandir}/man1/gfortran%{binsuffix}.1.gz
+
+%if %{separate_biarch}
+%files fortran%{separate_biarch_suffix}
+%defattr(-,root,root)
+%versbiarchlib libgfortran.a
+%versbiarchlib libgfortran.so
+%versbiarchlib libgfortran.spec
+%versbiarchlib libgfortranbegin.a
+%versbiarchlib libcaf_single.a
+%ifarch %quadmath_arch
+%versbiarchlib libquadmath.a
+%versbiarchlib libquadmath.so
+%endif
+%endif
+
+%files -n libgfortran%{libgfortran_sover}%{libgfortran_suffix}
+%defattr(-,root,root)
+%mainlib libgfortran.so.%{libgfortran_sover}*
+
+%if %{separate_biarch}
+%files -n libgfortran%{libgfortran_sover}%{libgfortran_suffix}%{separate_biarch_suffix}
+%defattr(-,root,root)
+%biarchlib libgfortran.so.%{libgfortran_sover}*
+%endif
+
+%ifarch %quadmath_arch
+%files -n libquadmath%{libquadmath_sover}%{libquadmath_suffix}
+%defattr(-,root,root)
+%mainlib libquadmath.so.%{libquadmath_sover}*
+
+%if %{separate_biarch}
+%files -n libquadmath%{libquadmath_sover}%{libquadmath_suffix}%{separate_biarch_suffix}
+%defattr(-,root,root)
+%biarchlib libquadmath.so.%{libquadmath_sover}*
+%endif
+%endif
+%endif
+
+%files info
+%defattr(-,root,root)
+%doc %{_infodir}/cpp%{binsuffix}.info*.gz
+%doc %{_infodir}/cppinternals%{binsuffix}.info*.gz
+%doc %{_infodir}/gcc%{binsuffix}.info*.gz
+%doc %{_infodir}/gccint%{binsuffix}.info*.gz
+%doc %{_infodir}/gccinstall%{binsuffix}.info*.gz
+%doc %{_infodir}/libgomp%{binsuffix}.info*.gz
+%ifarch %itm_arch
+%doc %{_infodir}/libitm%{binsuffix}.info*.gz
+%endif
+%if %{build_fortran}
+%doc %{_infodir}/gfortran%{binsuffix}.info*.gz
+%ifarch %quadmath_arch
+%doc %{_infodir}/libquadmath%{binsuffix}.info*.gz
+%endif
+%endif
+%if %{build_java}
+%doc %{_infodir}/gcj%{binsuffix}.info*.gz
+%endif
+%if %{build_ada}
+%doc %{_infodir}/gnat-style%{binsuffix}.info*gz
+%doc %{_infodir}/gnat_rm%{binsuffix}.info*gz
+%doc %{_infodir}/gnat_ugn%{binsuffix}.info*gz
+%endif
+
+%files -n cpp@base_ver@
+%defattr(-,root,root)
+%dir %{_libdir}/gcc
+%dir %{_libdir}/gcc/%{GCCDIST}
+%dir %{libsubdir}
+%{_prefix}/bin/cpp%{binsuffix}
+%{libsubdir}/cc1
+#%{libsubdir}/specs
+%doc %{_mandir}/man1/cpp%{binsuffix}.1.gz
+
+%if %{build_objc}
+%files objc
+%defattr(-,root,root)
+%{libsubdir}/cc1obj
+%{libsubdir}/include/objc
+%versmainlib libobjc.a
+%versmainlib libobjc.so
+
+%if %{separate_biarch}
+%files objc%{separate_biarch_suffix}
+%defattr(-,root,root)
+%versbiarchlib libobjc.a
+%versbiarchlib libobjc.so
+%endif
+
+%files -n libobjc%{libobjc_sover}%{libobjc_suffix}
+%defattr(-,root,root)
+%mainlib libobjc.so.%{libobjc_sover}*
+
+%if %{separate_biarch}
+%files -n libobjc%{libobjc_sover}%{libobjc_suffix}%{separate_biarch_suffix}
+%defattr(-,root,root)
+%biarchlib libobjc.so.%{libobjc_sover}*
+%endif
+%endif
+
+
+%if %{build_objcp}
+%files obj-c++
+%defattr(-,root,root)
+%{libsubdir}/cc1objplus
+%endif
+
+
+%if %{build_ada}
+%files ada
+%defattr(-,root,root)
+%dir %{_libdir}/gcc
+%dir %{_libdir}/gcc/%{GCCDIST}
+%dir %{libsubdir}
+%{_prefix}/bin/gnat*
+%dir %{versmainlibdir}/adalib
+%{versmainlibdir}/adainclude
+%{versmainlibdir}/adalib/*.ali
+%{versmainlibdir}/adalib/*.a
+%{versmainlibdir}/adalib/libgnarl.so
+%{versmainlibdir}/adalib/libgnat.so
+%{versmainlibdir}/gnat1
+
+%if %{separate_biarch}
+%files ada%{separate_biarch_suffix}
+%defattr(-,root,root)
+%dir %{versmainlibdirbi}/adalib
+%{versmainlibdirbi}/adainclude
+%{versmainlibdirbi}/adalib/*.ali
+%{versmainlibdirbi}/adalib/*.a
+%{versmainlibdirbi}/adalib/libgnarl.so
+%{versmainlibdirbi}/adalib/libgnat.so
+%endif
+
+%files -n libada@base_ver@
+%defattr(-,root,root)
+%mainlib libgnarl-*.so
+%mainlib libgnat-*.so
+
+%if %{separate_biarch}
+%files -n libada@base_ver@%{separate_biarch_suffix}
+%defattr(-,root,root)
+%biarchlib libgnarl-*.so
+%biarchlib libgnat-*.so
+%endif
+%endif
+# LIBJAVA-DELETE-END
+
+
+%if %{build_java}
+%if 0%{?building_libjava:1}
+%files -n gcc@base_ver@-java
+%defattr(-,root,root)
+%{_prefix}/bin/gcj%{binsuffix}
+%{_prefix}/bin/gcjh%{binsuffix}
+%{_prefix}/bin/gcj-dbtool%{binsuffix}
+%{_prefix}/bin/jcf-dump%{binsuffix}
+%{_prefix}/bin/jv-convert%{binsuffix}
+%{_prefix}/bin/gc-analyze%{binsuffix}
+%{_prefix}/bin/aot-compile%{binsuffix}
+%{_prefix}/bin/rebuild-gcj-db%{binsuffix}
+%{libsubdir}/jc1
+%{libsubdir}/jvgenmain
+%{libsubdir}/ecj.jar
+%{libsubdir}/ecj1
+%doc %{_mandir}/man1/gcj%{binsuffix}.1.gz
+%doc %{_mandir}/man1/gcjh%{binsuffix}.1.gz
+%doc %{_mandir}/man1/gcj-dbtool%{binsuffix}.1.gz
+%doc %{_mandir}/man1/jcf-dump%{binsuffix}.1.gz
+%doc %{_mandir}/man1/jv-convert%{binsuffix}.1.gz
+%doc %{_mandir}/man1/gc-analyze%{binsuffix}.1.gz
+%doc %{_mandir}/man1/aot-compile%{binsuffix}.1.gz
+%doc %{_mandir}/man1/rebuild-gcj-db%{binsuffix}.1.gz
+%endif
+%endif
+
+%if %{build_java}
+%if %{build_libjava}
+%files -n libgcj@base_ver@
+%defattr(-,root,root)
+%dir %{libsubdir}/gcj-%{gcc_dir_version}-%{libgcj_sover}
+%dir %{_libdir}/gcc
+%dir %{_libdir}/gcc/%{GCCDIST}
+%dir %{libsubdir}
+%{libsubdir}/gcj-%{gcc_dir_version}-%{libgcj_sover}/classmap.db
+# We usually do not multilib libjava
+%if %{biarch_libjava}
+%versbiarchlib libgcj.la
+%biarchlib libgcj.so.*
+%biarchlib libgij.so.*
+%biarchlib libgcj-tools.so.*
+%else
+%versmainlib libgcj.la
+%mainlib libgcj.so.*
+%mainlib libgij.so.*
+%mainlib libgcj-tools.so.*
+%endif
+%{libsubdir}/gcj-%{gcc_dir_version}-%{libgcj_sover}/libjvm.la
+%{libsubdir}/gcj-%{gcc_dir_version}-%{libgcj_sover}/libjvm.so
+%{libsubdir}/gcj-%{gcc_dir_version}-%{libgcj_sover}/libjavamath.la
+%{libsubdir}/gcj-%{gcc_dir_version}-%{libgcj_sover}/libjavamath.so
+
+%files -n libgcj_bc%{libgcj_bc_sover}%{libgcj_bc_suffix}
+%defattr(-,root,root)
+%if %{biarch_libjava}
+%biarchlib libgcj_bc.so.%{libgcj_bc_sover}*
+%else
+%mainlib libgcj_bc.so.%{libgcj_bc_sover}*
+%endif
+
+%files -n libgcj@base_ver@-jar
+%defattr(-,root,root)
+%{_prefix}/share/java/libgcj-%{gcc_dir_version}.jar
+%{_prefix}/share/java/libgcj-tools-%{gcc_dir_version}.jar
+
+%files -n libgcj@base_ver@-devel
+%defattr(-,root,root)
+%dir %{_prefix}/include/c++
+%dir %{libsubdir}
+%dir %{libsubdir}/include
+%dir %{gxxinclude}
+%{_libdir}/pkgconfig/libgcj%{binsuffix}.pc
+%{libsubdir}/include/jawt.h
+%{libsubdir}/include/jawt_md.h
+%{libsubdir}/include/jni.h
+%{libsubdir}/include/jni_md.h
+%{libsubdir}/include/jvmpi.h
+%{gxxinclude}/gnu
+%{gxxinclude}/gcj
+%{gxxinclude}/java
+%{gxxinclude}/javax
+%{gxxinclude}/org
+%{gxxinclude}/sun
+%{libsubdir}/include/gcj
+%if %{biarch_libjava}
+%versbiarchlib libgcj.so
+%versbiarchlib libgcj.spec
+%versbiarchlib libgcj-tools.so
+%versbiarchlib libgij.so
+%versbiarchlib libgcj_bc.so
+%else
+%versmainlib libgcj.so
+%versmainlib libgcj.spec
+%versmainlib libgcj-tools.so
+%versmainlib libgij.so
+%versmainlib libgcj_bc.so
+%endif
+
+%files -n gcc@base_ver@-gij
+%defattr(-,root,root)
+%{_prefix}/bin/gij%{binsuffix}
+%{_prefix}/bin/gappletviewer%{binsuffix}
+%{_prefix}/bin/gjar%{binsuffix}
+%{_prefix}/bin/gjarsigner%{binsuffix}
+%{_prefix}/bin/gjavah%{binsuffix}
+%{_prefix}/bin/gkeytool%{binsuffix}
+%{_prefix}/bin/gnative2ascii%{binsuffix}
+%{_prefix}/bin/gorbd%{binsuffix}
+%{_prefix}/bin/grmic%{binsuffix}
+%{_prefix}/bin/grmid%{binsuffix}
+%{_prefix}/bin/grmiregistry%{binsuffix}
+%{_prefix}/bin/gserialver%{binsuffix}
+%{_prefix}/bin/gtnameserv%{binsuffix}
+%doc %{_mandir}/man1/gij%{binsuffix}.1.gz
+%doc %{_mandir}/man1/gappletviewer%{binsuffix}.1.gz
+%doc %{_mandir}/man1/grmic%{binsuffix}.1.gz
+%doc %{_mandir}/man1/grmid%{binsuffix}.1.gz
+%doc %{_mandir}/man1/grmiregistry%{binsuffix}.1.gz
+%doc %{_mandir}/man1/gkeytool%{binsuffix}.1.gz
+%doc %{_mandir}/man1/gjar%{binsuffix}.1.gz
+%doc %{_mandir}/man1/gjarsigner%{binsuffix}.1.gz
+%doc %{_mandir}/man1/gjavah%{binsuffix}.1.gz
+%doc %{_mandir}/man1/gnative2ascii%{binsuffix}.1.gz
+%doc %{_mandir}/man1/gorbd%{binsuffix}.1.gz
+%doc %{_mandir}/man1/gserialver%{binsuffix}.1.gz
+%doc %{_mandir}/man1/gtnameserv%{binsuffix}.1.gz
+%endif
+%endif
+
+%if 0%{?building_libjava:1}
+%files -n libstdc++@base_ver@-doc
+%defattr(-,root,root)
+%doc libstdc++-v3/doc/html
+%endif
+# LIBFFI-DELETE-END
+
+%if %{build_java}
+%if 0%{?building_libffi:1}
+%files -n libffi%{libffi_sover}%{libffi_suffix}
+%defattr(-,root,root)
+%mainlib libffi.so.%{libffi_sover}*
+
+%if %{separate_biarch}
+%files -n libffi%{libffi_sover}%{libffi_suffix}%{separate_biarch_suffix}
+%defattr(-,root,root)
+%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
+%{_prefix}/include/ffitarget.h
+%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}
+%defattr(-,root,root)
+%biarchlib libffi.so
+%biarchlib libffi.a
+%endif
+%endif
+%endif
+
+%if %{build_go}
+%files go
+%{_prefix}/bin/gccgo%{binsuffix}
+%{libsubdir}/go1
+%versmainlib libgo.a
+%versmainlib libgo.so
+%versmainlib libgobegin.a
+%dir %mainlibdir/go
+%dir %mainlibdir/go/%{gcc_dir_version}
+%mainlibdir/go/%{gcc_dir_version}/%{GCCDIST}
+%doc %{_mandir}/man1/gccgo%{binsuffix}.1.gz
+
+%if %{separate_biarch}
+%files go%{separate_biarch_suffix}
+%versbiarchlib libgo.a
+%versbiarchlib libgo.so
+%versbiarchlib libgobegin.a
+%dir %mainlibdirbi/go
+%dir %mainlibdirbi/go/%{gcc_dir_version}
+%mainlibdirbi/go/%{gcc_dir_version}/%{GCCDIST}
+%endif
+
+%files -n libgo%{libgo_sover}%{libgo_suffix}
+%defattr(-,root,root)
+%mainlib libgo.so.%{libgo_sover}*
+
+%if %{separate_biarch}
+%files -n libgo%{libgo_sover}%{libgo_suffix}%{separate_biarch_suffix}
+%defattr(-,root,root)
+%biarchlib libgo.so.%{libgo_sover}*
+%endif
+%endif
+# GCC-TESTSUITE-DELETE-END
+
+%if 0%{?run_tests:1}
+%files -n gcc@base_ver@-testresults
+%defattr(-,root,root)
+%doc testresults/test_summary.txt
+%doc testresults/*.sum
+%doc testresults/*.log
+%endif
+
+
+%changelog
diff --git a/packaging/gcc49-rpmlintrc b/packaging/gcc49-rpmlintrc
new file mode 100644 (file)
index 0000000..d170513
--- /dev/null
@@ -0,0 +1,12 @@
+# This line is mandatory to access the configuration functions
+from Config import *
+
+addFilter ("gcc48.*devel-dependency glibc-devel")
+addFilter ("gcc48-c.*devel-dependency libstdc")
+addFilter ("shlib-policy-name-error")
+addFilter ("libgomp.*shlib-policy-name-error")
+addFilter ("libgcc.*shlib-policy-name-error")
+addFilter ("libgfortran.*shlib-policy-name-error")
+addFilter ("libquadmath.*shlib-policy-name-error")
+addFilter ("libobjc.*shlib-policy-name-error")
+addFilter ("libstdc.*shlib-policy-name-error")
diff --git a/packaging/gcc49-testresults.spec b/packaging/gcc49-testresults.spec
new file mode 100644 (file)
index 0000000..3207657
--- /dev/null
@@ -0,0 +1,707 @@
+%define building_testsuite 0
+%define run_tests 0
+#
+# spec file for package gcc49
+#
+# 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
+
+
+%define build_ada 0
+
+%define quadmath_arch %ix86 x86_64 ia64 aarch64
+%define tsan_arch x86_64
+%define asan_arch x86_64 %ix86 ppc ppc64 %sparc %arm
+%define itm_arch x86_64 %ix86 %arm ppc ppc64 ppc64le s390 s390x %sparc
+%define atomic_arch x86_64 %ix86 %arm aarch64 ppc ppc64 ppc64le s390 s390x %sparc m68k
+%define lsan_arch x86_64
+%define ubsan_arch x86_64 %ix86 ppc ppc64 %arm
+%if 0%{?build_libvtv:1}
+%define vtv_arch x86_64 %ix86
+%endif
+%define cilkrts_arch x86_64 %ix86
+
+# We don't want to build java
+%define build_java 0
+%define build_libjava 0
+
+%define build_cp 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_go !0%{?building_libjava:1}%{?building_libffi:1}
+
+%if %{build_objcp}
+%define build_cp 1
+%define build_objc 1
+%endif
+
+%if %{build_libjava}
+%define build_cp 1
+%endif
+
+# For optional compilers only build C, C++ and Fortran
+%if 0%{?build_optional_compiler_languages:1}
+%define build_ada 0
+%define build_java 0
+%define build_libjava 0
+%define build_objc 0
+%define build_objcp 0
+%define build_go 0
+%endif
+
+# Shared library SONAME versions
+%ifarch hppa
+%define libgcc_s 4
+%else
+%ifarch m68k
+%define libgcc_s 2
+%else
+%define libgcc_s 1
+%endif
+%endif
+%define libgcj_sover %{nil}
+%define libgcj_bc_sover %{nil}
+%define libffi_sover %{nil}
+%define libgomp_sover %{nil}
+%define libstdcxx_sover %{nil}
+%define libobjc_sover %{nil}
+%define libgfortran_sover %{nil}
+%define libquadmath_sover %{nil}
+%define libasan_sover %{nil}
+%define libtsan_sover %{nil}
+%define libatomic_sover %{nil}
+%define libitm_sover %{nil}
+%define libubsan_sover %{nil}
+%define liblsan_sover %{nil}
+%define libvtv_sover %{nil}
+%define libcilkrts_sover %{nil}
+%define libgo_sover %{nil}
+
+# 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:49}%{?product_libs_gcc_ver} != 49
+%define pne 1
+%endif
+%define libgcc_s_suffix %{?pne:-gcc49}
+# libgcj SONAME changes with every GCC version
+%define libgcj_suffix %nil
+%define libgcj_bc_suffix %{?pne:-gcc49}
+%define libffi_suffix %{?pne:-gcc49}
+%define libgomp_suffix %{?pne:-gcc49}
+%define libstdcxx_suffix %{?pne:-gcc49}
+%define libobjc_suffix %{?pne:-gcc49}
+%define libgfortran_suffix %{?pne:-gcc49}
+%define libquadmath_suffix %{?pne:-gcc49}
+%define libasan_suffix %{?pne:-gcc49}
+%define libtsan_suffix %{?pne:-gcc49}
+%define libatomic_suffix %{?pne:-gcc49}
+%define libitm_suffix %{?pne:-gcc49}
+
+
+%define libubsan_suffix %{?pne:-gcc49}
+%define liblsan_suffix %{?pne:-gcc49}
+%define libvtv_suffix %{?pne:-gcc49}
+%define libcilkrts_suffix %{?pne:-gcc49}
+%define libgo_suffix %{?pne:-gcc49}
+
+%define selfconflict() %1
+
+Name: gcc49-testresults
+# With generated files in src we could drop the following
+BuildRequires: bison
+BuildRequires: flex
+BuildRequires: gettext-devel
+BuildRequires: makeinfo
+# until here, but at least renaming and patching info files breaks this
+BuildRequires: gcc-c++
+BuildRequires: glibc-devel
+BuildRequires: mpc-devel
+BuildRequires: mpfr-devel
+BuildRequires: perl
+BuildRequires: zlib-devel
+%ifarch %ix86 x86_64 ppc ppc64 s390 s390x ia64 %sparc hppa %arm aarch64
+BuildRequires: cloog-isl-devel
+BuildRequires: isl-devel
+%endif
+%if %{build_ada}
+%define hostsuffix -4.9
+BuildRequires: gcc49-ada
+%endif
+%if 0%{?building_libjava:1}%{?building_testsuite:1}
+BuildRequires: fastjar
+%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 separate_bi32 0
+%define separate_bi64 0
+%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
+
+# Define two macros to trigger -32bit or -64bit package variants
+%define separate_biarch 0
+%if %{separate_bi32}
+%define separate_biarch 1
+%define separate_biarch_suffix -32bit
+%endif
+%if %{separate_bi64}
+%define separate_biarch 1
+%define separate_biarch_suffix -64bit
+%endif
+
+%ifarch x86_64 ia64 s390x alpha ppc64 sparc64 aarch64
+# 64-bit is primary build target
+%define build_primary_64bit 1
+%else
+%define build_primary_64bit 0
+%endif
+
+%define biarch_libjava 0
+
+%define biarch_targets x86_64 s390x powerpc64 powerpc sparc sparc64
+
+URL:          http://gcc.gnu.org/
+Version: 4.9.1
+Release:      1
+%define gcc_dir_version 4.9
+%define binsuffix -4.9
+
+%if !0%{?building_libjava:1}%{?building_libffi:1}%{?building_testsuite:1}
+Requires: binutils glibc-devel
+Requires: cpp49 = %{version}-%{release}
+Requires: libgcc_s%{libgcc_s} >= %{version}-%{release}
+Requires: libgomp%{libgomp_sover} >= %{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
+%ifarch %cilkrts_arch
+Requires: libcilkrts%{libcilkrts_sover} >= %{version}-%{release}
+%endif
+%ifarch %lsan_arch
+Requires: liblsan%{liblsan_sover} >= %{version}-%{release}
+%endif
+%ifarch %ubsan_arch
+Requires: libubsan%{libubsan_sover} >= %{version}-%{release}
+%endif
+%ifarch %vtv_arch
+Requires: libvtv%{libvtv_sover} >= %{version}-%{release}
+%endif
+Suggests: gcc49-info gcc49-locale
+%endif
+
+BuildRoot:     %{_tmppath}/%{name}-%{version}-build
+Source:                gcc-%{version}.tar.bz2
+Source1:       change_spec
+Source2:       libffi49-rpmlintrc
+Source3:       gcc49-rpmlintrc
+Source4:       ecj.jar
+Source5:       baselibs.conf
+Source6:       libgcj49-rpmlintrc
+
+Summary:      Testsuite results
+License:       SUSE-Public-Domain
+Group:        Development/Languages
+
+%description 
+Results from running the gcc and target library testsuites.
+
+
+
+
+# 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} == "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
+%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "aarch64"
+%define CONFIGURE_TARGET aarch64-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} == "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/;")
+%endif
+%define biarch %(case " %{biarch_targets} " in (*" %{TARGET_ARCH} "*) echo 1;; (*) echo 0;; esac)
+
+%define HOST_ARCH %(echo %{_host_cpu} | sed -e "s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;")
+%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}
+
+
+# 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
+
+%define mainlibdir %{_libdir}
+%define mainlibdirbi32 %{_prefix}/lib
+%define mainlibdirbi64 %{_prefix}/lib64
+%if %{build_primary_64bit}
+%define mainlibdirbi %{mainlibdirbi32}
+%else
+%define mainlibdirbi %{mainlibdirbi64}
+%endif
+
+
+# Now define a few macros that make it easy to package libs and
+# related files just to the right package, without caring for the
+# 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
+%define mainlib() %{mainlibdir}/%1\
+%{nil}
+%define biarchlib() %{nil}
+%if %{biarch}
+%if !%{separate_biarch}
+%define mainlib() %{mainlibdir}/%1\
+%{mainlibdirbi}/%1\
+%{nil}
+%else
+%define biarchlib() %{mainlibdirbi}/%1\
+%{nil}
+%endif
+%endif
+
+%define versmainlib() %{versmainlibdir}/%1\
+%{nil}
+%define versbiarchlib() %{nil}
+%if %{biarch}
+%if !%{separate_biarch}
+%define versmainlib() %{versmainlibdir}/%1\
+%{versmainlibdirbi}/%1\
+%{nil}
+%else
+%define versbiarchlib() %{versmainlibdirbi}/%1\
+%{nil}
+%endif
+%endif
+
+
+
+%prep
+%setup -q -n gcc-%{version}
+
+# 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
+contrib/gcc_update --touch
+# Avoid fucking up testsuite results with Java and indirect dispatch
+export LD_ASNEEDED=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 possible and remove
+# the 'prerelease' tagging in this case
+if test `cat gcc/DEV-PHASE` == "prerelease"; then
+  if test `cat gcc/BASE-VER | cut -d '.' -f 3` != "0"; then
+    : > gcc/DEV-PHASE
+  fi
+  ( 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
+%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'`
+%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
+%if %{build_go}
+languages=$languages,go
+%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
+
+%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 \
+%if "%{TARGET_ARCH}" == "armv7l" || "%{TARGET_ARCH}" == "armv7hl"
+# temporary workaround for a miscompilation of hash functions in java code
+GCJ_EXTRA_FLAGS="-marm"
+%endif
+
+export RPM_OPT_FLAGS="`echo $RPM_OPT_FLAGS | sed -e "s/ -Wp,-D_FORTIFY_SOURCE=2 / /g"`"
+
+CFLAGS="$RPM_OPT_FLAGS" CXXFLAGS="$RPM_OPT_FLAGS" XCFLAGS="$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 \
+%if 0%{!?build_libvtv:1}
+       --disable-libvtv \
+%endif
+       --disable-plugin \
+       --with-bugurl="http://bugs.tizen.org/" \
+       --with-pkgversion="Tizen" \
+%if !%{build_fortran}
+       --disable-libquadmath \
+%endif
+%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
+       --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 \
+       --enable-linux-futex \
+       --program-suffix=%{binsuffix} \
+%if 0%{!?gcc_target_arch:1}
+%ifarch ia64
+       --with-system-libunwind \
+%else
+       --without-system-libunwind \
+%endif
+%endif
+%if 0%{?gcc_target_arch:1}
+       --program-prefix=%{gcc_target_arch}- \
+       --target=%{gcc_target_arch} \
+       --disable-nls \
+%if 0%{?sysroot:1}
+       --with-sysroot=%sysroot \
+%else
+       --with-sysroot=%{_prefix}/%{gcc_target_arch} \
+%endif
+%if 0%{?build_sysroot:1}
+       --with-build-sysroot=%{build_sysroot} \
+%else
+%if 0%{?sysroot:1}
+       --with-build-sysroot=%{sysroot} \
+%else
+       --with-build-sysroot=%{_prefix}/%{gcc_target_arch} \
+%endif
+%endif
+%if 0%{?canonical_target:1}
+       --with-build-time-tools=/usr/%{canonical_target}-tizen-linux%{?canonical_target_abi:%canonical_target_abi}/bin \
+%endif
+%if "%{TARGET_ARCH}" == "spu"
+       --with-gxx-include-dir=%sysroot/include/c++/%{gcc_dir_version} \
+       --with-newlib \
+%endif
+%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}" == "armv7l" 
+       --with-arch=armv7-a \
+       --with-tune=cortex-a8 \
+       --with-float=softfp \
+       --with-fpu=vfpv3 \
+       --with-mode=thumb \
+       --disable-sjlj-exceptions \
+%endif
+%if "%{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}" == "aarch64"
+       --with-arch=armv8-a \
+       --disable-sjlj-exceptions \
+%endif
+%if "%{TARGET_ARCH}" == "powerpc" || "%{TARGET_ARCH}" == "powerpc64"
+%if "%{TARGET_ARCH}" == "powerpc"
+        --with-cpu=default32 \
+%endif
+%if "%{TARGET_ARCH}" == "powerpc64le"
+       --with-cpu=power7 \
+%else
+       --with-cpu-64=power4 \
+%endif
+       --enable-secureplt \
+       --with-long-double-128 \
+%if "%{TARGET_ARCH}" == "powerpc64le"
+       --disable-multilib \
+%endif
+%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 \
+%endif
+%if "%{TARGET_ARCH}" == "x86_64"
+       --with-arch-32=i586 \
+       --with-tune=generic \
+       --disable-multilib \
+%endif
+%if "%{TARGET_ARCH}" == "s390"
+        --with-tune=zEC12 --with-arch=z196 \
+       --with-long-double-128 \
+       --enable-decimal-float \
+%endif
+%if "%{TARGET_ARCH}" == "s390x"
+        --with-tune=zEC12 --with-arch=z196 \
+       --with-long-double-128 \
+       --enable-decimal-float \
+%endif
+%if "%{TARGET_ARCH}" == "m68k"
+       --disable-multilib \
+%endif
+       --build=%{GCCDIST} \
+       --host=%{GCCDIST}
+
+
+%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 and matters
+#%ifarch x86_64 ppc64le s390x
+#make profiledbootstrap STAGE1_CFLAGS="$STAGE1_FLAGS" BOOT_CFLAGS="$RPM_OPT_FLAGS" $PARALLEL
+#%else
+make STAGE1_CFLAGS="$STAGE1_FLAGS" BOOT_CFLAGS="$RPM_OPT_FLAGS" $PARALLEL
+#%endif
+make info
+%if 0%{?building_libjava:1}
+make -C %{GCCDIST}/libstdc++-v3/doc doc-html-doxygen
+%endif
+%if 0%{?run_tests:1}
+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
+%endif
+%endif
+
+%install
+export NO_BRP_CHECK_BYTECODE_VERSION=true
+cd obj-%{GCCDIST}
+%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
+
+%if 0%{?run_tests:1}
+%files 
+%defattr(-,root,root)
+%doc testresults/test_summary.txt
+%doc testresults/*.sum
+%doc testresults/*.log
+%endif
+
+
+%changelog
diff --git a/packaging/gcc49.spec b/packaging/gcc49.spec
new file mode 100644 (file)
index 0000000..182909a
--- /dev/null
@@ -0,0 +1,3120 @@
+#
+# spec file for package gcc49
+#
+# 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
+
+
+%define build_ada 0
+
+%define quadmath_arch %ix86 x86_64 ia64 aarch64
+%define tsan_arch x86_64
+%define asan_arch x86_64 %ix86 ppc ppc64 %sparc %arm
+%define itm_arch x86_64 %ix86 %arm ppc ppc64 ppc64le s390 s390x %sparc
+%define atomic_arch x86_64 %ix86 %arm aarch64 ppc ppc64 ppc64le s390 s390x %sparc m68k
+%define lsan_arch x86_64
+%define ubsan_arch x86_64 %ix86 ppc ppc64 %arm
+%if 0%{?build_libvtv:1}
+%define vtv_arch x86_64 %ix86
+%endif
+%define cilkrts_arch x86_64 %ix86
+
+# We don't want to build java
+%define build_java 0
+%define build_libjava 0
+
+%define build_cp 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_go !0%{?building_libjava:1}%{?building_libffi:1}
+
+%if %{build_objcp}
+%define build_cp 1
+%define build_objc 1
+%endif
+
+%if %{build_libjava}
+%define build_cp 1
+%endif
+
+# For optional compilers only build C, C++ and Fortran
+%if 0%{?build_optional_compiler_languages:1}
+%define build_ada 0
+%define build_java 0
+%define build_libjava 0
+%define build_objc 0
+%define build_objcp 0
+%define build_go 0
+%endif
+
+# Shared library SONAME versions
+%ifarch hppa
+%define libgcc_s 4
+%else
+%ifarch m68k
+%define libgcc_s 2
+%else
+%define libgcc_s 1
+%endif
+%endif
+%define libgcj_sover %{nil}
+%define libgcj_bc_sover %{nil}
+%define libffi_sover %{nil}
+%define libgomp_sover %{nil}
+%define libstdcxx_sover %{nil}
+%define libobjc_sover %{nil}
+%define libgfortran_sover %{nil}
+%define libquadmath_sover %{nil}
+%define libasan_sover %{nil}
+%define libtsan_sover %{nil}
+%define libatomic_sover %{nil}
+%define libitm_sover %{nil}
+%define libubsan_sover %{nil}
+%define liblsan_sover %{nil}
+%define libvtv_sover %{nil}
+%define libcilkrts_sover %{nil}
+%define libgo_sover %{nil}
+
+# 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:49}%{?product_libs_gcc_ver} != 49
+%define pne 1
+%endif
+%define libgcc_s_suffix %{?pne:-gcc49}
+# libgcj SONAME changes with every GCC version
+%define libgcj_suffix %nil
+%define libgcj_bc_suffix %{?pne:-gcc49}
+%define libffi_suffix %{?pne:-gcc49}
+%define libgomp_suffix %{?pne:-gcc49}
+%define libstdcxx_suffix %{?pne:-gcc49}
+%define libobjc_suffix %{?pne:-gcc49}
+%define libgfortran_suffix %{?pne:-gcc49}
+%define libquadmath_suffix %{?pne:-gcc49}
+%define libasan_suffix %{?pne:-gcc49}
+%define libtsan_suffix %{?pne:-gcc49}
+%define libatomic_suffix %{?pne:-gcc49}
+%define libitm_suffix %{?pne:-gcc49}
+
+
+%define libubsan_suffix %{?pne:-gcc49}
+%define liblsan_suffix %{?pne:-gcc49}
+%define libvtv_suffix %{?pne:-gcc49}
+%define libcilkrts_suffix %{?pne:-gcc49}
+%define libgo_suffix %{?pne:-gcc49}
+
+%define selfconflict() %1
+
+Name:         gcc49
+# With generated files in src we could drop the following
+BuildRequires: bison
+BuildRequires: flex
+BuildRequires: gettext-devel
+BuildRequires: makeinfo
+# until here, but at least renaming and patching info files breaks this
+BuildRequires: gcc-c++
+BuildRequires: glibc-devel
+BuildRequires: mpc-devel
+BuildRequires: mpfr-devel
+BuildRequires: perl
+BuildRequires: zlib-devel
+%ifarch %ix86 x86_64 ppc ppc64 s390 s390x ia64 %sparc hppa %arm aarch64
+BuildRequires: cloog-isl-devel
+BuildRequires: isl-devel
+%endif
+%if %{build_ada}
+%define hostsuffix -4.9
+BuildRequires: gcc49-ada
+%endif
+%if 0%{?building_libjava:1}%{?building_testsuite:1}
+BuildRequires: fastjar
+%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 separate_bi32 0
+%define separate_bi64 0
+%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
+
+# Define two macros to trigger -32bit or -64bit package variants
+%define separate_biarch 0
+%if %{separate_bi32}
+%define separate_biarch 1
+%define separate_biarch_suffix -32bit
+%endif
+%if %{separate_bi64}
+%define separate_biarch 1
+%define separate_biarch_suffix -64bit
+%endif
+
+%ifarch x86_64 ia64 s390x alpha ppc64 sparc64 aarch64
+# 64-bit is primary build target
+%define build_primary_64bit 1
+%else
+%define build_primary_64bit 0
+%endif
+
+%define biarch_libjava 0
+
+%define biarch_targets x86_64 s390x powerpc64 powerpc sparc sparc64
+
+URL:          http://gcc.gnu.org/
+Version: 4.9.1
+Release:      1
+%define gcc_dir_version 4.9
+%define binsuffix -4.9
+
+%if !0%{?building_libjava:1}%{?building_libffi:1}%{?building_testsuite:1}
+Requires: binutils glibc-devel
+Requires: cpp49 = %{version}-%{release}
+Requires: libgcc_s%{libgcc_s} >= %{version}-%{release}
+Requires: libgomp%{libgomp_sover} >= %{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
+%ifarch %cilkrts_arch
+Requires: libcilkrts%{libcilkrts_sover} >= %{version}-%{release}
+%endif
+%ifarch %lsan_arch
+Requires: liblsan%{liblsan_sover} >= %{version}-%{release}
+%endif
+%ifarch %ubsan_arch
+Requires: libubsan%{libubsan_sover} >= %{version}-%{release}
+%endif
+%ifarch %vtv_arch
+Requires: libvtv%{libvtv_sover} >= %{version}-%{release}
+%endif
+Suggests: gcc49-info gcc49-locale
+%endif
+
+BuildRoot:     %{_tmppath}/%{name}-%{version}-build
+Source:                gcc-%{version}.tar.bz2
+Source1:       change_spec
+Source2:       libffi49-rpmlintrc
+Source3:       gcc49-rpmlintrc
+Source4:       ecj.jar
+Source5:       baselibs.conf
+Source6:       libgcj49-rpmlintrc
+
+Group:          Development/Building
+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 gcc49-32bit
+Summary:      The GNU C Compiler 32bit support
+Group:          Development/Building
+Requires: gcc49 = %{version}-%{release}
+Requires: libgcc_s%{libgcc_s}-32bit >= %{version}-%{release}
+Requires: libgomp%{libgomp_sover}-32bit >= %{version}-%{release}
+%ifarch %asan_arch
+Requires: libasan%{libasan_sover}-32bit >= %{version}-%{release}
+%endif
+%ifarch %tsan_arch
+# tsan on x86_64 has no multilib
+%ifarch x86_64
+%else
+Requires: libtsan%{libtsan_sover}-32bit >= %{version}-%{release}
+%endif
+%endif
+%ifarch %atomic_arch
+Requires: libatomic%{libatomic_sover}-32bit >= %{version}-%{release}
+%endif
+%ifarch %itm_arch
+Requires: libitm%{libitm_sover}-32bit >= %{version}-%{release}
+%endif
+%ifarch %cilkrts_arch
+Requires: libcilkrts%{libcilkrts_sover}-32bit >= %{version}-%{release}
+%endif
+# lsan on x86_64 has no multilib
+%ifarch x86_64
+%else
+%ifarch %lsan_arch
+Requires: liblsan%{liblsan_sover} >= %{version}-%{release}
+%endif
+%endif
+%ifarch %ubsan_arch
+Requires: libubsan%{libubsan_sover}-32bit >= %{version}-%{release}
+%endif
+%ifarch %vtv_arch
+Requires: libvtv%{libvtv_sover}-32bit >= %{version}-%{release}
+%endif
+Requires: glibc-devel-32bit
+
+%description -n gcc49-32bit
+This package contains 32bit support for the GNU Compiler Collection.
+
+%package -n gcc49-64bit
+Summary:      The GNU C Compiler 64bit support
+Group:          Development/Building
+Requires: gcc49 = %{version}-%{release}
+Requires: libgcc_s%{libgcc_s}-64bit >= %{version}-%{release}
+Requires: libgomp%{libgomp_sover}-64bit >= %{version}-%{release}
+%ifarch %asan_arch
+Requires: libasan%{libasan_sover}-64bit >= %{version}-%{release}
+%endif
+%ifarch %tsan_arch
+Requires: libtsan%{libtsan_sover}-64bit >= %{version}-%{release}
+%endif
+%ifarch %atomic_arch
+Requires: libatomic%{libatomic_sover}-64bit >= %{version}-%{release}
+%endif
+%ifarch %itm_arch
+Requires: libitm%{libitm_sover}-64bit >= %{version}-%{release}
+%endif
+%ifarch %cilkrts_arch
+Requires: libcilkrts%{libcilkrts_sover}-64bit >= %{version}-%{release}
+%endif
+%ifarch %lsan_arch
+Requires: liblsan%{liblsan_sover}-64bit >= %{version}-%{release}
+%endif
+%ifarch %ubsan_arch
+Requires: libubsan%{libubsan_sover}-64bit >= %{version}-%{release}
+%endif
+%ifarch %vtv_arch
+Requires: libvtv%{libvtv_sover}-64bit >= %{version}-%{release}
+%endif
+Requires: glibc-devel-64bit
+
+%description -n gcc49-64bit
+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/Building
+Requires: gcc49 = %{version}-%{release}
+
+%description locale
+Locale data for the GNU Compiler Collection (GCC) to give error message
+in the current locale.
+
+
+%package c++
+Summary:      The GNU C++ Compiler
+License:        GPL-3.0+
+Group:        Development/Languages
+Requires: gcc49 = %{version}-%{release}
+Requires: libstdc++49-devel = %{version}-%{release}
+
+%description c++
+This package contains the GNU compiler for C++.
+
+%package -n libstdc++49-devel
+Summary:      Include Files and Libraries mandatory for Development
+License:        GPL-3.0-with-GCC-exception
+Group:          Development/Building
+Requires: libstdc++%{libstdcxx_sover} >= %{version}-%{release}
+Requires: glibc-devel
+%ifarch ia64
+Requires: libunwind-devel
+%endif
+
+%description -n libstdc++49-devel
+This package contains all the headers and libraries of the standard C++
+library. It is needed for compiling C++ code.
+%package -n libstdc++49-devel-32bit
+Summary:      Include Files and Libraries mandatory for Development
+License:        GPL-3.0-with-GCC-exception
+Group:          Development/Building
+Requires: libstdc++%{libstdcxx_sover}-32bit >= %{version}-%{release}
+Requires: glibc-devel-32bit
+%ifarch ia64
+Requires: libunwind-devel
+%endif
+
+%description -n libstdc++49-devel-32bit
+This package contains all the headers and libraries of the standard C++
+library. It is needed for compiling C++ code.
+%package -n libstdc++49-devel-64bit
+Summary:      Include Files and Libraries mandatory for Development
+License:        GPL-3.0-with-GCC-exception
+Group:          Development/Building
+Requires: libstdc++%{libstdcxx_sover}-64bit >= %{version}-%{release}
+Requires: glibc-devel-64bit
+%ifarch ia64
+Requires: libunwind-devel
+%endif
+
+%description -n libstdc++49-devel-64bit
+This package contains all the headers and libraries of the standard C++
+library. It is needed for compiling C++ code.
+
+
+%package -n libgcc_s%{libgcc_s}%{libgcc_s_suffix}
+Summary:      C compiler runtime library
+License:        GPL-3.0-with-GCC-exception
+Group:          Development/Building
+Provides:      libgcc_s%{libgcc_s} = %{version}-%{release}
+
+%description -n libgcc_s%{libgcc_s}%{libgcc_s_suffix}
+Libgcc is needed for dynamically linked C programs.
+
+%post -n libgcc_s%{libgcc_s}%{libgcc_s_suffix} -p /sbin/ldconfig
+
+%postun -n libgcc_s%{libgcc_s}%{libgcc_s_suffix} -p /sbin/ldconfig
+%package -n libgcc_s%{libgcc_s}%{libgcc_s_suffix}-32bit
+Summary:      C compiler runtime library
+License:        GPL-3.0-with-GCC-exception
+Group:          Development/Building
+Provides:      libgcc_s%{libgcc_s}-32bit = %{version}-%{release}
+
+%description -n libgcc_s%{libgcc_s}%{libgcc_s_suffix}-32bit
+Libgcc is needed for dynamically linked C programs.
+
+%post -n libgcc_s%{libgcc_s}%{libgcc_s_suffix}-32bit -p /sbin/ldconfig
+
+%postun -n libgcc_s%{libgcc_s}%{libgcc_s_suffix}-32bit -p /sbin/ldconfig
+%package -n libgcc_s%{libgcc_s}%{libgcc_s_suffix}-64bit
+Summary:      C compiler runtime library
+License:        GPL-3.0-with-GCC-exception
+Group:          Development/Building
+Provides:      libgcc_s%{libgcc_s}-64bit = %{version}-%{release}
+
+%description -n libgcc_s%{libgcc_s}%{libgcc_s_suffix}-64bit
+Libgcc is needed for dynamically linked C programs.
+
+%post -n libgcc_s%{libgcc_s}%{libgcc_s_suffix}-64bit -p /sbin/ldconfig
+
+%postun -n libgcc_s%{libgcc_s}%{libgcc_s_suffix}-64bit -p /sbin/ldconfig
+
+%package -n libgomp%{libgomp_sover}%{libgomp_suffix}
+Summary:      The GNU compiler collection OpenMP runtime library
+License:        GPL-3.0-with-GCC-exception
+Group:          Development/Building
+Provides:      libgomp%{libgomp_sover} = %{version}-%{release}
+
+%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 libgomp%{libgomp_sover}%{libgomp_suffix} -p /sbin/ldconfig
+
+%postun -n libgomp%{libgomp_sover}%{libgomp_suffix} -p /sbin/ldconfig
+%package -n libgomp%{libgomp_sover}%{libgomp_suffix}-32bit
+Summary:      The GNU compiler collection OpenMP runtime library
+License:        GPL-3.0-with-GCC-exception
+Group:          Development/Building
+Provides:      libgomp%{libgomp_sover}-32bit = %{version}-%{release}
+
+%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 libgomp%{libgomp_sover}%{libgomp_suffix}-32bit -p /sbin/ldconfig
+
+%postun -n libgomp%{libgomp_sover}%{libgomp_suffix}-32bit -p /sbin/ldconfig
+%package -n libgomp%{libgomp_sover}%{libgomp_suffix}-64bit
+Summary:      The GNU compiler collection OpenMP runtime library
+License:        GPL-3.0-with-GCC-exception
+Group:          Development/Building
+Provides:      libgomp%{libgomp_sover}-64bit = %{version}-%{release}
+
+%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 libgomp%{libgomp_sover}%{libgomp_suffix}-64bit -p /sbin/ldconfig
+
+%postun -n libgomp%{libgomp_sover}%{libgomp_suffix}-64bit -p /sbin/ldconfig
+
+%package -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}
+Summary:      The standard C++ shared library
+License:        GPL-3.0-with-GCC-exception
+Group:          Development/Building
+Suggests:      libstdc++%{libstdcxx_sover}-locale
+Provides:      libstdc++%{libstdcxx_sover} = %{version}-%{release}
+
+%description -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}
+The standard C++ library, needed for dynamically linked C++ programs.
+
+
+%post -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix} -p /sbin/ldconfig
+
+%postun -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix} -p /sbin/ldconfig
+%package -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}-32bit
+Summary:      The standard C++ shared library
+License:        GPL-3.0-with-GCC-exception
+Group:          Development/Building
+Suggests:      libstdc++%{libstdcxx_sover}-locale
+Provides:      libstdc++%{libstdcxx_sover}-32bit = %{version}-%{release}
+
+%description -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}-32bit
+The standard C++ library, needed for dynamically linked C++ programs.
+
+
+%post -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}-32bit -p /sbin/ldconfig
+
+%postun -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}-32bit -p /sbin/ldconfig
+%package -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}-64bit
+Summary:      The standard C++ shared library
+License:        GPL-3.0-with-GCC-exception
+Group:          Development/Building
+Suggests:      libstdc++%{libstdcxx_sover}-locale
+Provides:      libstdc++%{libstdcxx_sover}-64bit = %{version}-%{release}
+
+%description -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}-64bit
+The standard C++ library, needed for dynamically linked C++ programs.
+
+
+%post -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}-64bit -p /sbin/ldconfig
+
+%postun -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}-64bit -p /sbin/ldconfig
+
+%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:          Development/Building
+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:        Development/Building
+BuildArch:    noarch
+
+%description info
+GNU info-pages for the GNU compiler collection covering both user-level
+and internals documentation.
+
+
+%package objc
+Summary:      GNU Objective C Compiler
+License:        GPL-3.0+
+Group:        Development/Languages
+Requires: gcc49 = %{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 objc-32bit
+Summary:      GNU Objective C Compiler
+License:        GPL-3.0+
+Group:        Development/Languages
+Requires: gcc49 = %{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 objc-64bit
+Summary:      GNU Objective C Compiler
+License:        GPL-3.0+
+Group:        Development/Languages
+Requires: gcc49 = %{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 -n libobjc%{libobjc_sover}%{libobjc_suffix}
+Summary:      Library for the GNU Objective C Compiler
+License:        GPL-3.0-with-GCC-exception
+Group:        Development/Building
+Provides:      libobjc%{libobjc_sover} = %{version}-%{release}
+
+%description -n libobjc%{libobjc_sover}%{libobjc_suffix}
+The library for the GNU Objective C compiler.
+
+%post -n libobjc%{libobjc_sover}%{libobjc_suffix} -p /sbin/ldconfig
+
+%postun -n libobjc%{libobjc_sover}%{libobjc_suffix} -p /sbin/ldconfig
+%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/Building
+Provides:      libobjc%{libobjc_sover}-32bit = %{version}-%{release}
+
+%description -n libobjc%{libobjc_sover}%{libobjc_suffix}-32bit
+The library for the GNU Objective C compiler.
+
+%post -n libobjc%{libobjc_sover}%{libobjc_suffix}-32bit -p /sbin/ldconfig
+
+%postun -n libobjc%{libobjc_sover}%{libobjc_suffix}-32bit -p /sbin/ldconfig
+%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/Building
+Provides:      libobjc%{libobjc_sover}-64bit = %{version}-%{release}
+
+%description -n libobjc%{libobjc_sover}%{libobjc_suffix}-64bit
+The library for the GNU Objective C compiler.
+
+%post -n libobjc%{libobjc_sover}%{libobjc_suffix}-64bit -p /sbin/ldconfig
+
+%postun -n libobjc%{libobjc_sover}%{libobjc_suffix}-64bit -p /sbin/ldconfig
+
+%package obj-c++
+Summary:      GNU Objective C++ Compiler
+License:        GPL-3.0+
+Group:        Development/Languages
+Requires: gcc49-objc = %{version}-%{release}
+Requires: gcc49-c++ = %{version}-%{release}
+
+%description obj-c++
+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 -n cpp49
+Summary:      The GCC Preprocessor
+License:        GPL-3.0+
+Group:        Development/Languages
+
+%description -n cpp49
+This Package contains just the preprocessor that is used by the X11
+packages.
+
+
+%package ada
+Summary:      GNU Ada95 Compiler Based on GCC (GNAT)
+License:        GPL-3.0+
+Group:        Development/Languages
+Requires: gcc49 = %{version}-%{release}
+Requires: libada49 = %{version}-%{release}
+
+%description ada
+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 ada-32bit
+Summary:      GNU Ada95 Compiler Based on GCC (GNAT)
+License:        GPL-3.0+
+Group:        Development/Languages
+Requires: gcc49-32bit = %{version}-%{release}
+Requires: libada49-32bit = %{version}-%{release}
+
+%description ada-32bit
+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 ada-64bit
+Summary:      GNU Ada95 Compiler Based on GCC (GNAT)
+License:        GPL-3.0+
+Group:        Development/Languages
+Requires: gcc49-64bit = %{version}-%{release}
+Requires: libada49-64bit = %{version}-%{release}
+
+%description ada-64bit
+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 -n libada49
+Summary:      GNU Ada Runtime Libraries
+License:      GPL-3.0-with-GCC-exception
+Group:        Development/Languages
+Provides: libgnarl-4_9 = %{version}-%{release}
+Provides: libgnat-4_9 = %{version}-%{release}
+
+%description -n libada49
+This package contains the shared libraries required to run programs
+compiled with the GNU Ada compiler (GNAT) if they are compiled to use
+shared libraries. It also contains the shared libraries for the
+Implementation of the Ada Semantic Interface Specification (ASIS), the
+implementation of Distributed Systems Programming (GLADE) and the Posix
+1003.5 Binding (Florist).
+
+%post -n libada49 -p /sbin/ldconfig
+
+%postun -n libada49 -p /sbin/ldconfig
+%package -n libada49-32bit
+Summary:      GNU Ada Runtime Libraries
+License:      GPL-3.0-with-GCC-exception
+Group:        Development/Languages
+Provides: libgnarl-4_9-32bit = %{version}-%{release}
+Provides: libgnat-4_9-32bit = %{version}-%{release}
+
+%description -n libada49-32bit
+This package contains the shared libraries required to run programs
+compiled with the GNU Ada compiler (GNAT) if they are compiled to use
+shared libraries. It also contains the shared libraries for the
+Implementation of the Ada Semantic Interface Specification (ASIS), the
+implementation of Distributed Systems Programming (GLADE) and the Posix
+1003.5 Binding (Florist).
+
+%post -n libada49-32bit -p /sbin/ldconfig
+
+%postun -n libada49-32bit -p /sbin/ldconfig
+%package -n libada49-64bit
+Summary:      GNU Ada Runtime Libraries
+License:      GPL-3.0-with-GCC-exception
+Group:        Development/Languages
+Provides: libgnarl-4_9-64bit = %{version}-%{release}
+Provides: libgnat-4_9-64bit = %{version}-%{release}
+
+%description -n libada49-64bit
+This package contains the shared libraries required to run programs
+compiled with the GNU Ada compiler (GNAT) if they are compiled to use
+shared libraries. It also contains the shared libraries for the
+Implementation of the Ada Semantic Interface Specification (ASIS), the
+implementation of Distributed Systems Programming (GLADE) and the Posix
+1003.5 Binding (Florist).
+
+%post -n libada49-64bit -p /sbin/ldconfig
+
+%postun -n libada49-64bit -p /sbin/ldconfig
+
+%package fortran
+Summary:      The GNU Fortran Compiler and Support Files
+License:        GPL-3.0+
+Group:        Development/Languages
+Requires: gcc49 = %{version}-%{release}
+Requires: libgfortran%{libgfortran_sover} >= %{version}-%{release}
+%ifarch %quadmath_arch
+Requires: libquadmath%{libquadmath_sover} >= %{version}-%{release}
+%endif
+
+%description fortran
+This is the Fortran compiler of the GNU Compiler Collection (GCC).
+%package fortran-32bit
+Summary:      The GNU Fortran Compiler and Support Files
+License:        GPL-3.0+
+Group:        Development/Languages
+Requires: gcc49 = %{version}-%{release}
+Requires: libgfortran%{libgfortran_sover}-32bit >= %{version}-%{release}
+%ifarch %quadmath_arch
+Requires: libquadmath%{libquadmath_sover}-32bit >= %{version}-%{release}
+%endif
+
+%description fortran-32bit
+This is the Fortran compiler of the GNU Compiler Collection (GCC).
+%package fortran-64bit
+Summary:      The GNU Fortran Compiler and Support Files
+License:        GPL-3.0+
+Group:        Development/Languages
+Requires: gcc49 = %{version}-%{release}
+Requires: libgfortran%{libgfortran_sover}-64bit >= %{version}-%{release}
+%ifarch %quadmath_arch
+Requires: libquadmath%{libquadmath_sover}-64bit >= %{version}-%{release}
+%endif
+
+%description fortran-64bit
+This is the Fortran compiler of the GNU Compiler Collection (GCC).
+
+%package -n libgfortran%{libgfortran_sover}%{libgfortran_suffix}
+Summary:      The GNU Fortran Compiler Runtime Library
+License:        GPL-3.0-with-GCC-exception
+Group:        Development/Languages
+%ifarch %quadmath_arch
+Requires: libquadmath%{libquadmath_sover} >= %{version}-%{release}
+%endif
+Provides:      libgfortran%{libgfortran_sover} = %{version}-%{release}
+
+%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 libgfortran%{libgfortran_sover}%{libgfortran_suffix} -p /sbin/ldconfig
+
+%postun -n libgfortran%{libgfortran_sover}%{libgfortran_suffix} -p /sbin/ldconfig
+%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
+%ifarch %quadmath_arch
+Requires: libquadmath%{libquadmath_sover}-32bit >= %{version}-%{release}
+%endif
+Provides:      libgfortran%{libgfortran_sover}-32bit = %{version}-%{release}
+
+%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 libgfortran%{libgfortran_sover}%{libgfortran_suffix}-32bit -p /sbin/ldconfig
+
+%postun -n libgfortran%{libgfortran_sover}%{libgfortran_suffix}-32bit -p /sbin/ldconfig
+%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
+%ifarch %quadmath_arch
+Requires: libquadmath%{libquadmath_sover}-64bit >= %{version}-%{release}
+%endif
+Provides:      libgfortran%{libgfortran_sover}-64bit = %{version}-%{release}
+
+%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 libgfortran%{libgfortran_sover}%{libgfortran_suffix}-64bit -p /sbin/ldconfig
+
+%postun -n libgfortran%{libgfortran_sover}%{libgfortran_suffix}-64bit -p /sbin/ldconfig
+
+%package -n libquadmath%{libquadmath_sover}%{libquadmath_suffix}
+Summary:      The GNU Fortran Compiler Quadmath Runtime Library
+License:        LGPL-2.1
+Group:        Development/Languages
+Provides:      libquadmath%{libquadmath_sover} = %{version}-%{release}
+
+%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 libquadmath%{libquadmath_sover}%{libquadmath_suffix} -p /sbin/ldconfig
+
+%postun -n libquadmath%{libquadmath_sover}%{libquadmath_suffix} -p /sbin/ldconfig
+%package -n libquadmath%{libquadmath_sover}%{libquadmath_suffix}-32bit
+Summary:      The GNU Fortran Compiler Quadmath Runtime Library
+License:        LGPL-2.1
+Group:        Development/Languages
+Provides:      libquadmath%{libquadmath_sover}-32bit = %{version}-%{release}
+
+%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 libquadmath%{libquadmath_sover}%{libquadmath_suffix}-32bit -p /sbin/ldconfig
+
+%postun -n libquadmath%{libquadmath_sover}%{libquadmath_suffix}-32bit -p /sbin/ldconfig
+%package -n libquadmath%{libquadmath_sover}%{libquadmath_suffix}-64bit
+Summary:      The GNU Fortran Compiler Quadmath Runtime Library
+License:        LGPL-2.1
+Group:        Development/Languages
+Provides:      libquadmath%{libquadmath_sover}-64bit = %{version}-%{release}
+
+%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 libquadmath%{libquadmath_sover}%{libquadmath_suffix}-64bit -p /sbin/ldconfig
+
+%postun -n libquadmath%{libquadmath_sover}%{libquadmath_suffix}-64bit -p /sbin/ldconfig
+
+%package -n libitm%{libitm_sover}%{libitm_suffix}
+Summary:      The GNU Compiler Transactional Memory Runtime Library
+License:        MIT
+Group:        Development/Languages
+Provides:      libitm%{libitm_sover} = %{version}-%{release}
+
+%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} -p /sbin/ldconfig
+
+%postun -n libitm%{libitm_sover}%{libitm_suffix} -p /sbin/ldconfig
+%package -n libitm%{libitm_sover}%{libitm_suffix}-32bit
+Summary:      The GNU Compiler Transactional Memory Runtime Library
+License:        MIT
+Group:        Development/Languages
+Provides:      libitm%{libitm_sover}-32bit = %{version}-%{release}
+
+%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 -p /sbin/ldconfig
+
+%postun -n libitm%{libitm_sover}%{libitm_suffix}-32bit -p /sbin/ldconfig
+%package -n libitm%{libitm_sover}%{libitm_suffix}-64bit
+Summary:      The GNU Compiler Transactional Memory Runtime Library
+License:        MIT
+Group:        Development/Languages
+Provides:      libitm%{libitm_sover}-64bit = %{version}-%{release}
+
+%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 -p /sbin/ldconfig
+
+%postun -n libitm%{libitm_sover}%{libitm_suffix}-64bit -p /sbin/ldconfig
+
+%package -n libasan%{libasan_sover}%{libasan_suffix}
+Summary:      The GNU Compiler Address Sanitizer Runtime Library
+License:        MIT
+Group:        Development/Languages
+Provides:      libasan%{libasan_sover} = %{version}-%{release}
+
+%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} -p /sbin/ldconfig
+
+%postun -n libasan%{libasan_sover}%{libasan_suffix} -p /sbin/ldconfig
+%package -n libasan%{libasan_sover}%{libasan_suffix}-32bit
+Summary:      The GNU Compiler Address Sanitizer Runtime Library
+License:        MIT
+Group:        Development/Languages
+Provides:      libasan%{libasan_sover}-32bit = %{version}-%{release}
+
+%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 -p /sbin/ldconfig
+
+%postun -n libasan%{libasan_sover}%{libasan_suffix}-32bit -p /sbin/ldconfig
+%package -n libasan%{libasan_sover}%{libasan_suffix}-64bit
+Summary:      The GNU Compiler Address Sanitizer Runtime Library
+License:        MIT
+Group:        Development/Languages
+Provides:      libasan%{libasan_sover}-64bit = %{version}-%{release}
+
+%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 -p /sbin/ldconfig
+
+%postun -n libasan%{libasan_sover}%{libasan_suffix}-64bit -p /sbin/ldconfig
+
+%package -n libtsan%{libtsan_sover}%{libtsan_suffix}
+Summary:      The GNU Compiler Thread Sanitizer Runtime Library
+License:        MIT
+Group:        Development/Languages
+Provides:      libtsan%{libtsan_sover} = %{version}-%{release}
+
+%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} -p /sbin/ldconfig
+
+%postun -n libtsan%{libtsan_sover}%{libtsan_suffix} -p /sbin/ldconfig
+%package -n libtsan%{libtsan_sover}%{libtsan_suffix}-32bit
+Summary:      The GNU Compiler Thread Sanitizer Runtime Library
+License:        MIT
+Group:        Development/Languages
+Provides:      libtsan%{libtsan_sover}-32bit = %{version}-%{release}
+
+%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 -p /sbin/ldconfig
+
+%postun -n libtsan%{libtsan_sover}%{libtsan_suffix}-32bit -p /sbin/ldconfig
+%package -n libtsan%{libtsan_sover}%{libtsan_suffix}-64bit
+Summary:      The GNU Compiler Thread Sanitizer Runtime Library
+License:        MIT
+Group:        Development/Languages
+Provides:      libtsan%{libtsan_sover}-64bit = %{version}-%{release}
+
+%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 -p /sbin/ldconfig
+
+%postun -n libtsan%{libtsan_sover}%{libtsan_suffix}-64bit -p /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
+Provides:      libatomic%{libatomic_sover} = %{version}-%{release}
+
+%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} -p /sbin/ldconfig
+
+%postun -n libatomic%{libatomic_sover}%{libatomic_suffix} -p /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
+Provides:      libatomic%{libatomic_sover}-32bit = %{version}-%{release}
+
+%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 -p /sbin/ldconfig
+
+%postun -n libatomic%{libatomic_sover}%{libatomic_suffix}-32bit -p /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
+Provides:      libatomic%{libatomic_sover}-64bit = %{version}-%{release}
+
+%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 -p /sbin/ldconfig
+
+%postun -n libatomic%{libatomic_sover}%{libatomic_suffix}-64bit -p /sbin/ldconfig
+
+%package -n libcilkrts%{libcilkrts_sover}%{libcilkrts_suffix}
+Summary:      The GNU Compiler Cilk+ Runtime Library
+License:        MIT
+Group:        Development/Languages
+Provides:      libcilkrts%{libcilkrts_sover} = %{version}-%{release}
+
+%description -n libcilkrts%{libcilkrts_sover}%{libcilkrts_suffix}
+The runtime library needed to run programs compiled with the
+-fcilkplus option of the GNU Compiler Collection (GCC).
+
+%post -n libcilkrts%{libcilkrts_sover}%{libcilkrts_suffix} -p /sbin/ldconfig
+
+%postun -n libcilkrts%{libcilkrts_sover}%{libcilkrts_suffix} -p /sbin/ldconfig
+%package -n libcilkrts%{libcilkrts_sover}%{libcilkrts_suffix}-32bit
+Summary:      The GNU Compiler Cilk+ Runtime Library
+License:        MIT
+Group:        Development/Languages
+Provides:      libcilkrts%{libcilkrts_sover}-32bit = %{version}-%{release}
+
+%description -n libcilkrts%{libcilkrts_sover}%{libcilkrts_suffix}-32bit
+The runtime library needed to run programs compiled with the
+-fcilkplus option of the GNU Compiler Collection (GCC).
+
+%post -n libcilkrts%{libcilkrts_sover}%{libcilkrts_suffix}-32bit -p /sbin/ldconfig
+
+%postun -n libcilkrts%{libcilkrts_sover}%{libcilkrts_suffix}-32bit -p /sbin/ldconfig
+%package -n libcilkrts%{libcilkrts_sover}%{libcilkrts_suffix}-64bit
+Summary:      The GNU Compiler Cilk+ Runtime Library
+License:        MIT
+Group:        Development/Languages
+Provides:      libcilkrts%{libcilkrts_sover}-64bit = %{version}-%{release}
+
+%description -n libcilkrts%{libcilkrts_sover}%{libcilkrts_suffix}-64bit
+The runtime library needed to run programs compiled with the
+-fcilkplus option of the GNU Compiler Collection (GCC).
+
+%post -n libcilkrts%{libcilkrts_sover}%{libcilkrts_suffix}-64bit -p /sbin/ldconfig
+
+%postun -n libcilkrts%{libcilkrts_sover}%{libcilkrts_suffix}-64bit -p /sbin/ldconfig
+
+%package -n liblsan%{liblsan_sover}%{liblsan_suffix}
+Summary:      The GNU Compiler Leak Sanitizer Runtime Library
+License:        MIT
+Group:        Development/Languages
+Provides:      liblsan%{liblsan_sover} = %{version}-%{release}
+
+%description -n liblsan%{liblsan_sover}%{liblsan_suffix}
+The runtime library needed to run programs compiled with the
+-fsanitize=leak option of the GNU Compiler Collection (GCC).
+
+%post -n liblsan%{liblsan_sover}%{liblsan_suffix} -p /sbin/ldconfig
+
+%postun -n liblsan%{liblsan_sover}%{liblsan_suffix} -p /sbin/ldconfig
+%package -n liblsan%{liblsan_sover}%{liblsan_suffix}-32bit
+Summary:      The GNU Compiler Leak Sanitizer Runtime Library
+License:        MIT
+Group:        Development/Languages
+Provides:      liblsan%{liblsan_sover}-32bit = %{version}-%{release}
+
+%description -n liblsan%{liblsan_sover}%{liblsan_suffix}-32bit
+The runtime library needed to run programs compiled with the
+-fsanitize=leak option of the GNU Compiler Collection (GCC).
+
+%post -n liblsan%{liblsan_sover}%{liblsan_suffix}-32bit -p /sbin/ldconfig
+
+%postun -n liblsan%{liblsan_sover}%{liblsan_suffix}-32bit -p /sbin/ldconfig
+%package -n liblsan%{liblsan_sover}%{liblsan_suffix}-64bit
+Summary:      The GNU Compiler Leak Sanitizer Runtime Library
+License:        MIT
+Group:        Development/Languages
+Provides:      liblsan%{liblsan_sover}-64bit = %{version}-%{release}
+
+%description -n liblsan%{liblsan_sover}%{liblsan_suffix}-64bit
+The runtime library needed to run programs compiled with the
+-fsanitize=leak option of the GNU Compiler Collection (GCC).
+
+%post -n liblsan%{liblsan_sover}%{liblsan_suffix}-64bit -p /sbin/ldconfig
+
+%postun -n liblsan%{liblsan_sover}%{liblsan_suffix}-64bit -p /sbin/ldconfig
+
+%package -n libubsan%{libubsan_sover}%{libubsan_suffix}
+Summary:      The GNU Compiler Undefined Sanitizer Runtime Library
+License:        MIT
+Group:        Development/Languages
+Provides:      libubsan%{libubsan_sover} = %{version}-%{release}
+
+%description -n libubsan%{libubsan_sover}%{libubsan_suffix}
+The runtime library needed to run programs compiled with the
+-fsanitize=undefined option of the GNU Compiler Collection (GCC).
+
+%post -n libubsan%{libubsan_sover}%{libubsan_suffix} -p /sbin/ldconfig
+
+%postun -n libubsan%{libubsan_sover}%{libubsan_suffix} -p /sbin/ldconfig
+%package -n libubsan%{libubsan_sover}%{libubsan_suffix}-32bit
+Summary:      The GNU Compiler Undefined Sanitizer Runtime Library
+License:        MIT
+Group:        Development/Languages
+Provides:      libubsan%{libubsan_sover}-32bit = %{version}-%{release}
+
+%description -n libubsan%{libubsan_sover}%{libubsan_suffix}-32bit
+The runtime library needed to run programs compiled with the
+-fsanitize=undefined option of the GNU Compiler Collection (GCC).
+
+%post -n libubsan%{libubsan_sover}%{libubsan_suffix}-32bit -p /sbin/ldconfig
+
+%postun -n libubsan%{libubsan_sover}%{libubsan_suffix}-32bit -p /sbin/ldconfig
+%package -n libubsan%{libubsan_sover}%{libubsan_suffix}-64bit
+Summary:      The GNU Compiler Undefined Sanitizer Runtime Library
+License:        MIT
+Group:        Development/Languages
+Provides:      libubsan%{libubsan_sover}-64bit = %{version}-%{release}
+
+%description -n libubsan%{libubsan_sover}%{libubsan_suffix}-64bit
+The runtime library needed to run programs compiled with the
+-fsanitize=undefined option of the GNU Compiler Collection (GCC).
+
+%post -n libubsan%{libubsan_sover}%{libubsan_suffix}-64bit -p /sbin/ldconfig
+
+%postun -n libubsan%{libubsan_sover}%{libubsan_suffix}-64bit -p /sbin/ldconfig
+
+%package -n libvtv%{libvtv_sover}%{libvtv_suffix}
+Summary:      The GNU Compiler Vtable Verifier Runtime Library
+License:        MIT
+Group:        Development/Languages
+Provides:      libvtv%{libvtv_sover} = %{version}-%{release}
+
+%description -n libvtv%{libvtv_sover}%{libvtv_suffix}
+The runtime library needed to run programs compiled with the
+-fvtable-verify option of the GNU Compiler Collection (GCC).
+
+%post -n libvtv%{libvtv_sover}%{libvtv_suffix} -p /sbin/ldconfig
+
+%postun -n libvtv%{libvtv_sover}%{libvtv_suffix} -p /sbin/ldconfig
+%package -n libvtv%{libvtv_sover}%{libvtv_suffix}-32bit
+Summary:      The GNU Compiler Vtable Verifier Runtime Library
+License:        MIT
+Group:        Development/Languages
+Provides:      libvtv%{libvtv_sover}-32bit = %{version}-%{release}
+
+%description -n libvtv%{libvtv_sover}%{libvtv_suffix}-32bit
+The runtime library needed to run programs compiled with the
+-fvtable-verify option of the GNU Compiler Collection (GCC).
+
+%post -n libvtv%{libvtv_sover}%{libvtv_suffix}-32bit -p /sbin/ldconfig
+
+%postun -n libvtv%{libvtv_sover}%{libvtv_suffix}-32bit -p /sbin/ldconfig
+%package -n libvtv%{libvtv_sover}%{libvtv_suffix}-64bit
+Summary:      The GNU Compiler Vtable Verifier Runtime Library
+License:        MIT
+Group:        Development/Languages
+Provides:      libvtv%{libvtv_sover}-64bit = %{version}-%{release}
+
+%description -n libvtv%{libvtv_sover}%{libvtv_suffix}-64bit
+The runtime library needed to run programs compiled with the
+-fvtable-verify option of the GNU Compiler Collection (GCC).
+
+%post -n libvtv%{libvtv_sover}%{libvtv_suffix}-64bit -p /sbin/ldconfig
+
+%postun -n libvtv%{libvtv_sover}%{libvtv_suffix}-64bit -p /sbin/ldconfig
+
+
+%package -n libgcj49
+Summary:      Java Runtime Library for gcc
+License:      GPL-2.0-with-classpath-exception
+Group:        Development/Building
+Recommends:   libgcj49-jar = %{version}-%{release}
+Provides: libgcj%{libgcj_sover} = %{version}-%{release}
+Provides: libgij%{libgcj_sover} = %{version}-%{release}
+Provides: libgcj-tools%{libgcj_sover} = %{version}-%{release}
+
+%description -n libgcj49
+This library is needed if you want to use the GNU Java compiler, gcj.
+Source code for this package is in gcc.
+
+%post -n libgcj49 -p /sbin/ldconfig
+
+%postun -n libgcj49 -p /sbin/ldconfig
+
+
+%package -n gcc49-java
+Summary:      The GNU Java Compiler
+License:        GPL-3.0+
+Group:        Development/Languages
+Requires: gcc49 = %{version}
+Requires: libgcj49-devel = %{version}-%{release}
+
+%description -n gcc49-java
+The Java compiler from the GCC-tools-suite.
+
+
+%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/Languages
+# 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%{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.%{libgcj_bc_sover}
+%endif
+Provides:      libgcj_bc%{libgcj_bc_sover} = %{version}-%{release}
+
+%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
+libgcj.so changes.
+
+
+%package -n libgcj49-jar
+Summary:      Java runtime library (jar files).
+License:        GPL-2.0-with-classpath-exception
+Group:        Development/Languages
+
+%description -n libgcj49-jar
+These are the jar files that go along with the gcj front end to gcc.
+
+
+%package -n libgcj49-devel
+Summary:      Include Files and Libraries mandatory for Development.
+License:        GPL-2.0-with-classpath-exception
+Group:        Development/Languages
+Requires: libgcj%{libgcj_sover} >= %{version}-%{release}
+Requires: libgcj_bc%{libgcj_bc_sover} >= %{version}-%{release}
+Requires: libgcj49-jar = %{version}-%{release}
+
+%description -n libgcj49-devel
+This package contains all necessary include files and libraries needed
+to develop applications that require these.
+
+
+%package -n gcc49-gij
+Summary:      Java Bytecode Interpreter for gcc
+License:      GPL-2.0-with-classpath-exception
+Group:        Development/Languages
+Requires: libgcj%{libgcj_sover} >= %{version}-%{release}
+
+%description -n gcc49-gij
+This package contains the java bytecode interpreter gij and related tools.
+
+
+%package -n libstdc++49-doc
+Summary:      Documentation for the GNU C++ standard library
+License:        GPL-3.0+
+Group:        Development/Building
+BuildArch:    noarch
+
+%description -n libstdc++49-doc
+Extensive HTML documentation for the GNU C++ standard library.
+
+
+%package -n libffi%{libffi_sover}%{libffi_suffix}
+Summary:      Foreign Function Interface library
+License:        BSD-3-Clause
+Group:        Development/Building
+Provides:      libffi%{libffi_sover} = %{version}-%{release}
+
+%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 libffi%{libffi_sover}%{libffi_suffix} -p /sbin/ldconfig
+
+%postun -n libffi%{libffi_sover}%{libffi_suffix} -p /sbin/ldconfig
+%package -n libffi%{libffi_sover}%{libffi_suffix}-32bit
+Summary:      Foreign Function Interface library
+License:        BSD-3-Clause
+Group:        Development/Building
+Provides:      libffi%{libffi_sover}-32bit = %{version}-%{release}
+
+%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 libffi%{libffi_sover}%{libffi_suffix}-32bit -p /sbin/ldconfig
+
+%postun -n libffi%{libffi_sover}%{libffi_suffix}-32bit -p /sbin/ldconfig
+%package -n libffi%{libffi_sover}%{libffi_suffix}-64bit
+Summary:      Foreign Function Interface library
+License:        BSD-3-Clause
+Group:        Development/Building
+Provides:      libffi%{libffi_sover}-64bit = %{version}-%{release}
+
+%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 libffi%{libffi_sover}%{libffi_suffix}-64bit -p /sbin/ldconfig
+
+%postun -n libffi%{libffi_sover}%{libffi_suffix}-64bit -p /sbin/ldconfig
+
+%package -n libffi49-devel
+Summary:      Foreign Function Interface library development files
+License:        BSD 3-Clause
+Group:        Development/Building
+Requires: libffi%{libffi_sover} >= %{version}-%{release}
+Provides: libffi-devel = %{version}-%{release}
+
+%description -n libffi49-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 -n libffi49-devel-32bit
+Summary:      Foreign Function Interface library development files
+License:        BSD 3-Clause
+Group:        Development/Building
+Requires: libffi%{libffi_sover}-32bit >= %{version}-%{release}
+Provides: libffi-devel-32bit = %{version}-%{release}
+
+%description -n libffi49-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 -n libffi49-devel-64bit
+Summary:      Foreign Function Interface library development files
+License:        BSD 3-Clause
+Group:        Development/Building
+Requires: libffi%{libffi_sover}-64bit >= %{version}-%{release}
+Provides: libffi-devel-64bit = %{version}-%{release}
+
+%description -n libffi49-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 go
+Summary:      GNU Go Compiler
+License:        GPL-3.0+ 
+Group:        Development/Languages
+Requires: gcc49 = %{version}-%{release}
+Requires: libgo%{libgo_sover} >= %{version}-%{release}
+
+%description go
+This package contains a Go compiler and associated development
+files based on the GNU GCC technology.
+%package go-32bit
+Summary:      GNU Go Compiler
+License:        GPL-3.0+ 
+Group:        Development/Languages
+Requires: gcc49-32bit = %{version}-%{release}
+Requires: libgo%{libgo_sover}-32bit >= %{version}-%{release}
+
+%description go-32bit
+This package contains a Go compiler and associated development
+files based on the GNU GCC technology.
+%package go-64bit
+Summary:      GNU Go Compiler
+License:        GPL-3.0+ 
+Group:        Development/Languages
+Requires: gcc49-64bit = %{version}-%{release}
+Requires: libgo%{libgo_sover}-64bit >= %{version}-%{release}
+
+%description go-64bit
+This package contains a Go compiler and associated development
+files based on the GNU GCC technology.
+
+%package -n libgo%{libgo_sover}%{libgo_suffix}
+Summary:      GNU Go compiler runtime library
+License:        BSD-3-Clause
+Group:        Development/Languages
+Provides:      libgo%{libgo_sover} = %{version}-%{release}
+
+%description -n libgo%{libgo_sover}%{libgo_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 libgo%{libgo_sover}%{libgo_suffix} -p /sbin/ldconfig
+
+%postun -n libgo%{libgo_sover}%{libgo_suffix} -p /sbin/ldconfig
+%package -n libgo%{libgo_sover}%{libgo_suffix}-32bit
+Summary:      GNU Go compiler runtime library
+License:        BSD-3-Clause
+Group:        Development/Languages
+Provides:      libgo%{libgo_sover}-32bit = %{version}-%{release}
+
+%description -n libgo%{libgo_sover}%{libgo_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 libgo%{libgo_sover}%{libgo_suffix}-32bit -p /sbin/ldconfig
+
+%postun -n libgo%{libgo_sover}%{libgo_suffix}-32bit -p /sbin/ldconfig
+%package -n libgo%{libgo_sover}%{libgo_suffix}-64bit
+Summary:      GNU Go compiler runtime library
+License:        BSD-3-Clause
+Group:        Development/Languages
+Provides:      libgo%{libgo_sover}-64bit = %{version}-%{release}
+
+%description -n libgo%{libgo_sover}%{libgo_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 libgo%{libgo_sover}%{libgo_suffix}-64bit -p /sbin/ldconfig
+
+%postun -n libgo%{libgo_sover}%{libgo_suffix}-64bit -p /sbin/ldconfig
+
+
+%package -n gcc49-testresults
+Summary:      Testsuite results
+License:       SUSE-Public-Domain
+Group:        Development/Languages
+
+%description -n gcc49-testresults
+Results from running the gcc and target library testsuites.
+
+
+
+
+# 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} == "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
+%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "aarch64"
+%define CONFIGURE_TARGET aarch64-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} == "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/;")
+%endif
+%define biarch %(case " %{biarch_targets} " in (*" %{TARGET_ARCH} "*) echo 1;; (*) echo 0;; esac)
+
+%define HOST_ARCH %(echo %{_host_cpu} | sed -e "s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;")
+%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}
+
+
+# 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
+
+%define mainlibdir %{_libdir}
+%define mainlibdirbi32 %{_prefix}/lib
+%define mainlibdirbi64 %{_prefix}/lib64
+%if %{build_primary_64bit}
+%define mainlibdirbi %{mainlibdirbi32}
+%else
+%define mainlibdirbi %{mainlibdirbi64}
+%endif
+
+
+# Now define a few macros that make it easy to package libs and
+# related files just to the right package, without caring for the
+# 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
+%define mainlib() %{mainlibdir}/%1\
+%{nil}
+%define biarchlib() %{nil}
+%if %{biarch}
+%if !%{separate_biarch}
+%define mainlib() %{mainlibdir}/%1\
+%{mainlibdirbi}/%1\
+%{nil}
+%else
+%define biarchlib() %{mainlibdirbi}/%1\
+%{nil}
+%endif
+%endif
+
+%define versmainlib() %{versmainlibdir}/%1\
+%{nil}
+%define versbiarchlib() %{nil}
+%if %{biarch}
+%if !%{separate_biarch}
+%define versmainlib() %{versmainlibdir}/%1\
+%{versmainlibdirbi}/%1\
+%{nil}
+%else
+%define versbiarchlib() %{versmainlibdirbi}/%1\
+%{nil}
+%endif
+%endif
+
+
+
+%prep
+%setup -q -n gcc-%{version}
+
+# 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
+contrib/gcc_update --touch
+# Avoid fucking up testsuite results with Java and indirect dispatch
+export LD_ASNEEDED=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 possible and remove
+# the 'prerelease' tagging in this case
+if test `cat gcc/DEV-PHASE` == "prerelease"; then
+  if test `cat gcc/BASE-VER | cut -d '.' -f 3` != "0"; then
+    : > gcc/DEV-PHASE
+  fi
+  ( 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
+%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'`
+%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
+%if %{build_go}
+languages=$languages,go
+%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
+
+%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 \
+%if "%{TARGET_ARCH}" == "armv7l" || "%{TARGET_ARCH}" == "armv7hl"
+# temporary workaround for a miscompilation of hash functions in java code
+GCJ_EXTRA_FLAGS="-marm"
+%endif
+
+export RPM_OPT_FLAGS="`echo $RPM_OPT_FLAGS | sed -e "s/ -Wp,-D_FORTIFY_SOURCE=2 / /g"`"
+
+CFLAGS="$RPM_OPT_FLAGS" CXXFLAGS="$RPM_OPT_FLAGS" XCFLAGS="$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 \
+%if 0%{!?build_libvtv:1}
+       --disable-libvtv \
+%endif
+       --disable-plugin \
+       --with-bugurl="http://bugs.tizen.org/" \
+       --with-pkgversion="Tizen" \
+%if !%{build_fortran}
+       --disable-libquadmath \
+%endif
+%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
+       --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 \
+       --enable-linux-futex \
+       --program-suffix=%{binsuffix} \
+%if 0%{!?gcc_target_arch:1}
+%ifarch ia64
+       --with-system-libunwind \
+%else
+       --without-system-libunwind \
+%endif
+%endif
+%if 0%{?gcc_target_arch:1}
+       --program-prefix=%{gcc_target_arch}- \
+       --target=%{gcc_target_arch} \
+       --disable-nls \
+%if 0%{?sysroot:1}
+       --with-sysroot=%sysroot \
+%else
+       --with-sysroot=%{_prefix}/%{gcc_target_arch} \
+%endif
+%if 0%{?build_sysroot:1}
+       --with-build-sysroot=%{build_sysroot} \
+%else
+%if 0%{?sysroot:1}
+       --with-build-sysroot=%{sysroot} \
+%else
+       --with-build-sysroot=%{_prefix}/%{gcc_target_arch} \
+%endif
+%endif
+%if 0%{?canonical_target:1}
+       --with-build-time-tools=/usr/%{canonical_target}-tizen-linux%{?canonical_target_abi:%canonical_target_abi}/bin \
+%endif
+%if "%{TARGET_ARCH}" == "spu"
+       --with-gxx-include-dir=%sysroot/include/c++/%{gcc_dir_version} \
+       --with-newlib \
+%endif
+%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}" == "armv7l" 
+       --with-arch=armv7-a \
+       --with-tune=cortex-a8 \
+       --with-float=softfp \
+       --with-fpu=vfpv3 \
+       --with-mode=thumb \
+       --disable-sjlj-exceptions \
+%endif
+%if "%{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}" == "aarch64"
+       --with-arch=armv8-a \
+       --disable-sjlj-exceptions \
+%endif
+%if "%{TARGET_ARCH}" == "powerpc" || "%{TARGET_ARCH}" == "powerpc64"
+%if "%{TARGET_ARCH}" == "powerpc"
+        --with-cpu=default32 \
+%endif
+%if "%{TARGET_ARCH}" == "powerpc64le"
+       --with-cpu=power7 \
+%else
+       --with-cpu-64=power4 \
+%endif
+       --enable-secureplt \
+       --with-long-double-128 \
+%if "%{TARGET_ARCH}" == "powerpc64le"
+       --disable-multilib \
+%endif
+%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 \
+%endif
+%if "%{TARGET_ARCH}" == "x86_64"
+       --with-arch-32=i586 \
+       --with-tune=generic \
+       --disable-multilib \
+%endif
+%if "%{TARGET_ARCH}" == "s390"
+        --with-tune=zEC12 --with-arch=z196 \
+       --with-long-double-128 \
+       --enable-decimal-float \
+%endif
+%if "%{TARGET_ARCH}" == "s390x"
+        --with-tune=zEC12 --with-arch=z196 \
+       --with-long-double-128 \
+       --enable-decimal-float \
+%endif
+%if "%{TARGET_ARCH}" == "m68k"
+       --disable-multilib \
+%endif
+       --build=%{GCCDIST} \
+       --host=%{GCCDIST}
+
+
+%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 and matters
+#%ifarch x86_64 ppc64le s390x
+#make profiledbootstrap STAGE1_CFLAGS="$STAGE1_FLAGS" BOOT_CFLAGS="$RPM_OPT_FLAGS" $PARALLEL
+#%else
+make STAGE1_CFLAGS="$STAGE1_FLAGS" BOOT_CFLAGS="$RPM_OPT_FLAGS" $PARALLEL
+#%endif
+make info
+%if 0%{?building_libjava:1}
+make -C %{GCCDIST}/libstdc++-v3/doc doc-html-doxygen
+%endif
+%if 0%{?run_tests:1}
+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
+%endif
+%endif
+
+%install
+export NO_BRP_CHECK_BYTECODE_VERSION=true
+cd obj-%{GCCDIST}
+# Work around tail/head -1 changes
+export _POSIX2_VERSION=199209
+export LIBRARY_PATH=$RPM_BUILD_ROOT%{libsubdir}:$RPM_BUILD_ROOT%{mainlibdirbi}
+%if 0%{?building_libffi:1}
+make -C %{GCCDIST}/libffi install DESTDIR=$RPM_BUILD_ROOT
+%else
+%if 0%{?building_libjava:1}
+make -C %{GCCDIST}/libjava install DESTDIR=$RPM_BUILD_ROOT
+make -C gcc java.install-man DESTDIR=$RPM_BUILD_ROOT
+make -C gcc java.install-common DESTDIR=$RPM_BUILD_ROOT
+make -C gcc install-common DESTDIR=$RPM_BUILD_ROOT COMPILERS='jc1$(exeext) jvgenmain$(exeext)'
+# copy the libstdc++ API reference
+cp -r %{GCCDIST}/libstdc++-v3/doc/doxygen/html ../libstdc++-v3/doc/html/api
+# install-common also installs collect2, gcov and the g++ and gfortran driver
+%if %{build_cp}
+rm $RPM_BUILD_ROOT%{_prefix}/bin/g++%{binsuffix}
+%endif
+%if %{build_fortran}
+rm $RPM_BUILD_ROOT%{_prefix}/bin/gfortran%{binsuffix}
+%endif
+rm $RPM_BUILD_ROOT%{_prefix}/bin/gcov%{binsuffix}
+rm $RPM_BUILD_ROOT%{libsubdir}/collect2
+%else
+make install DESTDIR=$RPM_BUILD_ROOT
+%if %{build_java}
+make -C gcc java.uninstall DESTDIR=$RPM_BUILD_ROOT
+make -C gcc java.install-info DESTDIR=$RPM_BUILD_ROOT
+rm $RPM_BUILD_ROOT%{_prefix}/bin/jcf-dump%{binsuffix}
+rm $RPM_BUILD_ROOT%{_mandir}/man1/jcf-dump%{binsuffix}.1
+rm $RPM_BUILD_ROOT%{libsubdir}/jc1
+rm $RPM_BUILD_ROOT%{libsubdir}/jvgenmain
+%endif
+%endif
+%endif
+
+# Remove libffi installed files if we did not want to build it
+%if !0%{?building_libffi:1}
+rm -f $RPM_BUILD_ROOT%{mainlibdir}/libffi.*
+%if %{biarch}
+  rm -f $RPM_BUILD_ROOT%{mainlibdirbi}/libffi.*
+%endif
+rm -f $RPM_BUILD_ROOT%{libsubdir}/include/ffi.h
+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 \
+    libgomp libstdc++ libsupc++ libgcj-tools libgij libgo \
+    libasan libatomic libitm libtsan libcilkrts liblsan libubsan libvtv; do
+  rm -f $RPM_BUILD_ROOT%{versmainlibdir}/$lib.la
+%if %{biarch}
+  rm -f $RPM_BUILD_ROOT%{versmainlibdirbi}/$lib.la
+%endif
+done
+
+mkdir -p $RPM_BUILD_ROOT%{_libdir}
+%if %{biarch}
+%if %{build_primary_64bit}
+mkdir -p $RPM_BUILD_ROOT%{_prefix}/lib
+%else
+mkdir -p $RPM_BUILD_ROOT%{_prefix}/lib64
+%endif
+%endif
+
+%if %{build_cp}
+# Merge multilib c++config.h to allow omitting the duplicate and
+# identical other arch specific headers
+dir_ml=
+cxxconfig="`find %{GCCDIST}/libstdc++-v3/include -name c++config.h`"
+for i in `find %{GCCDIST}/[36]*/libstdc++-v3/include -name c++config.h 2>/dev/null`; do
+  if ! diff -up $cxxconfig $i; then
+    file_32=x
+    file_64=x
+    case $i in
+      %{GCCDIST}/32/*)
+        file_32=$i
+        file_64=$cxxconfig
+        dir_ml=32
+       ;;
+      %{GCCDIST}/64/*)
+        file_32=$cxxconfig
+       file_64=$i
+        dir_ml=64
+       ;;
+    esac
+    if ! ( test -f "$file_32" && test -f "$file_64" ); then
+      echo "Urgs?"
+      exit 1
+    fi
+    
+    cat > $RPM_BUILD_ROOT%{_prefix}/include/c++/%{gcc_dir_version}/%{GCCDIST}/bits/c++config.h <<EOF
+#ifndef _CPP_CPPCONFIG_WRAPPER
+#define _CPP_CPPCONFIG_WRAPPER 1
+#include <bits/wordsize.h>
+#if __WORDSIZE == 32
+`cat $file_32`
+#else
+`cat $file_64`
+#endif
+#endif
+EOF
+    break
+  fi
+done
+rm -rf $RPM_BUILD_ROOT%{_prefix}/include/c++/%{gcc_dir_version}/%{GCCDIST}/[36]*
+if ! test -z "$dir_ml"; then
+  ln -s . $RPM_BUILD_ROOT%{_prefix}/include/c++/%{gcc_dir_version}/%{GCCDIST}/$dir_ml
+fi
+%endif
+
+# move shared libs from versionspecific dir to main libdir
+for libname in \
+%if 0%{?building_libjava:1}
+  libgcj libgij libgcj-tools \
+%else
+%if %{build_fortran}
+  libgfortran \
+%ifarch %quadmath_arch
+  libquadmath \
+%endif
+%endif
+%if %{build_objc}
+  libobjc \
+%endif
+%if %{build_cp}
+  libstdc++ \
+%endif
+%if %{build_go}
+  libgo \
+%endif
+  libgomp \
+%ifarch %atomic_arch
+  libatomic \
+%endif
+%ifarch %itm_arch
+  libitm \
+%endif
+%ifarch %asan_arch
+  libasan \
+%endif
+%ifarch %tsan_arch
+  libtsan \
+%endif
+%ifarch %cilkrts_arch
+  libcilkrts \
+%endif
+%ifarch %lsan_arch
+  liblsan \
+%endif
+%ifarch %ubsan_arch
+  libubsan \
+%endif
+%ifarch %vtv_arch
+  libvtv \
+%endif
+%endif
+    ; do
+  for lib in `find $RPM_BUILD_ROOT%{versmainlibdir} -maxdepth 1 -name $libname.so.*`; do
+    mv $lib $RPM_BUILD_ROOT%{mainlibdir}/
+  done
+  ln -sf %{mainlibdir}/`readlink $RPM_BUILD_ROOT%{versmainlibdir}/$libname.so | sed -e 's/\(.*\.so\.[^\.]*\).*/\1/'`  \
+         $RPM_BUILD_ROOT%{versmainlibdir}/$libname.so
+%if %{biarch}
+  if test -d $RPM_BUILD_ROOT%{versmainlibdirbi}; then
+    for lib in `find $RPM_BUILD_ROOT%{versmainlibdirbi} -maxdepth 1 -name "$libname.so.*"`; do
+      mv $lib $RPM_BUILD_ROOT%{mainlibdirbi}/
+    done
+    ln -sf %{mainlibdirbi}/`readlink $RPM_BUILD_ROOT%{versmainlibdirbi}/$libname.so | sed -e 's/\(.*\.so\.[^\.]*\).*/\1/'`  \
+         $RPM_BUILD_ROOT%{versmainlibdirbi}/$libname.so
+  fi
+%endif
+done
+# FIXME, tsan and lsan are not multilib
+%ifarch %tsan_arch
+%if %{biarch}
+rm -f $RPM_BUILD_ROOT%{versmainlibdirbi}/libtsan.so
+%endif
+%endif
+%ifarch %lsan_arch
+%if %{biarch}
+rm -f $RPM_BUILD_ROOT%{versmainlibdirbi}/liblsan.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
+# place so ldconfig does not complain
+mkdir -p $RPM_BUILD_ROOT%{_datadir}/gdb/auto-load%{mainlibdir}
+mv $RPM_BUILD_ROOT%{mainlibdir}/libstdc++.so.*-gdb.py $RPM_BUILD_ROOT%{_datadir}/gdb/auto-load%{mainlibdir}/
+sed -i -e '/^libdir/s/\/gcc\/%{GCCDIST}\/%{gcc_dir_version}//g' $RPM_BUILD_ROOT%{_datadir}/gdb/auto-load%{mainlibdir}/libstdc++.so.*-gdb.py
+%if %{biarch}
+  if test -d $RPM_BUILD_ROOT%{versmainlibdirbi}; then
+    mkdir -p $RPM_BUILD_ROOT%{_datadir}/gdb/auto-load%{mainlibdirbi}
+    mv $RPM_BUILD_ROOT%{mainlibdirbi}/libstdc++.so.*-gdb.py $RPM_BUILD_ROOT%{_datadir}/gdb/auto-load%{mainlibdirbi}/
+    sed -i -e '/^libdir/s/\/gcc\/%{GCCDIST}\/%{gcc_dir_version}//g' $RPM_BUILD_ROOT%{_datadir}/gdb/auto-load%{mainlibdirbi}/libstdc++.so.*-gdb.py
+  fi
+%endif
+%endif
+%endif
+%if 0%{?building_libjava:1}
+# libgcj_bc is special as the .so file is actually a different
+# library as the library refered to by the SONAME which should
+# be a simple link to our libgcj.
+for lib in `find $RPM_BUILD_ROOT%{versmainlibdir} -maxdepth 1 -name libgcj_bc.so.*`; do
+  rm $lib
+done
+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.%{libgcj_sover} $RPM_BUILD_ROOT%{mainlibdirbi}/libgcj_bc.so.%{libgcj_bc_sover}
+%endif
+mv $RPM_BUILD_ROOT%{libsubdir}/pkgconfig $RPM_BUILD_ROOT%{_libdir}/
+%endif
+
+# Move libgcc_s around
+%ifarch aarch64
+if test -L $RPM_BUILD_ROOT/lib64/libgcc_s.so; then
+  rm -f $RPM_BUILD_ROOT/lib64/libgcc_s.so
+  ln -sf /lib64/libgcc_s.so.%{libgcc_s} $RPM_BUILD_ROOT%{versmainlibdir}/libgcc_s.so
+else
+  mv $RPM_BUILD_ROOT/lib64/libgcc_s.so $RPM_BUILD_ROOT%{versmainlibdir}/
+fi
+chmod a+x $RPM_BUILD_ROOT/lib64/libgcc_s.so.%{libgcc_s}
+%else
+if test -L $RPM_BUILD_ROOT/%{_lib}/libgcc_s.so; then
+  rm -f $RPM_BUILD_ROOT/%{_lib}/libgcc_s.so
+  ln -sf /%{_lib}/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/%{_lib}/libgcc_s.so.%{libgcc_s}
+%endif
+
+%if %{biarch}
+%if %{build_primary_64bit}
+if test -L $RPM_BUILD_ROOT/lib/libgcc_s.so; then
+  rm -f $RPM_BUILD_ROOT/lib/libgcc_s.so
+  ln -sf /lib/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/lib/libgcc_s.so.%{libgcc_s}
+%else
+# 32-bit biarch systems
+if test -L $RPM_BUILD_ROOT/lib64/libgcc_s.so; then
+  rm -f $RPM_BUILD_ROOT/lib64/libgcc_s.so
+  ln -sf /lib64/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/lib64/libgcc_s.so.%{libgcc_s}
+%endif
+%endif
+
+
+%if %{build_ada}
+mv $RPM_BUILD_ROOT%{libsubdir}/adalib/lib*-*.so $RPM_BUILD_ROOT%{_libdir}
+ln -sf %{_libdir}/libgnarl%{binsuffix}.so $RPM_BUILD_ROOT%{libsubdir}/adalib/libgnarl.so
+ln -sf %{_libdir}/libgnat%{binsuffix}.so $RPM_BUILD_ROOT%{libsubdir}/adalib/libgnat.so
+chmod a+x $RPM_BUILD_ROOT%{_libdir}/libgna*-*.so
+%if %{biarch}
+mv $RPM_BUILD_ROOT%{versmainlibdirbi}/adalib/lib*-*.so $RPM_BUILD_ROOT%{mainlibdirbi}/
+ln -sf %{mainlibdirbi}/libgnarl%{binsuffix}.so $RPM_BUILD_ROOT%{versmainlibdirbi}/adalib/libgnarl.so
+ln -sf %{mainlibdirbi}/libgnat%{binsuffix}.so $RPM_BUILD_ROOT%{versmainlibdirbi}/adalib/libgnarl.so
+chmod a+x $RPM_BUILD_ROOT%{mainlibdirbi}/libgna*-*.so
+%endif
+%endif
+
+rm -f $RPM_BUILD_ROOT%{_prefix}/bin/c++%{binsuffix}
+
+# Remove some crap from the .la files:
+for l in `find $RPM_BUILD_ROOT -name '*.la'`; do
+  echo "changing $l"
+# -e '/^dependency_libs/s|%{libsubdir}/\([^.]*\)\.la |%{_libdir}/\1\.la |g'
+  sed -e '/^dependency_libs/s| -L%{_builddir}/[^ ]*||g' \
+      -e '/^dependency_libs/s| -L/usr/%{GCCDIST}/bin||g' \
+      -e '/^dependency_libs/s|-lm \(-lm \)*|-lm |' \
+      -e '/^dependency_libs/s|-L[^ ]* ||g' \
+%if %{biarch}
+%if %{build_primary_64bit}
+      -e '/^libdir/s|%{_libdir}/32|%{_prefix}/lib|' \
+      -e '/^libdir/s|lib64/\.\./||' \
+%else
+      -e '/^libdir/s|%{_libdir}/64|%{_prefix}/lib64|' \
+%endif
+%endif
+      < $l  > $l.new
+  mv $l.new $l
+done
+
+%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
+%if %{build_cp}
+# Find C++ and Java headers
+find $RPM_BUILD_ROOT%{_prefix}/include/c++ \
+  -regex ".*/\(org\|gcj\|gnu\|java\|javax\)" -prune \
+  -o \( -type d -printf "%%%%dir " , \
+        -printf "%{_prefix}/include/c++/%%P\n" \) > ../c++-headers
+%endif
+# 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
+#rm -rf $RPM_BUILD_ROOT%{_libdir}/pkgconfig/libgcj%{binsuffix}.pc
+rm -f $RPM_BUILD_ROOT%{libsubdir}/include-fixed/zutil.h
+rm -f $RPM_BUILD_ROOT%{libsubdir}/include-fixed/linux/a.out.h
+rm -f $RPM_BUILD_ROOT%{libsubdir}/include-fixed/asm-generic/socket.h
+# no plugins
+rm -rf $RPM_BUILD_ROOT%{libsubdir}/plugin
+rm -f  $RPM_BUILD_ROOT%{_infodir}/dir
+
+
+%if 0%{?building_libjava:1}
+# gcj -static doesn't work properly anyway, unless using --whole-archive
+# let's save the space instead.
+find $RPM_BUILD_ROOT -name libgcj.a \
+       -o -name libgcj-tools.a \
+       -o -name libgij.a \
+       -o -name libjvm.a \
+       -o -name libgcj_bc.a \
+  | xargs rm -f
+
+find $RPM_BUILD_ROOT -name libgcj.spec | xargs \
+  sed -i -e 's/lib: /&%%{static:%%eJava programs cannot be linked statically}/'
+
+# security files have broken install locations, also they cause conflicts
+# between libgcj versions.  Simply delete them here, libgcj will use its
+# defaults in this case (which is what these files contain anyway).
+rm -f $RPM_BUILD_ROOT%{libsubdir}/logging.properties
+rm -r $RPM_BUILD_ROOT%{libsubdir}/security
+%endif
+
+%if 0%{?building_libffi:1}
+# Move libffi headers, remove empty libffi libtool file
+mkdir -p $RPM_BUILD_ROOT%{_prefix}/include
+mv $RPM_BUILD_ROOT%{libsubdir}/include/ffitarget.h $RPM_BUILD_ROOT%{_prefix}/include/
+mv $RPM_BUILD_ROOT%{libsubdir}/include/ffi.h $RPM_BUILD_ROOT%{_prefix}/include/
+rm -f $RPM_BUILD_ROOT%{mainlibdir}/libffi.la
+%if %{biarch}
+rm -f $RPM_BUILD_ROOT%{mainlibdirbi}/libffi.la
+%endif
+# Generate a simple pkg-config file
+mkdir -p $RPM_BUILD_ROOT%{_libdir}/pkgconfig
+echo -e 'Name: libffi\nVersion: 3.0.9\nDescription: libffi\nLibs: -lffi' > $RPM_BUILD_ROOT%{_libdir}/pkgconfig/libffi.pc
+%endif
+
+%if %{build_java}
+%if !%{build_libjava}
+rm $RPM_BUILD_ROOT%{_mandir}/man1/jv-convert%{binsuffix}.1
+rm $RPM_BUILD_ROOT%{_mandir}/man1/gcj-dbtool%{binsuffix}.1
+rm $RPM_BUILD_ROOT%{_mandir}/man1/gij%{binsuffix}.1
+rm $RPM_BUILD_ROOT%{_mandir}/man1/grmic%{binsuffix}.1
+rm $RPM_BUILD_ROOT%{_mandir}/man1/gc-analyze%{binsuffix}.1
+rm $RPM_BUILD_ROOT%{_mandir}/man1/aot-compile%{binsuffix}.1
+rm $RPM_BUILD_ROOT%{_mandir}/man1/rebuild-gcj-db%{binsuffix}.1
+%endif
+rm -f $RPM_BUILD_ROOT%{_datadir}/gcc%{binsuffix}/python/libjava/aotcompile.py
+rm -f $RPM_BUILD_ROOT%{_datadir}/gcc%{binsuffix}/python/libjava/classfile.py
+%endif
+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 %{biarch}
+%if %{build_primary_64bit}
+rm -f $RPM_BUILD_ROOT%{_prefix}/lib/libiberty.a
+%else
+rm -f $RPM_BUILD_ROOT%{_prefix}/lib64/libiberty.a
+%endif
+%endif
+rm -f $RPM_BUILD_ROOT%{libsubdir}/liblto_plugin.a
+rm -f $RPM_BUILD_ROOT%{libsubdir}/liblto_plugin.la
+%if %{build_go}
+# gccgo.info isn't properly versioned
+rm $RPM_BUILD_ROOT%{_infodir}/gccgo.info*
+%endif
+
+%if 0%{?building_libjava:1}
+# For building libjava only we need to delete other info docs
+rm $RPM_BUILD_ROOT%{_infodir}/cp-tools.info*
+# Remove stale manpages for binaries we do not build
+rm $RPM_BUILD_ROOT%{_mandir}/man1/gjdoc%{binsuffix}.1
+# For building the java frontend we need to copy the ecj jar
+mkdir -p $RPM_BUILD_ROOT%{libsubdir}
+cp $RPM_SOURCE_DIR/ecj.jar $RPM_BUILD_ROOT%{libsubdir}
+%else
+# 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
+%endif
+%endif
+%if %{build_ada}
+mv $RPM_BUILD_ROOT%{_infodir}/gnat-style.info $RPM_BUILD_ROOT%{_infodir}/gnat-style%{binsuffix}.info
+mv $RPM_BUILD_ROOT%{_infodir}/gnat_rm.info $RPM_BUILD_ROOT%{_infodir}/gnat_rm%{binsuffix}.info
+mv $RPM_BUILD_ROOT%{_infodir}/gnat_ugn.info $RPM_BUILD_ROOT%{_infodir}/gnat_ugn%{binsuffix}.info
+%endif
+%endif
+
+cd ..
+%find_lang cpplib%{binsuffix}
+%find_lang gcc%{binsuffix}
+%find_lang libstdc++
+cat cpplib%{binsuffix}.lang gcc%{binsuffix}.lang > gcc49-locale.lang
+
+%post info
+%install_info --info-dir=%{_infodir} %{_infodir}/cpp%{binsuffix}.info.gz
+%install_info --info-dir=%{_infodir} %{_infodir}/cppinternals%{binsuffix}.info.gz
+%install_info --info-dir=%{_infodir} %{_infodir}/gcc%{binsuffix}.info.gz
+%install_info --info-dir=%{_infodir} %{_infodir}/gccint%{binsuffix}.info.gz
+%install_info --info-dir=%{_infodir} %{_infodir}/gccinstall%{binsuffix}.info.gz
+%install_info --info-dir=%{_infodir} %{_infodir}/libgomp%{binsuffix}.info.gz
+%if %{build_fortran} 
+%install_info --info-dir=%{_infodir} %{_infodir}/gfortran%{binsuffix}.info.gz
+%ifarch %quadmath_arch
+%install_info --info-dir=%{_infodir} %{_infodir}/libquadmath%{binsuffix}.info.gz
+%endif
+%endif
+%if %{build_java}
+%install_info --info-dir=%{_infodir} %{_infodir}/gcj%{binsuffix}.info.gz
+%endif
+%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} %{_infodir}/gnat_ugn%{binsuffix}.info.gz
+%endif
+
+%postun info
+%install_info_delete --info-dir=%{_infodir} %{_infodir}/cpp%{binsuffix}.info.gz
+%install_info_delete --info-dir=%{_infodir} %{_infodir}/cppinternals%{binsuffix}.info.gz
+%install_info_delete --info-dir=%{_infodir} %{_infodir}/gcc%{binsuffix}.info.gz
+%install_info_delete --info-dir=%{_infodir} %{_infodir}/gccint%{binsuffix}.info.gz
+%install_info_delete --info-dir=%{_infodir} %{_infodir}/gccinstall%{binsuffix}.info.gz
+%install_info_delete --info-dir=%{_infodir} %{_infodir}/libgomp%{binsuffix}.info.gz
+%if %{build_fortran}
+%install_info_delete --info-dir=%{_infodir} %{_infodir}/gfortran%{binsuffix}.info.gz
+%ifarch %quadmath_arch
+%install_info_delete --info-dir=%{_infodir} %{_infodir}/libquadmath%{binsuffix}.info.gz
+%endif
+%endif
+%if %{build_java}
+%install_info_delete --info-dir=%{_infodir} %{_infodir}/gcj%{binsuffix}.info.gz
+%endif
+%if %{build_ada}
+%install_info_delete --info-dir=%{_infodir} %{_infodir}/gnat-style%{binsuffix}.info.gz
+%install_info_delete --info-dir=%{_infodir} %{_infodir}/gnat_rm%{binsuffix}.info.gz
+%install_info_delete --info-dir=%{_infodir} %{_infodir}/gnat_ugn%{binsuffix}.info.gz
+%endif
+
+%files
+%defattr(-,root,root)
+%dir %{_libdir}/gcc
+%dir %{_libdir}/gcc/%{GCCDIST}
+%dir %{libsubdir}
+%dir %{libsubdir}/include
+%dir %{libsubdir}/include-fixed
+%if %{biarch}
+%if %{build_primary_64bit}
+%dir %{libsubdir}/32
+%else
+%dir %{libsubdir}/64
+%endif
+%endif
+%{_prefix}/bin/gcc%{binsuffix}
+%{_prefix}/bin/gcov%{binsuffix}
+%{_prefix}/bin/gcc-ar%{binsuffix}
+%{_prefix}/bin/gcc-nm%{binsuffix}
+%{_prefix}/bin/gcc-ranlib%{binsuffix}
+%{libsubdir}/collect2
+%{libsubdir}/lto1
+%{libsubdir}/lto-wrapper
+%{libsubdir}/liblto_plugin.so*
+%{libsubdir}/include-fixed/README
+%{libsubdir}/include-fixed/limits.h
+%{libsubdir}/include-fixed/syslimits.h
+%{libsubdir}/include/omp.h
+%{libsubdir}/include/float.h
+%{libsubdir}/include/iso646.h
+%{libsubdir}/include/stdarg.h
+%{libsubdir}/include/stdbool.h
+%{libsubdir}/include/stdfix.h
+%{libsubdir}/include/stddef.h
+%{libsubdir}/include/unwind.h
+%{libsubdir}/include/varargs.h
+%{libsubdir}/include/stdint.h
+%{libsubdir}/include/stdint-gcc.h
+%{libsubdir}/include/stdnoreturn.h
+%{libsubdir}/include/stdalign.h
+%{libsubdir}/include/stdatomic.h
+%ifarch %sparc
+%{libsubdir}/include/visintrin.h
+%endif
+%ifarch ppc ppc64 ppc64le
+%{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
+%{libsubdir}/include/htmintrin.h
+%{libsubdir}/include/htmxlintrin.h
+%endif
+%ifarch s390 s390x
+%{libsubdir}/include/htmintrin.h
+%{libsubdir}/include/htmxlintrin.h
+%{libsubdir}/include/s390intrin.h
+%endif
+%ifarch ia64
+%{libsubdir}/include/ia64intrin.h
+%endif
+%ifarch %arm aarch64
+%{libsubdir}/include/arm_neon.h
+%endif
+%ifarch %arm
+%{libsubdir}/include/mmintrin.h
+%{libsubdir}/include/arm_neon.h
+%{libsubdir}/include/unwind-arm-common.h
+%{libsubdir}/include/arm_acle.h
+%endif
+%ifarch %ix86 x86_64
+%{libsubdir}/include/cross-stdarg.h
+%{libsubdir}/include/cpuid.h
+%{libsubdir}/include/mm3dnow.h
+%{libsubdir}/include/mmintrin.h
+%{libsubdir}/include/ammintrin.h
+%{libsubdir}/include/bmmintrin.h
+%{libsubdir}/include/emmintrin.h
+%{libsubdir}/include/immintrin.h
+%{libsubdir}/include/avxintrin.h
+%{libsubdir}/include/pmmintrin.h
+%{libsubdir}/include/xmmintrin.h
+%{libsubdir}/include/tmmintrin.h
+%{libsubdir}/include/nmmintrin.h
+%{libsubdir}/include/smmintrin.h
+%{libsubdir}/include/wmmintrin.h
+%{libsubdir}/include/x86intrin.h
+%{libsubdir}/include/ia32intrin.h
+%{libsubdir}/include/mm_malloc.h
+%{libsubdir}/include/fma4intrin.h
+%{libsubdir}/include/xopintrin.h
+%{libsubdir}/include/lwpintrin.h
+%{libsubdir}/include/popcntintrin.h
+%{libsubdir}/include/bmiintrin.h
+%{libsubdir}/include/tbmintrin.h
+%{libsubdir}/include/avx2intrin.h
+%{libsubdir}/include/bmi2intrin.h
+%{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
+%{libsubdir}/include/avx512cdintrin.h
+%{libsubdir}/include/avx512erintrin.h
+%{libsubdir}/include/avx512fintrin.h
+%{libsubdir}/include/avx512pfintrin.h
+%{libsubdir}/include/shaintrin.h
+%endif
+%ifarch m68k
+%{libsubdir}/include/math-68881.h
+%endif
+%ifarch %cilkrts_arch
+%{libsubdir}/include/cilk
+%endif
+%versmainlib *crt*.o
+%versmainlib libgcc*.a
+%versmainlib libgcov.a
+%versmainlib libgcc_s*.so
+%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
+%ifarch %cilkrts_arch
+%versmainlib libcilkrts.so
+%versmainlib libcilkrts.a
+%versmainlib libcilkrts.spec
+%endif
+%ifarch %lsan_arch
+%versmainlib liblsan.so
+%versmainlib liblsan.a
+%endif
+%ifarch %ubsan_arch
+%versmainlib libubsan.so
+%versmainlib libubsan.a
+%endif
+%ifarch %asan_arch %ubsan_arch %tsan_arch %lsan_arch
+%versmainlib libsanitizer.spec
+%endif
+%ifarch %vtv_arch
+%versmainlib libvtv.so
+%versmainlib libvtv.a
+%endif
+%doc %{_mandir}/man1/gcc%{binsuffix}.1.gz
+%doc %{_mandir}/man1/gcov%{binsuffix}.1.gz
+
+%if %{separate_biarch}
+%files -n gcc49%{separate_biarch_suffix}
+%defattr(-,root,root)
+%versbiarchlib *crt*.o
+%versbiarchlib libgcc*.a
+%versbiarchlib libgcov.a
+%versbiarchlib libgcc_s*.so
+%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
+%ifarch %ubsan_arch
+%versbiarchlib libubsan.a
+%versbiarchlib libubsan.so
+%endif
+%ifarch %cilkrts_arch
+%versbiarchlib libcilkrts.a
+%versbiarchlib libcilkrts.so
+%versbiarchlib libcilkrts.spec
+%endif
+%if 0
+%ifarch %tsan_arch
+%versbiarchlib libtsan.a
+%versbiarchlib libtsan.so
+%endif
+%ifarch %lsan_arch
+%versbiarchlib liblsan.a
+%versbiarchlib liblsan.so
+%endif
+%endif
+%ifarch %asan_arch %ubsan_arch %tsan_arch %lsan_arch
+%versbiarchlib libsanitizer.spec
+%endif
+%ifarch %vtv_arch
+%versbiarchlib libvtv.a
+%versbiarchlib libvtv.so
+%endif
+%endif
+
+%files locale -f gcc49-locale.lang
+
+%files -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}-locale -f libstdc++.lang
+
+%if %{build_cp}
+%files c++
+%defattr(-,root,root)
+%dir %{_libdir}/gcc
+%dir %{_libdir}/gcc/%{GCCDIST}
+%dir %{libsubdir}
+%{_prefix}/bin/g++%{binsuffix}
+%doc %{_mandir}/man1/g++%{binsuffix}.1.gz
+%{libsubdir}/cc1plus
+
+%files -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}
+%defattr(-,root,root)
+%mainlib libstdc++.so.%{libstdcxx_sover}*
+
+%if %{separate_biarch}
+%files -n libstdc++%{libstdcxx_sover}%{libstdcxx_suffix}%{separate_biarch_suffix}
+%defattr(-,root,root)
+%biarchlib libstdc++.so.%{libstdcxx_sover}*
+%endif
+
+%files -n libstdc++49-devel -f c++-headers
+%defattr(-,root,root)
+%versmainlib libstdc++.a
+%versmainlib libstdc++.so
+%versmainlib libsupc++.a
+%dir %{_datadir}/gdb
+%dir %{_datadir}/gdb/auto-load
+%dir %{_datadir}/gdb/auto-load%{_prefix}
+%dir %{_datadir}/gdb/auto-load/%{mainlibdir}
+%{_datadir}/gdb/auto-load/%{mainlibdir}/libstdc++.so.*-gdb.py
+%{_datadir}/gcc%{binsuffix}
+
+%if %{separate_biarch}
+%files -n libstdc++49-devel%{separate_biarch_suffix}
+%defattr(-,root,root)
+%versbiarchlib libstdc++.a
+%versbiarchlib libstdc++.so
+%versbiarchlib libsupc++.a
+%dir %{_datadir}/gdb/auto-load/%{mainlibdirbi}
+%{_datadir}/gdb/auto-load/%{mainlibdirbi}/libstdc++.so.*-gdb.py
+%endif
+%endif
+
+%files -n libgcc_s%{libgcc_s}%{libgcc_s_suffix}
+%defattr(-,root,root)
+/%{_lib}/libgcc_s.so.%{libgcc_s}
+%if %{biarch}
+%if %{build_primary_64bit}
+%if !%{separate_bi32}
+/lib/libgcc_s.so.%{libgcc_s}
+%endif
+%else
+%if !%{separate_bi64}
+/lib64/libgcc_s.so.%{libgcc_s}
+%endif
+%endif
+%endif
+
+%if %{separate_bi64}
+%files -n libgcc_s%{libgcc_s}%{libgcc_s_suffix}-64bit
+%defattr(-,root,root)
+/lib64/libgcc_s.so.%{libgcc_s}
+%endif
+
+%if %{separate_bi32}
+%files -n libgcc_s%{libgcc_s}%{libgcc_s_suffix}-32bit
+%defattr(-,root,root)
+/lib/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
+
+
+%ifarch %lsan_arch
+%files -n liblsan%{liblsan_sover}%{liblsan_suffix}
+%defattr(-,root,root)
+%mainlib liblsan.so.%{liblsan_sover}*
+
+%if 0
+%if %{separate_biarch}
+%files -n liblsan%{liblsan_sover}%{liblsan_suffix}%{separate_biarch_suffix}
+%defattr(-,root,root)
+%biarchlib liblsan.so.%{liblsan_sover}*
+%endif
+%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
+
+
+%ifarch %cilkrts_arch
+%files -n libcilkrts%{libcilkrts_sover}%{libcilkrts_suffix}
+%defattr(-,root,root)
+%mainlib libcilkrts.so.%{libcilkrts_sover}*
+
+%if %{separate_biarch}
+%files -n libcilkrts%{libcilkrts_sover}%{libcilkrts_suffix}%{separate_biarch_suffix}
+%defattr(-,root,root)
+%biarchlib libcilkrts.so.%{libcilkrts_sover}*
+%endif
+%endif
+
+
+%ifarch %ubsan_arch
+%files -n libubsan%{libubsan_sover}%{libubsan_suffix}
+%defattr(-,root,root)
+%mainlib libubsan.so.%{libubsan_sover}*
+
+%if %{separate_biarch}
+%files -n libubsan%{libubsan_sover}%{libubsan_suffix}%{separate_biarch_suffix}
+%defattr(-,root,root)
+%biarchlib libubsan.so.%{libubsan_sover}*
+%endif
+%endif
+
+
+%ifarch %vtv_arch
+%files -n libvtv%{libvtv_sover}%{libvtv_suffix}
+%defattr(-,root,root)
+%mainlib libvtv.so.%{libvtv_sover}*
+
+%if %{separate_biarch}
+%files -n libvtv%{libvtv_sover}%{libvtv_suffix}%{separate_biarch_suffix}
+%defattr(-,root,root)
+%biarchlib libvtv.so.%{libvtv_sover}*
+%endif
+%endif
+
+
+%if %{build_fortran}
+%files fortran
+%defattr(-,root,root)
+%dir %{libsubdir}/finclude
+%{_prefix}/bin/gfortran%{binsuffix}
+%{libsubdir}/f951
+%{libsubdir}/finclude/*
+%versmainlib libgfortran.a
+%versmainlib libgfortran.so
+%versmainlib libgfortran.spec
+%versmainlib libgfortranbegin.a
+%versmainlib libcaf_single.a
+%ifarch %quadmath_arch
+%{libsubdir}/include/quadmath.h
+%{libsubdir}/include/quadmath_weak.h
+%versmainlib libquadmath.a
+%versmainlib libquadmath.so
+%endif
+%doc %{_mandir}/man1/gfortran%{binsuffix}.1.gz
+
+%if %{separate_biarch}
+%files fortran%{separate_biarch_suffix}
+%defattr(-,root,root)
+%versbiarchlib libgfortran.a
+%versbiarchlib libgfortran.so
+%versbiarchlib libgfortran.spec
+%versbiarchlib libgfortranbegin.a
+%versbiarchlib libcaf_single.a
+%ifarch %quadmath_arch
+%versbiarchlib libquadmath.a
+%versbiarchlib libquadmath.so
+%endif
+%endif
+
+%files -n libgfortran%{libgfortran_sover}%{libgfortran_suffix}
+%defattr(-,root,root)
+%mainlib libgfortran.so.%{libgfortran_sover}*
+
+%if %{separate_biarch}
+%files -n libgfortran%{libgfortran_sover}%{libgfortran_suffix}%{separate_biarch_suffix}
+%defattr(-,root,root)
+%biarchlib libgfortran.so.%{libgfortran_sover}*
+%endif
+
+%ifarch %quadmath_arch
+%files -n libquadmath%{libquadmath_sover}%{libquadmath_suffix}
+%defattr(-,root,root)
+%mainlib libquadmath.so.%{libquadmath_sover}*
+
+%if %{separate_biarch}
+%files -n libquadmath%{libquadmath_sover}%{libquadmath_suffix}%{separate_biarch_suffix}
+%defattr(-,root,root)
+%biarchlib libquadmath.so.%{libquadmath_sover}*
+%endif
+%endif
+%endif
+
+%files info
+%defattr(-,root,root)
+%doc %{_infodir}/cpp%{binsuffix}.info*.gz
+%doc %{_infodir}/cppinternals%{binsuffix}.info*.gz
+%doc %{_infodir}/gcc%{binsuffix}.info*.gz
+%doc %{_infodir}/gccint%{binsuffix}.info*.gz
+%doc %{_infodir}/gccinstall%{binsuffix}.info*.gz
+%doc %{_infodir}/libgomp%{binsuffix}.info*.gz
+%ifarch %itm_arch
+%doc %{_infodir}/libitm%{binsuffix}.info*.gz
+%endif
+%if %{build_fortran}
+%doc %{_infodir}/gfortran%{binsuffix}.info*.gz
+%ifarch %quadmath_arch
+%doc %{_infodir}/libquadmath%{binsuffix}.info*.gz
+%endif
+%endif
+%if %{build_java}
+%doc %{_infodir}/gcj%{binsuffix}.info*.gz
+%endif
+%if %{build_ada}
+%doc %{_infodir}/gnat-style%{binsuffix}.info*gz
+%doc %{_infodir}/gnat_rm%{binsuffix}.info*gz
+%doc %{_infodir}/gnat_ugn%{binsuffix}.info*gz
+%endif
+
+%files -n cpp49
+%defattr(-,root,root)
+%dir %{_libdir}/gcc
+%dir %{_libdir}/gcc/%{GCCDIST}
+%dir %{libsubdir}
+%{_prefix}/bin/cpp%{binsuffix}
+%{libsubdir}/cc1
+#%{libsubdir}/specs
+%doc %{_mandir}/man1/cpp%{binsuffix}.1.gz
+
+%if %{build_objc}
+%files objc
+%defattr(-,root,root)
+%{libsubdir}/cc1obj
+%{libsubdir}/include/objc
+%versmainlib libobjc.a
+%versmainlib libobjc.so
+
+%if %{separate_biarch}
+%files objc%{separate_biarch_suffix}
+%defattr(-,root,root)
+%versbiarchlib libobjc.a
+%versbiarchlib libobjc.so
+%endif
+
+%files -n libobjc%{libobjc_sover}%{libobjc_suffix}
+%defattr(-,root,root)
+%mainlib libobjc.so.%{libobjc_sover}*
+
+%if %{separate_biarch}
+%files -n libobjc%{libobjc_sover}%{libobjc_suffix}%{separate_biarch_suffix}
+%defattr(-,root,root)
+%biarchlib libobjc.so.%{libobjc_sover}*
+%endif
+%endif
+
+
+%if %{build_objcp}
+%files obj-c++
+%defattr(-,root,root)
+%{libsubdir}/cc1objplus
+%endif
+
+
+%if %{build_ada}
+%files ada
+%defattr(-,root,root)
+%dir %{_libdir}/gcc
+%dir %{_libdir}/gcc/%{GCCDIST}
+%dir %{libsubdir}
+%{_prefix}/bin/gnat*
+%dir %{versmainlibdir}/adalib
+%{versmainlibdir}/adainclude
+%{versmainlibdir}/adalib/*.ali
+%{versmainlibdir}/adalib/*.a
+%{versmainlibdir}/adalib/libgnarl.so
+%{versmainlibdir}/adalib/libgnat.so
+%{versmainlibdir}/gnat1
+
+%if %{separate_biarch}
+%files ada%{separate_biarch_suffix}
+%defattr(-,root,root)
+%dir %{versmainlibdirbi}/adalib
+%{versmainlibdirbi}/adainclude
+%{versmainlibdirbi}/adalib/*.ali
+%{versmainlibdirbi}/adalib/*.a
+%{versmainlibdirbi}/adalib/libgnarl.so
+%{versmainlibdirbi}/adalib/libgnat.so
+%endif
+
+%files -n libada49
+%defattr(-,root,root)
+%mainlib libgnarl-*.so
+%mainlib libgnat-*.so
+
+%if %{separate_biarch}
+%files -n libada49%{separate_biarch_suffix}
+%defattr(-,root,root)
+%biarchlib libgnarl-*.so
+%biarchlib libgnat-*.so
+%endif
+%endif
+
+
+%if %{build_java}
+%if 0%{?building_libjava:1}
+%files -n gcc49-java
+%defattr(-,root,root)
+%{_prefix}/bin/gcj%{binsuffix}
+%{_prefix}/bin/gcjh%{binsuffix}
+%{_prefix}/bin/gcj-dbtool%{binsuffix}
+%{_prefix}/bin/jcf-dump%{binsuffix}
+%{_prefix}/bin/jv-convert%{binsuffix}
+%{_prefix}/bin/gc-analyze%{binsuffix}
+%{_prefix}/bin/aot-compile%{binsuffix}
+%{_prefix}/bin/rebuild-gcj-db%{binsuffix}
+%{libsubdir}/jc1
+%{libsubdir}/jvgenmain
+%{libsubdir}/ecj.jar
+%{libsubdir}/ecj1
+%doc %{_mandir}/man1/gcj%{binsuffix}.1.gz
+%doc %{_mandir}/man1/gcjh%{binsuffix}.1.gz
+%doc %{_mandir}/man1/gcj-dbtool%{binsuffix}.1.gz
+%doc %{_mandir}/man1/jcf-dump%{binsuffix}.1.gz
+%doc %{_mandir}/man1/jv-convert%{binsuffix}.1.gz
+%doc %{_mandir}/man1/gc-analyze%{binsuffix}.1.gz
+%doc %{_mandir}/man1/aot-compile%{binsuffix}.1.gz
+%doc %{_mandir}/man1/rebuild-gcj-db%{binsuffix}.1.gz
+%endif
+%endif
+
+%if %{build_java}
+%if %{build_libjava}
+%files -n libgcj49
+%defattr(-,root,root)
+%dir %{libsubdir}/gcj-%{gcc_dir_version}-%{libgcj_sover}
+%dir %{_libdir}/gcc
+%dir %{_libdir}/gcc/%{GCCDIST}
+%dir %{libsubdir}
+%{libsubdir}/gcj-%{gcc_dir_version}-%{libgcj_sover}/classmap.db
+# We usually do not multilib libjava
+%if %{biarch_libjava}
+%versbiarchlib libgcj.la
+%biarchlib libgcj.so.*
+%biarchlib libgij.so.*
+%biarchlib libgcj-tools.so.*
+%else
+%versmainlib libgcj.la
+%mainlib libgcj.so.*
+%mainlib libgij.so.*
+%mainlib libgcj-tools.so.*
+%endif
+%{libsubdir}/gcj-%{gcc_dir_version}-%{libgcj_sover}/libjvm.la
+%{libsubdir}/gcj-%{gcc_dir_version}-%{libgcj_sover}/libjvm.so
+%{libsubdir}/gcj-%{gcc_dir_version}-%{libgcj_sover}/libjavamath.la
+%{libsubdir}/gcj-%{gcc_dir_version}-%{libgcj_sover}/libjavamath.so
+
+%files -n libgcj_bc%{libgcj_bc_sover}%{libgcj_bc_suffix}
+%defattr(-,root,root)
+%if %{biarch_libjava}
+%biarchlib libgcj_bc.so.%{libgcj_bc_sover}*
+%else
+%mainlib libgcj_bc.so.%{libgcj_bc_sover}*
+%endif
+
+%files -n libgcj49-jar
+%defattr(-,root,root)
+%{_prefix}/share/java/libgcj-%{gcc_dir_version}.jar
+%{_prefix}/share/java/libgcj-tools-%{gcc_dir_version}.jar
+
+%files -n libgcj49-devel
+%defattr(-,root,root)
+%dir %{_prefix}/include/c++
+%dir %{libsubdir}
+%dir %{libsubdir}/include
+%dir %{gxxinclude}
+%{_libdir}/pkgconfig/libgcj%{binsuffix}.pc
+%{libsubdir}/include/jawt.h
+%{libsubdir}/include/jawt_md.h
+%{libsubdir}/include/jni.h
+%{libsubdir}/include/jni_md.h
+%{libsubdir}/include/jvmpi.h
+%{gxxinclude}/gnu
+%{gxxinclude}/gcj
+%{gxxinclude}/java
+%{gxxinclude}/javax
+%{gxxinclude}/org
+%{gxxinclude}/sun
+%{libsubdir}/include/gcj
+%if %{biarch_libjava}
+%versbiarchlib libgcj.so
+%versbiarchlib libgcj.spec
+%versbiarchlib libgcj-tools.so
+%versbiarchlib libgij.so
+%versbiarchlib libgcj_bc.so
+%else
+%versmainlib libgcj.so
+%versmainlib libgcj.spec
+%versmainlib libgcj-tools.so
+%versmainlib libgij.so
+%versmainlib libgcj_bc.so
+%endif
+
+%files -n gcc49-gij
+%defattr(-,root,root)
+%{_prefix}/bin/gij%{binsuffix}
+%{_prefix}/bin/gappletviewer%{binsuffix}
+%{_prefix}/bin/gjar%{binsuffix}
+%{_prefix}/bin/gjarsigner%{binsuffix}
+%{_prefix}/bin/gjavah%{binsuffix}
+%{_prefix}/bin/gkeytool%{binsuffix}
+%{_prefix}/bin/gnative2ascii%{binsuffix}
+%{_prefix}/bin/gorbd%{binsuffix}
+%{_prefix}/bin/grmic%{binsuffix}
+%{_prefix}/bin/grmid%{binsuffix}
+%{_prefix}/bin/grmiregistry%{binsuffix}
+%{_prefix}/bin/gserialver%{binsuffix}
+%{_prefix}/bin/gtnameserv%{binsuffix}
+%doc %{_mandir}/man1/gij%{binsuffix}.1.gz
+%doc %{_mandir}/man1/gappletviewer%{binsuffix}.1.gz
+%doc %{_mandir}/man1/grmic%{binsuffix}.1.gz
+%doc %{_mandir}/man1/grmid%{binsuffix}.1.gz
+%doc %{_mandir}/man1/grmiregistry%{binsuffix}.1.gz
+%doc %{_mandir}/man1/gkeytool%{binsuffix}.1.gz
+%doc %{_mandir}/man1/gjar%{binsuffix}.1.gz
+%doc %{_mandir}/man1/gjarsigner%{binsuffix}.1.gz
+%doc %{_mandir}/man1/gjavah%{binsuffix}.1.gz
+%doc %{_mandir}/man1/gnative2ascii%{binsuffix}.1.gz
+%doc %{_mandir}/man1/gorbd%{binsuffix}.1.gz
+%doc %{_mandir}/man1/gserialver%{binsuffix}.1.gz
+%doc %{_mandir}/man1/gtnameserv%{binsuffix}.1.gz
+%endif
+%endif
+
+%if 0%{?building_libjava:1}
+%files -n libstdc++49-doc
+%defattr(-,root,root)
+%doc libstdc++-v3/doc/html
+%endif
+
+%if %{build_java}
+%if 0%{?building_libffi:1}
+%files -n libffi%{libffi_sover}%{libffi_suffix}
+%defattr(-,root,root)
+%mainlib libffi.so.%{libffi_sover}*
+
+%if %{separate_biarch}
+%files -n libffi%{libffi_sover}%{libffi_suffix}%{separate_biarch_suffix}
+%defattr(-,root,root)
+%biarchlib libffi.so.%{libffi_sover}*
+%endif
+
+%post -n libffi49-devel
+%install_info --info-dir=%{_infodir} %{_infodir}/libffi%{binsuffix}.info.gz
+%postun -n libffi49-devel
+%install_info_delete --info-dir=%{_infodir} %{_infodir}/libffi%{binsuffix}.info.gz
+
+%files -n libffi49-devel
+%defattr(-,root,root)
+%{_prefix}/include/ffi.h
+%{_prefix}/include/ffitarget.h
+%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 libffi49-devel%{separate_biarch_suffix}
+%defattr(-,root,root)
+%biarchlib libffi.so
+%biarchlib libffi.a
+%endif
+%endif
+%endif
+
+%if %{build_go}
+%files go
+%{_prefix}/bin/gccgo%{binsuffix}
+%{libsubdir}/go1
+%versmainlib libgo.a
+%versmainlib libgo.so
+%versmainlib libgobegin.a
+%dir %mainlibdir/go
+%dir %mainlibdir/go/%{gcc_dir_version}
+%mainlibdir/go/%{gcc_dir_version}/%{GCCDIST}
+%doc %{_mandir}/man1/gccgo%{binsuffix}.1.gz
+
+%if %{separate_biarch}
+%files go%{separate_biarch_suffix}
+%versbiarchlib libgo.a
+%versbiarchlib libgo.so
+%versbiarchlib libgobegin.a
+%dir %mainlibdirbi/go
+%dir %mainlibdirbi/go/%{gcc_dir_version}
+%mainlibdirbi/go/%{gcc_dir_version}/%{GCCDIST}
+%endif
+
+%files -n libgo%{libgo_sover}%{libgo_suffix}
+%defattr(-,root,root)
+%mainlib libgo.so.%{libgo_sover}*
+
+%if %{separate_biarch}
+%files -n libgo%{libgo_sover}%{libgo_suffix}%{separate_biarch_suffix}
+%defattr(-,root,root)
+%biarchlib libgo.so.%{libgo_sover}*
+%endif
+%endif
+
+%if 0%{?run_tests:1}
+%files -n gcc49-testresults
+%defattr(-,root,root)
+%doc testresults/test_summary.txt
+%doc testresults/*.sum
+%doc testresults/*.log
+%endif
+
+
+%changelog
diff --git a/packaging/libffi49-rpmlintrc b/packaging/libffi49-rpmlintrc
new file mode 100644 (file)
index 0000000..89224d4
--- /dev/null
@@ -0,0 +1,5 @@
+# This line is mandatory to access the configuration functions
+from Config import *
+
+addFilter ("shlib-policy-name-error")
+
diff --git a/packaging/libffi49.spec b/packaging/libffi49.spec
new file mode 100644 (file)
index 0000000..db05d1e
--- /dev/null
@@ -0,0 +1,1105 @@
+%define building_libffi 1
+#
+# spec file for package gcc49
+#
+# 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
+
+
+%define build_ada 0
+
+%define quadmath_arch %ix86 x86_64 ia64 aarch64
+%define tsan_arch x86_64
+%define asan_arch x86_64 %ix86 ppc ppc64 %sparc %arm
+%define itm_arch x86_64 %ix86 %arm ppc ppc64 ppc64le s390 s390x %sparc
+%define atomic_arch x86_64 %ix86 %arm aarch64 ppc ppc64 ppc64le s390 s390x %sparc m68k
+%define lsan_arch x86_64
+%define ubsan_arch x86_64 %ix86 ppc ppc64 %arm
+%if 0%{?build_libvtv:1}
+%define vtv_arch x86_64 %ix86
+%endif
+%define cilkrts_arch x86_64 %ix86
+
+# We don't want to build java
+%define build_java 0
+%define build_libjava 0
+
+%define build_cp 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_go !0%{?building_libjava:1}%{?building_libffi:1}
+
+%if %{build_objcp}
+%define build_cp 1
+%define build_objc 1
+%endif
+
+%if %{build_libjava}
+%define build_cp 1
+%endif
+
+# For optional compilers only build C, C++ and Fortran
+%if 0%{?build_optional_compiler_languages:1}
+%define build_ada 0
+%define build_java 0
+%define build_libjava 0
+%define build_objc 0
+%define build_objcp 0
+%define build_go 0
+%endif
+
+# Shared library SONAME versions
+%ifarch hppa
+%define libgcc_s 4
+%else
+%ifarch m68k
+%define libgcc_s 2
+%else
+%define libgcc_s 1
+%endif
+%endif
+%define libgcj_sover %{nil}
+%define libgcj_bc_sover %{nil}
+%define libffi_sover %{nil}
+%define libgomp_sover %{nil}
+%define libstdcxx_sover %{nil}
+%define libobjc_sover %{nil}
+%define libgfortran_sover %{nil}
+%define libquadmath_sover %{nil}
+%define libasan_sover %{nil}
+%define libtsan_sover %{nil}
+%define libatomic_sover %{nil}
+%define libitm_sover %{nil}
+%define libubsan_sover %{nil}
+%define liblsan_sover %{nil}
+%define libvtv_sover %{nil}
+%define libcilkrts_sover %{nil}
+%define libgo_sover %{nil}
+
+# 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:49}%{?product_libs_gcc_ver} != 49
+%define pne 1
+%endif
+%define libgcc_s_suffix %{?pne:-gcc49}
+# libgcj SONAME changes with every GCC version
+%define libgcj_suffix %nil
+%define libgcj_bc_suffix %{?pne:-gcc49}
+%define libffi_suffix %{?pne:-gcc49}
+%define libgomp_suffix %{?pne:-gcc49}
+%define libstdcxx_suffix %{?pne:-gcc49}
+%define libobjc_suffix %{?pne:-gcc49}
+%define libgfortran_suffix %{?pne:-gcc49}
+%define libquadmath_suffix %{?pne:-gcc49}
+%define libasan_suffix %{?pne:-gcc49}
+%define libtsan_suffix %{?pne:-gcc49}
+%define libatomic_suffix %{?pne:-gcc49}
+%define libitm_suffix %{?pne:-gcc49}
+
+
+%define libubsan_suffix %{?pne:-gcc49}
+%define liblsan_suffix %{?pne:-gcc49}
+%define libvtv_suffix %{?pne:-gcc49}
+%define libcilkrts_suffix %{?pne:-gcc49}
+%define libgo_suffix %{?pne:-gcc49}
+
+%define selfconflict() %1
+
+Name: libffi49
+# With generated files in src we could drop the following
+BuildRequires: bison
+BuildRequires: flex
+BuildRequires: gettext-devel
+BuildRequires: makeinfo
+# until here, but at least renaming and patching info files breaks this
+BuildRequires: gcc-c++
+BuildRequires: glibc-devel
+BuildRequires: mpc-devel
+BuildRequires: mpfr-devel
+BuildRequires: perl
+BuildRequires: zlib-devel
+%ifarch %ix86 x86_64 ppc ppc64 s390 s390x ia64 %sparc hppa %arm aarch64
+BuildRequires: cloog-isl-devel
+BuildRequires: isl-devel
+%endif
+%if %{build_ada}
+%define hostsuffix -4.9
+BuildRequires: gcc49-ada
+%endif
+%if 0%{?building_libjava:1}%{?building_testsuite:1}
+BuildRequires: fastjar
+%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 separate_bi32 0
+%define separate_bi64 0
+%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
+
+# Define two macros to trigger -32bit or -64bit package variants
+%define separate_biarch 0
+%if %{separate_bi32}
+%define separate_biarch 1
+%define separate_biarch_suffix -32bit
+%endif
+%if %{separate_bi64}
+%define separate_biarch 1
+%define separate_biarch_suffix -64bit
+%endif
+
+%ifarch x86_64 ia64 s390x alpha ppc64 sparc64 aarch64
+# 64-bit is primary build target
+%define build_primary_64bit 1
+%else
+%define build_primary_64bit 0
+%endif
+
+%define biarch_libjava 0
+
+%define biarch_targets x86_64 s390x powerpc64 powerpc sparc sparc64
+
+URL:          http://gcc.gnu.org/
+Version: 4.9.1
+Release:      1
+%define gcc_dir_version 4.9
+%define binsuffix -4.9
+
+%if !0%{?building_libjava:1}%{?building_libffi:1}%{?building_testsuite:1}
+Requires: binutils glibc-devel
+Requires: cpp49 = %{version}-%{release}
+Requires: libgcc_s%{libgcc_s} >= %{version}-%{release}
+Requires: libgomp%{libgomp_sover} >= %{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
+%ifarch %cilkrts_arch
+Requires: libcilkrts%{libcilkrts_sover} >= %{version}-%{release}
+%endif
+%ifarch %lsan_arch
+Requires: liblsan%{liblsan_sover} >= %{version}-%{release}
+%endif
+%ifarch %ubsan_arch
+Requires: libubsan%{libubsan_sover} >= %{version}-%{release}
+%endif
+%ifarch %vtv_arch
+Requires: libvtv%{libvtv_sover} >= %{version}-%{release}
+%endif
+Suggests: gcc49-info gcc49-locale
+%endif
+
+BuildRoot:     %{_tmppath}/%{name}-%{version}-build
+Source:                gcc-%{version}.tar.bz2
+Source1:       change_spec
+Source2:       libffi49-rpmlintrc
+Source3:       gcc49-rpmlintrc
+Source4:       ecj.jar
+Source5:       baselibs.conf
+Source6:       libgcj49-rpmlintrc
+
+Group:          Development/Building
+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:        Development/Building
+Provides:      libffi%{libffi_sover} = %{version}-%{release}
+
+%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 libffi%{libffi_sover}%{libffi_suffix} -p /sbin/ldconfig
+
+%postun -n libffi%{libffi_sover}%{libffi_suffix} -p /sbin/ldconfig
+%package -n libffi%{libffi_sover}%{libffi_suffix}-32bit
+Summary:      Foreign Function Interface library
+License:        BSD-3-Clause
+Group:        Development/Building
+Provides:      libffi%{libffi_sover}-32bit = %{version}-%{release}
+
+%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 libffi%{libffi_sover}%{libffi_suffix}-32bit -p /sbin/ldconfig
+
+%postun -n libffi%{libffi_sover}%{libffi_suffix}-32bit -p /sbin/ldconfig
+%package -n libffi%{libffi_sover}%{libffi_suffix}-64bit
+Summary:      Foreign Function Interface library
+License:        BSD-3-Clause
+Group:        Development/Building
+Provides:      libffi%{libffi_sover}-64bit = %{version}-%{release}
+
+%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 libffi%{libffi_sover}%{libffi_suffix}-64bit -p /sbin/ldconfig
+
+%postun -n libffi%{libffi_sover}%{libffi_suffix}-64bit -p /sbin/ldconfig
+
+%package -n libffi49-devel
+Summary:      Foreign Function Interface library development files
+License:        BSD 3-Clause
+Group:        Development/Building
+Requires: libffi%{libffi_sover} >= %{version}-%{release}
+Provides: libffi-devel = %{version}-%{release}
+
+%description -n libffi49-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 -n libffi49-devel-32bit
+Summary:      Foreign Function Interface library development files
+License:        BSD 3-Clause
+Group:        Development/Building
+Requires: libffi%{libffi_sover}-32bit >= %{version}-%{release}
+Provides: libffi-devel-32bit = %{version}-%{release}
+
+%description -n libffi49-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 -n libffi49-devel-64bit
+Summary:      Foreign Function Interface library development files
+License:        BSD 3-Clause
+Group:        Development/Building
+Requires: libffi%{libffi_sover}-64bit >= %{version}-%{release}
+Provides: libffi-devel-64bit = %{version}-%{release}
+
+%description -n libffi49-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 go
+Summary:      GNU Go Compiler
+License:        GPL-3.0+ 
+Group:        Development/Languages
+Requires: gcc49 = %{version}-%{release}
+Requires: libgo%{libgo_sover} >= %{version}-%{release}
+
+%description go
+This package contains a Go compiler and associated development
+files based on the GNU GCC technology.
+%package go-32bit
+Summary:      GNU Go Compiler
+License:        GPL-3.0+ 
+Group:        Development/Languages
+Requires: gcc49-32bit = %{version}-%{release}
+Requires: libgo%{libgo_sover}-32bit >= %{version}-%{release}
+
+%description go-32bit
+This package contains a Go compiler and associated development
+files based on the GNU GCC technology.
+%package go-64bit
+Summary:      GNU Go Compiler
+License:        GPL-3.0+ 
+Group:        Development/Languages
+Requires: gcc49-64bit = %{version}-%{release}
+Requires: libgo%{libgo_sover}-64bit >= %{version}-%{release}
+
+%description go-64bit
+This package contains a Go compiler and associated development
+files based on the GNU GCC technology.
+
+%package -n libgo%{libgo_sover}%{libgo_suffix}
+Summary:      GNU Go compiler runtime library
+License:        BSD-3-Clause
+Group:        Development/Languages
+Provides:      libgo%{libgo_sover} = %{version}-%{release}
+
+%description -n libgo%{libgo_sover}%{libgo_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 libgo%{libgo_sover}%{libgo_suffix} -p /sbin/ldconfig
+
+%postun -n libgo%{libgo_sover}%{libgo_suffix} -p /sbin/ldconfig
+%package -n libgo%{libgo_sover}%{libgo_suffix}-32bit
+Summary:      GNU Go compiler runtime library
+License:        BSD-3-Clause
+Group:        Development/Languages
+Provides:      libgo%{libgo_sover}-32bit = %{version}-%{release}
+
+%description -n libgo%{libgo_sover}%{libgo_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 libgo%{libgo_sover}%{libgo_suffix}-32bit -p /sbin/ldconfig
+
+%postun -n libgo%{libgo_sover}%{libgo_suffix}-32bit -p /sbin/ldconfig
+%package -n libgo%{libgo_sover}%{libgo_suffix}-64bit
+Summary:      GNU Go compiler runtime library
+License:        BSD-3-Clause
+Group:        Development/Languages
+Provides:      libgo%{libgo_sover}-64bit = %{version}-%{release}
+
+%description -n libgo%{libgo_sover}%{libgo_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 libgo%{libgo_sover}%{libgo_suffix}-64bit -p /sbin/ldconfig
+
+%postun -n libgo%{libgo_sover}%{libgo_suffix}-64bit -p /sbin/ldconfig
+
+
+%package -n gcc49-testresults
+Summary:      Testsuite results
+License:       SUSE-Public-Domain
+Group:        Development/Languages
+
+%description -n gcc49-testresults
+Results from running the gcc and target library testsuites.
+
+
+
+
+# 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} == "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
+%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "aarch64"
+%define CONFIGURE_TARGET aarch64-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} == "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/;")
+%endif
+%define biarch %(case " %{biarch_targets} " in (*" %{TARGET_ARCH} "*) echo 1;; (*) echo 0;; esac)
+
+%define HOST_ARCH %(echo %{_host_cpu} | sed -e "s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;")
+%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}
+
+
+# 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
+
+%define mainlibdir %{_libdir}
+%define mainlibdirbi32 %{_prefix}/lib
+%define mainlibdirbi64 %{_prefix}/lib64
+%if %{build_primary_64bit}
+%define mainlibdirbi %{mainlibdirbi32}
+%else
+%define mainlibdirbi %{mainlibdirbi64}
+%endif
+
+
+# Now define a few macros that make it easy to package libs and
+# related files just to the right package, without caring for the
+# 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
+%define mainlib() %{mainlibdir}/%1\
+%{nil}
+%define biarchlib() %{nil}
+%if %{biarch}
+%if !%{separate_biarch}
+%define mainlib() %{mainlibdir}/%1\
+%{mainlibdirbi}/%1\
+%{nil}
+%else
+%define biarchlib() %{mainlibdirbi}/%1\
+%{nil}
+%endif
+%endif
+
+%define versmainlib() %{versmainlibdir}/%1\
+%{nil}
+%define versbiarchlib() %{nil}
+%if %{biarch}
+%if !%{separate_biarch}
+%define versmainlib() %{versmainlibdir}/%1\
+%{versmainlibdirbi}/%1\
+%{nil}
+%else
+%define versbiarchlib() %{versmainlibdirbi}/%1\
+%{nil}
+%endif
+%endif
+
+
+
+%prep
+%setup -q -n gcc-%{version}
+
+# 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
+contrib/gcc_update --touch
+# Avoid fucking up testsuite results with Java and indirect dispatch
+export LD_ASNEEDED=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 possible and remove
+# the 'prerelease' tagging in this case
+if test `cat gcc/DEV-PHASE` == "prerelease"; then
+  if test `cat gcc/BASE-VER | cut -d '.' -f 3` != "0"; then
+    : > gcc/DEV-PHASE
+  fi
+  ( 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
+%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'`
+%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
+%if %{build_go}
+languages=$languages,go
+%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
+
+%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 \
+%if "%{TARGET_ARCH}" == "armv7l" || "%{TARGET_ARCH}" == "armv7hl"
+# temporary workaround for a miscompilation of hash functions in java code
+GCJ_EXTRA_FLAGS="-marm"
+%endif
+
+export RPM_OPT_FLAGS="`echo $RPM_OPT_FLAGS | sed -e "s/ -Wp,-D_FORTIFY_SOURCE=2 / /g"`"
+
+CFLAGS="$RPM_OPT_FLAGS" CXXFLAGS="$RPM_OPT_FLAGS" XCFLAGS="$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 \
+%if 0%{!?build_libvtv:1}
+       --disable-libvtv \
+%endif
+       --disable-plugin \
+       --with-bugurl="http://bugs.tizen.org/" \
+       --with-pkgversion="Tizen" \
+%if !%{build_fortran}
+       --disable-libquadmath \
+%endif
+%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
+       --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 \
+       --enable-linux-futex \
+       --program-suffix=%{binsuffix} \
+%if 0%{!?gcc_target_arch:1}
+%ifarch ia64
+       --with-system-libunwind \
+%else
+       --without-system-libunwind \
+%endif
+%endif
+%if 0%{?gcc_target_arch:1}
+       --program-prefix=%{gcc_target_arch}- \
+       --target=%{gcc_target_arch} \
+       --disable-nls \
+%if 0%{?sysroot:1}
+       --with-sysroot=%sysroot \
+%else
+       --with-sysroot=%{_prefix}/%{gcc_target_arch} \
+%endif
+%if 0%{?build_sysroot:1}
+       --with-build-sysroot=%{build_sysroot} \
+%else
+%if 0%{?sysroot:1}
+       --with-build-sysroot=%{sysroot} \
+%else
+       --with-build-sysroot=%{_prefix}/%{gcc_target_arch} \
+%endif
+%endif
+%if 0%{?canonical_target:1}
+       --with-build-time-tools=/usr/%{canonical_target}-tizen-linux%{?canonical_target_abi:%canonical_target_abi}/bin \
+%endif
+%if "%{TARGET_ARCH}" == "spu"
+       --with-gxx-include-dir=%sysroot/include/c++/%{gcc_dir_version} \
+       --with-newlib \
+%endif
+%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}" == "armv7l" 
+       --with-arch=armv7-a \
+       --with-tune=cortex-a8 \
+       --with-float=softfp \
+       --with-fpu=vfpv3 \
+       --with-mode=thumb \
+       --disable-sjlj-exceptions \
+%endif
+%if "%{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}" == "aarch64"
+       --with-arch=armv8-a \
+       --disable-sjlj-exceptions \
+%endif
+%if "%{TARGET_ARCH}" == "powerpc" || "%{TARGET_ARCH}" == "powerpc64"
+%if "%{TARGET_ARCH}" == "powerpc"
+        --with-cpu=default32 \
+%endif
+%if "%{TARGET_ARCH}" == "powerpc64le"
+       --with-cpu=power7 \
+%else
+       --with-cpu-64=power4 \
+%endif
+       --enable-secureplt \
+       --with-long-double-128 \
+%if "%{TARGET_ARCH}" == "powerpc64le"
+       --disable-multilib \
+%endif
+%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 \
+%endif
+%if "%{TARGET_ARCH}" == "x86_64"
+       --with-arch-32=i586 \
+       --with-tune=generic \
+       --disable-multilib \
+%endif
+%if "%{TARGET_ARCH}" == "s390"
+        --with-tune=zEC12 --with-arch=z196 \
+       --with-long-double-128 \
+       --enable-decimal-float \
+%endif
+%if "%{TARGET_ARCH}" == "s390x"
+        --with-tune=zEC12 --with-arch=z196 \
+       --with-long-double-128 \
+       --enable-decimal-float \
+%endif
+%if "%{TARGET_ARCH}" == "m68k"
+       --disable-multilib \
+%endif
+       --build=%{GCCDIST} \
+       --host=%{GCCDIST}
+
+
+%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 and matters
+#%ifarch x86_64 ppc64le s390x
+#make profiledbootstrap STAGE1_CFLAGS="$STAGE1_FLAGS" BOOT_CFLAGS="$RPM_OPT_FLAGS" $PARALLEL
+#%else
+make STAGE1_CFLAGS="$STAGE1_FLAGS" BOOT_CFLAGS="$RPM_OPT_FLAGS" $PARALLEL
+#%endif
+make info
+%if 0%{?building_libjava:1}
+make -C %{GCCDIST}/libstdc++-v3/doc doc-html-doxygen
+%endif
+%if 0%{?run_tests:1}
+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
+%endif
+%endif
+
+%install
+export NO_BRP_CHECK_BYTECODE_VERSION=true
+cd obj-%{GCCDIST}
+# Work around tail/head -1 changes
+export _POSIX2_VERSION=199209
+export LIBRARY_PATH=$RPM_BUILD_ROOT%{libsubdir}:$RPM_BUILD_ROOT%{mainlibdirbi}
+%if 0%{?building_libffi:1}
+make -C %{GCCDIST}/libffi install DESTDIR=$RPM_BUILD_ROOT
+%else
+%if 0%{?building_libjava:1}
+make -C %{GCCDIST}/libjava install DESTDIR=$RPM_BUILD_ROOT
+make -C gcc java.install-man DESTDIR=$RPM_BUILD_ROOT
+make -C gcc java.install-common DESTDIR=$RPM_BUILD_ROOT
+make -C gcc install-common DESTDIR=$RPM_BUILD_ROOT COMPILERS='jc1$(exeext) jvgenmain$(exeext)'
+# copy the libstdc++ API reference
+cp -r %{GCCDIST}/libstdc++-v3/doc/doxygen/html ../libstdc++-v3/doc/html/api
+# install-common also installs collect2, gcov and the g++ and gfortran driver
+%if %{build_cp}
+rm $RPM_BUILD_ROOT%{_prefix}/bin/g++%{binsuffix}
+%endif
+%if %{build_fortran}
+rm $RPM_BUILD_ROOT%{_prefix}/bin/gfortran%{binsuffix}
+%endif
+rm $RPM_BUILD_ROOT%{_prefix}/bin/gcov%{binsuffix}
+rm $RPM_BUILD_ROOT%{libsubdir}/collect2
+%else
+make install DESTDIR=$RPM_BUILD_ROOT
+%if %{build_java}
+make -C gcc java.uninstall DESTDIR=$RPM_BUILD_ROOT
+make -C gcc java.install-info DESTDIR=$RPM_BUILD_ROOT
+rm $RPM_BUILD_ROOT%{_prefix}/bin/jcf-dump%{binsuffix}
+rm $RPM_BUILD_ROOT%{_mandir}/man1/jcf-dump%{binsuffix}.1
+rm $RPM_BUILD_ROOT%{libsubdir}/jc1
+rm $RPM_BUILD_ROOT%{libsubdir}/jvgenmain
+%endif
+%endif
+%endif
+
+# Remove libffi installed files if we did not want to build it
+%if !0%{?building_libffi:1}
+rm -f $RPM_BUILD_ROOT%{mainlibdir}/libffi.*
+%if %{biarch}
+  rm -f $RPM_BUILD_ROOT%{mainlibdirbi}/libffi.*
+%endif
+rm -f $RPM_BUILD_ROOT%{libsubdir}/include/ffi.h
+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 \
+    libgomp libstdc++ libsupc++ libgcj-tools libgij libgo \
+    libasan libatomic libitm libtsan libcilkrts liblsan libubsan libvtv; do
+  rm -f $RPM_BUILD_ROOT%{versmainlibdir}/$lib.la
+%if %{biarch}
+  rm -f $RPM_BUILD_ROOT%{versmainlibdirbi}/$lib.la
+%endif
+done
+
+mkdir -p $RPM_BUILD_ROOT%{_libdir}
+%if %{biarch}
+%if %{build_primary_64bit}
+mkdir -p $RPM_BUILD_ROOT%{_prefix}/lib
+%else
+mkdir -p $RPM_BUILD_ROOT%{_prefix}/lib64
+%endif
+%endif
+
+
+%if %{build_ada}
+mv $RPM_BUILD_ROOT%{libsubdir}/adalib/lib*-*.so $RPM_BUILD_ROOT%{_libdir}
+ln -sf %{_libdir}/libgnarl%{binsuffix}.so $RPM_BUILD_ROOT%{libsubdir}/adalib/libgnarl.so
+ln -sf %{_libdir}/libgnat%{binsuffix}.so $RPM_BUILD_ROOT%{libsubdir}/adalib/libgnat.so
+chmod a+x $RPM_BUILD_ROOT%{_libdir}/libgna*-*.so
+%if %{biarch}
+mv $RPM_BUILD_ROOT%{versmainlibdirbi}/adalib/lib*-*.so $RPM_BUILD_ROOT%{mainlibdirbi}/
+ln -sf %{mainlibdirbi}/libgnarl%{binsuffix}.so $RPM_BUILD_ROOT%{versmainlibdirbi}/adalib/libgnarl.so
+ln -sf %{mainlibdirbi}/libgnat%{binsuffix}.so $RPM_BUILD_ROOT%{versmainlibdirbi}/adalib/libgnarl.so
+chmod a+x $RPM_BUILD_ROOT%{mainlibdirbi}/libgna*-*.so
+%endif
+%endif
+
+rm -f $RPM_BUILD_ROOT%{_prefix}/bin/c++%{binsuffix}
+
+# Remove some crap from the .la files:
+for l in `find $RPM_BUILD_ROOT -name '*.la'`; do
+  echo "changing $l"
+# -e '/^dependency_libs/s|%{libsubdir}/\([^.]*\)\.la |%{_libdir}/\1\.la |g'
+  sed -e '/^dependency_libs/s| -L%{_builddir}/[^ ]*||g' \
+      -e '/^dependency_libs/s| -L/usr/%{GCCDIST}/bin||g' \
+      -e '/^dependency_libs/s|-lm \(-lm \)*|-lm |' \
+      -e '/^dependency_libs/s|-L[^ ]* ||g' \
+%if %{biarch}
+%if %{build_primary_64bit}
+      -e '/^libdir/s|%{_libdir}/32|%{_prefix}/lib|' \
+      -e '/^libdir/s|lib64/\.\./||' \
+%else
+      -e '/^libdir/s|%{_libdir}/64|%{_prefix}/lib64|' \
+%endif
+%endif
+      < $l  > $l.new
+  mv $l.new $l
+done
+
+%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
+# 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
+#rm -rf $RPM_BUILD_ROOT%{_libdir}/pkgconfig/libgcj%{binsuffix}.pc
+rm -f $RPM_BUILD_ROOT%{libsubdir}/include-fixed/zutil.h
+rm -f $RPM_BUILD_ROOT%{libsubdir}/include-fixed/linux/a.out.h
+rm -f $RPM_BUILD_ROOT%{libsubdir}/include-fixed/asm-generic/socket.h
+# no plugins
+rm -rf $RPM_BUILD_ROOT%{libsubdir}/plugin
+rm -f  $RPM_BUILD_ROOT%{_infodir}/dir
+
+
+%if 0%{?building_libjava:1}
+# gcj -static doesn't work properly anyway, unless using --whole-archive
+# let's save the space instead.
+find $RPM_BUILD_ROOT -name libgcj.a \
+       -o -name libgcj-tools.a \
+       -o -name libgij.a \
+       -o -name libjvm.a \
+       -o -name libgcj_bc.a \
+  | xargs rm -f
+
+find $RPM_BUILD_ROOT -name libgcj.spec | xargs \
+  sed -i -e 's/lib: /&%%{static:%%eJava programs cannot be linked statically}/'
+
+# security files have broken install locations, also they cause conflicts
+# between libgcj versions.  Simply delete them here, libgcj will use its
+# defaults in this case (which is what these files contain anyway).
+rm -f $RPM_BUILD_ROOT%{libsubdir}/logging.properties
+rm -r $RPM_BUILD_ROOT%{libsubdir}/security
+%endif
+
+%if 0%{?building_libffi:1}
+# Move libffi headers, remove empty libffi libtool file
+mkdir -p $RPM_BUILD_ROOT%{_prefix}/include
+mv $RPM_BUILD_ROOT%{libsubdir}/include/ffitarget.h $RPM_BUILD_ROOT%{_prefix}/include/
+mv $RPM_BUILD_ROOT%{libsubdir}/include/ffi.h $RPM_BUILD_ROOT%{_prefix}/include/
+rm -f $RPM_BUILD_ROOT%{mainlibdir}/libffi.la
+%if %{biarch}
+rm -f $RPM_BUILD_ROOT%{mainlibdirbi}/libffi.la
+%endif
+# Generate a simple pkg-config file
+mkdir -p $RPM_BUILD_ROOT%{_libdir}/pkgconfig
+echo -e 'Name: libffi\nVersion: 3.0.9\nDescription: libffi\nLibs: -lffi' > $RPM_BUILD_ROOT%{_libdir}/pkgconfig/libffi.pc
+%endif
+
+%if %{build_java}
+%if !%{build_libjava}
+rm $RPM_BUILD_ROOT%{_mandir}/man1/jv-convert%{binsuffix}.1
+rm $RPM_BUILD_ROOT%{_mandir}/man1/gcj-dbtool%{binsuffix}.1
+rm $RPM_BUILD_ROOT%{_mandir}/man1/gij%{binsuffix}.1
+rm $RPM_BUILD_ROOT%{_mandir}/man1/grmic%{binsuffix}.1
+rm $RPM_BUILD_ROOT%{_mandir}/man1/gc-analyze%{binsuffix}.1
+rm $RPM_BUILD_ROOT%{_mandir}/man1/aot-compile%{binsuffix}.1
+rm $RPM_BUILD_ROOT%{_mandir}/man1/rebuild-gcj-db%{binsuffix}.1
+%endif
+rm -f $RPM_BUILD_ROOT%{_datadir}/gcc%{binsuffix}/python/libjava/aotcompile.py
+rm -f $RPM_BUILD_ROOT%{_datadir}/gcc%{binsuffix}/python/libjava/classfile.py
+%endif
+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 %{biarch}
+%if %{build_primary_64bit}
+rm -f $RPM_BUILD_ROOT%{_prefix}/lib/libiberty.a
+%else
+rm -f $RPM_BUILD_ROOT%{_prefix}/lib64/libiberty.a
+%endif
+%endif
+rm -f $RPM_BUILD_ROOT%{libsubdir}/liblto_plugin.a
+rm -f $RPM_BUILD_ROOT%{libsubdir}/liblto_plugin.la
+%if %{build_go}
+# gccgo.info isn't properly versioned
+rm $RPM_BUILD_ROOT%{_infodir}/gccgo.info*
+%endif
+
+
+%if %{build_java}
+%if 0%{?building_libffi:1}
+%files -n libffi%{libffi_sover}%{libffi_suffix}
+%defattr(-,root,root)
+%mainlib libffi.so.%{libffi_sover}*
+
+%if %{separate_biarch}
+%files -n libffi%{libffi_sover}%{libffi_suffix}%{separate_biarch_suffix}
+%defattr(-,root,root)
+%biarchlib libffi.so.%{libffi_sover}*
+%endif
+
+%post -n libffi49-devel
+%install_info --info-dir=%{_infodir} %{_infodir}/libffi%{binsuffix}.info.gz
+%postun -n libffi49-devel
+%install_info_delete --info-dir=%{_infodir} %{_infodir}/libffi%{binsuffix}.info.gz
+
+%files -n libffi49-devel
+%defattr(-,root,root)
+%{_prefix}/include/ffi.h
+%{_prefix}/include/ffitarget.h
+%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 libffi49-devel%{separate_biarch_suffix}
+%defattr(-,root,root)
+%biarchlib libffi.so
+%biarchlib libffi.a
+%endif
+%endif
+%endif
+
+%if %{build_go}
+%files go
+%{_prefix}/bin/gccgo%{binsuffix}
+%{libsubdir}/go1
+%versmainlib libgo.a
+%versmainlib libgo.so
+%versmainlib libgobegin.a
+%dir %mainlibdir/go
+%dir %mainlibdir/go/%{gcc_dir_version}
+%mainlibdir/go/%{gcc_dir_version}/%{GCCDIST}
+%doc %{_mandir}/man1/gccgo%{binsuffix}.1.gz
+
+%if %{separate_biarch}
+%files go%{separate_biarch_suffix}
+%versbiarchlib libgo.a
+%versbiarchlib libgo.so
+%versbiarchlib libgobegin.a
+%dir %mainlibdirbi/go
+%dir %mainlibdirbi/go/%{gcc_dir_version}
+%mainlibdirbi/go/%{gcc_dir_version}/%{GCCDIST}
+%endif
+
+%files -n libgo%{libgo_sover}%{libgo_suffix}
+%defattr(-,root,root)
+%mainlib libgo.so.%{libgo_sover}*
+
+%if %{separate_biarch}
+%files -n libgo%{libgo_sover}%{libgo_suffix}%{separate_biarch_suffix}
+%defattr(-,root,root)
+%biarchlib libgo.so.%{libgo_sover}*
+%endif
+%endif
+
+%if 0%{?run_tests:1}
+%files -n gcc49-testresults
+%defattr(-,root,root)
+%doc testresults/test_summary.txt
+%doc testresults/*.sum
+%doc testresults/*.log
+%endif
+
+
+%changelog
diff --git a/packaging/libgcj49-rpmlintrc b/packaging/libgcj49-rpmlintrc
new file mode 100644 (file)
index 0000000..89224d4
--- /dev/null
@@ -0,0 +1,5 @@
+# This line is mandatory to access the configuration functions
+from Config import *
+
+addFilter ("shlib-policy-name-error")
+
diff --git a/packaging/libgcj49.spec b/packaging/libgcj49.spec
new file mode 100644 (file)
index 0000000..2f7a4db
--- /dev/null
@@ -0,0 +1,1464 @@
+%define building_libjava 1
+#
+# spec file for package gcc49
+#
+# 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
+
+
+%define build_ada 0
+
+%define quadmath_arch %ix86 x86_64 ia64 aarch64
+%define tsan_arch x86_64
+%define asan_arch x86_64 %ix86 ppc ppc64 %sparc %arm
+%define itm_arch x86_64 %ix86 %arm ppc ppc64 ppc64le s390 s390x %sparc
+%define atomic_arch x86_64 %ix86 %arm aarch64 ppc ppc64 ppc64le s390 s390x %sparc m68k
+%define lsan_arch x86_64
+%define ubsan_arch x86_64 %ix86 ppc ppc64 %arm
+%if 0%{?build_libvtv:1}
+%define vtv_arch x86_64 %ix86
+%endif
+%define cilkrts_arch x86_64 %ix86
+
+# We don't want to build java
+%define build_java 0
+%define build_libjava 0
+
+%define build_cp 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_go !0%{?building_libjava:1}%{?building_libffi:1}
+
+%if %{build_objcp}
+%define build_cp 1
+%define build_objc 1
+%endif
+
+%if %{build_libjava}
+%define build_cp 1
+%endif
+
+# For optional compilers only build C, C++ and Fortran
+%if 0%{?build_optional_compiler_languages:1}
+%define build_ada 0
+%define build_java 0
+%define build_libjava 0
+%define build_objc 0
+%define build_objcp 0
+%define build_go 0
+%endif
+
+# Shared library SONAME versions
+%ifarch hppa
+%define libgcc_s 4
+%else
+%ifarch m68k
+%define libgcc_s 2
+%else
+%define libgcc_s 1
+%endif
+%endif
+%define libgcj_sover %{nil}
+%define libgcj_bc_sover %{nil}
+%define libffi_sover %{nil}
+%define libgomp_sover %{nil}
+%define libstdcxx_sover %{nil}
+%define libobjc_sover %{nil}
+%define libgfortran_sover %{nil}
+%define libquadmath_sover %{nil}
+%define libasan_sover %{nil}
+%define libtsan_sover %{nil}
+%define libatomic_sover %{nil}
+%define libitm_sover %{nil}
+%define libubsan_sover %{nil}
+%define liblsan_sover %{nil}
+%define libvtv_sover %{nil}
+%define libcilkrts_sover %{nil}
+%define libgo_sover %{nil}
+
+# 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:49}%{?product_libs_gcc_ver} != 49
+%define pne 1
+%endif
+%define libgcc_s_suffix %{?pne:-gcc49}
+# libgcj SONAME changes with every GCC version
+%define libgcj_suffix %nil
+%define libgcj_bc_suffix %{?pne:-gcc49}
+%define libffi_suffix %{?pne:-gcc49}
+%define libgomp_suffix %{?pne:-gcc49}
+%define libstdcxx_suffix %{?pne:-gcc49}
+%define libobjc_suffix %{?pne:-gcc49}
+%define libgfortran_suffix %{?pne:-gcc49}
+%define libquadmath_suffix %{?pne:-gcc49}
+%define libasan_suffix %{?pne:-gcc49}
+%define libtsan_suffix %{?pne:-gcc49}
+%define libatomic_suffix %{?pne:-gcc49}
+%define libitm_suffix %{?pne:-gcc49}
+
+
+%define libubsan_suffix %{?pne:-gcc49}
+%define liblsan_suffix %{?pne:-gcc49}
+%define libvtv_suffix %{?pne:-gcc49}
+%define libcilkrts_suffix %{?pne:-gcc49}
+%define libgo_suffix %{?pne:-gcc49}
+
+%define selfconflict() %1
+
+Name: libgcj49
+# With generated files in src we could drop the following
+BuildRequires: bison
+BuildRequires: flex
+BuildRequires: gettext-devel
+BuildRequires: makeinfo
+# until here, but at least renaming and patching info files breaks this
+BuildRequires: gcc-c++
+BuildRequires: glibc-devel
+BuildRequires: mpc-devel
+BuildRequires: mpfr-devel
+BuildRequires: perl
+BuildRequires: zlib-devel
+%ifarch %ix86 x86_64 ppc ppc64 s390 s390x ia64 %sparc hppa %arm aarch64
+BuildRequires: cloog-isl-devel
+BuildRequires: isl-devel
+%endif
+%if %{build_ada}
+%define hostsuffix -4.9
+BuildRequires: gcc49-ada
+%endif
+%if 0%{?building_libjava:1}%{?building_testsuite:1}
+BuildRequires: fastjar
+%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 separate_bi32 0
+%define separate_bi64 0
+%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
+
+# Define two macros to trigger -32bit or -64bit package variants
+%define separate_biarch 0
+%if %{separate_bi32}
+%define separate_biarch 1
+%define separate_biarch_suffix -32bit
+%endif
+%if %{separate_bi64}
+%define separate_biarch 1
+%define separate_biarch_suffix -64bit
+%endif
+
+%ifarch x86_64 ia64 s390x alpha ppc64 sparc64 aarch64
+# 64-bit is primary build target
+%define build_primary_64bit 1
+%else
+%define build_primary_64bit 0
+%endif
+
+%define biarch_libjava 0
+
+%define biarch_targets x86_64 s390x powerpc64 powerpc sparc sparc64
+
+URL:          http://gcc.gnu.org/
+Version: 4.9.1
+Release:      1
+%define gcc_dir_version 4.9
+%define binsuffix -4.9
+
+%if !0%{?building_libjava:1}%{?building_libffi:1}%{?building_testsuite:1}
+Requires: binutils glibc-devel
+Requires: cpp49 = %{version}-%{release}
+Requires: libgcc_s%{libgcc_s} >= %{version}-%{release}
+Requires: libgomp%{libgomp_sover} >= %{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
+%ifarch %cilkrts_arch
+Requires: libcilkrts%{libcilkrts_sover} >= %{version}-%{release}
+%endif
+%ifarch %lsan_arch
+Requires: liblsan%{liblsan_sover} >= %{version}-%{release}
+%endif
+%ifarch %ubsan_arch
+Requires: libubsan%{libubsan_sover} >= %{version}-%{release}
+%endif
+%ifarch %vtv_arch
+Requires: libvtv%{libvtv_sover} >= %{version}-%{release}
+%endif
+Suggests: gcc49-info gcc49-locale
+%endif
+
+BuildRoot:     %{_tmppath}/%{name}-%{version}-build
+Source:                gcc-%{version}.tar.bz2
+Source1:       change_spec
+Source2:       libffi49-rpmlintrc
+Source3:       gcc49-rpmlintrc
+Source4:       ecj.jar
+Source5:       baselibs.conf
+Source6:       libgcj49-rpmlintrc
+
+Summary:      Java Runtime Library for gcc
+License:      GPL-2.0-with-classpath-exception
+Group:        Development/Building
+Recommends:   libgcj49-jar = %{version}-%{release}
+Provides: libgcj%{libgcj_sover} = %{version}-%{release}
+Provides: libgij%{libgcj_sover} = %{version}-%{release}
+Provides: libgcj-tools%{libgcj_sover} = %{version}-%{release}
+
+%description 
+This library is needed if you want to use the GNU Java compiler, gcj.
+Source code for this package is in gcc.
+
+%post -n libgcj49 -p /sbin/ldconfig
+
+%postun -n libgcj49 -p /sbin/ldconfig
+
+
+%package -n gcc49-java
+Summary:      The GNU Java Compiler
+License:        GPL-3.0+
+Group:        Development/Languages
+Requires: gcc49 = %{version}
+Requires: libgcj49-devel = %{version}-%{release}
+
+%description -n gcc49-java
+The Java compiler from the GCC-tools-suite.
+
+
+%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/Languages
+# 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%{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.%{libgcj_bc_sover}
+%endif
+Provides:      libgcj_bc%{libgcj_bc_sover} = %{version}-%{release}
+
+%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
+libgcj.so changes.
+
+
+%package -n libgcj49-jar
+Summary:      Java runtime library (jar files).
+License:        GPL-2.0-with-classpath-exception
+Group:        Development/Languages
+
+%description -n libgcj49-jar
+These are the jar files that go along with the gcj front end to gcc.
+
+
+%package -n libgcj49-devel
+Summary:      Include Files and Libraries mandatory for Development.
+License:        GPL-2.0-with-classpath-exception
+Group:        Development/Languages
+Requires: libgcj%{libgcj_sover} >= %{version}-%{release}
+Requires: libgcj_bc%{libgcj_bc_sover} >= %{version}-%{release}
+Requires: libgcj49-jar = %{version}-%{release}
+
+%description -n libgcj49-devel
+This package contains all necessary include files and libraries needed
+to develop applications that require these.
+
+
+%package -n gcc49-gij
+Summary:      Java Bytecode Interpreter for gcc
+License:      GPL-2.0-with-classpath-exception
+Group:        Development/Languages
+Requires: libgcj%{libgcj_sover} >= %{version}-%{release}
+
+%description -n gcc49-gij
+This package contains the java bytecode interpreter gij and related tools.
+
+
+%package -n libstdc++49-doc
+Summary:      Documentation for the GNU C++ standard library
+License:        GPL-3.0+
+Group:        Development/Building
+BuildArch:    noarch
+
+%description -n libstdc++49-doc
+Extensive HTML documentation for the GNU C++ standard library.
+
+
+%package -n libffi%{libffi_sover}%{libffi_suffix}
+Summary:      Foreign Function Interface library
+License:        BSD-3-Clause
+Group:        Development/Building
+Provides:      libffi%{libffi_sover} = %{version}-%{release}
+
+%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 libffi%{libffi_sover}%{libffi_suffix} -p /sbin/ldconfig
+
+%postun -n libffi%{libffi_sover}%{libffi_suffix} -p /sbin/ldconfig
+%package -n libffi%{libffi_sover}%{libffi_suffix}-32bit
+Summary:      Foreign Function Interface library
+License:        BSD-3-Clause
+Group:        Development/Building
+Provides:      libffi%{libffi_sover}-32bit = %{version}-%{release}
+
+%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 libffi%{libffi_sover}%{libffi_suffix}-32bit -p /sbin/ldconfig
+
+%postun -n libffi%{libffi_sover}%{libffi_suffix}-32bit -p /sbin/ldconfig
+%package -n libffi%{libffi_sover}%{libffi_suffix}-64bit
+Summary:      Foreign Function Interface library
+License:        BSD-3-Clause
+Group:        Development/Building
+Provides:      libffi%{libffi_sover}-64bit = %{version}-%{release}
+
+%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 libffi%{libffi_sover}%{libffi_suffix}-64bit -p /sbin/ldconfig
+
+%postun -n libffi%{libffi_sover}%{libffi_suffix}-64bit -p /sbin/ldconfig
+
+%package -n libffi49-devel
+Summary:      Foreign Function Interface library development files
+License:        BSD 3-Clause
+Group:        Development/Building
+Requires: libffi%{libffi_sover} >= %{version}-%{release}
+Provides: libffi-devel = %{version}-%{release}
+
+%description -n libffi49-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 -n libffi49-devel-32bit
+Summary:      Foreign Function Interface library development files
+License:        BSD 3-Clause
+Group:        Development/Building
+Requires: libffi%{libffi_sover}-32bit >= %{version}-%{release}
+Provides: libffi-devel-32bit = %{version}-%{release}
+
+%description -n libffi49-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 -n libffi49-devel-64bit
+Summary:      Foreign Function Interface library development files
+License:        BSD 3-Clause
+Group:        Development/Building
+Requires: libffi%{libffi_sover}-64bit >= %{version}-%{release}
+Provides: libffi-devel-64bit = %{version}-%{release}
+
+%description -n libffi49-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 go
+Summary:      GNU Go Compiler
+License:        GPL-3.0+ 
+Group:        Development/Languages
+Requires: gcc49 = %{version}-%{release}
+Requires: libgo%{libgo_sover} >= %{version}-%{release}
+
+%description go
+This package contains a Go compiler and associated development
+files based on the GNU GCC technology.
+%package go-32bit
+Summary:      GNU Go Compiler
+License:        GPL-3.0+ 
+Group:        Development/Languages
+Requires: gcc49-32bit = %{version}-%{release}
+Requires: libgo%{libgo_sover}-32bit >= %{version}-%{release}
+
+%description go-32bit
+This package contains a Go compiler and associated development
+files based on the GNU GCC technology.
+%package go-64bit
+Summary:      GNU Go Compiler
+License:        GPL-3.0+ 
+Group:        Development/Languages
+Requires: gcc49-64bit = %{version}-%{release}
+Requires: libgo%{libgo_sover}-64bit >= %{version}-%{release}
+
+%description go-64bit
+This package contains a Go compiler and associated development
+files based on the GNU GCC technology.
+
+%package -n libgo%{libgo_sover}%{libgo_suffix}
+Summary:      GNU Go compiler runtime library
+License:        BSD-3-Clause
+Group:        Development/Languages
+Provides:      libgo%{libgo_sover} = %{version}-%{release}
+
+%description -n libgo%{libgo_sover}%{libgo_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 libgo%{libgo_sover}%{libgo_suffix} -p /sbin/ldconfig
+
+%postun -n libgo%{libgo_sover}%{libgo_suffix} -p /sbin/ldconfig
+%package -n libgo%{libgo_sover}%{libgo_suffix}-32bit
+Summary:      GNU Go compiler runtime library
+License:        BSD-3-Clause
+Group:        Development/Languages
+Provides:      libgo%{libgo_sover}-32bit = %{version}-%{release}
+
+%description -n libgo%{libgo_sover}%{libgo_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 libgo%{libgo_sover}%{libgo_suffix}-32bit -p /sbin/ldconfig
+
+%postun -n libgo%{libgo_sover}%{libgo_suffix}-32bit -p /sbin/ldconfig
+%package -n libgo%{libgo_sover}%{libgo_suffix}-64bit
+Summary:      GNU Go compiler runtime library
+License:        BSD-3-Clause
+Group:        Development/Languages
+Provides:      libgo%{libgo_sover}-64bit = %{version}-%{release}
+
+%description -n libgo%{libgo_sover}%{libgo_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 libgo%{libgo_sover}%{libgo_suffix}-64bit -p /sbin/ldconfig
+
+%postun -n libgo%{libgo_sover}%{libgo_suffix}-64bit -p /sbin/ldconfig
+
+
+%package -n gcc49-testresults
+Summary:      Testsuite results
+License:       SUSE-Public-Domain
+Group:        Development/Languages
+
+%description -n gcc49-testresults
+Results from running the gcc and target library testsuites.
+
+
+
+
+# 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} == "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
+%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "aarch64"
+%define CONFIGURE_TARGET aarch64-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} == "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/;")
+%endif
+%define biarch %(case " %{biarch_targets} " in (*" %{TARGET_ARCH} "*) echo 1;; (*) echo 0;; esac)
+
+%define HOST_ARCH %(echo %{_host_cpu} | sed -e "s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;")
+%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}
+
+
+# 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
+
+%define mainlibdir %{_libdir}
+%define mainlibdirbi32 %{_prefix}/lib
+%define mainlibdirbi64 %{_prefix}/lib64
+%if %{build_primary_64bit}
+%define mainlibdirbi %{mainlibdirbi32}
+%else
+%define mainlibdirbi %{mainlibdirbi64}
+%endif
+
+
+# Now define a few macros that make it easy to package libs and
+# related files just to the right package, without caring for the
+# 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
+%define mainlib() %{mainlibdir}/%1\
+%{nil}
+%define biarchlib() %{nil}
+%if %{biarch}
+%if !%{separate_biarch}
+%define mainlib() %{mainlibdir}/%1\
+%{mainlibdirbi}/%1\
+%{nil}
+%else
+%define biarchlib() %{mainlibdirbi}/%1\
+%{nil}
+%endif
+%endif
+
+%define versmainlib() %{versmainlibdir}/%1\
+%{nil}
+%define versbiarchlib() %{nil}
+%if %{biarch}
+%if !%{separate_biarch}
+%define versmainlib() %{versmainlibdir}/%1\
+%{versmainlibdirbi}/%1\
+%{nil}
+%else
+%define versbiarchlib() %{versmainlibdirbi}/%1\
+%{nil}
+%endif
+%endif
+
+
+
+%prep
+%setup -q -n gcc-%{version}
+
+# 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
+contrib/gcc_update --touch
+# Avoid fucking up testsuite results with Java and indirect dispatch
+export LD_ASNEEDED=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 possible and remove
+# the 'prerelease' tagging in this case
+if test `cat gcc/DEV-PHASE` == "prerelease"; then
+  if test `cat gcc/BASE-VER | cut -d '.' -f 3` != "0"; then
+    : > gcc/DEV-PHASE
+  fi
+  ( 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
+%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'`
+%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
+%if %{build_go}
+languages=$languages,go
+%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
+
+%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 \
+%if "%{TARGET_ARCH}" == "armv7l" || "%{TARGET_ARCH}" == "armv7hl"
+# temporary workaround for a miscompilation of hash functions in java code
+GCJ_EXTRA_FLAGS="-marm"
+%endif
+
+export RPM_OPT_FLAGS="`echo $RPM_OPT_FLAGS | sed -e "s/ -Wp,-D_FORTIFY_SOURCE=2 / /g"`"
+
+CFLAGS="$RPM_OPT_FLAGS" CXXFLAGS="$RPM_OPT_FLAGS" XCFLAGS="$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 \
+%if 0%{!?build_libvtv:1}
+       --disable-libvtv \
+%endif
+       --disable-plugin \
+       --with-bugurl="http://bugs.tizen.org/" \
+       --with-pkgversion="Tizen" \
+%if !%{build_fortran}
+       --disable-libquadmath \
+%endif
+%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
+       --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 \
+       --enable-linux-futex \
+       --program-suffix=%{binsuffix} \
+%if 0%{!?gcc_target_arch:1}
+%ifarch ia64
+       --with-system-libunwind \
+%else
+       --without-system-libunwind \
+%endif
+%endif
+%if 0%{?gcc_target_arch:1}
+       --program-prefix=%{gcc_target_arch}- \
+       --target=%{gcc_target_arch} \
+       --disable-nls \
+%if 0%{?sysroot:1}
+       --with-sysroot=%sysroot \
+%else
+       --with-sysroot=%{_prefix}/%{gcc_target_arch} \
+%endif
+%if 0%{?build_sysroot:1}
+       --with-build-sysroot=%{build_sysroot} \
+%else
+%if 0%{?sysroot:1}
+       --with-build-sysroot=%{sysroot} \
+%else
+       --with-build-sysroot=%{_prefix}/%{gcc_target_arch} \
+%endif
+%endif
+%if 0%{?canonical_target:1}
+       --with-build-time-tools=/usr/%{canonical_target}-tizen-linux%{?canonical_target_abi:%canonical_target_abi}/bin \
+%endif
+%if "%{TARGET_ARCH}" == "spu"
+       --with-gxx-include-dir=%sysroot/include/c++/%{gcc_dir_version} \
+       --with-newlib \
+%endif
+%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}" == "armv7l" 
+       --with-arch=armv7-a \
+       --with-tune=cortex-a8 \
+       --with-float=softfp \
+       --with-fpu=vfpv3 \
+       --with-mode=thumb \
+       --disable-sjlj-exceptions \
+%endif
+%if "%{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}" == "aarch64"
+       --with-arch=armv8-a \
+       --disable-sjlj-exceptions \
+%endif
+%if "%{TARGET_ARCH}" == "powerpc" || "%{TARGET_ARCH}" == "powerpc64"
+%if "%{TARGET_ARCH}" == "powerpc"
+        --with-cpu=default32 \
+%endif
+%if "%{TARGET_ARCH}" == "powerpc64le"
+       --with-cpu=power7 \
+%else
+       --with-cpu-64=power4 \
+%endif
+       --enable-secureplt \
+       --with-long-double-128 \
+%if "%{TARGET_ARCH}" == "powerpc64le"
+       --disable-multilib \
+%endif
+%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 \
+%endif
+%if "%{TARGET_ARCH}" == "x86_64"
+       --with-arch-32=i586 \
+       --with-tune=generic \
+       --disable-multilib \
+%endif
+%if "%{TARGET_ARCH}" == "s390"
+        --with-tune=zEC12 --with-arch=z196 \
+       --with-long-double-128 \
+       --enable-decimal-float \
+%endif
+%if "%{TARGET_ARCH}" == "s390x"
+        --with-tune=zEC12 --with-arch=z196 \
+       --with-long-double-128 \
+       --enable-decimal-float \
+%endif
+%if "%{TARGET_ARCH}" == "m68k"
+       --disable-multilib \
+%endif
+       --build=%{GCCDIST} \
+       --host=%{GCCDIST}
+
+
+%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 and matters
+#%ifarch x86_64 ppc64le s390x
+#make profiledbootstrap STAGE1_CFLAGS="$STAGE1_FLAGS" BOOT_CFLAGS="$RPM_OPT_FLAGS" $PARALLEL
+#%else
+make STAGE1_CFLAGS="$STAGE1_FLAGS" BOOT_CFLAGS="$RPM_OPT_FLAGS" $PARALLEL
+#%endif
+make info
+%if 0%{?building_libjava:1}
+make -C %{GCCDIST}/libstdc++-v3/doc doc-html-doxygen
+%endif
+%if 0%{?run_tests:1}
+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
+%endif
+%endif
+
+%install
+export NO_BRP_CHECK_BYTECODE_VERSION=true
+cd obj-%{GCCDIST}
+# Work around tail/head -1 changes
+export _POSIX2_VERSION=199209
+export LIBRARY_PATH=$RPM_BUILD_ROOT%{libsubdir}:$RPM_BUILD_ROOT%{mainlibdirbi}
+%if 0%{?building_libffi:1}
+make -C %{GCCDIST}/libffi install DESTDIR=$RPM_BUILD_ROOT
+%else
+%if 0%{?building_libjava:1}
+make -C %{GCCDIST}/libjava install DESTDIR=$RPM_BUILD_ROOT
+make -C gcc java.install-man DESTDIR=$RPM_BUILD_ROOT
+make -C gcc java.install-common DESTDIR=$RPM_BUILD_ROOT
+make -C gcc install-common DESTDIR=$RPM_BUILD_ROOT COMPILERS='jc1$(exeext) jvgenmain$(exeext)'
+# copy the libstdc++ API reference
+cp -r %{GCCDIST}/libstdc++-v3/doc/doxygen/html ../libstdc++-v3/doc/html/api
+# install-common also installs collect2, gcov and the g++ and gfortran driver
+%if %{build_cp}
+rm $RPM_BUILD_ROOT%{_prefix}/bin/g++%{binsuffix}
+%endif
+%if %{build_fortran}
+rm $RPM_BUILD_ROOT%{_prefix}/bin/gfortran%{binsuffix}
+%endif
+rm $RPM_BUILD_ROOT%{_prefix}/bin/gcov%{binsuffix}
+rm $RPM_BUILD_ROOT%{libsubdir}/collect2
+%else
+make install DESTDIR=$RPM_BUILD_ROOT
+%if %{build_java}
+make -C gcc java.uninstall DESTDIR=$RPM_BUILD_ROOT
+make -C gcc java.install-info DESTDIR=$RPM_BUILD_ROOT
+rm $RPM_BUILD_ROOT%{_prefix}/bin/jcf-dump%{binsuffix}
+rm $RPM_BUILD_ROOT%{_mandir}/man1/jcf-dump%{binsuffix}.1
+rm $RPM_BUILD_ROOT%{libsubdir}/jc1
+rm $RPM_BUILD_ROOT%{libsubdir}/jvgenmain
+%endif
+%endif
+%endif
+
+# Remove libffi installed files if we did not want to build it
+%if !0%{?building_libffi:1}
+rm -f $RPM_BUILD_ROOT%{mainlibdir}/libffi.*
+%if %{biarch}
+  rm -f $RPM_BUILD_ROOT%{mainlibdirbi}/libffi.*
+%endif
+rm -f $RPM_BUILD_ROOT%{libsubdir}/include/ffi.h
+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 \
+    libgomp libstdc++ libsupc++ libgcj-tools libgij libgo \
+    libasan libatomic libitm libtsan libcilkrts liblsan libubsan libvtv; do
+  rm -f $RPM_BUILD_ROOT%{versmainlibdir}/$lib.la
+%if %{biarch}
+  rm -f $RPM_BUILD_ROOT%{versmainlibdirbi}/$lib.la
+%endif
+done
+
+mkdir -p $RPM_BUILD_ROOT%{_libdir}
+%if %{biarch}
+%if %{build_primary_64bit}
+mkdir -p $RPM_BUILD_ROOT%{_prefix}/lib
+%else
+mkdir -p $RPM_BUILD_ROOT%{_prefix}/lib64
+%endif
+%endif
+
+
+# move shared libs from versionspecific dir to main libdir
+for libname in \
+%if 0%{?building_libjava:1}
+  libgcj libgij libgcj-tools \
+%else
+%if %{build_fortran}
+  libgfortran \
+%ifarch %quadmath_arch
+  libquadmath \
+%endif
+%endif
+%if %{build_objc}
+  libobjc \
+%endif
+%if %{build_cp}
+  libstdc++ \
+%endif
+%if %{build_go}
+  libgo \
+%endif
+  libgomp \
+%ifarch %atomic_arch
+  libatomic \
+%endif
+%ifarch %itm_arch
+  libitm \
+%endif
+%ifarch %asan_arch
+  libasan \
+%endif
+%ifarch %tsan_arch
+  libtsan \
+%endif
+%ifarch %cilkrts_arch
+  libcilkrts \
+%endif
+%ifarch %lsan_arch
+  liblsan \
+%endif
+%ifarch %ubsan_arch
+  libubsan \
+%endif
+%ifarch %vtv_arch
+  libvtv \
+%endif
+%endif
+    ; do
+  for lib in `find $RPM_BUILD_ROOT%{versmainlibdir} -maxdepth 1 -name $libname.so.*`; do
+    mv $lib $RPM_BUILD_ROOT%{mainlibdir}/
+  done
+  ln -sf %{mainlibdir}/`readlink $RPM_BUILD_ROOT%{versmainlibdir}/$libname.so | sed -e 's/\(.*\.so\.[^\.]*\).*/\1/'`  \
+         $RPM_BUILD_ROOT%{versmainlibdir}/$libname.so
+%if %{biarch}
+  if test -d $RPM_BUILD_ROOT%{versmainlibdirbi}; then
+    for lib in `find $RPM_BUILD_ROOT%{versmainlibdirbi} -maxdepth 1 -name "$libname.so.*"`; do
+      mv $lib $RPM_BUILD_ROOT%{mainlibdirbi}/
+    done
+    ln -sf %{mainlibdirbi}/`readlink $RPM_BUILD_ROOT%{versmainlibdirbi}/$libname.so | sed -e 's/\(.*\.so\.[^\.]*\).*/\1/'`  \
+         $RPM_BUILD_ROOT%{versmainlibdirbi}/$libname.so
+  fi
+%endif
+done
+# FIXME, tsan and lsan are not multilib
+%ifarch %tsan_arch
+%if %{biarch}
+rm -f $RPM_BUILD_ROOT%{versmainlibdirbi}/libtsan.so
+%endif
+%endif
+%ifarch %lsan_arch
+%if %{biarch}
+rm -f $RPM_BUILD_ROOT%{versmainlibdirbi}/liblsan.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
+# place so ldconfig does not complain
+mkdir -p $RPM_BUILD_ROOT%{_datadir}/gdb/auto-load%{mainlibdir}
+mv $RPM_BUILD_ROOT%{mainlibdir}/libstdc++.so.*-gdb.py $RPM_BUILD_ROOT%{_datadir}/gdb/auto-load%{mainlibdir}/
+sed -i -e '/^libdir/s/\/gcc\/%{GCCDIST}\/%{gcc_dir_version}//g' $RPM_BUILD_ROOT%{_datadir}/gdb/auto-load%{mainlibdir}/libstdc++.so.*-gdb.py
+%if %{biarch}
+  if test -d $RPM_BUILD_ROOT%{versmainlibdirbi}; then
+    mkdir -p $RPM_BUILD_ROOT%{_datadir}/gdb/auto-load%{mainlibdirbi}
+    mv $RPM_BUILD_ROOT%{mainlibdirbi}/libstdc++.so.*-gdb.py $RPM_BUILD_ROOT%{_datadir}/gdb/auto-load%{mainlibdirbi}/
+    sed -i -e '/^libdir/s/\/gcc\/%{GCCDIST}\/%{gcc_dir_version}//g' $RPM_BUILD_ROOT%{_datadir}/gdb/auto-load%{mainlibdirbi}/libstdc++.so.*-gdb.py
+  fi
+%endif
+%endif
+%endif
+%if 0%{?building_libjava:1}
+# libgcj_bc is special as the .so file is actually a different
+# library as the library refered to by the SONAME which should
+# be a simple link to our libgcj.
+for lib in `find $RPM_BUILD_ROOT%{versmainlibdir} -maxdepth 1 -name libgcj_bc.so.*`; do
+  rm $lib
+done
+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.%{libgcj_sover} $RPM_BUILD_ROOT%{mainlibdirbi}/libgcj_bc.so.%{libgcj_bc_sover}
+%endif
+mv $RPM_BUILD_ROOT%{libsubdir}/pkgconfig $RPM_BUILD_ROOT%{_libdir}/
+%endif
+
+
+%if %{build_ada}
+mv $RPM_BUILD_ROOT%{libsubdir}/adalib/lib*-*.so $RPM_BUILD_ROOT%{_libdir}
+ln -sf %{_libdir}/libgnarl%{binsuffix}.so $RPM_BUILD_ROOT%{libsubdir}/adalib/libgnarl.so
+ln -sf %{_libdir}/libgnat%{binsuffix}.so $RPM_BUILD_ROOT%{libsubdir}/adalib/libgnat.so
+chmod a+x $RPM_BUILD_ROOT%{_libdir}/libgna*-*.so
+%if %{biarch}
+mv $RPM_BUILD_ROOT%{versmainlibdirbi}/adalib/lib*-*.so $RPM_BUILD_ROOT%{mainlibdirbi}/
+ln -sf %{mainlibdirbi}/libgnarl%{binsuffix}.so $RPM_BUILD_ROOT%{versmainlibdirbi}/adalib/libgnarl.so
+ln -sf %{mainlibdirbi}/libgnat%{binsuffix}.so $RPM_BUILD_ROOT%{versmainlibdirbi}/adalib/libgnarl.so
+chmod a+x $RPM_BUILD_ROOT%{mainlibdirbi}/libgna*-*.so
+%endif
+%endif
+
+rm -f $RPM_BUILD_ROOT%{_prefix}/bin/c++%{binsuffix}
+
+# Remove some crap from the .la files:
+for l in `find $RPM_BUILD_ROOT -name '*.la'`; do
+  echo "changing $l"
+# -e '/^dependency_libs/s|%{libsubdir}/\([^.]*\)\.la |%{_libdir}/\1\.la |g'
+  sed -e '/^dependency_libs/s| -L%{_builddir}/[^ ]*||g' \
+      -e '/^dependency_libs/s| -L/usr/%{GCCDIST}/bin||g' \
+      -e '/^dependency_libs/s|-lm \(-lm \)*|-lm |' \
+      -e '/^dependency_libs/s|-L[^ ]* ||g' \
+%if %{biarch}
+%if %{build_primary_64bit}
+      -e '/^libdir/s|%{_libdir}/32|%{_prefix}/lib|' \
+      -e '/^libdir/s|lib64/\.\./||' \
+%else
+      -e '/^libdir/s|%{_libdir}/64|%{_prefix}/lib64|' \
+%endif
+%endif
+      < $l  > $l.new
+  mv $l.new $l
+done
+
+%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
+%if %{build_cp}
+# Find C++ and Java headers
+find $RPM_BUILD_ROOT%{_prefix}/include/c++ \
+  -regex ".*/\(org\|gcj\|gnu\|java\|javax\)" -prune \
+  -o \( -type d -printf "%%%%dir " , \
+        -printf "%{_prefix}/include/c++/%%P\n" \) > ../c++-headers
+%endif
+# 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
+#rm -rf $RPM_BUILD_ROOT%{_libdir}/pkgconfig/libgcj%{binsuffix}.pc
+rm -f $RPM_BUILD_ROOT%{libsubdir}/include-fixed/zutil.h
+rm -f $RPM_BUILD_ROOT%{libsubdir}/include-fixed/linux/a.out.h
+rm -f $RPM_BUILD_ROOT%{libsubdir}/include-fixed/asm-generic/socket.h
+# no plugins
+rm -rf $RPM_BUILD_ROOT%{libsubdir}/plugin
+rm -f  $RPM_BUILD_ROOT%{_infodir}/dir
+
+
+%if 0%{?building_libjava:1}
+# gcj -static doesn't work properly anyway, unless using --whole-archive
+# let's save the space instead.
+find $RPM_BUILD_ROOT -name libgcj.a \
+       -o -name libgcj-tools.a \
+       -o -name libgij.a \
+       -o -name libjvm.a \
+       -o -name libgcj_bc.a \
+  | xargs rm -f
+
+find $RPM_BUILD_ROOT -name libgcj.spec | xargs \
+  sed -i -e 's/lib: /&%%{static:%%eJava programs cannot be linked statically}/'
+
+# security files have broken install locations, also they cause conflicts
+# between libgcj versions.  Simply delete them here, libgcj will use its
+# defaults in this case (which is what these files contain anyway).
+rm -f $RPM_BUILD_ROOT%{libsubdir}/logging.properties
+rm -r $RPM_BUILD_ROOT%{libsubdir}/security
+%endif
+
+%if 0%{?building_libffi:1}
+# Move libffi headers, remove empty libffi libtool file
+mkdir -p $RPM_BUILD_ROOT%{_prefix}/include
+mv $RPM_BUILD_ROOT%{libsubdir}/include/ffitarget.h $RPM_BUILD_ROOT%{_prefix}/include/
+mv $RPM_BUILD_ROOT%{libsubdir}/include/ffi.h $RPM_BUILD_ROOT%{_prefix}/include/
+rm -f $RPM_BUILD_ROOT%{mainlibdir}/libffi.la
+%if %{biarch}
+rm -f $RPM_BUILD_ROOT%{mainlibdirbi}/libffi.la
+%endif
+# Generate a simple pkg-config file
+mkdir -p $RPM_BUILD_ROOT%{_libdir}/pkgconfig
+echo -e 'Name: libffi\nVersion: 3.0.9\nDescription: libffi\nLibs: -lffi' > $RPM_BUILD_ROOT%{_libdir}/pkgconfig/libffi.pc
+%endif
+
+%if %{build_java}
+%if !%{build_libjava}
+rm $RPM_BUILD_ROOT%{_mandir}/man1/jv-convert%{binsuffix}.1
+rm $RPM_BUILD_ROOT%{_mandir}/man1/gcj-dbtool%{binsuffix}.1
+rm $RPM_BUILD_ROOT%{_mandir}/man1/gij%{binsuffix}.1
+rm $RPM_BUILD_ROOT%{_mandir}/man1/grmic%{binsuffix}.1
+rm $RPM_BUILD_ROOT%{_mandir}/man1/gc-analyze%{binsuffix}.1
+rm $RPM_BUILD_ROOT%{_mandir}/man1/aot-compile%{binsuffix}.1
+rm $RPM_BUILD_ROOT%{_mandir}/man1/rebuild-gcj-db%{binsuffix}.1
+%endif
+rm -f $RPM_BUILD_ROOT%{_datadir}/gcc%{binsuffix}/python/libjava/aotcompile.py
+rm -f $RPM_BUILD_ROOT%{_datadir}/gcc%{binsuffix}/python/libjava/classfile.py
+%endif
+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 %{biarch}
+%if %{build_primary_64bit}
+rm -f $RPM_BUILD_ROOT%{_prefix}/lib/libiberty.a
+%else
+rm -f $RPM_BUILD_ROOT%{_prefix}/lib64/libiberty.a
+%endif
+%endif
+rm -f $RPM_BUILD_ROOT%{libsubdir}/liblto_plugin.a
+rm -f $RPM_BUILD_ROOT%{libsubdir}/liblto_plugin.la
+%if %{build_go}
+# gccgo.info isn't properly versioned
+rm $RPM_BUILD_ROOT%{_infodir}/gccgo.info*
+%endif
+
+%if 0%{?building_libjava:1}
+# For building libjava only we need to delete other info docs
+rm $RPM_BUILD_ROOT%{_infodir}/cp-tools.info*
+# Remove stale manpages for binaries we do not build
+rm $RPM_BUILD_ROOT%{_mandir}/man1/gjdoc%{binsuffix}.1
+# For building the java frontend we need to copy the ecj jar
+mkdir -p $RPM_BUILD_ROOT%{libsubdir}
+cp $RPM_SOURCE_DIR/ecj.jar $RPM_BUILD_ROOT%{libsubdir}
+%else
+# 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
+%endif
+%endif
+%if %{build_ada}
+mv $RPM_BUILD_ROOT%{_infodir}/gnat-style.info $RPM_BUILD_ROOT%{_infodir}/gnat-style%{binsuffix}.info
+mv $RPM_BUILD_ROOT%{_infodir}/gnat_rm.info $RPM_BUILD_ROOT%{_infodir}/gnat_rm%{binsuffix}.info
+mv $RPM_BUILD_ROOT%{_infodir}/gnat_ugn.info $RPM_BUILD_ROOT%{_infodir}/gnat_ugn%{binsuffix}.info
+%endif
+%endif
+
+
+
+%if %{build_java}
+%if 0%{?building_libjava:1}
+%files -n gcc49-java
+%defattr(-,root,root)
+%{_prefix}/bin/gcj%{binsuffix}
+%{_prefix}/bin/gcjh%{binsuffix}
+%{_prefix}/bin/gcj-dbtool%{binsuffix}
+%{_prefix}/bin/jcf-dump%{binsuffix}
+%{_prefix}/bin/jv-convert%{binsuffix}
+%{_prefix}/bin/gc-analyze%{binsuffix}
+%{_prefix}/bin/aot-compile%{binsuffix}
+%{_prefix}/bin/rebuild-gcj-db%{binsuffix}
+%{libsubdir}/jc1
+%{libsubdir}/jvgenmain
+%{libsubdir}/ecj.jar
+%{libsubdir}/ecj1
+%doc %{_mandir}/man1/gcj%{binsuffix}.1.gz
+%doc %{_mandir}/man1/gcjh%{binsuffix}.1.gz
+%doc %{_mandir}/man1/gcj-dbtool%{binsuffix}.1.gz
+%doc %{_mandir}/man1/jcf-dump%{binsuffix}.1.gz
+%doc %{_mandir}/man1/jv-convert%{binsuffix}.1.gz
+%doc %{_mandir}/man1/gc-analyze%{binsuffix}.1.gz
+%doc %{_mandir}/man1/aot-compile%{binsuffix}.1.gz
+%doc %{_mandir}/man1/rebuild-gcj-db%{binsuffix}.1.gz
+%endif
+%endif
+
+%if %{build_java}
+%if %{build_libjava}
+%files 
+%defattr(-,root,root)
+%dir %{libsubdir}/gcj-%{gcc_dir_version}-%{libgcj_sover}
+%dir %{_libdir}/gcc
+%dir %{_libdir}/gcc/%{GCCDIST}
+%dir %{libsubdir}
+%{libsubdir}/gcj-%{gcc_dir_version}-%{libgcj_sover}/classmap.db
+# We usually do not multilib libjava
+%if %{biarch_libjava}
+%versbiarchlib libgcj.la
+%biarchlib libgcj.so.*
+%biarchlib libgij.so.*
+%biarchlib libgcj-tools.so.*
+%else
+%versmainlib libgcj.la
+%mainlib libgcj.so.*
+%mainlib libgij.so.*
+%mainlib libgcj-tools.so.*
+%endif
+%{libsubdir}/gcj-%{gcc_dir_version}-%{libgcj_sover}/libjvm.la
+%{libsubdir}/gcj-%{gcc_dir_version}-%{libgcj_sover}/libjvm.so
+%{libsubdir}/gcj-%{gcc_dir_version}-%{libgcj_sover}/libjavamath.la
+%{libsubdir}/gcj-%{gcc_dir_version}-%{libgcj_sover}/libjavamath.so
+
+%files -n libgcj_bc%{libgcj_bc_sover}%{libgcj_bc_suffix}
+%defattr(-,root,root)
+%if %{biarch_libjava}
+%biarchlib libgcj_bc.so.%{libgcj_bc_sover}*
+%else
+%mainlib libgcj_bc.so.%{libgcj_bc_sover}*
+%endif
+
+%files -n libgcj49-jar
+%defattr(-,root,root)
+%{_prefix}/share/java/libgcj-%{gcc_dir_version}.jar
+%{_prefix}/share/java/libgcj-tools-%{gcc_dir_version}.jar
+
+%files -n libgcj49-devel
+%defattr(-,root,root)
+%dir %{_prefix}/include/c++
+%dir %{libsubdir}
+%dir %{libsubdir}/include
+%dir %{gxxinclude}
+%{_libdir}/pkgconfig/libgcj%{binsuffix}.pc
+%{libsubdir}/include/jawt.h
+%{libsubdir}/include/jawt_md.h
+%{libsubdir}/include/jni.h
+%{libsubdir}/include/jni_md.h
+%{libsubdir}/include/jvmpi.h
+%{gxxinclude}/gnu
+%{gxxinclude}/gcj
+%{gxxinclude}/java
+%{gxxinclude}/javax
+%{gxxinclude}/org
+%{gxxinclude}/sun
+%{libsubdir}/include/gcj
+%if %{biarch_libjava}
+%versbiarchlib libgcj.so
+%versbiarchlib libgcj.spec
+%versbiarchlib libgcj-tools.so
+%versbiarchlib libgij.so
+%versbiarchlib libgcj_bc.so
+%else
+%versmainlib libgcj.so
+%versmainlib libgcj.spec
+%versmainlib libgcj-tools.so
+%versmainlib libgij.so
+%versmainlib libgcj_bc.so
+%endif
+
+%files -n gcc49-gij
+%defattr(-,root,root)
+%{_prefix}/bin/gij%{binsuffix}
+%{_prefix}/bin/gappletviewer%{binsuffix}
+%{_prefix}/bin/gjar%{binsuffix}
+%{_prefix}/bin/gjarsigner%{binsuffix}
+%{_prefix}/bin/gjavah%{binsuffix}
+%{_prefix}/bin/gkeytool%{binsuffix}
+%{_prefix}/bin/gnative2ascii%{binsuffix}
+%{_prefix}/bin/gorbd%{binsuffix}
+%{_prefix}/bin/grmic%{binsuffix}
+%{_prefix}/bin/grmid%{binsuffix}
+%{_prefix}/bin/grmiregistry%{binsuffix}
+%{_prefix}/bin/gserialver%{binsuffix}
+%{_prefix}/bin/gtnameserv%{binsuffix}
+%doc %{_mandir}/man1/gij%{binsuffix}.1.gz
+%doc %{_mandir}/man1/gappletviewer%{binsuffix}.1.gz
+%doc %{_mandir}/man1/grmic%{binsuffix}.1.gz
+%doc %{_mandir}/man1/grmid%{binsuffix}.1.gz
+%doc %{_mandir}/man1/grmiregistry%{binsuffix}.1.gz
+%doc %{_mandir}/man1/gkeytool%{binsuffix}.1.gz
+%doc %{_mandir}/man1/gjar%{binsuffix}.1.gz
+%doc %{_mandir}/man1/gjarsigner%{binsuffix}.1.gz
+%doc %{_mandir}/man1/gjavah%{binsuffix}.1.gz
+%doc %{_mandir}/man1/gnative2ascii%{binsuffix}.1.gz
+%doc %{_mandir}/man1/gorbd%{binsuffix}.1.gz
+%doc %{_mandir}/man1/gserialver%{binsuffix}.1.gz
+%doc %{_mandir}/man1/gtnameserv%{binsuffix}.1.gz
+%endif
+%endif
+
+%if 0%{?building_libjava:1}
+%files -n libstdc++49-doc
+%defattr(-,root,root)
+%doc libstdc++-v3/doc/html
+%endif
+
+%if %{build_java}
+%if 0%{?building_libffi:1}
+%files -n libffi%{libffi_sover}%{libffi_suffix}
+%defattr(-,root,root)
+%mainlib libffi.so.%{libffi_sover}*
+
+%if %{separate_biarch}
+%files -n libffi%{libffi_sover}%{libffi_suffix}%{separate_biarch_suffix}
+%defattr(-,root,root)
+%biarchlib libffi.so.%{libffi_sover}*
+%endif
+
+%post -n libffi49-devel
+%install_info --info-dir=%{_infodir} %{_infodir}/libffi%{binsuffix}.info.gz
+%postun -n libffi49-devel
+%install_info_delete --info-dir=%{_infodir} %{_infodir}/libffi%{binsuffix}.info.gz
+
+%files -n libffi49-devel
+%defattr(-,root,root)
+%{_prefix}/include/ffi.h
+%{_prefix}/include/ffitarget.h
+%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 libffi49-devel%{separate_biarch_suffix}
+%defattr(-,root,root)
+%biarchlib libffi.so
+%biarchlib libffi.a
+%endif
+%endif
+%endif
+
+%if %{build_go}
+%files go
+%{_prefix}/bin/gccgo%{binsuffix}
+%{libsubdir}/go1
+%versmainlib libgo.a
+%versmainlib libgo.so
+%versmainlib libgobegin.a
+%dir %mainlibdir/go
+%dir %mainlibdir/go/%{gcc_dir_version}
+%mainlibdir/go/%{gcc_dir_version}/%{GCCDIST}
+%doc %{_mandir}/man1/gccgo%{binsuffix}.1.gz
+
+%if %{separate_biarch}
+%files go%{separate_biarch_suffix}
+%versbiarchlib libgo.a
+%versbiarchlib libgo.so
+%versbiarchlib libgobegin.a
+%dir %mainlibdirbi/go
+%dir %mainlibdirbi/go/%{gcc_dir_version}
+%mainlibdirbi/go/%{gcc_dir_version}/%{GCCDIST}
+%endif
+
+%files -n libgo%{libgo_sover}%{libgo_suffix}
+%defattr(-,root,root)
+%mainlib libgo.so.%{libgo_sover}*
+
+%if %{separate_biarch}
+%files -n libgo%{libgo_sover}%{libgo_suffix}%{separate_biarch_suffix}
+%defattr(-,root,root)
+%biarchlib libgo.so.%{libgo_sover}*
+%endif
+%endif
+
+%if 0%{?run_tests:1}
+%files -n gcc49-testresults
+%defattr(-,root,root)
+%doc testresults/test_summary.txt
+%doc testresults/*.sum
+%doc testresults/*.log
+%endif
+
+
+%changelog
diff --git a/packaging/pre_checkin.sh b/packaging/pre_checkin.sh
new file mode 100755 (executable)
index 0000000..8b8cb59
--- /dev/null
@@ -0,0 +1,27 @@
+#!/bin/bash
+# This script is called automatically during autobuild checkin.
+case $0 in
+  \./*)
+    here=$PWD
+    ;;
+  */*)
+    here=${0%/*}
+    ;;
+  *)
+    here=$PWD
+    ;;
+esac
+_here=$here
+# remove packaging/
+_here=${here/\/packaging/}
+case ${_here##*/} in
+  gcc-*)
+    suffix=${_here##*/}
+    set ${suffix#*-}-
+    ;;
+  gcc[0-9]*)
+    suffix=${_here##*/}
+    set ${suffix#gcc}
+    ;;
+esac
+. ${here}/change_spec