Module Name: src Committed By: uebayasi Date: Fri Nov 19 15:25:37 UTC 2010
Modified Files: src/sys/miscfs/genfs [uebayasi-xip]: genfs_io.c Log Message: genfs_*_xip_io: Adjust start offset. To generate a diff of this commit: cvs rdiff -u -r1.36.2.46 -r1.36.2.47 src/sys/miscfs/genfs/genfs_io.c Please note that diffs are not public domain; they are subject to the copyright notices on the relevant files.
Modified files: Index: src/sys/miscfs/genfs/genfs_io.c diff -u src/sys/miscfs/genfs/genfs_io.c:1.36.2.46 src/sys/miscfs/genfs/genfs_io.c:1.36.2.47 --- src/sys/miscfs/genfs/genfs_io.c:1.36.2.46 Fri Nov 19 08:39:25 2010 +++ src/sys/miscfs/genfs/genfs_io.c Fri Nov 19 15:25:37 2010 @@ -1,4 +1,4 @@ -/* $NetBSD: genfs_io.c,v 1.36.2.46 2010/11/19 08:39:25 uebayasi Exp $ */ +/* $NetBSD: genfs_io.c,v 1.36.2.47 2010/11/19 15:25:37 uebayasi Exp $ */ /* * Copyright (c) 1982, 1986, 1989, 1993 @@ -31,7 +31,7 @@ */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: genfs_io.c,v 1.36.2.46 2010/11/19 08:39:25 uebayasi Exp $"); +__KERNEL_RCSID(0, "$NetBSD: genfs_io.c,v 1.36.2.47 2010/11/19 15:25:37 uebayasi Exp $"); #include "opt_xip.h" @@ -375,7 +375,7 @@ #endif #ifdef XIP if ((ap->a_vp->v_vflag & VV_XIP) != 0) - goto genfs_getpages_allocpages_done; + goto genfs_getpages_io_read_allocpages_done; #endif if (uvn_findpages(uobj, origoffset, &npages, &pgs[ridx], @@ -578,7 +578,7 @@ error = genfs_do_getpages_xip_io( ap->a_vp, ap->a_offset, - ap->a_m, + pgs, ap->a_count, ap->a_centeridx, ap->a_access_type, @@ -811,7 +811,7 @@ error = genfs_do_getpages_xip_io_done( ap->a_vp, ap->a_offset, - ap->a_m, + pgs, ap->a_count, ap->a_centeridx, ap->a_access_type, @@ -903,6 +903,10 @@ genfs_markdirty(vp); } mutex_exit(&uobj->vmobjlock); +#if 1 +genfs_getpages_generic_io_done_done: + {} +#endif if (ap->a_m != NULL) { memcpy(ap->a_m, &pgs[ridx], orignmempages * sizeof(struct vm_page *)); @@ -911,10 +915,6 @@ } #endif -#if 1 -genfs_getpages_generic_io_done_done: - {} -#endif out_err_free: if (pgs != NULL && pgs != pgs_onstack) @@ -964,8 +964,10 @@ UVMHIST_LOG(ubchist, "xip npages=%d startoffset=%lx endoffset=%lx", orignmempages, (long)startoffset, (long)endoffset, 0); + const int ridx = (origoffset - startoffset) >> PAGE_SHIFT; + off = origoffset; - for (i = 0; i < orignmempages; i++) { + for (i = ridx; i < ridx + orignmempages; i++) { daddr_t lbn, blkno; int run; struct vnode *devvp; @@ -1022,9 +1024,15 @@ struct uvm_object * const uobj = &vp->v_uobj; int i; + const int fs_bshift = vp2fs_bshift(vp); + const int fs_bsize = 1 << fs_bshift; + + const off_t startoffset = trunc_blk(origoffset); + const int ridx = (origoffset - startoffset) >> PAGE_SHIFT; + mutex_enter(&uobj->vmobjlock); - for (i = 0; i < orignmempages; i++) { + for (i = ridx; i < ridx + orignmempages; i++) { struct vm_page *pg = pps[i]; KASSERT((pg->flags & PG_RDONLY) != 0);