summaryrefslogtreecommitdiff
path: root/packaging
diff options
context:
space:
mode:
authorJunfeng.dong <junfeng.dong@intel.com>2013-07-18 10:23:52 +0800
committerJunfeng.dong <junfeng.dong@intel.com>2013-07-18 10:30:32 +0800
commitf2b7729bf48aad795235d947db0c769ca9f0f3f7 (patch)
tree0860aae0536f1f64b16bde2f6ac6aea4d9e9ba89 /packaging
downloadeglibc-arm-tizen_2.2.tar.gz
eglibc-arm-tizen_2.2.tar.bz2
eglibc-arm-tizen_2.2.zip
Change-Id: Idc0ef9212cb9092a161e3700133a8f7a3c29a720 Signed-off-by: Junfeng.dong <junfeng.dong@intel.com>
Diffstat (limited to 'packaging')
-rw-r--r--packaging/baselibs.conf6
-rw-r--r--packaging/eglibc-arm.changes2
-rw-r--r--packaging/eglibc-arm.spec202
-rw-r--r--packaging/files_to_ignore4
4 files changed, 214 insertions, 0 deletions
diff --git a/packaging/baselibs.conf b/packaging/baselibs.conf
new file mode 100644
index 0000000..1563200
--- /dev/null
+++ b/packaging/baselibs.conf
@@ -0,0 +1,6 @@
+arch armv5tel targets i586:armv5tel
+arch armv6l targets i586:armv6l
+arch armv7l targets i586:armv7l
+arch armv7hl targets i586:armv7hl
+arch armv7nhl targets i586:armv7nhl
+
diff --git a/packaging/eglibc-arm.changes b/packaging/eglibc-arm.changes
new file mode 100644
index 0000000..c81895c
--- /dev/null
+++ b/packaging/eglibc-arm.changes
@@ -0,0 +1,2 @@
+* Thu Aug 04 2011 Junfeng Dong <junfeng.dong@intel.com> -2.13
+- Initial version for SLP.
diff --git a/packaging/eglibc-arm.spec b/packaging/eglibc-arm.spec
new file mode 100644
index 0000000..46a475c
--- /dev/null
+++ b/packaging/eglibc-arm.spec
@@ -0,0 +1,202 @@
+%define __strip /bin/true
+%define _build_name_fmt %%{ARCH}/%%{NAME}-%%{VERSION}-%%{RELEASE}.%%{ARCH}.dontuse.rpm
+# meta spec file for opt-cross setup (arm -> x86 side)
+#
+# Copyright (c) 2010 Jan-Simon Möller (jsmoeller@linuxfoundation.org)
+# License: GPLv2
+#
+
+## README
+##
+## In this file:
+## 1) define name of original package (see oldname)
+##
+## File binaries_to_prepare:
+## 2) fill in the binaries which need to be available to the foreign chroot
+## e.g. /bin/bash - this will make a i586 bash available
+##
+
+#\/\/\/\/\/\/\/\/\/\/
+### only changes here
+#
+# The original package name
+%define oldname eglibc
+#
+# The architectures this meta package is built on
+%define myexclusive %arm
+#
+### no changes needed below this line
+# ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
+
+
+
+### no changes needed
+#
+# The new package name - convention is %oldname-x86
+%define newname %{oldname}-arm
+#
+# The version of the original package is read from its rpm db info
+%{expand:%%define newversion %(rpm -q --qf '[%{version}]' %oldname)}
+#
+# The license of the original package is read from its rpm db info
+%{expand:%%define newlicense %(rpm -q --qf '[%{license}]' %oldname)}
+#
+# The group information of the original package
+%{expand:%%define newgroup %(rpm -q --qf '[%{group}]' %oldname)}
+#
+# The summary of the original package
+%{expand:%%define newsummary %(rpm -q --qf '[%{summary} - special version ]' %oldname)}
+#
+# New rpath to add to files on request
+%define newrpath "/opt/cross/%_target_platform/sys-root/lib:/opt/cross/%_target_platform/sys-root/usr/lib"
+%define newinterpreter /opt/cross/%_target_platform/sys-root/lib/ld-linux.so.3
+#
+# Some automatic checks for availability
+# binaries_to_prepare
+%define binaries_to_prepare %{expand:%(test -e %{_sourcedir}/binaries_to_prepare && echo 1 || echo 0)}
+%define libraries_to_prepare %{expand:%(test -e %{_sourcedir}/libraries_to_prepare && echo 1 || echo 0)}
+%define special_script %{expand:%(test -e %{_sourcedir}/special_script && echo 1 || echo 0)}
+%define files_to_ignore %{expand:%(test -e %{_sourcedir}/files_to_ignore && echo 1 || echo 0)}
+#
+### no changes needed below this line
+
+Name: %newname
+Version: %newversion
+Release: 7
+AutoReqProv: 0
+Provides: %newname
+BuildRequires: rpm grep tar patchelf sed -rpmlint-Moblin -rpmlint-mini -post-build-checks -rpmlint-mini-x86-arm
+BuildRequires: %oldname
+Requires: %oldname
+# no auto requirements - they're generated
+License: %newlicense
+Group: %newgroup
+ExclusiveArch: %myexclusive
+Summary: %newsummary
+BuildRoot: %{_tmppath}/%{name}-%{version}-build
+%if %binaries_to_prepare
+Source10: binaries_to_prepare
+%endif
+%if %libraries_to_prepare
+Source20: libraries_to_prepare
+%endif
+%if %special_script
+Source30: special_script
+%endif
+Source100: baselibs.conf
+
+Provides: glibc-arm
+
+%description
+This is a meta-package providing %name.
+It is not intended to be used in a normal System!
+Original description:
+%{expand:%(rpm -q --qf '[%{description}]' %oldname)}
+
+
+
+%prep
+
+%build
+
+%install
+set +x
+mkdir -p %buildroot
+rpm -ql %oldname > filestoinclude1
+%if %files_to_ignore
+for i in `cat %{_sourcedir}/files_to_ignore`; do
+ echo "Ignoring file: $i"
+ sed -e "s#^${i}.*##" -i filestoinclude1
+done
+%endif
+tar -T filestoinclude1 -cpf - | ( cd %buildroot && tar -xvpf - )
+find %buildroot > filestoinclude2
+cat filestoinclude2 | sed -e "s#%{buildroot}##g" | uniq | sort > filestoinclude
+%if %binaries_to_prepare
+echo ""
+echo "[ .oO Preparing binaries Oo. ]"
+echo ""
+mkdir %buildroot/%{_prefix}/share/applybinary/
+set -x
+for binary in `cat %{_sourcedir}/binaries_to_prepare` ; do
+ echo "Processing binary: $binary"
+# deps=$(for i in `readelf -a "$binary" | grep "(NEEDED)" | sed -e "s/.*\[//g" -e "s/\].*//g" ` ; do rpm -q --whatprovides "$i" ; done)
+ ldd $binary | grep -v "ld-linux" | grep -v "linux-gate" | sed -e "s#=.*##g" -e "s#^\t*##g" > 1
+ deps=$(for i in `cat 1` ; do rpm -q --whatprovides "$i" | grep -v "no package"; done)
+ cleandeps=$(echo "$cleandeps" "$deps" | sort | uniq | sed -e "s/-[0-9].*//g")
+ patchelf --debug --set-rpath %newrpath %buildroot/$binary
+ patchelf --debug --set-rpath %newrpath %buildroot/$binary
+ patchelf --debug --set-interpreter %newinterpreter %buildroot/$binary
+ patchelf --debug --set-interpreter %newinterpreter %buildroot/$binary
+ patchelf --print-rpath %buildroot/$binary
+ patchelf --print-interpreter %buildroot/$binary
+ echo "$binary" >> %buildroot/%{_prefix}/share/applybinary/%name
+ echo ""
+done
+set +x
+%endif
+%if %libraries_to_prepare
+echo ""
+echo "[ .oO Preparing libraries Oo. ]"
+echo ""
+%endif
+%if %special_script
+echo ""
+echo "[ .oO Executing special script Oo. ]"
+echo ""
+%endif
+
+# lets start the shellquote nightmare ;)
+shellquote()
+{
+ for arg; do
+ arg=${arg//\\/\\\\}
+# arg=${arg//\$/\$} # already needs quoting ;(
+# arg=${arg/\"/\\\"} # dito
+# arg=${arg//\`/\`} # dito
+ arg=${arg//\\|/\|}
+ arg=${arg//\\|/|}
+ echo "$arg"
+ done
+}
+
+echo "Creating baselibs_new.conf"
+echo ""
+rm -rRf /tmp/baselibs_new.conf || true
+shellquote "%{name}" >> /tmp/baselibs_new.conf
+shellquote " targettype x86 block!" >> /tmp/baselibs_new.conf
+shellquote " targettype 32bit block!" >> /tmp/baselibs_new.conf
+shellquote " targettype %{_target_cpu} autoreqprov off" >> /tmp/baselibs_new.conf
+shellquote " targettype %{_target_cpu} targetname cross-%{_target_cpu}-%{oldname} " >> /tmp/baselibs_new.conf
+for i in $cleandeps ; do
+ shellquote " targettype %{_target_cpu} requires \"${i}-cross-%{_target_cpu}-x86\"" >> /tmp/baselibs_new.conf
+done
+shellquote " targettype %{_target_cpu} prefix /opt/cross/%_target_platform/sys-root" >> /tmp/baselibs_new.conf
+shellquote " targettype %{_target_cpu} extension -x86" >> /tmp/baselibs_new.conf
+shellquote " targettype %{_target_cpu} +/" >> /tmp/baselibs_new.conf
+shellquote " targettype %{_target_cpu} -%{_mandir}" >> /tmp/baselibs_new.conf
+shellquote " targettype %{_target_cpu} -%{_docdir}" >> /tmp/baselibs_new.conf
+shellquote " targettype %{_target_cpu} requires \"tizen-cross-%{_target_cpu}-sysroot\"" >> /tmp/baselibs_new.conf
+
+cat /tmp/baselibs_new.conf >> %{_sourcedir}/baselibs.conf
+
+
+echo ""
+echo ""
+echo ""
+echo "REQUIREMENTS:"
+grep "requires" %{_sourcedir}/baselibs.conf
+echo ""
+echo ""
+echo ""
+sleep 2
+set -x
+
+%clean
+rm -rf $RPM_BUILD_ROOT
+
+%files -f filestoinclude
+%defattr(-,root,root)
+%if %binaries_to_prepare
+/%{_prefix}/share/applybinary/%name
+%endif
diff --git a/packaging/files_to_ignore b/packaging/files_to_ignore
new file mode 100644
index 0000000..3011d50
--- /dev/null
+++ b/packaging/files_to_ignore
@@ -0,0 +1,4 @@
+/usr/sbin/glibc_post_upgrade*
+/var/cache/ldconfig
+/etc/ld.so.conf.d/tizen-accelerator.conf
+/etc/ld.so.cache