mirror of
https://github.com/openembedded/meta-openembedded.git
synced 2026-06-12 05:11:59 +00:00
vboxguestdrivers: Fix build with kernel 5.8
Remove patches which are already covered in this new patch Fixes step1b: ERROR: modpost: "__get_vm_area_caller" [/home/pokybuild/yocto-worker/meta-oe/build/build/tmp/work/qemux86_64-poky-linux/vboxguestdrivers/6.1.12-r0/vboxguestdrivers-6.1.12/vboxguest/vboxguest.ko] undefined! step1b: ERROR: modpost: "map_kernel_range" [/home/pokybuild/yocto-worker/meta-oe/build/build/tmp/work/qemux86_64-poky-linux/vboxguestdrivers/6.1.12-r0/vboxguestdrivers-6.1.12/vboxguest/vboxguest.ko] undefined! Signed-off-by: Khem Raj <raj.khem@gmail.com>
This commit is contained in:
-176
@@ -1,176 +0,0 @@
|
|||||||
From 98070c936931879d2b8e22939724b5a0689721d0 Mon Sep 17 00:00:00 2001
|
|
||||||
From: Hongxu Jia <hongxu.jia@windriver.com>
|
|
||||||
Date: Tue, 18 Aug 2020 17:48:29 +0800
|
|
||||||
Subject: [PATCH 1/3] fixes_for_mm_struct
|
|
||||||
|
|
||||||
Upstream-Status: Backport [https://www.virtualbox.org/ticket/19644]
|
|
||||||
|
|
||||||
Signed-off-by: Hongxu Jia <hongxu.jia@windriver.com>
|
|
||||||
---
|
|
||||||
.../Runtime/r0drv/linux/memobj-r0drv-linux.c | 74 +++++++++++++++++--
|
|
||||||
1 file changed, 67 insertions(+), 7 deletions(-)
|
|
||||||
|
|
||||||
diff --git a/src/VBox/Runtime/r0drv/linux/memobj-r0drv-linux.c b/src/VBox/Runtime/r0drv/linux/memobj-r0drv-linux.c
|
|
||||||
index 37389bcc..cdc7e8e6 100644
|
|
||||||
--- a/src/VBox/Runtime/r0drv/linux/memobj-r0drv-linux.c
|
|
||||||
+++ b/src/VBox/Runtime/r0drv/linux/memobj-r0drv-linux.c
|
|
||||||
@@ -222,9 +222,17 @@ static void *rtR0MemObjLinuxDoMmap(RTR3PTR R3PtrFixed, size_t cb, size_t uAlignm
|
|
||||||
#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0)
|
|
||||||
ulAddr = vm_mmap(NULL, R3PtrFixed, cb, fLnxProt, MAP_SHARED | MAP_ANONYMOUS | MAP_FIXED, 0);
|
|
||||||
#else
|
|
||||||
+#if LINUX_VERSION_CODE < KERNEL_VERSION(5, 8, 0)
|
|
||||||
down_write(&pTask->mm->mmap_sem);
|
|
||||||
+#else
|
|
||||||
+ down_write(&pTask->mm->mmap_lock);
|
|
||||||
+#endif
|
|
||||||
ulAddr = do_mmap(NULL, R3PtrFixed, cb, fLnxProt, MAP_SHARED | MAP_ANONYMOUS | MAP_FIXED, 0);
|
|
||||||
+#if LINUX_VERSION_CODE < KERNEL_VERSION(5, 8, 0)
|
|
||||||
up_write(&pTask->mm->mmap_sem);
|
|
||||||
+#else
|
|
||||||
+ up_write(&pTask->mm->mmap_lock);
|
|
||||||
+#endif
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
else
|
|
||||||
@@ -232,9 +240,17 @@ static void *rtR0MemObjLinuxDoMmap(RTR3PTR R3PtrFixed, size_t cb, size_t uAlignm
|
|
||||||
#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 5, 0)
|
|
||||||
ulAddr = vm_mmap(NULL, 0, cb, fLnxProt, MAP_SHARED | MAP_ANONYMOUS, 0);
|
|
||||||
#else
|
|
||||||
+#if LINUX_VERSION_CODE < KERNEL_VERSION(5, 8, 0)
|
|
||||||
down_write(&pTask->mm->mmap_sem);
|
|
||||||
+#else
|
|
||||||
+ down_write(&pTask->mm->mmap_lock);
|
|
||||||
+#endif
|
|
||||||
ulAddr = do_mmap(NULL, 0, cb, fLnxProt, MAP_SHARED | MAP_ANONYMOUS, 0);
|
|
||||||
+#if LINUX_VERSION_CODE < KERNEL_VERSION(5, 8, 0)
|
|
||||||
up_write(&pTask->mm->mmap_sem);
|
|
||||||
+#else
|
|
||||||
+ up_write(&pTask->mm->mmap_lock);
|
|
||||||
+#endif
|
|
||||||
#endif
|
|
||||||
if ( !(ulAddr & ~PAGE_MASK)
|
|
||||||
&& (ulAddr & (uAlignment - 1)))
|
|
||||||
@@ -269,13 +285,29 @@ static void rtR0MemObjLinuxDoMunmap(void *pv, size_t cb, struct task_struct *pTa
|
|
||||||
Assert(pTask == current); RT_NOREF_PV(pTask);
|
|
||||||
vm_munmap((unsigned long)pv, cb);
|
|
||||||
#elif defined(USE_RHEL4_MUNMAP)
|
|
||||||
+#if LINUX_VERSION_CODE < KERNEL_VERSION(5, 8, 0)
|
|
||||||
down_write(&pTask->mm->mmap_sem);
|
|
||||||
+#else
|
|
||||||
+ down_write(&pTask->mm->mmap_lock);
|
|
||||||
+#endif
|
|
||||||
do_munmap(pTask->mm, (unsigned long)pv, cb, 0); /* should it be 1 or 0? */
|
|
||||||
+#if LINUX_VERSION_CODE < KERNEL_VERSION(5, 8, 0)
|
|
||||||
up_write(&pTask->mm->mmap_sem);
|
|
||||||
#else
|
|
||||||
+ up_write(&pTask->mm->mmap_lock);
|
|
||||||
+#endif
|
|
||||||
+#else
|
|
||||||
+#if LINUX_VERSION_CODE < KERNEL_VERSION(5, 8, 0)
|
|
||||||
down_write(&pTask->mm->mmap_sem);
|
|
||||||
+#else
|
|
||||||
+ down_write(&pTask->mm->mmap_lock);
|
|
||||||
+#endif
|
|
||||||
do_munmap(pTask->mm, (unsigned long)pv, cb);
|
|
||||||
+#if LINUX_VERSION_CODE < KERNEL_VERSION(5, 8, 0)
|
|
||||||
up_write(&pTask->mm->mmap_sem);
|
|
||||||
+#else
|
|
||||||
+ up_write(&pTask->mm->mmap_lock);
|
|
||||||
+#endif
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -593,7 +625,11 @@ DECLHIDDEN(int) rtR0MemObjNativeFree(RTR0MEMOBJ pMem)
|
|
||||||
size_t iPage;
|
|
||||||
Assert(pTask);
|
|
||||||
if (pTask && pTask->mm)
|
|
||||||
- down_read(&pTask->mm->mmap_sem);
|
|
||||||
+#if LINUX_VERSION_CODE < KERNEL_VERSION(5, 8, 0)
|
|
||||||
+ down_read(&pTask->mm->mmap_sem);
|
|
||||||
+#else
|
|
||||||
+ down_read(&pTask->mm->mmap_lock);
|
|
||||||
+#endif
|
|
||||||
|
|
||||||
iPage = pMemLnx->cPages;
|
|
||||||
while (iPage-- > 0)
|
|
||||||
@@ -608,7 +644,11 @@ DECLHIDDEN(int) rtR0MemObjNativeFree(RTR0MEMOBJ pMem)
|
|
||||||
}
|
|
||||||
|
|
||||||
if (pTask && pTask->mm)
|
|
||||||
- up_read(&pTask->mm->mmap_sem);
|
|
||||||
+#if LINUX_VERSION_CODE < KERNEL_VERSION(5, 8, 0)
|
|
||||||
+ up_read(&pTask->mm->mmap_sem);
|
|
||||||
+#else
|
|
||||||
+ up_read(&pTask->mm->mmap_lock);
|
|
||||||
+#endif
|
|
||||||
}
|
|
||||||
/* else: kernel memory - nothing to do here. */
|
|
||||||
break;
|
|
||||||
@@ -1076,7 +1116,11 @@ DECLHIDDEN(int) rtR0MemObjNativeLockUser(PPRTR0MEMOBJINTERNAL ppMem, RTR3PTR R3P
|
|
||||||
papVMAs = (struct vm_area_struct **)RTMemAlloc(sizeof(*papVMAs) * cPages);
|
|
||||||
if (papVMAs)
|
|
||||||
{
|
|
||||||
- down_read(&pTask->mm->mmap_sem);
|
|
||||||
+#if LINUX_VERSION_CODE < KERNEL_VERSION(5, 8, 0)
|
|
||||||
+ down_read(&pTask->mm->mmap_sem);
|
|
||||||
+#else
|
|
||||||
+ down_read(&pTask->mm->mmap_lock);
|
|
||||||
+#endif
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Get user pages.
|
|
||||||
@@ -1162,7 +1206,11 @@ DECLHIDDEN(int) rtR0MemObjNativeLockUser(PPRTR0MEMOBJINTERNAL ppMem, RTR3PTR R3P
|
|
||||||
papVMAs[rc]->vm_flags |= VM_DONTCOPY | VM_LOCKED;
|
|
||||||
}
|
|
||||||
|
|
||||||
- up_read(&pTask->mm->mmap_sem);
|
|
||||||
+#if LINUX_VERSION_CODE < KERNEL_VERSION(5, 8, 0)
|
|
||||||
+ up_read(&pTask->mm->mmap_sem);
|
|
||||||
+#else
|
|
||||||
+ up_read(&pTask->mm->mmap_lock);
|
|
||||||
+#endif
|
|
||||||
|
|
||||||
RTMemFree(papVMAs);
|
|
||||||
|
|
||||||
@@ -1189,7 +1237,11 @@ DECLHIDDEN(int) rtR0MemObjNativeLockUser(PPRTR0MEMOBJINTERNAL ppMem, RTR3PTR R3P
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
- up_read(&pTask->mm->mmap_sem);
|
|
||||||
+#if LINUX_VERSION_CODE < KERNEL_VERSION(5, 8, 0)
|
|
||||||
+ up_read(&pTask->mm->mmap_sem);
|
|
||||||
+#else
|
|
||||||
+ up_read(&pTask->mm->mmap_lock);
|
|
||||||
+#endif
|
|
||||||
|
|
||||||
RTMemFree(papVMAs);
|
|
||||||
rc = VERR_LOCK_FAILED;
|
|
||||||
@@ -1604,7 +1656,11 @@ DECLHIDDEN(int) rtR0MemObjNativeMapUser(PPRTR0MEMOBJINTERNAL ppMem, RTR0MEMOBJ p
|
|
||||||
const size_t cPages = (offSub + cbSub) >> PAGE_SHIFT;
|
|
||||||
size_t iPage;
|
|
||||||
|
|
||||||
- down_write(&pTask->mm->mmap_sem);
|
|
||||||
+#if LINUX_VERSION_CODE < KERNEL_VERSION(5, 8, 0)
|
|
||||||
+ down_write(&pTask->mm->mmap_sem);
|
|
||||||
+#else
|
|
||||||
+ down_write(&pTask->mm->mmap_lock);
|
|
||||||
+#endif
|
|
||||||
|
|
||||||
rc = VINF_SUCCESS;
|
|
||||||
if (pMemLnxToMap->cPages)
|
|
||||||
@@ -1721,7 +1777,11 @@ DECLHIDDEN(int) rtR0MemObjNativeMapUser(PPRTR0MEMOBJINTERNAL ppMem, RTR0MEMOBJ p
|
|
||||||
}
|
|
||||||
#endif /* CONFIG_NUMA_BALANCING */
|
|
||||||
|
|
||||||
- up_write(&pTask->mm->mmap_sem);
|
|
||||||
+#if LINUX_VERSION_CODE < KERNEL_VERSION(5, 8, 0)
|
|
||||||
+ up_write(&pTask->mm->mmap_sem);
|
|
||||||
+#else
|
|
||||||
+ up_write(&pTask->mm->mmap_lock);
|
|
||||||
+#endif
|
|
||||||
|
|
||||||
if (RT_SUCCESS(rc))
|
|
||||||
{
|
|
||||||
--
|
|
||||||
2.18.2
|
|
||||||
|
|
||||||
-65
@@ -1,65 +0,0 @@
|
|||||||
From bb580f7b601e5395a2f8fcb2485387035273320f Mon Sep 17 00:00:00 2001
|
|
||||||
From: Hongxu Jia <hongxu.jia@windriver.com>
|
|
||||||
Date: Tue, 18 Aug 2020 17:49:34 +0800
|
|
||||||
Subject: [PATCH 2/3] fixes_for_module_memory
|
|
||||||
|
|
||||||
Upstream-Status: Backport [https://www.virtualbox.org/ticket/19644]
|
|
||||||
|
|
||||||
Signed-off-by: Hongxu Jia <hongxu.jia@windriver.com>
|
|
||||||
---
|
|
||||||
.../Runtime/r0drv/linux/alloc-r0drv-linux.c | 18 ++++++++++++++++--
|
|
||||||
1 file changed, 16 insertions(+), 2 deletions(-)
|
|
||||||
|
|
||||||
diff --git a/src/VBox/Runtime/r0drv/linux/alloc-r0drv-linux.c b/src/VBox/Runtime/r0drv/linux/alloc-r0drv-linux.c
|
|
||||||
index bbb8acc6..45cd34c7 100644
|
|
||||||
--- a/src/VBox/Runtime/r0drv/linux/alloc-r0drv-linux.c
|
|
||||||
+++ b/src/VBox/Runtime/r0drv/linux/alloc-r0drv-linux.c
|
|
||||||
@@ -153,6 +153,8 @@ RT_EXPORT_SYMBOL(RTR0MemExecDonate);
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef RTMEMALLOC_EXEC_VM_AREA
|
|
||||||
+
|
|
||||||
+
|
|
||||||
/**
|
|
||||||
* Allocate executable kernel memory in the module range.
|
|
||||||
*
|
|
||||||
@@ -168,7 +170,12 @@ static PRTMEMHDR rtR0MemAllocExecVmArea(size_t cb)
|
|
||||||
struct vm_struct *pVmArea;
|
|
||||||
size_t iPage;
|
|
||||||
|
|
||||||
+# if LINUX_VERSION_CODE >= KERNEL_VERSION(5, 8, 0)
|
|
||||||
+ pVmArea = __get_vm_area_caller(cbAlloc, VM_ALLOC, MODULES_VADDR, MODULES_END,
|
|
||||||
+ __builtin_return_address(0));
|
|
||||||
+#else
|
|
||||||
pVmArea = __get_vm_area(cbAlloc, VM_ALLOC, MODULES_VADDR, MODULES_END);
|
|
||||||
+#endif
|
|
||||||
if (!pVmArea)
|
|
||||||
return NULL;
|
|
||||||
pVmArea->nr_pages = 0; /* paranoia? */
|
|
||||||
@@ -201,14 +208,21 @@ static PRTMEMHDR rtR0MemAllocExecVmArea(size_t cb)
|
|
||||||
# endif
|
|
||||||
pVmArea->nr_pages = cPages;
|
|
||||||
pVmArea->pages = papPages;
|
|
||||||
- if (!map_vm_area(pVmArea, PAGE_KERNEL_EXEC,
|
|
||||||
+# if LINUX_VERSION_CODE >= KERNEL_VERSION(5, 8, 0)
|
|
||||||
+ unsigned long start = (unsigned long)pVmArea->addr;
|
|
||||||
+ unsigned long size = get_vm_area_size(pVmArea);
|
|
||||||
+
|
|
||||||
+ if (!map_kernel_range(start, size, PAGE_KERNEL_EXEC, papPages))
|
|
||||||
+#else
|
|
||||||
+ if (!map_vm_area(pVmArea, PAGE_KERNEL_EXEC,
|
|
||||||
# if LINUX_VERSION_CODE < KERNEL_VERSION(3, 17, 0)
|
|
||||||
&papPagesIterator
|
|
||||||
# else
|
|
||||||
papPages
|
|
||||||
# endif
|
|
||||||
))
|
|
||||||
- {
|
|
||||||
+#endif
|
|
||||||
+ {
|
|
||||||
PRTMEMLNXHDREX pHdrEx = (PRTMEMLNXHDREX)pVmArea->addr;
|
|
||||||
pHdrEx->pVmArea = pVmArea;
|
|
||||||
pHdrEx->pvDummy = NULL;
|
|
||||||
--
|
|
||||||
2.18.2
|
|
||||||
|
|
||||||
-39
@@ -1,39 +0,0 @@
|
|||||||
From 6089974a81b1b44e1d2dfa5af1fdc110dfee40c1 Mon Sep 17 00:00:00 2001
|
|
||||||
From: Hongxu Jia <hongxu.jia@windriver.com>
|
|
||||||
Date: Tue, 18 Aug 2020 17:51:24 +0800
|
|
||||||
Subject: [PATCH 3/3] fixes_for_changes_in_cpu_tlbstate
|
|
||||||
|
|
||||||
Upstream-Status: Backport [https://www.virtualbox.org/ticket/19644]
|
|
||||||
|
|
||||||
Signed-off-by: Hongxu Jia <hongxu.jia@windriver.com>
|
|
||||||
---
|
|
||||||
src/VBox/HostDrivers/Support/linux/SUPDrv-linux.c | 7 +++++++
|
|
||||||
1 file changed, 7 insertions(+)
|
|
||||||
|
|
||||||
diff --git a/src/VBox/HostDrivers/Support/linux/SUPDrv-linux.c b/src/VBox/HostDrivers/Support/linux/SUPDrv-linux.c
|
|
||||||
index c7d0d99a..2e7aa6e1 100644
|
|
||||||
--- a/src/VBox/HostDrivers/Support/linux/SUPDrv-linux.c
|
|
||||||
+++ b/src/VBox/HostDrivers/Support/linux/SUPDrv-linux.c
|
|
||||||
@@ -757,12 +757,19 @@ EXPORT_SYMBOL(SUPDrvLinuxIDC);
|
|
||||||
RTCCUINTREG VBOXCALL supdrvOSChangeCR4(RTCCUINTREG fOrMask, RTCCUINTREG fAndMask)
|
|
||||||
{
|
|
||||||
#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 20, 0)
|
|
||||||
+#if LINUX_VERSION_CODE < KERNEL_VERSION(5, 8, 0)
|
|
||||||
RTCCUINTREG uOld = this_cpu_read(cpu_tlbstate.cr4);
|
|
||||||
+#else
|
|
||||||
+ RTCCUINTREG uOld = __read_cr4();
|
|
||||||
+#endif
|
|
||||||
RTCCUINTREG uNew = (uOld & fAndMask) | fOrMask;
|
|
||||||
if (uNew != uOld)
|
|
||||||
{
|
|
||||||
+#if LINUX_VERSION_CODE < KERNEL_VERSION(5, 8, 0)
|
|
||||||
this_cpu_write(cpu_tlbstate.cr4, uNew);
|
|
||||||
__write_cr4(uNew);
|
|
||||||
+#endif
|
|
||||||
+ ASMSetCR4(uNew);
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
RTCCUINTREG uOld = ASMGetCR4();
|
|
||||||
--
|
|
||||||
2.18.2
|
|
||||||
|
|
||||||
File diff suppressed because it is too large
Load Diff
@@ -1,19 +0,0 @@
|
|||||||
Description: Fix kernel 5.8 forbidding use of vermagic.h header file
|
|
||||||
Author: Gianfranco Costamagna <locutusofborg@debian.org>
|
|
||||||
Origin: https://www.virtualbox.org/ticket/19644
|
|
||||||
Bug-Ubuntu: https://launchpad.net/bugs/1884652
|
|
||||||
Last-Update: 2020-08-10
|
|
||||||
|
|
||||||
--- virtualbox-6.1.12-dfsg.orig/src/VBox/Additions/linux/sharedfolders/vfsmod.c
|
|
||||||
+++ virtualbox-6.1.12-dfsg/src/VBox/Additions/linux/sharedfolders/vfsmod.c
|
|
||||||
@@ -53,7 +53,9 @@
|
|
||||||
#include <linux/seq_file.h>
|
|
||||||
#include <linux/vfs.h>
|
|
||||||
#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 5, 62)
|
|
||||||
-# include <linux/vermagic.h>
|
|
||||||
+# if LINUX_VERSION_CODE < KERNEL_VERSION(5, 8, 0)
|
|
||||||
+# include <linux/vermagic.h>
|
|
||||||
+# endif
|
|
||||||
#endif
|
|
||||||
#include <VBox/err.h>
|
|
||||||
#include <iprt/path.h>
|
|
||||||
@@ -12,10 +12,7 @@ COMPATIBLE_MACHINE = "(qemux86|qemux86-64)"
|
|||||||
VBOX_NAME = "VirtualBox-${PV}"
|
VBOX_NAME = "VirtualBox-${PV}"
|
||||||
|
|
||||||
SRC_URI = "http://download.virtualbox.org/virtualbox/${PV}/${VBOX_NAME}.tar.bz2 \
|
SRC_URI = "http://download.virtualbox.org/virtualbox/${PV}/${VBOX_NAME}.tar.bz2 \
|
||||||
file://0001-fixes_for_mm_struct.patch \
|
file://021-linux-5-8.patch \
|
||||||
file://0002-fixes_for_module_memory.patch \
|
|
||||||
file://0003-fixes_for_changes_in_cpu_tlbstate.patch \
|
|
||||||
file://kernel-5.8-4.patch \
|
|
||||||
file://Makefile.utils \
|
file://Makefile.utils \
|
||||||
"
|
"
|
||||||
SRC_URI[md5sum] = "3c351f7fd6376e0bb3c8489505a9450c"
|
SRC_URI[md5sum] = "3c351f7fd6376e0bb3c8489505a9450c"
|
||||||
|
|||||||
Reference in New Issue
Block a user