Accepting request 789598 from home:lwfinger:branches:Virtualization

- Fix build errors for gcc-10 (boo#1167897). File "fixes_for_gcc10.patch" is
  added.
- Convert /usr/bin/VirtualBox to use "~/.config/VirtualBox" instead "~/.vbox".
  This change was requested in boo#1167660.

OBS-URL: https://build.opensuse.org/request/show/789598
OBS-URL: https://build.opensuse.org/package/show/Virtualization/virtualbox?expand=0&rev=543
This commit is contained in:
Larry Finger 2020-03-30 04:53:46 +00:00 committed by Git OBS Bridge
parent 243616fc78
commit d8ce0b3983
7 changed files with 92 additions and 25 deletions

View File

@ -63,3 +63,4 @@ Index: VirtualBox-6.1.4/src/VBox/Additions/x11/VBoxClient/clipboard.cpp
#ifdef VBOX_WITH_SHARED_CLIPBOARD_FUSE #ifdef VBOX_WITH_SHARED_CLIPBOARD_FUSE
int rc2 = vboxClipboardFUSEStop(); int rc2 = vboxClipboardFUSEStop();

45
fixes_for_gcc10.patch Normal file
View File

@ -0,0 +1,45 @@
Index: VirtualBox-6.1.4/Config.kmk
===================================================================
--- VirtualBox-6.1.4.orig/Config.kmk
+++ VirtualBox-6.1.4/Config.kmk
@@ -2684,8 +2684,16 @@ else
# The reason for this hack is that the windows kmk_ash cannot deal with $((1+1)).
# Some versions of gcc (e.g. openSUSE11) return only major.minor on `gcc -dumpversion`.
# gcc-5 of openSUSE42.1 only returns the major version on `gcc -dumpversion`!
- VBOX_GCC_VERSION = $(shell ($(1) -dumpfullversion 2>/dev/null || $(1) -dumpversion) | \
- $(SED_EXT) 's|\([0-9]\)\.\{0,1\}\([0-9]\{0,1\}\)\.\{0,1\}\([0-9]\{0,1\}\).*|$$(int-add $$(int-mul 10000, \1), $$(int-mul 100, $$(firstword \2 0)), $$(firstword \3 0))|' )
+ #
+ # Check to make sure that the compiler has either -dumpfullversion or -dumpversion. gcc-10 has neither
+ RC = $(shell ($(1) -dumpfullversion 2>/dev/null || $(1) -dumpversion 2>/dev/null) ; echo $$?)
+ ifneq ($(RC),0)
+ # dump version commands not available - hardcode 10.0.1 for the moment
+ VBOX_GCC_VERSION = 100001
+ else
+ VBOX_GCC_VERSION = $(shell ($(1) -dumpfullversion 2>/dev/null || $(1) -dumpversion 2>/dev/null) | \
+ $(SED_EXT) 's|\([0-9]\)\.\{0,1\}\([0-9]\{0,1\}\)\.\{0,1\}\([0-9]\{0,1\}\).*|$$(int-add $$(int-mul 10000, \1), $$(int-mul 100, $$(firstword \2 0)), $$(firstword \3 0))|' )
+ endif
endif
# YASM macros
ifndef DONT_USE_YASM
Index: VirtualBox-6.1.4/include/iprt/formats/mach-o.h
===================================================================
--- VirtualBox-6.1.4.orig/include/iprt/formats/mach-o.h
+++ VirtualBox-6.1.4/include/iprt/formats/mach-o.h
@@ -38,7 +38,7 @@
/* cputype */
#define CPU_ARCH_MASK INT32_C(0xff000000)
#define CPU_ARCH_ABI64 INT32_C(0x01000000)
-#define CPU_TYPE_ANY INT32_C(-1)
+#define CPU_TYPE_ANY INT32_C(999)
#define CPU_TYPE_VAX INT32_C(1)
#define CPU_TYPE_MC680x0 INT32_C(6)
#define CPU_TYPE_X86 INT32_C(7)
@@ -53,7 +53,7 @@
#define CPU_TYPE_POWERPC64 (CPU_TYPE_POWERPC | CPU_ARCH_ABI64)
/* cpusubtype */
-#define CPU_SUBTYPE_MULTIPLE INT32_C(-1)
+#define CPU_SUBTYPE_MULTIPLE -1
#define CPU_SUBTYPE_LITTLE_ENDIAN INT32_C(0)
#define CPU_SUBTYPE_BIG_ENDIAN INT32_C(1)

View File

@ -1,8 +1,16 @@
Index: VirtualBox-5.1.4/Config.kmk Index: VirtualBox-6.1.4/Config.kmk
=================================================================== ===================================================================
--- VirtualBox-5.1.4.orig/Config.kmk --- VirtualBox-6.1.4.orig/Config.kmk
+++ VirtualBox-5.1.4/Config.kmk +++ VirtualBox-6.1.4/Config.kmk
@@ -4852,6 +4852,9 @@ TEMPLATE_VBOXR3HARDENEDEXE_LDFLAGS.darwi @@ -2687,7 +2687,6 @@ else
VBOX_GCC_VERSION = $(shell ($(1) -dumpfullversion 2>/dev/null || $(1) -dumpversion) | \
$(SED_EXT) 's|\([0-9]\)\.\{0,1\}\([0-9]\{0,1\}\)\.\{0,1\}\([0-9]\{0,1\}\).*|$$(int-add $$(int-mul 10000, \1), $$(int-mul 100, $$(firstword \2 0)), $$(firstword \3 0))|' )
endif
-
# YASM macros
ifndef DONT_USE_YASM
include $(KBUILD_PATH)/tools/YASM.kmk
@@ -5533,6 +5532,9 @@ TEMPLATE_VBOXR3HARDENEDEXE_LDFLAGS.darwi
ifeq ($(KBUILD_TARGET),linux) ifeq ($(KBUILD_TARGET),linux)
# not necessary except USE_LIB_PCAP is defined in SUPR3HardenedMain.cpp # not necessary except USE_LIB_PCAP is defined in SUPR3HardenedMain.cpp
# TEMPLATE_VBOXR3HARDENEDEXE_LIBS += cap # TEMPLATE_VBOXR3HARDENEDEXE_LIBS += cap
@ -12,7 +20,7 @@ Index: VirtualBox-5.1.4/Config.kmk
endif endif
ifeq ($(KBUILD_TARGET),win) # No CRT! ifeq ($(KBUILD_TARGET),win) # No CRT!
TEMPLATE_VBOXR3HARDENEDEXE_SDKS = VBOX_NTDLL $(TEMPLATE_VBOXR3EXE_SDKS) TEMPLATE_VBOXR3HARDENEDEXE_SDKS = VBOX_NTDLL $(TEMPLATE_VBOXR3EXE_SDKS)
@@ -4871,8 +4874,8 @@ ifeq ($(KBUILD_TARGET),win) # No CRT! @@ -5554,8 +5556,8 @@ ifeq ($(KBUILD_TARGET),win) # No CRT!
TEMPLATE_VBOXR3HARDENEDEXE_LIBS.amd64 = $(NOT_SUCH_VARIABLE) TEMPLATE_VBOXR3HARDENEDEXE_LIBS.amd64 = $(NOT_SUCH_VARIABLE)
else ifn1of ($(KBUILD_TARGET), os2 solaris) else ifn1of ($(KBUILD_TARGET), os2 solaris)
# We want to keep the RPATH on Solaris to be able to find libgcc_1/libstdc++ within $(VBOX_WITH_RUNPATH) # We want to keep the RPATH on Solaris to be able to find libgcc_1/libstdc++ within $(VBOX_WITH_RUNPATH)

View File

@ -64,10 +64,10 @@ Index: VirtualBox-5.1.22/src/apps/VBoxUSB_DevRules/VBoxUSB_DevRules.cpp
+ "As a result, it opens a security hole.\n\n" + "As a result, it opens a security hole.\n\n"
+ "Nonetheless, this feature is extremely useful and it may be worth the security risk. " + "Nonetheless, this feature is extremely useful and it may be worth the security risk. "
+ "Thus the code defaults to enabling it.\n\nIf you agree that the risk is acceptable, then click 'Enable'.\n" + "Thus the code defaults to enabling it.\n\nIf you agree that the risk is acceptable, then click 'Enable'.\n"
+ "You will not be asked this question again when VB is updated. If you later change your mind, run 'rm ~/.vbox/*'\n\n" + "You should not be asked this question again when VB is updated. If you later change your mind, run 'rm ~/.config/virtualbox/*'\n\n"
+ "If you wish to disable USB passthrough to plug the security hole, then click 'Disable'. " + "If you wish to disable USB passthrough to plug the security hole, then click 'Disable'. "
+ "You will be asked for the system password, and /etc/udev/rules.d/60-vboxdrv.rules will be changed.\n\n" + "You will be asked for the system password, and /etc/udev/rules.d/60-vboxdrv.rules will be changed.\n\n"
+ "These changes cannot be preserved through VB updates, thus this screen will be displayed again at that time.")); + "These changes may not be preserved through VB updates, thus this screen may be displayed again at that time."));
+ msgBox.exec(); + msgBox.exec();
+ app.quit(); + app.quit();
+ if (msgBox.clickedButton() == myYesButton) + if (msgBox.clickedButton() == myYesButton)

View File

@ -6,8 +6,8 @@ export QT_NO_KDE_INTEGRATION=1
# #
# Handle the issue regarding USB passthru # Handle the issue regarding USB passthru
# The following conditions apply: # The following conditions apply:
# 1. If ~/.vbox/enable exists, the user accepts the security risk. # 1. If ~/.config/VirtualBox/enable exists, the user accepts the security risk.
# 2. If ~/.vbox/disable exists, the user does not accept the risk. That file will contain the inode of /usr/lib/udev/rules.d/60-vboxdrv.rules. # 2. If ~/.config/VirtualBox/disable exists, the user does not accept the risk. That file will contain the inode of /usr/lib/udev/rules.d/60-vboxdrv.rules.
# When that changes, the VBoxUSB_DevRules will again be displayed as that means that VB has been reloaded. # When that changes, the VBoxUSB_DevRules will again be displayed as that means that VB has been reloaded.
# #
devrules() devrules()
@ -15,38 +15,40 @@ devrules()
/usr/lib/virtualbox/VBoxUSB_DevRules /usr/lib/virtualbox/VBoxUSB_DevRules
if [ $? -eq 0 ] ; then if [ $? -eq 0 ] ; then
# User accepts the risk # User accepts the risk
touch ~/.vbox/enable touch ~/.config/VirtualBox/enable
rm -f ~/.vbox/disable rm -f ~/.config/VirtualBox/disable
else else
# User declines the risk - save the inode # User declines the risk - save the inode
echo "" > ~/.vbox/disable echo "" > ~/.config/VirtualBox/disable
rm -f ~/.vbox/enable rm -f ~/.config/VirtualBox/enable
fi fi
} }
# Start of main routine # Start of main routine
# #
# Ensure that ~/.vbox exists # Ensure that ~/.config/VirtualBox exists
mkdir -p ~/.vbox/ mkdir -p ~/.config/VirtualBox
# Originally, this information was in ~/.vbox. Remove any files found there
rm -rf ~/.vbox
# Get the inode for /usr/lib/udev/rules.d/60-vboxdrv.rules # Get the inode for /usr/lib/udev/rules.d/60-vboxdrv.rules
INODE=$(stat /usr/lib/udev/rules.d/60-vboxdrv.rules | grep Inode | cut -d' ' -f3) INODE=$(stat /usr/lib/udev/rules.d/60-vboxdrv.rules | grep Inode | cut -d' ' -f3)
if [ ! -f ~/.vbox/enable ] && [ ! -f ~/.vbox/disable ] ; then if [ ! -f ~/.config/VirtualBox/enable ] && [ ! -f ~/.config/VirtualBox/disable ] ; then
# Neither file exists - find what the user wants # Neither file exists - find what the user wants
devrules devrules
fi fi
# Get the original Inode if it exists # Get the original Inode if it exists
if [ -f ~/.vbox/disable ] ; then if [ -f ~/.config/VirtualBox/disable ] ; then
read LINE < ~/.vbox/disable read LINE < ~/.config/VirtualBox/disable
else else
LINE=" " LINE=" "
fi fi
# If user originally declined, make certain that /usr/lib/udev/rules.d/60-vboxdrv.rules has not been changed # If user originally declined, make certain that /usr/lib/udev/rules.d/60-vboxdrv.rules has not been changed
if [ -f ~/.vbox/disable ] && [ "$LINE" != "$INODE" ] && [ "$LINE" != "" ] ; then if [ -f ~/.config/VirtualBox/disable ] && [ "$LINE" != "$INODE" ] && [ "$LINE" != "" ] ; then
# disable is selected and the Inode has changed - ask again # disable is selected and the Inode has changed - ask again
devrules devrules
fi fi
if [ -f ~/.vbox/disable ] ; then if [ -f ~/.config/VirtualBox/disable ] ; then
echo $INODE > ~/.vbox/disable echo $INODE > ~/.config/VirtualBox/disable
if [ "$LINE" != "$INODE" ] ; then if [ "$LINE" != "$INODE" ] ; then
if [ -f /usr/bin/kdesu ] ; then if [ -f /usr/bin/kdesu ] ; then
kdesu /sbin/vbox-fix-usb-rules.sh kdesu /sbin/vbox-fix-usb-rules.sh

View File

@ -1,3 +1,11 @@
-------------------------------------------------------------------
Sun Mar 29 19:20:48 UTC 2020 - Larry Finger <Larry.Finger@gmail.com>
- Fix build errors for gcc-10 (boo#1167897). File "fixes_for_gcc10.patch" is
added.
- Convert /usr/bin/VirtualBox to use "~/.config/VirtualBox" instead "~/.vbox".
This change was requested in boo#1167660.
------------------------------------------------------------------- -------------------------------------------------------------------
Fri Mar 27 09:32:21 UTC 2020 - Antonio Larrosa <alarrosa@suse.com> Fri Mar 27 09:32:21 UTC 2020 - Antonio Larrosa <alarrosa@suse.com>

View File

@ -156,6 +156,8 @@ Patch135: fixes_for_5.6.patch
Patch136: VirtualBox-6.1.4-VBoxClient-vmsvga-x11-crash.patch Patch136: VirtualBox-6.1.4-VBoxClient-vmsvga-x11-crash.patch
# Fix build for Qt 5.15 # Fix build for Qt 5.15
Patch137: fix-missing-includes-with-qt-5.15.patch Patch137: fix-missing-includes-with-qt-5.15.patch
# Fix builds with GCC10
Patch138: fixes_for_gcc10.patch
Patch999: virtualbox-fix-ui-background-color.patch Patch999: virtualbox-fix-ui-background-color.patch
# #
BuildRequires: LibVNCServer-devel BuildRequires: LibVNCServer-devel
@ -463,6 +465,7 @@ as an "extpack" for VirtualBox. The implementation is licensed under GPL.
%endif %endif
%patch136 -p1 %patch136 -p1
%patch137 -p1 %patch137 -p1
%patch138 -p1
# make VB UI background colors look sane again # make VB UI background colors look sane again
%patch999 -p1 %patch999 -p1