summaryrefslogtreecommitdiffstats
path: root/sys/vm
diff options
context:
space:
mode:
authoralc <alc@FreeBSD.org>2003-12-30 22:28:36 +0000
committeralc <alc@FreeBSD.org>2003-12-30 22:28:36 +0000
commit8218d1853714703421bc8a08edef4295be5946eb (patch)
tree2e0565f033e105d3876f28577d59381bc36f6900 /sys/vm
parent5489d0ad101df0e878e3f139b454fa24055b3df1 (diff)
downloadFreeBSD-src-8218d1853714703421bc8a08edef4295be5946eb.zip
FreeBSD-src-8218d1853714703421bc8a08edef4295be5946eb.tar.gz
- Modify vm_object_split() to expect a locked vm object on entry and
return on a locked vm object on exit. Remove GIANT_REQUIRED. - Eliminate some unnecessary local variables from vm_object_split().
Diffstat (limited to 'sys/vm')
-rw-r--r--sys/vm/vm_map.c2
-rw-r--r--sys/vm/vm_object.c25
2 files changed, 10 insertions, 17 deletions
diff --git a/sys/vm/vm_map.c b/sys/vm/vm_map.c
index 1572cbc..0917e54 100644
--- a/sys/vm/vm_map.c
+++ b/sys/vm/vm_map.c
@@ -2306,10 +2306,8 @@ vm_map_copy_entry(
src_object->type == OBJT_SWAP)) {
vm_object_collapse(src_object);
if ((src_object->flags & (OBJ_NOSPLIT|OBJ_ONEMAPPING)) == OBJ_ONEMAPPING) {
- VM_OBJECT_UNLOCK(src_object);
vm_object_split(src_entry);
src_object = src_entry->object.vm_object;
- VM_OBJECT_LOCK(src_object);
}
}
vm_object_reference_locked(src_object);
diff --git a/sys/vm/vm_object.c b/sys/vm/vm_object.c
index 0099e52..43e3371 100644
--- a/sys/vm/vm_object.c
+++ b/sys/vm/vm_object.c
@@ -1247,31 +1247,25 @@ vm_object_split(vm_map_entry_t entry)
{
vm_page_t m;
vm_object_t orig_object, new_object, source;
- vm_offset_t s, e;
vm_pindex_t offidxstart, offidxend;
vm_size_t idx, size;
- vm_ooffset_t offset;
-
- GIANT_REQUIRED;
orig_object = entry->object.vm_object;
if (orig_object->type != OBJT_DEFAULT && orig_object->type != OBJT_SWAP)
return;
if (orig_object->ref_count <= 1)
return;
+ VM_OBJECT_UNLOCK(orig_object);
- offset = entry->offset;
- s = entry->start;
- e = entry->end;
-
- offidxstart = OFF_TO_IDX(offset);
- offidxend = offidxstart + OFF_TO_IDX(e - s);
+ offidxstart = OFF_TO_IDX(entry->offset);
+ offidxend = offidxstart + OFF_TO_IDX(entry->end - entry->start);
size = offidxend - offidxstart;
- new_object = vm_pager_allocate(orig_object->type,
- NULL, IDX_TO_OFF(size), VM_PROT_ALL, 0LL);
- if (new_object == NULL)
- return;
+ /*
+ * If swap_pager_copy() is later called, it will convert new_object
+ * into a swap object.
+ */
+ new_object = vm_object_allocate(OBJT_DEFAULT, size);
VM_OBJECT_LOCK(new_object);
VM_OBJECT_LOCK(orig_object);
@@ -1286,7 +1280,7 @@ vm_object_split(vm_map_entry_t entry)
vm_object_clear_flag(source, OBJ_ONEMAPPING);
VM_OBJECT_UNLOCK(source);
new_object->backing_object_offset =
- orig_object->backing_object_offset + offset;
+ orig_object->backing_object_offset + entry->offset;
new_object->backing_object = source;
}
for (idx = 0; idx < size; idx++) {
@@ -1334,6 +1328,7 @@ vm_object_split(vm_map_entry_t entry)
entry->object.vm_object = new_object;
entry->offset = 0LL;
vm_object_deallocate(orig_object);
+ VM_OBJECT_LOCK(new_object);
}
#define OBSC_TEST_ALL_SHADOWED 0x0001
OpenPOWER on IntegriCloud