diff options
author | Vadim Kuznetsov <vadimk@gentoo.org> | 2009-09-02 02:13:32 +0000 |
---|---|---|
committer | Vadim Kuznetsov <vadimk@gentoo.org> | 2009-09-02 02:13:32 +0000 |
commit | 243092301ee174164408db325af645fb50e43ac1 (patch) | |
tree | 20334cc56618be1de2d0894b16d8402018fd6f86 /app-emulation | |
parent | Cleanup ebuild slightly, and add linux-headers dep to avoid compile failures ... (diff) | |
download | historical-243092301ee174164408db325af645fb50e43ac1.tar.gz historical-243092301ee174164408db325af645fb50e43ac1.tar.bz2 historical-243092301ee174164408db325af645fb50e43ac1.zip |
revert previous commit. Bug 273173.
Package-Manager: portage-2.2_rc33/cvs/Linux x86_64
Diffstat (limited to 'app-emulation')
4 files changed, 7 insertions, 1365 deletions
diff --git a/app-emulation/vmware-modules/ChangeLog b/app-emulation/vmware-modules/ChangeLog index dfde308b3bad..62499732a95b 100644 --- a/app-emulation/vmware-modules/ChangeLog +++ b/app-emulation/vmware-modules/ChangeLog @@ -1,6 +1,11 @@ # ChangeLog for app-emulation/vmware-modules # Copyright 1999-2009 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/app-emulation/vmware-modules/ChangeLog,v 1.48 2009/08/28 14:27:56 vadimk Exp $ +# $Header: /var/cvsroot/gentoo-x86/app-emulation/vmware-modules/ChangeLog,v 1.49 2009/09/02 02:13:31 vadimk Exp $ + + 02 Sep 2009; Vadim Kuznetsov vadimk@gentoo.org + -files/patches/vmmon/050_all_kernel-2.6.29.patch, + -files/patches/vmnet/040_all_kernel-2.6.29.patch: + revert previous commit. Bug 273173 28 Aug 2009; Vadim Kuznetsov vadimk@gentoo.org +files/patches/vmmon/050_all_kernel-2.6.29.patch, diff --git a/app-emulation/vmware-modules/Manifest b/app-emulation/vmware-modules/Manifest index 77ec5d567371..7b6541a14637 100644 --- a/app-emulation/vmware-modules/Manifest +++ b/app-emulation/vmware-modules/Manifest @@ -11,11 +11,9 @@ AUX patches/vmblock/010_all_kernel-2.6.25.patch 2398 RMD160 d0a3464f03486eda983b AUX patches/vmmon/030_all_fix-linux-headers.patch 472 RMD160 164b926b0cf53c1a695e7d9ee3e52c5bc1305443 SHA1 b2e485bd21c4106cccc00293df20bce6917e62a4 SHA256 092254308afc9848fd5cc63fb691ee67103fe6413a20e01a568278153d5e876c AUX patches/vmmon/035_all_kernel-2.6.25.patch 541 RMD160 fb0ec4af96238541ef3d5c6d28436166ccacfe7d SHA1 87b1226bc6b74e35c2945c65c7902c03eafa5058 SHA256 e6bba380c0943ee02b3c19cae340238b0a40614b3f5f840a40516ed05e1d964c AUX patches/vmmon/040_all_kernel-2.6.27.patch 17842 RMD160 b0caa9c331e46d30383d49371972f201689c1276 SHA1 908e15eb2b56c680e4385c89a683287c323512d3 SHA256 249733eb7f6341ba1b3135bea8690ef69f1e300baa24cc69cdc5a54b13426f8f -AUX patches/vmmon/050_all_kernel-2.6.29.patch 33036 RMD160 80ea56013d65529fb920532b35156b233d3604e9 SHA1 258b92fadc59ba55d3e3f6bd620871397890d4c3 SHA256 47c443186c36f57b8dbae460a526647a48b10eba310c8dfbce13d649333e70bd AUX patches/vmnet/021_all_wireless_fix.patch 668 RMD160 dbcd47fc4749b36417d028a5701b831035853d9e SHA1 a3e714383be2e0abbc434d5f3ef5253b72978c81 SHA256 231e4c15eb67753da10c01cfebecd851a01f6956263df69e4fb5a9a42957ff60 AUX patches/vmnet/025_all_kernel-2.6.25.patch 939 RMD160 c7f9f0b9e7bf98b4b37db70926c1c463874e8458 SHA1 43f8f9a5a0b9a28223ad901afd5b45749447bdc4 SHA256 a3247b261376f7cde78724d5704c4ea2511d54644f9c2b776b41f19d261cba17 AUX patches/vmnet/030_all_kernel-2.6.27.patch 2558 RMD160 9ba251de06852c33e4530628679bdf36ea8051bd SHA1 0078be861f34d4b8def9fcf38385e8c335cbc909 SHA256 b4bc5e5c1030bd5341ef60500dece1d0b6b1f4e553cb566c1ba5506ed6dbb03f -AUX patches/vmnet/040_all_kernel-2.6.29.patch 13107 RMD160 2a1530af65a631031af22a8f805ba5c312e0939e SHA1 ba75255162636d89a72459a01b75c93e2a99ef1b SHA256 950ebaecb63a180c7cdf8f1972cf3da66e6da2e404e3961d639004e0fcbe8450 DIST vmware-any-any-update115.tar.gz 493641 RMD160 56cabe56f70c01a22a7671e861cc5a2df19855c7 SHA1 ff9b6fdf6ca74495eb5f4822a1854fc91185377c SHA256 b1c14fa9514663b85c2efe8331407e71cce96e5a21a8b941fa570c960bbdcaa1 DIST vmware-modules-1.0.0.23-r1.amd64.tar.bz2 486989 RMD160 12f197294b4df7bf15935ef9d44d7c809a5d88aa SHA1 51436cfd97311eb5d1430b390d2d98a27bf47494 SHA256 b062c7505e0251ce5352c40d081a62989e6fa5f6441b737bbeb6c4471867686e DIST vmware-modules-1.0.0.23-r1.x86.tar.bz2 487101 RMD160 f69475312cbaeb0afccc46e8465dfbed7bee49d2 SHA1 f2b23a2adcfc8fde3cd26f1a75e504c82010bb10 SHA256 5fb5eb11d26e86a62018a57e6afe975f32ce9a7b0ec1069ed1f756e034337b6b @@ -31,5 +29,5 @@ EBUILD vmware-modules-1.0.0.23-r1.ebuild 817 RMD160 e126704918b1c106185e7743006c EBUILD vmware-modules-1.0.0.23.ebuild 724 RMD160 35c62995060e0c709dbd690ef63c48a431dfae8a SHA1 6ea6e450fd540c772f5c7227056848f8513939c2 SHA256 a132d0c74e914ff65e0cef0bdbe54e4e9e05e59ad7d1dc72e404d568bd0e31f4 EBUILD vmware-modules-1.0.0.24.ebuild 1869 RMD160 365eaf6f73a6bc3a9fb89104124fd31760dd3c2f SHA1 f36147072ac47de26f64153b834fcf553bfaf1f8 SHA256 5f7c3ac912d9d1c95c49d946c5f16639967a1e4ebaeae5ef5d0c5910cd89ab2f EBUILD vmware-modules-1.0.0.25.ebuild 1793 RMD160 f0d53f25710fe0a07594ad2567f6243defd7f940 SHA1 72e1c8dfd0bd62b4e22f39308382853bcaed840a SHA256 166a7c141f878e2adcf3630da17b2361fd2ed0f32456ce875b6f2115f83db25f -MISC ChangeLog 11132 RMD160 f4da9dd7a83a0b43e8e09ef7560f565028eba17c SHA1 41c0b41b15ac4b56cc26b33ce15393cc753045e4 SHA256 f39888eadbc8fc862f915acf26a532cb193eeb10c7ce66c31a96951c173ea8ed +MISC ChangeLog 11323 RMD160 16cc28eb104d461178b474fd153857d6b25656e4 SHA1 578e4969b7876769873a850b2565caef3e21ed3f SHA256 75c040b7cd708628b8615c5071da6d8f4b66ceef69214c73f24cddb85baaf92a MISC metadata.xml 288 RMD160 da2ee1499dd87693b63592a337d8352494cb9652 SHA1 e1b50a587afb7878e21828a957a6838e7d08e4e8 SHA256 100017b3059be218965923798780ab195dafaa893f98088592fb5b299e686c37 diff --git a/app-emulation/vmware-modules/files/patches/vmmon/050_all_kernel-2.6.29.patch b/app-emulation/vmware-modules/files/patches/vmmon/050_all_kernel-2.6.29.patch deleted file mode 100644 index a1ba8ec86841..000000000000 --- a/app-emulation/vmware-modules/files/patches/vmmon/050_all_kernel-2.6.29.patch +++ /dev/null @@ -1,1006 +0,0 @@ -diff -ruN vmmon-only-patched/autoconf/smpcall.c vmmon-only-rerefixed/autoconf/smpcall.c ---- vmmon-only-patched/autoconf/smpcall.c 1970-01-01 02:00:00.000000000 +0200 -+++ vmmon-only-rerefixed/autoconf/smpcall.c 2008-10-20 15:52:46.000000000 +0300 -@@ -0,0 +1,23 @@ -+/* ********************************************************** -+ * Copyright (C) 2008 VMware, Inc. All Rights Reserved. -- VMware Confidential -+ * **********************************************************/ -+ -+/* -+ * Detect whether smp_call_function has 4 or 3 arguments. -+ * Change happened between 2.6.26 and 2.6.27-rc1. -+ */ -+ -+#include <linux/autoconf.h> -+#include <linux/version.h> -+ -+#if LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 26) -+# error This compile test intentionally fails. -+#elif LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 27) -+# include <linux/smp.h> -+ -+int -+vmware_smp_call_function(void (*func)(void *info), void *info, int wait) -+{ -+ return smp_call_function(func, info, wait); -+} -+#endif -diff -ruN vmmon-only-patched/common/cpuid.c vmmon-only-rerefixed/common/cpuid.c ---- vmmon-only-patched/common/cpuid.c 2009-07-08 16:21:02.000000000 +0300 -+++ vmmon-only-rerefixed/common/cpuid.c 2008-10-20 16:23:37.000000000 +0300 -@@ -8,7 +8,6 @@ - - # include <linux/string.h> - #endif -- - #include "vmware.h" - #include "vm_assert.h" - #include "x86.h" -diff -ruN vmmon-only-patched/common/task.c vmmon-only-rerefixed/common/task.c ---- vmmon-only-patched/common/task.c 2009-07-08 16:21:02.000000000 +0300 -+++ vmmon-only-rerefixed/common/task.c 2008-10-20 16:09:29.000000000 +0300 -@@ -25,16 +25,13 @@ - * we do not need asm/page.h anymore in this file - not surprising, this - * is common file, yes? And Windows do not have page.h, do they? - */ --#include <linux/version.h> --#if LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 25) --#define _I386_PAGE_H --#else --#define _ASM_X86_PAGE_H --#endif -+#define _ASM_X86_PAGE_H - /* On Linux, must come before any inclusion of asm/page.h --hpreg */ --#include "hostKernel.h" - #ifdef linux -+#include "hostKernel.h" -+#include "driver-config.h" - # include <linux/string.h> -+//# include <linux/kernel.h> - - # ifdef USE_PERFCTRS_HOSTED - # include "perfctr.h" -diff -ruN vmmon-only-patched/common/task_compat.h vmmon-only-rerefixed/common/task_compat.h ---- vmmon-only-patched/common/task_compat.h 2009-07-08 16:21:02.000000000 +0300 -+++ vmmon-only-rerefixed/common/task_compat.h 2008-10-20 16:15:25.000000000 +0300 -@@ -1,7 +1,8 @@ -+#include <linux/init.h> - #include "modulecall_compat.h" - #include "x86msr.h" - --typedef struct SysenterStateV45 { -+struct SysenterStateV45 { - uint64 rsp; - uint64 rip; - Selector cs; -@@ -3646,5 +3647,6 @@ - return TRUE; - } - -+// printk("/dev/vmmon: Cannot load module. Use standard gcc compiler\n"); - return FALSE; - } -diff -ruN vmmon-only-patched/include/compat_semaphore.h vmmon-only-rerefixed/include/compat_semaphore.h ---- vmmon-only-patched/include/compat_semaphore.h 2009-07-08 16:21:02.000000000 +0300 -+++ vmmon-only-rerefixed/include/compat_semaphore.h 2008-10-20 14:15:58.000000000 +0300 -@@ -2,11 +2,7 @@ - # define __COMPAT_SEMAPHORE_H__ - - --#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 27) - #include <linux/semaphore.h> --#else --#include <asm/semaphore.h> --#endif - - - /* -diff -ruN vmmon-only-patched/include/compat_wait.h vmmon-only-rerefixed/include/compat_wait.h ---- vmmon-only-patched/include/compat_wait.h 2009-07-08 16:21:02.000000000 +0300 -+++ vmmon-only-rerefixed/include/compat_wait.h 2009-04-03 19:58:51.000000000 +0300 -@@ -34,13 +34,13 @@ - * 2.4.20-wolk4.0s. - */ - --#ifdef VMW_HAVE_EPOLL // { -+#if VMW_HAVE_EPOLL // { - #define compat_poll_wqueues struct poll_wqueues - #else // } { - #define compat_poll_wqueues poll_table - #endif // } - --#ifdef VMW_HAVE_EPOLL // { -+#if VMW_HAVE_EPOLL // { - - /* If prototype does not match, build will abort here */ - extern void poll_initwait(compat_poll_wqueues *); -@@ -57,7 +57,8 @@ - #elif LINUX_VERSION_CODE >= KERNEL_VERSION(2, 4, 0) // { - - /* If prototype does not match, build will abort here */ --extern void poll_initwait(compat_poll_wqueues *); -+//extern void poll_initwait(compat_poll_wqueues *); -+extern void poll_initwait(struct poll_wqueues *pwq); - - #define compat_poll_initwait(wait, table) ( \ - (wait) = (table), \ -diff -ruN vmmon-only-patched/include/vcpuset.h vmmon-only-rerefixed/include/vcpuset.h ---- vmmon-only-patched/include/vcpuset.h 2009-07-08 16:21:02.000000000 +0300 -+++ vmmon-only-rerefixed/include/vcpuset.h 2009-04-21 13:46:14.000000000 +0300 -@@ -71,9 +71,7 @@ - #define ffs(x) ffs_x86_64(x) - - #elif defined MODULE --#ifndef __cplusplus -- #include "linux/bitops.h" --#else -+ //#include <linux/bitops.h> - static inline int ffs_x86_hack(int x) - { - int r; -@@ -91,7 +89,7 @@ - } - - #define ffs(x) ffs_x86_hack(x) --#endif -+ - #elif defined __APPLE__ && defined KERNEL - /* - * XXXMACOS An ugly hack to resolve redefinition of PAGE_ defines -diff -ruN vmmon-only-patched/include/x86apic.h vmmon-only-rerefixed/include/x86apic.h ---- vmmon-only-patched/include/x86apic.h 2009-07-08 16:21:02.000000000 +0300 -+++ vmmon-only-rerefixed/include/x86apic.h 2009-04-20 19:50:19.000000000 +0300 -@@ -77,7 +77,7 @@ - #define APIC_LVT_DELVMODE(_lvt) (_lvt & 0x700) - #define APIC_LVT_RESET_VALUE 0x00010000 - --#define APIC_BASE_MSR 0x1b -+//#define APIC_BASE_MSR 0x1b - - #define APIC_MSR_BASEMASK QWORD(0x0000000f,0xfffff000) - #define APIC_MSR_ENABLED 0x00000800 -diff -ruN vmmon-only-patched/include/x86paging.h vmmon-only-rerefixed/include/x86paging.h ---- vmmon-only-patched/include/x86paging.h 2009-07-08 16:21:02.000000000 +0300 -+++ vmmon-only-rerefixed/include/x86paging.h 2008-10-20 14:15:49.000000000 +0300 -@@ -58,9 +58,7 @@ - - #define PTE_AVAIL_MASK 0xe00 - #define PTE_AVAIL_SHIFT 9 --#if LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 27) --#define PTE_PFN_MASK 0xfffff000 --#endif -+//#define PTE_PFN_MASK 0xfffff000 - #define PAE_PTE_PFN_MASK CONST64U(0xffffff000) - #define LM_PTE_PFN_MASK CONST64U(0xffffffffff000) - #define PTE_PFN_SHIFT 12 -diff -ruN vmmon-only-patched/linux/driver.c vmmon-only-rerefixed/linux/driver.c ---- vmmon-only-patched/linux/driver.c 2009-07-08 16:21:02.000000000 +0300 -+++ vmmon-only-rerefixed/linux/driver.c 2009-05-19 16:02:02.000000000 +0300 -@@ -113,15 +113,6 @@ - #define VMWare_SetVTracer(VTrace_Set) - #endif - --#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 24) --#define VMW_NOPAGE_2624 -- --#define VMMON_MAP_OFFSET_SHIFT 0 --#define VMMON_MAP_OFFSET_MASK 0x00000FFF --#define VMMON_MAP_OFFSET(base) \ -- (((base) >> VMMON_MAP_OFFSET_SHIFT) & VMMON_MAP_OFFSET_MASK) --#endif -- - struct VMXLinuxState linuxState; - - static int vmversion = VME_DEFAULT; -@@ -157,10 +148,8 @@ - - static int LinuxDriver_Close(struct inode *inode, struct file *filp); - static unsigned int LinuxDriverPoll(struct file *file, poll_table *wait); --#if defined(VMW_NOPAGE_2624) --static int LinuxDriverFault(struct vm_area_struct *vma, struct vm_fault *fault); --static int LinuxDriverLockedFault(struct vm_area_struct *vma, struct vm_fault *fault); --#elif defined(VMW_NOPAGE_261) -+#if 0 -+#if defined(VMW_NOPAGE_261) - static struct page *LinuxDriverNoPage(struct vm_area_struct *vma, - unsigned long address, int *type); - static struct page *LinuxDriverLockedNoPage(struct vm_area_struct *vma, -@@ -171,29 +160,36 @@ - static struct page *LinuxDriverLockedNoPage(struct vm_area_struct *vma, - unsigned long address, int unused); - #else --static unsigned long LinuxDriverNoPage(struct vm_area_struct *vma, -- unsigned long address, int write_access); --static unsigned long LinuxDriverLockedNoPage(struct vm_area_struct *vma, -- unsigned long address, int unused); - #endif --static int LinuxDriverMmap(struct file *filp, struct vm_area_struct *vma); -+static int LinuxDriverNoPage(struct vm_area_struct *vma, -+ struct vm_fault *fdata); -+static int LinuxDriverLockedNoPage(struct vm_area_struct *vma, -+ struct vm_fault *fdata); -+ - --static void LinuxDriverPollTimeout(unsigned long clientData); - - static struct vm_operations_struct vmuser_mops = { --#ifdef VMW_NOPAGE_2624 -- .fault = LinuxDriverFault --#else -- .nopage = LinuxDriverNoPage --#endif -+ .fault = LinuxDriverNoPage - }; - - struct vm_operations_struct vmuser_locked_mops = { --#ifdef VMW_NOPAGE_2624 -- .fault = LinuxDriverLockedFault --#else -- .nopage = LinuxDriverLockedNoPage -+ .fault = LinuxDriverLockedNoPage -+}; - #endif -+static void LinuxDriverPollTimeout(unsigned long clientData); -+static int LinuxDriverMmap(struct file *filp, struct vm_area_struct *vma); -+ -+static int LinuxDriverNoPage(struct vm_area_struct *vma, -+ struct vm_fault *fdata); -+static int LinuxDriverLockedNoPage(struct vm_area_struct *vma, -+ struct vm_fault *fdata); -+ -+static struct vm_operations_struct vmuser_mops = { -+ .fault = LinuxDriverNoPage -+}; -+ -+struct vm_operations_struct vmuser_locked_mops = { -+ .fault = LinuxDriverLockedNoPage - }; - - static struct file_operations vmuser_fops; -@@ -576,7 +572,7 @@ - memset(vmLinux, 0, sizeof *vmLinux); - vmLinux->version = LinuxDriverEmulatedVersion(); - /* If caller's euid was not 0, we are running devel build */ -- vmLinux->maySetUid = current->euid != 0; -+ vmLinux->maySetUid = current->cred->euid != 0; - vmLinux->ctType = VMCIOBJ_NOT_SET; - - sema_init(&vmLinux->lock4Gb, 1); -@@ -1164,53 +1160,22 @@ - *----------------------------------------------------------------------------- - */ - --#if defined(VMW_NOPAGE_2624) --static int LinuxDriverFault(struct vm_area_struct *vma, //IN -- struct vm_fault *fault) //IN/OUT --#elif defined(VMW_NOPAGE_261) --static struct page *LinuxDriverNoPage(struct vm_area_struct *vma, //IN -- unsigned long address, //IN -- int *type) //OUT: Fault type --#elif defined(KERNEL_2_4_0) --static struct page *LinuxDriverNoPage(struct vm_area_struct *vma, //IN -- unsigned long address, //IN -- int unused) //nothing --#else --static unsigned long LinuxDriverNoPage(struct vm_area_struct *vma,//IN -- unsigned long address, //IN -- int write_access) //IN --#endif -+static int LinuxDriverNoPage(struct vm_area_struct *vma,//IN -+ struct vm_fault *fdata) - { - VMLinux *vmLinux = (VMLinux *) vma->vm_file->private_data; - unsigned long pg; - struct page* page; - --#ifdef VMW_NOPAGE_2624 -- pg = fault->pgoff; --#else -- pg = ((address - vma->vm_start) >> PAGE_SHIFT) + compat_vm_pgoff(vma); --#endif -+ pg = fdata->pgoff; - pg = VMMON_MAP_OFFSET(pg); - if (pg >= vmLinux->size4Gb) { --#ifdef VMW_NOPAGE_2624 -- return VM_FAULT_SIGBUS; --#else - return 0; --#endif - } - page = vmLinux->pages4Gb[pg]; - get_page(page); --#ifdef VMW_NOPAGE_2624 -- fault->page = page; -- return 0; --#elif defined(KERNEL_2_4_0) --#ifdef VMW_NOPAGE_261 -- *type = VM_FAULT_MINOR; --#endif -- return page; --#else -- return page_address(page); --#endif -+ fdata->page = page; -+ return VM_FAULT_MINOR; - } - - -@@ -1393,6 +1358,7 @@ - VMLinux *vmLinux = (VMLinux *) filp->private_data; - int retval = 0; - Vcpuid vcpuid; -+ struct cred *new; - - switch (iocmd) { - case IOCTL_VMX86_VERSION: -@@ -1527,8 +1493,14 @@ - devel_suid(); - #else - if (vmLinux->maySetUid) { -- current->suid = 0; -- cap_set_full(current->cap_permitted); -+ new = prepare_creds(); -+ if (!new) { -+ retval = -ENOMEM; -+ break; -+ } -+ new->suid = 0; -+ cap_set_full(new->cap_permitted); -+ commit_creds(new); - retval = 0; - } else { - retval = -EPERM; -@@ -1793,10 +1765,10 @@ - } - - case IOCTL_VMX86_ALLOW_CORE_DUMP: -- if (current->euid == current->uid && -- current->fsuid == current->uid && -- current->egid == current->gid && -- current->fsgid == current->gid) { -+ if (new->euid == current_uid() && -+ new->fsuid == current_uid() && -+ new->egid == new->gid && -+ new->fsgid == new->gid) { - #if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 23) || defined(MMF_DUMPABLE) - /* Dump core, readable by user. */ - set_bit(MMF_DUMPABLE, ¤t->mm->flags); -@@ -1813,7 +1785,7 @@ - break; - - case IOCTL_VMX86_BROADCAST_IPI: -- retval = compat_smp_call_function(LinuxDriverIPIHandler, NULL, 1, 1); -+ retval = compat_smp_call_function(LinuxDriverIPIHandler, NULL, 1); - break; - - #ifdef USE_PERFCTRS_HOSTED -diff -ruN vmmon-only-patched/linux/driver_compat.h vmmon-only-rerefixed/linux/driver_compat.h ---- vmmon-only-patched/linux/driver_compat.h 2009-07-08 16:21:02.000000000 +0300 -+++ vmmon-only-rerefixed/linux/driver_compat.h 2008-07-24 18:55:05.000000000 +0300 -@@ -268,22 +268,8 @@ - *----------------------------------------------------------------------------- - */ - --#if defined(VMW_NOPAGE_2624) --static int LinuxDriverLockedFault(struct vm_area_struct *vma, //IN -- struct vm_fault *fault) //IN/OUT --#elif defined(VMW_NOPAGE_261) --static struct page *LinuxDriverLockedNoPage(struct vm_area_struct *vma, //IN -- unsigned long address, //IN -- int *type) //OUT: Fault type --#elif defined(KERNEL_2_4_0) --static struct page *LinuxDriverLockedNoPage(struct vm_area_struct *vma, //IN -- unsigned long address, //IN -- int unused) //nothing --#else --static unsigned long LinuxDriverLockedNoPage(struct vm_area_struct *vma, //IN -- unsigned long address, //IN -- int unused) //nothing --#endif -+static int LinuxDriverLockedNoPage(struct vm_area_struct *vma, //IN -+ struct vm_fault *fdata) - { - VMLinux *vmLinux = (VMLinux *) vma->vm_file->private_data; - unsigned long pg; -@@ -291,67 +277,34 @@ - struct VMHostEntry* vmhe; - struct page* result; - --#ifdef VMW_NOPAGE_2624 -- pg = fault->pgoff; --#else -- pg = ((address - vma->vm_start) >> PAGE_SHIFT) + compat_vm_pgoff(vma); --#endif -+ pg = fdata->pgoff; - if (pg >= vmLinux->sizeLocked) { - printk(KERN_DEBUG "vmmon: Something went wrong: entry %08lX out of range (>=%08X) for mapping on filp %p\n", pg, vmLinux->sizeLocked, vmLinux); --#ifdef VMW_NOPAGE_2624 -- return VM_FAULT_SIGBUS; --#else - return NOPAGE_SIGBUS; --#endif - } - if (!vmLinux->vm || !vmLinux->vm->vmhost) { - printk(KERN_DEBUG "vmmon: Something went wrong: no vm or vmhost for mapping on filp %p\n", vmLinux); --#ifdef VMW_NOPAGE_2624 -- return VM_FAULT_SIGBUS; --#else - return NOPAGE_SIGBUS; --#endif - } - pgt = vmLinux->pagesLocked->ent[pg / VMHOST_MAPPING_PT]; - if (!pgt) { - printk(KERN_DEBUG "vmmon: Something went wrong: missing entry %08lX from mapping on filp %p\n", pg, vmLinux); --#ifdef VMW_NOPAGE_2624 -- return VM_FAULT_SIGBUS; --#else - return NOPAGE_SIGBUS; --#endif - } - vmhe = kmap(pgt); - result = vmhe->ent[pg % VMHOST_MAPPING_PT]; - kunmap(pgt); - if (!result) { - printk(KERN_DEBUG "vmmon: Something went wrong: attempt to access non-existing entry %08lX in mapping on filp %p\n", pg, vmLinux); --#ifdef VMW_NOPAGE_2624 -- return VM_FAULT_SIGBUS; --#else - return NOPAGE_SIGBUS; --#endif - } - if (!PhysTrack_Test(vmLinux->vm->vmhost->AWEPages, page_to_pfn(result))) { - printk(KERN_DEBUG "vmmon: MPN %08lX not tracked! Someone released it before removing it from VA first!\n", pg); --#ifdef VMW_NOPAGE_2624 -- return VM_FAULT_SIGBUS; --#else - return NOPAGE_SIGBUS; --#endif - } - get_page(result); --#if defined(VMW_NOPAGE_2624) -- fault->page = result; -- return 0; --#elif defined(KERNEL_2_4_0) --#ifdef VMW_NOPAGE_261 -- *type = VM_FAULT_MINOR; --#endif -- return result; --#else -- return page_address(result); --#endif -+ fdata->page = result; -+ return VM_FAULT_MINOR; - } - - -diff -ruN vmmon-only-patched/linux/driver.h vmmon-only-rerefixed/linux/driver.h ---- vmmon-only-patched/linux/driver.h 2009-07-08 16:21:02.000000000 +0300 -+++ vmmon-only-rerefixed/linux/driver.h 2008-10-20 14:21:26.000000000 +0300 -@@ -90,7 +90,7 @@ - struct VMLinux **pollBack; - } VMLinux; - --extern struct vm_operations_struct vmuser_locked_mops; -+//extern struct vm_operations_struct vmuser_locked_mops; - #define VMHOST_MAPPING_PD (PAGE_SIZE / sizeof(void*)) - #define VMHOST_MAPPING_PT (PAGE_SIZE / sizeof(void*)) - struct VMHostEntry { -@@ -131,6 +131,7 @@ - spinlock_t pollListLock; - #endif - -+// volatile int fastClockThread; - volatile struct task_struct *fastClockThread; - unsigned fastClockRate; - -diff -ruN vmmon-only-patched/linux/hostif.c vmmon-only-rerefixed/linux/hostif.c ---- vmmon-only-patched/linux/hostif.c 2009-07-08 16:21:02.000000000 +0300 -+++ vmmon-only-rerefixed/linux/hostif.c 2009-04-21 17:47:54.000000000 +0300 -@@ -18,6 +18,7 @@ - #include "compat_page.h" - #include <linux/binfmts.h> - #include <linux/fs.h> -+#include <linux/kthread.h> - #include "compat_sched.h" - #include <linux/file.h> - #ifdef KERNEL_2_2 -@@ -70,10 +71,6 @@ - #include "compat_timer.h" - #include "x86.h" - --#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 24) --#include <linux/kthread.h> --#include <linux/mutex.h> --#endif - static COMPAT_DECLARE_COMPLETION(fastClockExited); - - /* -@@ -140,95 +137,6 @@ - #define HOST_ISTRACKED_PFN(_vm, _pfn) (PhysTrack_Test(_vm->physTracker, _pfn)) - - --#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 24)) --/* -- *----------------------------------------------------------------------------- -- * -- * MutexInit -- -- * -- * Initialize a Mutex. --hpreg -- * -- * Results: -- * None -- * -- * Side effects: -- * None -- * -- *----------------------------------------------------------------------------- -- */ -- --#define MutexInit(_mutex, _name) mutex_init(_mutex) --/* -- *----------------------------------------------------------------------------- -- * -- * MutexIsLocked -- -- * -- * Determine if a Mutex is locked by the current thread. --hpreg -- * -- * Results: -- * TRUE if yes -- * FALSE if no -- * -- * Side effects: -- * None -- * -- *----------------------------------------------------------------------------- -- */ -- --#define MutexIsLocked(_mutex) mutex_is_locked(_mutex) -- --/* -- *----------------------------------------------------------------------------- -- * -- * MutexLock -- -- * -- * Acquire a Mutex. --hpreg -- * -- * Results: -- * None -- * -- * Side effects: -- * None -- * -- *----------------------------------------------------------------------------- -- */ -- --#define MutexLock(_mutex, _callerID) mutex_lock(_mutex) -- --/* -- *----------------------------------------------------------------------------- -- * -- * MutexUnlock -- -- * -- * Release a Mutex. --hpreg -- * -- * Results: -- * None -- * -- * Side effects: -- * None -- * -- *----------------------------------------------------------------------------- -- */ -- --#define MutexUnlock(_mutex, _callerID) mutex_unlock(_mutex) -- --/* This mutex protects the driver-wide state. --hpreg */ --static DEFINE_MUTEX(globalMutex); -- --/* -- * This mutex protects the fast clock rate and is held while -- * creating/destroying the fastClockThread. It ranks below -- * globalMutex. We can't use globalMutex for this purpose because the -- * fastClockThread itself acquires the globalMutex, so trying to hold -- * the mutex while destroying the thread can cause a deadlock. -- */ --static DEFINE_MUTEX(fastClockMutex); -- --/* This mutex protects linuxState.pollList. */ --static DEFINE_MUTEX(pollListMutex); -- --#else - /* - *----------------------------------------------------------------------------- - * -@@ -371,7 +279,6 @@ - /* This mutex protects linuxState.pollList. */ - static Mutex pollListMutex; - --#endif /* USE_KTHREAD */ - - /* - *----------------------------------------------------------------------------- -@@ -444,7 +351,7 @@ - MutexUnlock(&globalMutex, callerID); - } - --#if LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 24) -+ - #ifdef VMX86_DEBUG - /* - *----------------------------------------------------------------------------- -@@ -469,7 +376,6 @@ - return MutexIsLocked(&globalMutex); - } - #endif --#endif - - - /* -@@ -564,7 +470,6 @@ - MutexUnlock(&pollListMutex, callerID); - } - -- - #if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 4, 3) - static INLINE void - down_write_mmap(void) -@@ -620,7 +525,6 @@ - up_write_mmap(); - } - #endif -- - /* - *---------------------------------------------------------------------- - * -@@ -678,7 +582,7 @@ - #else - pte_val(*pte) &= ~_PAGE_NX; - #endif -- compat_smp_call_function (TLBInvalidatePage, (void *)vaddr, 1, 1); -+ smp_call_function (TLBInvalidatePage, (void *)vaddr, 1); - TLBInvalidatePage((void *)vaddr); - } - if (ptemap) { -@@ -2911,7 +2815,7 @@ - if (targetHostCpu != INVALID_HOST_CPU) { - ASSERT(targetHostCpu < MAX_PROCESSORS); - (void) compat_smp_call_function(LinuxDriverIPIHandler, -- NULL, 1, 1); -+ NULL, 1); - return TRUE; - } - } -@@ -3099,7 +3003,7 @@ - { - compat_preempt_disable(); - HostIFFillCPUID((void*)info); -- (void)compat_smp_call_function(HostIFFillCPUID, (void*)info, 1, 1); -+ (void)compat_smp_call_function(HostIFFillCPUID, (void*)info, 1); - compat_preempt_enable(); - } - -@@ -3136,7 +3040,7 @@ - compat_preempt_disable(); - HostIFBrokenCPUHelper((void*)&badcpumask); // run on this machine CPU - (void)compat_smp_call_function(HostIFBrokenCPUHelper, (void*)&badcpumask, -- 1, 1); // run on all other machine CPUs -+ 1); // run on all other machine CPUs - compat_preempt_enable(); - - return badcpumask; -@@ -3335,46 +3239,6 @@ - /* - *---------------------------------------------------------------------- - * -- * HostIFDoIoctl -- -- * -- * Issue ioctl. Assume kernel is not locked. It is not true now, -- * but it makes things easier to understand, and won't surprise us -- * later when we get rid of kernel lock from our code. -- * -- * Results: -- * Same as ioctl method. -- * -- * Side effects: -- * none. -- * -- *---------------------------------------------------------------------- -- */ -- --static long --HostIFDoIoctl(struct file *filp, -- u_int iocmd, -- unsigned long ioarg) --{ --#ifdef HAVE_UNLOCKED_IOCTL -- if (filp->f_op->unlocked_ioctl) { -- return filp->f_op->unlocked_ioctl(filp, iocmd, ioarg); -- } --#endif -- if (filp->f_op->ioctl) { -- long err; -- -- lock_kernel(); -- err = filp->f_op->ioctl(filp->f_dentry->d_inode, filp, iocmd, ioarg); -- unlock_kernel(); -- return err; -- } -- return -ENOIOCTLCMD; --} -- -- --/* -- *---------------------------------------------------------------------- -- * - * HostIFFastClockThread -- - * - * Kernel thread that provides finer-grained wakeups than the -@@ -3399,15 +3263,19 @@ - int res; - mm_segment_t oldFS; - unsigned rate = 0; -+ struct cred *cred; - --#if LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 24) - compat_daemonize("vmware-rtc"); --#endif - oldFS = get_fs(); - set_fs(KERNEL_DS); - compat_allow_signal(SIGKILL); -- cap_raise(current->cap_effective, CAP_SYS_RESOURCE); -- compat_set_user_nice(current, -20); -+ cred = prepare_creds(); -+ if(!cred) -+ return -ENOMEM; -+ cap_raise(cred->cap_effective, CAP_SYS_RESOURCE); -+ commit_creds(cred); -+ -+ //compat_set_user_nice(current, -20); - - while (linuxState.fastClockRate > HZ + HZ/16) { - unsigned long buf; -@@ -3423,7 +3291,8 @@ - p2rate <<= 1; - } - -- res = HostIFDoIoctl(filp, RTC_IRQP_SET, p2rate); -+ res = filp->f_op->ioctl(filp->f_dentry->d_inode, -+ filp, RTC_IRQP_SET, p2rate); - if (res < 0) { - Warning("/dev/rtc set rate %d failed: %d\n", p2rate, res); - goto out; -@@ -3526,31 +3395,54 @@ - if (rate > HZ + HZ/16) { - if (!linuxState.fastClockThread) { - struct file *filp; -+ struct cred *cred; - int fsuid, res; - Bool cap; -- struct task_struct *t; -+ struct task_struct *t; - -- fsuid = current->fsuid; -+ /*fsuid = current->fsuid; - current->fsuid = 0; -+ */ -+ cred = prepare_creds(); -+ fsuid = cred->fsuid; -+ cred->fsuid = 0; -+ commit_creds(cred); - filp = filp_open("/dev/rtc", O_RDONLY, 0); -- current->fsuid = fsuid; -+ cred = prepare_creds(); -+ cred->fsuid = fsuid; -+ commit_creds(cred); -+ //current->fsuid = fsuid; - if (IS_ERR(filp) || !filp) { - Warning("/dev/rtc open failed: %d\n", (int)(VA)filp); - return -(int)(VA)filp; - } -- cap = cap_raised(current->cap_effective, CAP_SYS_RESOURCE); -+ /* cap = cap_raised(current->cap_effective, CAP_SYS_RESOURCE); - cap_raise(current->cap_effective, CAP_SYS_RESOURCE); -- res = HostIFDoIoctl(filp, RTC_PIE_ON, 0); -+*/ -+ cred = prepare_creds(); -+ cap = cap_raised(cred->cap_effective, CAP_SYS_RESOURCE); -+ cap_raise(cred->cap_effective, CAP_SYS_RESOURCE); -+ commit_creds(cred); -+ if (filp->f_op->ioctl) { -+ lock_kernel(); -+ res = filp->f_op->ioctl(filp->f_path.dentry->d_inode, filp, RTC_PIE_ON, 0); -+ unlock_kernel(); -+ } -+ else -+ res = -1; - if (!cap) { -- cap_lower(current->cap_effective, CAP_SYS_RESOURCE); -+ cred = prepare_creds(); -+ // cap_lower(current->cap_effective, CAP_SYS_RESOURCE); -+ cap_lower(cred->cap_effective, CAP_SYS_RESOURCE); -+ commit_creds(cred); - } - if (res < 0) { - Warning("/dev/rtc enable interrupt failed: %d\n", res); - compat_filp_close(filp, current->files); - return -res; - } -- t = kthread_create(HostIFFastClockThread, filp, "vmware-rtc"); -- if (IS_ERR(t)) { -+ t = kthread_create(HostIFFastClockThread, filp, "vmware-rtc"); -+ if (IS_ERR(t)) { - /* - * Ignore ERESTARTNOINTR silently, it occurs when signal is - * pending, and syscall layer automatically reissues operation -@@ -3563,11 +3455,11 @@ - return -PTR_ERR(t); - } - linuxState.fastClockThread = t; -- wake_up_process(t); -+ wake_up_process(t); - } - } else { - if (linuxState.fastClockThread) { -- send_sig(SIGKILL, linuxState.fastClockThread, 1); -+ send_sig(SIGKILL, linuxState.fastClockThread, 1); - compat_wait_for_completion(&fastClockExited); - linuxState.fastClockThread = NULL; - } -diff -ruN vmmon-only-patched/linux/hostif_compat.h vmmon-only-rerefixed/linux/hostif_compat.h ---- vmmon-only-patched/linux/hostif_compat.h 2009-07-08 16:21:02.000000000 +0300 -+++ vmmon-only-rerefixed/linux/hostif_compat.h 2009-04-21 13:45:08.000000000 +0300 -@@ -93,11 +93,13 @@ - } - return -EFAULT; - } -+ /* - if (vma->vm_ops != &vmuser_locked_mops) { - printk(KERN_DEBUG "Found non-vmmon VMA (%#lX-%#lX) for VA %p\n", - vma->vm_start, vma->vm_end, (void*)va); - return -EINVAL; - } -+ */ - vmLinux = (VMLinux*)vma->vm_file->private_data; - if (!vmLinux) { - printk(KERN_DEBUG "Found vmmon VMA (%#lX-%#lX) for VA %p" -@@ -367,7 +369,7 @@ - { - compat_preempt_disable(); - HostIFSystemCallResetMSR(regs); -- (void)compat_smp_call_function(HostIFSystemCallResetMSR, (void *)regs, 1, 1); -+ (void)compat_smp_call_function(HostIFSystemCallResetMSR, (void *)regs, 1); - compat_preempt_enable(); - } - -@@ -775,7 +777,8 @@ - } - } - -- mpn = PgtblVa2MPN(__fix_to_virt(VMWARE__FIX_IO_APIC_BASE)); -+ //mpn = PgtblVa2MPN(__fix_to_virt(VMWARE__FIX_IO_APIC_BASE)); -+ mpn = PgtblVa2MPN(__fix_to_virt(FIX_IO_APIC_BASE_0)); - if (mpn == INVALID_MPN) { - return 0; - } -diff -ruN vmmon-only-patched/linux/vmhost.h vmmon-only-rerefixed/linux/vmhost.h ---- vmmon-only-patched/linux/vmhost.h 2009-07-08 16:21:02.000000000 +0300 -+++ vmmon-only-rerefixed/linux/vmhost.h 2005-06-19 04:23:03.000000000 +0300 -@@ -13,7 +13,7 @@ - #include "compat_semaphore.h" - #include "compat_wait.h" - --#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 24) -+ - #ifdef VMX86_DEBUG - /* - * A MutexHolder object. In debug builds, we record information about the -@@ -54,7 +54,7 @@ - MutexHolder cur; - #endif - } Mutex; --#endif -+ - - /* - * Per-vm host-specific state. -@@ -65,11 +65,7 @@ - * Used for shared modifications to VM's VMDriver data, mostly page locking. - * It has higher rank than the global mutex. - */ --#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 24) -- struct mutex vmMutex; --#else - Mutex vmMutex; --#endif - - atomic_t pendingUserCalls; - wait_queue_head_t callQueue; -diff -ruN vmmon-only-patched/linux/vmmonInt.h vmmon-only-rerefixed/linux/vmmonInt.h ---- vmmon-only-patched/linux/vmmonInt.h 2009-07-08 16:21:02.000000000 +0300 -+++ vmmon-only-rerefixed/linux/vmmonInt.h 2009-04-20 19:14:30.000000000 +0300 -@@ -31,16 +31,7 @@ - } while (0) - #endif - --#if defined(CONFIG_SMP) && LINUX_VERSION_CODE >= KERNEL_VERSION(2, 2, 8) --#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 27) --#define compat_smp_call_function(_a0,_a1,_a2,_a3) smp_call_function(_a0,_a1,_a3) --#else --#define compat_smp_call_function smp_call_function --#endif --#else --#define compat_smp_call_function(_a0,_a1,_a2,_a3) 0 --#endif -- -+#define compat_smp_call_function(fn, info, wait) smp_call_function(fn, info, wait) - - /* - * Although this is not really related to kernel-compatibility, I put this -diff -ruN vmmon-only-patched/Makefile vmmon-only-rerefixed/Makefile ---- vmmon-only-patched/Makefile 2009-07-08 16:21:02.000000000 +0300 -+++ vmmon-only-rerefixed/Makefile 2007-11-28 12:39:37.000000000 +0200 -@@ -15,7 +15,7 @@ - VM_UNAME = $(shell uname -r) - - # Header directory for the running kernel --HEADER_DIR = ${KERNEL_DIR}/include -+HEADER_DIR = /lib/modules/$(VM_UNAME)/build/include - - BUILD_DIR = $(HEADER_DIR)/.. - -diff -ruN vmmon-only-patched/Makefile.kernel vmmon-only-rerefixed/Makefile.kernel ---- vmmon-only-patched/Makefile.kernel 2009-07-08 16:21:02.000000000 +0300 -+++ vmmon-only-rerefixed/Makefile.kernel 2009-04-21 18:01:30.000000000 +0300 -@@ -16,18 +16,20 @@ - EXTRA_CFLAGS += $(call vm_check_build, $(SRCROOT)/autoconf/nopage1.c, -DVMW_NOPAGE_261, ) - EXTRA_CFLAGS += $(call vm_check_build, $(SRCROOT)/autoconf/skas1.c, -DVMW_SKAS_MMAP, ) - EXTRA_CFLAGS += $(call vm_check_build, $(SRCROOT)/autoconf/ioapic.c, \ -- -DVMWARE__FIX_IO_APIC_BASE=FIX_IO_APIC_BASE_0, \ -- -DVMWARE__FIX_IO_APIC_BASE=FIX_IO_APIC_BASE ) --EXTRA_CFLAGS += $(call vm_check_build, $(SRCROOT)/autoconf/epoll.c, -DVMW_HAVE_EPOLL, ) -+ -DVMWARE__FIX_IO_APIC_BASE=FIX_IO_APIC_BASE_0) -+# -DVMWARE__FIX_IO_APIC_BASE=FIX_IO_APIC_BASE ) #only for UP ? -+#EXTRA_CFLAGS += $(call vm_check_build, $(SRCROOT)/autoconf/epoll.c, -DVMW_HAVE_EPOLL, ) -+EXTRA_CFLAGS += "-DVMW_HAVE_EPOLL" - EXTRA_CFLAGS += $(shell if [ -f $(HEADER_DIR)/linux/compile.h ]; then echo "-DVMW_HAVE_COMPILE_H"; fi) - EXTRA_CFLAGS += $(call vm_check_build, $(SRCROOT)/autoconf/setnice.c, -DVMW_HAVE_SET_USER_NICE, ) -+EXTRA_CFLAGS += $(call vm_check_build, $(SRCROOT)/autoconf/smpcall.c, -DVMW_HAVE_SMP_CALL_3ARG, ) - - CXX_KFLAGS := $(call vm_check_gxx,-fno-exceptions,) - - # 2.6.x build system - CFLAGS_task.o := -x c++ $(CXX_KFLAGS) - # 2.4.x build system --CFLAGS_common/task.o := $(CFLAGS_task.o) -+#CFLAGS_common/task.o := $(CFLAGS_task.o) - - obj-m += $(DRIVER).o - -diff -ruN vmmon-only-patched/Makefile.normal vmmon-only-rerefixed/Makefile.normal ---- vmmon-only-patched/Makefile.normal 2009-07-08 16:21:02.000000000 +0300 -+++ vmmon-only-rerefixed/Makefile.normal 2009-04-21 13:42:29.000000000 +0300 -@@ -67,8 +67,8 @@ - CC_OPTS += $(call vm_check_build, $(SRCROOT)/autoconf/nopage1.c, -DVMW_NOPAGE_261, ) - CC_OPTS += $(call vm_check_build, $(SRCROOT)/autoconf/skas1.c, -DVMW_SKAS_MMAP, ) - CC_OPTS += $(call vm_check_build, $(SRCROOT)/autoconf/ioapic.c, \ -- -DVMWARE__FIX_IO_APIC_BASE=FIX_IO_APIC_BASE_0, \ -- -DVMWARE__FIX_IO_APIC_BASE=FIX_IO_APIC_BASE ) -+ -DVMWARE__FIX_IO_APIC_BASE=FIX_IO_APIC_BASE_0) -+# -DVMWARE__FIX_IO_APIC_BASE=FIX_IO_APIC_BASE ) #up? - CC_OPTS += $(call vm_check_build, $(SRCROOT)/autoconf/epoll.c, -DVMW_HAVE_EPOLL, ) - CC_OPTS += $(shell if [ -f $(HEADER_DIR)/linux/compile.h ]; then echo "-DVMW_HAVE_COMPILE_H"; fi) - CC_OPTS += $(call vm_check_build, $(SRCROOT)/autoconf/setnice.c, -DVMW_HAVE_SET_USER_NICE, ) -diff -ruN vmmon-only-patched/Module.markers vmmon-only-rerefixed/Module.markers ---- vmmon-only-patched/Module.markers 1970-01-01 02:00:00.000000000 +0200 -+++ vmmon-only-rerefixed/Module.markers 2008-10-20 16:18:10.000000000 +0300 -@@ -0,0 +1,4 @@ -+core_marker_format vmlinux name %s format %s -+kernel_sched_schedule vmlinux prev_pid %d next_pid %d prev_state %ld ## rq %p prev %p next %p -+kernel_sched_wakeup vmlinux pid %d state %ld ## rq %p task %p rq->curr %p -+kernel_sched_wakeup_new vmlinux pid %d state %ld ## rq %p task %p rq->curr %p -diff -ruN vmmon-only-patched/modules.order vmmon-only-rerefixed/modules.order ---- vmmon-only-patched/modules.order 1970-01-01 02:00:00.000000000 +0200 -+++ vmmon-only-rerefixed/modules.order 2009-04-21 18:01:42.000000000 +0300 -@@ -0,0 +1 @@ -+kernel//home/kang/tmp/vmware-update-2.6.27-5.5.7-2/vmmon-only/vmmon.ko - diff --git a/app-emulation/vmware-modules/files/patches/vmnet/040_all_kernel-2.6.29.patch b/app-emulation/vmware-modules/files/patches/vmnet/040_all_kernel-2.6.29.patch deleted file mode 100644 index eac6e23c8509..000000000000 --- a/app-emulation/vmware-modules/files/patches/vmnet/040_all_kernel-2.6.29.patch +++ /dev/null @@ -1,355 +0,0 @@ -diff -ruN vmnet-only-patched/bridge.c vmnet-only-refixed/bridge.c ---- vmnet-only-patched/bridge.c 2009-07-08 16:21:02.000000000 +0300 -+++ vmnet-only-refixed/bridge.c 2009-04-21 18:30:03.000000000 +0300 -@@ -275,11 +275,7 @@ - struct net_device *net) // IN: Network device - { - #ifdef VMW_NETDEV_HAS_NET --#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 26) - if (dev_net(net) != dev_net(bridge->internalDev)) { --#else -- if (net->nd_net != bridge->internalDev->nd_net) { --#endif - return 0; - } - #endif -@@ -857,6 +853,9 @@ - static Bool - VNetBridgeIsDeviceWireless(struct net_device *dev) //IN: sock - { -+ return FALSE; -+} -+#if 0 - #ifdef CONFIG_WIRELESS_EXT - return dev->wireless_handlers != NULL; - #elif !defined CONFIG_NET_RADIO && !defined CONFIG_WLAN_80211 -@@ -869,7 +868,7 @@ - return dev->get_wireless_stats != NULL; - #endif - } -- -+#endif - /* - *---------------------------------------------------------------------- - * -diff -ruN vmnet-only-patched/compat_semaphore.h vmnet-only-refixed/compat_semaphore.h ---- vmnet-only-patched/compat_semaphore.h 2009-07-08 16:21:02.000000000 +0300 -+++ vmnet-only-refixed/compat_semaphore.h 2008-10-20 16:35:18.000000000 +0300 -@@ -6,11 +6,7 @@ - # define __COMPAT_SEMAPHORE_H__ - - --#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 27) - #include <linux/semaphore.h> --#else --#include <asm/semaphore.h> --#endif - - - /* -diff -ruN vmnet-only-patched/compat_wait.h vmnet-only-refixed/compat_wait.h ---- vmnet-only-patched/compat_wait.h 2009-07-08 16:21:02.000000000 +0300 -+++ vmnet-only-refixed/compat_wait.h 2009-04-21 18:16:24.000000000 +0300 -@@ -37,14 +37,12 @@ - * /dev/epoll interface was added. It was backported to the - * 2.4.20-wolk4.0s. - */ -- --#ifdef VMW_HAVE_EPOLL // { -+#if VMW_HAVE_EPOLL // { - #define compat_poll_wqueues struct poll_wqueues - #else // } { - #define compat_poll_wqueues poll_table - #endif // } -- --#ifdef VMW_HAVE_EPOLL // { -+#if VMW_HAVE_EPOLL // { - - /* If prototype does not match, build will abort here */ - extern void poll_initwait(compat_poll_wqueues *); -diff -ruN vmnet-only-patched/filter.c vmnet-only-refixed/filter.c ---- vmnet-only-patched/filter.c 2009-07-08 16:21:02.000000000 +0300 -+++ vmnet-only-refixed/filter.c 2008-07-24 18:21:23.000000000 +0300 -@@ -13,11 +13,9 @@ - #include "compat_skbuff.h" - #include <linux/netdevice.h> - --#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 25) --# define NF_IP_LOCAL_OUT NF_INET_LOCAL_OUT --# define NF_IP_LOCAL_IN NF_INET_LOCAL_IN --# define NF_IP_POST_ROUTING NF_INET_POST_ROUTING --#endif -+#define NF_IP_LOCAL_OUT NF_INET_LOCAL_OUT -+#define NF_IP_LOCAL_IN NF_INET_LOCAL_IN -+#define NF_IP_POST_ROUTING NF_INET_POST_ROUTING - - /* - * All this makes sense only if NETFILTER support is configured in our kernel. -diff -ruN vmnet-only-patched/Makefile vmnet-only-refixed/Makefile ---- vmnet-only-patched/Makefile 2009-07-08 16:21:02.000000000 +0300 -+++ vmnet-only-refixed/Makefile 2007-11-28 12:19:12.000000000 +0200 -@@ -15,7 +15,7 @@ - VM_UNAME = $(shell uname -r) - - # Header directory for the running kernel --HEADER_DIR = ${KERNEL_DIR}/include -+HEADER_DIR = /lib/modules/$(VM_UNAME)/build/include - - BUILD_DIR = $(HEADER_DIR)/.. - -diff -ruN vmnet-only-patched/Makefile.kernel vmnet-only-refixed/Makefile.kernel ---- vmnet-only-patched/Makefile.kernel 2009-07-08 16:21:02.000000000 +0300 -+++ vmnet-only-refixed/Makefile.kernel 2009-04-21 18:27:50.000000000 +0300 -@@ -12,7 +12,8 @@ - INCLUDE := -I$(SRCROOT) - - EXTRA_CFLAGS := $(CC_OPTS) $(INCLUDE) --EXTRA_CFLAGS += $(call vm_check_build, $(SRCROOT)/epoll.c, -DVMW_HAVE_EPOLL, ) -+#EXTRA_CFLAGS += $(call vm_check_build, $(SRCROOT)/epoll.c, -DVMW_HAVE_EPOLL, ) -+EXTRA_CFLAGS += -I$(HEADER_DIR) -DVMW_HAVE_EPOLL - EXTRA_CFLAGS += $(call vm_check_build, $(SRCROOT)/socket.c, -DVMW_HAVE_SK_WMEM_ALLOC, ) - EXTRA_CFLAGS += $(call vm_check_build, $(SRCROOT)/sk_alloc.c,-DVMW_HAVE_SK_ALLOC_WITH_PROTO, ) - EXTRA_CFLAGS += $(call vm_check_build, $(SRCROOT)/netdev_has_net.c,-DVMW_NETDEV_HAS_NET, ) -diff -ruN vmnet-only-patched/Makefile.normal vmnet-only-refixed/Makefile.normal ---- vmnet-only-patched/Makefile.normal 2009-07-08 16:21:02.000000000 +0300 -+++ vmnet-only-refixed/Makefile.normal 2009-04-21 18:28:04.000000000 +0300 -@@ -37,7 +37,8 @@ - | sed -n -e 's!^APATH!-I$(HEADER_DIR)/asm!p') - - CC_OPTS += -DVME_DEFAULT=$(VMWARE_VER) --CC_OPTS += $(call vm_check_build, $(SRCROOT)/epoll.c, -DVMW_HAVE_EPOLL, ) -+#CC_OPTS += $(call vm_check_build, $(SRCROOT)/epoll.c, -DVMW_HAVE_EPOLL, ) -+EXTRA_CFLAGS += -I$(HEADER_DIR) -DVMW_HAVE_EPOLL - CC_OPTS += $(call vm_check_build, $(SRCROOT)/socket.c, -DVMW_HAVE_SK_WMEM_ALLOC, ) - CC_OPTS += $(call vm_check_build, $(SRCROOT)/sk_alloc.c,-DVMW_HAVE_SK_ALLOC_WITH_PROTO, ) - CC_OPTS += $(call vm_check_build, $(SRCROOT)/netdev_has_net.c,-DVMW_NETDEV_HAS_NET, ) -diff -ruN vmnet-only-patched/Module.markers vmnet-only-refixed/Module.markers ---- vmnet-only-patched/Module.markers 1970-01-01 02:00:00.000000000 +0200 -+++ vmnet-only-refixed/Module.markers 2008-10-20 16:35:37.000000000 +0300 -@@ -0,0 +1,4 @@ -+core_marker_format vmlinux name %s format %s -+kernel_sched_schedule vmlinux prev_pid %d next_pid %d prev_state %ld ## rq %p prev %p next %p -+kernel_sched_wakeup vmlinux pid %d state %ld ## rq %p task %p rq->curr %p -+kernel_sched_wakeup_new vmlinux pid %d state %ld ## rq %p task %p rq->curr %p -diff -ruN vmnet-only-patched/modules.order vmnet-only-refixed/modules.order ---- vmnet-only-patched/modules.order 1970-01-01 02:00:00.000000000 +0200 -+++ vmnet-only-refixed/modules.order 2009-04-21 18:30:09.000000000 +0300 -@@ -0,0 +1 @@ -+kernel//home/kang/tmp/vmware-update-2.6.27-5.5.7-2/vmnet-only/vmnet.ko -diff -ruN vmnet-only-patched/netif.c vmnet-only-refixed/netif.c ---- vmnet-only-patched/netif.c 2009-07-08 16:21:02.000000000 +0300 -+++ vmnet-only-refixed/netif.c 2009-04-21 18:03:24.000000000 +0300 -@@ -310,7 +310,7 @@ - goto out; - } - -- dev->priv = netIf; -+ dev->ml_priv = netIf; - netIf->dev = dev; - - memcpy(dev->dev_addr, netIf->port.paddr, sizeof netIf->port.paddr); -@@ -552,7 +552,7 @@ - VNetNetifStartXmit(struct sk_buff *skb, // IN: - struct net_device *dev) // IN: - { -- VNetNetIF *netIf = (VNetNetIF*)dev->priv; -+ VNetNetIF *netIf = (VNetNetIF*)dev->ml_priv; - - if(skb == NULL) { - return 0; -@@ -604,7 +604,7 @@ - VNetNetifSetMAC(struct net_device *dev, // IN: - void *p) // IN: - { -- VNetNetIF *netIf = (VNetNetIF*)dev->priv; -+ VNetNetIF *netIf = (VNetNetIF*)dev->ml_priv; - struct sockaddr const *addr = p; - if (!VMX86_IS_STATIC_MAC(addr->sa_data)) { - return -EINVAL; -@@ -661,7 +661,7 @@ - struct net_device_stats * - VNetNetifGetStats(struct net_device *dev) // IN: - { -- VNetNetIF *netIf = (VNetNetIF*)dev->priv; -+ VNetNetIF *netIf = (VNetNetIF*)dev->ml_priv; - return &(netIf->stats); - } - -diff -ruN vmnet-only-patched/vmnetInt.h vmnet-only-refixed/vmnetInt.h ---- vmnet-only-patched/vmnetInt.h 2009-07-08 16:21:02.000000000 +0300 -+++ vmnet-only-refixed/vmnetInt.h 2008-07-24 18:31:28.000000000 +0300 -@@ -63,11 +63,7 @@ - # define dev_lock_list() read_lock(&dev_base_lock) - # define dev_unlock_list() read_unlock(&dev_base_lock) - # ifdef VMW_NETDEV_HAS_NET --# if LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 26) --# define DEV_GET(x) __dev_get_by_name((x)->internalDev->nd_net, (x)->name) --# else - # define DEV_GET(x) __dev_get_by_name(dev_net((x)->internalDev), (x)->name) --# endif - # else - # define DEV_GET(x) __dev_get_by_name((x)->name) - # endif -@@ -91,13 +87,8 @@ - - #ifdef VMW_NETDEV_HAS_NET - extern struct proto vmnet_proto; --# if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 26) - # define compat_sk_alloc(_bri, _pri) sk_alloc(dev_net((_bri)->internalDev), \ - PF_NETLINK, _pri, &vmnet_proto) --# else --# define compat_sk_alloc(_bri, _pri) sk_alloc((_bri)->internalDev->nd_net, \ -- PF_NETLINK, _pri, &vmnet_proto) --# endif - #elif defined(VMW_HAVE_SK_ALLOC_WITH_PROTO) - extern struct proto vmnet_proto; - # define compat_sk_alloc(_bri, _pri) sk_alloc(PF_NETLINK, _pri, &vmnet_proto, 1) -diff -ruN vmnet-only-patched/vmnetInt.h.orig vmnet-only-refixed/vmnetInt.h.orig ---- vmnet-only-patched/vmnetInt.h.orig 1970-01-01 02:00:00.000000000 +0200 -+++ vmnet-only-refixed/vmnetInt.h.orig 2007-11-28 12:25:06.000000000 +0200 -@@ -0,0 +1,144 @@ -+/* ********************************************************** -+ * Copyright 1998 VMware, Inc. All rights reserved. -- VMware Confidential -+ * **********************************************************/ -+ -+#ifndef __VMNETINT_H__ -+#define __VMNETINT_H__ -+ -+ -+#define INCLUDE_ALLOW_MODULE -+#include "includeCheck.h" -+#include "driver-config.h" -+ -+ -+/* -+ * Hide all kernel compatibility stuff in those macros -+ */ -+ -+/* All kernels above 2.6.23 have net namespaces. */ -+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 24) && !defined(VMW_NETDEV_HAS_NET) -+# define VMW_NETDEV_HAS_NET -+#endif -+ -+/* All kernels above 2.6.23 have skb argument in nf_hookfn. */ -+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 24) && !defined(VMW_NFHOOK_USES_SKB) -+# define VMW_NFHOOK_USES_SKB -+#endif -+ -+ -+#ifdef KERNEL_2_4_0 -+# define compat_fop_set_owner(_pFop) do { \ -+ (_pFop)->owner = THIS_MODULE; \ -+} while (0) -+# define compat_mod_inc_refcount -+# define compat_mod_dec_refcount -+#else -+# define compat_fop_set_owner(_pFop) -+# define compat_mod_inc_refcount do { \ -+ MOD_INC_USE_COUNT; \ -+} while (0) -+# define compat_mod_dec_refcount do { \ -+ MOD_DEC_USE_COUNT; \ -+} while (0) -+#endif -+ -+ -+#ifdef skb_shinfo -+# define SKB_IS_CLONE_OF(clone, skb) ( \ -+ skb_shinfo(clone) == skb_shinfo(skb) \ -+ ) -+#else -+# define SKB_IS_CLONE_OF(clone, skb) ( \ -+ skb_datarefp(clone) == skb_datarefp(skb) \ -+ ) -+#endif -+#define DEV_QUEUE_XMIT(skb, dev, pri) ( \ -+ (skb)->dev = (dev), \ -+ (skb)->priority = (pri), \ -+ compat_skb_reset_mac_header(skb), \ -+ compat_skb_set_network_header(skb, sizeof (struct ethhdr)), \ -+ dev_queue_xmit(skb) \ -+ ) -+#ifdef KERNEL_2_3_15 -+# define dev_lock_list() read_lock(&dev_base_lock) -+# define dev_unlock_list() read_unlock(&dev_base_lock) -+# ifdef VMW_NETDEV_HAS_NET -+# define DEV_GET(x) __dev_get_by_name((x)->internalDev->nd_net, (x)->name) -+# else -+# define DEV_GET(x) __dev_get_by_name((x)->name) -+# endif -+#else -+# define DEV_GET(x) dev_get((x)->name) -+#endif -+ -+ -+/* -+ * Various fields (including 'dead') of struct sock are replaced with the -+ * 'flags' bitfield in 2.5.65 --hpreg -+ */ -+#if LINUX_VERSION_CODE < KERNEL_VERSION(2, 5, 65) -+# define SET_SK_DEAD(_sk, _val) (_sk)->dead = (_val) -+#else -+# define SET_SK_DEAD(_sk, _val) sock_valbool_flag(_sk, SOCK_DEAD, _val) -+#endif -+ -+ -+#ifdef VMW_NETDEV_HAS_NET -+extern struct proto vmnet_proto; -+# define compat_sk_alloc(_bri, _pri) sk_alloc((_bri)->internalDev->nd_net, \ -+ PF_NETLINK, _pri, &vmnet_proto) -+#elif defined(VMW_HAVE_SK_ALLOC_WITH_PROTO) -+extern struct proto vmnet_proto; -+# define compat_sk_alloc(_bri, _pri) sk_alloc(PF_NETLINK, _pri, &vmnet_proto, 1) -+#elif defined(KERNEL_2_5_5) -+# define compat_sk_alloc(_bri, _pri) sk_alloc(PF_NETLINK, _pri, 1, NULL) -+#else -+# define compat_sk_alloc(_bri, _pri) sk_alloc(0, _pri, 1) -+#endif -+ -+ -+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0) -+# define fileTraversalLock(lock) spin_lock(lock) -+# define fileTraversalUnLock(lock) spin_unlock(lock) -+#elif LINUX_VERSION_CODE >= KERNEL_VERSION(2,4,0) -+# define fileTraversalLock(lock) read_lock(lock) -+# define fileTraversalUnLock(lock) read_unlock(lock) -+#else //2.2 kernels -+# define fileTraversalLock(lock) lock_kernel() -+# define fileTraversalUnLock(lock) unlock_kernel() -+#endif -+ -+ -+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,4,0) -+# define taskLock(lock) task_lock(lock) -+# define taskUnLock(lock) task_unlock(lock) -+#else //2.2 kernels -+# define taskLock(lock) lock_kernel() -+# define taskUnLock(lock) unlock_kernel() -+#endif -+ -+ -+/* -+ * Use CHECKSUM_HW for old kernels, if they have CHECKSUM_HW. Use CHECKSUM_PARTIAL for -+ * new ones even if CHECKSUM_HW is defined. We do not do decision based on kernel version -+ * only as CHECKSUM_PARTIAL was in mm tree for some time already, and we do not test -+ * for CHECKSUM_PARTIAL existence as it may get converted to enum in future. -+ */ -+#if LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 19) && defined(CHECKSUM_HW) -+# define VM_CHECKSUM_PARTIAL CHECKSUM_HW -+#else -+# define VM_CHECKSUM_PARTIAL CHECKSUM_PARTIAL -+#endif -+ -+ -+/* -+ * The "owner" field in nf_hook_ops got added in 2.5.69 -+ */ -+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 5, 69) -+# define compat_nf_hook_owner .owner = THIS_MODULE, -+#else -+# define compat_nf_hook_owner -+#endif -+ -+ -+#endif /* __VMNETINT_H__ */ - |