]> git.pld-linux.org Git - packages/VirtualBox.git/blobdiff - VirtualBox.spec
- install rel files (works now on x86_64 th)
[packages/VirtualBox.git] / VirtualBox.spec
index 1fd2e49904c6f5135cf667e73b17e93b7d23705e..6cda03af542f72d4ffb0436e062178093741c4a0 100644 (file)
@@ -1,16 +1,19 @@
 #
 # TODO:
+# - separate udev stuff from kernel package
 # - Find how to compile with PLD CFLAGS/CXXFLAGS/LDFLAGS.
 # - Package SDK.
 # - Package utils (and write initscripts ?) for Guest OS.
 # - Add udev rule.
+# - Check License of VBoxGuestAdditions_*.iso, it's propably not GPL v2.
+#   If so check if it is distributable.
 #
 # Conditional build:
 %bcond_without dist_kernel     # without distribution kernel
 %bcond_without kernel          # don't build kernel module
 %bcond_without userspace       # don't build userspace package
 
-%define                _rel            1
+%define                rel             3
 
 %if %{without kernel}
 %undefine      with_dist_kernel
 Summary:       VirtualBox - x86 hardware virtualizer
 Summary(pl.UTF-8):     VirtualBox - wirtualizator sprzętu x86
 Name:          VirtualBox
-Version:       1.5.0
-Release:       %{_rel}
+Version:       1.5.4
+Release:       %{rel}
 License:       GPL v2
 Group:         Applications/Emulators
 Source0:       http://www.virtualbox.org/download/%{version}/%{name}-%{version}_OSE.tar.bz2
-# Source0-md5: 56c074900260c109ed735c08e726fe81
-Source1:       http://www.virtualbox.org/download/UserManual.pdf
-# Source1-md5: 2e5458bd5b4b9acd18cc86866e8a7284
-Source2:       http://www.virtualbox.org/download/%{version}_OSE/VBoxGuestAdditions_%{version}_OSE.iso
-# Source2-md5: ed3ce6537350ab3e3557dc1b1e7e1b5c
-Source3:       %{name}.desktop
-Source4:       %{name}.sh
+# Source0-md5: fbebb3f04911c4c39aac27b1d3532acc
+Source1:       http://www.virtualbox.org/download/%{version}/UserManual.pdf
+# Source1-md5: f56f0d904013cbc0940108ed042e539d
+Source2:       http://www.virtualbox.org/download/%{version}/VBoxGuestAdditions_%{version}.iso
+# Source2-md5: e021a51fc5946659b0789d134b1fd5ff
+Source3:       %{name}.init
+Source4:       %{name}.desktop
+Source5:       %{name}.sh
 Patch0:                %{name}-configure.patch
 Patch1:                %{name}-qt-paths.patch
 Patch2:                %{name}-shared-libstdc++.patch
-#Patch3:               %{name}-disable-xclient-build.patch
+Patch3:                %{name}-disable-xclient-build.patch
 URL:           http://www.virtualbox.org/
 BuildRequires: SDL-devel
 BuildRequires: alsa-lib-devel
@@ -48,6 +52,7 @@ BuildRequires:        libIDL-devel
 BuildRequires: libuuid-devel
 BuildRequires: libxslt-progs
 BuildRequires: pkgconfig
+BuildRequires: pulseaudio-devel
 BuildRequires: qt-devel >= 6:3.3.6
 BuildRequires: qt-linguist
 BuildRequires: rpmbuild(macros) >= 1.329
@@ -70,9 +75,9 @@ ExclusiveArch:        %{ix86} %{x8664}
 BuildRoot:     %{tmpdir}/%{name}-%{version}-root-%(id -u -n)
 
 %ifarch %{x8664}
-%define                _outdir amd64
+%define                outdir  amd64
 %else
-%define                _outdir x86
+%define                outdir  x86
 %endif
 
 %description
@@ -121,7 +126,7 @@ konfigurację maszyny wirtualnej na inny komputer.
 %package -n kernel%{_alt_kernel}-misc-vboxadd
 Summary:       Linux kernel module for VirtualBox
 Summary(pl.UTF-8):     Moduł jądra Linuksa dla VirtualBoksa
-Release:       %{_rel}@%{_kernel_ver_str}
+Release:       %{rel}@%{_kernel_ver_str}
 Group:         Base/Kernel
 Requires(post,postun): /sbin/depmod
 Requires:      dev >= 2.9.0-7
@@ -129,7 +134,7 @@ Requires:   dev >= 2.9.0-7
 %requires_releq_kernel
 Requires(postun):      %releq_kernel
 %endif
-Provides:      kernel(vboxadd) = %{version}-%{_rel}
+Provides:      kernel(vboxadd) = %{version}-%{rel}
 
 %description -n kernel%{_alt_kernel}-misc-vboxadd
 Linux kernel module vboxadd for VirtualBox.
@@ -140,7 +145,7 @@ Moduł jądra Linuksa vboxadd dla VirtualBoksa.
 %package -n kernel%{_alt_kernel}-misc-vboxdrv
 Summary:       Linux kernel module for VirtualBox
 Summary(pl.UTF-8):     Moduł jądra Linuksa dla VirtualBoksa
-Release:       %{_rel}@%{_kernel_ver_str}
+Release:       %{rel}@%{_kernel_ver_str}
 Group:         Base/Kernel
 Requires(post,postun): /sbin/depmod
 Requires:      dev >= 2.9.0-7
@@ -148,7 +153,7 @@ Requires:   dev >= 2.9.0-7
 %requires_releq_kernel
 Requires(postun):      %releq_kernel
 %endif
-Provides:      kernel(vboxdrv) = %{version}-%{_rel}
+Provides:      kernel(vboxdrv) = %{version}-%{rel}
 
 %description -n kernel%{_alt_kernel}-misc-vboxdrv
 Linux kernel module vboxdrv for VirtualBox.
@@ -159,7 +164,7 @@ Moduł jądra Linuksa vboxdrv dla VirtualBoksa.
 %package -n kernel%{_alt_kernel}-misc-vboxvfs
 Summary:       Linux kernel module for VirtualBox
 Summary(pl.UTF-8):     Moduł jądra Linuksa dla VirtualBoksa
-Release:       %{_rel}@%{_kernel_ver_str}
+Release:       %{rel}@%{_kernel_ver_str}
 Group:         Base/Kernel
 Requires(post,postun): /sbin/depmod
 Requires:      dev >= 2.9.0-7
@@ -167,7 +172,7 @@ Requires:   dev >= 2.9.0-7
 %requires_releq_kernel
 Requires(postun):      %releq_kernel
 %endif
-Provides:      kernel(vboxvfs) = %{version}-%{_rel}
+Provides:      kernel(vboxvfs) = %{version}-%{rel}
 
 %description -n kernel%{_alt_kernel}-misc-vboxvfs
 Linux kernel module vboxvfs for VirtualBox.
@@ -177,8 +182,8 @@ Moduł jądra Linuksa vboxvfs dla VirtualBoksa.
 
 %package -n xorg-driver-input-vboxmouse
 Summary:       X.org mouse driver for VirtualBox guest OS
-Summary(pl.UTF-8):     Sterownik myszy dla systemu gościa w VirtualBox'ie
-Release:       %{_rel}
+Summary(pl.UTF-8):     Sterownik myszy dla systemu gościa w VirtualBoksie
+Release:       %{rel}
 Group:         X11/Applications
 Requires:      xorg-xserver-server >= 1.0.99.901
 
@@ -186,12 +191,12 @@ Requires: xorg-xserver-server >= 1.0.99.901
 X.org mouse driver for VirtualBox guest OS.
 
 %description -n xorg-driver-input-vboxmouse  -l pl.UTF-8
-Sterownik myszy dla systemu gościa w VirtualBox'ie.
+Sterownik myszy dla systemu gościa w VirtualBoksie.
 
 %package -n xorg-driver-video-vboxvideo
 Summary:       X.org video driver for VirtualBox guest OS
-Summary(pl.UTF-8):     Sterownik grafiki dla systemu gościa w VirtualBox'ie
-Release:       %{_rel}
+Summary(pl.UTF-8):     Sterownik grafiki dla systemu gościa w VirtualBoksie
+Release:       %{rel}
 Group:         X11/Applications
 Requires:      xorg-xserver-server >= 1.0.99.901
 
@@ -199,7 +204,7 @@ Requires:   xorg-xserver-server >= 1.0.99.901
 X.org video driver for VirtualBox guest OS.
 
 %description -n xorg-driver-video-vboxvideo -l pl.UTF-8
-Sterownik grafiki dla systemu gościa w VirtualBox'ie.
+Sterownik grafiki dla systemu gościa w VirtualBoksie.
 
 %prep
 %setup -q -n %{name}-%{version}_OSE
@@ -207,9 +212,13 @@ Sterownik grafiki dla systemu gościa w VirtualBox'ie.
 %patch1 -p0
 %patch2 -p1
 
-#%ifarch %{x8664}
-#%patch3 -p1
-#%endif
+%ifarch %{x8664}
+%patch3 -p1
+%endif
+
+cat <<'EOF' > udev.conf
+KERNEL=="vboxdrv", NAME="%k", GROUP="vbox", MODE="0660"
+EOF
 
 install %{SOURCE1} .
 
@@ -217,10 +226,17 @@ install %{SOURCE1} .
 KDIR="%{_builddir}/%{buildsubdir}/kernel"
 mkdir -p $KDIR
 cp -Ra %{_kernelsrcdir}/include $KDIR
+%ifarch %{x8664} %{ix86}
+if [ -d $KDIR/include/asm-x86 ]; then
+ln -sf $KDIR/include/asm-x86 $KDIR/include/asm
 %ifarch %{x8664}
-ln -sf $KDIR/include/asm-x86_64 $KDIR/include/asm
+else
+       ln -sf $KDIR/include/asm-x86_64 $KDIR/include/asm
 %else
-ln -sf $KDIR/include/asm-i386 $KDIR/include/asm
+else
+       ln -sf $KDIR/include/asm-i386 $KDIR/include/asm
+%endif
+fi
 %endif
 
 %if %{with dist_kernel}
@@ -245,9 +261,15 @@ rm -rf PLD-MODULE-BUILD && mkdir PLD-MODULE-BUILD && cd PLD-MODULE-BUILD
        tar -zxf modules.tar.gz && rm -f modules.tar.gz
 ../src/VBox/Additions/linux/export_modules modules.tar.gz
        tar -zxf modules.tar.gz && rm -f modules.tar.gz
-       
+
+%ifarch %{x8664}
+# HACK, is this really safe on x86_64?
+sed -i -e 's:#.*define.*RTMEMALLOC_EXEC_HEAP::g' vboxadd/r0drv/linux/alloc-r0drv-linux.c vboxvfs/r0drv/linux/alloc-r0drv-linux.c
+%endif
+
 %build_kernel_modules -m vboxadd -C vboxadd
 %build_kernel_modules -m vboxdrv -C vboxdrv
+cp -a vboxadd/Module.symvers vboxvfs
 %build_kernel_modules -m vboxvfs -C vboxvfs
 cd ..
 %endif
@@ -259,41 +281,47 @@ rm -rf $RPM_BUILD_ROOT
 install -d \
        $RPM_BUILD_ROOT{%{_bindir},%{_pixmapsdir},%{_desktopdir}} \
        $RPM_BUILD_ROOT%{_libdir}/VirtualBox \
+       $RPM_BUILD_ROOT/etc/rc.d/init.d \
        $RPM_BUILD_ROOT%{_libdir}/xorg/modules/drivers \
        $RPM_BUILD_ROOT%{_libdir}/xorg/modules/input
 
-install %{SOURCE4} $RPM_BUILD_ROOT%{_libdir}/VirtualBox/VirtualBox-wrapper.sh
+install %{SOURCE3} $RPM_BUILD_ROOT/etc/rc.d/init.d/virtualbox
+
+install %{SOURCE5} $RPM_BUILD_ROOT%{_libdir}/VirtualBox/VirtualBox-wrapper.sh
 for f in {VBox{BFE,Manage,SDL,SVC,XPCOMIPCD},VirtualBox,vditool}; do
-       install out/linux.%{_outdir}/release/bin/$f $RPM_BUILD_ROOT%{_libdir}/VirtualBox/$f
+       install out/linux.%{outdir}/release/bin/$f $RPM_BUILD_ROOT%{_libdir}/VirtualBox/$f
        ln -s %{_libdir}/VirtualBox/VirtualBox-wrapper.sh $RPM_BUILD_ROOT%{_bindir}/$f
 done
 
-install out/linux.%{_outdir}/release/bin/VBox*.so \
+install out/linux.%{outdir}/release/bin/VBox*.{so,rel} \
        $RPM_BUILD_ROOT%{_libdir}/VirtualBox
-install out/linux.%{_outdir}/release/bin/{VBox{DD,DD2}{GC.gc,R0.r0},VMM{GC.gc,R0.r0},*.xpt} \
+install out/linux.%{outdir}/release/bin/{VBox{DD,DD2}{GC.gc,R0.r0},VMM{GC.gc,R0.r0},*.xpt} \
        $RPM_BUILD_ROOT%{_libdir}/VirtualBox
 
 install -d $RPM_BUILD_ROOT%{_libdir}/VirtualBox/additions
 install -d $RPM_BUILD_ROOT%{_libdir}/VirtualBox/nls
 
 install %{SOURCE2} $RPM_BUILD_ROOT%{_libdir}/VirtualBox/additions/VBoxGuestAdditions.iso
-cp -a out/linux.%{_outdir}/release/bin/components $RPM_BUILD_ROOT%{_libdir}/VirtualBox
-cp -a out/linux.%{_outdir}/release/bin/nls/VirtualBox* $RPM_BUILD_ROOT%{_libdir}/VirtualBox/nls
+cp -a out/linux.%{outdir}/release/bin/components $RPM_BUILD_ROOT%{_libdir}/VirtualBox
+cp -a out/linux.%{outdir}/release/bin/nls/* $RPM_BUILD_ROOT%{_libdir}/VirtualBox/nls
 
-install out/linux.%{_outdir}/release/bin/additions/mountvboxsf         \
+install out/linux.%{outdir}/release/bin/additions/mountvboxsf          \
        $RPM_BUILD_ROOT%{_bindir}
 
-install out/linux.%{_outdir}/release/bin/additions/vboxmouse_drv_71.so \
+install out/linux.%{outdir}/release/bin/additions/vboxmouse_drv_14.so  \
        $RPM_BUILD_ROOT%{_libdir}/xorg/modules/input/vboxmouse_drv.so
 
-install out/linux.%{_outdir}/release/bin/additions/vboxvideo_drv_71.so \
+install out/linux.%{outdir}/release/bin/additions/vboxvideo_drv_14.so  \
        $RPM_BUILD_ROOT%{_libdir}/xorg/modules/drivers/vboxvideo_drv.so
 
-install out/linux.%{_outdir}/release/bin/VBox.png $RPM_BUILD_ROOT%{_pixmapsdir}/VBox.png
-install %{SOURCE3} $RPM_BUILD_ROOT%{_desktopdir}/%{name}.desktop
+install out/linux.%{outdir}/release/bin/VBox.png $RPM_BUILD_ROOT%{_pixmapsdir}/VBox.png
+install %{SOURCE4} $RPM_BUILD_ROOT%{_desktopdir}/%{name}.desktop
 %endif
 
 %if %{with kernel}
+install -d $RPM_BUILD_ROOT/etc/udev/rules.d
+install udev.conf $RPM_BUILD_ROOT/etc/udev/rules.d/virtualbox.rules
+
 cd PLD-MODULE-BUILD
 for MODULE in *; do
        [ ! -d $MODULE ] && continue;
@@ -342,6 +370,7 @@ fi
 %dir %{_libdir}/VirtualBox/additions
 %dir %{_libdir}/VirtualBox/components
 %dir %{_libdir}/VirtualBox/nls
+%attr(754,root,root) /etc/rc.d/init.d/virtualbox
 %attr(755,root,root) %{_bindir}/mountvboxsf
 %attr(755,root,root) %{_bindir}/vditool
 %attr(755,root,root) %{_bindir}/VBox*
@@ -360,23 +389,26 @@ fi
 %{_libdir}/VirtualBox/*.xpt
 %{_libdir}/VirtualBox/additions/*
 %{_libdir}/VirtualBox/components/*
-%lang(ar) %{_libdir}/VirtualBox/nls/VirtualBox_ar.qm
-%lang(cs) %{_libdir}/VirtualBox/nls/VirtualBox_cs.qm
-%lang(de) %{_libdir}/VirtualBox/nls/VirtualBox_de.qm
-%lang(es) %{_libdir}/VirtualBox/nls/VirtualBox_es.qm
-%lang(fi) %{_libdir}/VirtualBox/nls/VirtualBox_fi.qm
-%lang(fr) %{_libdir}/VirtualBox/nls/VirtualBox_fr.qm
-%lang(hu) %{_libdir}/VirtualBox/nls/VirtualBox_hu.qm
-%lang(it) %{_libdir}/VirtualBox/nls/VirtualBox_it.qm
-%lang(ja) %{_libdir}/VirtualBox/nls/VirtualBox_ja.qm
-%lang(ko) %{_libdir}/VirtualBox/nls/VirtualBox_ko.qm
-%lang(pl) %{_libdir}/VirtualBox/nls/VirtualBox_pl.qm
-%lang(pt_BR) %{_libdir}/VirtualBox/nls/VirtualBox_pt_BR.qm
-%lang(ro) %{_libdir}/VirtualBox/nls/VirtualBox_ro.qm
-%lang(ru) %{_libdir}/VirtualBox/nls/VirtualBox_ru.qm
-%lang(sv) %{_libdir}/VirtualBox/nls/VirtualBox_sv.qm
-%lang(zh_CN) %{_libdir}/VirtualBox/nls/VirtualBox_zh_CN.qm
-%lang(zh_TW) %{_libdir}/VirtualBox/nls/VirtualBox_zh_TW.qm
+%lang(ar) %{_libdir}/VirtualBox/nls/*_ar.qm
+%lang(cs) %{_libdir}/VirtualBox/nls/*_cs.qm
+%lang(de) %{_libdir}/VirtualBox/nls/*_de.qm
+%lang(es) %{_libdir}/VirtualBox/nls/*_es.qm
+%lang(eu) %{_libdir}/VirtualBox/nls/*_eu.qm
+%lang(fi) %{_libdir}/VirtualBox/nls/*_fi.qm
+%lang(fr) %{_libdir}/VirtualBox/nls/*_fr.qm
+%lang(hu) %{_libdir}/VirtualBox/nls/*_hu.qm
+%lang(it) %{_libdir}/VirtualBox/nls/*_it.qm
+%lang(ja) %{_libdir}/VirtualBox/nls/*_ja.qm
+%lang(ko) %{_libdir}/VirtualBox/nls/*_ko.qm
+%lang(pl) %{_libdir}/VirtualBox/nls/*_pl.qm
+%lang(pt_BR) %{_libdir}/VirtualBox/nls/*_pt_BR.qm
+%lang(pt_PT) %{_libdir}/VirtualBox/nls/*_pt_PT.qm
+%lang(ro) %{_libdir}/VirtualBox/nls/*_ro.qm
+%lang(ru) %{_libdir}/VirtualBox/nls/*_ru.qm
+%lang(sk) %{_libdir}/VirtualBox/nls/*_sk.qm
+%lang(sv) %{_libdir}/VirtualBox/nls/*_sv.qm
+%lang(zh_CN) %{_libdir}/VirtualBox/nls/*_zh_CN.qm
+%lang(zh_TW) %{_libdir}/VirtualBox/nls/*_zh_TW.qm
 %{_pixmapsdir}/VBox.png
 %{_desktopdir}/%{name}.desktop
 
@@ -399,6 +431,7 @@ fi
 
 %files -n kernel%{_alt_kernel}-misc-vboxdrv
 %defattr(644,root,root,755)
+%config(noreplace) %verify(not md5 mtime size) /etc/udev/rules.d/virtualbox.rules
 /lib/modules/%{_kernel_ver}/misc/vboxdrv.ko*
 
 %files -n kernel%{_alt_kernel}-misc-vboxvfs
This page took 0.092724 seconds and 4 git commands to generate.