1 /* SPDX-License-Identifier: GPL-2.0 */
3 * Copyright (C) 1995-1997 Olaf Kirch <okir@monad.swb.de>
6 #ifndef LINUX_NFSD_VFS_H
7 #define LINUX_NFSD_VFS_H
13 * Flags for nfsd_permission
15 #define NFSD_MAY_NOP 0
16 #define NFSD_MAY_EXEC 0x001 /* == MAY_EXEC */
17 #define NFSD_MAY_WRITE 0x002 /* == MAY_WRITE */
18 #define NFSD_MAY_READ 0x004 /* == MAY_READ */
19 #define NFSD_MAY_SATTR 0x008
20 #define NFSD_MAY_TRUNC 0x010
21 #define NFSD_MAY_LOCK 0x020
22 #define NFSD_MAY_MASK 0x03f
24 /* extra hints to permission and open routines: */
25 #define NFSD_MAY_OWNER_OVERRIDE 0x040
26 #define NFSD_MAY_LOCAL_ACCESS 0x080 /* for device special files */
27 #define NFSD_MAY_BYPASS_GSS_ON_ROOT 0x100
28 #define NFSD_MAY_NOT_BREAK_LEASE 0x200
29 #define NFSD_MAY_BYPASS_GSS 0x400
30 #define NFSD_MAY_READ_IF_EXEC 0x800
32 #define NFSD_MAY_64BIT_COOKIE 0x1000 /* 64 bit readdir cookies for >= NFSv3 */
34 #define NFSD_MAY_CREATE (NFSD_MAY_EXEC|NFSD_MAY_WRITE)
35 #define NFSD_MAY_REMOVE (NFSD_MAY_EXEC|NFSD_MAY_WRITE|NFSD_MAY_TRUNC)
38 * Callback function for readdir
40 typedef int (*nfsd_filldir_t
)(void *, const char *, int, loff_t
, u64
, unsigned);
43 int nfsd_racache_init(int);
44 void nfsd_racache_shutdown(void);
45 int nfsd_cross_mnt(struct svc_rqst
*rqstp
, struct dentry
**dpp
,
46 struct svc_export
**expp
);
47 __be32
nfsd_lookup(struct svc_rqst
*, struct svc_fh
*,
48 const char *, unsigned int, struct svc_fh
*);
49 __be32
nfsd_lookup_dentry(struct svc_rqst
*, struct svc_fh
*,
50 const char *, unsigned int,
51 struct svc_export
**, struct dentry
**);
52 __be32
nfsd_setattr(struct svc_rqst
*, struct svc_fh
*,
53 struct iattr
*, int, time_t);
54 int nfsd_mountpoint(struct dentry
*, struct svc_export
*);
56 __be32
nfsd4_set_nfs4_label(struct svc_rqst
*, struct svc_fh
*,
58 __be32
nfsd4_vfs_fallocate(struct svc_rqst
*, struct svc_fh
*,
59 struct file
*, loff_t
, loff_t
, int);
60 __be32
nfsd4_clone_file_range(struct file
*, u64
, struct file
*,
62 #endif /* CONFIG_NFSD_V4 */
63 __be32
nfsd_create_locked(struct svc_rqst
*, struct svc_fh
*,
64 char *name
, int len
, struct iattr
*attrs
,
65 int type
, dev_t rdev
, struct svc_fh
*res
);
66 __be32
nfsd_create(struct svc_rqst
*, struct svc_fh
*,
67 char *name
, int len
, struct iattr
*attrs
,
68 int type
, dev_t rdev
, struct svc_fh
*res
);
70 __be32
nfsd_access(struct svc_rqst
*, struct svc_fh
*, u32
*, u32
*);
71 __be32
do_nfsd_create(struct svc_rqst
*, struct svc_fh
*,
72 char *name
, int len
, struct iattr
*attrs
,
73 struct svc_fh
*res
, int createmode
,
74 u32
*verifier
, bool *truncp
, bool *created
);
75 __be32
nfsd_commit(struct svc_rqst
*, struct svc_fh
*,
76 loff_t
, unsigned long);
77 #endif /* CONFIG_NFSD_V3 */
78 __be32
nfsd_open(struct svc_rqst
*, struct svc_fh
*, umode_t
,
81 __be32
nfsd_splice_read(struct svc_rqst
*,
82 struct file
*, loff_t
, unsigned long *);
83 __be32
nfsd_readv(struct file
*, loff_t
, struct kvec
*, int,
85 __be32
nfsd_read(struct svc_rqst
*, struct svc_fh
*,
86 loff_t
, struct kvec
*, int, unsigned long *);
87 __be32
nfsd_write(struct svc_rqst
*, struct svc_fh
*, loff_t
,
88 struct kvec
*, int, unsigned long *, int);
89 __be32
nfsd_vfs_write(struct svc_rqst
*rqstp
, struct svc_fh
*fhp
,
90 struct file
*file
, loff_t offset
,
91 struct kvec
*vec
, int vlen
, unsigned long *cnt
,
93 __be32
nfsd_readlink(struct svc_rqst
*, struct svc_fh
*,
95 __be32
nfsd_symlink(struct svc_rqst
*, struct svc_fh
*,
96 char *name
, int len
, char *path
,
98 __be32
nfsd_link(struct svc_rqst
*, struct svc_fh
*,
99 char *, int, struct svc_fh
*);
100 ssize_t
nfsd_copy_file_range(struct file
*, u64
,
101 struct file
*, u64
, u64
);
102 __be32
nfsd_rename(struct svc_rqst
*,
103 struct svc_fh
*, char *, int,
104 struct svc_fh
*, char *, int);
105 __be32
nfsd_unlink(struct svc_rqst
*, struct svc_fh
*, int type
,
106 char *name
, int len
);
107 __be32
nfsd_readdir(struct svc_rqst
*, struct svc_fh
*,
108 loff_t
*, struct readdir_cd
*, nfsd_filldir_t
);
109 __be32
nfsd_statfs(struct svc_rqst
*, struct svc_fh
*,
110 struct kstatfs
*, int access
);
112 __be32
nfsd_permission(struct svc_rqst
*, struct svc_export
*,
113 struct dentry
*, int);
115 struct raparms
*nfsd_init_raparms(struct file
*file
);
116 void nfsd_put_raparams(struct file
*file
, struct raparms
*ra
);
118 static inline int fh_want_write(struct svc_fh
*fh
)
120 int ret
= mnt_want_write(fh
->fh_export
->ex_path
.mnt
);
123 fh
->fh_want_write
= true;
127 static inline void fh_drop_write(struct svc_fh
*fh
)
129 if (fh
->fh_want_write
) {
130 fh
->fh_want_write
= false;
131 mnt_drop_write(fh
->fh_export
->ex_path
.mnt
);
135 static inline __be32
fh_getattr(struct svc_fh
*fh
, struct kstat
*stat
)
137 struct path p
= {.mnt
= fh
->fh_export
->ex_path
.mnt
,
138 .dentry
= fh
->fh_dentry
};
139 return nfserrno(vfs_getattr(&p
, stat
, STATX_BASIC_STATS
,
140 AT_STATX_SYNC_AS_STAT
));
143 static inline int nfsd_create_is_exclusive(int createmode
)
145 return createmode
== NFS3_CREATE_EXCLUSIVE
146 || createmode
== NFS4_CREATE_EXCLUSIVE4_1
;
149 static inline bool nfsd_eof_on_read(long requested
, long read
,
150 loff_t offset
, loff_t size
)
152 /* We assume a short read means eof: */
153 if (requested
> read
)
156 * A non-short read might also reach end of file. The spec
157 * still requires us to set eof in that case.
159 * Further operations may have modified the file size since
160 * the read, so the following check is not atomic with the read.
161 * We've only seen that cause a problem for a client in the case
162 * where the read returned a count of 0 without setting eof.
163 * That case was fixed by the addition of the above check.
165 return (offset
+ read
>= size
);
168 #endif /* LINUX_NFSD_VFS_H */