]> git.proxmox.com Git - mirror_ubuntu-jammy-kernel.git/blame - fs/cifs/cifsfs.c
CIFS: Make cifsFileInfo_put work with strict cache mode
[mirror_ubuntu-jammy-kernel.git] / fs / cifs / cifsfs.c
CommitLineData
1da177e4
LT
1/*
2 * fs/cifs/cifsfs.c
3 *
2b280fab 4 * Copyright (C) International Business Machines Corp., 2002,2008
1da177e4
LT
5 * Author(s): Steve French (sfrench@us.ibm.com)
6 *
7 * Common Internet FileSystem (CIFS) client
8 *
9 * This library is free software; you can redistribute it and/or modify
10 * it under the terms of the GNU Lesser General Public License as published
11 * by the Free Software Foundation; either version 2.1 of the License, or
12 * (at your option) any later version.
13 *
14 * This library is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See
17 * the GNU Lesser General Public License for more details.
18 *
19 * You should have received a copy of the GNU Lesser General Public License
20 * along with this library; if not, write to the Free Software
21 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
22 */
23
24/* Note that BB means BUGBUG (ie something to fix eventually) */
25
26#include <linux/module.h>
27#include <linux/fs.h>
28#include <linux/mount.h>
29#include <linux/slab.h>
30#include <linux/init.h>
31#include <linux/list.h>
32#include <linux/seq_file.h>
33#include <linux/vfs.h>
34#include <linux/mempool.h>
6ab16d24 35#include <linux/delay.h>
45af7a0f 36#include <linux/kthread.h>
7dfb7103 37#include <linux/freezer.h>
3eb9a889 38#include <net/ipv6.h>
1da177e4
LT
39#include "cifsfs.h"
40#include "cifspdu.h"
41#define DECLARE_GLOBALS_HERE
42#include "cifsglob.h"
43#include "cifsproto.h"
44#include "cifs_debug.h"
45#include "cifs_fs_sb.h"
46#include <linux/mm.h>
84a15b93 47#include <linux/key-type.h>
e545937a 48#include "cifs_spnego.h"
f579cf3c 49#include "fscache.h"
1da177e4
LT
50#define CIFS_MAGIC_NUMBER 0xFF534D42 /* the first four bytes of SMB PDUs */
51
1da177e4
LT
52int cifsFYI = 0;
53int cifsERROR = 1;
54int traceSMB = 0;
55unsigned int oplockEnabled = 1;
56unsigned int experimEnabled = 0;
57unsigned int linuxExtEnabled = 1;
58unsigned int lookupCacheEnabled = 1;
59unsigned int multiuser_mount = 0;
04912d6a 60unsigned int global_secflags = CIFSSEC_DEF;
3979877e 61/* unsigned int ntlmv2_support = 0; */
1da177e4 62unsigned int sign_CIFS_PDUs = 1;
ee9b6d61 63static const struct super_operations cifs_super_ops;
1da177e4
LT
64unsigned int CIFSMaxBufSize = CIFS_MAX_MSGSIZE;
65module_param(CIFSMaxBufSize, int, 0);
63135e08
SF
66MODULE_PARM_DESC(CIFSMaxBufSize, "Network buffer size (not including header). "
67 "Default: 16384 Range: 8192 to 130048");
1da177e4
LT
68unsigned int cifs_min_rcv = CIFS_MIN_RCV_POOL;
69module_param(cifs_min_rcv, int, 0);
63135e08
SF
70MODULE_PARM_DESC(cifs_min_rcv, "Network buffers in pool. Default: 4 Range: "
71 "1 to 64");
1da177e4
LT
72unsigned int cifs_min_small = 30;
73module_param(cifs_min_small, int, 0);
63135e08
SF
74MODULE_PARM_DESC(cifs_min_small, "Small network buffers in pool. Default: 30 "
75 "Range: 2 to 256");
1da177e4
LT
76unsigned int cifs_max_pending = CIFS_MAX_REQ;
77module_param(cifs_max_pending, int, 0);
63135e08
SF
78MODULE_PARM_DESC(cifs_max_pending, "Simultaneous requests to server. "
79 "Default: 50 Range: 2 to 256");
fda35943
SF
80unsigned short echo_retries = 5;
81module_param(echo_retries, ushort, 0644);
82MODULE_PARM_DESC(echo_retries, "Number of echo attempts before giving up and "
83 "reconnecting server. Default: 5. 0 means "
84 "never reconnect.");
1da177e4
LT
85extern mempool_t *cifs_sm_req_poolp;
86extern mempool_t *cifs_req_poolp;
87extern mempool_t *cifs_mid_poolp;
88
d7c86ff8
JL
89void
90cifs_sb_active(struct super_block *sb)
91{
92 struct cifs_sb_info *server = CIFS_SB(sb);
93
94 if (atomic_inc_return(&server->active) == 1)
95 atomic_inc(&sb->s_active);
96}
97
98void
99cifs_sb_deactive(struct super_block *sb)
100{
101 struct cifs_sb_info *server = CIFS_SB(sb);
102
103 if (atomic_dec_and_test(&server->active))
104 deactivate_super(sb);
105}
106
1da177e4
LT
107static int
108cifs_read_super(struct super_block *sb, void *data,
109 const char *devname, int silent)
110{
111 struct inode *inode;
112 struct cifs_sb_info *cifs_sb;
113 int rc = 0;
50c2f753 114
1b2b2126
SF
115 /* BB should we make this contingent on mount parm? */
116 sb->s_flags |= MS_NODIRATIME | MS_NOATIME;
790fe579 117 sb->s_fs_info = kzalloc(sizeof(struct cifs_sb_info), GFP_KERNEL);
1da177e4 118 cifs_sb = CIFS_SB(sb);
4523cc30 119 if (cifs_sb == NULL)
1da177e4 120 return -ENOMEM;
1da177e4 121
0dd12c21 122 spin_lock_init(&cifs_sb->tlink_tree_lock);
b647c35f 123 cifs_sb->tlink_tree = RB_ROOT;
0dd12c21 124
8044f7f4
JA
125 rc = bdi_setup_and_register(&cifs_sb->bdi, "cifs", BDI_CAP_MAP_COPY);
126 if (rc) {
127 kfree(cifs_sb);
128 return rc;
129 }
130
e6ab1582
IM
131#ifdef CONFIG_CIFS_DFS_UPCALL
132 /* copy mount params to sb for use in submounts */
133 /* BB: should we move this after the mount so we
134 * do not have to do the copy on failed mounts?
135 * BB: May be it is better to do simple copy before
136 * complex operation (mount), and in case of fail
137 * just exit instead of doing mount and attempting
138 * undo it if this copy fails?*/
79ee9a8b
SF
139 if (data) {
140 int len = strlen(data);
141 cifs_sb->mountdata = kzalloc(len + 1, GFP_KERNEL);
142 if (cifs_sb->mountdata == NULL) {
8044f7f4 143 bdi_destroy(&cifs_sb->bdi);
79ee9a8b
SF
144 kfree(sb->s_fs_info);
145 sb->s_fs_info = NULL;
146 return -ENOMEM;
147 }
148 strncpy(cifs_sb->mountdata, data, len + 1);
149 cifs_sb->mountdata[len] = '\0';
e6ab1582 150 }
e6ab1582
IM
151#endif
152
1da177e4
LT
153 rc = cifs_mount(sb, cifs_sb, data, devname);
154
155 if (rc) {
156 if (!silent)
b6b38f70 157 cERROR(1, "cifs_mount failed w/return code = %d", rc);
1da177e4
LT
158 goto out_mount_failed;
159 }
160
161 sb->s_magic = CIFS_MAGIC_NUMBER;
162 sb->s_op = &cifs_super_ops;
8044f7f4 163 sb->s_bdi = &cifs_sb->bdi;
1da177e4
LT
164 sb->s_blocksize = CIFS_MAX_MSGSIZE;
165 sb->s_blocksize_bits = 14; /* default 2**14 = CIFS_MAX_MSGSIZE */
bd433d4c 166 inode = cifs_root_iget(sb, ROOT_I);
1da177e4 167
ce634ab2
DH
168 if (IS_ERR(inode)) {
169 rc = PTR_ERR(inode);
170 inode = NULL;
1da177e4
LT
171 goto out_no_root;
172 }
173
174 sb->s_root = d_alloc_root(inode);
175
176 if (!sb->s_root) {
177 rc = -ENOMEM;
178 goto out_no_root;
179 }
50c2f753 180
1c929cfe
AV
181 /* do that *after* d_alloc_root() - we want NULL ->d_op for root here */
182 if (cifs_sb_master_tcon(cifs_sb)->nocase)
183 sb->s_d_op = &cifs_ci_dentry_ops;
184 else
185 sb->s_d_op = &cifs_dentry_ops;
186
7521a3c5
SF
187#ifdef CONFIG_CIFS_EXPERIMENTAL
188 if (cifs_sb->mnt_cifs_flags & CIFS_MOUNT_SERVER_INUM) {
b6b38f70 189 cFYI(1, "export ops supported");
7521a3c5
SF
190 sb->s_export_op = &cifs_export_ops;
191 }
192#endif /* EXPERIMENTAL */
1da177e4
LT
193
194 return 0;
195
196out_no_root:
b6b38f70 197 cERROR(1, "cifs_read_super: get root inode failed");
1da177e4
LT
198 if (inode)
199 iput(inode);
54b4602d 200
2c731afb 201 cifs_umount(sb, cifs_sb);
1da177e4
LT
202
203out_mount_failed:
4523cc30 204 if (cifs_sb) {
e6ab1582
IM
205#ifdef CONFIG_CIFS_DFS_UPCALL
206 if (cifs_sb->mountdata) {
207 kfree(cifs_sb->mountdata);
208 cifs_sb->mountdata = NULL;
209 }
210#endif
6d729e44 211 unload_nls(cifs_sb->local_nls);
8044f7f4 212 bdi_destroy(&cifs_sb->bdi);
1da177e4
LT
213 kfree(cifs_sb);
214 }
215 return rc;
216}
217
218static void
219cifs_put_super(struct super_block *sb)
220{
221 int rc = 0;
222 struct cifs_sb_info *cifs_sb;
223
b6b38f70 224 cFYI(1, "In cifs_put_super");
1da177e4 225 cifs_sb = CIFS_SB(sb);
4523cc30 226 if (cifs_sb == NULL) {
b6b38f70 227 cFYI(1, "Empty cifs superblock info passed to unmount");
1da177e4
LT
228 return;
229 }
6cfd0148 230
790fe579 231 rc = cifs_umount(sb, cifs_sb);
ad7a2926 232 if (rc)
b6b38f70 233 cERROR(1, "cifs_umount failed with return code %d", rc);
e6ab1582
IM
234#ifdef CONFIG_CIFS_DFS_UPCALL
235 if (cifs_sb->mountdata) {
236 kfree(cifs_sb->mountdata);
237 cifs_sb->mountdata = NULL;
238 }
239#endif
240
1da177e4 241 unload_nls(cifs_sb->local_nls);
8044f7f4 242 bdi_destroy(&cifs_sb->bdi);
1da177e4 243 kfree(cifs_sb);
1da177e4
LT
244}
245
246static int
726c3342 247cifs_statfs(struct dentry *dentry, struct kstatfs *buf)
1da177e4 248{
726c3342 249 struct super_block *sb = dentry->d_sb;
39da9847 250 struct cifs_sb_info *cifs_sb = CIFS_SB(sb);
0d424ad0 251 struct cifsTconInfo *tcon = cifs_sb_master_tcon(cifs_sb);
c81156dd 252 int rc = -EOPNOTSUPP;
39da9847 253 int xid;
1da177e4
LT
254
255 xid = GetXid();
256
1da177e4
LT
257 buf->f_type = CIFS_MAGIC_NUMBER;
258
39da9847
SF
259 /*
260 * PATH_MAX may be too long - it would presumably be total path,
261 * but note that some servers (includinng Samba 3) have a shorter
262 * maximum path.
263 *
264 * Instead could get the real value via SMB_QUERY_FS_ATTRIBUTE_INFO.
265 */
266 buf->f_namelen = PATH_MAX;
1da177e4
LT
267 buf->f_files = 0; /* undefined */
268 buf->f_ffree = 0; /* unlimited */
269
39da9847
SF
270 /*
271 * We could add a second check for a QFS Unix capability bit
272 */
273 if ((tcon->ses->capabilities & CAP_UNIX) &&
274 (CIFS_POSIX_EXTENSIONS & le64_to_cpu(tcon->fsUnixInfo.Capability)))
275 rc = CIFSSMBQFSPosixInfo(xid, tcon, buf);
276
277 /*
278 * Only need to call the old QFSInfo if failed on newer one,
279 * e.g. by OS/2.
280 **/
281 if (rc && (tcon->ses->capabilities & CAP_NT_SMBS))
282 rc = CIFSSMBQFSInfo(xid, tcon, buf);
283
284 /*
285 * Some old Windows servers also do not support level 103, retry with
286 * older level one if old server failed the previous call or we
287 * bypassed it because we detected that this was an older LANMAN sess
288 */
4523cc30 289 if (rc)
39da9847
SF
290 rc = SMBOldQFSInfo(xid, tcon, buf);
291
1da177e4 292 FreeXid(xid);
39da9847 293 return 0;
1da177e4
LT
294}
295
b74c79e9 296static int cifs_permission(struct inode *inode, int mask, unsigned int flags)
1da177e4
LT
297{
298 struct cifs_sb_info *cifs_sb;
299
b74c79e9
NP
300 if (flags & IPERM_FLAG_RCU)
301 return -ECHILD;
302
1da177e4
LT
303 cifs_sb = CIFS_SB(inode->i_sb);
304
f696a365
MS
305 if (cifs_sb->mnt_cifs_flags & CIFS_MOUNT_NO_PERM) {
306 if ((mask & MAY_EXEC) && !execute_ok(inode))
307 return -EACCES;
308 else
309 return 0;
310 } else /* file mode might have been restricted at mount time
50c2f753 311 on the client (above and beyond ACL on servers) for
1da177e4 312 servers which do not support setting and viewing mode bits,
50c2f753 313 so allowing client to check permissions is useful */
b74c79e9 314 return generic_permission(inode, mask, flags, NULL);
1da177e4
LT
315}
316
e18b890b
CL
317static struct kmem_cache *cifs_inode_cachep;
318static struct kmem_cache *cifs_req_cachep;
319static struct kmem_cache *cifs_mid_cachep;
e18b890b 320static struct kmem_cache *cifs_sm_req_cachep;
1da177e4
LT
321mempool_t *cifs_sm_req_poolp;
322mempool_t *cifs_req_poolp;
323mempool_t *cifs_mid_poolp;
324
325static struct inode *
326cifs_alloc_inode(struct super_block *sb)
327{
328 struct cifsInodeInfo *cifs_inode;
e94b1766 329 cifs_inode = kmem_cache_alloc(cifs_inode_cachep, GFP_KERNEL);
1da177e4
LT
330 if (!cifs_inode)
331 return NULL;
332 cifs_inode->cifsAttrs = 0x20; /* default */
1da177e4
LT
333 cifs_inode->time = 0;
334 /* Until the file is open and we have gotten oplock
335 info back from the server, can not assume caching of
336 file data or metadata */
c6723628 337 cifs_set_oplock_level(cifs_inode, 0);
9a8165fc 338 cifs_inode->delete_pending = false;
df2cf170 339 cifs_inode->invalid_mapping = false;
1da177e4 340 cifs_inode->vfs_inode.i_blkbits = 14; /* 2**14 = CIFS_MAX_MSGSIZE */
fbec9ab9 341 cifs_inode->server_eof = 0;
20054bd6
JL
342 cifs_inode->uniqueid = 0;
343 cifs_inode->createtime = 0;
50c2f753 344
1b2b2126
SF
345 /* Can not set i_flags here - they get immediately overwritten
346 to zero by the VFS */
347/* cifs_inode->vfs_inode.i_flags = S_NOATIME | S_NOCMTIME;*/
1da177e4
LT
348 INIT_LIST_HEAD(&cifs_inode->openFileList);
349 return &cifs_inode->vfs_inode;
350}
351
fa0d7e3d
NP
352static void cifs_i_callback(struct rcu_head *head)
353{
354 struct inode *inode = container_of(head, struct inode, i_rcu);
355 INIT_LIST_HEAD(&inode->i_dentry);
356 kmem_cache_free(cifs_inode_cachep, CIFS_I(inode));
357}
358
1da177e4
LT
359static void
360cifs_destroy_inode(struct inode *inode)
361{
fa0d7e3d 362 call_rcu(&inode->i_rcu, cifs_i_callback);
1da177e4
LT
363}
364
9451a9a5 365static void
b57922d9 366cifs_evict_inode(struct inode *inode)
9451a9a5 367{
b57922d9
AV
368 truncate_inode_pages(&inode->i_data, 0);
369 end_writeback(inode);
9451a9a5
SJ
370 cifs_fscache_release_inode_cookie(inode);
371}
372
61f98ffd
JL
373static void
374cifs_show_address(struct seq_file *s, struct TCP_Server_Info *server)
375{
a9f1b85e
PS
376 struct sockaddr_in *sa = (struct sockaddr_in *) &server->dstaddr;
377 struct sockaddr_in6 *sa6 = (struct sockaddr_in6 *) &server->dstaddr;
378
61f98ffd
JL
379 seq_printf(s, ",addr=");
380
a9f1b85e 381 switch (server->dstaddr.ss_family) {
61f98ffd 382 case AF_INET:
a9f1b85e 383 seq_printf(s, "%pI4", &sa->sin_addr.s_addr);
61f98ffd
JL
384 break;
385 case AF_INET6:
a9f1b85e
PS
386 seq_printf(s, "%pI6", &sa6->sin6_addr.s6_addr);
387 if (sa6->sin6_scope_id)
388 seq_printf(s, "%%%u", sa6->sin6_scope_id);
61f98ffd
JL
389 break;
390 default:
391 seq_printf(s, "(unknown)");
392 }
393}
394
1da177e4
LT
395/*
396 * cifs_show_options() is for displaying mount options in /proc/mounts.
397 * Not all settable options are displayed but most of the important
398 * ones are.
399 */
400static int
401cifs_show_options(struct seq_file *s, struct vfsmount *m)
402{
8e047d09 403 struct cifs_sb_info *cifs_sb = CIFS_SB(m->mnt_sb);
0d424ad0 404 struct cifsTconInfo *tcon = cifs_sb_master_tcon(cifs_sb);
3eb9a889
BG
405 struct sockaddr *srcaddr;
406 srcaddr = (struct sockaddr *)&tcon->ses->server->srcaddr;
8616e0fc 407
8e047d09 408 seq_printf(s, ",unc=%s", tcon->treeName);
29e07c82
JL
409
410 if (cifs_sb->mnt_cifs_flags & CIFS_MOUNT_MULTIUSER)
411 seq_printf(s, ",multiuser");
412 else if (tcon->ses->userName)
8616e0fc 413 seq_printf(s, ",username=%s", tcon->ses->userName);
29e07c82 414
8616e0fc
JL
415 if (tcon->ses->domainName)
416 seq_printf(s, ",domain=%s", tcon->ses->domainName);
417
3eb9a889
BG
418 if (srcaddr->sa_family != AF_UNSPEC) {
419 struct sockaddr_in *saddr4;
420 struct sockaddr_in6 *saddr6;
421 saddr4 = (struct sockaddr_in *)srcaddr;
422 saddr6 = (struct sockaddr_in6 *)srcaddr;
423 if (srcaddr->sa_family == AF_INET6)
424 seq_printf(s, ",srcaddr=%pI6c",
425 &saddr6->sin6_addr);
426 else if (srcaddr->sa_family == AF_INET)
427 seq_printf(s, ",srcaddr=%pI4",
428 &saddr4->sin_addr.s_addr);
429 else
430 seq_printf(s, ",srcaddr=BAD-AF:%i",
431 (int)(srcaddr->sa_family));
432 }
433
8616e0fc 434 seq_printf(s, ",uid=%d", cifs_sb->mnt_uid);
340481a3
JL
435 if (cifs_sb->mnt_cifs_flags & CIFS_MOUNT_OVERR_UID)
436 seq_printf(s, ",forceuid");
4486d6ed
JL
437 else
438 seq_printf(s, ",noforceuid");
340481a3 439
8616e0fc 440 seq_printf(s, ",gid=%d", cifs_sb->mnt_gid);
340481a3
JL
441 if (cifs_sb->mnt_cifs_flags & CIFS_MOUNT_OVERR_GID)
442 seq_printf(s, ",forcegid");
4486d6ed
JL
443 else
444 seq_printf(s, ",noforcegid");
8616e0fc 445
61f98ffd 446 cifs_show_address(s, tcon->ses->server);
1da177e4 447
8616e0fc
JL
448 if (!tcon->unix_ext)
449 seq_printf(s, ",file_mode=0%o,dir_mode=0%o",
2b280fab
SF
450 cifs_sb->mnt_file_mode,
451 cifs_sb->mnt_dir_mode);
8616e0fc
JL
452 if (tcon->seal)
453 seq_printf(s, ",seal");
454 if (tcon->nocase)
455 seq_printf(s, ",nocase");
456 if (tcon->retry)
457 seq_printf(s, ",hard");
458 if (cifs_sb->prepath)
459 seq_printf(s, ",prepath=%s", cifs_sb->prepath);
460 if (cifs_sb->mnt_cifs_flags & CIFS_MOUNT_POSIX_PATHS)
461 seq_printf(s, ",posixpaths");
462 if (cifs_sb->mnt_cifs_flags & CIFS_MOUNT_SET_UID)
463 seq_printf(s, ",setuids");
464 if (cifs_sb->mnt_cifs_flags & CIFS_MOUNT_SERVER_INUM)
465 seq_printf(s, ",serverino");
466 if (cifs_sb->mnt_cifs_flags & CIFS_MOUNT_DIRECT_IO)
467 seq_printf(s, ",directio");
468 if (cifs_sb->mnt_cifs_flags & CIFS_MOUNT_NO_XATTR)
469 seq_printf(s, ",nouser_xattr");
470 if (cifs_sb->mnt_cifs_flags & CIFS_MOUNT_MAP_SPECIAL_CHR)
471 seq_printf(s, ",mapchars");
472 if (cifs_sb->mnt_cifs_flags & CIFS_MOUNT_UNX_EMUL)
473 seq_printf(s, ",sfu");
474 if (cifs_sb->mnt_cifs_flags & CIFS_MOUNT_NO_BRL)
475 seq_printf(s, ",nobrl");
476 if (cifs_sb->mnt_cifs_flags & CIFS_MOUNT_CIFS_ACL)
477 seq_printf(s, ",cifsacl");
478 if (cifs_sb->mnt_cifs_flags & CIFS_MOUNT_DYNPERM)
479 seq_printf(s, ",dynperm");
480 if (m->mnt_sb->s_flags & MS_POSIXACL)
481 seq_printf(s, ",acl");
736a3320
SM
482 if (cifs_sb->mnt_cifs_flags & CIFS_MOUNT_MF_SYMLINKS)
483 seq_printf(s, ",mfsymlinks");
476428f8
SJ
484 if (cifs_sb->mnt_cifs_flags & CIFS_MOUNT_FSCACHE)
485 seq_printf(s, ",fsc");
8616e0fc
JL
486
487 seq_printf(s, ",rsize=%d", cifs_sb->rsize);
488 seq_printf(s, ",wsize=%d", cifs_sb->wsize);
6d20e840
SJ
489 /* convert actimeo and display it in seconds */
490 seq_printf(s, ",actimeo=%lu", cifs_sb->actimeo / HZ);
8616e0fc 491
1da177e4
LT
492 return 0;
493}
494
42faad99 495static void cifs_umount_begin(struct super_block *sb)
68058e75 496{
42faad99 497 struct cifs_sb_info *cifs_sb = CIFS_SB(sb);
50c2f753 498 struct cifsTconInfo *tcon;
68058e75 499
4523cc30 500 if (cifs_sb == NULL)
9e2e85f8
SF
501 return;
502
0d424ad0 503 tcon = cifs_sb_master_tcon(cifs_sb);
f1987b44 504
3f9bcca7 505 spin_lock(&cifs_tcp_ses_lock);
ad8034f1
SF
506 if ((tcon->tc_count > 1) || (tcon->tidStatus == CifsExiting)) {
507 /* we have other mounts to same share or we have
508 already tried to force umount this and woken up
509 all waiting network requests, nothing to do */
3f9bcca7 510 spin_unlock(&cifs_tcp_ses_lock);
ad8034f1
SF
511 return;
512 } else if (tcon->tc_count == 1)
5e1253b5 513 tcon->tidStatus = CifsExiting;
3f9bcca7 514 spin_unlock(&cifs_tcp_ses_lock);
5e1253b5 515
3a5ff61c 516 /* cancel_brl_requests(tcon); */ /* BB mark all brl mids as exiting */
7b7abfe3 517 /* cancel_notify_requests(tcon); */
50c2f753 518 if (tcon->ses && tcon->ses->server) {
b6b38f70 519 cFYI(1, "wake up tasks now - umount begin not complete");
9e2e85f8 520 wake_up_all(&tcon->ses->server->request_q);
6ab16d24
SF
521 wake_up_all(&tcon->ses->server->response_q);
522 msleep(1); /* yield */
523 /* we have to kick the requests once more */
524 wake_up_all(&tcon->ses->server->response_q);
525 msleep(1);
5e1253b5 526 }
68058e75
SF
527
528 return;
529}
68058e75 530
bf97d287
SF
531#ifdef CONFIG_CIFS_STATS2
532static int cifs_show_stats(struct seq_file *s, struct vfsmount *mnt)
533{
534 /* BB FIXME */
535 return 0;
536}
537#endif
538
1da177e4
LT
539static int cifs_remount(struct super_block *sb, int *flags, char *data)
540{
541 *flags |= MS_NODIRATIME;
542 return 0;
543}
544
45321ac5 545static int cifs_drop_inode(struct inode *inode)
12420ac3
JL
546{
547 struct cifs_sb_info *cifs_sb = CIFS_SB(inode->i_sb);
548
45321ac5
AV
549 /* no serverino => unconditional eviction */
550 return !(cifs_sb->mnt_cifs_flags & CIFS_MOUNT_SERVER_INUM) ||
551 generic_drop_inode(inode);
12420ac3
JL
552}
553
ee9b6d61 554static const struct super_operations cifs_super_ops = {
1da177e4
LT
555 .put_super = cifs_put_super,
556 .statfs = cifs_statfs,
557 .alloc_inode = cifs_alloc_inode,
558 .destroy_inode = cifs_destroy_inode,
12420ac3 559 .drop_inode = cifs_drop_inode,
b57922d9 560 .evict_inode = cifs_evict_inode,
12420ac3
JL
561/* .delete_inode = cifs_delete_inode, */ /* Do not need above
562 function unless later we add lazy close of inodes or unless the
50c2f753
SF
563 kernel forgets to call us with the same number of releases (closes)
564 as opens */
1da177e4 565 .show_options = cifs_show_options,
7b7abfe3 566 .umount_begin = cifs_umount_begin,
1da177e4 567 .remount_fs = cifs_remount,
bf97d287 568#ifdef CONFIG_CIFS_STATS2
f46d3e11 569 .show_stats = cifs_show_stats,
bf97d287 570#endif
1da177e4
LT
571};
572
d753ed97
AV
573static struct dentry *
574cifs_do_mount(struct file_system_type *fs_type,
575 int flags, const char *dev_name, void *data)
1da177e4
LT
576{
577 int rc;
db719222
JB
578 struct super_block *sb;
579
db719222 580 sb = sget(fs_type, NULL, set_anon_super, NULL);
1da177e4 581
b6b38f70 582 cFYI(1, "Devname: %s flags: %d ", dev_name, flags);
1da177e4 583
b0991aa3 584 if (IS_ERR(sb))
d753ed97 585 return ERR_CAST(sb);
1da177e4
LT
586
587 sb->s_flags = flags;
588
9b04c997 589 rc = cifs_read_super(sb, data, dev_name, flags & MS_SILENT ? 1 : 0);
1da177e4 590 if (rc) {
6f5bbff9 591 deactivate_locked_super(sb);
d753ed97 592 return ERR_PTR(rc);
1da177e4
LT
593 }
594 sb->s_flags |= MS_ACTIVE;
d753ed97 595 return dget(sb->s_root);
1da177e4
LT
596}
597
027445c3
BP
598static ssize_t cifs_file_aio_write(struct kiocb *iocb, const struct iovec *iov,
599 unsigned long nr_segs, loff_t pos)
1da177e4 600{
e6a00296 601 struct inode *inode = iocb->ki_filp->f_path.dentry->d_inode;
1da177e4
LT
602 ssize_t written;
603
027445c3 604 written = generic_file_aio_write(iocb, iov, nr_segs, pos);
87c89dd7
SF
605 if (!CIFS_I(inode)->clientCanCacheAll)
606 filemap_fdatawrite(inode->i_mapping);
1da177e4
LT
607 return written;
608}
609
c32a0b68
SF
610static loff_t cifs_llseek(struct file *file, loff_t offset, int origin)
611{
612 /* origin == SEEK_END => we must revalidate the cached file length */
0889a944 613 if (origin == SEEK_END) {
030e9d81
SF
614 int retval;
615
616 /* some applications poll for the file length in this strange
617 way so we must seek to end on non-oplocked files by
618 setting the revalidate time to zero */
c33f8d32 619 CIFS_I(file->f_path.dentry->d_inode)->time = 0;
030e9d81 620
abab095d 621 retval = cifs_revalidate_file(file);
c32a0b68
SF
622 if (retval < 0)
623 return (loff_t)retval;
624 }
9465efc9 625 return generic_file_llseek_unlocked(file, offset, origin);
c32a0b68
SF
626}
627
84210e91
SF
628static int cifs_setlease(struct file *file, long arg, struct file_lock **lease)
629{
b89f4321
AB
630 /* note that this is called by vfs setlease with lock_flocks held
631 to protect *lease from going away */
84210e91 632 struct inode *inode = file->f_path.dentry->d_inode;
ba00ba64 633 struct cifsFileInfo *cfile = file->private_data;
84210e91
SF
634
635 if (!(S_ISREG(inode->i_mode)))
636 return -EINVAL;
637
638 /* check if file is oplocked */
639 if (((arg == F_RDLCK) &&
640 (CIFS_I(inode)->clientCanCacheRead)) ||
641 ((arg == F_WRLCK) &&
642 (CIFS_I(inode)->clientCanCacheAll)))
643 return generic_setlease(file, arg, lease);
13cfb733
JL
644 else if (tlink_tcon(cfile->tlink)->local_lease &&
645 !CIFS_I(inode)->clientCanCacheRead)
84210e91
SF
646 /* If the server claims to support oplock on this
647 file, then we still need to check oplock even
648 if the local_lease mount option is set, but there
649 are servers which do not support oplock for which
650 this mount option may be useful if the user
651 knows that the file won't be changed on the server
652 by anyone else */
653 return generic_setlease(file, arg, lease);
51ee4b84 654 else
84210e91
SF
655 return -EAGAIN;
656}
84210e91 657
e6ab1582 658struct file_system_type cifs_fs_type = {
1da177e4
LT
659 .owner = THIS_MODULE,
660 .name = "cifs",
d753ed97 661 .mount = cifs_do_mount,
1da177e4
LT
662 .kill_sb = kill_anon_super,
663 /* .fs_flags */
664};
754661f1 665const struct inode_operations cifs_dir_inode_ops = {
1da177e4
LT
666 .create = cifs_create,
667 .lookup = cifs_lookup,
668 .getattr = cifs_getattr,
669 .unlink = cifs_unlink,
670 .link = cifs_hardlink,
671 .mkdir = cifs_mkdir,
672 .rmdir = cifs_rmdir,
673 .rename = cifs_rename,
674 .permission = cifs_permission,
675/* revalidate:cifs_revalidate, */
676 .setattr = cifs_setattr,
677 .symlink = cifs_symlink,
678 .mknod = cifs_mknod,
679#ifdef CONFIG_CIFS_XATTR
680 .setxattr = cifs_setxattr,
681 .getxattr = cifs_getxattr,
682 .listxattr = cifs_listxattr,
683 .removexattr = cifs_removexattr,
684#endif
685};
686
754661f1 687const struct inode_operations cifs_file_inode_ops = {
1da177e4
LT
688/* revalidate:cifs_revalidate, */
689 .setattr = cifs_setattr,
690 .getattr = cifs_getattr, /* do we need this anymore? */
691 .rename = cifs_rename,
692 .permission = cifs_permission,
693#ifdef CONFIG_CIFS_XATTR
694 .setxattr = cifs_setxattr,
695 .getxattr = cifs_getxattr,
696 .listxattr = cifs_listxattr,
697 .removexattr = cifs_removexattr,
50c2f753 698#endif
1da177e4
LT
699};
700
754661f1 701const struct inode_operations cifs_symlink_inode_ops = {
50c2f753 702 .readlink = generic_readlink,
1da177e4
LT
703 .follow_link = cifs_follow_link,
704 .put_link = cifs_put_link,
705 .permission = cifs_permission,
706 /* BB add the following two eventually */
707 /* revalidate: cifs_revalidate,
708 setattr: cifs_notify_change, *//* BB do we need notify change */
709#ifdef CONFIG_CIFS_XATTR
710 .setxattr = cifs_setxattr,
711 .getxattr = cifs_getxattr,
712 .listxattr = cifs_listxattr,
713 .removexattr = cifs_removexattr,
50c2f753 714#endif
1da177e4
LT
715};
716
4b6f5d20 717const struct file_operations cifs_file_ops = {
87c89dd7
SF
718 .read = do_sync_read,
719 .write = do_sync_write,
87c89dd7
SF
720 .aio_read = generic_file_aio_read,
721 .aio_write = cifs_file_aio_write,
1da177e4
LT
722 .open = cifs_open,
723 .release = cifs_close,
724 .lock = cifs_lock,
725 .fsync = cifs_fsync,
726 .flush = cifs_flush,
727 .mmap = cifs_file_mmap,
5ffc4ef4 728 .splice_read = generic_file_splice_read,
c32a0b68 729 .llseek = cifs_llseek,
c67593a0 730#ifdef CONFIG_CIFS_POSIX
f9ddcca4 731 .unlocked_ioctl = cifs_ioctl,
c67593a0 732#endif /* CONFIG_CIFS_POSIX */
84210e91 733 .setlease = cifs_setlease,
1da177e4
LT
734};
735
4b6f5d20 736const struct file_operations cifs_file_direct_ops = {
a994b8fa 737 /* no aio, no readv -
1da177e4
LT
738 BB reevaluate whether they can be done with directio, no cache */
739 .read = cifs_user_read,
740 .write = cifs_user_write,
741 .open = cifs_open,
742 .release = cifs_close,
743 .lock = cifs_lock,
744 .fsync = cifs_fsync,
745 .flush = cifs_flush,
a994b8fa 746 .mmap = cifs_file_mmap,
5ffc4ef4 747 .splice_read = generic_file_splice_read,
c67593a0 748#ifdef CONFIG_CIFS_POSIX
f9ddcca4 749 .unlocked_ioctl = cifs_ioctl,
c67593a0 750#endif /* CONFIG_CIFS_POSIX */
c32a0b68 751 .llseek = cifs_llseek,
84210e91 752 .setlease = cifs_setlease,
1da177e4 753};
4b6f5d20 754const struct file_operations cifs_file_nobrl_ops = {
87c89dd7
SF
755 .read = do_sync_read,
756 .write = do_sync_write,
87c89dd7
SF
757 .aio_read = generic_file_aio_read,
758 .aio_write = cifs_file_aio_write,
759 .open = cifs_open,
760 .release = cifs_close,
761 .fsync = cifs_fsync,
762 .flush = cifs_flush,
763 .mmap = cifs_file_mmap,
5ffc4ef4 764 .splice_read = generic_file_splice_read,
c32a0b68 765 .llseek = cifs_llseek,
8b94bcb9 766#ifdef CONFIG_CIFS_POSIX
f9ddcca4 767 .unlocked_ioctl = cifs_ioctl,
8b94bcb9 768#endif /* CONFIG_CIFS_POSIX */
84210e91 769 .setlease = cifs_setlease,
8b94bcb9
SF
770};
771
4b6f5d20 772const struct file_operations cifs_file_direct_nobrl_ops = {
50c2f753 773 /* no mmap, no aio, no readv -
87c89dd7
SF
774 BB reevaluate whether they can be done with directio, no cache */
775 .read = cifs_user_read,
776 .write = cifs_user_write,
777 .open = cifs_open,
778 .release = cifs_close,
779 .fsync = cifs_fsync,
780 .flush = cifs_flush,
810627a0 781 .mmap = cifs_file_mmap,
5ffc4ef4 782 .splice_read = generic_file_splice_read,
8b94bcb9 783#ifdef CONFIG_CIFS_POSIX
f9ddcca4 784 .unlocked_ioctl = cifs_ioctl,
8b94bcb9 785#endif /* CONFIG_CIFS_POSIX */
c32a0b68 786 .llseek = cifs_llseek,
84210e91 787 .setlease = cifs_setlease,
8b94bcb9 788};
1da177e4 789
4b6f5d20 790const struct file_operations cifs_dir_ops = {
1da177e4
LT
791 .readdir = cifs_readdir,
792 .release = cifs_closedir,
793 .read = generic_read_dir,
f9ddcca4 794 .unlocked_ioctl = cifs_ioctl,
3222a3e5 795 .llseek = generic_file_llseek,
1da177e4
LT
796};
797
798static void
51cc5068 799cifs_init_once(void *inode)
1da177e4
LT
800{
801 struct cifsInodeInfo *cifsi = inode;
802
a35afb83
CL
803 inode_init_once(&cifsi->vfs_inode);
804 INIT_LIST_HEAD(&cifsi->lockList);
1da177e4
LT
805}
806
807static int
808cifs_init_inodecache(void)
809{
810 cifs_inode_cachep = kmem_cache_create("cifs_inode_cache",
26f57364 811 sizeof(struct cifsInodeInfo),
fffb60f9
PJ
812 0, (SLAB_RECLAIM_ACCOUNT|
813 SLAB_MEM_SPREAD),
20c2df83 814 cifs_init_once);
1da177e4
LT
815 if (cifs_inode_cachep == NULL)
816 return -ENOMEM;
817
818 return 0;
819}
820
821static void
822cifs_destroy_inodecache(void)
823{
1a1d92c1 824 kmem_cache_destroy(cifs_inode_cachep);
1da177e4
LT
825}
826
827static int
828cifs_init_request_bufs(void)
829{
4523cc30 830 if (CIFSMaxBufSize < 8192) {
1da177e4
LT
831 /* Buffer size can not be smaller than 2 * PATH_MAX since maximum
832 Unicode path name has to fit in any SMB/CIFS path based frames */
833 CIFSMaxBufSize = 8192;
834 } else if (CIFSMaxBufSize > 1024*127) {
835 CIFSMaxBufSize = 1024 * 127;
836 } else {
837 CIFSMaxBufSize &= 0x1FE00; /* Round size to even 512 byte mult*/
838 }
b6b38f70 839/* cERROR(1, "CIFSMaxBufSize %d 0x%x",CIFSMaxBufSize,CIFSMaxBufSize); */
1da177e4
LT
840 cifs_req_cachep = kmem_cache_create("cifs_request",
841 CIFSMaxBufSize +
842 MAX_CIFS_HDR_SIZE, 0,
20c2df83 843 SLAB_HWCACHE_ALIGN, NULL);
1da177e4
LT
844 if (cifs_req_cachep == NULL)
845 return -ENOMEM;
846
4523cc30 847 if (cifs_min_rcv < 1)
1da177e4
LT
848 cifs_min_rcv = 1;
849 else if (cifs_min_rcv > 64) {
850 cifs_min_rcv = 64;
b6b38f70 851 cERROR(1, "cifs_min_rcv set to maximum (64)");
1da177e4
LT
852 }
853
93d2341c
MD
854 cifs_req_poolp = mempool_create_slab_pool(cifs_min_rcv,
855 cifs_req_cachep);
1da177e4 856
4523cc30 857 if (cifs_req_poolp == NULL) {
1da177e4
LT
858 kmem_cache_destroy(cifs_req_cachep);
859 return -ENOMEM;
860 }
ec637e3f 861 /* MAX_CIFS_SMALL_BUFFER_SIZE bytes is enough for most SMB responses and
1da177e4
LT
862 almost all handle based requests (but not write response, nor is it
863 sufficient for path based requests). A smaller size would have
50c2f753 864 been more efficient (compacting multiple slab items on one 4k page)
1da177e4
LT
865 for the case in which debug was on, but this larger size allows
866 more SMBs to use small buffer alloc and is still much more
6dc0f87e 867 efficient to alloc 1 per page off the slab compared to 17K (5page)
1da177e4
LT
868 alloc of large cifs buffers even when page debugging is on */
869 cifs_sm_req_cachep = kmem_cache_create("cifs_small_rq",
6dc0f87e 870 MAX_CIFS_SMALL_BUFFER_SIZE, 0, SLAB_HWCACHE_ALIGN,
20c2df83 871 NULL);
1da177e4
LT
872 if (cifs_sm_req_cachep == NULL) {
873 mempool_destroy(cifs_req_poolp);
874 kmem_cache_destroy(cifs_req_cachep);
6dc0f87e 875 return -ENOMEM;
1da177e4
LT
876 }
877
4523cc30 878 if (cifs_min_small < 2)
1da177e4
LT
879 cifs_min_small = 2;
880 else if (cifs_min_small > 256) {
881 cifs_min_small = 256;
b6b38f70 882 cFYI(1, "cifs_min_small set to maximum (256)");
1da177e4
LT
883 }
884
93d2341c
MD
885 cifs_sm_req_poolp = mempool_create_slab_pool(cifs_min_small,
886 cifs_sm_req_cachep);
1da177e4 887
4523cc30 888 if (cifs_sm_req_poolp == NULL) {
1da177e4
LT
889 mempool_destroy(cifs_req_poolp);
890 kmem_cache_destroy(cifs_req_cachep);
891 kmem_cache_destroy(cifs_sm_req_cachep);
892 return -ENOMEM;
893 }
894
895 return 0;
896}
897
898static void
899cifs_destroy_request_bufs(void)
900{
901 mempool_destroy(cifs_req_poolp);
1a1d92c1 902 kmem_cache_destroy(cifs_req_cachep);
1da177e4 903 mempool_destroy(cifs_sm_req_poolp);
1a1d92c1 904 kmem_cache_destroy(cifs_sm_req_cachep);
1da177e4
LT
905}
906
907static int
908cifs_init_mids(void)
909{
910 cifs_mid_cachep = kmem_cache_create("cifs_mpx_ids",
26f57364
SF
911 sizeof(struct mid_q_entry), 0,
912 SLAB_HWCACHE_ALIGN, NULL);
1da177e4
LT
913 if (cifs_mid_cachep == NULL)
914 return -ENOMEM;
915
93d2341c
MD
916 /* 3 is a reasonable minimum number of simultaneous operations */
917 cifs_mid_poolp = mempool_create_slab_pool(3, cifs_mid_cachep);
4523cc30 918 if (cifs_mid_poolp == NULL) {
1da177e4
LT
919 kmem_cache_destroy(cifs_mid_cachep);
920 return -ENOMEM;
921 }
922
1da177e4
LT
923 return 0;
924}
925
926static void
927cifs_destroy_mids(void)
928{
929 mempool_destroy(cifs_mid_poolp);
1a1d92c1 930 kmem_cache_destroy(cifs_mid_cachep);
1da177e4
LT
931}
932
1da177e4
LT
933static int __init
934init_cifs(void)
935{
936 int rc = 0;
1da177e4 937 cifs_proc_init();
e7ddee90 938 INIT_LIST_HEAD(&cifs_tcp_ses_list);
4ca9c190
SF
939#ifdef CONFIG_CIFS_EXPERIMENTAL
940 INIT_LIST_HEAD(&GlobalDnotifyReqList);
941 INIT_LIST_HEAD(&GlobalDnotifyRsp_Q);
6dc0f87e 942#endif
1da177e4
LT
943/*
944 * Initialize Global counters
945 */
946 atomic_set(&sesInfoAllocCount, 0);
947 atomic_set(&tconInfoAllocCount, 0);
6dc0f87e 948 atomic_set(&tcpSesAllocCount, 0);
1da177e4
LT
949 atomic_set(&tcpSesReconnectCount, 0);
950 atomic_set(&tconInfoReconnectCount, 0);
951
952 atomic_set(&bufAllocCount, 0);
4498eed5
SF
953 atomic_set(&smBufAllocCount, 0);
954#ifdef CONFIG_CIFS_STATS2
955 atomic_set(&totBufAllocCount, 0);
956 atomic_set(&totSmBufAllocCount, 0);
957#endif /* CONFIG_CIFS_STATS2 */
958
1da177e4
LT
959 atomic_set(&midCount, 0);
960 GlobalCurrentXid = 0;
961 GlobalTotalActiveXid = 0;
962 GlobalMaxActiveXid = 0;
3f9bcca7 963 spin_lock_init(&cifs_tcp_ses_lock);
4477288a 964 spin_lock_init(&cifs_file_list_lock);
1da177e4
LT
965 spin_lock_init(&GlobalMid_Lock);
966
4523cc30 967 if (cifs_max_pending < 2) {
1da177e4 968 cifs_max_pending = 2;
b6b38f70 969 cFYI(1, "cifs_max_pending set to min of 2");
4523cc30 970 } else if (cifs_max_pending > 256) {
1da177e4 971 cifs_max_pending = 256;
b6b38f70 972 cFYI(1, "cifs_max_pending set to max of 256");
1da177e4
LT
973 }
974
f579cf3c
SJ
975 rc = cifs_fscache_register();
976 if (rc)
d3bf5221 977 goto out_clean_proc;
f579cf3c 978
1da177e4 979 rc = cifs_init_inodecache();
45af7a0f 980 if (rc)
d3bf5221 981 goto out_unreg_fscache;
45af7a0f
SF
982
983 rc = cifs_init_mids();
984 if (rc)
985 goto out_destroy_inodecache;
986
987 rc = cifs_init_request_bufs();
988 if (rc)
989 goto out_destroy_mids;
990
991 rc = register_filesystem(&cifs_fs_type);
992 if (rc)
993 goto out_destroy_request_bufs;
84a15b93
JL
994#ifdef CONFIG_CIFS_UPCALL
995 rc = register_key_type(&cifs_spnego_key_type);
996 if (rc)
997 goto out_unregister_filesystem;
6103335d 998#endif
45af7a0f 999
45af7a0f
SF
1000 return 0;
1001
84a15b93 1002#ifdef CONFIG_CIFS_UPCALL
d3bf5221 1003out_unregister_filesystem:
45af7a0f 1004 unregister_filesystem(&cifs_fs_type);
1fc7995d 1005#endif
d3bf5221 1006out_destroy_request_bufs:
45af7a0f 1007 cifs_destroy_request_bufs();
d3bf5221 1008out_destroy_mids:
45af7a0f 1009 cifs_destroy_mids();
d3bf5221 1010out_destroy_inodecache:
45af7a0f 1011 cifs_destroy_inodecache();
d3bf5221 1012out_unreg_fscache:
f579cf3c 1013 cifs_fscache_unregister();
d3bf5221
SF
1014out_clean_proc:
1015 cifs_proc_clean();
1da177e4
LT
1016 return rc;
1017}
1018
1019static void __exit
1020exit_cifs(void)
1021{
b6b38f70 1022 cFYI(DBG2, "exit_cifs");
1da177e4 1023 cifs_proc_clean();
f579cf3c 1024 cifs_fscache_unregister();
6103335d 1025#ifdef CONFIG_CIFS_DFS_UPCALL
78d31a3a 1026 cifs_dfs_release_automount_timer();
6103335d 1027#endif
84a15b93
JL
1028#ifdef CONFIG_CIFS_UPCALL
1029 unregister_key_type(&cifs_spnego_key_type);
1da177e4
LT
1030#endif
1031 unregister_filesystem(&cifs_fs_type);
1032 cifs_destroy_inodecache();
1033 cifs_destroy_mids();
1034 cifs_destroy_request_bufs();
1da177e4
LT
1035}
1036
1037MODULE_AUTHOR("Steve French <sfrench@us.ibm.com>");
6dc0f87e 1038MODULE_LICENSE("GPL"); /* combination of LGPL + GPL source behaves as GPL */
1da177e4 1039MODULE_DESCRIPTION
63135e08
SF
1040 ("VFS to access servers complying with the SNIA CIFS Specification "
1041 "e.g. Samba and Windows");
1da177e4
LT
1042MODULE_VERSION(CIFS_VERSION);
1043module_init(init_cifs)
1044module_exit(exit_cifs)