Hello community,

here is the log from the commit of package gcc47 for openSUSE:12.2 checked in 
at 2012-07-01 20:59:39
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Comparing /work/SRC/openSUSE:12.2/gcc47 (Old)
 and      /work/SRC/openSUSE:12.2/.gcc47.new (New)
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

Package is "gcc47", Maintainer is ""

Changes:
--------
--- /work/SRC/openSUSE:12.2/gcc47/cross-armv5el-gcc47-icecream-backend.changes  
2012-06-26 15:37:28.000000000 +0200
+++ 
/work/SRC/openSUSE:12.2/.gcc47.new/cross-armv5el-gcc47-icecream-backend.changes 
    2012-07-02 10:43:55.000000000 +0200
@@ -1,0 +2,6 @@
+Fri Jun 29 08:42:19 UTC 2012 - [email protected]
+
+- Adjust arm icecream cross for continued change of the canonical
+  target used in binutils.
+
+-------------------------------------------------------------------
New Changes file:

--- /dev/null   2012-06-28 07:48:42.835576985 +0200
+++ 
/work/SRC/openSUSE:12.2/.gcc47.new/cross-armv7hl-gcc47-icecream-backend.changes 
    2012-07-02 10:43:55.000000000 +0200
@@ -0,0 +1,172 @@
+-------------------------------------------------------------------
+Fri Jun 29 08:42:19 UTC 2012 - [email protected]
+
+- Adjust arm icecream cross for continued change of the canonical
+  target used in binutils.
+
+-------------------------------------------------------------------
+Tue Jun 26 08:03:03 UTC 2012 - [email protected]
+
+- Require a version of libquadmath0 at least as new as the
+  libgfortran3 library from the latter.  [bnc#768785]
+
+-------------------------------------------------------------------
+Fri Jun 22 11:03:09 UTC 2012 - [email protected]
+
+- complete armv7hl switch
+
+-------------------------------------------------------------------
+Wed Jun 20 15:13:58 UTC 2012 - [email protected]
+
+- Use new dynamic linker path /lib/ld-linux-armhf.so.3 for ARM v7.
+
+-------------------------------------------------------------------
+Tue Jun 19 08:08:02 UTC 2012 - [email protected]
+
+- do not build cross environments on architectures that
+  are not native
+
+-------------------------------------------------------------------
+Thu Jun 15 13:08:54 UTC 2012 - [email protected]
+
+- Update to gcc-4_7-branch head (r188649).
+  * Includes GCC 4.7.1 release.
+
+-------------------------------------------------------------------
+Wed Jun  6 08:54:04 UTC 2012 - [email protected]
+
+- Explicitely specify target tools used for building.
+
+-------------------------------------------------------------------
+Mon Jun  4 11:10:00 UTC 2012 - [email protected]
+
+- Update to gcc-4_7-branch head (r188177).
+
+-------------------------------------------------------------------
+Fri Jun  1 09:01:40 UTC 2012 - [email protected]
+
+- Fix typo in cross-icecream.spec.in.
+- Also dump test-summary to the build log.
+
+-------------------------------------------------------------------
+Wed May 30 14:13:54 UTC 2012 - [email protected]
+
+- Update patch for PR52080.
+
+-------------------------------------------------------------------
+Mon May  7 09:35:56 UTC 2012 - [email protected]
+
+- Update to gcc-4_7-branch head (r187228).
+- Add patch for PR52841.
+
+-------------------------------------------------------------------
+Thu Apr 19 11:32:05 UTC 2012 - [email protected]
+
+- Fix canonicalized target names for crosses.
+- Enable icecream backends, make their package name version specific.
+
+-------------------------------------------------------------------
+Fri Apr 13 12:47:22 UTC 2012 - [email protected]
+
+- Update to gcc-4_7-branch head (r186417).
+- Fix libstdc++.so-gdb.py autoload script.  [bnc#750960]
+- Drop to release checking.
+- Fix build of cross targets with canonicalized name.
+
+-------------------------------------------------------------------
+Thu Mar 22 12:06:49 UTC 2012 - [email protected]
+
+- Update to GCC 4.7.0 release.
+- Update to gcc-4_7-branch head (r185687).
+
+-------------------------------------------------------------------
+Tue Mar 20 11:53:04 UTC 2012 - [email protected]
+
+- Package the gdb python scripts.  [bnc#750960]
+
+-------------------------------------------------------------------
+Mon Mar 19 12:13:21 UTC 2012 - [email protected]
+
+- Change armv5 to use soft floating-point.
+
+-------------------------------------------------------------------
+Tue Mar 13 12:59:26 UTC 2012 - [email protected]
+
+- Update to gcc-4_7-branch head (r185330).
+
+-------------------------------------------------------------------
+Fri Mar  2 13:50:22 UTC 2012 - [email protected]
+
+- Update to GCC 4.7.0 release candidate.
+- Fixup libstdc++v3 symbol baselines on powerpc.
+
+-------------------------------------------------------------------
+Wed Feb 29 09:03:10 UTC 2012 - [email protected]
+
+- Fixup more SPDX license issues.
+
+-------------------------------------------------------------------
+Tue Feb 28 13:10:03 UTC 2012 - [email protected]
+
+- Update to SVN trunk head (r184624).
+- Merge changes from GCC 4.6 package.
+
+-------------------------------------------------------------------
+Fri Feb 24 09:35:29 UTC 2012 - [email protected]
+
+- Update to SVN trunk head (r184541).
+
+-------------------------------------------------------------------
+Tue Feb 21 13:05:10 UTC 2012 - [email protected]
+
+- Update to SVN trunk head (r184435).
+- Merge changes from GCC 4.6 package.
+- Add patches for PR49484 and PR52080.
+
+-------------------------------------------------------------------
+Wed Feb  8 11:14:05 UTC 2012 - [email protected]
+
+- Update to SVN trunk head (r184004).
+
+-------------------------------------------------------------------
+Tue Jan 31 10:35:44 UTC 2012 - [email protected]
+
+- Update to SVN trunk head (r183753).
+- Merge changes from GCC 4.6 package.
+
+-------------------------------------------------------------------
+Tue Jan 24 14:46:07 UTC 2012 - [email protected]
+
+- Drop AWT support from libgcj.  [bnc#742935]
+
+-------------------------------------------------------------------
+Wed Jan 18 14:48:06 UTC 2012 - [email protected]
+
+- Update to SVN trunk head (r183273).
+
+-------------------------------------------------------------------
+Wed Jan 11 11:51:29 UTC 2012 - [email protected]
+
+- Update to SVN trunk head (r183092).
+- Merge changes from GCC 4.6 package.
+
+-------------------------------------------------------------------
+Wed Jan  4 13:36:37 UTC 2012 - [email protected]
+
+- Update to SVN trunk head (r182872).
+
+-------------------------------------------------------------------
+Tue Dec 20 10:48:33 UTC 2011 - [email protected]
+
+- Update to SVN trunk head (r182525).
+
+-------------------------------------------------------------------
+Sun Dec 18 11:10:32 UTC 2011 - [email protected]
+
+- fix file list for arm architecture
+
+-------------------------------------------------------------------
+Thu Nov  3 15:23:33 UTC 2011 - [email protected]
+
+- New package.
+
--- /work/SRC/openSUSE:12.2/gcc47/cross-hppa-gcc47-icecream-backend.changes     
2012-06-26 15:37:28.000000000 +0200
+++ 
/work/SRC/openSUSE:12.2/.gcc47.new/cross-hppa-gcc47-icecream-backend.changes    
    2012-07-02 10:43:55.000000000 +0200
@@ -1,0 +2,6 @@
+Fri Jun 29 08:42:19 UTC 2012 - [email protected]
+
+- Adjust arm icecream cross for continued change of the canonical
+  target used in binutils.
+
+-------------------------------------------------------------------
cross-i386-gcc47-icecream-backend.changes: same change
cross-ia64-gcc47-icecream-backend.changes: same change
cross-ppc-gcc47-icecream-backend.changes: same change
cross-ppc64-gcc47-icecream-backend.changes: same change
cross-s390-gcc47-icecream-backend.changes: same change
cross-s390x-gcc47-icecream-backend.changes: same change
cross-x86_64-gcc47-icecream-backend.changes: same change
gcc47-testresults.changes: same change
gcc47.changes: same change
libffi47.changes: same change
libgcj47.changes: same change

Old:
----
  cross-armv7l-gcc47-icecream-backend.changes
  cross-armv7l-gcc47-icecream-backend.spec

New:
----
  cross-armv7hl-gcc47-icecream-backend.changes
  cross-armv7hl-gcc47-icecream-backend.spec

++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

Other differences:
------------------
++++++ cross-armv5el-gcc47-icecream-backend.spec ++++++
--- /var/tmp/diff_new_pack.TTIgYl/_old  2012-07-02 10:43:58.000000000 +0200
+++ /var/tmp/diff_new_pack.TTIgYl/_new  2012-07-02 10:43:58.000000000 +0200
@@ -36,6 +36,9 @@
 %define binutils_target arm
 %endif
 %define canonical_target %(echo %{binutils_target} | sed -e 
"s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;")
+%if %{binutils_target} == "arm"
+%define canonical_target_abi gnueabi-
+%endif
 
 Name:           cross-armv5el-gcc47-icecream-backend
 BuildRequires:  bison
@@ -461,7 +464,7 @@
 
 # But the assembler comes from the cross-binutils, and hence is _not_
 # named funnily, not even on ppc, so there we need the original target
-install -s -D %{_prefix}/bin/%{canonical_target}-suse-linux-as \
+install -s -D 
%{_prefix}/bin/%{canonical_target}-suse-linux-%{?canonical_target_abi:%canonical_target_abi}as
 \
        $RPM_BUILD_ROOT/env/usr/bin/as
 install -s $RPM_BUILD_ROOT/inst%{_prefix}/bin/%{CONFIGURE_TARGET}-g++ \
        $RPM_BUILD_ROOT/env/usr/bin/g++

++++++ cross-armv7hl-gcc47-icecream-backend.spec ++++++
#
# spec file for package cross-armv7hl-gcc47-icecream-backend
#
# Copyright (c) 2012 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/
#


%define build_cp 1
%define build_ada 0
%define build_libjava 0
%define build_java 0
%define build_fortran 0
%define build_objc 0
%define build_objcp 0
%define build_nof 0
%define build_with_mudflap 0
%define gcc_target_arch armv7hl-suse-linux
%define gcc_icecream 1

%define binutils_target armv7hl
%if %{binutils_target} == "armv7l" || %{binutils_target} == "armv7hl"
%define binutils_target arm
%endif
%if %{binutils_target} == "armv5el"
%define binutils_target arm
%endif
%define canonical_target %(echo %{binutils_target} | sed -e 
"s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;")
%if %{binutils_target} == "arm"
%define canonical_target_abi gnueabi-
%endif

Name:           cross-armv7hl-gcc47-icecream-backend
BuildRequires:  bison
BuildRequires:  cross-%{binutils_target}-binutils
BuildRequires:  flex
BuildRequires:  gettext-devel
BuildRequires:  glibc-devel-32bit
BuildRequires:  mpc-devel
BuildRequires:  mpfr-devel
BuildRequires:  perl
BuildRequires:  texinfo
BuildRequires:  zlib-devel
%ifarch %ix86 x86_64 ppc ppc64 s390 s390x ia64 %sparc
BuildRequires:  cloog-devel
BuildRequires:  libelf-devel
BuildRequires:  ppl-devel
%endif
%ifarch ia64
BuildRequires:  libunwind-devel
%endif
ExclusiveArch:  ppc ppc64 %ix86 x86_64 ia64 
%define _binary_payload w.ufdio

# COMMON-BEGIN
# COMMON-BEGIN
%define biarch_targets x86_64 s390x powerpc64 powerpc sparc sparc64

Url:            http://gcc.gnu.org/
Version:        4.7.1_20120615
Release:        0
%define gcc_version %(echo %version | sed 's/_.*//')
%define gcc_dir_version %(echo %gcc_version | cut -d '.' -f 1-2)
%define snapshot_date %(echo %version | sed 's/[34]\.[0-9]\.[0-6]//' | sed 
's/_/-/')
%define binsuffix -4.7
# COMMON-END
# COMMON-BEGIN
BuildRoot:      %{_tmppath}/%{name}-%{version}-build
Source:         gcc-%{gcc_version}%{snapshot_date}.tar.bz2
Source1:        change_spec
Source2:        libgcj47-rpmlintrc
Source3:        gcc47-rpmlintrc
Source4:        ecj.jar
Source5:        README.First-for.SuSE.packagers
Source6:        baselibs.conf
Patch1:         gcc-dir-version.patch
Patch2:         gcc-sles-version.patch
Patch3:         gcc-noalias-warn.diff
Patch6:         suse-record-gcc-opts.diff
Patch7:         gcc-add-defaultsspec.diff
Patch8:         Wunprototyped-calls.diff
Patch10:        program-transform-name.diff
Patch12:        gcc4-ppc64-m32-m64-multilib-only.patch
Patch23:        libjava-no-multilib.diff
Patch24:        tls-no-direct.diff
Patch28:        pr33763.diff
Patch30:        gcc43-no-unwind-tables.diff
Patch32:        pr49484.diff
Patch33:        gcc-arm-linker.patch
# A set of patches from the RH srpm
Patch51:        gcc41-ia64-stack-protector.patch
Patch55:        gcc41-java-slow_pthread_self.patch
Patch57:        gcc41-ppc32-retaddr.patch
# Some patches taken from Debian
Patch60:        gcc44-textdomain.patch
Patch61:        gcc44-rename-info-files.patch
# Patches for SAP features
Patch130:       sap303956-uchar.diff

# GCC-TESTSUITE-DELETE-BEGIN
# LIBFFI-DELETE-BEGIN
# LIBJAVA-DELETE-BEGIN
Summary:        The GNU C Compiler and Support Files
License:        GPL-3.0+
Group:          Development/Languages/C and C++

%description
Core package for the GNU Compiler Collection, including the C language
frontend.

Language frontends other than C are split to different sub-packages,
namely gcc-ada, gcc-c++, gcc-fortran, gcc-java, gcc-objc and
gcc-obj-c++.



# COMMON-END
# COMMON-BEGIN

# Define the canonical target and host architecture
#   %gcc_target_arch  is supposed to be the full target triple
#   %TARGET_ARCH      is the canonicalized CPU part
#   %CONFIGURE_TARGET is the target triple used for --target=
%if 0%{?gcc_target_arch:1}
%define CONFIGURE_TARGET %{gcc_target_arch}
%define TARGET_ARCH %(echo %{gcc_target_arch} | cut -d - -f 1 | sed -e 
"s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;")
%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "powerpc"
%define CONFIGURE_TARGET powerpc64-suse-linux
%endif
%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "powerpc64"
%define CONFIGURE_TARGET powerpc64-suse-linux
%endif
%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "i586"
%define CONFIGURE_TARGET i586-suse-linux
%endif
%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "armv7l"
%define CONFIGURE_TARGET armv7l-suse-linux-gnueabi
%endif
%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "armv7hl"
%define CONFIGURE_TARGET armv7hl-suse-linux-gnueabi
%endif
%if 0%{?gcc_icecream:1} && %{TARGET_ARCH} == "armv5el"
%define CONFIGURE_TARGET armv5el-suse-linux-gnueabi
%endif
%else
%define TARGET_ARCH %(echo %{_target_cpu} | sed -e 
"s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;")
%endif
%define HOST_ARCH %(echo %{_host_cpu} | sed -e 
"s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;")

%define biarch %(case " %{biarch_targets} " in (*" %{TARGET_ARCH} "*) echo 1;; 
(*) echo 0;; esac)

%ifarch ppc
%define GCCDIST powerpc64-suse-linux
%else
%ifarch %sparc
%define GCCDIST sparc64-suse-linux
%else
%ifarch %arm
%define GCCDIST %{HOST_ARCH}-suse-linux-gnueabi
%else
%define GCCDIST %{HOST_ARCH}-suse-linux
%endif
%endif
%endif

%define libsubdir %{_libdir}/gcc/%{GCCDIST}/%{gcc_dir_version}
%define gxxinclude %{_prefix}/include/c++/%{gcc_dir_version}

# COMMON-END
# COMMON-BEGIN

%prep
%setup -q -n gcc-%{gcc_version}%{snapshot_date}
%patch1
%patch2
%patch3
%patch6
%patch7
%patch8
%patch10
%if !%{build_nof}
%patch12
%endif
%patch23
%patch24
%patch28
%patch30
%patch32
%patch33 -p1
%patch51
%patch55
%patch57
%patch60
%patch61
%patch130
# 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 SUSE_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 test `cat gcc/DEV-PHASE` == "prerelease"; then
  ( cat gcc/BASE-VER | cut -d '.' -f 1-2 | tr -d '\n'; echo -n .; cat 
gcc/BASE-VER | cut -d '.' -f 3 | tr '0123456789' '0012345678' ) > gcc/FULL-VER
else
  mv gcc/BASE-VER gcc/FULL-VER
fi
cat gcc/FULL-VER | cut -d '.' -f 1-2 > gcc/BASE-VER

rm -rf obj-%{GCCDIST}
mkdir obj-%{GCCDIST}
cd obj-%{GCCDIST}
RPM_OPT_FLAGS="$RPM_OPT_FLAGS -U_FORTIFY_SOURCE"
RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-fno-rtti//g' -e 
's/-fno-exceptions//g' -e 's/-Wmissing-format-attribute//g' -e 
's/-fstack-protector//g' -e 's/-ffortify=.//g' -e 's/-Wall//g' -e 's/-m32//g' 
-e 's/-m64//g'`
%ifarch %ix86
# -mcpu is superceded by -mtune but -mtune is not supported by
# our bootstrap compiler.  -mcpu gives a warning that stops
# the build process, so remove it for now.  Also remove all other
# -march and -mtune flags.  They are superseeded by proper
# default compiler settings now.
RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-mcpu=i.86//g' -e 
's/-march=i.86//g' -e 's/-mtune=i.86//g'`
%endif
%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

J=%{?jobs:%jobs}
if test -z "$J"; then
  J=$(getconf _NPROCESSORS_CONF)
  JL=$(($J * 2))
else
  test 1 -gt "$J" && J=1
  JL=$(($(getconf _NPROCESSORS_CONF)*2))
fi
if test "$J" == "0"; then
  J=1
fi
if test "$JL" == "0"; then
  JL=1
fi
PARALLEL="-j$J -l$JL"

# we don't want some miscompiles in the testsuite, or some fault in
# the compiler to kill the machine.  Hence we limit the amount of memory
# by the physical RAM plus half of swap
#MEM=$(free -m | awk '/^Mem:/ {print $2}')
#SWAP=$(free -m | awk '/^Swap:/ {print $2}')
#ulimit -v $(((MEM + SWAP/2)*1024))

# In general we want to ship release checking enabled compilers
# and run BETA with checking enabled.
#ENABLE_CHECKING="--enable-checking=yes"
ENABLE_CHECKING="--enable-checking=release"

# Work around tail/head -1 changes
export _POSIX2_VERSION=199209

# configure tries to parse include/features.h to detect
# if glibc supports SSP.  When cross compiling we would need
# to install a cross glibc, which we don't, or make the whole
# thing point to the native glibc, which is in /, hence the
# --with-sysroot=/

%if %{build_ada}
# Using the host gnatmake like
#   CC="gcc%{hostsuffix}" GNATBIND="gnatbind%{hostsuffix}"
#   GNATMAKE="gnatmake%{hostsuffix}"
# doesn't work due to PR33857, so an un-suffixed gnatmake has to be
# available
mkdir -p host-tools/bin
cp -a /usr/bin/gnatmake%{hostsuffix} host-tools/bin/gnatmake
cp -a /usr/bin/gnatlink%{hostsuffix} host-tools/bin/gnatlink
cp -a /usr/bin/gnatbind%{hostsuffix} host-tools/bin/gnatbind
cp -a /usr/bin/gcc%{hostsuffix} host-tools/bin/gcc
ln -sf /usr/%{_lib} host-tools/%{_lib}
export PATH="`pwd`/host-tools/bin:$PATH"
%endif
#%if 0%{?gcc_target_arch:1} && 0%{!?gcc_icecream:1}
#%else
#       --enable-threads=posix \
#%endif
#       --enable-shared \
CFLAGS="$RPM_OPT_FLAGS" CXXFLAGS="$RPM_OPT_FLAGS" XCFLAGS="$RPM_OPT_FLAGS" \
TCFLAGS="$RPM_OPT_FLAGS" GCJFLAGS="$RPM_OPT_FLAGS" \
../configure \
        --prefix=%{_prefix} \
        --infodir=%{_infodir} \
        --mandir=%{_mandir} \
        --libdir=%{_libdir} \
        --libexecdir=%{_libdir} \
        --enable-languages=$languages \
        $ENABLE_CHECKING \
        --with-gxx-include-dir=%{_prefix}/include/c++/%{gcc_dir_version} \
        --enable-ssp \
        --disable-libssp \
        --disable-libitm \
        --disable-plugin \
        --with-bugurl="http://bugs.opensuse.org/"; \
        --with-pkgversion="SUSE Linux" \
%if !%{build_libjava}
        --disable-libgcj \
%else
        --with-java-home=%{_libdir}/jvm/java-1.5.0-gcj%{binsuffix}-1.5.0.0/jre \
        --with-ecj-jar=%{libsubdir}/ecj.jar \
        --disable-java-awt \
%if !%{biarch_libjava}
        --disable-libjava-multilib \
%endif
%endif
%if !%{build_with_mudflap}
        --disable-libmudflap \
%endif
        --with-slibdir=/%{_lib} \
        --with-system-zlib \
        --enable-__cxa_atexit \
        --enable-libstdcxx-allocator=new \
        --disable-libstdcxx-pch \
        --enable-version-specific-runtime-libs \
%if 0%{suse_version} > 1100
        --enable-linker-build-id \
%endif
%if 0%{?gcc_target_arch:1}
%if 0%{?gcc_icecream:1}
        --with-sysroot=/ \
        --enable-linux-futex \
%endif
%if 0%{?canonical_target:1}
        --with-build-time-tools=/usr/%{canonical_target}-suse-linux/bin \
%endif
%if 0%{?build_static:1}
        --disable-shared \
%endif
%if "%{TARGET_ARCH}" == "spu"
        --with-sysroot=/usr/spu \
        --with-gxx-include-dir=%{_prefix}/spu/include/c++/%{gcc_dir_version} \
        --with-newlib \
%endif
        --disable-nls \
        --target=%{CONFIGURE_TARGET} \
%else
        --program-suffix=%{binsuffix} \
        --enable-linux-futex \
%ifarch ia64
        --with-system-libunwind \
%else
        --without-system-libunwind \
%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" || "%{TARGET_ARCH}" == "armv7hl"
        --with-arch=armv7-a \
        --with-tune=cortex-a9 \
        --with-float=hard \
        --with-mode=thumb \
        --with-abi=aapcs-linux \
        --with-fpu=vfpv3-d16 \
        --disable-sjlj-exceptions \
%endif
%if "%{TARGET_ARCH}" == "powerpc"
        --with-cpu=default32 \
        --enable-secureplt \
        --with-long-double-128 \
%endif
%if "%{TARGET_ARCH}" == "powerpc64"
        --with-cpu=power4 \
        --enable-secureplt \
        --with-long-double-128 \
%endif
%if "%{TARGET_ARCH}" == "sparc64"
        --with-cpu=ultrasparc \
        --with-long-double-128 \
%endif
%if "%{TARGET_ARCH}" == "sparc"
        --with-cpu=v8 \
        --with-long-double-128 \
%endif
%if "%{TARGET_ARCH}" == "i586"
        --with-arch-32=i586 \
        --with-tune=generic \
%endif
%if "%{TARGET_ARCH}" == "x86_64"
        --with-arch-32=i586 \
        --with-tune=generic \
%endif
%if "%{TARGET_ARCH}" == "s390"
        --with-tune=z196 --with-arch=z10 \
        --with-long-double-128 \
        --enable-decimal-float \
%endif
%if "%{TARGET_ARCH}" == "s390x"
        --with-tune=z196 --with-arch=z10 \
        --with-long-double-128 \
        --enable-decimal-float \
%endif
        --build=%{GCCDIST}

# COMMON-END
# COMMON-END

make %{?jobs:-j%jobs} all-gcc TARGET-gcc="cc1 cc1plus gcc-cross g++ native"

%install
cd obj-%{GCCDIST}
rm -rf $RPM_BUILD_ROOT
make -C gcc DESTDIR=$RPM_BUILD_ROOT/inst install-driver install-common
make DESTDIR=$RPM_BUILD_ROOT/inst maybe-install-lto-plugin

# But the assembler comes from the cross-binutils, and hence is _not_
# named funnily, not even on ppc, so there we need the original target
install -s -D 
%{_prefix}/bin/%{canonical_target}-suse-linux-%{?canonical_target_abi:%canonical_target_abi}as
 \
        $RPM_BUILD_ROOT/env/usr/bin/as
install -s $RPM_BUILD_ROOT/inst%{_prefix}/bin/%{CONFIGURE_TARGET}-g++ \
        $RPM_BUILD_ROOT/env/usr/bin/g++
install -s $RPM_BUILD_ROOT/inst%{_prefix}/bin/%{CONFIGURE_TARGET}-gcc \
        $RPM_BUILD_ROOT/env/usr/bin/gcc

%define targetlibsubdir %{_libdir}/gcc/%{CONFIGURE_TARGET}/%{gcc_dir_version}
for back in cc1 cc1plus; do 
        install -s -D $RPM_BUILD_ROOT/inst%{targetlibsubdir}/$back \
                $RPM_BUILD_ROOT/env%{targetlibsubdir}/$back
done
if test -f $RPM_BUILD_ROOT/inst%{targetlibsubdir}/liblto_plugin.so; then
  install -s -D $RPM_BUILD_ROOT/inst%{targetlibsubdir}/liblto_plugin.so \
                $RPM_BUILD_ROOT/env%{targetlibsubdir}/liblto_plugin.so
fi

libs=`for bin in $RPM_BUILD_ROOT/env/usr/bin/* 
$RPM_BUILD_ROOT/env%{targetlibsubdir}/*; do \
  ldd $bin | sed -n '\,^[^/]*\(/[^ ]*\).*,{ s//\1/; p; }'  ;\
done | sort -u `
for lib in $libs; do
   # Check wether the same library also exists in the parent directory,
   # and prefer that on the assumption that it is a more generic one.
   baselib=`echo "$lib" | sed 's,/[^/]*\(/[^/]*\)$,\1,'`
   test -f "$baselib" && lib=$baselib
   install -s -D $lib $RPM_BUILD_ROOT/env$lib
done
rm -rf $RPM_BUILD_ROOT/inst
cd $RPM_BUILD_ROOT/env
tar cvzf ../%{name}_%{_arch}.tar.gz *
cd ..
mkdir -p usr/share/icecream-envs
mv %{name}_%{_arch}.tar.gz usr/share/icecream-envs
rpm -q --changelog glibc >  usr/share/icecream-envs/%{name}_%{_arch}.glibc
rpm -q --changelog binutils >  usr/share/icecream-envs/%{name}_%{_arch}.binutils
rm -r env

%clean
rm -rf $RPM_BUILD_ROOT

%files
%defattr(-,root,root)
/usr/share/icecream-envs

%changelog
++++++ cross-hppa-gcc47-icecream-backend.spec ++++++
--- /var/tmp/diff_new_pack.TTIgYl/_old  2012-07-02 10:43:58.000000000 +0200
+++ /var/tmp/diff_new_pack.TTIgYl/_new  2012-07-02 10:43:58.000000000 +0200
@@ -36,6 +36,9 @@
 %define binutils_target arm
 %endif
 %define canonical_target %(echo %{binutils_target} | sed -e 
"s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;")
+%if %{binutils_target} == "arm"
+%define canonical_target_abi gnueabi-
+%endif
 
 Name:           cross-hppa-gcc47-icecream-backend
 BuildRequires:  bison
@@ -461,7 +464,7 @@
 
 # But the assembler comes from the cross-binutils, and hence is _not_
 # named funnily, not even on ppc, so there we need the original target
-install -s -D %{_prefix}/bin/%{canonical_target}-suse-linux-as \
+install -s -D 
%{_prefix}/bin/%{canonical_target}-suse-linux-%{?canonical_target_abi:%canonical_target_abi}as
 \
        $RPM_BUILD_ROOT/env/usr/bin/as
 install -s $RPM_BUILD_ROOT/inst%{_prefix}/bin/%{CONFIGURE_TARGET}-g++ \
        $RPM_BUILD_ROOT/env/usr/bin/g++

cross-i386-gcc47-icecream-backend.spec: same change
cross-ia64-gcc47-icecream-backend.spec: same change
cross-ppc-gcc47-icecream-backend.spec: same change
cross-ppc64-gcc47-icecream-backend.spec: same change
cross-s390-gcc47-icecream-backend.spec: same change
cross-s390x-gcc47-icecream-backend.spec: same change
cross-x86_64-gcc47-icecream-backend.spec: same change
gcc47.spec: same change
libffi47.spec: same change
libgcj47.spec: same change
++++++ change_spec ++++++
--- /var/tmp/diff_new_pack.TTIgYl/_old  2012-07-02 10:43:59.000000000 +0200
+++ /var/tmp/diff_new_pack.TTIgYl/_new  2012-07-02 10:43:59.000000000 +0200
@@ -113,7 +113,7 @@
 
 # disabled: mips, sparc, alpha
 if test "$do_icecream" = 1 ; then
-  for arch in hppa i386 x86_64 s390 s390x ppc ppc64 ia64 armv7l armv5el; do
+  for arch in hppa i386 x86_64 s390 s390x ppc ppc64 ia64 armv7hl armv5el; do
     exclarch=`echo $arch | sed -e 's/i.86/%ix86/'`
     { sed -n -e '1,/COMMON-BEGIN/p' cross-icecream.spec.in
       sed -n -e '/COMMON-BEGIN/,/COMMON-END/p' $outfile

++++++ cross-icecream.spec.in ++++++
--- /var/tmp/diff_new_pack.TTIgYl/_old  2012-07-02 10:43:59.000000000 +0200
+++ /var/tmp/diff_new_pack.TTIgYl/_new  2012-07-02 10:43:59.000000000 +0200
@@ -28,6 +28,9 @@
 %define binutils_target arm
 %endif
 %define canonical_target %(echo %{binutils_target} | sed -e 
"s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;")
+%if %{binutils_target} == "arm"
+%define canonical_target_abi gnueabi-
+%endif
 
 Name:         cross-@cross_arch@-gcc@base_ver@-icecream-backend
 BuildRequires: bison flex gettext-devel glibc-devel-32bit mpfr-devel perl 
texinfo zlib-devel mpc-devel
@@ -54,7 +57,7 @@
 
 # But the assembler comes from the cross-binutils, and hence is _not_
 # named funnily, not even on ppc, so there we need the original target
-install -s -D %{_prefix}/bin/%{canonical_target}-suse-linux-as \
+install -s -D 
%{_prefix}/bin/%{canonical_target}-suse-linux-%{?canonical_target_abi:%canonical_target_abi}as
 \
        $RPM_BUILD_ROOT/env/usr/bin/as
 install -s $RPM_BUILD_ROOT/inst%{_prefix}/bin/%{CONFIGURE_TARGET}-g++ \
        $RPM_BUILD_ROOT/env/usr/bin/g++


-- 
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]

Reply via email to