git: 6dd1c0643e9c - main - vm_page: use lookup_ge in grab_valid_iter()
- Go to: [ bottom of page ] [ top of archives ] [ this month ]
Date: Sat, 31 May 2025 18:40:36 UTC
The branch main has been updated by dougm: URL: https://cgit.FreeBSD.org/src/commit/?id=6dd1c0643e9c5562d8b09c41fc792129a8081f06 commit 6dd1c0643e9c5562d8b09c41fc792129a8081f06 Author: Doug Moore <dougm@FreeBSD.org> AuthorDate: 2025-05-31 18:37:33 +0000 Commit: Doug Moore <dougm@FreeBSD.org> CommitDate: 2025-05-31 18:37:33 +0000 vm_page: use lookup_ge in grab_valid_iter() To improve performance slightly, use vm_radix_iter_lookup_ge to skip over several missing pages at once in grab_valid_iter(). Fix a case in which the function could return with the iterator argument not reset after a lock release/reacquire. Reviewed by: alc, markj Differential Revision: https://reviews.freebsd.org/D50601 --- sys/vm/vm_page.c | 20 +++++++++++++------- 1 file changed, 13 insertions(+), 7 deletions(-) diff --git a/sys/vm/vm_page.c b/sys/vm/vm_page.c index a3ebc92175f8..79eaf8563208 100644 --- a/sys/vm/vm_page.c +++ b/sys/vm/vm_page.c @@ -4882,7 +4882,7 @@ vm_page_grab_valid_iter(vm_page_t *mp, vm_object_t object, vm_pindex_t pindex, { vm_page_t m; vm_page_t ma[VM_INITIAL_PAGEIN]; - int after, i, pflags, rv; + int after, ahead, i, pflags, rv; KASSERT((allocflags & VM_ALLOC_SBUSY) == 0 || (allocflags & VM_ALLOC_IGN_SBUSY) != 0, @@ -4942,13 +4942,18 @@ retrylookup: ma[0] = m; pctrie_iter_reset(pages); for (i = 1; i < after; i++) { - m = vm_radix_iter_lookup(pages, pindex + i); - if (m == NULL) { - m = vm_page_alloc_iter(object, pindex + i, + m = vm_radix_iter_lookup_ge(pages, pindex + i); + ahead = after; + if (m != NULL) + ahead = MIN(ahead, m->pindex - pindex); + for (; i < ahead; i++) { + ma[i] = vm_page_alloc_iter(object, pindex + i, VM_ALLOC_NORMAL, pages); - if (m == NULL) + if (ma[i] == NULL) break; - } else if (vm_page_any_valid(m) || !vm_page_tryxbusy(m)) + } + if (m == NULL || m->pindex != pindex + i || + vm_page_any_valid(m) || !vm_page_tryxbusy(m)) break; ma[i] = m; } @@ -4956,6 +4961,7 @@ retrylookup: vm_object_pip_add(object, after); VM_OBJECT_WUNLOCK(object); rv = vm_pager_get_pages(object, ma, after, NULL, NULL); + pctrie_iter_reset(pages); VM_OBJECT_WLOCK(object); vm_object_pip_wakeupn(object, after); /* Pager may have replaced a page. */ @@ -4975,8 +4981,8 @@ retrylookup: MPASS(vm_page_all_valid(m)); } else { vm_page_zero_invalid(m, TRUE); + pctrie_iter_reset(pages); } - pctrie_iter_reset(pages); out: if ((allocflags & VM_ALLOC_WIRED) != 0) vm_page_wire(m);