aboutsummaryrefslogtreecommitdiffstats
path: root/emulators/vmware3/files
diff options
context:
space:
mode:
authorknu <knu@FreeBSD.org>2001-07-12 22:26:10 +0800
committerknu <knu@FreeBSD.org>2001-07-12 22:26:10 +0800
commit8b676ab135be20abe601aef8b908aba65c0c12ef (patch)
treeee2b40a520c6871bddd0dd73bc5ce3ced11caad8 /emulators/vmware3/files
parent8e341b404f8c9bc7b092d8a0135a25307b422e2c (diff)
downloadfreebsd-ports-gnome-8b676ab135be20abe601aef8b908aba65c0c12ef.tar.gz
freebsd-ports-gnome-8b676ab135be20abe601aef8b908aba65c0c12ef.tar.zst
freebsd-ports-gnome-8b676ab135be20abe601aef8b908aba65c0c12ef.zip
Fix for the latest CURRENT. (SMPng folks, feel free to correct it if
it's a wrong fix) Tested by: kuriyama
Diffstat (limited to 'emulators/vmware3/files')
-rw-r--r--emulators/vmware3/files/patch-be52
1 files changed, 38 insertions, 14 deletions
diff --git a/emulators/vmware3/files/patch-be b/emulators/vmware3/files/patch-be
index 0f1463f0bf84..1bfac1cee747 100644
--- a/emulators/vmware3/files/patch-be
+++ b/emulators/vmware3/files/patch-be
@@ -1,61 +1,85 @@
---- vmmon-only/freebsd/hostif.c.orig Wed Jun 6 22:49:52 2001
-+++ vmmon-only/freebsd/hostif.c Thu Jun 7 13:13:02 2001
-@@ -107,7 +107,13 @@
+--- vmmon-only/freebsd/hostif.c.orig Thu Jul 12 22:05:29 2001
++++ vmmon-only/freebsd/hostif.c Thu Jul 12 22:14:09 2001
+@@ -55,7 +55,11 @@
+
+ #include <vm/vm.h>
+ #include <vm/vm_param.h>
++#if __FreeBSD_version >= 500018
++#include <sys/mutex.h>
++#else
+ #include <sys/lock.h>
++#endif
+ #include <vm/pmap.h>
+ #include <vm/vm_map.h>
+ #include <vm/vm_page.h>
+@@ -107,7 +111,16 @@
paddr = (vm_offset_t)addr;
m = PHYS_TO_VM_PAGE(paddr);
-+#if __FreeBSD_version >= 500013
++#if __FreeBSD_version >= 500021
++ GIANT_REQUIRED;
++#elif __FreeBSD_version >= 500013
+ mtx_lock(&vm_mtx);
+#endif
vm_page_wire(m);
-+#if __FreeBSD_version >= 500013
++#if __FreeBSD_version >= 500021
++#elif __FreeBSD_version >= 500013
+ mtx_unlock(&vm_mtx);
+#endif
return 0;
}
-@@ -120,7 +126,13 @@
+@@ -120,7 +133,16 @@
paddr = (vm_offset_t)addr;
m = PHYS_TO_VM_PAGE(paddr);
-+#if __FreeBSD_version >= 500013
++#if __FreeBSD_version >= 500021
++ GIANT_REQUIRED;
++#elif __FreeBSD_version >= 500013
+ mtx_lock(&vm_mtx);
+#endif
vm_page_unwire(m, 1);
-+#if __FreeBSD_version >= 500013
++#if __FreeBSD_version >= 500021
++#elif __FreeBSD_version >= 500013
+ mtx_unlock(&vm_mtx);
+#endif
return 0;
}
-@@ -1066,10 +1078,16 @@
+@@ -1066,10 +1088,19 @@
return NULL;
}
paddr = vtophys(addr);
-+#if __FreeBSD_version >= 500013
++#if __FreeBSD_version >= 500021
++ GIANT_REQUIRED;
++#elif __FreeBSD_version >= 500013
+ mtx_lock(&vm_mtx);
+#endif
ka->kaddr = kmem_alloc_pageable(kernel_map, PAGE_SIZE);
ka->map = PHYS_TO_VM_PAGE(paddr);
vm_page_wire(ka->map);
pmap_kenter(ka->kaddr, paddr);
-+#if __FreeBSD_version >= 500013
++#if __FreeBSD_version >= 500021
++#elif __FreeBSD_version >= 500013
+ mtx_unlock(&vm_mtx);
+#endif
return ka->kaddr;
}
-@@ -1079,9 +1097,15 @@
+@@ -1079,9 +1110,18 @@
if (ka->map==NULL)
return 0;
-+#if __FreeBSD_version >= 500013
++#if __FreeBSD_version >= 500021
++ GIANT_REQUIRED;
++#elif __FreeBSD_version >= 500013
+ mtx_lock(&vm_mtx);
+#endif
vm_page_unwire(ka->map, 1);
pmap_kremove(ka->kaddr);
kmem_free(kernel_map, ka->kaddr, PAGE_SIZE);
-+#if __FreeBSD_version >= 500013
++#if __FreeBSD_version >= 500021
++#elif __FreeBSD_version >= 500013
+ mtx_unlock(&vm_mtx);
+#endif
ka->kaddr = 0;