diff options
author | kib <kib@FreeBSD.org> | 2012-11-02 13:56:36 +0000 |
---|---|---|
committer | kib <kib@FreeBSD.org> | 2012-11-02 13:56:36 +0000 |
commit | f16ea990070abd8c9cb42bfc7001ada604b4df01 (patch) | |
tree | 77eb9f8e9de108d0ae7792cfceedcd340198177e /sys/kern/vnode_if.src | |
parent | 37f3bd87e4ec81bcec505485b1cf96c74db846f0 (diff) | |
download | FreeBSD-src-f16ea990070abd8c9cb42bfc7001ada604b4df01.zip FreeBSD-src-f16ea990070abd8c9cb42bfc7001ada604b4df01.tar.gz |
The r241025 fixed the case when a binary, executed from nullfs mount,
was still possible to open for write from the lower filesystem. There
is a symmetric situation where the binary could already has file
descriptors opened for write, but it can be executed from the nullfs
overlay.
Handle the issue by passing one v_writecount reference to the lower
vnode if nullfs vnode has non-zero v_writecount. Note that only one
write reference can be donated, since nullfs only keeps one use
reference on the lower vnode. Always use the lower vnode v_writecount
for the checks.
Introduce the VOP_GET_WRITECOUNT to read v_writecount, which is
currently always bypassed to the lower vnode, and VOP_ADD_WRITECOUNT
to manipulate the v_writecount value, which manages a single bypass
reference to the lower vnode. Caling the VOPs instead of directly
accessing v_writecount provide the fix described in the previous
paragraph.
Tested by: pho
MFC after: 3 weeks
Diffstat (limited to 'sys/kern/vnode_if.src')
-rw-r--r-- | sys/kern/vnode_if.src | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/sys/kern/vnode_if.src b/sys/kern/vnode_if.src index 4c86ff6..3c3563c 100644 --- a/sys/kern/vnode_if.src +++ b/sys/kern/vnode_if.src @@ -678,6 +678,20 @@ vop_unset_text { IN struct vnode *vp; }; +%% get_writecount vp L L L + +vop_get_writecount { + IN struct vnode *vp; + OUT int *writecount; +}; + +%% add_writecount vp E E E + +vop_add_writecount { + IN struct vnode *vp; + IN int inc; +}; + # The VOPs below are spares at the end of the table to allow new VOPs to be # added in stable branches without breaking the KBI. New VOPs in HEAD should # be added above these spares. When merging a new VOP to a stable branch, |