diff options
author | kib <kib@FreeBSD.org> | 2012-09-28 11:25:02 +0000 |
---|---|---|
committer | kib <kib@FreeBSD.org> | 2012-09-28 11:25:02 +0000 |
commit | 8f845e475e69e9777c5f940109bf0c45b87aadda (patch) | |
tree | 2c2a67940ecbf715c5dc909f32de63a9eed6f793 /sys/kern/vnode_if.src | |
parent | 025fb75eb6e2720e82276647d1f8fad9515c281c (diff) | |
download | FreeBSD-src-8f845e475e69e9777c5f940109bf0c45b87aadda.zip FreeBSD-src-8f845e475e69e9777c5f940109bf0c45b87aadda.tar.gz |
Fix the mis-handling of the VV_TEXT on the nullfs vnodes.
If you have a binary on a filesystem which is also mounted over by
nullfs, you could execute the binary from the lower filesystem, or
from the nullfs mount. When executed from lower filesystem, the lower
vnode gets VV_TEXT flag set, and the file cannot be modified while the
binary is active. But, if executed as the nullfs alias, only the
nullfs vnode gets VV_TEXT set, and you still can open the lower vnode
for write.
Add a set of VOPs for the VV_TEXT query, set and clear operations,
which are correctly bypassed to lower vnode.
Tested by: pho (previous version)
MFC after: 2 weeks
Diffstat (limited to 'sys/kern/vnode_if.src')
-rw-r--r-- | sys/kern/vnode_if.src | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/sys/kern/vnode_if.src b/sys/kern/vnode_if.src index 5e3fa11..4c86ff6 100644 --- a/sys/kern/vnode_if.src +++ b/sys/kern/vnode_if.src @@ -660,6 +660,24 @@ vop_unp_detach { IN struct vnode *vp; }; +%% is_text vp L L L + +vop_is_text { + IN struct vnode *vp; +}; + +%% set_text vp E E E + +vop_set_text { + IN struct vnode *vp; +}; + +%% vop_unset_text vp E E E + +vop_unset_text { + IN struct vnode *vp; +}; + # 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, |