[rtems-crossrpms commit] New.

Ralf Corsepius ralf at rtems.org
Mon Nov 19 10:06:16 UTC 2012


Module:    rtems-crossrpms
Branch:    master
Commit:    15d1fb647f8b8fe55151aebb6557f66d5e388092
Changeset: http://git.rtems.org/rtems-crossrpms/commit/?id=15d1fb647f8b8fe55151aebb6557f66d5e388092

Author:    Ralf Corsépius <ralf.corsepius at rtems.org>
Date:      Sun Nov 18 10:20:58 2012 +0100

New.

---

 freebsd7.4/Makefile.am                           |    1 +
 freebsd7.4/binutils.am                           |   32 +
 freebsd7.4/gcc.am                                |   44 ++
 freebsd7.4/i586/Makefile.am                      |   21 +
 freebsd7.4/i586/binutils-sources.add             |    2 +
 freebsd7.4/i586/gcc-sources.add                  |   60 ++
 freebsd7.4/i586/i586-pc-freebsd7.4-binutils.spec |  170 +++++
 freebsd7.4/i586/i586-pc-freebsd7.4-gcc.spec      |  827 ++++++++++++++++++++++
 freebsd7.4/i586/i586-pc-freebsd7.4-libs.spec     |  206 ++++++
 freebsd7.4/i586/libs.add                         |   98 +++
 freebsd7.4/i586/target-libs.add                  |   11 +
 freebsd7.4/libs.am                               |   18 +
 12 files changed, 1490 insertions(+), 0 deletions(-)

diff --git a/freebsd7.4/Makefile.am b/freebsd7.4/Makefile.am
new file mode 100644
index 0000000..44484ed
--- /dev/null
+++ b/freebsd7.4/Makefile.am
@@ -0,0 +1 @@
+SUBDIRS = i586
diff --git a/freebsd7.4/binutils.am b/freebsd7.4/binutils.am
new file mode 100644
index 0000000..f109d8c
--- /dev/null
+++ b/freebsd7.4/binutils.am
@@ -0,0 +1,32 @@
+EXTRA_DIST += binutils-sources.add
+
+BINUTILS_OPTS =
+
+BINUTILS_SUBPACKAGES = $(top_srcdir)/common/common.add
+BINUTILS_SUBPACKAGES += $(top_srcdir)/binutils/binutils.add
+BINUTILS_SUBPACKAGES += $(top_srcdir)/binutils/prep.add
+BINUTILS_SUBPACKAGES += $(top_srcdir)/binutils/build.add
+BINUTILS_SUBPACKAGES += $(top_srcdir)/binutils/install.add
+BINUTILS_SUBPACKAGES += $(top_srcdir)/binutils/rpm-install.add
+BINUTILS_SUBPACKAGES += $(top_srcdir)/common/clean.add
+BINUTILS_SUBPACKAGES += $(top_srcdir)/binutils/target-binutils.add
+BINUTILS_SUBPACKAGES += $(top_srcdir)/binutils/base-binutils.add
+
+$(TARGET)-binutils.spec.in: $(BINUTILS_SUBPACKAGES) Makefile.am $(srcdir)/binutils-sources.add
+	cat $(BINUTILS_SUBPACKAGES) | sed \
+	  -e "/[@]SOURCES[@]/r $(srcdir)/binutils-sources.add" \
+	  -e "/[@]SOURCES[@]/d" \
+	  -e "s/[@]BINUTILS_VERS[@]/$(BINUTILS_VERS)/g" \
+	  -e "s/[@]BINUTILS_PKGVERS[@]/$(BINUTILS_PKGVERS)/g" \
+	  -e "s/[@]BINUTILS_RPMREL[@]/$(BINUTILS_RPMREL)%{?dist}/g" \
+	  | $(MKSPEC0) > $(TARGET)-binutils.spec.in
+CLEANFILES += $(TARGET)-binutils.spec.in
+
+ at rpmprefix@$(TARGET)-binutils.spec: $(TARGET)-binutils.spec.in
+	$(MKSPEC) $(TARGET)-binutils.spec.in | $(SPECSTRIP) $(BINUTILS_OPTS) > $@
+if CUSTOM_RPMPREFIX
+CLEANFILES += @rpmprefix@$(TARGET)-binutils.spec
+endif
+noinst_DATA += @rpmprefix@$(TARGET)-binutils.spec
+
+EXTRA_DIST += $(BINUTILS_SUBPACKAGES)
diff --git a/freebsd7.4/gcc.am b/freebsd7.4/gcc.am
new file mode 100644
index 0000000..a5360f1
--- /dev/null
+++ b/freebsd7.4/gcc.am
@@ -0,0 +1,44 @@
+EXTRA_DIST += $(srcdir)/../gcc-prep.add
+EXTRA_DIST += $(srcdir)/gcc-sources.add
+
+GCC_OPTS =
+
+GCC_SUBPACKAGES = $(top_srcdir)/common/common.add
+GCC_SUBPACKAGES += $(top_srcdir)/gcc/gccnewlib.add
+GCC_SUBPACKAGES += $(top_srcdir)/gcc/prep.add
+GCC_SUBPACKAGES += $(top_srcdir)/gcc/build.add
+GCC_SUBPACKAGES += $(top_srcdir)/gcc/install.add
+GCC_SUBPACKAGES += $(top_srcdir)/gcc/rpm-install.add
+GCC_SUBPACKAGES += $(top_srcdir)/common/clean.add
+GCC_SUBPACKAGES += $(top_srcdir)/gcc/target-gcc.add
+GCC_SUBPACKAGES += $(top_srcdir)/gcc/base-gcc.add
+GCC_SUBPACKAGES += $(top_srcdir)/gcc/target-c++.add
+GCC_SUBPACKAGES += $(top_srcdir)/gcc/target-gfortran.add
+GCC_SUBPACKAGES += $(top_srcdir)/gcc/base-gfortran.add
+GCC_SUBPACKAGES += $(top_srcdir)/gcc/target-objc.add
+
+$(TARGET)-gcc.spec.in: $(GCC_SUBPACKAGES) Makefile.am $(srcdir)/gcc-sources.add $(srcdir)/../gcc-prep.add $(srcdir)/../gcc.am
+	cat $(GCC_SUBPACKAGES) \
+	  | sed \
+	  -e "/[@]SOURCES[@]/r $(srcdir)/gcc-sources.add" \
+	  -e "/[@]SOURCES[@]/d" \
+	  -e "/[@]PREP[@]/r $(srcdir)/../gcc-prep.add" \
+	  -e "/[@]PREP[@]/d" \
+	  | sed \
+	  -e "s/[@]GCC_VERS[@]/$(GCC_VERS)/g" \
+	  -e "s/[@]GCC_PKGVERS[@]/$(GCC_PKGVERS)/g" \
+	  -e "s/[@]GCC_RPMREL[@]/$(GCC_RPMREL)%{?dist}/g" \
+	  -e "/[@]tool_target[@]-newlib/d" \
+	  -e "/[@]tool_target[@]-w32api-sys-root/d" \
+	  -e "/--with-newlib/d" \
+	  | $(MKSPEC0) > $(TARGET)-gcc.spec.in
+CLEANFILES += $(TARGET)-gcc.spec.in
+
+ at rpmprefix@$(TARGET)-gcc.spec: $(TARGET)-gcc.spec.in
+	$(MKSPEC) $(TARGET)-gcc.spec.in | $(SPECSTRIP) $(GCC_OPTS) > $@
+if CUSTOM_RPMPREFIX
+CLEANFILES += @rpmprefix@$(TARGET)-gcc.spec
+endif
+noinst_DATA += @rpmprefix@$(TARGET)-gcc.spec
+
+EXTRA_DIST += $(GCC_SUBPACKAGES)
diff --git a/freebsd7.4/i586/Makefile.am b/freebsd7.4/i586/Makefile.am
new file mode 100644
index 0000000..70ee9a8
--- /dev/null
+++ b/freebsd7.4/i586/Makefile.am
@@ -0,0 +1,21 @@
+TARGET = i586-pc-freebsd7.4
+
+include $(top_srcdir)/mkspec.am
+
+FREEBSD_VERS = 7.4
+FREEBSD_RPMREL = 0.20121118.0
+EXTRA_DIST += libs.add
+EXTRA_DIST += target-libs.add
+include ../libs.am
+
+BINUTILS_VERS = 2.22
+BINUTILS_PKGVERS = $(BINUTILS_VERS)
+BINUTILS_RPMREL = 0.20120919.0
+include ../binutils.am
+BINUTILS_OPTS +=
+
+GCC_VERS = 4.7.1
+GCC_PKGVERS = $(GCC_VERS)
+GCC_RPMREL = 0.20121118.0
+include ../gcc.am
+GCC_OPTS += --languages=cxx,fortran,objc
diff --git a/freebsd7.4/i586/binutils-sources.add b/freebsd7.4/i586/binutils-sources.add
new file mode 100644
index 0000000..e458c6f
--- /dev/null
+++ b/freebsd7.4/i586/binutils-sources.add
@@ -0,0 +1,2 @@
+Source0: http://ftp.gnu.org/gnu/binutils/binutils-%{binutils_pkgvers}.tar.bz2
+ at PATCH0@
diff --git a/freebsd7.4/i586/gcc-sources.add b/freebsd7.4/i586/gcc-sources.add
new file mode 100644
index 0000000..625314d
--- /dev/null
+++ b/freebsd7.4/i586/gcc-sources.add
@@ -0,0 +1,60 @@
+%if "%{gcc_version}" == "4.7.1"
+# Source0:      ftp://ftp.gnu.org/gnu/gcc/gcc-%{gcc_pkgvers}/gcc-%{gcc_pkgvers}.tar.bz2
+Source0:        ftp://ftp.rtems.org/pub/rtems/SOURCES/4.11/gcc-4.7.1.tar.%{?el5:bz2}%{!?el5:xz}
+Patch0:         ftp://ftp.rtems.org/pub/rtems/SOURCES/4.11/gcc-4.7.1-rtems4.11-20120627.diff
+%endif
+%if "%{gcc_version}" == "4.7.0"
+# Source0:	ftp://ftp.gnu.org/gnu/gcc/gcc-%{gcc_pkgvers}/gcc-%{gcc_pkgvers}.tar.bz2
+Source0:        ftp://ftp.rtems.org/pub/rtems/SOURCES/4.11/gcc-%{gcc_pkgvers}.tar.%{?el5:bz2}%{!?el5:xz}
+Patch0:         ftp://ftp.rtems.org/pub/rtems/SOURCES/4.11/gcc-4.7.0-rtems4.11-20120419.diff
+%endif
+%if "%{gcc_version}" == "4.6.3"
+Source0:	ftp://ftp.gnu.org/gnu/gcc/gcc-%{gcc_pkgvers}/gcc-core-%{gcc_pkgvers}.tar.bz2
+Patch0:         ftp://ftp.rtems.org/pub/rtems/SOURCES/4.11/gcc-core-4.6.3-rtems4.11-20120303.diff
+%endif
+%if "%{gcc_version}" == "4.6.2"
+Source0:	ftp://ftp.gnu.org/gnu/gcc/gcc-%{gcc_pkgvers}/gcc-core-%{gcc_pkgvers}.tar.bz2
+Patch0:         ftp://ftp.rtems.org/pub/rtems/SOURCES/4.11/gcc-core-4.6.2-rtems4.11-20120124.diff
+%endif
+%if "%{gcc_version}" == "4.5.4"
+Source0:	ftp://ftp.gnu.org/gnu/gcc/gcc-%{gcc_pkgvers}/gcc-core-4.5.4.tar.bz2
+Patch0:         ftp://ftp.rtems.org/pub/rtems/SOURCES/4.11/gcc-core-4.5.4-rtems4.11-20120703.diff
+%endif
+
+%if "%{gcc_version}" < "4.7.0"
+%if %build_cxx
+%if "%{gcc_version}" == "4.6.3"
+Source1:	ftp://ftp.gnu.org/gnu/gcc/gcc-%{gcc_pkgvers}/%{gcc_pkgvers}/gcc-g++-%{gcc_pkgvers}.tar.bz2
+%endif
+%if "%{gcc_version}" == "4.6.2"
+Source1:	ftp://ftp.gnu.org/gnu/gcc/gcc-%{gcc_pkgvers}/%{gcc_pkgvers}/gcc-g++-%{gcc_pkgvers}.tar.bz2
+%endif
+%if "%{gcc_version}" == "4.5.4"
+Source1:	ftp://ftp.gnu.org/gnu/gcc/gcc-%{gcc_pkgvers}/gcc-g++-4.5.4.tar.bz2
+Patch1:         ftp://ftp.rtems.org/pub/rtems/SOURCES/4.11/gcc-g++-4.5.4-rtems4.11-20120703.diff
+%endif
+
+%endif
+%if %build_fortran
+Source2:	ftp://ftp.gnu.org/gnu/gcc/gcc-%{gcc_pkgvers}/gcc-fortran-%{gcc_pkgvers}.tar.bz2
+
+%endif
+%if %build_gcj
+Source3:	ftp://ftp.gnu.org/gnu/gcc/gcc-%{gcc_pkgvers}/gcc-java-%{gcc_pkgvers}.tar.bz2
+
+%endif
+%if %build_gnat
+Source4:	ftp://ftp.gnu.org/gnu/gcc/gcc-%{gcc_pkgvers}/gcc-ada-%{gcc_pkgvers}.tar.bz2
+
+%endif
+%if %build_objc
+Source5:	ftp://ftp.gnu.org/gnu/gcc/gcc-%{gcc_pkgvers}/gcc-objc-%{gcc_pkgvers}.tar.bz2
+
+%endif
+%endif
+%if %build_newlib
+%if "%{newlib_version}" == "1.20.0"
+Source50:	ftp://sourceware.org/pub/newlib/newlib-1.20.0.tar.gz
+Patch50:	ftp://ftp.rtems.org/pub/rtems/SOURCES/4.11/newlib-1.20.0-rtems4.11-20120629.diff
+%endif
+%endif
diff --git a/freebsd7.4/i586/i586-pc-freebsd7.4-binutils.spec b/freebsd7.4/i586/i586-pc-freebsd7.4-binutils.spec
new file mode 100644
index 0000000..7125652
--- /dev/null
+++ b/freebsd7.4/i586/i586-pc-freebsd7.4-binutils.spec
@@ -0,0 +1,170 @@
+#
+# Please send bugfixes or comments to
+# 	http://www.rtems.org/bugzilla
+#
+
+
+%ifos cygwin cygwin32 mingw mingw32
+%define _exeext .exe
+%define debug_package           %{nil}
+%define _libdir                 %{_exec_prefix}/lib
+%else
+%define _exeext %{nil}
+%endif
+
+%ifos cygwin cygwin32
+%define optflags -O3 -pipe -march=i486 -funroll-loops
+%endif
+
+%ifos mingw mingw32
+%if %{defined _mingw32_cflags}
+%define optflags %{_mingw32_cflags}
+%else
+%define optflags -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions --param=ssp-buffer-size=4 -mms-bitfields
+%endif
+%endif
+
+%if "%{_build}" != "%{_host}"
+%define _host_rpmprefix %{_host}-
+%else
+%define _host_rpmprefix %{nil}
+%endif
+
+%define binutils_pkgvers 2.22
+%define binutils_version 2.22
+%define binutils_rpmvers %{expand:%(echo "2.22" | tr - _ )}
+
+Name:		i586-pc-freebsd7.4-binutils
+Summary:	Binutils for target i586-pc-freebsd7.4
+Group:		Development/Tools
+Version:	%{binutils_rpmvers}
+Release:	0.20120919.0%{?dist}
+License:	GPL/LGPL
+URL: 		http://sources.redhat.com/binutils
+BuildRoot:	%{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n)
+
+BuildRequires:	%{_host_rpmprefix}gcc
+
+%if "%{binutils_version}" >= "2.18"
+# Bug in bfd: Doesn't build without texinfo installed
+BuildRequires:	texinfo >= 4.2
+%else
+%endif
+BuildRequires:	flex
+BuildRequires:	bison
+
+Source0: http://ftp.gnu.org/gnu/binutils/binutils-%{binutils_pkgvers}.tar.bz2
+
+%description
+Cross binutils for target i586-pc-freebsd7.4
+%prep
+%setup -q -c -T -n %{name}-%{version}
+
+%setup -q -D -T -n %{name}-%{version} -a0
+cd binutils-%{binutils_pkgvers}
+%{?PATCH0:%patch0 -p1}
+cd ..
+
+%build
+  mkdir -p build
+  cd build
+%if "%{_build}" != "%{_host}"
+  CFLAGS_FOR_BUILD="-g -O2 -Wall" \
+%endif
+  CFLAGS="$RPM_OPT_FLAGS" \
+  ../binutils-%{binutils_pkgvers}/configure \
+    --build=%_build --host=%_host \
+    --target=i586-pc-freebsd7.4 \
+    --verbose --disable-nls \
+    --without-included-gettext \
+    --disable-win32-registry \
+    --disable-werror \
+    --with-sysroot=%{_prefix}/i586-pc-freebsd7.4/sys-root \
+    --prefix=%{_prefix} --bindir=%{_bindir} \
+    --exec-prefix=%{_exec_prefix} \
+    --includedir=%{_includedir} --libdir=%{_libdir} \
+    --mandir=%{_mandir} --infodir=%{_infodir}
+
+  make %{?_smp_mflags} all
+  cd ..
+
+%install
+  rm -rf $RPM_BUILD_ROOT
+
+  cd build
+  make DESTDIR=$RPM_BUILD_ROOT install
+
+
+# Conflict with a native binutils' infos
+  rm -rf $RPM_BUILD_ROOT%{_infodir}
+
+# We don't ship host files
+  rm -f ${RPM_BUILD_ROOT}%{_libdir}/libiberty*
+
+# manpages without corresponding tools
+  if test ! -f ${RPM_BUILD_ROOT}%{_bindir}/i586-pc-freebsd7.4-dlltool%{_exeext}; then 
+    rm -f ${RPM_BUILD_ROOT}%{_mandir}/man1/i586-pc-freebsd7.4-dlltool*
+  fi
+  if test ! -f ${RPM_BUILD_ROOT}%{_bindir}/i586-pc-freebsd7.4-nlmconv%{_exeext}; then 
+    rm -f ${RPM_BUILD_ROOT}%{_mandir}/man1/i586-pc-freebsd7.4-nlmconv*
+  fi
+  if test ! -f ${RPM_BUILD_ROOT}%{_bindir}/i586-pc-freebsd7.4-windres%{_exeext}; then 
+    rm -f ${RPM_BUILD_ROOT}%{_mandir}/man1/i586-pc-freebsd7.4-windres*
+  fi
+  if test ! -f ${RPM_BUILD_ROOT}%{_bindir}/i586-pc-freebsd7.4-windmc%{_exeext}; then 
+    rm -f ${RPM_BUILD_ROOT}%{_mandir}/man1/i586-pc-freebsd7.4-windmc*
+  fi
+
+  cd ..
+
+# Extract %%__os_install_post into os_install_post~
+cat << \EOF > os_install_post~
+%__os_install_post
+EOF
+
+# Generate customized brp-*scripts
+cat os_install_post~ | while read a x y; do
+case $a in
+# Prevent brp-strip* from trying to handle foreign binaries
+*/brp-strip*)
+  b=$(basename $a)
+  sed -e 's,find $RPM_BUILD_ROOT,find $RPM_BUILD_ROOT%_bindir $RPM_BUILD_ROOT%_libexecdir,' $a > $b
+  chmod a+x $b
+  ;;
+esac
+done
+
+sed -e 's,^\s*/usr/lib/rpm.*/brp-strip,./brp-strip,' \
+< os_install_post~ > os_install_post 
+%define __os_install_post . ./os_install_post
+
+%clean
+  rm -rf $RPM_BUILD_ROOT
+
+# ==============================================================
+# i586-pc-freebsd7.4-binutils
+# ==============================================================
+# %package -n i586-pc-freebsd7.4-binutils
+# Summary:      rtems binutils for i586-pc-freebsd7.4
+# Group: Development/Tools
+# %if %build_infos
+# Requires: binutils-common
+# %endif
+
+%description -n i586-pc-freebsd7.4-binutils
+GNU binutils targetting i586-pc-freebsd7.4.
+
+%files -n i586-pc-freebsd7.4-binutils
+%defattr(-,root,root)
+
+%{_mandir}/man1/i586-pc-freebsd7.4-*.1*
+
+%{_bindir}/i586-pc-freebsd7.4-*
+
+%dir %{_exec_prefix}/i586-pc-freebsd7.4
+%dir %{_exec_prefix}/i586-pc-freebsd7.4/bin
+%{_exec_prefix}/i586-pc-freebsd7.4/bin/*
+
+%dir %{_exec_prefix}/i586-pc-freebsd7.4/lib
+%{_exec_prefix}/i586-pc-freebsd7.4/lib/ldscripts
+
diff --git a/freebsd7.4/i586/i586-pc-freebsd7.4-gcc.spec b/freebsd7.4/i586/i586-pc-freebsd7.4-gcc.spec
new file mode 100644
index 0000000..3543156
--- /dev/null
+++ b/freebsd7.4/i586/i586-pc-freebsd7.4-gcc.spec
@@ -0,0 +1,827 @@
+#
+# Please send bugfixes or comments to
+# 	http://www.rtems.org/bugzilla
+#
+
+
+%ifos cygwin cygwin32 mingw mingw32
+%define _exeext .exe
+%define debug_package           %{nil}
+%define _libdir                 %{_exec_prefix}/lib
+%else
+%define _exeext %{nil}
+%endif
+
+%ifos cygwin cygwin32
+%define optflags -O3 -pipe -march=i486 -funroll-loops
+%endif
+
+%ifos mingw mingw32
+%if %{defined _mingw32_cflags}
+%define optflags %{_mingw32_cflags}
+%else
+%define optflags -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions --param=ssp-buffer-size=4 -mms-bitfields
+%endif
+%endif
+
+%if "%{_build}" != "%{_host}"
+%define _host_rpmprefix %{_host}-
+%else
+%define _host_rpmprefix %{nil}
+%endif
+
+
+%define gcc_pkgvers 4.7.1
+%define gcc_version 4.7.1
+%define gcc_rpmvers %{expand:%(echo "4.7.1" | tr - _ )}
+
+
+Name:         	i586-pc-freebsd7.4-gcc
+Summary:      	i586-pc-freebsd7.4 gcc
+
+Group:	      	Development/Tools
+Version:        %{gcc_rpmvers}
+Release:      	0.20121118.0%{?dist}
+License:      	GPL
+URL:		http://gcc.gnu.org
+BuildRoot:	%{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n)
+
+%define _use_internal_dependency_generator 0
+
+BuildRequires:  %{_host_rpmprefix}gcc
+
+# FIXME: Disable lto for now, to avoid dependencies on libelf
+%bcond_with lto
+
+# FIXME: Disable python gdb scripts
+# ATM, no idea how to package them
+%bcond_with pygdb
+
+# FIXME: Disable GCC-plugin
+# Bug in gcc-4.5-20100318, doesn't build them on x86_84 hosts.
+%bcond_with plugin
+
+# Use gcc's stdint.h instead of newlib's
+# Should be applicable to gcc >= 4.5.0
+%if "%{gcc_version}" >= "4.5.3"
+%bcond_without gcc_stdint
+%else
+%bcond_with gcc_stdint
+%endif
+
+# Enable newlib's iconv
+%bcond_without iconv
+
+# versions of libraries, we conditionally bundle if necessary
+%global mpc_version	0.8.1
+%global mpfr_version	2.4.2
+%global gmp_version	4.3.2
+%global libelf_version  0.8.13
+
+# versions of libraries these distros are known to ship
+%if 0%{?fc18}
+%global mpc_provided 0.9
+%global mpfr_provided 3.1.0
+%global gmp_provided 5.0.4
+%endif
+
+%if 0%{?fc17}
+%global mpc_provided 0.9
+%global mpfr_provided 3.1.0
+%global gmp_provided 5.0.2
+%endif
+
+%if 0%{?fc16}
+%global mpc_provided 0.9
+%global mpfr_provided 3.0.0
+%global gmp_provided 4.3.2
+%endif
+
+%if 0%{?el6}
+%global mpc_provided 0.8
+%global mpfr_provided 2.4.1
+%global gmp_provided 4.3.1
+%endif
+
+%if 0%{?el5}
+%global mpc_provided %{nil}
+%global mpfr_provided %{nil}
+%global gmp_provided 4.1.4
+%endif
+
+%if 0%{?suse12_2}
+%global mpc_provided 0.8.2
+%global mpfr_provided 3.1.0
+%global gmp_provided 5.0.5
+%endif
+
+%if 0%{?suse12_1}
+%global mpc_provided 0.8.2
+%global mpfr_provided 3.0.1
+%global gmp_provided 5.0.2
+%endif
+
+%if 0%{?cygwin}
+%global mpc_provided 0.8
+%global mpfr_provided 2.4.1
+%global gmp_provided 4.3.1
+%endif
+
+%if 0%{?mingw32}
+%global mpc_provided 0.8.1
+%global mpfr_provided 2.4.1
+%global gmp_provided 4.3.2
+%endif
+
+%if "%{gcc_version}" >= "4.2.0"
+%define gmp_required		4.1
+%define mpfr_required		2.2.1
+%endif
+
+%if "%{gcc_version}" >= "4.3.0"
+%define gmp_required		4.1
+%define mpfr_required		2.3.1
+%endif
+
+%if "%{gcc_version}" >= "4.3.3"
+%define cloog_required 		0.15
+%endif
+
+%if "%{gcc_version}" >= "4.4.0"
+%define mpfr_required		2.3.2
+%endif
+
+%if "%{gcc_version}" >= "4.5.0"
+%define mpc_required 		0.8
+%if %{with lto}
+%define libelf_required 	0.8.12
+%endif
+%endif
+
+%if "%{gcc_version}" >= "4.7.0"
+%define gmp_required            4.2
+%endif
+
+%if %{defined mpc_required}
+%if "%{mpc_provided}" >= "%{mpc_required}"
+%{?fedora:BuildRequires: libmpc-devel >= %{mpc_required}}
+%{?el6:BuildRequires: libmpc-devel >= %{mpc_required}}
+%{?suse:BuildRequires: mpc-devel >= %{mpc_required}}
+%if "%{_build}" != "%{_host}"
+BuildRequires:  %{_host_rpmprefix}mpc-devel >= %{mpc_required}
+%endif
+%else
+%define _build_mpc 1
+%define gmp_required 		4.2
+%endif
+%endif
+
+%if %{defined gmp_required}
+%if "%{gmp_provided}" >= "%{gmp_required}"
+BuildRequires: gmp-devel >= %{gmp_required}
+%if "%{_build}" != "%{_host}"
+BuildRequires:  %{_host_rpmprefix}gmp-devel >= %{gmp_required}
+%endif
+%else
+%define _build_gmp 1
+%endif
+%endif
+
+%if %{defined libelf_required}
+%if "%{libelf_provided}" >= "%{libelf_required}"
+BuildRequires: libelf-devel >= %{libelf_required}
+%if "%{_build}" != "%{_host}"
+BuildRequires:  %{_host_rpmprefix}libelf-devel >= %{libelf_required}
+%endif
+%else
+%define _build_libelf 1
+%endif
+%endif
+
+
+%if %{defined cloog_required}
+%{?fedora:BuildRequires: cloog-ppl-devel >= %cloog_required}
+%{?el6:BuildRequires: cloog-ppl-devel >= %cloog_required}
+%{?suse:BuildRequires: cloog-devel >= %cloog_required, ppl-devel}
+%endif
+
+
+%if %{defined mpfr_required}
+%if "%{mpfr_provided}" >= "%{mpfr_required}"
+BuildRequires: mpfr-devel >= %{mpfr_required}
+%if "%{_build}" != "%{_host}"
+BuildRequires:  %{_host_rpmprefix}mpfr-devel >= %{mpfr_required}
+%endif
+%else
+%define _build_mpfr 1
+%endif
+%endif
+
+%if "%{_build}" != "%{_host}"
+BuildRequires:  i586-pc-freebsd7.4-gcc = %{gcc_rpmvers}
+%endif
+
+# Not strictly required, but patches may introduce a need to use them.
+# For reasons of simplicity, always require them.
+BuildRequires:	flex bison
+
+BuildRequires:	texinfo >= 4.2
+BuildRequires:	i586-pc-freebsd7.4-binutils
+BuildRequires:	i586-pc-freebsd7.4-sys-root
+
+Requires:	i586-pc-freebsd7.4-binutils
+Requires:	i586-pc-freebsd7.4-sys-root
+Requires:	i586-pc-freebsd7.4-gcc-libgcc = %{gcc_rpmvers}-%{release}
+
+%if "%{gcc_version}" >= "4.5.0"
+BuildRequires:  zlib-devel
+%if "%{_build}" != "%{_host}"
+BuildRequires:  %{_host_rpmprefix}zlib-devel
+%endif
+%else
+%endif
+
+%global _gcclibdir %{_prefix}/lib
+
+%if "%{gcc_version}" == "4.7.1"
+# Source0:      ftp://ftp.gnu.org/gnu/gcc/gcc-%{gcc_pkgvers}/gcc-%{gcc_pkgvers}.tar.bz2
+Source0:        ftp://ftp.rtems.org/pub/rtems/SOURCES/4.11/gcc-4.7.1.tar.%{?el5:bz2}%{!?el5:xz}
+Patch0:         ftp://ftp.rtems.org/pub/rtems/SOURCES/4.11/gcc-4.7.1-rtems4.11-20120627.diff
+%endif
+%if "%{gcc_version}" == "4.7.0"
+# Source0:	ftp://ftp.gnu.org/gnu/gcc/gcc-%{gcc_pkgvers}/gcc-%{gcc_pkgvers}.tar.bz2
+Source0:        ftp://ftp.rtems.org/pub/rtems/SOURCES/4.11/gcc-%{gcc_pkgvers}.tar.%{?el5:bz2}%{!?el5:xz}
+Patch0:         ftp://ftp.rtems.org/pub/rtems/SOURCES/4.11/gcc-4.7.0-rtems4.11-20120419.diff
+%endif
+%if "%{gcc_version}" == "4.6.3"
+Source0:	ftp://ftp.gnu.org/gnu/gcc/gcc-%{gcc_pkgvers}/gcc-core-%{gcc_pkgvers}.tar.bz2
+Patch0:         ftp://ftp.rtems.org/pub/rtems/SOURCES/4.11/gcc-core-4.6.3-rtems4.11-20120303.diff
+%endif
+%if "%{gcc_version}" == "4.6.2"
+Source0:	ftp://ftp.gnu.org/gnu/gcc/gcc-%{gcc_pkgvers}/gcc-core-%{gcc_pkgvers}.tar.bz2
+Patch0:         ftp://ftp.rtems.org/pub/rtems/SOURCES/4.11/gcc-core-4.6.2-rtems4.11-20120124.diff
+%endif
+%if "%{gcc_version}" == "4.5.4"
+Source0:	ftp://ftp.gnu.org/gnu/gcc/gcc-%{gcc_pkgvers}/gcc-core-4.5.4.tar.bz2
+Patch0:         ftp://ftp.rtems.org/pub/rtems/SOURCES/4.11/gcc-core-4.5.4-rtems4.11-20120703.diff
+%endif
+
+%if "%{gcc_version}" < "4.7.0"
+%if "%{gcc_version}" == "4.6.3"
+Source1:	ftp://ftp.gnu.org/gnu/gcc/gcc-%{gcc_pkgvers}/%{gcc_pkgvers}/gcc-g++-%{gcc_pkgvers}.tar.bz2
+%endif
+%if "%{gcc_version}" == "4.6.2"
+Source1:	ftp://ftp.gnu.org/gnu/gcc/gcc-%{gcc_pkgvers}/%{gcc_pkgvers}/gcc-g++-%{gcc_pkgvers}.tar.bz2
+%endif
+%if "%{gcc_version}" == "4.5.4"
+Source1:	ftp://ftp.gnu.org/gnu/gcc/gcc-%{gcc_pkgvers}/gcc-g++-4.5.4.tar.bz2
+Patch1:         ftp://ftp.rtems.org/pub/rtems/SOURCES/4.11/gcc-g++-4.5.4-rtems4.11-20120703.diff
+%endif
+
+Source2:	ftp://ftp.gnu.org/gnu/gcc/gcc-%{gcc_pkgvers}/gcc-fortran-%{gcc_pkgvers}.tar.bz2
+
+Source5:	ftp://ftp.gnu.org/gnu/gcc/gcc-%{gcc_pkgvers}/gcc-objc-%{gcc_pkgvers}.tar.bz2
+
+%endif
+
+%if 0%{?_build_mpfr}
+Source60:    http://www.mpfr.org/mpfr-%{mpfr_version}/mpfr-%{mpfr_version}.tar.bz2
+%endif
+
+%if 0%{?_build_mpc}
+Source61:    http://www.multiprecision.org/mpc/download/mpc-%{mpc_version}.tar.gz
+%endif
+
+%if 0%{?_build_gmp}
+Source62:    ftp://ftp.gnu.org/gnu/gmp/gmp-%{gmp_version}.tar.bz2
+%endif
+
+%if 0%{?_build_libelf}
+Source63:    http://www.mr511.de/software/libelf-%{libelf_version}.tar.gz
+%endif
+
+%description
+Cross gcc for i586-pc-freebsd7.4.
+
+%prep
+%setup -c -T -n %{name}-%{version}
+
+%setup -q -T -D -n %{name}-%{version} -a0
+cd gcc-%{gcc_pkgvers}
+%{?PATCH0:%patch0 -p1}
+cd ..
+
+%{?SOURCE1:%setup -q -T -D -n %{name}-%{version} -a1}
+cd gcc-%{gcc_pkgvers}
+%{?PATCH1:%patch1 -p1}
+cd ..
+
+%{?SOURCE2:%setup -q -T -D -n %{name}-%{version} -a2}
+%{?PATCH2:%patch2 -p0}
+
+
+
+%{?SOURCE5:%setup -q -T -D -n %{name}-%{version} -a5}
+%{?PATCH5:%patch5 -p0}
+
+%if %{with gcc_stdint}
+sed -i -e '/thread_file=.*rtems/,/use_gcc_stdint=wrap/ { s/use_gcc_stdint=wrap/use_gcc_stdint=provide/}' gcc-%{gcc_pkgvers}/gcc/config.gcc
+%endif
+
+
+%if 0%{?_build_mpfr}
+%setup -q -T -D -n %{name}-%{version} -a60
+%{?PATCH60:%patch60 -p1}
+  # Build mpfr one-tree style
+  ln -s ../mpfr-%{mpfr_version} gcc-%{gcc_pkgvers}/mpfr
+%endif
+
+%if 0%{?_build_mpc}
+%setup -q -T -D -n %{name}-%{version} -a61
+%{?PATCH61:%patch61 -p1}
+  # Build mpc one-tree style
+  ln -s ../mpc-%{mpc_version} gcc-%{gcc_pkgvers}/mpc
+%endif
+
+%if 0%{?_build_gmp}
+%setup -q -T -D -n %{name}-%{version} -a62
+%{?PATCH62:%patch62 -p1}
+  # Build gmp one-tree style
+  ln -s ../gmp-%{gmp_version} gcc-%{gcc_pkgvers}/gmp
+%endif
+
+%if 0%{?_build_libelf}
+%setup -q -T -D -n %{name}-%{version} -a63
+%{?PATCH63:%patch63 -p1}
+  # Build libelf one-tree style
+  ln -s ../libelf-%{libelf_version} gcc-%{gcc_pkgvers}/libelf
+%endif
+
+
+  # Fix timestamps
+  cd gcc-%{gcc_pkgvers}
+  contrib/gcc_update --touch
+  cd ..
+%build
+  mkdir -p build
+
+  cd build
+
+  languages="c"
+  languages="$languages,c++"
+  languages="$languages,fortran"
+  languages="$languages,objc"
+%if "%{_build}" != "%{_host}"
+  CFLAGS_FOR_BUILD="-g -O2 -Wall" \
+  CC="%{_host}-gcc ${RPM_OPT_FLAGS}" \
+%else
+# gcc is not ready to be compiled with -std=gnu99
+  CC=$(echo "%{__cc} ${RPM_OPT_FLAGS}" | sed -e 's,-std=gnu99 ,,') \
+%endif
+  ../gcc-%{gcc_pkgvers}/configure \
+    --prefix=%{_prefix} \
+    --bindir=%{_bindir} \
+    --exec_prefix=%{_exec_prefix} \
+    --includedir=%{_includedir} \
+    --libdir=%{_gcclibdir} \
+    --libexecdir=%{_libexecdir} \
+    --mandir=%{_mandir} \
+    --infodir=%{_infodir} \
+    --datadir=%{_datadir} \
+    --build=%_build --host=%_host \
+    --target=i586-pc-freebsd7.4 \
+    --disable-libstdcxx-pch \
+    --with-gnu-as --with-gnu-ld --verbose \
+    --with-system-zlib \
+    --disable-nls --without-included-gettext \
+    --disable-win32-registry \
+    --enable-version-specific-runtime-libs \
+    --enable-threads \
+    --with-sysroot=%{_exec_prefix}/i586-pc-freebsd7.4/sys-root \
+    %{?with_lto:--enable-lto}%{!?with_lto:--disable-lto} \
+    %{?with_plugin:--enable-plugin}%{!?with_plugin:--disable-plugin} \
+    --enable-languages="$languages"
+
+%if "%_host" != "%_build"
+  # Bug in gcc-3.2.1:
+  # Somehow, gcc doesn't get syslimits.h right for Cdn-Xs
+  mkdir -p gcc/include
+  cp ../gcc-%{gcc_pkgvers}/gcc/gsyslimits.h gcc/include/syslimits.h
+%endif
+
+  make %{?_smp_mflags} all
+  cd ..
+
+%install
+  rm -rf $RPM_BUILD_ROOT
+
+  cd build
+
+  make DESTDIR=$RPM_BUILD_ROOT install
+  cd ..
+
+
+%if "%{gcc_version}" <= "4.1.2"
+# Misplaced header file
+  if test -f $RPM_BUILD_ROOT%{_includedir}/mf-runtime.h; then
+    mv $RPM_BUILD_ROOT%{_includedir}/mf-runtime.h \
+      $RPM_BUILD_ROOT%{_gcclibdir}/gcc/i586-pc-freebsd7.4/%{gcc_version}/include/
+  fi
+%endif
+
+  # host library
+%if "%{gcc_version}" >= "4.2.0"
+  # libiberty doesn't honor --libdir, but always installs to a 
+  # magically guessed _libdir
+  rm -f  ${RPM_BUILD_ROOT}%{_libdir}/libiberty.a
+%else
+  # libiberty installs to --libdir=...
+  rm -f ${RPM_BUILD_ROOT}%{_gcclibdir}/libiberty.a
+%endif
+
+  # We use the version from binutils
+  rm -f $RPM_BUILD_ROOT%{_bindir}/i586-pc-freebsd7.4-c++filt%{_exeext}
+
+
+# Conflict with a native GCC's infos
+  rm -rf $RPM_BUILD_ROOT%{_infodir}
+
+# Conflict with a native GCC's man pages
+  rm -rf $RPM_BUILD_ROOT%{_mandir}/man7
+
+  # We don't want libffi's man-pages
+  rm -f $RPM_BUILD_ROOT%{_mandir}/man3/*ffi*
+
+  # Bug in gcc-3.4.0pre
+  rm -f $RPM_BUILD_ROOT%{_bindir}/i586-pc-freebsd7.4-i586-pc-freebsd7.4-gcjh%{_exeext}
+
+  # Bug in gcc-3.3.x/gcc-3.4.x: Despite we don't need fixincludes, it installs
+  # the fixinclude-install-tools
+  rm -rf ${RPM_BUILD_ROOT}%{_gcclibdir}/gcc/i586-pc-freebsd7.4/%{gcc_version}/install-tools
+  rm -rf ${RPM_BUILD_ROOT}%{_libexecdir}/gcc/i586-pc-freebsd7.4/%{gcc_version}/install-tools
+
+  # Bug in gcc > 4.1.0: Installs an unused, empty directory
+  if test -d ${RPM_BUILD_ROOT}%{_prefix}/i586-pc-freebsd7.4/include/bits; then
+    rmdir ${RPM_BUILD_ROOT}%{_prefix}/i586-pc-freebsd7.4/include/bits
+  fi
+
+%if ! %{with pygdb}
+  # gcc >= 4.5.0: installs weird libstdc++ python bindings.
+  if test -d ${RPM_BUILD_ROOT}%{_datadir}/gcc-%{gcc_version}/python; then
+    rm -rf ${RPM_BUILD_ROOT}%{_datadir}/gcc-%{gcc_version}/python/libstdcxx
+  fi
+
+%endif
+  # Collect multilib subdirectories
+  multilibs=`build/gcc/xgcc -Bbuild/gcc/ --print-multi-lib | sed -e 's,;.*$,,'`
+
+
+  rm -f dirs ;
+  echo "%defattr(-,root,root,-)" >> dirs
+  TGTDIR="%{_gcclibdir}/gcc/i586-pc-freebsd7.4/%{gcc_version}"
+  for i in $multilibs; do
+    case $i in
+    \.) ;; # ignore, handled elsewhere
+    *)  echo "%dir ${TGTDIR}/$i" >> dirs
+      ;;
+    esac
+  done
+
+  # Collect files to go into different packages
+  cp dirs build/files.gcc
+  cp dirs build/files.gfortran
+  cp dirs build/files.objc
+  cp dirs build/files.gcj
+  cp dirs build/files.g++
+  cp dirs build/files.go
+
+  TGTDIR="%{_gcclibdir}/gcc/i586-pc-freebsd7.4/%{gcc_version}"
+  f=`find ${RPM_BUILD_ROOT}${TGTDIR} ! -type d -print | sed -e "s,^$RPM_BUILD_ROOT,,g"`;
+  for i in $f; do
+    case $i in
+    *lib*.la) rm ${RPM_BUILD_ROOT}/$i ;; # ignore: gcc produces bogus libtool libs
+    *f771) ;;
+    *f951) ;;
+    *cc1) ;;
+    *cc1obj) ;;
+    *cc1plus) ;; # ignore: explicitly put into rpm elsewhere
+    *collect2) ;;
+    *libobjc*) echo "$i" >> build/files.objc ;;
+    *go1) ;; # ignore: explicitly put into rpm elsewhere
+    *include/objc*) ;;
+    *include/g++*);;
+    *include/c++*);;
+    *include-fixed/*);;
+    *finclude/*);;
+    */go/*) ;; # ignore : explicitly put into rpm elsewhere
+    *adainclude*);;
+    *adalib*);;
+    *gnat1);;
+    *jc1) ;;
+    *jvgenmain) ;;
+    */libgfortran*.*) echo "$i" >> build/files.gfortran ;;
+    */libgo.*) echo "$i" >> build/files.go ;;
+    %{!?with_pygdb:*/libstdc++*gdb.py*) rm ${RPM_BUILD_ROOT}/$i ;;} # ignore for now
+    %{?with_pygdb:*/libstdc++*gdb.py*) >> build/files.g++ ;;}
+    */libstdc++.*) echo "$i" >> build/files.g++ ;;
+    */libsupc++.*) echo "$i" >> build/files.g++ ;;
+    *) echo "$i" >> build/files.gcc ;;
+    esac
+  done
+
+  TGTDIR="%{_exec_prefix}/i586-pc-freebsd7.4/lib"
+  f=`find ${RPM_BUILD_ROOT}${TGTDIR} ! -type d -print | sed -e "s,^$RPM_BUILD_ROOT,,g"`;
+  for i in $f; do
+    case $i in
+    *lib*.la) rm ${RPM_BUILD_ROOT}/$i;; # ignore - gcc produces bogus libtool libs
+    *libiberty.a) rm ${RPM_BUILD_ROOT}/$i ;; # ignore - GPL'ed
+# all other files belong to newlib
+    *) echo "$i" >> build/files.newlib ;; 
+    esac
+  done
+# Extract %%__os_install_post into os_install_post~
+cat << \EOF > os_install_post~
+%__os_install_post
+EOF
+
+# Generate customized brp-*scripts
+cat os_install_post~ | while read a x y; do
+case $a in
+# Prevent brp-strip* from trying to handle foreign binaries
+*/brp-strip*)
+  b=$(basename $a)
+  sed -e 's,find $RPM_BUILD_ROOT,find $RPM_BUILD_ROOT%_bindir $RPM_BUILD_ROOT%_libexecdir,' $a > $b
+  chmod a+x $b
+  ;;
+esac
+done
+
+sed -e 's,^\s*/usr/lib/rpm.*/brp-strip,./brp-strip,' \
+< os_install_post~ > os_install_post 
+%define __os_install_post . ./os_install_post
+
+
+cat << EOF > %{_builddir}/%{name}-%{gcc_rpmvers}/find-provides
+#!/bin/sh
+grep -E -v '^${RPM_BUILD_ROOT}%{_exec_prefix}/i586-pc-freebsd7.4/(lib|include|sys-root)' \
+  %{?_gcclibdir:| grep -v '^${RPM_BUILD_ROOT}%{_gcclibdir}/gcc/i586-pc-freebsd7.4/'} | %__find_provides
+EOF
+chmod +x %{_builddir}/%{name}-%{gcc_rpmvers}/find-provides
+%define __find_provides %{_builddir}/%{name}-%{gcc_rpmvers}/find-provides
+
+cat << EOF > %{_builddir}/%{name}-%{gcc_rpmvers}/find-requires
+#!/bin/sh
+grep -E -v '^${RPM_BUILD_ROOT}%{_exec_prefix}/i586-pc-freebsd7.4/(lib|include|sys-root)' \
+  %{?_gcclibdir:| grep -v '^${RPM_BUILD_ROOT}%{_gcclibdir}/gcc/i586-pc-freebsd7.4/'} | %__find_requires
+EOF
+chmod +x %{_builddir}/%{name}-%{gcc_rpmvers}/find-requires
+%define __find_requires %{_builddir}/%{name}-%{gcc_rpmvers}/find-requires
+
+%ifnarch noarch
+# Extract %%__debug_install_post into debug_install_post~
+cat << \EOF > debug_install_post~
+%__debug_install_post
+EOF
+
+# Generate customized debug_install_post script
+cat debug_install_post~ | while read a x y; do
+case $a in
+# Prevent find-debuginfo.sh* from trying to handle foreign binaries
+*/find-debuginfo.sh)
+  b=$(basename $a)
+  sed -e 's,find "$RPM_BUILD_ROOT" !,find "$RPM_BUILD_ROOT"%_bindir "$RPM_BUILD_ROOT"%_libexecdir !,' $a > $b
+  chmod a+x $b
+  ;;
+esac
+done
+
+sed -e 's,^[ ]*/usr/lib/rpm/find-debuginfo.sh,./find-debuginfo.sh,' \
+< debug_install_post~ > debug_install_post 
+%define __debug_install_post . ./debug_install_post
+
+%endif
+
+%clean
+  rm -rf $RPM_BUILD_ROOT
+
+# ==============================================================
+# i586-pc-freebsd7.4-gcc
+# ==============================================================
+# %package -n i586-pc-freebsd7.4-gcc
+# Summary:        GNU cc compiler for i586-pc-freebsd7.4
+# Group:          Development/Tools
+# Version:        %{gcc_rpmvers}
+# Requires:       i586-pc-freebsd7.4-binutils
+# License:	GPL
+
+# %if %build_infos
+# Requires:      gcc-common
+# %endif
+
+%description -n i586-pc-freebsd7.4-gcc
+GNU cc compiler for i586-pc-freebsd7.4.
+
+# ==============================================================
+# i586-pc-freebsd7.4-gcc-libgcc
+# ==============================================================
+%package -n i586-pc-freebsd7.4-gcc-libgcc
+Summary:        libgcc for i586-pc-freebsd7.4-gcc
+Group:          Development/Tools
+Version:        %{gcc_rpmvers}
+%{?_with_noarch_subpackages:BuildArch: noarch}
+License:	GPL
+
+%description -n i586-pc-freebsd7.4-gcc-libgcc
+libgcc i586-pc-freebsd7.4-gcc.
+
+
+%files -n i586-pc-freebsd7.4-gcc
+%defattr(-,root,root)
+
+%{_mandir}/man1/i586-pc-freebsd7.4-gcc.1*
+%{_mandir}/man1/i586-pc-freebsd7.4-cpp.1*
+%{_mandir}/man1/i586-pc-freebsd7.4-gcov.1*
+
+%{_bindir}/i586-pc-freebsd7.4-cpp%{_exeext}
+%{_bindir}/i586-pc-freebsd7.4-gcc%{_exeext}
+%{_bindir}/i586-pc-freebsd7.4-gcc-%{gcc_version}%{_exeext}
+%{_bindir}/i586-pc-freebsd7.4-gcov%{_exeext}
+%if "%{gcc_version}" < "4.6.0"
+%{_bindir}/i586-pc-freebsd7.4-gccbug
+%endif
+%if "%{gcc_version}" >= "4.7.0"
+# FIXME: To ship or not to ship?
+%{_bindir}/i586-pc-freebsd7.4-gcc-ar%{_exeext}
+%{_bindir}/i586-pc-freebsd7.4-gcc-nm%{_exeext}
+%{_bindir}/i586-pc-freebsd7.4-gcc-ranlib%{_exeext}
+%endif
+
+%dir %{_libexecdir}/gcc
+%dir %{_libexecdir}/gcc/i586-pc-freebsd7.4
+%dir %{_libexecdir}/gcc/i586-pc-freebsd7.4/%{gcc_version}
+%{_libexecdir}/gcc/i586-pc-freebsd7.4/%{gcc_version}/cc1%{_exeext}
+%{_libexecdir}/gcc/i586-pc-freebsd7.4/%{gcc_version}/collect2%{_exeext}
+%if "%{gcc_version}" >= "4.5.0"
+%{?with_lto:%{_libexecdir}/gcc/i586-pc-freebsd7.4/%{gcc_version}/lto%{_exeext}}
+%{_libexecdir}/gcc/i586-pc-freebsd7.4/%{gcc_version}/lto-wrapper%{_exeext}
+%endif
+
+%files -n i586-pc-freebsd7.4-gcc-libgcc -f build/files.gcc
+%defattr(-,root,root)
+%dir %{_gcclibdir}/gcc
+%dir %{_gcclibdir}/gcc/i586-pc-freebsd7.4
+%dir %{_gcclibdir}/gcc/i586-pc-freebsd7.4/%{gcc_version}
+%dir %{_gcclibdir}/gcc/i586-pc-freebsd7.4/%{gcc_version}/include
+
+%if "%{gcc_version}" > "4.0.3"
+%dir %{_gcclibdir}/gcc/i586-pc-freebsd7.4/%{gcc_version}/include/ssp
+%endif
+
+%if "%{gcc_version}" >= "4.3.0"
+%{_gcclibdir}/gcc/i586-pc-freebsd7.4/%{gcc_version}/include-fixed
+%endif
+
+# ==============================================================
+# i586-pc-freebsd7.4-gcc-c++
+# ==============================================================
+%package -n i586-pc-freebsd7.4-gcc-c++
+Summary:	GCC c++ compiler for i586-pc-freebsd7.4
+Group:		Development/Tools
+Version:        %{gcc_rpmvers}
+License:	GPL
+Requires:       i586-pc-freebsd7.4-gcc-libstdc++ = %{gcc_rpmvers}-%{release}
+
+%if "%{_build}" != "%{_host}"
+BuildRequires:  i586-pc-freebsd7.4-gcc-c++ = %{gcc_rpmvers}
+%endif
+
+Requires:       i586-pc-freebsd7.4-gcc = %{gcc_rpmvers}-%{release}
+
+%description -n i586-pc-freebsd7.4-gcc-c++
+GCC c++ compiler for i586-pc-freebsd7.4.
+
+
+%package -n i586-pc-freebsd7.4-gcc-libstdc++
+Summary:	libstdc++ for i586-pc-freebsd7.4
+Group:		Development/Tools
+Version:        %{gcc_rpmvers}
+%{?_with_noarch_subpackages:BuildArch: noarch}
+License:	GPL
+
+%description -n i586-pc-freebsd7.4-gcc-libstdc++
+%{summary}
+
+
+%files -n i586-pc-freebsd7.4-gcc-c++
+%defattr(-,root,root)
+
+%{_mandir}/man1/i586-pc-freebsd7.4-g++.1*
+
+%{_bindir}/i586-pc-freebsd7.4-c++%{_exeext}
+%{_bindir}/i586-pc-freebsd7.4-g++%{_exeext}
+
+%dir %{_libexecdir}/gcc
+%dir %{_libexecdir}/gcc/i586-pc-freebsd7.4
+%dir %{_libexecdir}/gcc/i586-pc-freebsd7.4/%{gcc_version}
+%{_libexecdir}/gcc/i586-pc-freebsd7.4/%{gcc_version}/cc1plus%{_exeext}
+
+
+%files -n i586-pc-freebsd7.4-gcc-libstdc++ -f build/files.g++
+%defattr(-,root,root)
+%dir %{_gcclibdir}/gcc
+%dir %{_gcclibdir}/gcc/i586-pc-freebsd7.4
+%dir %{_gcclibdir}/gcc/i586-pc-freebsd7.4/%{gcc_version}
+%dir %{_gcclibdir}/gcc/i586-pc-freebsd7.4/%{gcc_version}/include
+%{_gcclibdir}/gcc/i586-pc-freebsd7.4/%{gcc_version}/include/c++
+
+# ==============================================================
+# i586-pc-freebsd7.4-gcc-gfortran
+# ==============================================================
+%package -n i586-pc-freebsd7.4-gcc-gfortran
+Summary:	Fortran 95 support for i586-pc-freebsd7.4-gcc
+Group:          Development/Tools
+Version:        %{gcc_rpmvers}
+License:	GPL
+
+Requires:       i586-pc-freebsd7.4-gcc = %{gcc_rpmvers}-%{release}
+Requires:       i586-pc-freebsd7.4-gcc-libgfortran = %{gcc_rpmvers}-%{release}
+
+%description -n i586-pc-freebsd7.4-gcc-gfortran
+GCC fortran compiler for i586-pc-freebsd7.4.
+
+%files -n i586-pc-freebsd7.4-gcc-gfortran
+%defattr(-,root,root)
+%{_bindir}/i586-pc-freebsd7.4-gfortran%{_exeext}
+
+%{_mandir}/man1/i586-pc-freebsd7.4-gfortran.1*
+
+%dir %{_libexecdir}/gcc
+%dir %{_libexecdir}/gcc/i586-pc-freebsd7.4
+%dir %{_libexecdir}/gcc/i586-pc-freebsd7.4/%{gcc_version}
+%{_libexecdir}/gcc/i586-pc-freebsd7.4/%{gcc_version}/f951%{_exeext}
+
+# ==============================================================
+# i586-pc-freebsd7.4-gcc-libgfortran
+# ==============================================================
+%package -n i586-pc-freebsd7.4-gcc-libgfortran
+Summary:	Fortran 95 support libraries for i586-pc-freebsd7.4-gcc
+Group:          Development/Tools
+Version:        %{gcc_rpmvers}
+%{?_with_noarch_subpackages:BuildArch: noarch}
+License:	GPL
+
+%description -n i586-pc-freebsd7.4-gcc-libgfortran
+%{summary}
+
+%files -n i586-pc-freebsd7.4-gcc-libgfortran -f build/files.gfortran
+%defattr(-,root,root)
+%dir %{_gcclibdir}/gcc
+%dir %{_gcclibdir}/gcc/i586-pc-freebsd7.4
+%dir %{_gcclibdir}/gcc/i586-pc-freebsd7.4/%{gcc_version}
+%if "%{gcc_version}" >= "4.2.0"
+%{_gcclibdir}/gcc/i586-pc-freebsd7.4/%{gcc_version}/finclude
+%endif
+
+# ==============================================================
+# i586-pc-freebsd7.4-gcc-objc
+# ==============================================================
+%package -n i586-pc-freebsd7.4-gcc-objc
+Summary:        Objective C support for i586-pc-freebsd7.4-gcc
+Group:          Development/Tools
+Version:        %{gcc_rpmvers}
+License:	GPL
+
+Requires:       i586-pc-freebsd7.4-gcc = %{gcc_rpmvers}-%{release}
+Requires:       i586-pc-freebsd7.4-gcc-libobjc = %{gcc_rpmvers}-%{release}
+
+%description -n i586-pc-freebsd7.4-gcc-objc
+GCC objc compiler for i586-pc-freebsd7.4.
+
+%files -n i586-pc-freebsd7.4-gcc-objc
+%defattr(-,root,root)
+%dir %{_libexecdir}/gcc
+%dir %{_libexecdir}/gcc/i586-pc-freebsd7.4
+%dir %{_libexecdir}/gcc/i586-pc-freebsd7.4/%{gcc_version}
+%{_libexecdir}/gcc/i586-pc-freebsd7.4/%{gcc_version}/cc1obj%{_exeext}
+
+# ==============================================================
+# i586-pc-freebsd7.4-gcc-libobjc
+# ==============================================================
+%package -n i586-pc-freebsd7.4-gcc-libobjc
+Summary:        Objective C support for i586-pc-freebsd7.4-gcc
+Group:          Development/Tools
+Version:        %{gcc_rpmvers}
+%{?_with_noarch_subpackages:BuildArch: noarch}
+License:	GPL
+
+%description -n i586-pc-freebsd7.4-gcc-libobjc
+Support libraries for GCC's objc compiler for i586-pc-freebsd7.4.
+
+%files -n i586-pc-freebsd7.4-gcc-libobjc -f build/files.objc
+%defattr(-,root,root)
+%dir %{_gcclibdir}/gcc
+%dir %{_gcclibdir}/gcc/i586-pc-freebsd7.4
+%dir %{_gcclibdir}/gcc/i586-pc-freebsd7.4/%{gcc_version}
+%dir %{_gcclibdir}/gcc/i586-pc-freebsd7.4/%{gcc_version}/include
+%{_gcclibdir}/gcc/i586-pc-freebsd7.4/%{gcc_version}/include/objc
+
diff --git a/freebsd7.4/i586/i586-pc-freebsd7.4-libs.spec b/freebsd7.4/i586/i586-pc-freebsd7.4-libs.spec
new file mode 100644
index 0000000..103f199
--- /dev/null
+++ b/freebsd7.4/i586/i586-pc-freebsd7.4-libs.spec
@@ -0,0 +1,206 @@
+#
+# Please send bugfixes or comments to
+# 	http://www.rtems.org/bugzilla
+#
+
+
+%ifos cygwin cygwin32 mingw mingw32
+%define _exeext .exe
+%define debug_package           %{nil}
+%define _libdir                 %{_exec_prefix}/lib
+%else
+%define _exeext %{nil}
+%endif
+
+%ifos cygwin cygwin32
+%define optflags -O3 -pipe -march=i486 -funroll-loops
+%endif
+
+%ifos mingw mingw32
+%if %{defined _mingw32_cflags}
+%define optflags %{_mingw32_cflags}
+%else
+%define optflags -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions --param=ssp-buffer-size=4 -mms-bitfields
+%endif
+%endif
+
+%if "%{_build}" != "%{_host}"
+%define _host_rpmprefix %{_host}-
+%else
+%define _host_rpmprefix %{nil}
+%endif
+
+%define freebsd_version 7.4
+%define freebsd_rpmvers %{expand:%(echo 7.4 | tr - _)}
+
+%define _use_internal_dependency_generator 0
+%define __debug_install_post %{nil}
+
+Name:		i586-pc-freebsd7.4
+Release:	0.20121118.0%{?dist}
+License:	FreeBSD
+Group:		Development/Tools
+
+BuildRoot:	%{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n)
+BuildArch:	noarch
+
+Version:      	%freebsd_rpmvers
+Summary:      	i586-pc-freebsd7.4 Libraries
+
+Source0:  http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/7.4-RELEASE/base/base.aa
+Source1:  http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/7.4-RELEASE/base/base.ab
+Source2:  http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/7.4-RELEASE/base/base.ac
+Source3:  http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/7.4-RELEASE/base/base.ad
+Source4:  http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/7.4-RELEASE/base/base.ae
+Source5:  http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/7.4-RELEASE/base/base.af
+Source6:  http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/7.4-RELEASE/base/base.ag
+Source7:  http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/7.4-RELEASE/base/base.ah
+Source8:  http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/7.4-RELEASE/base/base.ai
+Source9:  http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/7.4-RELEASE/base/base.aj
+Source10: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/7.4-RELEASE/base/base.ak
+Source11: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/7.4-RELEASE/base/base.al
+Source12: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/7.4-RELEASE/base/base.am
+Source13: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/7.4-RELEASE/base/base.an
+Source14: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/7.4-RELEASE/base/base.ao
+Source15: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/7.4-RELEASE/base/base.ap
+Source16: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/7.4-RELEASE/base/base.aq
+Source17: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/7.4-RELEASE/base/base.ar
+Source18: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/7.4-RELEASE/base/base.as
+Source19: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/7.4-RELEASE/base/base.at
+Source20: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/7.4-RELEASE/base/base.au
+Source21: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/7.4-RELEASE/base/base.av
+Source22: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/7.4-RELEASE/base/base.aw
+Source23: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/7.4-RELEASE/base/base.ax
+Source24: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/7.4-RELEASE/base/base.ay
+Source25: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/7.4-RELEASE/base/base.az
+Source26: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/7.4-RELEASE/base/base.ba
+Source27: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/7.4-RELEASE/base/base.bb
+Source28: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/7.4-RELEASE/base/base.bc
+Source29: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/7.4-RELEASE/base/base.bd
+Source30: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/7.4-RELEASE/base/base.be
+Source31: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/7.4-RELEASE/base/base.bf
+Source32: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/7.4-RELEASE/base/base.bg
+Source33: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/7.4-RELEASE/base/base.bh
+Source34: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/7.4-RELEASE/base/base.bi
+
+%description
+i586-pc-freebsd7.4 libraries.
+
+%prep
+%setup -q -c -T -n %{name}-%{version}
+
+  cat \
+ %SOURCE0 %SOURCE1 %SOURCE2 %SOURCE3 %SOURCE4 \
+ %SOURCE5 %SOURCE6 %SOURCE7 %SOURCE8 %SOURCE9 \
+ %SOURCE10 %SOURCE11 %SOURCE12 %SOURCE13 %SOURCE14 \
+ %SOURCE15 %SOURCE16 %SOURCE17 %SOURCE18 %SOURCE19 \
+ %SOURCE20 %SOURCE21 %SOURCE22 %SOURCE23 %SOURCE24 \
+ %SOURCE25 %SOURCE26 %SOURCE27 %SOURCE28 %SOURCE29 \
+ %SOURCE30 %SOURCE31 %SOURCE32 %SOURCE33 %SOURCE34 \
+ | %{__tar} --unlink -pxzf - ./lib ./usr/lib ./usr/include %{?el5:||:}
+
+%build
+  # Setup sys-root (Usable for gcc >= 3.4)
+  mkdir -p i586-pc-freebsd7.4/sys-root
+  %{__tar} cf - lib usr/lib usr/include | ( cd i586-pc-freebsd7.4/sys-root ; %{__tar} xf -)
+
+  pushd i586-pc-freebsd7.4/sys-root/usr/lib > /dev/null
+  # missing files
+  rm -f lib*_p.*
+  # not needed
+  rm -rf aout compat
+
+  # Fix up symlinks
+  find -type l -exec ls -l {} \; | \
+    while read a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 aA ; do \
+    case $aA in
+    /lib* ) # link
+       rm $a8;
+       b=`basename $aA`
+       ln -s ../../lib/$b $a8
+       ;;
+    esac
+  done
+  popd > /dev/null
+
+%install
+  rm -rf $RPM_BUILD_ROOT
+  mkdir -p $RPM_BUILD_ROOT%{_prefix}
+  cp -a i586-pc-freebsd7.4 $RPM_BUILD_ROOT%{_prefix}
+
+# Extract %%__os_install_post into os_install_post~
+cat << \EOF > os_install_post~
+%__os_install_post
+EOF
+
+# Generate customized brp-*scripts
+cat os_install_post~ | while read a x y; do
+case $a in
+# Prevent brp-strip* from trying to handle foreign binaries
+*/brp-strip*)
+  b=$(basename $a)
+  sed -e 's,find $RPM_BUILD_ROOT,find $RPM_BUILD_ROOT%_bindir $RPM_BUILD_ROOT%_libexecdir,' $a > $b
+  chmod a+x $b
+  ;;
+esac
+done
+
+sed -e 's,^\s*/usr/lib/rpm.*/brp-strip,./brp-strip,' \
+< os_install_post~ > os_install_post 
+%define __os_install_post . ./os_install_post
+
+
+cat << EOF > %{_builddir}/%{name}-%{freebsd_rpmvers}/find-provides
+#!/bin/sh
+grep -E -v '^${RPM_BUILD_ROOT}%{_exec_prefix}/i586-pc-freebsd7.4/(lib|include|sys-root)' \
+  %{?_gcclibdir:| grep -v '^${RPM_BUILD_ROOT}%{_gcclibdir}/gcc/i586-pc-freebsd7.4/'} | %__find_provides
+EOF
+chmod +x %{_builddir}/%{name}-%{freebsd_rpmvers}/find-provides
+%define __find_provides %{_builddir}/%{name}-%{freebsd_rpmvers}/find-provides
+
+cat << EOF > %{_builddir}/%{name}-%{freebsd_rpmvers}/find-requires
+#!/bin/sh
+grep -E -v '^${RPM_BUILD_ROOT}%{_exec_prefix}/i586-pc-freebsd7.4/(lib|include|sys-root)' \
+  %{?_gcclibdir:| grep -v '^${RPM_BUILD_ROOT}%{_gcclibdir}/gcc/i586-pc-freebsd7.4/'} | %__find_requires
+EOF
+chmod +x %{_builddir}/%{name}-%{freebsd_rpmvers}/find-requires
+%define __find_requires %{_builddir}/%{name}-%{freebsd_rpmvers}/find-requires
+
+%ifnarch noarch
+# Extract %%__debug_install_post into debug_install_post~
+cat << \EOF > debug_install_post~
+%__debug_install_post
+EOF
+
+# Generate customized debug_install_post script
+cat debug_install_post~ | while read a x y; do
+case $a in
+# Prevent find-debuginfo.sh* from trying to handle foreign binaries
+*/find-debuginfo.sh)
+  b=$(basename $a)
+  sed -e 's,find "$RPM_BUILD_ROOT" !,find "$RPM_BUILD_ROOT"%_bindir "$RPM_BUILD_ROOT"%_libexecdir !,' $a > $b
+  chmod a+x $b
+  ;;
+esac
+done
+
+sed -e 's,^[ ]*/usr/lib/rpm/find-debuginfo.sh,./find-debuginfo.sh,' \
+< debug_install_post~ > debug_install_post 
+%define __debug_install_post . ./debug_install_post
+
+%endif
+
+%clean
+  rm -rf $RPM_BUILD_ROOT
+
+%package sys-root
+Group: Development/Tools
+Summary: i586-pc-freebsd7.4 target files for gcc >= 3.4
+
+%description sys-root
+i586-pc-freebsd7.4 target files for gcc >= 3.4
+
+%files sys-root
+%defattr(-,root,root,-)
+%dir %{_prefix}/i586-pc-freebsd7.4
+%{_prefix}/i586-pc-freebsd7.4/sys-root
diff --git a/freebsd7.4/i586/libs.add b/freebsd7.4/i586/libs.add
new file mode 100644
index 0000000..279b1f1
--- /dev/null
+++ b/freebsd7.4/i586/libs.add
@@ -0,0 +1,98 @@
+%define freebsd_version @FREEBSD_VERS@
+%define freebsd_rpmvers %{expand:%(echo @FREEBSD_VERS@ | tr - _)}
+
+%define _use_internal_dependency_generator 0
+%define __debug_install_post %{nil}
+
+Name:		@rpmprefix@@tool_target@
+Release:	@FREEBSD_RPMREL@
+License:	FreeBSD
+Group:		Development/Tools
+
+BuildRoot:	%{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n)
+BuildArch:	noarch
+
+Version:      	%freebsd_rpmvers
+Summary:      	@tool_target@ Libraries
+
+Source0:  http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/@FREEBSD_VERS@-RELEASE/base/base.aa
+Source1:  http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/@FREEBSD_VERS@-RELEASE/base/base.ab
+Source2:  http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/@FREEBSD_VERS@-RELEASE/base/base.ac
+Source3:  http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/@FREEBSD_VERS@-RELEASE/base/base.ad
+Source4:  http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/@FREEBSD_VERS@-RELEASE/base/base.ae
+Source5:  http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/@FREEBSD_VERS@-RELEASE/base/base.af
+Source6:  http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/@FREEBSD_VERS@-RELEASE/base/base.ag
+Source7:  http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/@FREEBSD_VERS@-RELEASE/base/base.ah
+Source8:  http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/@FREEBSD_VERS@-RELEASE/base/base.ai
+Source9:  http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/@FREEBSD_VERS@-RELEASE/base/base.aj
+Source10: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/@FREEBSD_VERS@-RELEASE/base/base.ak
+Source11: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/@FREEBSD_VERS@-RELEASE/base/base.al
+Source12: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/@FREEBSD_VERS@-RELEASE/base/base.am
+Source13: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/@FREEBSD_VERS@-RELEASE/base/base.an
+Source14: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/@FREEBSD_VERS@-RELEASE/base/base.ao
+Source15: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/@FREEBSD_VERS@-RELEASE/base/base.ap
+Source16: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/@FREEBSD_VERS@-RELEASE/base/base.aq
+Source17: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/@FREEBSD_VERS@-RELEASE/base/base.ar
+Source18: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/@FREEBSD_VERS@-RELEASE/base/base.as
+Source19: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/@FREEBSD_VERS@-RELEASE/base/base.at
+Source20: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/@FREEBSD_VERS@-RELEASE/base/base.au
+Source21: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/@FREEBSD_VERS@-RELEASE/base/base.av
+Source22: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/@FREEBSD_VERS@-RELEASE/base/base.aw
+Source23: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/@FREEBSD_VERS@-RELEASE/base/base.ax
+Source24: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/@FREEBSD_VERS@-RELEASE/base/base.ay
+Source25: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/@FREEBSD_VERS@-RELEASE/base/base.az
+Source26: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/@FREEBSD_VERS@-RELEASE/base/base.ba
+Source27: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/@FREEBSD_VERS@-RELEASE/base/base.bb
+Source28: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/@FREEBSD_VERS@-RELEASE/base/base.bc
+Source29: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/@FREEBSD_VERS@-RELEASE/base/base.bd
+Source30: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/@FREEBSD_VERS@-RELEASE/base/base.be
+Source31: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/@FREEBSD_VERS@-RELEASE/base/base.bf
+Source32: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/@FREEBSD_VERS@-RELEASE/base/base.bg
+Source33: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/@FREEBSD_VERS@-RELEASE/base/base.bh
+Source34: http://ftp-archive.freebsd.org/pub/FreeBSD-Archive/old-releases/i386/@FREEBSD_VERS@-RELEASE/base/base.bi
+
+%description
+ at tool_target@ libraries.
+
+%prep
+%setup -q -c -T -n %{name}-%{version}
+
+  cat \
+ %SOURCE0 %SOURCE1 %SOURCE2 %SOURCE3 %SOURCE4 \
+ %SOURCE5 %SOURCE6 %SOURCE7 %SOURCE8 %SOURCE9 \
+ %SOURCE10 %SOURCE11 %SOURCE12 %SOURCE13 %SOURCE14 \
+ %SOURCE15 %SOURCE16 %SOURCE17 %SOURCE18 %SOURCE19 \
+ %SOURCE20 %SOURCE21 %SOURCE22 %SOURCE23 %SOURCE24 \
+ %SOURCE25 %SOURCE26 %SOURCE27 %SOURCE28 %SOURCE29 \
+ %SOURCE30 %SOURCE31 %SOURCE32 %SOURCE33 %SOURCE34 \
+ | %{__tar} --unlink -pxzf - ./lib ./usr/lib ./usr/include %{?el5:||:}
+
+%build
+  # Setup sys-root (Usable for gcc >= 3.4)
+  mkdir -p @tool_target@/sys-root
+  %{__tar} cf - lib usr/lib usr/include | ( cd @tool_target@/sys-root ; %{__tar} xf -)
+
+  pushd @tool_target@/sys-root/usr/lib > /dev/null
+  # missing files
+  rm -f lib*_p.*
+  # not needed
+  rm -rf aout compat
+
+  # Fix up symlinks
+  find -type l -exec ls -l {} \; | \
+    while read a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 aA ; do \
+    case $aA in
+    /lib* ) # link
+       rm $a8;
+       b=`basename $aA`
+       ln -s ../../lib/$b $a8
+       ;;
+    esac
+  done
+  popd > /dev/null
+
+%install
+  rm -rf $RPM_BUILD_ROOT
+  mkdir -p $RPM_BUILD_ROOT%{_prefix}
+  cp -a @tool_target@ $RPM_BUILD_ROOT%{_prefix}
+
diff --git a/freebsd7.4/i586/target-libs.add b/freebsd7.4/i586/target-libs.add
new file mode 100644
index 0000000..0550fc7
--- /dev/null
+++ b/freebsd7.4/i586/target-libs.add
@@ -0,0 +1,11 @@
+%package sys-root
+Group: Development/Tools
+Summary: @tool_target@ target files for gcc >= 3.4
+
+%description sys-root
+ at tool_target@ target files for gcc >= 3.4
+
+%files sys-root
+%defattr(-,root,root,-)
+%dir %{_prefix}/@tool_target@
+%{_prefix}/@tool_target@/sys-root
diff --git a/freebsd7.4/libs.am b/freebsd7.4/libs.am
new file mode 100644
index 0000000..a44fe58
--- /dev/null
+++ b/freebsd7.4/libs.am
@@ -0,0 +1,18 @@
+LIBS_SUBPACKAGES = $(top_srcdir)/common/common.add
+LIBS_SUBPACKAGES += $(srcdir)/libs.add
+LIBS_SUBPACKAGES += $(top_srcdir)/gcc/rpm-install.add
+LIBS_SUBPACKAGES += $(top_srcdir)/common/clean.add
+LIBS_SUBPACKAGES += $(srcdir)/target-libs.add
+
+$(TARGET)-libs.spec.in: $(LIBS_SUBPACKAGES) Makefile.am
+	cat $(LIBS_SUBPACKAGES) | sed \
+	  -e "s/[@]FREEBSD_VERS[@]/$(FREEBSD_VERS)/g" \
+	  -e "s/[@]FREEBSD_RPMREL[@]/$(FREEBSD_RPMREL)%{?dist}/g" \
+	  -e "s,%{gcc_rpmvers},%{freebsd_rpmvers},g" \
+	> $(TARGET)-libs.spec.in
+CLEANFILES += $(TARGET)-libs.spec.in
+	                      
+ at rpmprefix@$(TARGET)-libs.spec: $(TARGET)-libs.spec.in
+	$(MKSPEC) $(TARGET)-libs.spec.in | $(SPECSTRIP) > $@
+CLEANFILES += @rpmprefix@$(TARGET)-libs.spec
+noinst_DATA += @rpmprefix@$(TARGET)-libs.spec




More information about the vc mailing list