summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJoshua Baergen <joshua.baergen@emc.com>2016-12-12 11:11:23 -0700
committerJoshua Baergen <joshua.baergen@emc.com>2016-12-12 11:19:55 -0700
commit44fda826a47e67573d69290ea616e6da210e9849 (patch)
tree5169ba1678952b1765349547758236666e17e85b /app-emulation/vmware-modules
parentswitching to openrc-run from runscript (diff)
downloadvmware-44fda826a47e67573d69290ea616e6da210e9849.tar.gz
vmware-44fda826a47e67573d69290ea616e6da210e9849.tar.bz2
vmware-44fda826a47e67573d69290ea616e6da210e9849.zip
app-emulation/vmware-modules: add support for kernel 4.9
4.9 introduced a change to the get_user_pages() API: https://git.kernel.org/cgit/linux/kernel/git/torvalds/linux.git/commit/?id=768ae309a96103ed02eb1e111e838c87854d8b51
Diffstat (limited to 'app-emulation/vmware-modules')
-rw-r--r--app-emulation/vmware-modules/files/308-4.09-00-user-pages.patch77
-rw-r--r--app-emulation/vmware-modules/vmware-modules-308.1.1.ebuild1
2 files changed, 78 insertions, 0 deletions
diff --git a/app-emulation/vmware-modules/files/308-4.09-00-user-pages.patch b/app-emulation/vmware-modules/files/308-4.09-00-user-pages.patch
new file mode 100644
index 0000000..73c6c9f
--- /dev/null
+++ b/app-emulation/vmware-modules/files/308-4.09-00-user-pages.patch
@@ -0,0 +1,77 @@
+--- vmmon-only/linux/hostif.c 2016-12-12 09:17:44.438182532 -0700
++++ vmmon-only/linux/hostif.c 2016-12-12 09:19:24.066254301 -0700
+@@ -1172,7 +1172,11 @@
+ #else
+ retval = get_user_pages(current, current->mm, (unsigned long)uvAddr,
+ #endif
+- numPages, 0, 0, ppages, NULL);
++ numPages, 0,
++#if LINUX_VERSION_CODE < KERNEL_VERSION(4, 9, 0)
++ 0,
++#endif
++ ppages, NULL);
+ up_read(&current->mm->mmap_sem);
+
+ return retval != numPages;
+--- vmnet-only/userif.c 2016-12-12 09:27:12.445246854 -0700
++++ vmnet-only/userif.c 2016-12-12 09:27:30.654298646 -0700
+@@ -118,7 +118,13 @@
+ #else
+ retval = get_user_pages(current, current->mm, addr,
+ #endif
+- 1, 1, 0, &page, NULL);
++ 1,
++#if LINUX_VERSION_CODE < KERNEL_VERSION(4, 9, 0)
++ 1, 0,
++#else
++ FOLL_WRITE,
++#endif
++ &page, NULL);
+ up_read(&current->mm->mmap_sem);
+
+ if (retval != 1) {
+--- vmci-only/linux/driver.c 2016-12-12 09:38:13.076847013 -0700
++++ vmci-only/linux/driver.c 2016-12-12 09:38:45.638087445 -0700
+@@ -1473,7 +1473,13 @@
+ #else
+ retval = get_user_pages(current, current->mm, addr,
+ #endif
+- 1, 1, 0, &page, NULL);
++ 1,
++#if LINUX_VERSION_CODE < KERNEL_VERSION(4, 9, 0)
++ 1, 0,
++#else
++ FOLL_WRITE,
++#endif
++ &page, NULL);
+ up_read(&current->mm->mmap_sem);
+
+ if (retval != 1) {
+--- vmci-only/linux/vmciKernelIf.c 2016-12-12 09:38:20.678904322 -0700
++++ vmci-only/linux/vmciKernelIf.c 2016-12-12 09:39:59.129587451 -0700
+@@ -2061,7 +2061,11 @@
+ (VA)produceUVA,
+ #endif
+ produceQ->kernelIf->numPages,
+- 1, 0,
++#if LINUX_VERSION_CODE < KERNEL_VERSION(4, 9, 0)
++ 1, 0,
++#else
++ FOLL_WRITE,
++#endif
+ produceQ->kernelIf->u.h.headerPage,
+ NULL);
+ if (retval < produceQ->kernelIf->numPages) {
+@@ -2079,7 +2083,11 @@
+ (VA)consumeUVA,
+ #endif
+ consumeQ->kernelIf->numPages,
+- 1, 0,
++#if LINUX_VERSION_CODE < KERNEL_VERSION(4, 9, 0)
++ 1, 0,
++#else
++ FOLL_WRITE,
++#endif
+ consumeQ->kernelIf->u.h.headerPage,
+ NULL);
+ if (retval < consumeQ->kernelIf->numPages) {
diff --git a/app-emulation/vmware-modules/vmware-modules-308.1.1.ebuild b/app-emulation/vmware-modules/vmware-modules-308.1.1.ebuild
index b3faaaf..bb9db4f 100644
--- a/app-emulation/vmware-modules/vmware-modules-308.1.1.ebuild
+++ b/app-emulation/vmware-modules/vmware-modules-308.1.1.ebuild
@@ -105,6 +105,7 @@ src_prepare() {
kernel_is ge 4 7 0 && epatch "${FILESDIR}/${PV_MAJOR}-4.07-00-trans_start.patch"
kernel_is ge 4 7 0 && epatch "${FILESDIR}/${PV_MAJOR}-4.07-01-readlink_copy.patch"
kernel_is ge 4 8 0 && epatch "${FILESDIR}/${PV_MAJOR}-4.08-00-nr_anon_mapped.patch"
+ kernel_is ge 4 9 0 && epatch "${FILESDIR}/${PV_MAJOR}-4.09-00-user-pages.patch"
# Allow user patches so they can support RC kernels and whatever else
epatch_user