X-Git-Url: http://git.pld-linux.org/gitweb.cgi?a=blobdiff_plain;f=qemu.spec;h=530d17022f8da62545d9168e8e13ff09de84fdfb;hb=0d2efd95917ca5766e092b4dc68877a00b9de6cc;hp=088c689c6b1ec48c29d4769cdcdb1d544ebdd21c;hpb=076f784ae73fe4ecdfd7164b64ff306356b56ecd;p=packages%2Fqemu.git diff --git a/qemu.spec b/qemu.spec index 088c689..530d170 100644 --- a/qemu.spec +++ b/qemu.spec @@ -36,17 +36,15 @@ Patch4: %{name}-gcc4_x86.patch Patch5: %{name}-gcc4_ppc.patch Patch6: %{name}-nosdlgui.patch Patch7: %{name}-ifup.patch -Patch8: %{name}-gcc33.patch -Patch9: %{name}-parallel.patch URL: http://fabrice.bellard.free.fr/qemu/ BuildRequires: SDL-devel >= 1.2.1 BuildRequires: alsa-lib-devel %{!?with_gcc4:BuildRequires: gcc < 5:4.0} %if %{with kqemu} && %{with dist_kernel} -BuildRequires: kernel-module-build >= 3:2.6.7 +BuildRequires: kernel%{_alt_kernel}-module-build >= 3:2.6.7 %endif BuildRequires: perl-tools-pod -BuildRequires: rpmbuild(macros) >= 1.217 +BuildRequires: rpmbuild(macros) >= 1.326 BuildRequires: tetex BuildRequires: sed >= 4.0 Requires: SDL >= 1.2.1 @@ -88,7 +86,7 @@ aby dzia u¿ywane do wirtualnego hostowania kilku wirtualnych pecetów na pojedynczym serwerze. -%package -n kernel-misc-kqemu +%package -n kernel%{_alt_kernel}-misc-kqemu Summary: kqemu - kernel module Summary(pl): kqemu - modu³ j±dra Version: %{_kqemu_version} @@ -99,27 +97,27 @@ License: Free to use, non-distributable Requires(post,postun): /sbin/depmod Requires: module-init-tools >= 3.2.2-2 -%description -n kernel-misc-kqemu +%description -n kernel%{_alt_kernel}-misc-kqemu kqemu - kernel module. -%description -n kernel-misc-kqemu -l pl +%description -n kernel%{_alt_kernel}-misc-kqemu -l pl kqemu - modu³ j±dra. -%package -n kernel-smp-misc-kqemu +%package -n kernel%{_alt_kernel}-smp-misc-kqemu Summary: kqemu - SMP kernel module Summary(pl): kqemu - modu³ j±dra SMP Version: %{_kqemu_version} Release: %{_rel}@%{_kernel_ver_str} Group: Base/Kernel -%{?with_dist_kernel:%requires_releq_kernel_up} +%{?with_dist_kernel:%requires_releq_kernel_smp} License: Free to use, non-distributable Requires(post,postun): /sbin/depmod Requires: module-init-tools >= 3.2.2-2 -%description -n kernel-smp-misc-kqemu +%description -n kernel%{_alt_kernel}-smp-misc-kqemu kqemu - SMP kernel module. -%description -n kernel-smp-misc-kqemu -l pl +%description -n kernel%{_alt_kernel}-smp-misc-kqemu -l pl kqemu - modu³ j±dra SMP. %prep @@ -134,10 +132,6 @@ kqemu - modu %endif %{?with_nosdlgui:%patch6 -p1} %patch7 -p1 -# probably not needed -#%patch8 -p1 -# probably not needed -#%%patch9 -p1 %{__sed} -i -e 's/sdl_static=yes/sdl_static=no/' configure %{__sed} -i 's/.*MAKE) -C kqemu$//' Makefile @@ -167,35 +161,26 @@ EOF %build %if %{with kernel} cd kqemu-%{_kqemu_version} + +mv -f kqemu-mod-i386.o{,.bin} +mv -f kqemu-mod-x86_64.o{,.bin} mv -f kqemu-linux.c{,.orig} -for cfg in %{?with_dist_kernel:%{?with_smp:smp} up}%{!?with_dist_kernel:nondist}; do - if [ ! -r "%{_kernelsrcdir}/config-$cfg" ]; then - exit 1 - fi - install -d o/include/linux - ln -sf %{_kernelsrcdir}/config-$cfg o/.config - ln -sf %{_kernelsrcdir}/Module.symvers-$cfg o/Module.symvers - ln -sf %{_kernelsrcdir}/include/linux/autoconf-$cfg.h o/include/linux/autoconf.h -%if %{with dist_kernel} - %{__make} -C %{_kernelsrcdir} O=$PWD/o prepare scripts -%else - install -d o/include/config - touch o/include/config/MARKER - ln -sf %{_kernelsrcdir}/scripts o/scripts -%endif - if grep -q "^CONFIG_PREEMPT_RT=y$" o/.config; then - sed 's/SPIN_LOCK_UNLOCKED/SPIN_LOCK_UNLOCKED(kqemu_lock)/' \ - kqemu-linux.c.orig > kqemu-linux.c - else - cat kqemu-linux.c.orig > kqemu-linux.c - fi - - %{__make} -C %{_kernelsrcdir} modules \ - CC="%{__cc}" CPP="%{__cpp}" \ - M=$PWD O=$PWD/o \ - %{?with_verbose:V=1} - mv kqemu.ko kqemu-mod-$cfg.ko -done +cat > Makefile <<'EOF' +obj-m := kqemu.o +kqemu-objs:= kqemu-linux.o kqemu-mod.o + +$(obj)/kqemu-mod.o: $(src)/kqemu-mod-$(ARCH).o.bin + cp $< $@ +EOF + +%build_kernel_modules -m kqemu <<'EOF' +if grep -q "CONFIG_PREEMPT_RT" o/.config; then + sed 's/SPIN_LOCK_UNLOCKED/SPIN_LOCK_UNLOCKED(kqemu_lock)/' \ + kqemu-linux.c.orig > kqemu-linux.c +else + cat kqemu-linux.c.orig > kqemu-linux.c +fi +EOF cd - %endif @@ -237,12 +222,10 @@ EOF %endif %if %{with kernel} -install -d $RPM_BUILD_ROOT/lib/modules/%{_kernel_ver}{,smp}/misc +%install_kernel_modules -m kqemu-%{_kqemu_version}/kqemu -d misc install -d $RPM_BUILD_ROOT/etc/{modprobe.d/%{_kernel_ver}{,smp},udev/rules.d} -install kqemu-%{_kqemu_version}/kqemu-mod-up.ko $RPM_BUILD_ROOT/lib/modules/%{_kernel_ver}/misc/kqemu.ko install modprobe.conf $RPM_BUILD_ROOT/etc/modprobe.d/%{_kernel_ver}/kqemu.conf %if %{with smp} && %{with dist_kernel} -install kqemu-%{_kqemu_version}/kqemu-mod-smp.ko $RPM_BUILD_ROOT/lib/modules/%{_kernel_ver}smp/misc/kqemu.ko install modprobe.conf $RPM_BUILD_ROOT/etc/modprobe.d/%{_kernel_ver}smp/kqemu.conf %endif install udev.conf $RPM_BUILD_ROOT/etc/udev/rules.d/kqemu.rules @@ -262,16 +245,16 @@ modprobe kqemu EOF %endif -%post -n kernel-misc-kqemu +%post -n kernel%{_alt_kernel}-misc-kqemu %depmod %{_kernel_ver} -%postun -n kernel-misc-kqemu +%postun -n kernel%{_alt_kernel}-misc-kqemu %depmod %{_kernel_ver} -%post -n kernel-smp-misc-kqemu +%post -n kernel%{_alt_kernel}-smp-misc-kqemu %depmod %{_kernel_ver}smp -%postun -n kernel-smp-misc-kqemu +%postun -n kernel%{_alt_kernel}-smp-misc-kqemu %depmod %{_kernel_ver}smp %if %{with userspace} @@ -286,7 +269,7 @@ EOF %endif %if %{with kernel} -%files -n kernel-misc-kqemu +%files -n kernel%{_alt_kernel}-misc-kqemu %defattr(644,root,root,755) %doc kqemu-%{_kqemu_version}/LICENSE %config(noreplace) %verify(not md5 mtime size) /etc/udev/rules.d/kqemu.rules @@ -294,7 +277,7 @@ EOF /lib/modules/%{_kernel_ver}/misc/kqemu.ko* %if %{with smp} && %{with dist_kernel} -%files -n kernel-smp-misc-kqemu +%files -n kernel%{_alt_kernel}-smp-misc-kqemu %defattr(644,root,root,755) %doc kqemu-%{_kqemu_version}/LICENSE %config(noreplace) %verify(not md5 mtime size) /etc/udev/rules.d/kqemu.rules