summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMark Johnston <markj@FreeBSD.org>2020-06-25 15:21:21 +0000
committerMark Johnston <markj@FreeBSD.org>2020-06-25 15:21:21 +0000
commit84242cf68a82071a388472925d539ed9817ceb6d (patch)
treef2eb818e3db7e43535bab9fa2204e6c4d9db2cb8
parent0a1016f9e8a84edc8eb21e4f776b18b19fdd26ce (diff)
Notes
-rw-r--r--sys/dev/md/md.c2
-rw-r--r--sys/fs/tmpfs/tmpfs_subr.c5
-rw-r--r--sys/kern/uipc_shm.c5
-rw-r--r--sys/vm/vm_map.c8
-rw-r--r--sys/vm/vm_object.c9
5 files changed, 9 insertions, 20 deletions
diff --git a/sys/dev/md/md.c b/sys/dev/md/md.c
index 3c8f8de90e16..2fef08ed5861 100644
--- a/sys/dev/md/md.c
+++ b/sys/dev/md/md.c
@@ -1566,8 +1566,6 @@ mdresize(struct md_s *sc, struct md_req *mdr)
if (newpages < oldpages) {
VM_OBJECT_WLOCK(sc->object);
vm_object_page_remove(sc->object, newpages, 0, 0);
- swap_pager_freespace(sc->object, newpages,
- oldpages - newpages);
swap_release_by_cred(IDX_TO_OFF(oldpages -
newpages), sc->cred);
sc->object->charge = IDX_TO_OFF(newpages);
diff --git a/sys/fs/tmpfs/tmpfs_subr.c b/sys/fs/tmpfs/tmpfs_subr.c
index d8308aa8fa3a..06f5f9890749 100644
--- a/sys/fs/tmpfs/tmpfs_subr.c
+++ b/sys/fs/tmpfs/tmpfs_subr.c
@@ -1517,11 +1517,8 @@ retry:
/*
* Release any swap space and free any whole pages.
*/
- if (newpages < oldpages) {
- swap_pager_freespace(uobj, newpages, oldpages -
- newpages);
+ if (newpages < oldpages)
vm_object_page_remove(uobj, newpages, 0, 0);
- }
}
uobj->size = newpages;
VM_OBJECT_WUNLOCK(uobj);
diff --git a/sys/kern/uipc_shm.c b/sys/kern/uipc_shm.c
index dc8789716f3d..143afb982d2b 100644
--- a/sys/kern/uipc_shm.c
+++ b/sys/kern/uipc_shm.c
@@ -540,15 +540,10 @@ retry:
}
delta = IDX_TO_OFF(object->size - nobjsize);
- /* Toss in memory pages. */
if (nobjsize < object->size)
vm_object_page_remove(object, nobjsize, object->size,
0);
- /* Toss pages from swap. */
- if (object->type == OBJT_SWAP)
- swap_pager_freespace(object, nobjsize, delta);
-
/* Free the swap accounted for shm */
swap_release_by_cred(delta, object->cred);
object->charge -= delta;
diff --git a/sys/vm/vm_map.c b/sys/vm/vm_map.c
index f3a261c70d43..956d0e68167e 100644
--- a/sys/vm/vm_map.c
+++ b/sys/vm/vm_map.c
@@ -3644,7 +3644,7 @@ static void
vm_map_entry_delete(vm_map_t map, vm_map_entry_t entry)
{
vm_object_t object;
- vm_pindex_t offidxstart, offidxend, count, size1;
+ vm_pindex_t offidxstart, offidxend, size1;
vm_size_t size;
vm_map_entry_unlink(map, entry, UNLINK_MERGE_NONE);
@@ -3673,9 +3673,8 @@ vm_map_entry_delete(vm_map_t map, vm_map_entry_t entry)
KASSERT(entry->cred == NULL || object->cred == NULL ||
(entry->eflags & MAP_ENTRY_NEEDS_COPY),
("OVERCOMMIT vm_map_entry_delete: both cred %p", entry));
- count = atop(size);
offidxstart = OFF_TO_IDX(entry->offset);
- offidxend = offidxstart + count;
+ offidxend = offidxstart + atop(size);
VM_OBJECT_WLOCK(object);
if (object->ref_count != 1 &&
((object->flags & OBJ_ONEMAPPING) != 0 ||
@@ -3690,9 +3689,6 @@ vm_map_entry_delete(vm_map_t map, vm_map_entry_t entry)
*/
vm_object_page_remove(object, offidxstart, offidxend,
OBJPR_NOTMAPPED);
- if (object->type == OBJT_SWAP)
- swap_pager_freespace(object, offidxstart,
- count);
if (offidxend >= object->size &&
offidxstart < object->size) {
size1 = object->size;
diff --git a/sys/vm/vm_object.c b/sys/vm/vm_object.c
index 4e27327ef42b..5cce1b359d43 100644
--- a/sys/vm/vm_object.c
+++ b/sys/vm/vm_object.c
@@ -2121,6 +2121,12 @@ wired:
vm_page_free(p);
}
vm_object_pip_wakeup(object);
+
+ if (object->type == OBJT_SWAP) {
+ if (end == 0)
+ end = object->size;
+ swap_pager_freespace(object, start, end - start);
+ }
}
/*
@@ -2288,9 +2294,6 @@ vm_object_coalesce(vm_object_t prev_object, vm_ooffset_t prev_offset,
if (next_pindex < prev_object->size) {
vm_object_page_remove(prev_object, next_pindex, next_pindex +
next_size, 0);
- if (prev_object->type == OBJT_SWAP)
- swap_pager_freespace(prev_object,
- next_pindex, next_size);
#if 0
if (prev_object->cred != NULL) {
KASSERT(prev_object->charge >=