git: c1d12b925b2c - main - vm_page: pass page to iter_remove
- Go to: [ bottom of page ] [ top of archives ] [ this month ]
Date: Sun, 08 Dec 2024 20:31:16 UTC
The branch main has been updated by dougm: URL: https://cgit.FreeBSD.org/src/commit/?id=c1d12b925b2c87d55a86b874e7b7e7a590844eb9 commit c1d12b925b2c87d55a86b874e7b7e7a590844eb9 Author: Doug Moore <dougm@FreeBSD.org> AuthorDate: 2024-12-08 20:30:22 +0000 Commit: Doug Moore <dougm@FreeBSD.org> CommitDate: 2024-12-08 20:30:22 +0000 vm_page: pass page to iter_remove Pass the to-be-freed page to vm_page_iter_remove as a parameter, rather than computing it from the iterator parameter, to improve performance. Reviewed by: alc Differential Revision: https://reviews.freebsd.org/D47730 --- sys/arm/nvidia/drm2/tegra_bo.c | 2 +- sys/vm/device_pager.c | 10 +++++----- sys/vm/vm_object.c | 8 ++++---- sys/vm/vm_page.c | 6 ++---- sys/vm/vm_page.h | 2 +- sys/vm/vm_pager.h | 2 +- 6 files changed, 14 insertions(+), 16 deletions(-) diff --git a/sys/arm/nvidia/drm2/tegra_bo.c b/sys/arm/nvidia/drm2/tegra_bo.c index 0b62e78224dc..6d380b95a4a9 100644 --- a/sys/arm/nvidia/drm2/tegra_bo.c +++ b/sys/arm/nvidia/drm2/tegra_bo.c @@ -64,7 +64,7 @@ tegra_bo_destruct(struct tegra_bo *bo) for (i = 0; i < bo->npages; i++) { m = vm_page_iter_lookup(&pages, i); vm_page_busy_acquire(m, 0); - cdev_mgtdev_pager_free_page(&pages); + cdev_mgtdev_pager_free_page(&pages, m); m->flags &= ~PG_FICTITIOUS; vm_page_unwire_noq(m); vm_page_free(m); diff --git a/sys/vm/device_pager.c b/sys/vm/device_pager.c index 55bc948a4c44..24241d118c7a 100644 --- a/sys/vm/device_pager.c +++ b/sys/vm/device_pager.c @@ -268,7 +268,7 @@ cdev_pager_free_page(vm_object_t object, vm_page_t m) vm_page_iter_init(&pages, object); vm_page_iter_lookup(&pages, m->pindex); - cdev_mgtdev_pager_free_page(&pages); + cdev_mgtdev_pager_free_page(&pages, m); } else if (object->type == OBJT_DEVICE) dev_pager_free_page(object, m); else @@ -277,10 +277,10 @@ cdev_pager_free_page(vm_object_t object, vm_page_t m) } void -cdev_mgtdev_pager_free_page(struct pctrie_iter *pages) +cdev_mgtdev_pager_free_page(struct pctrie_iter *pages, vm_page_t m) { - pmap_remove_all(vm_radix_iter_page(pages)); - vm_page_iter_remove(pages); + pmap_remove_all(m); + vm_page_iter_remove(pages, m); } void @@ -298,7 +298,7 @@ retry: pctrie_iter_reset(&pages); goto retry; } - cdev_mgtdev_pager_free_page(&pages); + cdev_mgtdev_pager_free_page(&pages, m); } VM_OBJECT_WUNLOCK(object); } diff --git a/sys/vm/vm_object.c b/sys/vm/vm_object.c index ff95469749b7..a3cfb4d036be 100644 --- a/sys/vm/vm_object.c +++ b/sys/vm/vm_object.c @@ -1599,7 +1599,7 @@ retry: * an incomplete fault. Just remove and ignore. */ if (vm_page_none_valid(m)) { - if (vm_page_iter_remove(&pages)) + if (vm_page_iter_remove(&pages, m)) vm_page_free(m); continue; } @@ -1727,7 +1727,7 @@ vm_object_collapse_scan(vm_object_t object) KASSERT(!pmap_page_is_mapped(p), ("freeing mapped page %p", p)); - if (vm_page_iter_remove(&pages)) + if (vm_page_iter_remove(&pages, p)) vm_page_free(p); next = vm_radix_iter_step(&pages); continue; @@ -1736,7 +1736,7 @@ vm_object_collapse_scan(vm_object_t object) if (!vm_page_all_valid(p)) { KASSERT(!pmap_page_is_mapped(p), ("freeing mapped page %p", p)); - if (vm_page_iter_remove(&pages)) + if (vm_page_iter_remove(&pages, p)) vm_page_free(p); next = vm_radix_iter_step(&pages); continue; @@ -1779,7 +1779,7 @@ vm_object_collapse_scan(vm_object_t object) ("freeing mapped page %p", p)); if (pp != NULL) vm_page_xunbusy(pp); - if (vm_page_iter_remove(&pages)) + if (vm_page_iter_remove(&pages, p)) vm_page_free(p); next = vm_radix_iter_step(&pages); continue; diff --git a/sys/vm/vm_page.c b/sys/vm/vm_page.c index 8a23f900e987..f351295c1af5 100644 --- a/sys/vm/vm_page.c +++ b/sys/vm/vm_page.c @@ -1752,16 +1752,14 @@ vm_page_remove(vm_page_t m) /* * vm_page_iter_remove: * - * Remove the current page, as identified by iterator, and remove it from the + * Remove the current page, and use the iterator to remove it from the * radix tree. */ bool -vm_page_iter_remove(struct pctrie_iter *pages) +vm_page_iter_remove(struct pctrie_iter *pages, vm_page_t m) { - vm_page_t m; bool dropped; - m = vm_radix_iter_page(pages); vm_radix_iter_remove(pages); vm_page_remove_radixdone(m); dropped = (vm_page_drop(m, VPRC_OBJREF) == VPRC_OBJREF); diff --git a/sys/vm/vm_page.h b/sys/vm/vm_page.h index 29344eadbf05..744688bf789b 100644 --- a/sys/vm/vm_page.h +++ b/sys/vm/vm_page.h @@ -654,7 +654,7 @@ void vm_page_iter_free(struct pctrie_iter *pages, vm_page_t m); void vm_page_iter_init(struct pctrie_iter *, vm_object_t); void vm_page_iter_limit_init(struct pctrie_iter *, vm_object_t, vm_pindex_t); vm_page_t vm_page_iter_lookup(struct pctrie_iter *, vm_pindex_t); -bool vm_page_iter_remove(struct pctrie_iter *pages); +bool vm_page_iter_remove(struct pctrie_iter *pages, vm_page_t m); bool vm_page_iter_rename(struct pctrie_iter *old_pages, vm_page_t m, vm_object_t new_object, vm_pindex_t new_pindex); void vm_page_launder(vm_page_t m); diff --git a/sys/vm/vm_pager.h b/sys/vm/vm_pager.h index 0958d82d6968..c4a9b5e9dcb9 100644 --- a/sys/vm/vm_pager.h +++ b/sys/vm/vm_pager.h @@ -300,7 +300,7 @@ vm_object_t cdev_pager_allocate(void *handle, enum obj_type tp, vm_ooffset_t foff, struct ucred *cred); vm_object_t cdev_pager_lookup(void *handle); void cdev_pager_free_page(vm_object_t object, vm_page_t m); -void cdev_mgtdev_pager_free_page(struct pctrie_iter *pages); +void cdev_mgtdev_pager_free_page(struct pctrie_iter *pages, vm_page_t m); void cdev_mgtdev_pager_free_pages(vm_object_t object); struct phys_pager_ops {