]> git.pld-linux.org Git - packages/klibc.git/blobdiff - klibc.spec
- fix mktemp syntax.
[packages/klibc.git] / klibc.spec
index 9dc1d568240670fb56482b30d0e3346d1ced0d8a..25fdf27d40520ebbb95e4945dbe78482567af870 100644 (file)
@@ -3,16 +3,22 @@
 %bcond_without dist_kernel     # build without distribution kernel-headers
 #
 Summary:       Minimalistic libc subset for use with initramfs
-Summary(pl):   Zminimalizowany podzbiór bibliteki C do u¿ywa z initramfs
+Summary(pl):   Zminimalizowany podzbiór biblioteki C do u¿ywania z initramfs
 Name:          klibc
-Version:       0.87
+Version:       1.1.16
 Release:       1
-License:       BSD
+License:       BSD/GPL
 Group:         Libraries
-Source0:       ftp://ftp.kernel.org/pub/linux/libs/klibc/%{name}-%{version}.tar.bz2
-# Source0-md5: 51e93c1a42fe432c0eb5e98f5374ac6e
+Source0:       http://www.kernel.org/pub/linux/libs/klibc/Testing/%{name}-%{version}.tar.bz2
+# Source0-md5: 80b85e84306695ed61049720008dd409
+Patch0:                %{name}-klcc.patch
+Patch1:                %{name}-kill_interp_sohash.patch
+Patch2:                %{name}-ash-fix-mktemp-syntax.patch
 URL:           http://www.zytor.com/mailman/listinfo/klibc/
 %{?with_dist_kernel:BuildRequires:     kernel-headers >= 2.4}
+BuildRequires: bison
+BuildRequires: flex
+BuildRequires: rpmbuild(macros) >= 1.153
 BuildRequires: perl-base
 BuildRoot:     %{tmpdir}/%{name}-%{version}-root-%(id -u -n)
 
@@ -26,35 +32,147 @@ progress, and a lot of things are still missing.
 
 %description -l pl
 klibc w zamierzeniu ma byæ minimalistycznym podzbiorem biblioteki libc
-do u¿ycia z initramfs. Celem jest minimalizacja, przenaszalno¶æ ale
-nie szybko¶æ. klibc jest rozwijan± bibliotek± w zwi±zku z czym nadal
+do u¿ycia z initramfs. Celem jest minimalizacja, przeno¶no¶æ ale nie
+szybko¶æ. klibc jest rozwijan± bibliotek± w zwi±zku z czym nadal
 brakuje wielu rzeczy.
 
+%package devel
+Summary:       Development files for klibc
+Summary(pl):   Pliki dla programistów klibc
+Group:         Development/Libraries
+Requires:      %{name} = %{version}-%{release}
+Requires:      binutils
+%{?with_dist_kernel:Requires:  kernel-headers >= 2.4}
+
+%description devel
+Small libc for building embedded applications - development files.
+
+%description devel -l pl
+Ma³a libc do budowania aplikacji wbudowanych - pliki dla programistów.
+
+%package static
+Summary:       Static klibc libraries
+Summary(pl):   Biblioteki statyczne klibc
+Group:         Development/Libraries
+Requires:      %{name}-devel = %{version}-%{release}
+
+%description static
+Static klibc libraries.
+
+%description static -l pl
+Biblioteki statyczne klibc.
+
+%package utils-shared
+Summary:       Utilities dynamically linked with klibc
+Summary(pl):   Narzêdzia dynamicznie zlinkowane z klibc
+Group:         Base
+Requires:      %{name} = %{version}-%{release}
+
+%description utils-shared
+Utilities dynamically linked with klibc.
+
+%description utils-shared -l pl
+Narzêdzia dynamicznie zlinkowane z klibc.
+
+%package utils-static
+Summary:       Utilities statically linked with klibc
+Summary(pl):   Narzêdzia statycznie zlinkowane z klibc
+Group:         Base
+
+%description utils-static
+Utilities staticly linked with klibc.
+
+%description utils-static -l pl
+Narzêdzia statycznie zlinkowane z klibc.
+
 %prep
 %setup -q
+%patch0 -p1
+%patch1 -p1
+%patch2 -p1
 
 %build
-ln -s %{_kernelsrcdir} linux
+rm -rf include/{asm,asm-generic,linux}
+%ifarch ppc powerpc
+if [ -d %{_kernelsrcdir}/include/asm-powerpc ]; then
+       install -d include/asm
+       cp -a %{_kernelsrcdir}/include/asm-ppc/* include/asm/
+       cp -a %{_kernelsrcdir}/include/asm-powerpc/* include/asm/
+else
+       ln -sf %{_kernelsrcdir}/include/asm-%{_target_base_arch} include/asm
+fi
+%else
+       ln -sf %{_kernelsrcdir}/include/asm-%{_target_base_arch} include/asm
+%endif
+cd include
+ln -sf %{_kernelsrcdir}/include/asm-generic .
+ln -sf %{_kernelsrcdir}/include/linux .
+%if %{with dist_kernel}
+[ ! -d arch/%{_target_base_arch}/linux ] && mkdir arch/%{_target_base_arch}/linux
+ln -sf  %{_kernelsrcdir}/include/linux/autoconf-up.h arch/%{_target_base_arch}/linux/autoconf.h
+%endif
+for a in `ls arch`; do [ "$a" != "%{_target_base_arch}" ] && rm -rf arch/$a; done
+cd ..
+
+%ifarch sparc
+# hack; missing dependency in make system
+( cd klibc && %{__make} -f arch/sparc/Makefile.inc ARCH=sparc \
+        arch/sparc/sdiv.S arch/sparc/udiv.S arch/sparc/srem.S arch/sparc/urem.S )
+%endif
 
 %{__make} \
-       CC=%{__cc} \
+       ARCH=%{_target_base_arch} \
+       HOSTCC="%{__cc}" \
+       rpm_prefix=%{_prefix} \
+       rpm_bindir=%{_bindir} \
+       rpm_includedir=%{_includedir}/klibc \
+       rpm_libdir=%{_libdir} \
+       SHLIBDIR=/%{_lib} \
        OPTFLAGS="%{rpmcflags} -Os -fomit-frame-pointer -falign-functions=0 \
-               -falign-jumps=0 -falign-loops=0"
+               -falign-jumps=0 -falign-loops=0 -ffreestanding"
 
 %install
 rm -rf $RPM_BUILD_ROOT
+install -d $RPM_BUILD_ROOT/%{_lib}
 install -d $RPM_BUILD_ROOT%{_includedir}/klibc
-install -d $RPM_BUILD_ROOT%{_libdir}/klibc
+install -d $RPM_BUILD_ROOT%{_libdir}/klibc/bin-{shared,static}
 
-cp -a klibc/include/* $RPM_BUILD_ROOT%{_includedir}/klibc
-install klibc/libc.* klibc/crt0.o      $RPM_BUILD_ROOT%{_libdir}/klibc
+cp -a include/* $RPM_BUILD_ROOT%{_includedir}/klibc
+install klcc/klcc -D $RPM_BUILD_ROOT%{_bindir}/klcc
+install klcc/klcc.1 -D $RPM_BUILD_ROOT%{_mandir}/man1/klcc.1
+install klibc/libc.* klibc/arch/%{_target_base_arch}/crt0.o klibc/interp.o $RPM_BUILD_ROOT%{_libdir}/klibc
+install klibc/klibc.so $RPM_BUILD_ROOT/%{_lib}
+install dash/sh.shared $RPM_BUILD_ROOT%{_libdir}/klibc/bin-shared/sh
+install dash/sh $RPM_BUILD_ROOT%{_libdir}/klibc/bin-static/sh
+install utils/shared/* $RPM_BUILD_ROOT%{_libdir}/klibc/bin-shared
+install utils/static/* $RPM_BUILD_ROOT%{_libdir}/klibc/bin-static
 
 %clean
 rm -rf $RPM_BUILD_ROOT
 
 %files
 %defattr(644,root,root,755)
+%attr(755,root,root) /%{_lib}/klibc.so
+
+%files devel
+%defattr(644,root,root,755)
+%attr(755,root,root) %{_bindir}/klcc
+%{_includedir}/klibc
 %dir %{_libdir}/klibc
 %attr(755,root,root) %{_libdir}/klibc/*.so
-%{_libdir}/klibc/*.[ao]
-%{_includedir}/klibc
+%{_libdir}/klibc/*.o
+%{_mandir}/man1/*
+
+%files static
+%defattr(644,root,root,755)
+%{_libdir}/klibc/*.a
+
+%files utils-shared
+%defattr(644,root,root,755)
+%dir %{_libdir}/klibc/bin-shared
+%attr(755,root,root) %{_libdir}/klibc/bin-shared/*
+
+%files utils-static
+%defattr(644,root,root,755)
+%dir %{_libdir}/klibc/bin-static
+%attr(755,root,root) %{_libdir}/klibc/bin-static/*
This page took 0.077605 seconds and 4 git commands to generate.