From ff7f1b3c5b9b8b169bed580ff2031aa18f461be1 Mon Sep 17 00:00:00 2001 From: jhb Date: Wed, 4 Jul 2001 19:55:01 +0000 Subject: - Update the vmmeter statistics for vnode pageins and pageouts in getpages/putpages. - Use vm_page_undirty() instead of messing with pages' dirty fields directly. --- sys/fs/smbfs/smbfs_io.c | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) (limited to 'sys/fs') diff --git a/sys/fs/smbfs/smbfs_io.c b/sys/fs/smbfs/smbfs_io.c index 1033e8e..505c906 100644 --- a/sys/fs/smbfs/smbfs_io.c +++ b/sys/fs/smbfs/smbfs_io.c @@ -46,6 +46,7 @@ #include #include #include +#include #include #if __FreeBSD_version < 400000 @@ -444,6 +445,8 @@ smbfs_getpages(ap) npages = btoc(count); kva = (vm_offset_t) bp->b_data; pmap_qenter(kva, pages, npages); + cnt.v_vnodein++; + cnt.v_vnodepgsin += count; iov.iov_base = (caddr_t) kva; iov.iov_len = count; @@ -484,7 +487,7 @@ smbfs_getpages(ap) if (nextoff <= size) { m->valid = VM_PAGE_BITS_ALL; - m->dirty = 0; + vm_page_undirty(m); } else { int nvalid = ((size + DEV_BSIZE - 1) - toff) & ~(DEV_BSIZE - 1); vm_page_set_validclean(m, 0, nvalid); @@ -580,6 +583,8 @@ smbfs_putpages(ap) #endif kva = (vm_offset_t) bp->b_data; pmap_qenter(kva, pages, npages); + cnt.v_vnodeout++; + cnt.v_vnodepgsout += count; iov.iov_base = (caddr_t) kva; iov.iov_len = count; @@ -608,7 +613,7 @@ smbfs_putpages(ap) int nwritten = round_page(count - uio.uio_resid) / PAGE_SIZE; for (i = 0; i < nwritten; i++) { rtvals[i] = VM_PAGER_OK; - pages[i]->dirty = 0; + vm_page_undirty(pages[i]); } } return rtvals[0]; -- cgit v1.1