summaryrefslogtreecommitdiff
path: root/sys/uvm/uvm_map.h
diff options
context:
space:
mode:
Diffstat (limited to 'sys/uvm/uvm_map.h')
-rw-r--r--sys/uvm/uvm_map.h84
1 files changed, 24 insertions, 60 deletions
diff --git a/sys/uvm/uvm_map.h b/sys/uvm/uvm_map.h
index fcc6711d0e2..7de3f38393b 100644
--- a/sys/uvm/uvm_map.h
+++ b/sys/uvm/uvm_map.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: uvm_map.h,v 1.36 2007/03/25 13:02:51 thib Exp $ */
+/* $OpenBSD: uvm_map.h,v 1.37 2007/04/04 18:02:59 art Exp $ */
/* $NetBSD: uvm_map.h,v 1.24 2001/02/18 21:19:08 chs Exp $ */
/*
@@ -70,17 +70,11 @@
#ifndef _UVM_UVM_MAP_H_
#define _UVM_UVM_MAP_H_
-/*
- * uvm_map.h
- */
+#include <sys/rwlock.h>
#ifdef _KERNEL
/*
- * macros
- */
-
-/*
* UVM_MAP_CLIP_START: ensure that the entry begins at or after
* the starting address, if it doesn't we split the entry.
*
@@ -219,7 +213,7 @@ struct vm_map_entry {
*/
struct vm_map {
struct pmap * pmap; /* Physical map */
- lock_data_t lock; /* Lock for map data */
+ struct rwlock lock; /* Lock for map data */
RB_HEAD(uvm_tree, vm_map_entry) rbhead; /* Tree for entries */
struct vm_map_entry header; /* List of entries */
int nentries; /* Number of entries */
@@ -389,18 +383,17 @@ static __inline void vm_map_lock(vm_map_t);
extern const char vmmapbsy[];
static __inline boolean_t
-vm_map_lock_try(map)
- vm_map_t map;
+vm_map_lock_try(struct vm_map *map)
{
boolean_t rv;
- if (map->flags & VM_MAP_INTRSAFE)
- rv = simple_lock_try(&map->lock.lk_interlock);
- else {
+ if (map->flags & VM_MAP_INTRSAFE) {
+ rv = TRUE;
+ } else {
if (map->flags & VM_MAP_BUSY) {
return (FALSE);
}
- rv = (lockmgr(&map->lock, LK_EXCLUSIVE|LK_NOWAIT, NULL) == 0);
+ rv = (rw_enter(&map->lock, RW_WRITE|RW_NOSLEEP) == 0);
}
if (rv)
@@ -410,67 +403,38 @@ vm_map_lock_try(map)
}
static __inline void
-vm_map_lock(map)
- vm_map_t map;
+vm_map_lock(struct vm_map *map)
{
- int error;
-
- if (map->flags & VM_MAP_INTRSAFE) {
- simple_lock(&map->lock.lk_interlock);
+ if (map->flags & VM_MAP_INTRSAFE)
return;
- }
- try_again:
- while (map->flags & VM_MAP_BUSY) {
- map->flags |= VM_MAP_WANTLOCK;
- ltsleep(&map->flags, PVM, (char *)vmmapbsy, 0, NULL);
- }
-
- error = lockmgr(&map->lock, LK_EXCLUSIVE|LK_SLEEPFAIL, NULL);
-
- if (error) {
- goto try_again;
- }
+ do {
+ while (map->flags & VM_MAP_BUSY) {
+ map->flags |= VM_MAP_WANTLOCK;
+ tsleep(&map->flags, PVM, (char *)vmmapbsy, 0);
+ }
+ } while (rw_enter(&map->lock, RW_WRITE|RW_SLEEPFAIL) != 0);
- (map)->timestamp++;
+ map->timestamp++;
}
-#ifdef DIAGNOSTIC
-#define vm_map_lock_read(map) \
-do { \
- if (map->flags & VM_MAP_INTRSAFE) \
- panic("vm_map_lock_read: intrsafe map"); \
- (void) lockmgr(&(map)->lock, LK_SHARED, NULL); \
-} while (0)
-#else
-#define vm_map_lock_read(map) \
- (void) lockmgr(&(map)->lock, LK_SHARED, NULL)
-#endif
+#define vm_map_lock_read(map) rw_enter_read(&(map)->lock)
#define vm_map_unlock(map) \
do { \
- if ((map)->flags & VM_MAP_INTRSAFE) \
- simple_unlock(&(map)->lock.lk_interlock); \
- else \
- (void) lockmgr(&(map)->lock, LK_RELEASE, NULL); \
+ if (((map)->flags & VM_MAP_INTRSAFE) == 0) \
+ rw_exit(&(map)->lock); \
} while (0)
-#define vm_map_unlock_read(map) \
- (void) lockmgr(&(map)->lock, LK_RELEASE, NULL)
+#define vm_map_unlock_read(map) rw_exit_read(&(map)->lock)
-#define vm_map_downgrade(map) \
- (void) lockmgr(&(map)->lock, LK_DOWNGRADE, NULL)
+#define vm_map_downgrade(map) rw_enter(&(map)->lock, RW_DOWNGRADE)
-#ifdef DIAGNOSTIC
#define vm_map_upgrade(map) \
do { \
- if (lockmgr(&(map)->lock, LK_UPGRADE, NULL) != 0) \
- panic("vm_map_upgrade: failed to upgrade lock"); \
+ rw_exit_read(&(map)->lock); \
+ rw_enter_write(&(map)->lock); \
} while (0)
-#else
-#define vm_map_upgrade(map) \
- (void) lockmgr(&(map)->lock, LK_UPGRADE, NULL)
-#endif
#define vm_map_busy(map) \
do { \