aboutsummaryrefslogtreecommitdiff
path: root/sys/contrib/openzfs
diff options
context:
space:
mode:
authorMark Johnston <markj@FreeBSD.org>2020-09-29 13:41:47 +0000
committerMark Johnston <markj@FreeBSD.org>2020-09-29 13:41:47 +0000
commit752c1d14e398faab8e6f19f99ee29df87ecb05e1 (patch)
tree18b6a2995ed678bbbbe21b4898340ba7b6710fa3 /sys/contrib/openzfs
parent39e75a5a79ec67aadbfb066b08e17e02fc378388 (diff)
Notes
Diffstat (limited to 'sys/contrib/openzfs')
-rw-r--r--sys/contrib/openzfs/module/os/freebsd/zfs/zfs_vnops.c6
1 files changed, 4 insertions, 2 deletions
diff --git a/sys/contrib/openzfs/module/os/freebsd/zfs/zfs_vnops.c b/sys/contrib/openzfs/module/os/freebsd/zfs/zfs_vnops.c
index 2dde5b1f9d5c1..79202b60a6f01 100644
--- a/sys/contrib/openzfs/module/os/freebsd/zfs/zfs_vnops.c
+++ b/sys/contrib/openzfs/module/os/freebsd/zfs/zfs_vnops.c
@@ -4859,7 +4859,8 @@ zfs_getpages(struct vnode *vp, vm_page_t *ma, int count, int *rbehind,
obj_size = object->un_pager.vnp.vnp_size;
zfs_vmobject_wunlock(object);
if (IDX_TO_OFF(ma[count - 1]->pindex) >= obj_size) {
- zfs_rangelock_exit(lr);
+ if (lr != NULL)
+ zfs_rangelock_exit(lr);
ZFS_EXIT(zfsvfs);
return (zfs_vm_pagerret_bad);
}
@@ -4887,7 +4888,8 @@ zfs_getpages(struct vnode *vp, vm_page_t *ma, int count, int *rbehind,
error = dmu_read_pages(os, zp->z_id, ma, count, &pgsin_b, &pgsin_a,
MIN(end, obj_size) - (end - PAGE_SIZE));
- zfs_rangelock_exit(lr);
+ if (lr != NULL)
+ zfs_rangelock_exit(lr);
ZFS_ACCESSTIME_STAMP(zfsvfs, zp);
ZFS_EXIT(zfsvfs);