aboutsummaryrefslogtreecommitdiff
path: root/sys/ufs
diff options
context:
space:
mode:
authorJonathan Lemon <jlemon@FreeBSD.org>2001-02-23 20:06:01 +0000
committerJonathan Lemon <jlemon@FreeBSD.org>2001-02-23 20:06:01 +0000
commit7df2842deef5cf746f9dfbf3e7b10df8b796b4e2 (patch)
tree419f6040b9ed2cbd09aa5ad9034c1d80420c1bb7 /sys/ufs
parent15e0aafdc290bc0cbfbfc6385173e0ce906ad46a (diff)
downloadsrc-7df2842deef5cf746f9dfbf3e7b10df8b796b4e2.tar.gz
src-7df2842deef5cf746f9dfbf3e7b10df8b796b4e2.zip
Add a NOTE_REVOKE flag for vnodes, which is triggered from within vclean().
Use this to tell a filter attached to a vnode that the underlying vnode is no longer valid, by returning EV_EOF. PR: kern/25309, kern/25206
Notes
Notes: svn path=/head/; revision=72956
Diffstat (limited to 'sys/ufs')
-rw-r--r--sys/ufs/ufs/ufs_vnops.c13
1 files changed, 13 insertions, 0 deletions
diff --git a/sys/ufs/ufs/ufs_vnops.c b/sys/ufs/ufs/ufs_vnops.c
index 29efbcc221a7..870d6dd74177 100644
--- a/sys/ufs/ufs/ufs_vnops.c
+++ b/sys/ufs/ufs/ufs_vnops.c
@@ -2235,6 +2235,15 @@ filt_ufsread(struct knote *kn, long hint)
struct vnode *vp = (struct vnode *)kn->kn_hook;
struct inode *ip = VTOI(vp);
+ /*
+ * filesystem is gone, so set the EOF flag and schedule
+ * the knote for deletion.
+ */
+ if (hint == NOTE_REVOKE) {
+ kn->kn_flags |= (EV_EOF | EV_ONESHOT);
+ return (1);
+ }
+
kn->kn_data = ip->i_size - kn->kn_fp->f_offset;
return (kn->kn_data != 0);
}
@@ -2245,6 +2254,10 @@ filt_ufsvnode(struct knote *kn, long hint)
if (kn->kn_sfflags & hint)
kn->kn_fflags |= hint;
+ if (hint == NOTE_REVOKE) {
+ kn->kn_flags |= EV_EOF;
+ return (1);
+ }
return (kn->kn_fflags != 0);
}