From 0df9a5d8c92091b2d03d364a1fe5e84445aaad8c8fff8d9452417371c600f89a Mon Sep 17 00:00:00 2001 From: Larry Finger Date: Wed, 14 Jul 2021 16:47:06 +0000 Subject: [PATCH 1/2] Accepting request 906333 from home:lwfinger:branches:Virtualization - Add file "fixes_for_5.14.patch" to fix builds on kernel 5.14. OBS-URL: https://build.opensuse.org/request/show/906333 OBS-URL: https://build.opensuse.org/package/show/Virtualization/virtualbox?expand=0&rev=609 --- fixes_for_5.14.patch | 50 +++++++++++++++++++++++++++++++++++ virtualbox.changes | 5 ++++ virtualbox.spec | 62 +++++++++++++++++++++++++++++++++++++++++--- 3 files changed, 113 insertions(+), 4 deletions(-) create mode 100644 fixes_for_5.14.patch diff --git a/fixes_for_5.14.patch b/fixes_for_5.14.patch new file mode 100644 index 0000000..d39e5cf --- /dev/null +++ b/fixes_for_5.14.patch @@ -0,0 +1,50 @@ +Index: VirtualBox-6.1.22/src/VBox/Additions/linux/sharedfolders/regops.c +=================================================================== +--- VirtualBox-6.1.22.orig/src/VBox/Additions/linux/sharedfolders/regops.c ++++ VirtualBox-6.1.22/src/VBox/Additions/linux/sharedfolders/regops.c +@@ -2126,7 +2126,11 @@ static int vbsf_iter_lock_pages(struct i + int rc = 0; + + Assert(iov_iter_count(iter) + pStash->cb > 0); ++#if RTLNX_VER_MAX(5, 14,0) + if (!(iter->type & ITER_KVEC)) { ++#else ++ if (iov_iter_type(iter) != ITER_KVEC) { ++#endif + /* + * Do we have a stashed page? + */ +@@ -2373,7 +2377,11 @@ static size_t vbsf_iter_max_span_of_page + { + size_t cPages; + # if RTLNX_VER_MIN(3,16,0) ++# if RTLNX_VER_MAX(5, 14, 0) + if (iter_is_iovec(iter) || (iter->type & ITER_KVEC)) { ++#else ++ if (iter_is_iovec(iter) || (iter_is_iovec(iter) == ITER_KVEC)) { ++#endif + #endif + const struct iovec *pCurIov = iter->iov; + size_t cLeft = iter->nr_segs; +@@ -2436,7 +2444,11 @@ static size_t vbsf_iter_max_span_of_page + } else { + /* Won't bother with accurate counts for the next two types, just make + some rough estimates (does pipes have segments?): */ ++#if RTLNX_VER_MAX(5, 14,0) + size_t cSegs = iter->type & ITER_BVEC ? RT_MAX(1, iter->nr_segs) : 1; ++#else ++ size_t cSegs = (iov_iter_type(iter) == ITER_BVEC) ? RT_MAX(1, iter->nr_segs) : 1; ++#endif + cPages = (iov_iter_count(iter) + (PAGE_SIZE * 2 - 2) * cSegs) >> PAGE_SHIFT; + } + # endif +@@ -3793,7 +3805,9 @@ struct address_space_operations vbsf_reg + #endif + #if RTLNX_VER_MIN(2,6,24) + .write_begin = vbsf_write_begin, ++#if RTLNX_VER_MAX(5, 14, 0) + .write_end = simple_write_end, ++#endif + #elif RTLNX_VER_MIN(2,5,45) + .prepare_write = simple_prepare_write, + .commit_write = simple_commit_write, diff --git a/virtualbox.changes b/virtualbox.changes index ddb5b50..e9f07bd 100644 --- a/virtualbox.changes +++ b/virtualbox.changes @@ -1,3 +1,8 @@ +------------------------------------------------------------------- +Wed Jul 14 04:03:16 UTC 2021 - Larry Finger + +- Add file "fixes_for_5.14.patch" to fix builds on kernel 5.14. + ------------------------------------------------------------------- Mon May 17 15:59:52 UTC 2021 - Larry Finger diff --git a/virtualbox.spec b/virtualbox.spec index 98fddd1..24d55e8 100644 --- a/virtualbox.spec +++ b/virtualbox.spec @@ -1,5 +1,5 @@ # -# spec file for package virtualbox%{?dash}%{?name_suffix} +# spec file # # Copyright (c) 2021 SUSE LLC # @@ -186,8 +186,8 @@ Patch137: handle_gsoap_208103.patch # Fix for struct file_operations backport in 15.3 Patch139: fixes_for_leap15.3.patch Patch141: vb-6.1.16-modal-dialog-parent.patch -# Fixes for kernel 5.13 -# Patch142: fixes_for_5.13.patch +# Fixes for kernel 5.14 +Patch142: fixes_for_5.14.patch Patch999: virtualbox-fix-ui-background-color.patch # @@ -330,6 +330,12 @@ the terms of the GNU Public License (GPL). + + + + + + @@ -373,6 +379,12 @@ This package contains the code for the GUI used to control VMs. + + + + + + @@ -410,6 +422,12 @@ The VirtualBox web server is used to control headless VMs using a browser. + + + + + + @@ -449,6 +467,12 @@ This package contains X11 guest utilities and X11 guest mouse and video drivers + + + + + + @@ -493,6 +517,12 @@ VirtualBox guest addition tools. + + + + + + @@ -537,6 +567,12 @@ Python XPCOM bindings to %{name}. Used e.g. by vboxgtk package. + + + + + + @@ -576,6 +612,12 @@ Development file for %{name} + + + + + + @@ -624,6 +666,12 @@ sudo /sbin/vboxguestconfig + + + + + + ########################################### %package guest-desktop-icons @@ -654,6 +702,12 @@ This package contains icons for guest desktop files that were created on the des + + + + + + @@ -734,7 +788,7 @@ This package contains the kernel-modules that VirtualBox uses to create or run v %patch139 -p1 %endif %patch141 -p1 -#%patch142 -p1 +%patch142 -p1 # make VB UI background colors look sane again %patch999 -p1 From 4122f0cd242391a0fcf1ba9bc3882fd333ee9fe518788ec09ddf513efbe93407 Mon Sep 17 00:00:00 2001 From: Larry Finger Date: Thu, 15 Jul 2021 01:13:33 +0000 Subject: [PATCH 2/2] Accepting request 906360 from home:lwfinger:branches:Virtualization - Add file "fix_random_stack_failure.patch" to fix CONFIG_RANDOMIZE_KSTACK_OFFSET_DEFAULT problem with kernel 5.13 as shown in boo#118105. OBS-URL: https://build.opensuse.org/request/show/906360 OBS-URL: https://build.opensuse.org/package/show/Virtualization/virtualbox?expand=0&rev=610 --- fix_random_stack_failure.patch | 23 +++++++++++++++++++++++ virtualbox.changes | 6 ++++++ virtualbox.spec | 30 +++++++++++++++++++++--------- 3 files changed, 50 insertions(+), 9 deletions(-) create mode 100644 fix_random_stack_failure.patch diff --git a/fix_random_stack_failure.patch b/fix_random_stack_failure.patch new file mode 100644 index 0000000..1a03071 --- /dev/null +++ b/fix_random_stack_failure.patch @@ -0,0 +1,23 @@ +Index: VirtualBox-6.1.22/src/VBox/VMM/VMMR0/VMMR0JmpA-amd64.asm +=================================================================== +--- VirtualBox-6.1.22.orig/src/VBox/VMM/VMMR0/VMMR0JmpA-amd64.asm ++++ VirtualBox-6.1.22/src/VBox/VMM/VMMR0/VMMR0JmpA-amd64.asm +@@ -32,10 +32,17 @@ + %define STACK_PADDING 0eeeeeeeeeeeeeeeeh + + ;; Workaround for linux 4.6 fast/slow syscall stack depth difference. ++;; Update: This got worse with linux 5.13 and CONFIG_RANDOMIZE_KSTACK_OFFSET_DEFAULT. ++;; The x86 arch_exit_to_user_mode_prepare code limits the offset to 255, ++;; while the generic limit is 1023. See bugref:10064 for details. + %ifdef VMM_R0_SWITCH_STACK + %define STACK_FUZZ_SIZE 0 + %else +- %define STACK_FUZZ_SIZE 128 ++ %ifdef RT_OS_LINUX ++ %define STACK_FUZZ_SIZE 384 ++ %else ++ %define STACK_FUZZ_SIZE 128 ++ %endif + %endif + + diff --git a/virtualbox.changes b/virtualbox.changes index e9f07bd..d8586ab 100644 --- a/virtualbox.changes +++ b/virtualbox.changes @@ -1,3 +1,9 @@ +------------------------------------------------------------------- +Thu Jul 15 00:31:08 UTC 2021 - Larry Finger + +- Add file "fix_random_stack_failure.patch" to fix CONFIG_RANDOMIZE_KSTACK_OFFSET_DEFAULT + problem with kernel 5.13 as shown in boo#118105. + ------------------------------------------------------------------- Wed Jul 14 04:03:16 UTC 2021 - Larry Finger diff --git a/virtualbox.spec b/virtualbox.spec index 24d55e8..a7d4f00 100644 --- a/virtualbox.spec +++ b/virtualbox.spec @@ -188,6 +188,8 @@ Patch139: fixes_for_leap15.3.patch Patch141: vb-6.1.16-modal-dialog-parent.patch # Fixes for kernel 5.14 Patch142: fixes_for_5.14.patch +# Fix for CONFIG_RANDOMIZE_KSTACK_OFFSET_DEFAULT +Patch143: fix_random_stack_failure.patch Patch999: virtualbox-fix-ui-background-color.patch # @@ -343,8 +345,9 @@ the terms of the GNU Public License (GPL). -########################################## + +########################################## %package qt Summary: Qt GUI part for %{name} Group: System/Emulators/PC @@ -392,8 +395,9 @@ This package contains the code for the GUI used to control VMs. -######################################### + +######################################### %package websrv Summary: WebService GUI part for %{name} Group: System/Emulators/PC @@ -435,8 +439,9 @@ The VirtualBox web server is used to control headless VMs using a browser. -######################################### + +######################################### %package guest-x11 Summary: VirtualBox X11 drivers for mouse and video Group: System/X11/Servers/XF86_4 @@ -480,8 +485,9 @@ This package contains X11 guest utilities and X11 guest mouse and video drivers -########################################### + +########################################### %package guest-tools Summary: VirtualBox guest tools Group: System/Emulators/PC @@ -530,8 +536,9 @@ VirtualBox guest addition tools. -########################################### + +########################################### %package -n python3-%{name} Summary: Python bindings for %{name} Group: Development/Libraries/Python @@ -580,8 +587,9 @@ Python XPCOM bindings to %{name}. Used e.g. by vboxgtk package. -########################################### + +########################################### %package devel Summary: Devel files for %{name} Group: Development/Libraries/Other @@ -625,8 +633,9 @@ Development file for %{name} -########################################### + +########################################### %package host-source Summary: Source files for %{name} host kernel modules Group: Development/Sources @@ -672,8 +681,9 @@ sudo /sbin/vboxguestconfig -########################################### + +########################################### %package guest-desktop-icons Summary: Icons for guest desktop files Group: System/Emulators/PC @@ -715,8 +725,9 @@ This package contains icons for guest desktop files that were created on the des -########################################### + +########################################### %package vnc Summary: VNC desktop sharing Group: System/Emulators/PC @@ -789,6 +800,7 @@ This package contains the kernel-modules that VirtualBox uses to create or run v %endif %patch141 -p1 %patch142 -p1 +%patch143 -p1 # make VB UI background colors look sane again %patch999 -p1