summaryrefslogtreecommitdiffstats
path: root/sys/kern
diff options
context:
space:
mode:
authorrwatson <rwatson@FreeBSD.org>2003-06-22 23:03:07 +0000
committerrwatson <rwatson@FreeBSD.org>2003-06-22 23:03:07 +0000
commit45b727fb419518245f31034506b46523e0be97ce (patch)
treeaffd6b23d626ba835f70f989f610ee811a3ab062 /sys/kern
parenteb83dc490d02342ca04aeac31e6a2333e01018fd (diff)
downloadFreeBSD-src-45b727fb419518245f31034506b46523e0be97ce.zip
FreeBSD-src-45b727fb419518245f31034506b46523e0be97ce.tar.gz
Prefer the vop_rmextattr() vnode operation for removing extended
attributes from objects over vop_setextattr() with a NULL uio; if the file system doesn't support the vop_rmextattr() method, fall back to the vop_setextattr() method. Obtained from: TrustedBSD Project Sponsored by: DARPA, Network Associates Laboratories
Diffstat (limited to 'sys/kern')
-rw-r--r--sys/kern/vfs_extattr.c6
-rw-r--r--sys/kern/vfs_syscalls.c6
-rw-r--r--sys/kern/vfs_vnops.c5
3 files changed, 12 insertions, 5 deletions
diff --git a/sys/kern/vfs_extattr.c b/sys/kern/vfs_extattr.c
index 3b45d43..000fa0a 100644
--- a/sys/kern/vfs_extattr.c
+++ b/sys/kern/vfs_extattr.c
@@ -4245,8 +4245,10 @@ extattr_delete_vp(struct vnode *vp, int attrnamespace, const char *attrname,
goto done;
#endif
- error = VOP_SETEXTATTR(vp, attrnamespace, attrname, NULL, td->td_ucred,
- td);
+ error = VOP_RMEXTATTR(vp, attrnamespace, attrname, td->td_ucred, td);
+ if (error == EOPNOTSUPP)
+ error = VOP_SETEXTATTR(vp, attrnamespace, attrname, NULL,
+ td->td_ucred, td);
#ifdef MAC
done:
#endif
diff --git a/sys/kern/vfs_syscalls.c b/sys/kern/vfs_syscalls.c
index 3b45d43..000fa0a 100644
--- a/sys/kern/vfs_syscalls.c
+++ b/sys/kern/vfs_syscalls.c
@@ -4245,8 +4245,10 @@ extattr_delete_vp(struct vnode *vp, int attrnamespace, const char *attrname,
goto done;
#endif
- error = VOP_SETEXTATTR(vp, attrnamespace, attrname, NULL, td->td_ucred,
- td);
+ error = VOP_RMEXTATTR(vp, attrnamespace, attrname, td->td_ucred, td);
+ if (error == EOPNOTSUPP)
+ error = VOP_SETEXTATTR(vp, attrnamespace, attrname, NULL,
+ td->td_ucred, td);
#ifdef MAC
done:
#endif
diff --git a/sys/kern/vfs_vnops.c b/sys/kern/vfs_vnops.c
index 8d8f13d..2b53323 100644
--- a/sys/kern/vfs_vnops.c
+++ b/sys/kern/vfs_vnops.c
@@ -1150,7 +1150,10 @@ vn_extattr_rm(struct vnode *vp, int ioflg, int attrnamespace,
}
/* authorize attribute removal as kernel */
- error = VOP_SETEXTATTR(vp, attrnamespace, attrname, NULL, NULL, td);
+ error = VOP_RMEXTATTR(vp, attrnamespace, attrname, NULL, td);
+ if (error == EOPNOTSUPP)
+ error = VOP_SETEXTATTR(vp, attrnamespace, attrname, NULL,
+ NULL, td);
if ((ioflg & IO_NODELOCKED) == 0) {
vn_finished_write(mp);
OpenPOWER on IntegriCloud