diff options
author | J. Bruce Fields <bfields@redhat.com> | 2011-01-11 14:07:12 -0500 |
---|---|---|
committer | J. Bruce Fields <bfields@redhat.com> | 2011-01-13 21:04:07 -0500 |
commit | 9ce137eee4febaabca81143be07d4205d2bd52d4 (patch) | |
tree | e52e5225e1d113164382bf85bca83a2c0330d64e /fs/nfsd/vfs.c | |
parent | 9ee1ba5402e9d35fb35f8e61c968f4987b5fb443 (diff) |
nfsd: don't support msnfs export option
We've long had these pointless #ifdef MSNFS's sprinkled throughout the
code--pointless because MSNFS is always defined (and we give no config
option to make that easy to change). So we could just remove the
ifdef's and compile the resulting code unconditionally.
But as long as we're there: why not just rip out this code entirely?
The only purpose is to implement the "msnfs" export option which turns
on Windows-like behavior in some cases, and:
- the export option isn't documented anywhere;
- the userland utilities (which would need to be able to parse
"msnfs" in an export file) don't support it;
- I don't know how to maintain this, as I don't know what the
proper behavior is; and
- google shows no evidence that anyone has ever used this.
Signed-off-by: J. Bruce Fields <bfields@redhat.com>
Diffstat (limited to 'fs/nfsd/vfs.c')
-rw-r--r-- | fs/nfsd/vfs.c | 41 |
1 files changed, 2 insertions, 39 deletions
diff --git a/fs/nfsd/vfs.c b/fs/nfsd/vfs.c index b991125ce4a5..0a01e2fc5dda 100644 --- a/fs/nfsd/vfs.c +++ b/fs/nfsd/vfs.c | |||
@@ -1,4 +1,3 @@ | |||
1 | #define MSNFS /* HACK HACK */ | ||
2 | /* | 1 | /* |
3 | * File operations used by nfsd. Some of these have been ripped from | 2 | * File operations used by nfsd. Some of these have been ripped from |
4 | * other parts of the kernel because they weren't exported, others | 3 | * other parts of the kernel because they weren't exported, others |
@@ -875,15 +874,6 @@ static int nfsd_direct_splice_actor(struct pipe_inode_info *pipe, | |||
875 | return __splice_from_pipe(pipe, sd, nfsd_splice_actor); | 874 | return __splice_from_pipe(pipe, sd, nfsd_splice_actor); |
876 | } | 875 | } |
877 | 876 | ||
878 | static inline int svc_msnfs(struct svc_fh *ffhp) | ||
879 | { | ||
880 | #ifdef MSNFS | ||
881 | return (ffhp->fh_export->ex_flags & NFSEXP_MSNFS); | ||
882 | #else | ||
883 | return 0; | ||
884 | #endif | ||
885 | } | ||
886 | |||
887 | static __be32 | 877 | static __be32 |
888 | nfsd_vfs_read(struct svc_rqst *rqstp, struct svc_fh *fhp, struct file *file, | 878 | nfsd_vfs_read(struct svc_rqst *rqstp, struct svc_fh *fhp, struct file *file, |
889 | loff_t offset, struct kvec *vec, int vlen, unsigned long *count) | 879 | loff_t offset, struct kvec *vec, int vlen, unsigned long *count) |
@@ -896,9 +886,6 @@ nfsd_vfs_read(struct svc_rqst *rqstp, struct svc_fh *fhp, struct file *file, | |||
896 | err = nfserr_perm; | 886 | err = nfserr_perm; |
897 | inode = file->f_path.dentry->d_inode; | 887 | inode = file->f_path.dentry->d_inode; |
898 | 888 | ||
899 | if (svc_msnfs(fhp) && !lock_may_read(inode, offset, *count)) | ||
900 | goto out; | ||
901 | |||
902 | if (file->f_op->splice_read && rqstp->rq_splice_ok) { | 889 | if (file->f_op->splice_read && rqstp->rq_splice_ok) { |
903 | struct splice_desc sd = { | 890 | struct splice_desc sd = { |
904 | .len = 0, | 891 | .len = 0, |
@@ -923,7 +910,6 @@ nfsd_vfs_read(struct svc_rqst *rqstp, struct svc_fh *fhp, struct file *file, | |||
923 | fsnotify_access(file); | 910 | fsnotify_access(file); |
924 | } else | 911 | } else |
925 | err = nfserrno(host_err); | 912 | err = nfserrno(host_err); |
926 | out: | ||
927 | return err; | 913 | return err; |
928 | } | 914 | } |
929 | 915 | ||
@@ -988,14 +974,6 @@ nfsd_vfs_write(struct svc_rqst *rqstp, struct svc_fh *fhp, struct file *file, | |||
988 | int stable = *stablep; | 974 | int stable = *stablep; |
989 | int use_wgather; | 975 | int use_wgather; |
990 | 976 | ||
991 | #ifdef MSNFS | ||
992 | err = nfserr_perm; | ||
993 | |||
994 | if ((fhp->fh_export->ex_flags & NFSEXP_MSNFS) && | ||
995 | (!lock_may_write(file->f_path.dentry->d_inode, offset, *cnt))) | ||
996 | goto out; | ||
997 | #endif | ||
998 | |||
999 | dentry = file->f_path.dentry; | 977 | dentry = file->f_path.dentry; |
1000 | inode = dentry->d_inode; | 978 | inode = dentry->d_inode; |
1001 | exp = fhp->fh_export; | 979 | exp = fhp->fh_export; |
@@ -1046,7 +1024,6 @@ out_nfserr: | |||
1046 | err = 0; | 1024 | err = 0; |
1047 | else | 1025 | else |
1048 | err = nfserrno(host_err); | 1026 | err = nfserrno(host_err); |
1049 | out: | ||
1050 | return err; | 1027 | return err; |
1051 | } | 1028 | } |
1052 | 1029 | ||
@@ -1751,13 +1728,6 @@ nfsd_rename(struct svc_rqst *rqstp, struct svc_fh *ffhp, char *fname, int flen, | |||
1751 | if (ndentry == trap) | 1728 | if (ndentry == trap) |
1752 | goto out_dput_new; | 1729 | goto out_dput_new; |
1753 | 1730 | ||
1754 | if (svc_msnfs(ffhp) && | ||
1755 | ((atomic_read(&odentry->d_count) > 1) | ||
1756 | || (atomic_read(&ndentry->d_count) > 1))) { | ||
1757 | host_err = -EPERM; | ||
1758 | goto out_dput_new; | ||
1759 | } | ||
1760 | |||
1761 | host_err = -EXDEV; | 1731 | host_err = -EXDEV; |
1762 | if (ffhp->fh_export->ex_path.mnt != tfhp->fh_export->ex_path.mnt) | 1732 | if (ffhp->fh_export->ex_path.mnt != tfhp->fh_export->ex_path.mnt) |
1763 | goto out_dput_new; | 1733 | goto out_dput_new; |
@@ -1836,17 +1806,10 @@ nfsd_unlink(struct svc_rqst *rqstp, struct svc_fh *fhp, int type, | |||
1836 | if (host_err) | 1806 | if (host_err) |
1837 | goto out_nfserr; | 1807 | goto out_nfserr; |
1838 | 1808 | ||
1839 | if (type != S_IFDIR) { /* It's UNLINK */ | 1809 | if (type != S_IFDIR) |
1840 | #ifdef MSNFS | ||
1841 | if ((fhp->fh_export->ex_flags & NFSEXP_MSNFS) && | ||
1842 | (atomic_read(&rdentry->d_count) > 1)) { | ||
1843 | host_err = -EPERM; | ||
1844 | } else | ||
1845 | #endif | ||
1846 | host_err = vfs_unlink(dirp, rdentry); | 1810 | host_err = vfs_unlink(dirp, rdentry); |
1847 | } else { /* It's RMDIR */ | 1811 | else |
1848 | host_err = vfs_rmdir(dirp, rdentry); | 1812 | host_err = vfs_rmdir(dirp, rdentry); |
1849 | } | ||
1850 | 1813 | ||
1851 | dput(rdentry); | 1814 | dput(rdentry); |
1852 | 1815 | ||