blob: b6243972edf3b0fbb5c177510aaab532b466cde8 [file] [log] [blame]
Ronnie Sahlberga6a9cff2020-10-21 10:22:33 +10001/* SPDX-License-Identifier: GPL-2.0-or-later */
2/*
3 * Copyright (C) 2020, Microsoft Corporation.
4 *
5 * Author(s): Steve French <stfrench@microsoft.com>
6 * David Howells <dhowells@redhat.com>
7 */
8
9#ifndef _FS_CONTEXT_H
10#define _FS_CONTEXT_H
11
Ronnie Sahlberg5c6e5aa2020-10-21 10:37:11 +100012#include "cifsglob.h"
Ronnie Sahlberg24e0a1e2020-12-10 00:06:02 -060013#include <linux/parser.h>
14#include <linux/fs_parser.h>
15
Aurelien Aptel9d4ac8b2021-03-01 19:25:00 +010016/* Log errors in fs_context (new mount api) but also in dmesg (old style) */
17#define cifs_errorf(fc, fmt, ...) \
18 do { \
19 errorf(fc, fmt, ## __VA_ARGS__); \
20 cifs_dbg(VFS, fmt, ## __VA_ARGS__); \
21 } while (0)
Ronnie Sahlberga6a9cff2020-10-21 10:22:33 +100022
Ronnie Sahlberg555782a2020-10-21 12:10:44 +100023enum smb_version {
24 Smb_1 = 1,
25 Smb_20,
26 Smb_21,
27 Smb_30,
28 Smb_302,
29 Smb_311,
30 Smb_3any,
31 Smb_default,
32 Smb_version_err
33};
34
Ronnie Sahlberg2f20f072020-10-21 11:30:35 +100035enum {
36 Opt_cache_loose,
37 Opt_cache_strict,
38 Opt_cache_none,
39 Opt_cache_ro,
40 Opt_cache_rw,
41 Opt_cache_err
42};
43
Ronnie Sahlberg5c6e5aa2020-10-21 10:37:11 +100044enum cifs_sec_param {
45 Opt_sec_krb5,
46 Opt_sec_krb5i,
47 Opt_sec_krb5p,
48 Opt_sec_ntlmsspi,
49 Opt_sec_ntlmssp,
50 Opt_ntlm,
51 Opt_sec_ntlmi,
52 Opt_sec_ntlmv2,
53 Opt_sec_ntlmv2i,
54 Opt_sec_lanman,
55 Opt_sec_none,
56
57 Opt_sec_err
58};
59
Ronnie Sahlberg15c7d092020-11-02 10:59:55 +100060enum cifs_param {
61 /* Mount options that take no arguments */
Ronnie Sahlberg24e0a1e2020-12-10 00:06:02 -060062 Opt_user_xattr,
63 Opt_forceuid,
64 Opt_forcegid,
Ronnie Sahlberg15c7d092020-11-02 10:59:55 +100065 Opt_noblocksend,
66 Opt_noautotune,
67 Opt_nolease,
Ronnie Sahlberg24e0a1e2020-12-10 00:06:02 -060068 Opt_hard,
69 Opt_soft,
70 Opt_perm,
Ronnie Sahlberg15c7d092020-11-02 10:59:55 +100071 Opt_nodelete,
Ronnie Sahlberg24e0a1e2020-12-10 00:06:02 -060072 Opt_mapposix,
Ronnie Sahlberg15c7d092020-11-02 10:59:55 +100073 Opt_mapchars,
74 Opt_nomapchars,
Ronnie Sahlberg24e0a1e2020-12-10 00:06:02 -060075 Opt_sfu,
Ronnie Sahlberg15c7d092020-11-02 10:59:55 +100076 Opt_nodfs,
Ronnie Sahlberg24e0a1e2020-12-10 00:06:02 -060077 Opt_posixpaths,
78 Opt_unix,
Ronnie Sahlberg15c7d092020-11-02 10:59:55 +100079 Opt_nocase,
Ronnie Sahlberg24e0a1e2020-12-10 00:06:02 -060080 Opt_brl,
81 Opt_handlecache,
Ronnie Sahlberg15c7d092020-11-02 10:59:55 +100082 Opt_forcemandatorylock,
83 Opt_setuidfromacl,
Ronnie Sahlberg24e0a1e2020-12-10 00:06:02 -060084 Opt_setuids,
85 Opt_dynperm,
86 Opt_intr,
87 Opt_strictsync,
88 Opt_serverino,
Ronnie Sahlberg15c7d092020-11-02 10:59:55 +100089 Opt_rwpidforward,
Ronnie Sahlberg24e0a1e2020-12-10 00:06:02 -060090 Opt_cifsacl,
91 Opt_acl,
Ronnie Sahlberg15c7d092020-11-02 10:59:55 +100092 Opt_locallease,
93 Opt_sign,
94 Opt_ignore_signature,
95 Opt_seal,
96 Opt_noac,
97 Opt_fsc,
98 Opt_mfsymlinks,
99 Opt_multiuser,
100 Opt_sloppy,
101 Opt_nosharesock,
Ronnie Sahlberg24e0a1e2020-12-10 00:06:02 -0600102 Opt_persistent,
103 Opt_resilient,
Ronnie Sahlberg15c7d092020-11-02 10:59:55 +1000104 Opt_domainauto,
105 Opt_rdma,
106 Opt_modesid,
107 Opt_rootfs,
Ronnie Sahlberg24e0a1e2020-12-10 00:06:02 -0600108 Opt_multichannel,
Ronnie Sahlberg15c7d092020-11-02 10:59:55 +1000109 Opt_compress,
Samuel Cabrero0ac4e292020-12-11 22:59:29 -0600110 Opt_witness,
Ronnie Sahlberg15c7d092020-11-02 10:59:55 +1000111
112 /* Mount options which take numeric value */
113 Opt_backupuid,
114 Opt_backupgid,
115 Opt_uid,
116 Opt_cruid,
117 Opt_gid,
118 Opt_port,
119 Opt_file_mode,
120 Opt_dirmode,
121 Opt_min_enc_offload,
122 Opt_blocksize,
Steve Frenchb8d64f82021-04-24 21:46:23 -0500123 Opt_rasize,
Ronnie Sahlberg15c7d092020-11-02 10:59:55 +1000124 Opt_rsize,
125 Opt_wsize,
126 Opt_actimeo,
Steve French4c9f9482021-02-23 15:50:57 -0600127 Opt_acdirmax,
Steve French57804642021-02-24 12:12:53 -0600128 Opt_acregmax,
Ronnie Sahlberg15c7d092020-11-02 10:59:55 +1000129 Opt_echo_interval,
130 Opt_max_credits,
131 Opt_snapshot,
132 Opt_max_channels,
133 Opt_handletimeout,
134
135 /* Mount options which take string value */
136 Opt_source,
137 Opt_user,
138 Opt_pass,
139 Opt_ip,
140 Opt_domain,
141 Opt_srcaddr,
142 Opt_iocharset,
143 Opt_netbiosname,
144 Opt_servern,
145 Opt_ver,
146 Opt_vers,
147 Opt_sec,
148 Opt_cache,
149
150 /* Mount options to be ignored */
151 Opt_ignore,
152
Ronnie Sahlberg15c7d092020-11-02 10:59:55 +1000153 Opt_err
154};
155
Ronnie Sahlberg3fa1c6d2020-12-09 23:07:12 -0600156struct smb3_fs_context {
157 bool uid_specified;
Ronnie Sahlberge0a3cbc2021-07-08 09:24:16 +1000158 bool cruid_specified;
Ronnie Sahlberg3fa1c6d2020-12-09 23:07:12 -0600159 bool gid_specified;
160 bool sloppy;
Ronnie Sahlberg3fa1c6d2020-12-09 23:07:12 -0600161 bool got_ip;
162 bool got_version;
Ronnie Sahlberg522aa3b2020-12-14 16:40:17 +1000163 bool got_rsize;
164 bool got_wsize;
165 bool got_bsize;
Ronnie Sahlberg3fa1c6d2020-12-09 23:07:12 -0600166 unsigned short port;
167
168 char *username;
169 char *password;
170 char *domainname;
Ronnie Sahlbergaf1a3d22021-02-11 16:06:16 +1000171 char *source;
Ronnie Sahlberg3fa1c6d2020-12-09 23:07:12 -0600172 char *UNC;
Ronnie Sahlberg9ccecae2020-12-14 16:40:19 +1000173 char *nodename;
Ronnie Sahlberg3fa1c6d2020-12-09 23:07:12 -0600174 char *iocharset; /* local code page for mapping to and from Unicode */
175 char source_rfc1001_name[RFC1001_NAME_LEN_WITH_NULL]; /* clnt nb name */
176 char target_rfc1001_name[RFC1001_NAME_LEN_WITH_NULL]; /* srvr nb name */
177 kuid_t cred_uid;
178 kuid_t linux_uid;
179 kgid_t linux_gid;
180 kuid_t backupuid;
181 kgid_t backupgid;
182 umode_t file_mode;
183 umode_t dir_mode;
184 enum securityEnum sectype; /* sectype requested via mnt opts */
185 bool sign; /* was signing requested via mnt opts? */
186 bool ignore_signature:1;
187 bool retry:1;
188 bool intr:1;
189 bool setuids:1;
190 bool setuidfromacl:1;
191 bool override_uid:1;
192 bool override_gid:1;
193 bool dynperm:1;
194 bool noperm:1;
195 bool nodelete:1;
196 bool mode_ace:1;
197 bool no_psx_acl:1; /* set if posix acl support should be disabled */
198 bool cifs_acl:1;
199 bool backupuid_specified; /* mount option backupuid is specified */
200 bool backupgid_specified; /* mount option backupgid is specified */
201 bool no_xattr:1; /* set if xattr (EA) support should be disabled*/
202 bool server_ino:1; /* use inode numbers from server ie UniqueId */
203 bool direct_io:1;
204 bool strict_io:1; /* strict cache behavior */
205 bool cache_ro:1;
206 bool cache_rw:1;
207 bool remap:1; /* set to remap seven reserved chars in filenames */
208 bool sfu_remap:1; /* remap seven reserved chars ala SFU */
209 bool posix_paths:1; /* unset to not ask for posix pathnames. */
210 bool no_linux_ext:1;
211 bool linux_ext:1;
212 bool sfu_emul:1;
213 bool nullauth:1; /* attempt to authenticate with null user */
214 bool nocase:1; /* request case insensitive filenames */
215 bool nobrl:1; /* disable sending byte range locks to srv */
216 bool nohandlecache:1; /* disable caching dir handles if srvr probs */
217 bool mand_lock:1; /* send mandatory not posix byte range lock reqs */
218 bool seal:1; /* request transport encryption on share */
219 bool nodfs:1; /* Do not request DFS, even if available */
220 bool local_lease:1; /* check leases only on local system, not remote */
221 bool noblocksnd:1;
222 bool noautotune:1;
223 bool nostrictsync:1; /* do not force expensive SMBflush on every sync */
224 bool no_lease:1; /* disable requesting leases */
225 bool fsc:1; /* enable fscache */
226 bool mfsymlinks:1; /* use Minshall+French Symlinks */
227 bool multiuser:1;
228 bool rwpidforward:1; /* pid forward for read/write operations */
229 bool nosharesock:1;
230 bool persistent:1;
231 bool nopersistent:1;
232 bool resilient:1; /* noresilient not required since not fored for CA */
233 bool domainauto:1;
234 bool rdma:1;
235 bool multichannel:1;
236 bool use_client_guid:1;
237 /* reuse existing guid for multichannel */
238 u8 client_guid[SMB2_CLIENT_GUID_SIZE];
239 unsigned int bsize;
Steve Frenchb8d64f82021-04-24 21:46:23 -0500240 unsigned int rasize;
Ronnie Sahlberg3fa1c6d2020-12-09 23:07:12 -0600241 unsigned int rsize;
242 unsigned int wsize;
243 unsigned int min_offload;
244 bool sockopt_tcp_nodelay:1;
Steve French57804642021-02-24 12:12:53 -0600245 /* attribute cache timemout for files and directories in jiffies */
246 unsigned long acregmax;
247 unsigned long acdirmax;
Ronnie Sahlberg3fa1c6d2020-12-09 23:07:12 -0600248 struct smb_version_operations *ops;
249 struct smb_version_values *vals;
250 char *prepath;
251 struct sockaddr_storage dstaddr; /* destination address */
252 struct sockaddr_storage srcaddr; /* allow binding to a local IP */
Ronnie Sahlberg387ec582020-12-14 16:40:20 +1000253 struct nls_table *local_nls; /* This is a copy of the pointer in cifs_sb */
Ronnie Sahlberg3fa1c6d2020-12-09 23:07:12 -0600254 unsigned int echo_interval; /* echo interval in secs */
255 __u64 snapshot_time; /* needed for timewarp tokens */
256 __u32 handle_timeout; /* persistent and durable handle timeout in ms */
257 unsigned int max_credits; /* smb3 max_credits 10 < credits < 60000 */
258 unsigned int max_channels;
259 __u16 compression; /* compression algorithm 0xFFFF default 0=disabled */
260 bool rootfs:1; /* if it's a SMB root file system */
Samuel Cabrero0ac4e292020-12-11 22:59:29 -0600261 bool witness:1; /* use witness protocol */
Ronnie Sahlberg24e0a1e2020-12-10 00:06:02 -0600262
263 char *mount_options;
Ronnie Sahlberg3fa1c6d2020-12-09 23:07:12 -0600264};
265
Ronnie Sahlberg24e0a1e2020-12-10 00:06:02 -0600266extern const struct fs_parameter_spec smb3_fs_parameters[];
267
Ronnie Sahlberg24e0a1e2020-12-10 00:06:02 -0600268extern int smb3_init_fs_context(struct fs_context *fc);
Ronnie Sahlbergc741cba2020-12-14 16:40:16 +1000269extern void smb3_cleanup_fs_context_contents(struct smb3_fs_context *ctx);
270extern void smb3_cleanup_fs_context(struct smb3_fs_context *ctx);
Ronnie Sahlberg24e0a1e2020-12-10 00:06:02 -0600271
272static inline struct smb3_fs_context *smb3_fc2context(const struct fs_context *fc)
273{
274 return fc->fs_private;
275}
276
Ronnie Sahlberg837e3a12020-11-02 09:36:24 +1000277extern int smb3_fs_context_dup(struct smb3_fs_context *new_ctx, struct smb3_fs_context *ctx);
Ronnie Sahlberg2d39f502020-12-14 16:40:25 +1000278extern void smb3_update_mnt_flags(struct cifs_sb_info *cifs_sb);
Ronnie Sahlberga6a9cff2020-10-21 10:22:33 +1000279
280#endif