X-Git-Url: https://git.pld-linux.org/?a=blobdiff_plain;f=qemu.spec;h=3d8abc848b9436bd10942ac58c6caa7297f36057;hb=80e91c6894fa411b1ae3b30572bfb0c0f95be777;hp=ea4b6ec0f12c92989bddfea980fcad03842a73a7;hpb=f8982f2f2b54c0f15c03d664ac4b6da2dd40d32e;p=packages%2Fqemu.git diff --git a/qemu.spec b/qemu.spec index ea4b6ec..3d8abc8 100644 --- a/qemu.spec +++ b/qemu.spec @@ -3,58 +3,67 @@ # - wait till the gcc bug http://gcc.gnu.org/PR16185 is fixed. # # Conditional build: -%bcond_with kqemu # with QEMU accelerator module +%bcond_without kqemu # disable KQEMU ACCELERATOR support in QEMU %bcond_with cflags_passing # with passing rpmcflags to Makefiles +%bcond_with dosguest # add special patch when use with DOS as guest os %bcond_with nosdlgui # do not use SDL gui (use X11 instead) +# Note that gcc4 build is very problematic and not supported by qemu team +%bcond_with gcc4 # use gcc4 patches (broke build on gcc33) %bcond_without dist_kernel # without distribution kernel -%bcond_without kernel # don't build kernel modules +%bcond_without kernel # build kqemu KERNEL MODULES +%bcond_without up # don't build up module %bcond_without smp # don't build SMP module %bcond_without userspace # don't build userspace utilities # + +%define _kqemu_version 1.3.0pre11 +%define _rel 1 Summary: QEMU CPU Emulator -Summary(pl): QEMU - emulator procesora +Summary(pl.UTF-8): QEMU - emulator procesora Name: qemu -Version: 0.7.2 -%define _rel 1 +Version: 0.9.0 Release: %{_rel}%{?with_kqemu:k} License: GPL Group: Applications/Emulators #Source0Download: http://fabrice.bellard.free.fr/qemu/download.html Source0: http://fabrice.bellard.free.fr/qemu/%{name}-%{version}.tar.gz -# Source0-md5: 7d69dd96edf7ae5298a9a7283a0e9fb8 -%if %{with kqemu} -Source1: http://fabrice.bellard.free.fr/qemu/kqemu-%{version}.tar.gz -# NoSource1-md5: 02cfdecda90458d6393781496ec6b48b -NoSource: 1 -%endif +# Source0-md5: ab11a03ba30cf4a70641f0f170473d69 +Source1: http://fabrice.bellard.free.fr/qemu/k%{name}-%{_kqemu_version}.tar.gz +# Source1-md5: 970521874ef8b1ba4598925ace5936c3 Patch0: %{name}-nostatic.patch -Patch1: %{name}-DESTDIR.patch -Patch2: %{name}-longjmp.patch +Patch1: %{name}-cc.patch Patch3: %{name}-dot.patch -Patch4: %{name}-initrd_load_addr.patch -Patch5: %{name}-gcc4_x86.patch -Patch6: %{name}-gcc4_ppc.patch -Patch7: %{name}-parallel.patch -Patch8: %{name}-nosdlgui.patch -Patch9: %{name}-ifup.patch +Patch4: %{name}-gcc4_x86.patch +Patch5: %{name}-gcc4_ppc.patch +Patch6: %{name}-nosdlgui.patch +Patch7: %{name}-ifup.patch +# Proof of concept, for reference, do not remove +Patch8: %{name}-kde_virtual_workspaces_hack.patch +# http://gwenole.beauchesne.info/en/projects/qemu +Patch9: %{name}-0.8.0-gcc4-hacks.patch +Patch11: %{name}-0.7.2-gcc4-opts.patch +#Patch12: %{name}-0.7.2-dyngen-check-stack-clobbers.patch +Patch13: %{name}-dosguest.patch URL: http://fabrice.bellard.free.fr/qemu/ -BuildRequires: SDL-devel >= 1.2.1 -%if %{with kqemu} && %{with dist_kernel} -BuildRequires: kernel-module-build >= 2.6.7 +%if %{with kernel} && %{with dist_kernel} +BuildRequires: kernel%{_alt_kernel}-module-build >= 3:2.6.7 +BuildRequires: rpmbuild(macros) >= 1.330 %endif -BuildRequires: rpmbuild(macros) >= 1.217 +%if %{with userspace} +BuildRequires: SDL-devel >= 1.2.1 +BuildRequires: alsa-lib-devel +%{!?with_gcc4:BuildRequires: gcc < 5:4.0} +BuildRequires: perl-tools-pod +BuildRequires: tetex BuildRequires: sed >= 4.0 +%endif Requires: SDL >= 1.2.1 -ExclusiveArch: %{ix86} %{x8664} ppc # sparc is currently unsupported (missing cpu_get_real_ticks() impl in vl.c) +ExclusiveArch: %{ix86} %{x8664} %{!?with_kqemu:ppc} BuildRoot: %{tmpdir}/%{name}-%{version}-root-%(id -u -n) # some SPARC boot image in ELF format -%define _noautostrip .*%{_datadir}/qemu/proll.elf - -%if !%{with kqemu} -%undefine with_kernel -%endif +%define _noautostrip .*%{_datadir}/qemu/openbios-sparc32 %description QEMU is a FAST! processor emulator. By using dynamic translation it @@ -67,67 +76,82 @@ CPUs. QEMU has two operating modes: emulation) and DOSEMU (DOS emulation) are the main targets for QEMU. - Full system emulation. In this mode, QEMU emulates a full system, - including a processor and various peripherials. - It can also be used to provide virtual hosting of several - virtual PC on a single server. + including a processor and various peripherials. It can also be used to + provide virtual hosting of several virtual PC on a single server. -%description -l pl -QEMU to szybki(!) emulator procesora. Poprzez u¿ycie dynamicznego -t³umaczenia osi±ga rozs±dn± szybko¶æ i jest ³atwy do przeportowania, -aby dzia³a³ na kolejnych procesorach. QEMU ma dwa tryby pracy: +%description -l pl.UTF-8 +QEMU to szybki(!) emulator procesora. Poprzez użycie dynamicznego +tłumaczenia osiąga rozsądną szybkość i jest łatwy do przeportowania, +aby działał na kolejnych procesorach. QEMU ma dwa tryby pracy: -- Emulacja trybu u¿ytkownika. W tym trybie QEMU mo¿e uruchamiaæ +- Emulacja trybu użytkownika. W tym trybie QEMU może uruchamiać procesy linuksowe skompilowane dla jednego procesora na innym - procesorze. Linuksowe wywo³ania systemowe s± t³umaczone ze wzglêdu - na niezgodno¶æ kolejno¶ci bajtów w s³owie i 32/64-bitowego rozmiaru - s³owa. Wine (emulacja Windows) i DOSEMU (emulacja DOS-a) to g³ówne + procesorze. Linuksowe wywołania systemowe są tłumaczone ze względu na + niezgodność kolejności bajtów w słowie i 32/64-bitowego rozmiaru + słowa. Wine (emulacja Windows) i DOSEMU (emulacja DOS-a) to główne cele QEMU. -- Pe³na emulacja systemu. W tym trybie QEMU emuluje ca³y system, - w³±czaj±c w to procesor i ró¿ne urz±dzenia peryferyjne. - Mo¿e byæ tak¿e u¿ywane do wirtualnego hostowania kilku wirtualnych - pecetów na pojedynczym serwerze. +- Pełna emulacja systemu. W tym trybie QEMU emuluje cały system, + włączając w to procesor i różne urządzenia peryferyjne. Może być także + 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 +Summary(pl.UTF-8): kqemu - moduł jądra +Version: %{_kqemu_version} Release: %{_rel}@%{_kernel_ver_str} Group: Base/Kernel %{?with_dist_kernel:%requires_releq_kernel_up} +License: GPL v2 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 -kqemu - modu³ j±dra. +%description -n kernel%{_alt_kernel}-misc-kqemu -l pl.UTF-8 +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 +Summary(pl.UTF-8): 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: GPL v2 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 -kqemu - modu³ j±dra SMP. +%description -n kernel%{_alt_kernel}-smp-misc-kqemu -l pl.UTF-8 +kqemu - moduł jądra SMP. %prep -%setup -q %{?with_kqemu:-a1} +%if %{with kernel} +%if %{with dist_kernel} && %{without up} && %{without smp} +%{error:%{name}: If building kernel module You need to enable at least one of up or smp} +exit 1 +%endif +%endif + +%setup -q %{?with_kernel:-a1} %patch0 -p1 %patch1 -p1 -%patch2 -p1 %patch3 -p1 -%patch4 -p1 -%patch5 -p0 -%patch6 -p1 -%patch7 -p1 -%{?with_nosdlgui:%patch8 -p1} +%if %{with gcc4} %patch9 -p1 +%patch11 -p1 +#%patch12 -p1 +#%patch4 -p0 +%patch5 -p1 +%endif +%{?with_nosdlgui:%patch6 -p1} +%patch7 -p1 +#%patch8 -p1 %{__sed} -i -e 's/sdl_static=yes/sdl_static=no/' configure %{__sed} -i 's/.*MAKE) -C kqemu$//' Makefile @@ -139,31 +163,57 @@ kqemu - modu %{__sed} -i 's/-Wall -O2 -g/-Wall -O2/' Makefile Makefile.target %endif -%{?with_kqemu:echo -n > kqemu/install.sh} +%if %{with kernel} +echo -n > kqemu-%{_kqemu_version}/install.sh + +cat <<'EOF' > modprobe.conf +# enable dynamic major +options kqemu major=0 +# for autoloading from static dev +#alias char-major-250 kqemu +EOF + +cat <<'EOF' > udev.conf +KERNEL=="kqemu", NAME="%k", MODE="0666" +EOF +%endif + +%if %{with dosguest} +%patch13 -p1 +%endif %build %if %{with kernel} -cd kqemu -for cfg in %{?with_dist_kernel:%{?with_smp:smp} up}%{!?with_dist_kernel:nondist}; do - if [ ! -r "%{_kernelsrcdir}/config-$cfg" ]; then - exit 1 - fi - rm -rf include - install -d include/{linux,config} - ln -sf %{_kernelsrcdir}/config-$cfg .config - ln -sf %{_kernelsrcdir}/include/linux/autoconf-$cfg.h include/linux/autoconf.h - ln -sf %{_kernelsrcdir}/include/asm-%{_target_base_arch} include/asm -%if %{without dist_kernel} - ln -sf %{_kernelsrcdir}/scripts +cd kqemu-%{_kqemu_version} + +%{__sed} -i 's#include ../config-host.mak##' ./common/Makefile +%ifarch %{x8664} +%{__sed} -i 's/^#ARCH=x86_64/ARCH=x86_64/' ./common/Makefile +%{__make} -C common +mv -f kqemu-mod-x86_64.o{,.bin} +%else +%{__sed} -i 's/^#ARCH=i386/ARCH=i386/' ./common/Makefile +%{__make} -C common +mv -f kqemu-mod-i386.o{,.bin} %endif - touch include/config/MARKER - %{__make} -C %{_kernelsrcdir} clean \ - RCS_FIND_IGNORE="-name 'kqemu-mod-*.*' -o" \ - M=$PWD O=$PWD - %{__make} -C %{_kernelsrcdir} modules \ - M=$PWD O=$PWD - mv kqemu.ko kqemu-mod-$cfg.ko -done + +mv -f kqemu-linux.c{,.orig} +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 @@ -173,8 +223,16 @@ cd - ./configure \ --prefix=%{_prefix} \ --cc="%{__cc}" \ - %{!?with_kqemu:--disable-kqemu} \ - --make="%{__make}" + --host-cc="%{__cc}" \ + --make="%{__make}" \ +%if %{with kqemu} + --kernel-path=%{_kernelsrcdir} \ +%else + --disable-kqemu \ +%endif + %{?with_gcc4:--disable-gcc-check} \ + --enable-alsa \ + --interp-prefix=%{_libdir}/%{name} %{__make} %endif @@ -197,20 +255,22 @@ EOF %endif %if %{with kernel} -install -d $RPM_BUILD_ROOT/lib/modules/%{_kernel_ver}{,smp}/misc -install kqemu/kqemu-mod-up.ko $RPM_BUILD_ROOT/lib/modules/%{_kernel_ver}/misc/kqemu.ko +%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 modprobe.conf $RPM_BUILD_ROOT/etc/modprobe.d/%{_kernel_ver}/kqemu.conf %if %{with smp} && %{with dist_kernel} -install kqemu/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 %endif -# This dir is unneeded -rm -rf $RPM_BUILD_ROOT/usr/share/doc/qemu +# already packaged +rm -rf $RPM_BUILD_ROOT%{_docdir}/qemu/qemu-{doc,tech}.html %clean rm -rf $RPM_BUILD_ROOT -%if %{with kqemu} +%if %{with kernel} %post %banner %{name} -e <