[CIFS] Replace cifs md5 hashing functions with kernel crypto APIs
[GitHub/mt8127/android_kernel_alcatel_ttab.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
8be7e6ba
PS
736const struct file_operations cifs_file_strict_ops = {
737 .read = do_sync_read,
738 .write = do_sync_write,
a70307ee 739 .aio_read = cifs_strict_readv,
8be7e6ba
PS
740 .aio_write = cifs_file_aio_write,
741 .open = cifs_open,
742 .release = cifs_close,
743 .lock = cifs_lock,
744 .fsync = cifs_strict_fsync,
745 .flush = cifs_flush,
7a6a19b1 746 .mmap = cifs_file_strict_mmap,
8be7e6ba
PS
747 .splice_read = generic_file_splice_read,
748 .llseek = cifs_llseek,
749#ifdef CONFIG_CIFS_POSIX
750 .unlocked_ioctl = cifs_ioctl,
751#endif /* CONFIG_CIFS_POSIX */
752 .setlease = cifs_setlease,
753};
754
4b6f5d20 755const struct file_operations cifs_file_direct_ops = {
a994b8fa 756 /* no aio, no readv -
1da177e4
LT
757 BB reevaluate whether they can be done with directio, no cache */
758 .read = cifs_user_read,
759 .write = cifs_user_write,
760 .open = cifs_open,
761 .release = cifs_close,
762 .lock = cifs_lock,
763 .fsync = cifs_fsync,
764 .flush = cifs_flush,
a994b8fa 765 .mmap = cifs_file_mmap,
5ffc4ef4 766 .splice_read = generic_file_splice_read,
c67593a0 767#ifdef CONFIG_CIFS_POSIX
f9ddcca4 768 .unlocked_ioctl = cifs_ioctl,
c67593a0 769#endif /* CONFIG_CIFS_POSIX */
c32a0b68 770 .llseek = cifs_llseek,
84210e91 771 .setlease = cifs_setlease,
1da177e4 772};
8be7e6ba 773
4b6f5d20 774const struct file_operations cifs_file_nobrl_ops = {
87c89dd7
SF
775 .read = do_sync_read,
776 .write = do_sync_write,
87c89dd7
SF
777 .aio_read = generic_file_aio_read,
778 .aio_write = cifs_file_aio_write,
779 .open = cifs_open,
780 .release = cifs_close,
781 .fsync = cifs_fsync,
782 .flush = cifs_flush,
783 .mmap = cifs_file_mmap,
5ffc4ef4 784 .splice_read = generic_file_splice_read,
c32a0b68 785 .llseek = cifs_llseek,
8b94bcb9 786#ifdef CONFIG_CIFS_POSIX
f9ddcca4 787 .unlocked_ioctl = cifs_ioctl,
8b94bcb9 788#endif /* CONFIG_CIFS_POSIX */
84210e91 789 .setlease = cifs_setlease,
8b94bcb9
SF
790};
791
8be7e6ba
PS
792const struct file_operations cifs_file_strict_nobrl_ops = {
793 .read = do_sync_read,
794 .write = do_sync_write,
a70307ee 795 .aio_read = cifs_strict_readv,
8be7e6ba
PS
796 .aio_write = cifs_file_aio_write,
797 .open = cifs_open,
798 .release = cifs_close,
799 .fsync = cifs_strict_fsync,
800 .flush = cifs_flush,
7a6a19b1 801 .mmap = cifs_file_strict_mmap,
8be7e6ba
PS
802 .splice_read = generic_file_splice_read,
803 .llseek = cifs_llseek,
804#ifdef CONFIG_CIFS_POSIX
805 .unlocked_ioctl = cifs_ioctl,
806#endif /* CONFIG_CIFS_POSIX */
807 .setlease = cifs_setlease,
808};
809
4b6f5d20 810const struct file_operations cifs_file_direct_nobrl_ops = {
50c2f753 811 /* no mmap, no aio, no readv -
87c89dd7
SF
812 BB reevaluate whether they can be done with directio, no cache */
813 .read = cifs_user_read,
814 .write = cifs_user_write,
815 .open = cifs_open,
816 .release = cifs_close,
817 .fsync = cifs_fsync,
818 .flush = cifs_flush,
810627a0 819 .mmap = cifs_file_mmap,
5ffc4ef4 820 .splice_read = generic_file_splice_read,
8b94bcb9 821#ifdef CONFIG_CIFS_POSIX
f9ddcca4 822 .unlocked_ioctl = cifs_ioctl,
8b94bcb9 823#endif /* CONFIG_CIFS_POSIX */
c32a0b68 824 .llseek = cifs_llseek,
84210e91 825 .setlease = cifs_setlease,
8b94bcb9 826};
1da177e4 827
4b6f5d20 828const struct file_operations cifs_dir_ops = {
1da177e4
LT
829 .readdir = cifs_readdir,
830 .release = cifs_closedir,
831 .read = generic_read_dir,
f9ddcca4 832 .unlocked_ioctl = cifs_ioctl,
3222a3e5 833 .llseek = generic_file_llseek,
1da177e4
LT
834};
835
836static void
51cc5068 837cifs_init_once(void *inode)
1da177e4
LT
838{
839 struct cifsInodeInfo *cifsi = inode;
840
a35afb83
CL
841 inode_init_once(&cifsi->vfs_inode);
842 INIT_LIST_HEAD(&cifsi->lockList);
1da177e4
LT
843}
844
845static int
846cifs_init_inodecache(void)
847{
848 cifs_inode_cachep = kmem_cache_create("cifs_inode_cache",
26f57364 849 sizeof(struct cifsInodeInfo),
fffb60f9
PJ
850 0, (SLAB_RECLAIM_ACCOUNT|
851 SLAB_MEM_SPREAD),
20c2df83 852 cifs_init_once);
1da177e4
LT
853 if (cifs_inode_cachep == NULL)
854 return -ENOMEM;
855
856 return 0;
857}
858
859static void
860cifs_destroy_inodecache(void)
861{
1a1d92c1 862 kmem_cache_destroy(cifs_inode_cachep);
1da177e4
LT
863}
864
865static int
866cifs_init_request_bufs(void)
867{
4523cc30 868 if (CIFSMaxBufSize < 8192) {
1da177e4
LT
869 /* Buffer size can not be smaller than 2 * PATH_MAX since maximum
870 Unicode path name has to fit in any SMB/CIFS path based frames */
871 CIFSMaxBufSize = 8192;
872 } else if (CIFSMaxBufSize > 1024*127) {
873 CIFSMaxBufSize = 1024 * 127;
874 } else {
875 CIFSMaxBufSize &= 0x1FE00; /* Round size to even 512 byte mult*/
876 }
b6b38f70 877/* cERROR(1, "CIFSMaxBufSize %d 0x%x",CIFSMaxBufSize,CIFSMaxBufSize); */
1da177e4
LT
878 cifs_req_cachep = kmem_cache_create("cifs_request",
879 CIFSMaxBufSize +
880 MAX_CIFS_HDR_SIZE, 0,
20c2df83 881 SLAB_HWCACHE_ALIGN, NULL);
1da177e4
LT
882 if (cifs_req_cachep == NULL)
883 return -ENOMEM;
884
4523cc30 885 if (cifs_min_rcv < 1)
1da177e4
LT
886 cifs_min_rcv = 1;
887 else if (cifs_min_rcv > 64) {
888 cifs_min_rcv = 64;
b6b38f70 889 cERROR(1, "cifs_min_rcv set to maximum (64)");
1da177e4
LT
890 }
891
93d2341c
MD
892 cifs_req_poolp = mempool_create_slab_pool(cifs_min_rcv,
893 cifs_req_cachep);
1da177e4 894
4523cc30 895 if (cifs_req_poolp == NULL) {
1da177e4
LT
896 kmem_cache_destroy(cifs_req_cachep);
897 return -ENOMEM;
898 }
ec637e3f 899 /* MAX_CIFS_SMALL_BUFFER_SIZE bytes is enough for most SMB responses and
1da177e4
LT
900 almost all handle based requests (but not write response, nor is it
901 sufficient for path based requests). A smaller size would have
50c2f753 902 been more efficient (compacting multiple slab items on one 4k page)
1da177e4
LT
903 for the case in which debug was on, but this larger size allows
904 more SMBs to use small buffer alloc and is still much more
6dc0f87e 905 efficient to alloc 1 per page off the slab compared to 17K (5page)
1da177e4
LT
906 alloc of large cifs buffers even when page debugging is on */
907 cifs_sm_req_cachep = kmem_cache_create("cifs_small_rq",
6dc0f87e 908 MAX_CIFS_SMALL_BUFFER_SIZE, 0, SLAB_HWCACHE_ALIGN,
20c2df83 909 NULL);
1da177e4
LT
910 if (cifs_sm_req_cachep == NULL) {
911 mempool_destroy(cifs_req_poolp);
912 kmem_cache_destroy(cifs_req_cachep);
6dc0f87e 913 return -ENOMEM;
1da177e4
LT
914 }
915
4523cc30 916 if (cifs_min_small < 2)
1da177e4
LT
917 cifs_min_small = 2;
918 else if (cifs_min_small > 256) {
919 cifs_min_small = 256;
b6b38f70 920 cFYI(1, "cifs_min_small set to maximum (256)");
1da177e4
LT
921 }
922
93d2341c
MD
923 cifs_sm_req_poolp = mempool_create_slab_pool(cifs_min_small,
924 cifs_sm_req_cachep);
1da177e4 925
4523cc30 926 if (cifs_sm_req_poolp == NULL) {
1da177e4
LT
927 mempool_destroy(cifs_req_poolp);
928 kmem_cache_destroy(cifs_req_cachep);
929 kmem_cache_destroy(cifs_sm_req_cachep);
930 return -ENOMEM;
931 }
932
933 return 0;
934}
935
936static void
937cifs_destroy_request_bufs(void)
938{
939 mempool_destroy(cifs_req_poolp);
1a1d92c1 940 kmem_cache_destroy(cifs_req_cachep);
1da177e4 941 mempool_destroy(cifs_sm_req_poolp);
1a1d92c1 942 kmem_cache_destroy(cifs_sm_req_cachep);
1da177e4
LT
943}
944
945static int
946cifs_init_mids(void)
947{
948 cifs_mid_cachep = kmem_cache_create("cifs_mpx_ids",
26f57364
SF
949 sizeof(struct mid_q_entry), 0,
950 SLAB_HWCACHE_ALIGN, NULL);
1da177e4
LT
951 if (cifs_mid_cachep == NULL)
952 return -ENOMEM;
953
93d2341c
MD
954 /* 3 is a reasonable minimum number of simultaneous operations */
955 cifs_mid_poolp = mempool_create_slab_pool(3, cifs_mid_cachep);
4523cc30 956 if (cifs_mid_poolp == NULL) {
1da177e4
LT
957 kmem_cache_destroy(cifs_mid_cachep);
958 return -ENOMEM;
959 }
960
1da177e4
LT
961 return 0;
962}
963
964static void
965cifs_destroy_mids(void)
966{
967 mempool_destroy(cifs_mid_poolp);
1a1d92c1 968 kmem_cache_destroy(cifs_mid_cachep);
1da177e4
LT
969}
970
1da177e4
LT
971static int __init
972init_cifs(void)
973{
974 int rc = 0;
1da177e4 975 cifs_proc_init();
e7ddee90 976 INIT_LIST_HEAD(&cifs_tcp_ses_list);
4ca9c190
SF
977#ifdef CONFIG_CIFS_EXPERIMENTAL
978 INIT_LIST_HEAD(&GlobalDnotifyReqList);
979 INIT_LIST_HEAD(&GlobalDnotifyRsp_Q);
6dc0f87e 980#endif
1da177e4
LT
981/*
982 * Initialize Global counters
983 */
984 atomic_set(&sesInfoAllocCount, 0);
985 atomic_set(&tconInfoAllocCount, 0);
6dc0f87e 986 atomic_set(&tcpSesAllocCount, 0);
1da177e4
LT
987 atomic_set(&tcpSesReconnectCount, 0);
988 atomic_set(&tconInfoReconnectCount, 0);
989
990 atomic_set(&bufAllocCount, 0);
4498eed5
SF
991 atomic_set(&smBufAllocCount, 0);
992#ifdef CONFIG_CIFS_STATS2
993 atomic_set(&totBufAllocCount, 0);
994 atomic_set(&totSmBufAllocCount, 0);
995#endif /* CONFIG_CIFS_STATS2 */
996
1da177e4
LT
997 atomic_set(&midCount, 0);
998 GlobalCurrentXid = 0;
999 GlobalTotalActiveXid = 0;
1000 GlobalMaxActiveXid = 0;
3f9bcca7 1001 spin_lock_init(&cifs_tcp_ses_lock);
4477288a 1002 spin_lock_init(&cifs_file_list_lock);
1da177e4
LT
1003 spin_lock_init(&GlobalMid_Lock);
1004
4523cc30 1005 if (cifs_max_pending < 2) {
1da177e4 1006 cifs_max_pending = 2;
b6b38f70 1007 cFYI(1, "cifs_max_pending set to min of 2");
4523cc30 1008 } else if (cifs_max_pending > 256) {
1da177e4 1009 cifs_max_pending = 256;
b6b38f70 1010 cFYI(1, "cifs_max_pending set to max of 256");
1da177e4
LT
1011 }
1012
f579cf3c
SJ
1013 rc = cifs_fscache_register();
1014 if (rc)
d3bf5221 1015 goto out_clean_proc;
f579cf3c 1016
1da177e4 1017 rc = cifs_init_inodecache();
45af7a0f 1018 if (rc)
d3bf5221 1019 goto out_unreg_fscache;
45af7a0f
SF
1020
1021 rc = cifs_init_mids();
1022 if (rc)
1023 goto out_destroy_inodecache;
1024
1025 rc = cifs_init_request_bufs();
1026 if (rc)
1027 goto out_destroy_mids;
1028
1029 rc = register_filesystem(&cifs_fs_type);
1030 if (rc)
1031 goto out_destroy_request_bufs;
84a15b93
JL
1032#ifdef CONFIG_CIFS_UPCALL
1033 rc = register_key_type(&cifs_spnego_key_type);
1034 if (rc)
1035 goto out_unregister_filesystem;
6103335d 1036#endif
45af7a0f 1037
45af7a0f
SF
1038 return 0;
1039
84a15b93 1040#ifdef CONFIG_CIFS_UPCALL
d3bf5221 1041out_unregister_filesystem:
45af7a0f 1042 unregister_filesystem(&cifs_fs_type);
1fc7995d 1043#endif
d3bf5221 1044out_destroy_request_bufs:
45af7a0f 1045 cifs_destroy_request_bufs();
d3bf5221 1046out_destroy_mids:
45af7a0f 1047 cifs_destroy_mids();
d3bf5221 1048out_destroy_inodecache:
45af7a0f 1049 cifs_destroy_inodecache();
d3bf5221 1050out_unreg_fscache:
f579cf3c 1051 cifs_fscache_unregister();
d3bf5221
SF
1052out_clean_proc:
1053 cifs_proc_clean();
1da177e4
LT
1054 return rc;
1055}
1056
1057static void __exit
1058exit_cifs(void)
1059{
b6b38f70 1060 cFYI(DBG2, "exit_cifs");
1da177e4 1061 cifs_proc_clean();
f579cf3c 1062 cifs_fscache_unregister();
6103335d 1063#ifdef CONFIG_CIFS_DFS_UPCALL
78d31a3a 1064 cifs_dfs_release_automount_timer();
6103335d 1065#endif
84a15b93
JL
1066#ifdef CONFIG_CIFS_UPCALL
1067 unregister_key_type(&cifs_spnego_key_type);
1da177e4
LT
1068#endif
1069 unregister_filesystem(&cifs_fs_type);
1070 cifs_destroy_inodecache();
1071 cifs_destroy_mids();
1072 cifs_destroy_request_bufs();
1da177e4
LT
1073}
1074
1075MODULE_AUTHOR("Steve French <sfrench@us.ibm.com>");
6dc0f87e 1076MODULE_LICENSE("GPL"); /* combination of LGPL + GPL source behaves as GPL */
1da177e4 1077MODULE_DESCRIPTION
63135e08
SF
1078 ("VFS to access servers complying with the SNIA CIFS Specification "
1079 "e.g. Samba and Windows");
1da177e4
LT
1080MODULE_VERSION(CIFS_VERSION);
1081module_init(init_cifs)
1082module_exit(exit_cifs)