]> git.pld-linux.org Git - packages/VirtualBox.git/blobdiff - VirtualBox.spec
- outdated
[packages/VirtualBox.git] / VirtualBox.spec
index 6260e77ebbbce6712bd3d504e7cb4ca6eb538ef9..4fc22bfe95b4362421dc4a6c3640611cb76839a3 100644 (file)
@@ -10,8 +10,9 @@
 %bcond_without dist_kernel     # without distribution kernel
 %bcond_without kernel          # don't build kernel module
 %bcond_without userspace       # don't build userspace package
+%bcond_with    verbose
 
-%define                rel             9
+%define                rel             1
 
 %if %{without kernel}
 %undefine      with_dist_kernel
 %undefine      with_userspace
 %endif
 
+%if "%{pld_release}" != "ti"
+%define                __ucc   gcc-3.4
+%else
+%define                __ucc   %{__cc}
+%endif
+
 %define                pname   VirtualBox
 
-Summary:       VirtualBox - x86 hardware virtualizer
-Summary(pl.UTF-8):     VirtualBox - wirtualizator sprzętu x86
+Summary:       VirtualBox OSE - x86 hardware virtualizer
+Summary(pl.UTF-8):     VirtualBox OSE - wirtualizator sprzętu x86
 Name:          %{pname}%{_alt_kernel}
-Version:       1.5.6
+Version:       1.6.6
 Release:       %{rel}
 License:       GPL v2
 Group:         Applications/Emulators
-Source0:       http://www.virtualbox.org/download/%{version}/%{pname}-%{version}-1_OSE.tar.bz2
-# Source0-md5: 305c65f9e91b6137cb773d578de09922
-Source1:       http://www.virtualbox.org/download/%{version}/UserManual.pdf
-# Source1-md5: 9ba7f17584fb3e9c98e026a1501cf7c0
+Source0:       http://download.virtualbox.org/virtualbox/%{version}/%{pname}-%{version}-OSE.tar.bz2
+# Source0-md5: 19f8cb080ec2cb11aab8b381d9b89323
+Source1:       http://download.virtualbox.org/virtualbox/%{version}/UserManual.pdf
+# Source1-md5: 5b261cc5a752c4c28c40a93417c0434b
 Source2:       http://www.virtualbox.org/download/%{version}/VBoxGuestAdditions_%{version}.iso
-# Source2-md5: 9d74dea92bd225ad59faee9fd427a55e
-Source3:       %{pname}.init
-Source4:       %{pname}.desktop
-Source5:       %{pname}.sh
+# Source2-md5: 2fff3ec12f5c3dd86bf41ee7c71e3bab
+Source3:       %{pname}-vboxdrv.init
+Source4:       %{pname}-vboxadd.init
+Source5:       %{pname}.desktop
+Source6:       %{pname}.sh
 Patch0:                %{pname}-configure.patch
 Patch1:                %{pname}-qt-paths.patch
 Patch2:                %{pname}-shared-libstdc++.patch
 Patch3:                %{pname}-disable-xclient-build.patch
 Patch4:                %{pname}-configure-spaces.patch
+Patch5:                %{pname}-gcc.patch
 URL:           http://www.virtualbox.org/
 %if %{with userspace}
-BuildRequires: SDL-devel
-BuildRequires: alsa-lib-devel
+BuildRequires: SDL-devel >= 1.2.7
+BuildRequires: alsa-lib-devel >= 1.0.6
 BuildRequires: bash
 BuildRequires: bcc
 BuildRequires: bin86
 BuildRequires: gcc >= 5:3.2.3
+%if "%{pld_release}" != "ti"
+BuildRequires: compat-gcc-34
+%endif
 BuildRequires: iasl
 %endif
-%{?with_dist_kernel:BuildRequires:     kernel%{_alt_kernel}-module-build >= 3:2.6.20}
+%if %{with dist_kernel}
+BuildRequires: kernel%{_alt_kernel}-module-build >= 3:2.6.20
+%endif
 %if %{with userspace}
 BuildRequires: libIDL-devel
+BuildRequires: libpng >= 1.2.5
+BuildRequires: libstdc++-devel >= 5:3.2.3
 BuildRequires: libuuid-devel
-BuildRequires: libxslt-progs
+BuildRequires: libxml2-devel >= 2.6.26
+BuildRequires: libxslt-devel >= 1.1.17
+BuildRequires: libxslt-progs >= 1.1.17
 BuildRequires: pkgconfig
-BuildRequires: pulseaudio-devel
+BuildRequires: pulseaudio-devel >= 0.9.0
 BuildRequires: qt-devel >= 6:3.3.6
 BuildRequires: qt-linguist
 %endif
@@ -73,8 +91,8 @@ BuildRequires:        xorg-lib-libXcursor-devel
 BuildRequires: zlib-devel >= 1.2.1
 %ifarch %{x8664}
 BuildRequires: gcc-multilib
+BuildRequires: glibc-devel(i686)
 BuildRequires: libstdc++-multilib-devel
-# TODO: How to add glibc-devel.i686 here ?
 %endif
 %endif
 Requires(post,preun):  /sbin/chkconfig
@@ -93,21 +111,21 @@ BuildRoot: %{tmpdir}/%{name}-%{version}-root-%(id -u -n)
 %endif
 
 %description
-InnoTek VirtualBox is a general-purpose full virtualizer for x86
+InnoTek VirtualBox OSE is a general-purpose full virtualizer for x86
 hardware. Targeted at server, desktop and embedded use, it is now the
 only professional-quality virtualization solution that is also Open
 Source Software.
 
-Some of the features of VirtualBox are:
+Some of the features of VirtualBox OSE are:
 
-Modularity: VirtualBox has an extremely modular design with
+Modularity: VirtualBox OSE has an extremely modular design with
 well-defined internal programming interfaces and a client/server
 design. This makes it easy to control it from several interfaces at
 once: for example, you can start a virtual machine in a typical
 virtual machine GUI and then control that machine from the command
-line. VirtualBox also comes with a full Software Development Kit: even
-though it is Open Source Software, you don't have to hack the source
-to write a new interface for VirtualBox.
+line. VirtualBox OSE also comes with a full Software Development Kit:
+even though it is Open Source Software, you don't have to hack the
+source to write a new interface for VirtualBox OSE.
 
 Virtual machine descriptions in XML: the configuration settings of
 virtual machines are stored entirely in XML and are independent of the
@@ -115,20 +133,21 @@ local machines. Virtual machine definitions can therefore easily be
 ported to other computers.
 
 %description -l pl.UTF-8
-InnoTek VirtualBox jest emulatorem sprzętu x86. Kierowany do
+InnoTek VirtualBox OSE jest emulatorem sprzętu x86. Kierowany do
 zastosowań serwerowych, desktopowych oraz wbudowanych jest obecnie
 jedynym wysokiej jakości rozwiązaniem wirtualizacyjnym dostępnym
 również jako Otwarte Oprogramowanie.
 
 Przykładowe cechy VirtualBoksa:
 
-Modularność: VirtualBox jest wysoce zmodularyzowanym produktem z
+Modularność: VirtualBox OSE jest wysoce zmodularyzowanym produktem z
 dobrze zaprojektowanym wewnętrznym interfejsem programowym typu
 klient/serwer. Dzięki temu można łatwo kontrolować go za pomocą
 różnych interfejsów. Można na przykład uruchomić maszynę wirtualną z
 poziomu interfejsu graficznego, a później kontrolować ją z linii
-poleceń. VirtualBox dostarcza również pełny pakiet deweloperski, co
-pozwala stworzyć dowolny inny interfejs zarządzania maszyną wirtualną.
+poleceń. VirtualBox OSE dostarcza również pełny pakiet deweloperski,
+co pozwala stworzyć dowolny inny interfejs zarządzania maszyną
+wirtualną.
 
 Opisy maszyn wirtualnych w XML-u: konfiguracje poszczególnych maszyn
 wirtualnych są w całości przechowywane w XML-u i są niezależne od
@@ -136,20 +155,20 @@ lokalnej maszyny. Dzięki temu można szybko i łatwo przenieść
 konfigurację maszyny wirtualnej na inny komputer.
 
 %package udev
-Summary:       udev rules for VirtualBox kernel modules
+Summary:       udev rules for VirtualBox OSE kernel modules
 Summary(pl.UTF-8):     Reguły udev dla modułów jądra Linuksa dla VirtualBoksa
-Release:       %{rel}@%{_kernel_ver_str}
+Release:       %{rel}
 Group:         Base/Kernel
-Requires:      udev
+Requires:      udev-core
 
 %description udev
-udev rules for VirtualBox kernel modules
+udev rules for VirtualBox OSE kernel modules.
 
 %description udev -l pl.UTF-8
-Reguły udev dla modułów jądra Linuksa dla VirtualBoksa
+Reguły udev dla modułów jądra Linuksa dla VirtualBoksa.
 
 %package -n kernel%{_alt_kernel}-misc-vboxadd
-Summary:       Linux kernel module for VirtualBox
+Summary:       Linux kernel module for VirtualBox OSE
 Summary(pl.UTF-8):     Moduł jądra Linuksa dla VirtualBoksa
 Release:       %{rel}@%{_kernel_ver_str}
 Group:         Base/Kernel
@@ -162,13 +181,13 @@ Requires: dev >= 2.9.0-7
 Provides:      kernel(vboxadd) = %{version}-%{rel}
 
 %description -n kernel%{_alt_kernel}-misc-vboxadd
-Linux kernel module vboxadd for VirtualBox.
+Linux kernel module vboxadd for VirtualBox OSE.
 
 %description -n kernel%{_alt_kernel}-misc-vboxadd -l pl.UTF-8
 Moduł jądra Linuksa vboxadd dla VirtualBoksa.
 
 %package -n kernel%{_alt_kernel}-misc-vboxdrv
-Summary:       Linux kernel module for VirtualBox
+Summary:       Linux kernel module for VirtualBox OSE
 Summary(pl.UTF-8):     Moduł jądra Linuksa dla VirtualBoksa
 Release:       %{rel}@%{_kernel_ver_str}
 Group:         Base/Kernel
@@ -181,13 +200,13 @@ Requires(postun): %releq_kernel
 Provides:      kernel(vboxdrv) = %{version}-%{rel}
 
 %description -n kernel%{_alt_kernel}-misc-vboxdrv
-Linux kernel module vboxdrv for VirtualBox.
+Linux kernel module vboxdrv for VirtualBox OSE.
 
 %description -n kernel%{_alt_kernel}-misc-vboxdrv -l pl.UTF-8
 Moduł jądra Linuksa vboxdrv dla VirtualBoksa.
 
 %package -n kernel%{_alt_kernel}-misc-vboxvfs
-Summary:       Linux kernel module for VirtualBox
+Summary:       Linux kernel module for VirtualBox OSE
 Summary(pl.UTF-8):     Moduł jądra Linuksa dla VirtualBoksa
 Release:       %{rel}@%{_kernel_ver_str}
 Group:         Base/Kernel
@@ -200,39 +219,39 @@ Requires(postun): %releq_kernel
 Provides:      kernel(vboxvfs) = %{version}-%{rel}
 
 %description -n kernel%{_alt_kernel}-misc-vboxvfs
-Linux kernel module vboxvfs for VirtualBox.
+Linux kernel module vboxvfs for VirtualBox OSE.
 
 %description -n kernel%{_alt_kernel}-misc-vboxvfs -l pl.UTF-8
 Moduł jądra Linuksa vboxvfs dla VirtualBoksa.
 
 %package -n xorg-driver-input-vboxmouse
-Summary:       X.org mouse driver for VirtualBox guest OS
+Summary:       X.org mouse driver for VirtualBox OSE guest OS
 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
 
 %description -n xorg-driver-input-vboxmouse
-X.org mouse driver for VirtualBox guest OS.
+X.org mouse driver for VirtualBox OSE guest OS.
 
 %description -n xorg-driver-input-vboxmouse  -l pl.UTF-8
 Sterownik myszy dla systemu gościa w VirtualBoksie.
 
 %package -n xorg-driver-video-vboxvideo
-Summary:       X.org video driver for VirtualBox guest OS
+Summary:       X.org video driver for VirtualBox OSE guest OS
 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
 
 %description -n xorg-driver-video-vboxvideo
-X.org video driver for VirtualBox guest OS.
+X.org video driver for VirtualBox OSE guest OS.
 
 %description -n xorg-driver-video-vboxvideo -l pl.UTF-8
 Sterownik grafiki dla systemu gościa w VirtualBoksie.
 
 %prep
-%setup -q -n %{pname}-%{version}_OSE
+%setup -q -n %{pname}-%{version}
 %patch0 -p0
 %patch1 -p0
 %patch2 -p1
@@ -242,9 +261,11 @@ Sterownik grafiki dla systemu gościa w VirtualBoksie.
 %endif
 
 %patch4 -p1
+%patch5 -p0
 
 cat <<'EOF' > udev.conf
 KERNEL=="vboxdrv", NAME="%k", GROUP="vbox", MODE="0660"
+KERNEL=="vboxadd", NAME="%k", GROUP="vbox", MODE="0660"
 EOF
 
 install %{SOURCE1} .
@@ -255,23 +276,25 @@ rm -rf PLD-MODULE-BUILD && mkdir PLD-MODULE-BUILD && cd PLD-MODULE-BUILD
 ../src/VBox/HostDrivers/Support/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 '/#.*define.*RTMEMALLOC_EXEC_HEAP/d' vboxadd/r0drv/linux/alloc-r0drv-linux.c vboxvfs/r0drv/linux/alloc-r0drv-linux.c
+%endif
+
 %build
 %if %{with userspace}
 ./configure \
        --with-gcc="%{__cc}" \
        --with-g++="%{__cxx}" \
+       --disable-qt4 \
        --disable-kmods
 
-. ./env.sh && kmk -j1
+. ./env.sh && \
+kmk -j1 VBOX_RECOMPILER_OP_GCC_PLD_COMPAT="%{__ucc}"
 %endif
 
 %if %{with kernel}
 cd PLD-MODULE-BUILD
-%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
@@ -285,14 +308,9 @@ rm -rf $RPM_BUILD_ROOT
 %if %{with userspace}
 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 %{SOURCE3} $RPM_BUILD_ROOT/etc/rc.d/init.d/virtualbox
+       $RPM_BUILD_ROOT%{_libdir}/VirtualBox
 
-install %{SOURCE5} $RPM_BUILD_ROOT%{_libdir}/VirtualBox/VirtualBox-wrapper.sh
+install %{SOURCE6} $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
        ln -s %{_libdir}/VirtualBox/VirtualBox-wrapper.sh $RPM_BUILD_ROOT%{_bindir}/$f
@@ -318,20 +336,25 @@ cp -a out/linux.%{outdir}/release/bin/nls/* $RPM_BUILD_ROOT%{_libdir}/VirtualBox
 install out/linux.%{outdir}/release/bin/additions/mountvboxsf          \
        $RPM_BUILD_ROOT%{_bindir}
 
+%ifnarch %{x8664}
+install -d $RPM_BUILD_ROOT%{_libdir}/xorg/modules/{drivers,input}
 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_14.so  \
        $RPM_BUILD_ROOT%{_libdir}/xorg/modules/drivers/vboxvideo_drv.so
+%endif
 
 install out/linux.%{outdir}/release/bin/VBox.png $RPM_BUILD_ROOT%{_pixmapsdir}/VBox.png
-install %{SOURCE4} $RPM_BUILD_ROOT%{_desktopdir}/%{pname}.desktop
+install %{SOURCE5} $RPM_BUILD_ROOT%{_desktopdir}/%{pname}.desktop
 
 install -d $RPM_BUILD_ROOT/etc/udev/rules.d
 install udev.conf $RPM_BUILD_ROOT/etc/udev/rules.d/virtualbox.rules
 %endif
 
 %if %{with kernel}
+install -d $RPM_BUILD_ROOT/etc/rc.d/init.d
+install %{SOURCE3} $RPM_BUILD_ROOT/etc/rc.d/init.d/vboxdrv
+install %{SOURCE4} $RPM_BUILD_ROOT/etc/rc.d/init.d/vboxadd
 %install_kernel_modules -m PLD-MODULE-BUILD/vboxadd/vboxadd -d misc
 %install_kernel_modules -m PLD-MODULE-BUILD/vboxdrv/vboxdrv -d misc
 %install_kernel_modules -m PLD-MODULE-BUILD/vboxvfs/vboxvfs -d misc
@@ -344,14 +367,17 @@ rm -rf $RPM_BUILD_ROOT
 %groupadd -g 221 -r -f vbox
 
 %post
-/sbin/chkconfig --add virtualbox
-%service virtualbox restart "VirtualBox"
+cat << 'EOF'
+NOTE: You must also install kernel module for this software to work
+  kernel-misc-vboxdrv-%{version}-%{rel}@%{_kernel_ver_str}
+  kernel-desktop-misc-vboxdrv-%{version}-%{rel}@%{_kernel_ver_str}
+  kernel-laptop-misc-vboxdrv-%{version}-%{rel}@%{_kernel_ver_str}
+  kernel-vanilla-misc-vboxdrv-%{version}-%{rel}@%{_kernel_ver_str}
+  etc.
 
-%preun
-if [ "$1" = "0" ]; then
-       %service virtualbox stop
-       /sbin/chkconfig --del virtualbox
-fi
+Depending on which kernel brand You use.
+
+EOF
 
 %postun
 if [ "$1" = "0" ]; then
@@ -360,16 +386,32 @@ fi
 
 %post  -n kernel%{_alt_kernel}-misc-vboxadd
 %depmod %{_kernel_ver}
+/sbin/chkconfig --add vboxadd
+%service vboxadd restart "VirtualBox OSE guest additions driver"
 
 %postun        -n kernel%{_alt_kernel}-misc-vboxadd
 %depmod %{_kernel_ver}
 
+%preun -n kernel%{_alt_kernel}-misc-vboxadd
+if [ "$1" = "0" ]; then
+       %service vboxadd stop
+       /sbin/chkconfig --del vboxadd
+fi
+
 %post  -n kernel%{_alt_kernel}-misc-vboxdrv
 %depmod %{_kernel_ver}
+/sbin/chkconfig --add vboxdrv
+%service vboxdrv restart "VirtualBox OSE driver"
 
 %postun        -n kernel%{_alt_kernel}-misc-vboxdrv
 %depmod %{_kernel_ver}
 
+%preun -n kernel%{_alt_kernel}-misc-vboxdrv
+if [ "$1" = "0" ]; then
+       %service vboxdrv stop
+       /sbin/chkconfig --del vboxdrv
+fi
+
 %post  -n kernel%{_alt_kernel}-misc-vboxvfs
 %depmod %{_kernel_ver}
 
@@ -384,7 +426,6 @@ 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*
@@ -421,8 +462,8 @@ fi
 %lang(ko) %{_libdir}/VirtualBox/nls/*_ko.qm
 %lang(nl) %{_libdir}/VirtualBox/nls/*_nl.qm
 %lang(pl) %{_libdir}/VirtualBox/nls/*_pl.qm
+%lang(pt) %{_libdir}/VirtualBox/nls/*_pt.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
@@ -453,10 +494,12 @@ fi
 %if %{with kernel}
 %files -n kernel%{_alt_kernel}-misc-vboxadd
 %defattr(644,root,root,755)
+%attr(754,root,root) /etc/rc.d/init.d/vboxadd
 /lib/modules/%{_kernel_ver}/misc/vboxadd.ko*
 
 %files -n kernel%{_alt_kernel}-misc-vboxdrv
 %defattr(644,root,root,755)
+%attr(754,root,root) /etc/rc.d/init.d/vboxdrv
 /lib/modules/%{_kernel_ver}/misc/vboxdrv.ko*
 
 %files -n kernel%{_alt_kernel}-misc-vboxvfs
This page took 0.133107 seconds and 4 git commands to generate.