X-Git-Url: http://git.pld-linux.org/?p=packages%2FVirtualBox.git;a=blobdiff_plain;f=VirtualBox.spec;h=39bbd28c75b8d3ac3bc2c6acf4e1caec7637452b;hp=0d0bf6c98f361d2a79d698b7100df5d999ac061f;hb=4e3859c523bfc67b4adb5607465dd5836d276be3;hpb=e08dff858d9d46ec10c1a21126a2fbcf398567d9 diff --git a/VirtualBox.spec b/VirtualBox.spec index 0d0bf6c..39bbd28 100644 --- a/VirtualBox.spec +++ b/VirtualBox.spec @@ -1,3 +1,5 @@ +# NOTE +# - https://www.virtualbox.org/wiki/Linux%20build%20instructions # TODO # - java bindings # - Package SDK. @@ -6,7 +8,7 @@ # - guest x11 additions: currently incomplete/untested # - enable VDE networking: --enable-vde # - initscripts for webservice -# - install systemd vboxservice.service +# - fix desc for dkms packages (proper wording needed), kernel modules desc is mess as well # # Conditional build: %bcond_without doc # don't build the documentation @@ -15,64 +17,76 @@ %bcond_without userspace # don't build userspace package %bcond_with webservice # webservice (SOAP) support %bcond_without lightdm # lightdm greeter +%bcond_without dkms # build dkms package %bcond_without verbose -%bcond_with force_userspace # force userspace build (useful if alt_kernel is set) %if %{without kernel} %undefine with_dist_kernel +%else +%define _duplicate_files_terminate_build 0 +%endif + +# The goal here is to have main, userspace, package built once with +# simple release number, and only rebuild kernel packages with kernel +# version as part of release number, without the need to bump release +# with every kernel change. +%if 0%{?_pld_builder:1} && %{with kernel} && %{with userspace} +%{error:kernel and userspace cannot be built at the same time on PLD builders} +exit 1 %endif + %if "%{_alt_kernel}" != "%{nil}" -%undefine with_userspace +%if 0%{?build_kernels:1} +%{error:alt_kernel and build_kernels are mutually exclusive} +exit 1 %endif -%if %{with force_userspace} -%define with_userspace 1 +%undefine with_userspace +%global _build_kernels %{alt_kernel} +%else +%global _build_kernels %{?build_kernels:,%{?build_kernels}} %endif + %if %{without userspace} # nothing to be placed to debuginfo package %define _enable_debug_packages 0 %endif -%define rel 6 +%define kbrs %(echo %{_build_kernels} | tr , '\\n' | while read n ; do echo %%undefine alt_kernel ; [ -z "$n" ] || echo %%define alt_kernel $n ; echo "BuildRequires:kernel%%{_alt_kernel}-module-build >= 3:2.6.20.2" ; done) +%define kpkg %(echo %{_build_kernels} | tr , '\\n' | while read n ; do echo %%undefine alt_kernel ; [ -z "$n" ] || echo %%define alt_kernel $n ; echo %%kernel_pkg ; done) +%define bkpkg %(echo %{_build_kernels} | tr , '\\n' | while read n ; do echo %%undefine alt_kernel ; [ -z "$n" ] || echo %%define alt_kernel $n ; echo %%build_kernel_pkg ; done) +%define ikpkg %(echo %{_build_kernels} | tr , '\\n' | while read n ; do echo %%undefine alt_kernel ; [ -z "$n" ] || echo %%define alt_kernel $n ; echo %%install_kernel_pkg ; done) + +%define rel 3 %define pname VirtualBox Summary: VirtualBox - x86 hardware virtualizer Summary(pl.UTF-8): VirtualBox - wirtualizator sprzętu x86 -Name: %{pname}%{_alt_kernel} -Version: 4.2.16 -Release: %{rel} +Name: %{pname}%{?_pld_builder:%{?with_kernel:-kernel}}%{_alt_kernel} +Version: 4.3.8 +Release: %{rel}%{?_pld_builder:%{?with_kernel:@%{_kernel_ver_str}}} License: GPL v2 Group: Applications/Emulators Source0: http://download.virtualbox.org/virtualbox/%{version}/%{pname}-%{version}.tar.bz2 -# Source0-md5: c4a36e2099a317f4715cd3861cdae238 +# Source0-md5: 422ab09b7eb9c0564b55a6a0a6e6678f Source1: http://download.virtualbox.org/virtualbox/%{version}/VBoxGuestAdditions_%{version}.iso -# Source1-md5: 6074747feb9ae8b6eec365616347eef3 +# Source1-md5: f23d3980a509418b2dcb614483271ffa Source2: vboxservice.init -Source3: %{pname}-vboxdrv.init -Source4: %{pname}-vboxguest.init -Source5: %{pname}-vboxnetflt.init -Source6: %{pname}-vboxsf.init -Source7: %{pname}-vboxnetadp.init -Source8: %{pname}-vboxpci.init -Source9: %{pname}.sh -Source10: mount.vdi -Source11: udev.rules -Source12: %{pname}-vboxdrv-modules-load.conf -Source13: %{pname}-vboxguest-modules-load.conf -Source14: %{pname}-vboxnetflt-modules-load.conf -Source15: %{pname}-vboxsf-modules-load.conf -Source16: %{pname}-vboxnetadp-modules-load.conf -Source17: %{pname}-vboxpci-modules-load.conf +Source3: vboxservice.service +Source5: mount.vdi +Source6: udev.rules +Source7: %{pname}-virtualbox-host-modules-load.conf +Source8: %{pname}-virtualbox-guest-modules-load.conf Patch0: %{pname}-configure-spaces.patch Patch1: %{pname}-VBoxSysInfo.patch Patch2: %{pname}-warning_workaround.patch Patch3: %{pname}-dri.patch -Patch4: %{pname}-disable_build_NetBiosBin.patch +Patch4: wrapper.patch Patch5: xserver-1.12.patch +Patch6: hardening-shared.patch Patch7: lightdm-greeter-glib-includes.patch Patch8: lightdm-greeter-g++-link.patch -# ubuntu patches +Patch9: pld-guest.patch Patch10: 16-no-update.patch Patch11: 18-system-xorg.patch -# /ubuntu patches URL: http://www.virtualbox.org/ %if %{with userspace} %ifarch %{x8664} @@ -104,10 +118,12 @@ BuildRequires: bin86 BuildRequires: curl-devel BuildRequires: device-mapper-devel %{?with_doc:BuildRequires: docbook-dtd44-xml} +BuildRequires: fakeroot +%{?with_lightdm:BuildRequires: fltk-devel} BuildRequires: gcc >= 5:3.2.3 %{?with_webservice:BuildRequires: gsoap-devel} BuildRequires: issue -BuildRequires: kBuild >= 0.1.9998-2 +BuildRequires: kBuild >= 0.1.9998.2700 BuildRequires: libIDL-devel BuildRequires: libcap-static BuildRequires: libdrm-devel @@ -116,6 +132,7 @@ BuildRequires: libstdc++-devel >= 5:3.2.3 BuildRequires: libstdc++-static >= 5:3.2.3 BuildRequires: libuuid-devel BuildRequires: libvncserver-devel >= 0.9.9 +BuildRequires: libvpx-devel BuildRequires: libxml2-devel >= 2.6.26 BuildRequires: libxslt-devel >= 1.1.17 BuildRequires: libxslt-progs >= 1.1.17 @@ -130,7 +147,7 @@ BuildRequires: python-devel BuildRequires: python-modules BuildRequires: qt4-build >= 4.2.0 BuildRequires: qt4-linguist -BuildRequires: rpmbuild(macros) >= 1.664 +BuildRequires: rpmbuild(macros) >= 1.678 BuildRequires: sed >= 4.0 %if %{with doc} BuildRequires: texlive-fonts-bitstream @@ -146,20 +163,13 @@ BuildRequires: xerces-c-devel >= 2.6.0 BuildRequires: yasm BuildRequires: zlib-devel >= 1.2.1 %endif -%if %{with dist_kernel} -BuildRequires: kernel%{_alt_kernel}-module-build >= 3:2.6.20 -%endif +%{?with_dist_kernel:%{expand:%kbrs}} Requires(post,preun): /sbin/chkconfig Requires(postun): /usr/sbin/groupdel Requires(pre): /usr/bin/getgid Requires(pre): /usr/sbin/groupadd -Requires: QtCore >= 4.7.0 -Requires: desktop-file-utils -Requires: fontconfig -Requires: fonts-Type1-urw Requires: libvncserver >= 0.9.9 Requires: udev-core -Suggests: gxmessage Provides: group(vbox) Obsoletes: VirtualBox-udev < 4.2.10-5 ExclusiveArch: %{ix86} %{x8664} @@ -174,25 +184,6 @@ BuildRoot: %{tmpdir}/%{name}-%{version}-root-%(id -u -n) %define outdir out/%{vbox_platform}/release/bin %define objdir out/%{vbox_platform}/release/obj -# workaround buggy 'file' results: -# -# EfiThunk: \0 -# qt_ro.qm: \0 "<\270d\030\312\357\234\225\315!\034\277`\241\275\335B" -# VBoxEFI32.fd: \0 -# VBoxEFI64.fd: \0 -# -# which lead to 'Stripping ... ELF shared libraries... (...)/nls/qt_ro.qm: File format not recognized' -%define _noautostrip .*%{_libdir}/%{name}/.* - -%define vbox_kernel_post(d:) \ -if [ -x /etc/rc.d/init.d/%{-d*} ]; then \ - %{expand:%service %%{-d*} restart %%*} \ -else \ - /sbin/rmmod %{-d*} || : \ - /sbin/modprobe -s %{-d*} || : \ -fi \ -%{nil} - %description Oracle VirtualBox is a general-purpose full virtualizer for x86 hardware. Targeted at server, desktop and embedded use, it is now the @@ -238,6 +229,24 @@ wirtualnych są w całości przechowywane w XML-u i są niezależne od lokalnej maszyny. Dzięki temu można szybko i łatwo przenieść konfigurację maszyny wirtualnej na inny komputer. +%package gui +Summary: Qt GUI part for VirtualBox +Group: X11/Applications +Requires: %{name} = %{version}-%{release} +Requires: QtCore >= 4.7.0 +Requires: desktop-file-utils +Requires: desktop-file-utils +Requires: fontconfig +Requires: fonts-Type1-urw +Requires: gtk-update-icon-cache +Requires: hicolor-icon-theme +Requires: shared-mime-info +Suggests: gxmessage +Conflicts: %{name} < 4.3.8-3 + +%description gui +Qt GUI part for VirtualBox. + %package doc Summary: VirtualBox documentation Group: Documentation @@ -248,7 +257,10 @@ This package contains VirtualBox User Manual. %package additions Summary: VirtualBox Guest Additions Group: Base -Requires: %{name} = %{version}-%{release} +Requires: %{name} = %{version} +%if "%{_rpmversion}" >= "5" +BuildArch: noarch +%endif %description additions VirtualBox Guest Additions. @@ -261,7 +273,9 @@ You should install this package in your Host OS. Summary: VirtualBox Guest tools Group: Base Requires(post,preun): /sbin/chkconfig +Requires(post): systemd-units >= 38 Requires: rc-scripts +Requires: systemd-units >= 38 Suggests: kernel(vboxguest) Suggests: kernel(vboxsf) Suggests: pam-pam_vbox @@ -274,9 +288,10 @@ You should install this package in your Guest OS for base VirtualBox communication %package guest-x11 -Summary: VirtualBox Guest Additions -Group: Base +Summary: VirtualBox Guest X11 Additions +Group: X11/Applications Requires: %{name}-guest = %{version}-%{release} +Requires: xorg-app-xrandr Requires: xorg-driver-video-vboxvideo = %{version}-%{release} Suggests: kernel(vboxvideo) Obsoletes: xorg-driver-input-vboxmouse < %{version}-%{release} @@ -303,7 +318,7 @@ Group: Themes # NOTE: '#' in url is lost because rpm treats it as comment, even hacking with # macros doesn't help as rpmbuild takes final result to parse URL: http://www.virtualbox.org/manual/ch09.html#autologon_unix_lightdm -Requires: kernel%{_alt_kernel}-misc-vboxguest +Requires: kernel(vboxguest) Requires: lightdm >= 1.0.1 Provides: lightdm-greeter @@ -325,8 +340,9 @@ Group: X11/Applications Requires: Mesa-dri-driver-swrast Requires: xorg-xserver-libdri >= 1.7.4 Requires: xorg-xserver-server >= 1.0.99.901 -Requires: xorg-xserver-server(videodrv-abi) <= 14.1 +Requires: xorg-xserver-server(videodrv-abi) <= 15.0 Requires: xorg-xserver-server(videodrv-abi) >= 2.0 +Provides: xorg-driver-video %description -n xorg-driver-video-vboxvideo X.org video driver for VirtualBox guest OS. @@ -334,203 +350,167 @@ 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 VirtualBoksie. -%package kernel-init-host -Summary: SysV initscripts for host kernel modules -Group: Base/Kernel - -%description kernel-init-host -SysV initscripts for host kernel modules. - -%package kernel-init-guest -Summary: SysV initscripts for guest kernel modules -Group: Base/Kernel - -%description kernel-init-guest -SysV initscripts for guest kernel modules. - -# KERNEL PACKAGES - -# KEEP ALL REGULAR SUBPACKAGES BEFORE KERNEL PACKAGES. - -%package -n kernel%{_alt_kernel}-misc-vboxguest -Summary: VirtualBox Guest Additions for Linux Module -Summary(pl.UTF-8): Moduł jądra Linuksa dla VirtualBoksa -Release: %{rel}@%{_kernel_ver_str} -Group: Base/Kernel -Requires(post,postun): /sbin/depmod -Requires(post): systemd-units >= 38 -Requires: dev >= 2.9.0-7 -%if %{with dist_kernel} -%requires_releq_kernel -Requires(postun): %releq_kernel -%endif -Requires: systemd-units >= 38 -Suggests: %{name}-kernel-init-guest >= %{version}-%{rel} -Provides: kernel(vboxguest) = %{version}-%{rel} -Obsoletes: kernel%{_alt_kernel}-misc-vboxadd -Conflicts: kernel%{_alt_kernel}-misc-vboxdrv - -%description -n kernel%{_alt_kernel}-misc-vboxguest -VirtualBox Guest Additions for Linux Module. - -You should install this package in your Guest OS. - -%description -n kernel%{_alt_kernel}-misc-vboxguest -l pl.UTF-8 -Moduł jądra Linuksa vboxguest dla VirtualBoksa - dodatki dla systemu -gościa. - -%package -n kernel%{_alt_kernel}-misc-vboxdrv -Summary: VirtualBox Support Driver -Summary(pl.UTF-8): Moduł jądra Linuksa dla VirtualBoksa -Release: %{rel}@%{_kernel_ver_str} -Group: Base/Kernel -Requires(post,postun): /sbin/depmod -Requires(post): systemd-units >= 38 -Requires: dev >= 2.9.0-7 -%if %{with dist_kernel} -%requires_releq_kernel -Requires(postun): %releq_kernel -%endif -Requires: systemd-units >= 38 -Suggests: %{name}-kernel-init-host >= %{version}-%{rel} -Provides: kernel(vboxdrv) = %{version}-%{rel} - -%description -n kernel%{_alt_kernel}-misc-vboxdrv -VirtualBox Support Driver. - -You should install this package in your Host OS. - -%description -n kernel%{_alt_kernel}-misc-vboxdrv -l pl.UTF-8 -Moduł jądra Linuksa dla VirtualBoksa - sterownik wsparcia dla systemu -głównego. - -%package -n kernel%{_alt_kernel}-misc-vboxnetadp -Summary: VirtualBox Network Adapter Driver -Summary(pl.UTF-8): Moduł jądra Linuksa dla VirtualBoksa -Release: %{rel}@%{_kernel_ver_str} -Group: Base/Kernel -Requires(post,postun): /sbin/depmod -Requires(post): systemd-units >= 38 -Requires: dev >= 2.9.0-7 -Requires: kernel%{_alt_kernel}-misc-vboxdrv -%if %{with dist_kernel} -%requires_releq_kernel -Requires(postun): %releq_kernel -%endif -Requires: systemd-units >= 38 -Suggests: %{name}-kernel-init-host >= %{version}-%{rel} -Provides: kernel(vboxnetflt) = %{version}-%{rel} - -%description -n kernel%{_alt_kernel}-misc-vboxnetadp -VirtualBox Network Adapter Driver. - -You should install this package in your Host OS. - -%description -n kernel%{_alt_kernel}-misc-vboxnetadp -l pl.UTF-8 -Moduł jądra Linuksa dla VirtualBoksa - sterownik witrualnej karty -sieciowej. - -%package -n kernel%{_alt_kernel}-misc-vboxnetflt -Summary: VirtualBox Network Filter Driver -Summary(pl.UTF-8): Moduł jądra Linuksa dla VirtualBoksa -Release: %{rel}@%{_kernel_ver_str} -Group: Base/Kernel -Requires(post,postun): /sbin/depmod -Requires(post): systemd-units >= 38 -Requires: dev >= 2.9.0-7 -Requires: kernel%{_alt_kernel}-misc-vboxdrv -%if %{with dist_kernel} -%requires_releq_kernel -Requires(postun): %releq_kernel -%endif -Requires: systemd-units >= 38 -Suggests: %{name}-kernel-init-host >= %{version}-%{rel} -Provides: kernel(vboxnetflt) = %{version}-%{rel} - -%description -n kernel%{_alt_kernel}-misc-vboxnetflt -VirtualBox Network Filter Driver. - -You should install this package in your Host OS. - -%description -n kernel%{_alt_kernel}-misc-vboxnetflt -l pl.UTF-8 -Moduł jądra Linuksa dla VirtualBoksa - sterownik filtrowania sieci dla -systemu głównego. - -%package -n kernel%{_alt_kernel}-misc-vboxpci -Summary: VirtualBox PCI card passthrough Driver -Summary(pl.UTF-8): Moduł jądra Linuksa dla VirtualBoksa -Release: %{rel}@%{_kernel_ver_str} +%package -n dkms-vboxguest +Summary: VirtualBox kernel modules source for Linux Guest +Summary(pl.UTF-8): Moduły VirtualBoksa do jądra Linuksa dla systemu gościa +License: GPL v2+ Group: Base/Kernel -Requires(post,postun): /sbin/depmod -Requires(post): systemd-units >= 38 -Requires: dev >= 2.9.0-7 -Requires: kernel%{_alt_kernel}-misc-vboxdrv -%if %{with dist_kernel} -%requires_releq_kernel -Requires(postun): %releq_kernel +Requires(pre): dkms +Requires(post): dkms +%if "%{_rpmversion}" >= "5" +BuildArch: noarch %endif -Requires: systemd-units >= 38 -Suggests: %{name}-kernel-init-host >= %{version}-%{rel} -Provides: kernel(vboxpci) = %{version}-%{rel} -%description -n kernel%{_alt_kernel}-misc-vboxpci -VirtualBox PCI card passthrough driver that works as host proxy -between guest and PCI hardware. +%description -n dkms-vboxguest +This package contains DKMS-ready VirtualBox Guest Additions for Linux +Module, host file system access (Shared Folders) and DRM support for +Linux guest system. -You should install this package in your Host OS. +%description -n dkms-vboxguest -l pl.UTF-8 +Ten pakiet zawiera moduł jądra Linuksa vboxguest dla VirtualBoksa - +dodatki dla systemu gościa, dostęp do plików systemu głównego z +poziomu systemu gościa i sterownik obsługi DRM. -%description -n kernel%{_alt_kernel}-misc-vboxnetflt -l pl.UTF-8 -Moduł jądra Linuksa dla VirtualBoksa - sterownik, ktory działa jako -proxy między gościem i gospodarzem sprzętu PCI. - -%package -n kernel%{_alt_kernel}-misc-vboxsf -Summary: Host file system access (Shared Folders) for VirtualBox -Summary(pl.UTF-8): Moduł jądra Linuksa dla VirtualBoksa -Release: %{rel}@%{_kernel_ver_str} +%package -n dkms-vboxhost +Summary: VirtualBox Support Drivers source +Summary(pl.UTF-8): Moduły jądra Linuksa dla VirtualBoksa +License: GPL v2+ Group: Base/Kernel -Requires(post,postun): /sbin/depmod -Requires(post): systemd-units >= 38 -Requires: dev >= 2.9.0-7 -Requires: kernel%{_alt_kernel}-misc-vboxguest -%if %{with dist_kernel} -%requires_releq_kernel -Requires(postun): %releq_kernel +Requires(pre): dkms +Requires(post): dkms +%if "%{_rpmversion}" >= "5" +BuildArch: noarch %endif -Requires: systemd-units >= 38 -Suggests: %{name}-kernel-init-guest >= %{version}-%{rel} -Provides: kernel(vboxsf) = %{version}-%{rel} -Obsoletes: kernel%{_alt_kernel}-misc-vboxvfs -%description -n kernel%{_alt_kernel}-misc-vboxsf -Host file system access (Shared Folders) for VirtualBox. +%description -n dkms-vboxhost +This package contains DKMS enabled sourcecode of VirtualBox Support +Driver, Network Adapter Driver, Network Filter Driver and PCI card +passthrough driver that works as host proxy between guest and PCI +hardware. -You should install this package in your Guest OS. +%description -n dkms-vboxhost -l pl.UTF-8 +Ten pakiet zawiera sterownik wsparcia dla systemu głównego, sterownik +witrualnej karty sieciowej, sterownik filtrowania sieci dla systemu +głównego oraz sterownik, ktory działa jako proxy między gościem i +gospodarzem sprzętu PCI. -%description -n kernel%{_alt_kernel}-misc-vboxsf -l pl.UTF-8 -Moduł jądra Linuksa dla VirtualBoksa - dostęp do plików systemu -głównego z poziomu systemu gościa. +# KERNEL PACKAGES -%package -n kernel%{_alt_kernel}-video-vboxvideo -Summary: DRM support for VirtualBox -Summary(pl.UTF-8): Moduł jądra Linuksa dla VirtualBoksa -Release: %{rel}@%{_kernel_ver_str} -Group: Base/Kernel -Requires(post,postun): /sbin/depmod -Requires: dev >= 2.9.0-7 -%if %{with dist_kernel} -%requires_releq_kernel -%requires_releq_kernel -n drm -Requires(postun): %releq_kernel -%endif -Provides: kernel(vboxvideo) = %{version}-%{rel} +# KEEP ALL REGULAR SUBPACKAGES BEFORE KERNEL PACKAGES. -%description -n kernel%{_alt_kernel}-video-vboxvideo -DRM support for VirtualBox. +%define kernel_pkg()\ +%package -n kernel%{_alt_kernel}-virtualbox-guest\ +Summary: VirtualBox kernel modules for Linux Guest\ +Summary(pl.UTF-8): Moduły VirtualBoksa do jądra Linuksa dla systemu gościa\ +Release: %{rel}@%{_kernel_ver_str}\ +Group: Base/Kernel\ +Requires(post,postun): /sbin/depmod\ +Requires(post): systemd-units >= 38\ +Requires: dev >= 2.9.0-7\ +Requires: systemd-units >= 38\ +%if %{with dist_kernel}\ +%requires_releq_kernel\ +Requires: %{releq_kernel -n drm}\ +Requires(postun): %releq_kernel\ +%endif\ +Provides: kernel(vboxguest) = %{version}-%{rel}\ +Provides: kernel(vboxsf) = %{version}-%{rel}\ +Provides: kernel(vboxvideo) = %{version}-%{rel}\ +Obsoletes: kernel-init-guest\ +Conflicts: kernel%{_alt_kernel}-virtualbox-host\ +\ +%description -n kernel%{_alt_kernel}-virtualbox-guest\ +This package contains VirtualBox Guest Additions for Linux Module,\ +host file system access (Shared Folders) and DRM support for\ +Linux guest system.\ +\ +%description -n kernel%{_alt_kernel}-virtualbox-guest -l pl.UTF-8\ +Ten pakiet zawiera moduł jądra Linuksa vboxguest dla VirtualBoksa -\ +dodatki dla systemu gościa, dostęp do plików systemu głównego z\ +poziomu systemu gościa i sterownik obsługi DRM.\ +\ +%package -n kernel%{_alt_kernel}-virtualbox-host\ +Summary: VirtualBox Support Drivers\ +Summary(pl.UTF-8): Moduły jądra Linuksa dla VirtualBoksa\ +Release: %{rel}@%{_kernel_ver_str}\ +Group: Base/Kernel\ +Requires(post,postun): /sbin/depmod\ +Requires(post): systemd-units >= 38\ +Requires: dev >= 2.9.0-7\ +%if %{with dist_kernel}\ +%requires_releq_kernel\ +Requires(postun): %releq_kernel\ +%endif\ +Requires: systemd-units >= 38\ +Provides: kernel(vboxdrv) = %{version}-%{rel}\ +Provides: kernel(vboxnetadp) = %{version}-%{rel}\ +Provides: kernel(vboxnetflt) = %{version}-%{rel}\ +Provides: kernel(vboxpci) = %{version}-%{rel}\ +Obsoletes: kernel-init-host\ +\ +%description -n kernel%{_alt_kernel}-virtualbox-host\ +This package contains VirtualBox Support Driver, Network Adapter\ +Driver, Network Filter Driver and PCI card passthrough driver that\ +works as host proxy between guest and PCI hardware.\ +\ +%description -n kernel%{_alt_kernel}-virtualbox-host -l pl.UTF-8\ +Ten pakiet zawiera sterownik wsparcia dla systemu głównego, sterownik\ +witrualnej karty sieciowej, sterownik filtrowania sieci dla systemu\ +głównego oraz sterownik, ktory działa jako proxy między gościem i\ +gospodarzem sprzętu PCI.\ +\ +%if %{with kernel}\ +%files -n kernel%{_alt_kernel}-virtualbox-guest\ +%defattr(644,root,root,755)\ +%config(noreplace) %verify(not md5 mtime size) /etc/modules-load.d/virtualbox-guest.conf\ +/lib/modules/%{_kernel_ver}/misc/vboxguest.ko*\ +/lib/modules/%{_kernel_ver}/misc/vboxsf.ko*\ +/lib/modules/%{_kernel_ver}/misc/vboxvideo.ko*\ +\ +%files -n kernel%{_alt_kernel}-virtualbox-host\ +%config(noreplace) %verify(not md5 mtime size) /etc/modules-load.d/virtualbox-host.conf\ +/lib/modules/%{_kernel_ver}/misc/vboxdrv.ko*\ +/lib/modules/%{_kernel_ver}/misc/vboxnetadp.ko*\ +/lib/modules/%{_kernel_ver}/misc/vboxnetflt.ko*\ +/lib/modules/%{_kernel_ver}/misc/vboxpci.ko*\ +%endif\ +\ +%post -n kernel%{_alt_kernel}-virtualbox-guest\ +%depmod %{_kernel_ver}\ +\ +%postun -n kernel%{_alt_kernel}-virtualbox-guest\ +%depmod %{_kernel_ver}\ +\ +%post -n kernel%{_alt_kernel}-virtualbox-host\ +%depmod %{_kernel_ver}\ +\ +%postun -n kernel%{_alt_kernel}-virtualbox-host\ +%depmod %{_kernel_ver}\ +%{nil} -You should install this package in your Guest OS. +%define build_kernel_pkg()\ +export KERN_DIR=%{_kernelsrcdir}\ +cd PLD-MODULE-BUILD/HostDrivers\ +%build_kernel_modules -m vboxdrv -C vboxdrv\ +%build_kernel_modules -m vboxnetadp -C vboxnetadp\ +%build_kernel_modules -m vboxnetflt -C vboxnetflt\ +%build_kernel_modules -m vboxpci -C vboxpci\ +cd ../GuestDrivers\ +%build_kernel_modules -m vboxguest -C vboxguest\ +cp -a vboxguest/Module.symvers vboxsf\ +%build_kernel_modules -m vboxsf -C vboxsf -c\ +%build_kernel_modules -m vboxvideo -C vboxvideo\ +cd ../..\ +%install_kernel_modules -D PLD-MODULE-BUILD/installed -m PLD-MODULE-BUILD/HostDrivers/vboxdrv/vboxdrv -d misc\ +%install_kernel_modules -D PLD-MODULE-BUILD/installed -m PLD-MODULE-BUILD/HostDrivers/vboxnetadp/vboxnetadp -d misc\ +%install_kernel_modules -D PLD-MODULE-BUILD/installed -m PLD-MODULE-BUILD/HostDrivers/vboxnetflt/vboxnetflt -d misc\ +%install_kernel_modules -D PLD-MODULE-BUILD/installed -m PLD-MODULE-BUILD/HostDrivers/vboxpci/vboxpci -d misc\ +%install_kernel_modules -D PLD-MODULE-BUILD/installed -m PLD-MODULE-BUILD/GuestDrivers/vboxguest/vboxguest -d misc\ +%install_kernel_modules -D PLD-MODULE-BUILD/installed -m PLD-MODULE-BUILD/GuestDrivers/vboxsf/vboxsf -d misc\ +%install_kernel_modules -D PLD-MODULE-BUILD/installed -m PLD-MODULE-BUILD/GuestDrivers/vboxvideo/vboxvideo -d misc\ +%{nil} -%description -n kernel%{_alt_kernel}-video-vboxvideo -l pl.UTF-8 -Moduł jądra Linuksa dla VirtualBoksa - sterownik obsługi DRM. +%{?with_kernel:%{expand:%kpkg}} %prep %setup -q -n %{pname}-%{version} @@ -540,8 +520,10 @@ Moduł jądra Linuksa dla VirtualBoksa - sterownik obsługi DRM. %patch3 -p1 %patch4 -p1 %patch5 -p1 +%patch6 -p1 %patch7 -p1 %patch8 -p1 +%patch9 -p1 %{__sed} -i -e 's,@VBOX_DOC_PATH@,%{_docdir}/%{name}-%{version},' \ -e 's/Categories=.*/Categories=Utility;Emulator;/' src/VBox/Installer/common/virtualbox.desktop.in @@ -550,7 +532,7 @@ Moduł jądra Linuksa dla VirtualBoksa - sterownik obsługi DRM. %{__sed} -i -e "s@_LDFLAGS\.%{vbox_arch}*.*=@& %{rpmldflags}@g" \ -i Config.kmk src/libs/xpcom18a4/Config.kmk -%{__sed} 's#@LIBDIR@#%{_libdir}#' < %{SOURCE9} > VirtualBox-wrapper.sh +%{__sed} -i -e 's#@INSTALL_DIR@#%{_libdir}/%{pname}#' src/VBox/Installer/linux/VBox.sh install -d PLD-MODULE-BUILD/{GuestDrivers,HostDrivers} cd PLD-MODULE-BUILD @@ -566,6 +548,10 @@ cd - # using system kBuild package %{__rm} -r kBuild +# use linux icon for now +cp -p src/VBox/Frontends/VirtualBox/images/os_{linux26,pld}.png +cp -p src/VBox/Frontends/VirtualBox/images/os_{linux26,pld}_64.png + cat <<'EOF'>> LocalConfig.kmk %{?with_verbose:KBUILD_VERBOSE=3} USERNAME=%(id -un) @@ -580,7 +566,17 @@ VBOX_WITH_LIGHTDM_GREETER_PACKING=1 TOOL_GCC3_CFLAGS=%{rpmcflags} TOOL_GCC3_CXXFLAGS=%{rpmcxxflags} VBOX_GCC_OPT=%{rpmcxxflags} -VBOX_WITH_TESTCASES= + +VBOX_PATH_APP_PRIVATE_ARCH := %{_libdir}/%{pname} +VBOX_PATH_APP_PRIVATE := %{_datadir}/%{pname} +VBOX_PATH_SHARED_LIBS := $(VBOX_PATH_APP_PRIVATE_ARCH) +VBOX_WITH_ORIGIN := +VBOX_WITH_RUNPATH := $(VBOX_PATH_APP_PRIVATE_ARCH) +#VBOX_PATH_APP_DOCS := %{_docdir}/%{pname}-doc-%{version} + +# don't build testcases to save time, they are not needed for the package +VBOX_WITH_TESTCASES := +VBOX_WITH_TESTSUITE := EOF %build @@ -596,63 +592,35 @@ EOF %{__enable webservice} \ %{nil} -XSERVER_VERSION=$(rpm -q --queryformat '%{VERSION}\n' xorg-xserver-server-devel | awk -F. ' { print $1 $2 } ' 2> /dev/null || echo ERROR) kmk %{?_smp_mflags} -%endif -%if %{with kernel} -export KERN_DIR=%{_kernelsrcdir} -cd PLD-MODULE-BUILD/HostDrivers -%build_kernel_modules -m vboxdrv -C vboxdrv -%build_kernel_modules -m vboxnetadp -C vboxnetadp -%build_kernel_modules -m vboxnetflt -C vboxnetflt -%build_kernel_modules -m vboxpci -C vboxpci - -cd ../GuestDrivers -%build_kernel_modules -m vboxguest -C vboxguest -cp -a vboxguest/Module.symvers vboxsf -%build_kernel_modules -m vboxsf -C vboxsf -c -%build_kernel_modules -m vboxvideo -C vboxvideo -cd ../.. %{__cc} %{rpmcflags} %{rpmldflags} -Wall -Werror src/VBox/Additions/linux/sharedfolders/{mount.vboxsf.c,vbsfmount.c} -o mount.vboxsf %endif +%{?with_kernel:%{expand:%bkpkg}} + %install rm -rf $RPM_BUILD_ROOT %if %{with userspace} install -d $RPM_BUILD_ROOT{%{_bindir},/sbin,%{_sbindir},%{_libdir}/%{pname}/ExtensionPacks} \ - $RPM_BUILD_ROOT{%{_pixmapsdir},%{_desktopdir}} \ + $RPM_BUILD_ROOT{%{_pixmapsdir},%{_desktopdir},%{_datadir}/mime/packages} \ $RPM_BUILD_ROOT%{_libdir}/xorg/modules/{drivers,dri,input} \ - $RPM_BUILD_ROOT{/lib/udev,/etc/udev/rules.d} + $RPM_BUILD_ROOT{/lib/udev,/etc/udev/rules.d} \ + $RPM_BUILD_ROOT{/etc/rc.d/init.d,%{systemdunitdir},%{_usrsrc}} # test if we can hardlink -- %{_builddir} and $RPM_BUILD_ROOT on same partition -if cp -al VBox.png $RPM_BUILD_ROOT/Vbox.png 2>/dev/null; then +if cp -al COPYING $RPM_BUILD_ROOT/COPYING; then l=l - %{__rm} -f $RPM_BUILD_ROOT/VBox.png + %{__rm} $RPM_BUILD_ROOT/COPYING fi cp -a$l %{outdir}/* $RPM_BUILD_ROOT%{_libdir}/%{pname} - -%if %{with doc} -ln -sf %{_docdir}/%{pname}-doc-%{version}/UserManual.pdf $RPM_BUILD_ROOT%{_libdir}/%{pname}/UserManual.pdf -ln -sf %{_docdir}/%{pname}-doc-%{version}/UserManual_fr_FR.pdf $RPM_BUILD_ROOT%{_libdir}/%{pname}/UserManual_fr_FR.pdf -%endif - -install -d $RPM_BUILD_ROOT%{_libdir}/%{pname}/additions cp -a$l %{SOURCE1} $RPM_BUILD_ROOT%{_libdir}/%{pname}/additions/VBoxGuestAdditions.iso -install -p %{SOURCE10} $RPM_BUILD_ROOT/sbin/mount.vdi -install -p VirtualBox-wrapper.sh $RPM_BUILD_ROOT%{_libdir}/%{pname} -for f in {VBox{BFE,Headless,Manage,SDL,SVC,Tunctl,XPCOMIPCD},VirtualBox}; do - ln -s %{_libdir}/%{pname}/VirtualBox-wrapper.sh $RPM_BUILD_ROOT%{_bindir}/$f -done - -%{__mv} $RPM_BUILD_ROOT{%{_libdir}/%{pname}/VBox.png,%{_pixmapsdir}/virtualbox.png} -%{__mv} $RPM_BUILD_ROOT{%{_libdir}/%{pname},%{_desktopdir}}/virtualbox.desktop -%{__mv} $RPM_BUILD_ROOT{%{_libdir}/%{pname}/additions/vboxvideo_drv_system.so,%{_libdir}/xorg/modules/drivers/vboxvideo_drv.so} +# vboxvideo %{__mv} $RPM_BUILD_ROOT{%{_libdir}/%{pname}/additions/VBoxOGL.so,%{_libdir}/xorg/modules/dri/vboxvideo_dri.so} - +%{__mv} $RPM_BUILD_ROOT{%{_libdir}/%{pname}/additions/vboxvideo_drv_system.so,%{_libdir}/xorg/modules/drivers/vboxvideo_drv.so} # XXX: where else to install them that vboxvideo_dri.so finds them? patch with rpath? %{__mv} $RPM_BUILD_ROOT{%{_libdir}/%{pname}/additions,%{_libdir}}/VBoxOGLarrayspu.so %{__mv} $RPM_BUILD_ROOT{%{_libdir}/%{pname}/additions,%{_libdir}}/VBoxOGLcrutil.so @@ -661,28 +629,16 @@ done %{__mv} $RPM_BUILD_ROOT{%{_libdir}/%{pname}/additions,%{_libdir}}/VBoxOGLpackspu.so %{__mv} $RPM_BUILD_ROOT{%{_libdir}/%{pname}/additions,%{_libdir}}/VBoxOGLpassthroughspu.so -cp -a %{SOURCE11} $RPM_BUILD_ROOT/etc/udev/rules.d/virtualbox.rules -%{__mv} $RPM_BUILD_ROOT{%{_libdir}/%{pname},/lib/udev}/VBoxCreateUSBNode.sh - -install -d $RPM_BUILD_ROOT/%{_lib}/security -%{__mv} $RPM_BUILD_ROOT{%{_libdir}/%{pname}/additions,/%{_lib}/security}/pam_vbox.so - -# cleanup unpackaged -%{__rm} -r $RPM_BUILD_ROOT%{_libdir}/%{pname}/{src,sdk,testcase} -%{__rm} -r $RPM_BUILD_ROOT%{_libdir}/%{pname}/additions/src -%{__rm} $RPM_BUILD_ROOT%{_libdir}/%{pname}/vboxkeyboard.tar.bz2 -%{__rm} $RPM_BUILD_ROOT%{_libdir}/%{pname}/tst* -%{__rm} $RPM_BUILD_ROOT%{_libdir}/%{pname}/ExtensionPacks/VNC/ExtPack-license.* - # Guest Only Tools -install -d $RPM_BUILD_ROOT/etc/{X11/xinit/xinitrc.d,xdg/autostart} -%{__mv} $RPM_BUILD_ROOT{%{_libdir}/%{pname}/additions,%{_bindir}}/VBoxService %{__mv} $RPM_BUILD_ROOT{%{_libdir}/%{pname}/additions,%{_bindir}}/VBoxClient %{__mv} $RPM_BUILD_ROOT{%{_libdir}/%{pname}/additions,%{_bindir}}/VBoxControl -install -p -D src/VBox/Additions/x11/Installer/98vboxadd-xclient \ - $RPM_BUILD_ROOT/etc/X11/xinit/xinitrc.d/98vboxadd-xclient.sh +%{__mv} $RPM_BUILD_ROOT{%{_libdir}/%{pname}/additions,%{_bindir}}/VBoxService +install -d $RPM_BUILD_ROOT/etc/xdg/autostart cp -p src/VBox/Additions/x11/Installer/vboxclient.desktop \ $RPM_BUILD_ROOT/etc/xdg/autostart/vboxclient.desktop +install -p src/VBox/Additions/x11/Installer/98vboxadd-xclient $RPM_BUILD_ROOT%{_bindir}/VBoxClient-all +install -p %{SOURCE2} $RPM_BUILD_ROOT/etc/rc.d/init.d/vboxservice +install -p %{SOURCE3} $RPM_BUILD_ROOT%{systemdunitdir}/vboxservice.service %if %{with lightdm} install -d $RPM_BUILD_ROOT%{_datadir}/xgreeters @@ -690,69 +646,101 @@ install -d $RPM_BUILD_ROOT%{_datadir}/xgreeters cp -p %{objdir}/Additions/Installer/linux/share/VBoxGuestAdditions/vbox-greeter.desktop $RPM_BUILD_ROOT%{_datadir}/xgreeters %endif +# pam +install -d $RPM_BUILD_ROOT/%{_lib}/security +%{__mv} $RPM_BUILD_ROOT{%{_libdir}/%{pname}/additions,/%{_lib}/security}/pam_vbox.so + +# mount.vboxsf +%{__rm} $RPM_BUILD_ROOT%{_libdir}/%{pname}/additions/mount.vboxsf +install -p mount.vboxsf $RPM_BUILD_ROOT/sbin/mount.vboxsf + +# mount.vdi +install -p %{SOURCE5} $RPM_BUILD_ROOT/sbin/mount.vdi + +# these belong to .iso +%{__rm} $RPM_BUILD_ROOT%{_libdir}/%{pname}/additions/autorun.sh +%{__rm} $RPM_BUILD_ROOT%{_libdir}/%{pname}/additions/runasroot.sh + # unknown - checkme %if 1 +%{__rm} $RPM_BUILD_ROOT%{_libdir}/%{pname}/additions/vboxadd +%{__rm} $RPM_BUILD_ROOT%{_libdir}/%{pname}/additions/vboxadd-service +%{__rm} $RPM_BUILD_ROOT%{_libdir}/%{pname}/additions/vboxadd-x11 +%{__rm} $RPM_BUILD_ROOT%{_libdir}/%{pname}/helpers/generate_service_file %{__rm} $RPM_BUILD_ROOT%{_libdir}/%{pname}/SUPInstall %{__rm} $RPM_BUILD_ROOT%{_libdir}/%{pname}/SUPLoggerCtl %{__rm} $RPM_BUILD_ROOT%{_libdir}/%{pname}/SUPUninstall -%{__rm} $RPM_BUILD_ROOT%{_libdir}/%{pname}/VBox.sh -%{__rm} $RPM_BUILD_ROOT%{_libdir}/%{pname}/vboxshell.py -%{__rm} $RPM_BUILD_ROOT%{_libdir}/%{pname}/xpidl -%{__rm} $RPM_BUILD_ROOT%{_libdir}/%{pname}/additions/runasroot.sh %{__rm} $RPM_BUILD_ROOT%{_libdir}/%{pname}/load.sh %{__rm} $RPM_BUILD_ROOT%{_libdir}/%{pname}/loadall.sh -%{__rm} $RPM_BUILD_ROOT%{_libdir}/%{pname}/dtrace/lib/%{vbox_arch}/CPUMInternal.d -%{__rm} $RPM_BUILD_ROOT%{_libdir}/%{pname}/dtrace/lib/%{vbox_arch}/cpumctx.d -%{__rm} $RPM_BUILD_ROOT%{_libdir}/%{pname}/dtrace/lib/%{vbox_arch}/vbox-arch-types.d -%{__rm} $RPM_BUILD_ROOT%{_libdir}/%{pname}/dtrace/lib/%{vbox_arch}/vbox-types.d -%{__rm} $RPM_BUILD_ROOT%{_libdir}/%{pname}/dtrace/lib/%{vbox_arch}/vm.d -%{__rm} $RPM_BUILD_ROOT%{_libdir}/%{pname}/dtrace/lib/%{vbox_arch}/x86.d -%{__rm} $RPM_BUILD_ROOT%{_libdir}/%{pname}/dtrace/testcase/%{vbox_arch}/vbox-vm-struct-test.d -%{__rm} $RPM_BUILD_ROOT%{_libdir}/%{pname}/helpers/generate_service_file %{__rm} $RPM_BUILD_ROOT%{_libdir}/%{pname}/scripts/VBoxHeadlessXOrg.sh -%{__rm} $RPM_BUILD_ROOT%{_libdir}/%{pname}/scripts/generated.sh %{__rm} $RPM_BUILD_ROOT%{_libdir}/%{pname}/scripts/init_template.sh %{__rm} $RPM_BUILD_ROOT%{_libdir}/%{pname}/scripts/install_service +%{__rm} $RPM_BUILD_ROOT%{_libdir}/%{pname}/vboxshell.py +%{__rm} $RPM_BUILD_ROOT%{_libdir}/%{pname}/xpidl +%{__rm} -r $RPM_BUILD_ROOT%{_libdir}/%{pname}/additions/src %endif -# packaged by kernel part -%{__rm} $RPM_BUILD_ROOT%{_libdir}/%{pname}/additions/mount.vboxsf +# use upstream installer to relocate rest of the files, fakeroot because it forces uid/gid 0 +fakeroot sh -x $RPM_BUILD_ROOT%{_libdir}/%{pname}/scripts/install.sh \ + --ose \ + --prefix %{_prefix} \ + %{!?with_webservice:--no-web-service} \ + --root $RPM_BUILD_ROOT + +%{__mv} $RPM_BUILD_ROOT{%{_datadir}/%{pname},/lib/udev}/VBoxCreateUSBNode.sh +cp -p %{SOURCE6} $RPM_BUILD_ROOT/etc/udev/rules.d/virtualbox.rules + +# cleanup lowercased variants, not used in any script (less cruft) +%{__rm} -r $RPM_BUILD_ROOT%{_bindir}/vboxautostart +%{__rm} -r $RPM_BUILD_ROOT%{_bindir}/vboxballoonctrl +%{__rm} -r $RPM_BUILD_ROOT%{_bindir}/vboxheadless +%{__rm} -r $RPM_BUILD_ROOT%{_bindir}/vboxmanage +%{__rm} -r $RPM_BUILD_ROOT%{_bindir}/vboxsdl +%{__rm} -r $RPM_BUILD_ROOT%{_bindir}/virtualbox + +# cleanup unpackaged +%{__rm} -r $RPM_BUILD_ROOT%{_libdir}/%{pname}/{sdk,testcase} +%{__rm} -r $RPM_BUILD_ROOT%{_libdir}/%{pname}/dtrace +%{__rm} -r $RPM_BUILD_ROOT%{_datadir}/%{pname}/src +%{__rm} $RPM_BUILD_ROOT%{_libdir}/%{pname}/vboxkeyboard.tar.bz2 +%{__rm} $RPM_BUILD_ROOT%{_libdir}/%{pname}/tst* +%{__rm} $RPM_BUILD_ROOT%{_libdir}/%{pname}/scripts/generated.sh +%{__rm} $RPM_BUILD_ROOT%{_libdir}/%{pname}/ExtensionPacks/VNC/ExtPack-license.* +%{__rm} $RPM_BUILD_ROOT%{_usrsrc}/vboxhost-%{version}_PLD +%{__rm} -r $RPM_BUILD_ROOT%{py_sitescriptdir}/vboxapi* + +# weird icon size +%{__rm} -r $RPM_BUILD_ROOT%{_iconsdir}/hicolor/40x40 +# duplicate, we already have virtualbox.png (128x128), this is 32x32 +%{__rm} -r $RPM_BUILD_ROOT%{_pixmapsdir}/VBox.png + +%if %{with doc} +ln -sf %{_docdir}/%{pname}-doc-%{version}/UserManual.pdf $RPM_BUILD_ROOT%{_libdir}/%{pname}/UserManual.pdf +ln -sf %{_docdir}/%{pname}-doc-%{version}/UserManual_fr_FR.pdf $RPM_BUILD_ROOT%{_libdir}/%{pname}/UserManual_fr_FR.pdf +%endif + +%if %{with dkms} +install -d $RPM_BUILD_ROOT%{_usrsrc}/vbox{host,guest}-%{version}-%{rel} +cp -a PLD-MODULE-BUILD/HostDrivers/* $RPM_BUILD_ROOT%{_usrsrc}/vboxhost-%{version}-%{rel} +cp -p src/VBox/HostDrivers/linux/dkms.conf $RPM_BUILD_ROOT%{_usrsrc}/vboxhost-%{version}-%{rel} +%{__make} -C $RPM_BUILD_ROOT%{_usrsrc}/vboxhost-%{version}-%{rel} clean +rm -rf $RPM_BUILD_ROOT%{_usrsrc}/vboxhost-%{version}-%{rel}/*/o + +cp -a PLD-MODULE-BUILD/GuestDrivers/* $RPM_BUILD_ROOT%{_usrsrc}/vboxguest-%{version}-%{rel} +cp -p src/VBox/Additions/common/VBoxGuest/linux/dkms.conf $RPM_BUILD_ROOT%{_usrsrc}/vboxguest-%{version}-%{rel} +%{__make} -C $RPM_BUILD_ROOT%{_usrsrc}/vboxguest-%{version}-%{rel} clean +rm -rf $RPM_BUILD_ROOT%{_usrsrc}/vboxguest-%{version}-%{rel}/*/o +%endif %endif %if %{with kernel} -install -d $RPM_BUILD_ROOT{/etc/{rc.d/init.d,modules-load.d},/sbin,%{systemdunitdir}} -install -p %{SOURCE2} $RPM_BUILD_ROOT/etc/rc.d/init.d/vboxservice -install -p %{SOURCE3} $RPM_BUILD_ROOT/etc/rc.d/init.d/vboxdrv -install -p %{SOURCE4} $RPM_BUILD_ROOT/etc/rc.d/init.d/vboxguest -install -p %{SOURCE5} $RPM_BUILD_ROOT/etc/rc.d/init.d/vboxnetflt -install -p %{SOURCE6} $RPM_BUILD_ROOT/etc/rc.d/init.d/vboxsf -install -p %{SOURCE7} $RPM_BUILD_ROOT/etc/rc.d/init.d/vboxnetadp -install -p %{SOURCE8} $RPM_BUILD_ROOT/etc/rc.d/init.d/vboxpci -%install_kernel_modules -m PLD-MODULE-BUILD/HostDrivers/vboxdrv/vboxdrv -d misc -%install_kernel_modules -m PLD-MODULE-BUILD/HostDrivers/vboxnetadp/vboxnetadp -d misc -%install_kernel_modules -m PLD-MODULE-BUILD/HostDrivers/vboxnetflt/vboxnetflt -d misc -%install_kernel_modules -m PLD-MODULE-BUILD/HostDrivers/vboxpci/vboxpci -d misc -%install_kernel_modules -m PLD-MODULE-BUILD/GuestDrivers/vboxguest/vboxguest -d misc -%install_kernel_modules -m PLD-MODULE-BUILD/GuestDrivers/vboxsf/vboxsf -d misc -%install_kernel_modules -m PLD-MODULE-BUILD/GuestDrivers/vboxvideo/vboxvideo -d misc +install -d $RPM_BUILD_ROOT{/etc/modules-load.d,/sbin} -install -p mount.vboxsf $RPM_BUILD_ROOT/sbin/mount.vboxsf +cp -a PLD-MODULE-BUILD/installed/* $RPM_BUILD_ROOT # Tell systemd to load modules -cp -p %{SOURCE12} $RPM_BUILD_ROOT/etc/modules-load.d/vboxdrv.conf -cp -p %{SOURCE13} $RPM_BUILD_ROOT/etc/modules-load.d/vboxguest.conf -cp -p %{SOURCE14} $RPM_BUILD_ROOT/etc/modules-load.d/vboxnetflt.conf -cp -p %{SOURCE15} $RPM_BUILD_ROOT/etc/modules-load.d/vboxsf.conf -cp -p %{SOURCE16} $RPM_BUILD_ROOT/etc/modules-load.d/vboxnetadp.conf -cp -p %{SOURCE17} $RPM_BUILD_ROOT/etc/modules-load.d/vboxpci.conf - -# And mask module-loading services -ln -sf /dev/null $RPM_BUILD_ROOT%{systemdunitdir}/vboxdrv.service -ln -sf /dev/null $RPM_BUILD_ROOT%{systemdunitdir}/vboxguest.service -ln -sf /dev/null $RPM_BUILD_ROOT%{systemdunitdir}/vboxnetflt.service -ln -sf /dev/null $RPM_BUILD_ROOT%{systemdunitdir}/vboxsf.service -ln -sf /dev/null $RPM_BUILD_ROOT%{systemdunitdir}/vboxnetadp.service -ln -sf /dev/null $RPM_BUILD_ROOT%{systemdunitdir}/vboxpci.service +cp -p %{SOURCE7} $RPM_BUILD_ROOT/etc/modules-load.d/virtualbox-host.conf +cp -p %{SOURCE8} $RPM_BUILD_ROOT/etc/modules-load.d/virtualbox-guest.conf %endif %clean @@ -762,7 +750,6 @@ rm -rf $RPM_BUILD_ROOT %groupadd -g 221 -r -f vbox %post -%update_desktop_database for i in /sys/bus/usb/devices/*; do if [ -r "$i/dev" ]; then dev="`cat "$i/dev" 2>/dev/null || true`" @@ -774,18 +761,11 @@ for i in /sys/bus/usb/devices/*; do done cat << 'EOF' -You must install vboxdrv kernel module for this software to work: - kernel-misc-vboxdrv-%{version}-%{rel}@%{_kernel_ver_str} - -Additionally you might want to install: - kernel-misc-vboxnetadp-%{version}-%{rel}@%{_kernel_ver_str} - kernel-misc-vboxnetflt-%{version}-%{rel}@%{_kernel_ver_str} - kernel-misc-vboxpci-%{version}-%{rel}@%{_kernel_ver_str} +You must install vboxdrv kernel modules for this software to work: + kernel*-virtualbox-host-%{version}-%{rel}@* On Guest Linux system you might want to install: - kernel-misc-vboxguest-%{version}-%{rel}@%{_kernel_ver_str} - kernel-misc-vboxsf-%{version}-%{rel}@%{_kernel_ver_str} - kernel-video-vboxvideo-%{version}-%{rel}@%{_kernel_ver_str} + kernel*-virtualbox-guest-%{version}-%{rel}@* EOF @@ -794,281 +774,226 @@ if [ "$1" = "0" ]; then %groupremove vbox fi +%post gui +%update_desktop_database +%update_icon_cache hicolor +%update_mime_database + +%postun gui +%update_desktop_database +%update_icon_cache hicolor +%update_mime_database + %post guest /sbin/chkconfig --add vboxservice %service vboxservice restart +%systemd_post vboxservice.service %preun guest if [ "$1" = "0" ]; then /sbin/chkconfig --del vboxservice %service vboxservice -q stop fi +%systemd_preun vboxservice.service -%pre -n lightdm-greeter-vbox -%addusertogroup xdm vbox - -%post -n kernel%{_alt_kernel}-misc-vboxdrv -%depmod %{_kernel_ver} -%vbox_kernel_post -d vboxdrv VirtualBox Support Driver - -%preun -n kernel%{_alt_kernel}-misc-vboxdrv -if [ "$1" = "0" ]; then - %service vboxdrv stop -fi - -%postun -n kernel%{_alt_kernel}-misc-vboxdrv -%depmod %{_kernel_ver} - -%post -n kernel%{_alt_kernel}-misc-vboxnetadp -%depmod %{_kernel_ver} -%vbox_kernel_post -d vboxnetadp VirtualBox Network HostOnly driver - -%preun -n kernel%{_alt_kernel}-misc-vboxnetadp -if [ "$1" = "0" ]; then - %service vboxnetadp stop -fi - -%postun -n kernel%{_alt_kernel}-misc-vboxnetadp -%depmod %{_kernel_ver} - -%post -n kernel%{_alt_kernel}-misc-vboxnetflt -%depmod %{_kernel_ver} -%vbox_kernel_post -d vboxnetflt VirtualBox Network Filter driver - -%preun -n kernel%{_alt_kernel}-misc-vboxnetflt -if [ "$1" = "0" ]; then - %service vboxnetflt stop -fi - -%postun -n kernel%{_alt_kernel}-misc-vboxnetflt -%depmod %{_kernel_ver} - -%post -n kernel%{_alt_kernel}-misc-vboxpci -%depmod %{_kernel_ver} -%vbox_kernel_post -d vboxpci VirtualBox PCI passthrough driver - -%preun -n kernel%{_alt_kernel}-misc-vboxpci -if [ "$1" = "0" ]; then - %service vboxpci stop -fi - -%postun -n kernel%{_alt_kernel}-misc-vboxpci -%depmod %{_kernel_ver} - -%post -n kernel%{_alt_kernel}-misc-vboxguest -%depmod %{_kernel_ver} -%vbox_kernel_post -d vboxguest VirtualBox Guest additions driver - -%preun -n kernel%{_alt_kernel}-misc-vboxguest -if [ "$1" = "0" ]; then - %service vboxguest stop -fi - -%postun -n kernel%{_alt_kernel}-misc-vboxguest -%depmod %{_kernel_ver} - -%post -n kernel%{_alt_kernel}-misc-vboxsf -%depmod %{_kernel_ver} -%vbox_kernel_post -d vboxsf VirtualBox Host file system access (Shared Folders) - -%preun -n kernel%{_alt_kernel}-misc-vboxsf -if [ "$1" = "0" ]; then - %service vboxsf stop -fi - -%postun -n kernel%{_alt_kernel}-misc-vboxsf -%depmod %{_kernel_ver} - -%post -n kernel%{_alt_kernel}-video-vboxvideo -%depmod %{_kernel_ver} - -%postun -n kernel%{_alt_kernel}-video-vboxvideo -%depmod %{_kernel_ver} - -%post kernel-init-host -/sbin/chkconfig --add vboxdrv -/sbin/chkconfig --add vboxnetadp -/sbin/chkconfig --add vboxnetflt -/sbin/chkconfig --add vboxpci +%postun guest %systemd_reload -%preun kernel-init-host -if [ "$1" = "0" ]; then - /sbin/chkconfig --del vboxdrv - /sbin/chkconfig --del vboxnetadp - /sbin/chkconfig --del vboxnetflt - /sbin/chkconfig --del vboxpci -fi +%triggerpostun guest -- VirtualBox-guest < 4.3.0-1 +%systemd_trigger vboxservice.service -%postun kernel-init-host -%systemd_reload +%pre -n lightdm-greeter-vbox +%addusertogroup xdm vbox -%post kernel-init-guest -/sbin/chkconfig --add vboxguest -/sbin/chkconfig --add vboxsf -%systemd_reload +%post -n dkms-vboxguest +set -x +dkms add -m vboxguest -v %{version}-%{rel} --rpm_safe_upgrade && \ +dkms build -m vboxguest -v %{version}-%{rel} --rpm_safe_upgrade && \ +dkms install -m vboxguest -v %{version}-%{rel} --rpm_safe_upgrade || : -%preun kernel-init-guest -if [ "$1" = "0" ]; then - /sbin/chkconfig --del vboxguest - /sbin/chkconfig --del vboxsf -fi +%preun -n dkms-vboxguest +set -x +dkms remove -m vboxguest -v %{version}-%{rel} --rpm_safe_upgrade --all || : -%postun kernel-init-guest -%systemd_reload +%post -n dkms-vboxhost +set -x +dkms add -m vboxhost -v %{version}-%{rel} --rpm_safe_upgrade && \ +dkms build -m vboxhost -v %{version}-%{rel} --rpm_safe_upgrade && \ +dkms install -m vboxhost -v %{version}-%{rel} --rpm_safe_upgrade || : + +%preun -n dkms-vboxhost +set -x +dkms remove -m vboxhost -v %{version}-%{rel} --rpm_safe_upgrade --all || : %if %{with userspace} %files %defattr(644,root,root,755) -%dir %{_libdir}/%{pname} -%dir %{_libdir}/%{pname}/ExtensionPacks -%dir %{_libdir}/%{pname}/ExtensionPacks/VNC -%dir %{_libdir}/%{pname}/ExtensionPacks/VNC/linux* -%dir %{_libdir}/%{pname}/additions -%dir %{_libdir}/%{pname}/components -%dir %{_libdir}/%{pname}/nls -%attr(755,root,root) %{_bindir}/VBoxBFE +%attr(755,root,root) /sbin/mount.vdi +%attr(755,root,root) %{_bindir}/VBox +%attr(755,root,root) %{_bindir}/VBoxAutostart +%attr(755,root,root) %{_bindir}/VBoxBalloonCtrl %attr(755,root,root) %{_bindir}/VBoxHeadless %attr(755,root,root) %{_bindir}/VBoxManage %attr(755,root,root) %{_bindir}/VBoxSDL -%attr(755,root,root) %{_bindir}/VBoxSVC %attr(755,root,root) %{_bindir}/VBoxTunctl -%attr(755,root,root) %{_bindir}/VBoxXPCOMIPCD -%attr(755,root,root) %{_bindir}/VirtualBox -%attr(755,root,root) /sbin/mount.vdi +%dir %{_libdir}/%{pname} +# libraries %attr(755,root,root) %{_libdir}/%{pname}/DBGCPlugInDiggers.so %attr(755,root,root) %{_libdir}/%{pname}/VBoxAuth.so %attr(755,root,root) %{_libdir}/%{pname}/VBoxAuthSimple.so -%attr(755,root,root) %{_libdir}/%{pname}/VBoxAutostart -%attr(755,root,root) %{_libdir}/%{pname}/VBoxBFE -%attr(755,root,root) %{_libdir}/%{pname}/VBoxBalloonCtrl -%attr(755,root,root) %{_libdir}/%{pname}/VBoxDbg.so -%attr(755,root,root) %{_libdir}/%{pname}/VBoxDD2.so %attr(755,root,root) %{_libdir}/%{pname}/VBoxDD.so +%attr(755,root,root) %{_libdir}/%{pname}/VBoxDD2.so %attr(755,root,root) %{_libdir}/%{pname}/VBoxDDU.so %attr(755,root,root) %{_libdir}/%{pname}/VBoxDragAndDropSvc.so -%attr(755,root,root) %{_libdir}/%{pname}/VBoxExtPackHelperApp %attr(755,root,root) %{_libdir}/%{pname}/VBoxGuestControlSvc.so %attr(755,root,root) %{_libdir}/%{pname}/VBoxGuestPropSvc.so -%attr(755,root,root) %{_libdir}/%{pname}/VBoxHeadless %attr(755,root,root) %{_libdir}/%{pname}/VBoxHostChannel.so %attr(755,root,root) %{_libdir}/%{pname}/VBoxKeyboard.so -%attr(755,root,root) %{_libdir}/%{pname}/VBoxManage -%if %{with doc} -%attr(755,root,root) %{_libdir}/%{pname}/VBoxManageHelp -%endif -%attr(755,root,root) %{_libdir}/%{pname}/VBoxNetAdpCtl -%attr(755,root,root) %{_libdir}/%{pname}/VBoxNetDHCP %attr(755,root,root) %{_libdir}/%{pname}/VBoxOGLhostcrutil.so %attr(755,root,root) %{_libdir}/%{pname}/VBoxOGLhosterrorspu.so %attr(755,root,root) %{_libdir}/%{pname}/VBoxOGLrenderspu.so %attr(755,root,root) %{_libdir}/%{pname}/VBoxPython*.so %attr(755,root,root) %{_libdir}/%{pname}/VBoxREM.so +%attr(755,root,root) %{_libdir}/%{pname}/VBoxRT.so +%attr(755,root,root) %{_libdir}/%{pname}/VBoxSharedClipboard.so +%attr(755,root,root) %{_libdir}/%{pname}/VBoxSharedCrOpenGL.so +%attr(755,root,root) %{_libdir}/%{pname}/VBoxSharedFolders.so +%attr(755,root,root) %{_libdir}/%{pname}/VBoxVMM.so +%attr(755,root,root) %{_libdir}/%{pname}/VBoxXPCOM.so +%attr(755,root,root) %{_libdir}/%{pname}/VBoxXPCOMC.so %ifarch %{ix86} %attr(755,root,root) %{_libdir}/%{pname}/VBoxREM32.so %attr(755,root,root) %{_libdir}/%{pname}/VBoxREM64.so %endif -%attr(755,root,root) %{_libdir}/%{pname}/VBoxRT.so + +# binaries +%attr(755,root,root) %{_libdir}/%{pname}/VBoxAutostart +%attr(755,root,root) %{_libdir}/%{pname}/VBoxBalloonCtrl +%attr(755,root,root) %{_libdir}/%{pname}/VBoxExtPackHelperApp +%attr(755,root,root) %{_libdir}/%{pname}/VBoxHeadless +%attr(755,root,root) %{_libdir}/%{pname}/VBoxManage +%attr(755,root,root) %{_libdir}/%{pname}/VBoxNetAdpCtl +%attr(755,root,root) %{_libdir}/%{pname}/VBoxNetDHCP +%attr(755,root,root) %{_libdir}/%{pname}/VBoxNetNAT %attr(755,root,root) %{_libdir}/%{pname}/VBoxSDL -%attr(755,root,root) %{_libdir}/%{pname}/VBoxSharedClipboard.so -%attr(755,root,root) %{_libdir}/%{pname}/VBoxSharedCrOpenGL.so -%attr(755,root,root) %{_libdir}/%{pname}/VBoxSharedFolders.so %attr(755,root,root) %{_libdir}/%{pname}/VBoxSVC -%attr(755,root,root) %{_libdir}/%{pname}/VBoxSysInfo.sh -%attr(755,root,root) %{_libdir}/%{pname}/VBoxTestOGL -%attr(755,root,root) %{_libdir}/%{pname}/VBoxTunctl -%attr(755,root,root) %{_libdir}/%{pname}/VBoxVMM.so %attr(755,root,root) %{_libdir}/%{pname}/VBoxVMMPreload -%attr(755,root,root) %{_libdir}/%{pname}/VBoxXPCOMC.so +%attr(755,root,root) %{_libdir}/%{pname}/VBoxVolInfo %attr(755,root,root) %{_libdir}/%{pname}/VBoxXPCOMIPCD -%attr(755,root,root) %{_libdir}/%{pname}/VBoxXPCOM.so -%attr(755,root,root) %{_libdir}/%{pname}/VirtualBox -%attr(755,root,root) %{_libdir}/%{pname}/VirtualBox-wrapper.sh +%attr(755,root,root) %{_libdir}/%{pname}/iPxeBaseBin +%if %{with doc} +%attr(755,root,root) %{_libdir}/%{pname}/VBoxManageHelp +%endif + +%dir %{_libdir}/%{pname}/ExtensionPacks +%{_libdir}/%{pname}/ExtensionPacks/VNC/ExtPack.xml +%dir %{_libdir}/%{pname}/ExtensionPacks/VNC +%dir %{_libdir}/%{pname}/ExtensionPacks/VNC/linux* %attr(755,root,root) %{_libdir}/%{pname}/ExtensionPacks/VNC/linux*/VBoxVNC*.so + +%{_libdir}/%{pname}/VBoxDD2GC.debug %{_libdir}/%{pname}/VBoxDD2GC.gc -%{_libdir}/%{pname}/VBoxDDGC.gc -%{_libdir}/%{pname}/VMMGC.gc +%{_libdir}/%{pname}/VBoxDD2R0.debug %{_libdir}/%{pname}/VBoxDD2R0.r0 +%{_libdir}/%{pname}/VBoxDDGC.debug +%{_libdir}/%{pname}/VBoxDDGC.gc +%{_libdir}/%{pname}/VBoxDDR0.debug %{_libdir}/%{pname}/VBoxDDR0.r0 -%{_libdir}/%{pname}/VMMR0.r0 -#%{_libdir}/%{pname}/EfiThunk %{_libdir}/%{pname}/VBoxEFI32.fd %{_libdir}/%{pname}/VBoxEFI64.fd +%{_libdir}/%{pname}/VMMGC.debug +%{_libdir}/%{pname}/VMMGC.gc +%{_libdir}/%{pname}/VMMR0.debug +%{_libdir}/%{pname}/VMMR0.r0 + +%dir %{_libdir}/%{pname}/components %{_libdir}/%{pname}/components/VBoxXPCOMBase.xpt -%{_libdir}/%{pname}/ExtensionPacks/VNC/ExtPack.xml %{_libdir}/%{pname}/components/VirtualBox_XPCOM.xpt %attr(755,root,root) %{_libdir}/%{pname}/components/VBoxC.so %attr(755,root,root) %{_libdir}/%{pname}/components/VBoxSVCM.so %attr(755,root,root) %{_libdir}/%{pname}/components/VBoxXPCOMIPCC.so -%lang(bg) %{_libdir}/%{pname}/nls/*_bg.qm -%lang(ca) %{_libdir}/%{pname}/nls/*_ca.qm -%lang(ca_VA) %{_libdir}/%{pname}/nls/*_ca_VA.qm -%lang(cs) %{_libdir}/%{pname}/nls/*_cs.qm -%lang(da) %{_libdir}/%{pname}/nls/*_da.qm -%lang(de) %{_libdir}/%{pname}/nls/*_de.qm -%lang(en) %{_libdir}/%{pname}/nls/*_en.qm -%lang(es) %{_libdir}/%{pname}/nls/*_es.qm -%lang(eu) %{_libdir}/%{pname}/nls/*_eu.qm -%lang(fi) %{_libdir}/%{pname}/nls/*_fa_IR.qm -%lang(fi) %{_libdir}/%{pname}/nls/*_fi.qm -%lang(fr) %{_libdir}/%{pname}/nls/*_fr.qm -%lang(gl_ES) %{_libdir}/%{pname}/nls/*_gl_ES.qm -%lang(hu) %{_libdir}/%{pname}/nls/*_hu.qm -%lang(id) %{_libdir}/%{pname}/nls/*_id.qm -%lang(it) %{_libdir}/%{pname}/nls/*_it.qm -%lang(ja) %{_libdir}/%{pname}/nls/*_ja.qm -%lang(km_KH) %{_libdir}/%{pname}/nls/*_km_KH.qm -%lang(ko) %{_libdir}/%{pname}/nls/*_ko.qm -%lang(lt) %{_libdir}/%{pname}/nls/*_lt.qm -%lang(nl) %{_libdir}/%{pname}/nls/*_nl.qm -%lang(pl) %{_libdir}/%{pname}/nls/*_pl.qm -%lang(pt) %{_libdir}/%{pname}/nls/*_pt.qm -%lang(pt_BR) %{_libdir}/%{pname}/nls/*_pt_BR.qm -%lang(ro) %{_libdir}/%{pname}/nls/*_ro.qm -%lang(ru) %{_libdir}/%{pname}/nls/*_ru.qm -%lang(sk) %{_libdir}/%{pname}/nls/*_sk.qm -%lang(sr) %{_libdir}/%{pname}/nls/*_sr.qm -%lang(sv) %{_libdir}/%{pname}/nls/*_sv.qm -%lang(tr) %{_libdir}/%{pname}/nls/*_tr.qm -%lang(uk) %{_libdir}/%{pname}/nls/*_uk.qm -%lang(zh_CN) %{_libdir}/%{pname}/nls/*_zh_CN.qm -%lang(zh_TW) %{_libdir}/%{pname}/nls/*_zh_TW.qm -%{_pixmapsdir}/virtualbox.png -%{_desktopdir}/*.desktop -%{_libdir}/%{pname}/icons -%{_libdir}/%{pname}/virtualbox.xml + +%dir %{_datadir}/%{pname} +%attr(755,root,root) %{_datadir}/%{pname}/VBoxSysInfo.sh %config(noreplace) %verify(not md5 mtime size) /etc/udev/rules.d/virtualbox.rules %attr(755,root,root) /lib/udev/VBoxCreateUSBNode.sh +%files gui +%defattr(644,root,root,755) +%attr(755,root,root) %{_bindir}/VirtualBox +%attr(755,root,root) %{_libdir}/%{pname}/VBoxDbg.so +%attr(755,root,root) %{_libdir}/%{pname}/VBoxTestOGL +%attr(755,root,root) %{_libdir}/%{pname}/VirtualBox +%dir %{_datadir}/%{pname}/nls +%lang(bg) %{_datadir}/%{pname}/nls/*_bg.qm +%lang(ca) %{_datadir}/%{pname}/nls/*_ca.qm +%lang(ca_VA) %{_datadir}/%{pname}/nls/*_ca_VA.qm +%lang(cs) %{_datadir}/%{pname}/nls/*_cs.qm +%lang(da) %{_datadir}/%{pname}/nls/*_da.qm +%lang(de) %{_datadir}/%{pname}/nls/*_de.qm +%lang(en) %{_datadir}/%{pname}/nls/*_en.qm +%lang(es) %{_datadir}/%{pname}/nls/*_es.qm +%lang(eu) %{_datadir}/%{pname}/nls/*_eu.qm +%lang(fi) %{_datadir}/%{pname}/nls/*_fa_IR.qm +%lang(fi) %{_datadir}/%{pname}/nls/*_fi.qm +%lang(fr) %{_datadir}/%{pname}/nls/*_fr.qm +%lang(gl_ES) %{_datadir}/%{pname}/nls/*_gl_ES.qm +%lang(hu) %{_datadir}/%{pname}/nls/*_hu.qm +%lang(id) %{_datadir}/%{pname}/nls/*_id.qm +%lang(it) %{_datadir}/%{pname}/nls/*_it.qm +%lang(ja) %{_datadir}/%{pname}/nls/*_ja.qm +%lang(km_KH) %{_datadir}/%{pname}/nls/*_km_KH.qm +%lang(ko) %{_datadir}/%{pname}/nls/*_ko.qm +%lang(lt) %{_datadir}/%{pname}/nls/*_lt.qm +%lang(nl) %{_datadir}/%{pname}/nls/*_nl.qm +%lang(pl) %{_datadir}/%{pname}/nls/*_pl.qm +%lang(pt) %{_datadir}/%{pname}/nls/*_pt.qm +%lang(pt_BR) %{_datadir}/%{pname}/nls/*_pt_BR.qm +%lang(ro) %{_datadir}/%{pname}/nls/*_ro.qm +%lang(ru) %{_datadir}/%{pname}/nls/*_ru.qm +%lang(sk) %{_datadir}/%{pname}/nls/*_sk.qm +%lang(sr) %{_datadir}/%{pname}/nls/*_sr.qm +%lang(sv) %{_datadir}/%{pname}/nls/*_sv.qm +%lang(tr) %{_datadir}/%{pname}/nls/*_tr.qm +%lang(uk) %{_datadir}/%{pname}/nls/*_uk.qm +%lang(zh_CN) %{_datadir}/%{pname}/nls/*_zh_CN.qm +%lang(zh_TW) %{_datadir}/%{pname}/nls/*_zh_TW.qm +%{_desktopdir}/virtualbox.desktop +%{_pixmapsdir}/virtualbox.png +%{_iconsdir}/hicolor/*/apps/virtualbox.png +%{_iconsdir}/hicolor/*/apps/virtualbox.svg +%{_iconsdir}/hicolor/*/mimetypes/virtualbox-*.png +%{_datadir}/mime/packages/virtualbox.xml + %files additions %defattr(644,root,root,755) -%{_libdir}/%{pname}/additions/VBoxGuestAdditions.iso +%{_datadir}/%{pname}/VBoxGuestAdditions.iso %files guest %defattr(644,root,root,755) %attr(755,root,root) /sbin/mount.vboxsf %attr(754,root,root) /etc/rc.d/init.d/vboxservice +%{systemdunitdir}/vboxservice.service %attr(755,root,root) %{_bindir}/VBoxControl %attr(755,root,root) %{_bindir}/VBoxService %files guest-x11 %defattr(644,root,root,755) -# NOTE: unfinished, should contain .desktop files for starting up mouse -# integration and other desktop services -# NOTE: the filelist is incomplete too -%attr(755,root,root) %{_bindir}/VBoxClient -/etc/X11/xinit/xinitrc.d/98vboxadd-xclient.sh /etc/xdg/autostart/vboxclient.desktop +%attr(755,root,root) %{_bindir}/VBoxClient +%attr(755,root,root) %{_bindir}/VBoxClient-all -%attr(755,root,root) %{_libdir}/%{pname}/additions/autorun.sh +%if 0 %attr(755,root,root) %{_libdir}/%{pname}/additions/vboxadd %attr(755,root,root) %{_libdir}/%{pname}/additions/vboxadd-service %attr(755,root,root) %{_libdir}/%{pname}/additions/vboxadd-x11 +%endif %if %{with webservice} %files webservice %defattr(644,root,root,755) +%attr(755,root,root) %{_bindir}/vboxwebsrv %attr(755,root,root) %{_libdir}/%{pname}/vboxwebsrv %attr(755,root,root) %{_libdir}/%{pname}/webtest %endif @@ -1106,58 +1031,14 @@ fi %attr(755,root,root) %{_libdir}/VBoxOGLfeedbackspu.so %attr(755,root,root) %{_libdir}/VBoxOGLpackspu.so %attr(755,root,root) %{_libdir}/VBoxOGLpassthroughspu.so -%endif - -%if %{with kernel} -%files kernel-init-host -%defattr(644,root,root,755) -%attr(754,root,root) /etc/rc.d/init.d/vboxdrv -%attr(754,root,root) /etc/rc.d/init.d/vboxnetadp -%attr(754,root,root) /etc/rc.d/init.d/vboxnetflt -%attr(754,root,root) /etc/rc.d/init.d/vboxpci -%{systemdunitdir}/vboxdrv.service -%{systemdunitdir}/vboxnetadp.service -%{systemdunitdir}/vboxnetflt.service -%{systemdunitdir}/vboxpci.service - -%files kernel-init-guest -%defattr(644,root,root,755) -%attr(754,root,root) /etc/rc.d/init.d/vboxguest -%attr(754,root,root) /etc/rc.d/init.d/vboxsf -%{systemdunitdir}/vboxguest.service -%{systemdunitdir}/vboxsf.service - -%files -n kernel%{_alt_kernel}-misc-vboxguest -%defattr(644,root,root,755) -%config(noreplace) %verify(not md5 mtime size) /etc/modules-load.d/vboxguest.conf -/lib/modules/%{_kernel_ver}/misc/vboxguest.ko* -%files -n kernel%{_alt_kernel}-misc-vboxdrv +%if %{with dkms} +%files -n dkms-vboxguest %defattr(644,root,root,755) -%config(noreplace) %verify(not md5 mtime size) /etc/modules-load.d/vboxdrv.conf -/lib/modules/%{_kernel_ver}/misc/vboxdrv.ko* +%{_usrsrc}/vboxguest-%{version}-%{rel} -%files -n kernel%{_alt_kernel}-misc-vboxnetadp +%files -n dkms-vboxhost %defattr(644,root,root,755) -%config(noreplace) %verify(not md5 mtime size) /etc/modules-load.d/vboxnetadp.conf -/lib/modules/%{_kernel_ver}/misc/vboxnetadp.ko* - -%files -n kernel%{_alt_kernel}-misc-vboxnetflt -%defattr(644,root,root,755) -%config(noreplace) %verify(not md5 mtime size) /etc/modules-load.d/vboxnetflt.conf -/lib/modules/%{_kernel_ver}/misc/vboxnetflt.ko* - -%files -n kernel%{_alt_kernel}-misc-vboxpci -%defattr(644,root,root,755) -%config(noreplace) %verify(not md5 mtime size) /etc/modules-load.d/vboxpci.conf -/lib/modules/%{_kernel_ver}/misc/vboxpci.ko* - -%files -n kernel%{_alt_kernel}-misc-vboxsf -%defattr(644,root,root,755) -%config(noreplace) %verify(not md5 mtime size) /etc/modules-load.d/vboxsf.conf -/lib/modules/%{_kernel_ver}/misc/vboxsf.ko* - -%files -n kernel%{_alt_kernel}-video-vboxvideo -%defattr(644,root,root,755) -/lib/modules/%{_kernel_ver}/misc/vboxvideo.ko* +%{_usrsrc}/vboxhost-%{version}-%{rel} +%endif %endif