Accepting request 382287 from home:lwfinger:branches:Virtualization
Fix problems with VB 5.0.17 OBS-URL: https://build.opensuse.org/request/show/382287 OBS-URL: https://build.opensuse.org/package/show/Virtualization/virtualbox?expand=0&rev=246
This commit is contained in:
parent
7d2e3597f7
commit
fb04d2a68e
@ -1,3 +0,0 @@
|
||||
version https://git-lfs.github.com/spec/v1
|
||||
oid sha256:c4af95a125b2ce3f80915c9cc5df88b0a9899ae5a5985a71ea26aee94e4fd4bb
|
||||
size 76698645
|
3
VirtualBox-5.0.17-patched.tar.bz2
Normal file
3
VirtualBox-5.0.17-patched.tar.bz2
Normal file
@ -0,0 +1,3 @@
|
||||
version https://git-lfs.github.com/spec/v1
|
||||
oid sha256:fe6c170f395ae3caa10e1f06ffb5999e3258bbf37723ce7fa0c7ed7ac5e76cce
|
||||
size 77502602
|
267
VirtualBox-5.0.17-r106108-r106140.patch
Normal file
267
VirtualBox-5.0.17-r106108-r106140.patch
Normal file
@ -0,0 +1,267 @@
|
||||
Index: src/VBox/Additions/linux/drm/vbox_drv.h
|
||||
===================================================================
|
||||
--- src/VBox/Additions/linux/drm/vbox_drv.h (revision 106108)
|
||||
+++ src/VBox/Additions/linux/drm/vbox_drv.h (revision 106140)
|
||||
@@ -118,6 +118,9 @@
|
||||
|
||||
struct mutex hw_mutex;
|
||||
bool isr_installed;
|
||||
+ /** Have we finished fbdev initialisation? We limit reported display
|
||||
+ * modes to 800x600 until this point to get a sensible console size. */
|
||||
+ bool fbdev_init;
|
||||
struct work_struct hotplug_work;
|
||||
};
|
||||
|
||||
Index: src/VBox/Additions/linux/drm/vbox_mode.c
|
||||
===================================================================
|
||||
--- src/VBox/Additions/linux/drm/vbox_mode.c (revision 106108)
|
||||
+++ src/VBox/Additions/linux/drm/vbox_mode.c (revision 106140)
|
||||
@@ -426,11 +426,15 @@
|
||||
{
|
||||
struct vbox_connector *vbox_connector = NULL;
|
||||
struct drm_display_mode *mode = NULL;
|
||||
+ struct vbox_private *vbox = NULL;
|
||||
unsigned num_modes = 0;
|
||||
int preferred_width, preferred_height;
|
||||
|
||||
LogFunc(("vboxvideo: %d: connector=%p\n", __LINE__, connector));
|
||||
vbox_connector = to_vbox_connector(connector);
|
||||
+ vbox = connector->dev->dev_private;
|
||||
+ if (!vbox->fbdev_init)
|
||||
+ return drm_add_modes_noedid(connector, 800, 600);
|
||||
num_modes = drm_add_modes_noedid(connector, 2560, 1600);
|
||||
preferred_width = vbox_connector->mode_hint.width ? vbox_connector->mode_hint.width : 1024;
|
||||
preferred_height = vbox_connector->mode_hint.height ? vbox_connector->mode_hint.height : 768;
|
||||
@@ -691,5 +695,8 @@
|
||||
static int vbox_cursor_move(struct drm_crtc *crtc,
|
||||
int x, int y)
|
||||
{
|
||||
+ struct vbox_private *vbox = crtc->dev->dev_private;
|
||||
+
|
||||
+ VBoxHGSMICursorPosition(&vbox->submit_info, true, x, y, NULL, NULL);
|
||||
return 0;
|
||||
}
|
||||
Index: src/VBox/Additions/linux/drm/vbox_fb.c
|
||||
===================================================================
|
||||
--- src/VBox/Additions/linux/drm/vbox_fb.c (revision 106108)
|
||||
+++ src/VBox/Additions/linux/drm/vbox_fb.c (revision 106140)
|
||||
@@ -438,6 +438,7 @@
|
||||
ret = drm_fb_helper_initial_config(&fbdev->helper, 32);
|
||||
if (ret)
|
||||
goto fini;
|
||||
+ vbox->fbdev_init = true;
|
||||
|
||||
LogFunc(("vboxvideo: %d\n", __LINE__));
|
||||
return 0;
|
||||
Index: src/VBox/Additions/linux/drm/vbox_drv.c
|
||||
===================================================================
|
||||
--- src/VBox/Additions/linux/drm/vbox_drv.c (revision 106108)
|
||||
+++ src/VBox/Additions/linux/drm/vbox_drv.c (revision 106140)
|
||||
@@ -257,7 +257,7 @@
|
||||
/* Do not load if any of the virtual consoles is in graphics mode to be
|
||||
* sure that we do not pick a fight with a user-mode driver or VESA. */
|
||||
for (i = 0; i < MAX_NR_CONSOLES - 1; ++i)
|
||||
- if (vc_cons[i].d->vc_mode == KD_GRAPHICS)
|
||||
+ if (vc_cons[i].d && vc_cons[i].d->vc_mode == KD_GRAPHICS)
|
||||
return -EINVAL;
|
||||
|
||||
return drm_pci_init(&driver, &vbox_pci_driver);
|
||||
Index: src/VBox/Additions/linux/installer/vboxadd-x11.sh
|
||||
===================================================================
|
||||
--- src/VBox/Additions/linux/installer/vboxadd-x11.sh (revision 106108)
|
||||
+++ src/VBox/Additions/linux/installer/vboxadd-x11.sh (revision 106140)
|
||||
@@ -424,7 +424,7 @@
|
||||
}
|
||||
# Do not install if we can use the kernel driver.
|
||||
case `uname -r` in
|
||||
- 1.* | 2.* | 3.[0-9].* | 3.11 ) ;;
|
||||
+ 1.* | 2.* | 3.[0-9].* | 3.10.* ) ;;
|
||||
* ) vboxvideo_src="" ;;
|
||||
esac
|
||||
;;
|
||||
Index: src/VBox/Additions/common/crOpenGL/egl.c
|
||||
===================================================================
|
||||
--- src/VBox/Additions/common/crOpenGL/egl.c (revision 106108)
|
||||
+++ src/VBox/Additions/common/crOpenGL/egl.c (revision 106140)
|
||||
@@ -910,6 +910,13 @@
|
||||
return setEGLError(EGL_BAD_MATCH);
|
||||
}
|
||||
|
||||
+DECLEXPORT(EGLBoolean) eglSwapInterval (EGLDisplay dpy, EGLint interval)
|
||||
+{
|
||||
+ NOREF(dpy);
|
||||
+ NOREF(interval);
|
||||
+ return EGL_TRUE;
|
||||
+}
|
||||
+
|
||||
typedef void (*VBEGLFuncPtr)(void);
|
||||
DECLEXPORT(VBEGLFuncPtr)eglGetProcAddress(const char *pszName)
|
||||
{
|
||||
Index: src/VBox/Additions/x11/vboxvideo/vboxvideo.c
|
||||
===================================================================
|
||||
--- src/VBox/Additions/x11/vboxvideo/vboxvideo.c (revision 106108)
|
||||
+++ src/VBox/Additions/x11/vboxvideo/vboxvideo.c (revision 106140)
|
||||
@@ -1010,102 +1010,8 @@
|
||||
}
|
||||
#endif
|
||||
|
||||
-#ifdef VBOXVIDEO_13
|
||||
+#ifndef VBOXVIDEO_13
|
||||
|
||||
-static void setVirtualSizeRandR12(ScrnInfoPtr pScrn, bool fScreenInitTime)
|
||||
-{
|
||||
- VBOXPtr pVBox = VBOXGetRec(pScrn);
|
||||
- unsigned i;
|
||||
- unsigned cx = 0;
|
||||
- unsigned cy = 0;
|
||||
-
|
||||
- for (i = 0; i < pVBox->cScreens; ++i)
|
||||
- {
|
||||
- if ( pVBox->fHaveHGSMIModeHints && pVBox->pScreens[i].afHaveLocation)
|
||||
- {
|
||||
- pVBox->pScreens[i].paCrtcs->x = pVBox->pScreens[i].aPreferredLocation.x;
|
||||
- pVBox->pScreens[i].paCrtcs->y = pVBox->pScreens[i].aPreferredLocation.y;
|
||||
- }
|
||||
- if ( pVBox->pScreens[i].paOutputs->status == XF86OutputStatusConnected
|
||||
- && pVBox->pScreens[i].paCrtcs->x + pVBox->pScreens[i].aPreferredSize.cx < VBOX_VIDEO_MAX_VIRTUAL
|
||||
- && pVBox->pScreens[i].paCrtcs->y + pVBox->pScreens[i].aPreferredSize.cy < VBOX_VIDEO_MAX_VIRTUAL)
|
||||
- {
|
||||
- cx = max(cx, pVBox->pScreens[i].paCrtcs->x + pVBox->pScreens[i].aPreferredSize.cx);
|
||||
- cy = max(cy, pVBox->pScreens[i].paCrtcs->y + pVBox->pScreens[i].aPreferredSize.cy);
|
||||
- }
|
||||
- }
|
||||
- if (cx != 0 && cy != 0)
|
||||
- {
|
||||
- /* Do not set the virtual resolution in limited context as that can
|
||||
- * cause problems setting up RandR 1.2 which needs it set to the
|
||||
- * maximum size at this point. */
|
||||
- if (!fScreenInitTime)
|
||||
- {
|
||||
- TRACE_LOG("cx=%u, cy=%u\n", cx, cy);
|
||||
- xf86ScrnToScreen(pScrn)->width = cx;
|
||||
- xf86ScrnToScreen(pScrn)->height = cy;
|
||||
- xf86ScrnToScreen(pScrn)->mmWidth = cx * 254 / 960;
|
||||
- xf86ScrnToScreen(pScrn)->mmHeight = cy * 254 / 960;
|
||||
- adjustScreenPixmap(pScrn, cx, cy);
|
||||
- vbvxSetSolarisMouseRange(cx, cy);
|
||||
- }
|
||||
- }
|
||||
-}
|
||||
-
|
||||
-static void setScreenSizesRandR12(ScrnInfoPtr pScrn, bool fScreenInitTime)
|
||||
-{
|
||||
- VBOXPtr pVBox = VBOXGetRec(pScrn);
|
||||
- unsigned i;
|
||||
-
|
||||
- for (i = 0; i < pVBox->cScreens; ++i)
|
||||
- {
|
||||
- if (!pVBox->pScreens[i].afConnected)
|
||||
- continue;
|
||||
- /* The Crtc can get "unset" if the screen was disconnected previously.
|
||||
- * I couldn't find an API to re-set it which did not have side-effects.
|
||||
- */
|
||||
- pVBox->pScreens[i].paOutputs->crtc = pVBox->pScreens[i].paCrtcs;
|
||||
- xf86CrtcSetMode(pVBox->pScreens[i].paCrtcs, pVBox->pScreens[i].paOutputs->probed_modes, RR_Rotate_0,
|
||||
- pVBox->pScreens[i].paCrtcs->x, pVBox->pScreens[i].paCrtcs->y);
|
||||
- if (!fScreenInitTime)
|
||||
- RRCrtcNotify(pVBox->pScreens[i].paCrtcs->randr_crtc, pVBox->pScreens[i].paOutputs->randr_output->modes[0],
|
||||
- pVBox->pScreens[i].paCrtcs->x, pVBox->pScreens[i].paCrtcs->y, RR_Rotate_0,
|
||||
-#if GET_ABI_MAJOR(ABI_VIDEODRV_VERSION) >= 5
|
||||
- NULL,
|
||||
-#endif
|
||||
- 1, &pVBox->pScreens[i].paOutputs->randr_output);
|
||||
- }
|
||||
-}
|
||||
-
|
||||
-static void setSizesRandR12(ScrnInfoPtr pScrn, bool fScreenInitTime)
|
||||
-{
|
||||
- VBOXPtr pVBox = VBOXGetRec(pScrn);
|
||||
-
|
||||
- if (!fScreenInitTime)
|
||||
- {
|
||||
-# if GET_ABI_MAJOR(ABI_VIDEODRV_VERSION) >= 5
|
||||
- RRGetInfo(xf86ScrnToScreen(pScrn), TRUE);
|
||||
-# else
|
||||
- RRGetInfo(xf86ScrnToScreen(pScrn));
|
||||
-# endif
|
||||
- }
|
||||
- setVirtualSizeRandR12(pScrn, fScreenInitTime);
|
||||
- setScreenSizesRandR12(pScrn, fScreenInitTime);
|
||||
- if (!fScreenInitTime)
|
||||
- {
|
||||
- /* We use RRScreenSizeSet() here and not RRScreenSizeNotify() because
|
||||
- * the first also pushes the virtual screen size to the input driver.
|
||||
- * We were doing this manually by setting screenInfo.width and height
|
||||
- * and calling xf86UpdateDesktopDimensions() where appropriate, but this
|
||||
- * failed on Ubuntu 12.04.0 due to a problematic X server back-port. */
|
||||
- RRScreenSizeSet(xf86ScrnToScreen(pScrn), xf86ScrnToScreen(pScrn)->width, xf86ScrnToScreen(pScrn)->height,
|
||||
- xf86ScrnToScreen(pScrn)->mmWidth, xf86ScrnToScreen(pScrn)->mmHeight);
|
||||
- RRTellChanged(xf86ScrnToScreen(pScrn));
|
||||
- }
|
||||
-}
|
||||
-
|
||||
-#else
|
||||
-
|
||||
#define PREFERRED_MODE_ATOM_NAME "VBOXVIDEO_PREFERRED_MODE"
|
||||
|
||||
static void setSizesRandR11(ScrnInfoPtr pScrn)
|
||||
@@ -1131,7 +1037,11 @@
|
||||
|
||||
TRACE_LOG("fScreenInitTime=%d\n", (int)fScreenInitTime);
|
||||
#ifdef VBOXVIDEO_13
|
||||
- setSizesRandR12(pScrn, fScreenInitTime);
|
||||
+# if GET_ABI_MAJOR(ABI_VIDEODRV_VERSION) >= 5
|
||||
+ RRGetInfo(xf86ScrnToScreen(pScrn), TRUE);
|
||||
+# else
|
||||
+ RRGetInfo(xf86ScrnToScreen(pScrn));
|
||||
+# endif
|
||||
#else
|
||||
setSizesRandR11(pScrn);
|
||||
#endif
|
||||
@@ -1246,8 +1156,6 @@
|
||||
if (ShadowFBInit2(pScreen, NULL, vbvxHandleDirtyRect) != TRUE)
|
||||
return FALSE;
|
||||
VBoxInitialiseSizeHints(pScrn);
|
||||
- /* Get any screen size hints from HGSMI. */
|
||||
- vbvxReadSizesAndCursorIntegrationFromHGSMI(pScrn, NULL);
|
||||
|
||||
#ifdef VBOXVIDEO_13
|
||||
/* Initialise CRTC and output configuration for use with randr1.2. */
|
||||
@@ -1304,7 +1212,9 @@
|
||||
}
|
||||
|
||||
/* set first video mode */
|
||||
- setSizesAndCursorIntegration(pScrn, true);
|
||||
+ if (!xf86SetDesiredModes(pScrn)) {
|
||||
+ return FALSE;
|
||||
+ }
|
||||
#else
|
||||
/* set first video mode */
|
||||
setModeRandR11(pScrn, pScrn->currentMode, true, false, 0, 0);
|
||||
@@ -1368,8 +1278,9 @@
|
||||
vboxEnableVbva(pScrn);
|
||||
/* Re-set video mode */
|
||||
#ifdef VBOXVIDEO_13
|
||||
- vbvxReadSizesAndCursorIntegrationFromHGSMI(pScrn, NULL);
|
||||
- setSizesAndCursorIntegration(pScrn, false);
|
||||
+ if (!xf86SetDesiredModes(pScrn)) {
|
||||
+ return FALSE;
|
||||
+ }
|
||||
#else
|
||||
updateGraphicsCapability(pScrn, TRUE);
|
||||
setModeRandR11(pScrn, pScrn->currentMode, false, true, cXOverRide, cYOverRide);
|
||||
Index: src/VBox/Frontends/VirtualBox/src/platform/darwin/UICocoaApplication.mm
|
||||
===================================================================
|
||||
--- src/VBox/Frontends/VirtualBox/src/platform/darwin/UICocoaApplication.mm (revision 106108)
|
||||
+++ src/VBox/Frontends/VirtualBox/src/platform/darwin/UICocoaApplication.mm (revision 106140)
|
||||
@@ -88,6 +88,10 @@
|
||||
if (self)
|
||||
m_pCallbacks = [[NSMutableArray alloc] init];
|
||||
|
||||
+ /* Gently disable El Capitan tries to break everything with the Enter Full Screen action.
|
||||
+ * S.a. https://developer.apple.com/library/mac/releasenotes/AppKit/RN-AppKit/ for reference. */
|
||||
+ [[NSUserDefaults standardUserDefaults] setBool:NO forKey:@"NSFullScreenMenuItemEverywhere"];
|
||||
+
|
||||
return self;
|
||||
}
|
||||
|
@ -1,6 +1,6 @@
|
||||
%defattr (-,root,root)
|
||||
%dir /lib/modules/%2-%1/
|
||||
%dir /lib/modules/%2-%1/updates
|
||||
/lib/modules/%2-%1/updates/vboxsf.ko
|
||||
/lib/modules/%2-%1/updates/vboxvideo.ko
|
||||
/lib/modules/%2-%1/updates/vboxguest.ko
|
||||
%dir /lib/modules/%2-%1/misc
|
||||
/lib/modules/%2-%1/misc/vboxsf.ko
|
||||
/lib/modules/%2-%1/misc/vboxvideo.ko
|
||||
/lib/modules/%2-%1/misc/vboxguest.ko
|
||||
|
@ -1,7 +1,7 @@
|
||||
%defattr (-,root,root)
|
||||
%dir /lib/modules/%2-%1/
|
||||
%dir /lib/modules/%2-%1/updates
|
||||
/lib/modules/%2-%1/updates/vboxdrv.ko
|
||||
/lib/modules/%2-%1/updates/vboxnetadp.ko
|
||||
/lib/modules/%2-%1/updates/vboxnetflt.ko
|
||||
/lib/modules/%2-%1/updates/vboxpci.ko
|
||||
%dir /lib/modules/%2-%1/misc
|
||||
/lib/modules/%2-%1/misc/vboxdrv.ko
|
||||
/lib/modules/%2-%1/misc/vboxnetadp.ko
|
||||
/lib/modules/%2-%1/misc/vboxnetflt.ko
|
||||
/lib/modules/%2-%1/misc/vboxpci.ko
|
||||
|
@ -1,3 +1,27 @@
|
||||
-------------------------------------------------------------------
|
||||
Wed Mar 30 21:06:08 UTC 2016 - Larry.Finger@lwfinger.net
|
||||
|
||||
- Modify Guest Additions so that openSUSE build works with new Oracle code. The following changes have been made:
|
||||
|
||||
Added Oracle patch to bring code to r106140 commit.
|
||||
Moved VB guest modules to /lib/modules/.../misc/. This layout matches that of the Oracle Guest Additions ISO.
|
||||
Added missing copy of Module.symvers from vboxguest build so that loads of vboxvideo can resolve all symbols.
|
||||
Remove patch added in previous cycle to build under kernel 4.5.0. The Oracle code now has this fix.
|
||||
|
||||
With these changes, both Gnome and KDE desktops as VB virtual machines work with gdm and the versions of X.Org that do not run as root.
|
||||
The only known defect is that the mouse pointer is missing when 3D acceleration is turned on in the VB control panel.
|
||||
|
||||
-------------------------------------------------------------------
|
||||
Mon Mar 7 22:20:56 UTC 2016 - Larry.Finger@lwfinger.net
|
||||
|
||||
- Version bump to 5.0.17 (released 2016-03-07 by Oracle)
|
||||
|
||||
Following the 5.0.16 release, the Guest Additions were updated to support Linux guests
|
||||
with X.Org Server running without root privileges and to fix certain 3D acceleration-related issues.
|
||||
There are no other changes to VirtualBox.
|
||||
|
||||
A patch "vbox-guest-add.diff" is needed to enable the Oracle code to build with kernel 4.5.
|
||||
|
||||
-------------------------------------------------------------------
|
||||
Sat Mar 5 18:19:56 UTC 2016 - Larry.Finger@lwfinger.net
|
||||
|
||||
|
@ -19,7 +19,7 @@
|
||||
%define _vbox_instdir %{_libexecdir}/virtualbox
|
||||
%define _udevrulesdir %{_libexecdir}/udev/rules.d
|
||||
Name: virtualbox
|
||||
Version: 5.0.16
|
||||
Version: 5.0.17
|
||||
Release: 0
|
||||
Summary: VirtualBox is an Emulator
|
||||
License: GPL-2.0+
|
||||
@ -83,6 +83,8 @@ Patch107: virtualbox-sed-params.patch
|
||||
Patch108: virtualbox-snpritnf-buffer-overflow.patch
|
||||
# Patch to add code to explain USB Passthru
|
||||
Patch109: vbox-usb-warning.diff
|
||||
# Upgrade sources from r106108 to r106140
|
||||
Patch110: VirtualBox-5.0.17-r106108-r106140.patch
|
||||
#
|
||||
BuildRequires: LibVNCServer-devel
|
||||
BuildRequires: SDL-devel
|
||||
@ -313,6 +315,7 @@ This package contains icons for guest desktop files that were created on the des
|
||||
%patch107 -p1
|
||||
%patch108 -p1
|
||||
%patch109 -p1
|
||||
%patch110 -p0
|
||||
#copy user manual
|
||||
cp %{SOURCE1} UserManual.pdf
|
||||
#copy kbuild config
|
||||
@ -405,6 +408,11 @@ for vbox_module in out/linux.*/release/bin/src/vbox{drv,netflt,netadp,pci} \
|
||||
cp $PWD/modules_build_dir/$flavor/vboxguest/Module.symvers \
|
||||
$PWD/modules_build_dir/$flavor/$module_name
|
||||
fi
|
||||
# copy vboxguest (for guest) module symbols which are used by vboxvideo km:
|
||||
if [ "$module_name" = "vboxvideo" ]; then
|
||||
cp $PWD/modules_build_dir/$flavor/vboxguest/Module.symvers \
|
||||
$PWD/modules_build_dir/$flavor/$module_name
|
||||
fi
|
||||
# build the module for the specific flavor
|
||||
make %{?_smp_mflags} -C %{_prefix}/src/linux-obj/%{_target_cpu}/$flavor modules \
|
||||
M=$PWD/modules_build_dir/$flavor/$module_name
|
||||
@ -436,7 +444,7 @@ install -d -m 755 %{buildroot}%{_sysconfdir}/X11/xinit/xinitrc.d
|
||||
echo "entering virtualbox-kmp-guest and virtualbox-kmp-host install section"
|
||||
####################################################################################
|
||||
export INSTALL_MOD_PATH=%{buildroot}
|
||||
export INSTALL_MOD_DIR=updates
|
||||
export INSTALL_MOD_DIR=misc
|
||||
#to install modules we use here similar steps like in build phase, go trought the all modules :
|
||||
for module_name in vbox{drv,netflt,pci,netadp,guest,sf,video}
|
||||
do
|
||||
|
Loading…
Reference in New Issue
Block a user