Author: kib
Date: Wed Apr  5 16:56:04 2017
New Revision: 316526
URL: https://svnweb.freebsd.org/changeset/base/316526

Log:
  Extract calculation of ioflags from the vm_pager_putpages flags into a
  helper.
  
  Reviewed by:  markj
  Tested by:    pho
  Sponsored by: The FreeBSD Foundation
  MFC after:    1 week
  X-Differential revision:      https://reviews.freebsd.org/D10241

Modified:
  head/sys/vm/vnode_pager.c
  head/sys/vm/vnode_pager.h

Modified: head/sys/vm/vnode_pager.c
==============================================================================
--- head/sys/vm/vnode_pager.c   Wed Apr  5 16:45:00 2017        (r316525)
+++ head/sys/vm/vnode_pager.c   Wed Apr  5 16:56:04 2017        (r316526)
@@ -1198,7 +1198,7 @@ vnode_pager_generic_putpages(struct vnod
        vm_ooffset_t poffset;
        struct uio auio;
        struct iovec aiov;
-       int count, error, i, ioflags, maxsize, ncount, ppscheck;
+       int count, error, i, maxsize, ncount, ppscheck;
        static struct timeval lastfail;
        static int curfail;
 
@@ -1265,22 +1265,6 @@ vnode_pager_generic_putpages(struct vnod
        }
        VM_OBJECT_WUNLOCK(object);
 
-       /*
-        * pageouts are already clustered, use IO_ASYNC to force a bawrite()
-        * rather then a bdwrite() to prevent paging I/O from saturating 
-        * the buffer cache.  Dummy-up the sequential heuristic to cause
-        * large ranges to cluster.  If neither IO_SYNC or IO_ASYNC is set,
-        * the system decides how to cluster.
-        */
-       ioflags = IO_VMIO;
-       if (flags & (VM_PAGER_PUT_SYNC | VM_PAGER_PUT_INVAL))
-               ioflags |= IO_SYNC;
-       else if ((flags & VM_PAGER_CLUSTER_OK) == 0)
-               ioflags |= IO_ASYNC;
-       ioflags |= (flags & VM_PAGER_PUT_INVAL) ? IO_INVAL: 0;
-       ioflags |= (flags & VM_PAGER_PUT_NOREUSE) ? IO_NOREUSE : 0;
-       ioflags |= IO_SEQMAX << IO_SEQSHIFT;
-
        aiov.iov_base = (caddr_t) 0;
        aiov.iov_len = maxsize;
        auio.uio_iov = &aiov;
@@ -1290,7 +1274,8 @@ vnode_pager_generic_putpages(struct vnod
        auio.uio_rw = UIO_WRITE;
        auio.uio_resid = maxsize;
        auio.uio_td = (struct thread *) 0;
-       error = VOP_WRITE(vp, &auio, ioflags, curthread->td_ucred);
+       error = VOP_WRITE(vp, &auio, vnode_pager_putpages_ioflags(flags),
+           curthread->td_ucred);
        PCPU_INC(cnt.v_vnodeout);
        PCPU_ADD(cnt.v_vnodepgsout, ncount);
 
@@ -1310,6 +1295,30 @@ vnode_pager_generic_putpages(struct vnod
        return rtvals[0];
 }
 
+int
+vnode_pager_putpages_ioflags(int pager_flags)
+{
+       int ioflags;
+
+       /*
+        * Pageouts are already clustered, use IO_ASYNC to force a
+        * bawrite() rather then a bdwrite() to prevent paging I/O
+        * from saturating the buffer cache.  Dummy-up the sequential
+        * heuristic to cause large ranges to cluster.  If neither
+        * IO_SYNC or IO_ASYNC is set, the system decides how to
+        * cluster.
+        */
+       ioflags = IO_VMIO;
+       if ((pager_flags & (VM_PAGER_PUT_SYNC | VM_PAGER_PUT_INVAL)) != 0)
+               ioflags |= IO_SYNC;
+       else if ((pager_flags & VM_PAGER_CLUSTER_OK) == 0)
+               ioflags |= IO_ASYNC;
+       ioflags |= (pager_flags & VM_PAGER_PUT_INVAL) != 0 ? IO_INVAL: 0;
+       ioflags |= (pager_flags & VM_PAGER_PUT_NOREUSE) != 0 ? IO_NOREUSE : 0;
+       ioflags |= IO_SEQMAX << IO_SEQSHIFT;
+       return (ioflags);
+}
+
 void
 vnode_pager_undirty_pages(vm_page_t *ma, int *rtvals, int written)
 {

Modified: head/sys/vm/vnode_pager.h
==============================================================================
--- head/sys/vm/vnode_pager.h   Wed Apr  5 16:45:00 2017        (r316525)
+++ head/sys/vm/vnode_pager.h   Wed Apr  5 16:56:04 2017        (r316526)
@@ -47,7 +47,7 @@ int vnode_pager_generic_putpages(struct 
     int count, int flags, int *rtvals);
 int vnode_pager_local_getpages(struct vop_getpages_args *ap);
 int vnode_pager_local_getpages_async(struct vop_getpages_async_args *ap);
-
+int vnode_pager_putpages_ioflags(int pager_flags);
 void vnode_pager_release_writecount(vm_object_t object, vm_offset_t start,
     vm_offset_t end);
 void vnode_pager_undirty_pages(vm_page_t *ma, int *rtvals, int written);
_______________________________________________
svn-src-head@freebsd.org mailing list
https://lists.freebsd.org/mailman/listinfo/svn-src-head
To unsubscribe, send any mail to "svn-src-head-unsubscr...@freebsd.org"

Reply via email to