summaryrefslogtreecommitdiffstats
path: root/sys/kern/vfs_bio.c
diff options
context:
space:
mode:
authorkib <kib@FreeBSD.org>2016-11-29 08:15:12 +0000
committerkib <kib@FreeBSD.org>2016-11-29 08:15:12 +0000
commit9e49301e62d444d93c70ed48cee7e6e2209288e1 (patch)
treecce98dd67d5a3006aeb9d0ccdbc7977c54c238e0 /sys/kern/vfs_bio.c
parentb77adef4ef3ad9fb6790f5c5d39e1a6cc1012822 (diff)
downloadFreeBSD-src-9e49301e62d444d93c70ed48cee7e6e2209288e1.zip
FreeBSD-src-9e49301e62d444d93c70ed48cee7e6e2209288e1.tar.gz
MFC r308969:
Restore vnode pager statistic for buffer pagers.
Diffstat (limited to 'sys/kern/vfs_bio.c')
-rw-r--r--sys/kern/vfs_bio.c33
1 files changed, 21 insertions, 12 deletions
diff --git a/sys/kern/vfs_bio.c b/sys/kern/vfs_bio.c
index 1565849..81e591f 100644
--- a/sys/kern/vfs_bio.c
+++ b/sys/kern/vfs_bio.c
@@ -4727,7 +4727,7 @@ vfs_bio_getpages(struct vnode *vp, vm_page_t *ma, int count,
daddr_t lbn, lbnp;
vm_ooffset_t la, lb, poff, poffe;
long bsize;
- int bo_bs, br_flags, error, i;
+ int bo_bs, br_flags, error, i, pgsin, pgsin_a, pgsin_b;
bool redo, lpart;
object = vp->v_object;
@@ -4737,17 +4737,26 @@ vfs_bio_getpages(struct vnode *vp, vm_page_t *ma, int count,
return (VM_PAGER_BAD);
lpart = la + PAGE_SIZE > object->un_pager.vnp.vnp_size;
bo_bs = get_blksize(vp, get_lblkno(vp, IDX_TO_OFF(ma[0]->pindex)));
- if (rbehind != NULL) {
- lb = IDX_TO_OFF(ma[0]->pindex);
- *rbehind = OFF_TO_IDX(lb - rounddown2(lb, bo_bs));
- }
- if (rahead != NULL) {
- *rahead = OFF_TO_IDX(roundup2(la, bo_bs) - la);
- if (la + IDX_TO_OFF(*rahead) >= object->un_pager.vnp.vnp_size) {
- *rahead = OFF_TO_IDX(roundup2(object->un_pager.
- vnp.vnp_size, PAGE_SIZE) - la);
- }
- }
+
+ /*
+ * Calculate read-ahead, behind and total pages.
+ */
+ pgsin = count;
+ lb = IDX_TO_OFF(ma[0]->pindex);
+ pgsin_b = OFF_TO_IDX(lb - rounddown2(lb, bo_bs));
+ pgsin += pgsin_b;
+ if (rbehind != NULL)
+ *rbehind = pgsin_b;
+ pgsin_a = OFF_TO_IDX(roundup2(la, bo_bs) - la);
+ if (la + IDX_TO_OFF(pgsin_a) >= object->un_pager.vnp.vnp_size)
+ pgsin_a = OFF_TO_IDX(roundup2(object->un_pager.vnp.vnp_size,
+ PAGE_SIZE) - la);
+ pgsin += pgsin_a;
+ if (rahead != NULL)
+ *rahead = pgsin_a;
+ PCPU_INC(cnt.v_vnodein);
+ PCPU_ADD(cnt.v_vnodepgsin, pgsin);
+
br_flags = (mp != NULL && (mp->mnt_kern_flag & MNTK_UNMAPPED_BUFS)
!= 0) ? GB_UNMAPPED : 0;
VM_OBJECT_WLOCK(object);
OpenPOWER on IntegriCloud