cifs: handle the TCP_Server_Info->tsk field more carefully
[linux-2.6] / fs / cifs / CHANGES
1 Version 1.55
2 ------------
3 Various fixes to make delete of open files behavior more predictable
4 (when delete of an open file fails we mark the file as "delete-on-close"
5 in a way that more servers accept, but only if we can first rename the
6 file to a temporary name).  Add experimental support for more safely
7 handling fcntl(F_SETLEASE).
8
9 Version 1.54
10 ------------
11 Fix premature write failure on congested networks (we would give up
12 on EAGAIN from the socket too quickly on large writes).
13 Cifs_mkdir and cifs_create now respect the setgid bit on parent dir.
14 Fix endian problems in acl (mode from/to cifs acl) on bigendian
15 architectures.  Fix problems with preserving timestamps on copying open
16 files (e.g. "cp -a") to Windows servers.  For mkdir and create honor setgid bit
17 on parent directory when server supports Unix Extensions but not POSIX
18 create. Update cifs.upcall version to handle new Kerberos sec flags
19 (this requires update of cifs.upcall program from Samba).  Fix memory leak
20 on dns_upcall (resolving DFS referralls).  Fix plain text password
21 authentication (requires setting SecurityFlags to 0x30030 to enable
22 lanman and plain text though).  Fix writes to be at correct offset when
23 file is open with O_APPEND and file is on a directio (forcediretio) mount.
24 Fix bug in rewinding readdir directory searches.  Add nodfs mount option.
25
26 Version 1.53
27 ------------
28 DFS support added (Microsoft Distributed File System client support needed
29 for referrals which enable a hierarchical name space among servers).
30 Disable temporary caching of mode bits to servers which do not support
31 storing of mode (e.g. Windows servers, when client mounts without cifsacl
32 mount option) and add new "dynperm" mount option to enable temporary caching
33 of mode (enable old behavior).  Fix hang on mount caused when server crashes
34 tcp session during negotiate protocol.
35
36 Version 1.52
37 ------------
38 Fix oops on second mount to server when null auth is used.
39 Enable experimental Kerberos support.  Return writebehind errors on flush
40 and sync so that events like out of disk space get reported properly on
41 cached files. Fix setxattr failure to certain Samba versions. Fix mount
42 of second share to disconnected server session (autoreconnect on this).
43 Add ability to modify cifs acls for handling chmod (when mounted with
44 cifsacl flag). Fix prefixpath path separator so we can handle mounts
45 with prefixpaths longer than one directory (one path component) when
46 mounted to Windows servers.  Fix slow file open when cifsacl
47 enabled. Fix memory leak in FindNext when the SMB call returns -EBADF.
48
49
50 Version 1.51
51 ------------
52 Fix memory leak in statfs when mounted to very old servers (e.g.
53 Windows 9x).  Add new feature "POSIX open" which allows servers
54 which support the current POSIX Extensions to provide better semantics
55 (e.g. delete for open files opened with posix open).  Take into
56 account umask on posix mkdir not just older style mkdir.  Add
57 ability to mount to IPC$ share (which allows CIFS named pipes to be
58 opened, read and written as if they were files).  When 1st tree
59 connect fails (e.g. due to signing negotiation failure) fix
60 leak that causes cifsd not to stop and rmmod to fail to cleanup
61 cifs_request_buffers pool. Fix problem with POSIX Open/Mkdir on
62 bigendian architectures. Fix possible memory corruption when
63 EAGAIN returned on kern_recvmsg. Return better error if server
64 requires packet signing but client has disabled it. When mounted
65 with cifsacl mount option - mode bits are approximated based
66 on the contents of the ACL of the file or directory. When cifs
67 mount helper is missing convert make sure that UNC name 
68 has backslash (not forward slash) between ip address of server
69 and the share name.
70
71 Version 1.50
72 ------------
73 Fix NTLMv2 signing. NFS server mounted over cifs works (if cifs mount is
74 done with "serverino" mount option).  Add support for POSIX Unlink
75 (helps with certain sharing violation cases when server such as
76 Samba supports newer POSIX CIFS Protocol Extensions). Add "nounix"
77 mount option to allow disabling the CIFS Unix Extensions for just
78 that mount. Fix hang on spinlock in find_writable_file (race when
79 reopening file after session crash).  Byte range unlock request to
80 windows server could unlock more bytes (on server copy of file)
81 than intended if start of unlock request is well before start of
82 a previous byte range lock that we issued.
83
84 Version 1.49
85 ------------
86 IPv6 support.  Enable ipv6 addresses to be passed on mount (put the ipv6
87 address after the "ip=" mount option, at least until mount.cifs is fixed to
88 handle DNS host to ipv6 name translation).  Accept override of uid or gid
89 on mount even when Unix Extensions are negotiated (it used to be ignored
90 when Unix Extensions were ignored).  This allows users to override the
91 default uid and gid for files when they are certain that the uids or
92 gids on the server do not match those of the client.  Make "sec=none"
93 mount override username (so that null user connection is attempted)
94 to match what documentation said. Support for very large reads, over 127K,
95 available to some newer servers (such as Samba 3.0.26 and later but
96 note that it also requires setting CIFSMaxBufSize at module install
97 time to a larger value which may hurt performance in some cases).
98 Make sign option force signing (or fail if server does not support it).
99
100 Version 1.48
101 ------------
102 Fix mtime bouncing around from local idea of last write times to remote time.
103 Fix hang (in i_size_read) when simultaneous size update of same remote file
104 on smp system corrupts sequence number. Do not reread unnecessarily partial page
105 (which we are about to overwrite anyway) when writing out file opened rw.
106 When DOS attribute of file on non-Unix server's file changes on the server side
107 from read-only back to read-write, reflect this change in default file mode
108 (we had been leaving a file's mode read-only until the inode were reloaded).
109 Allow setting of attribute back to ATTR_NORMAL (removing readonly dos attribute
110 when archive dos attribute not set and we are changing mode back to writeable
111 on server which does not support the Unix Extensions).  Remove read only dos
112 attribute on chmod when adding any write permission (ie on any of
113 user/group/other (not all of user/group/other ie  0222) when
114 mounted to windows.  Add support for POSIX MkDir (slight performance
115 enhancement and eliminates the network race between the mkdir and set 
116 path info of the mode).
117
118
119 Version 1.47
120 ------------
121 Fix oops in list_del during mount caused by unaligned string.
122 Fix file corruption which could occur on some large file
123 copies caused by writepages page i/o completion bug.
124 Seek to SEEK_END forces check for update of file size for non-cached
125 files. Allow file size to be updated on remote extend of locally open,
126 non-cached file.  Fix reconnect to newer Samba servers (or other servers
127 which support the CIFS Unix/POSIX extensions) so that we again tell the
128 server the Unix/POSIX cifs capabilities which we support (SetFSInfo).
129 Add experimental support for new POSIX Open/Mkdir (which returns
130 stat information on the open, and allows setting the mode).
131
132 Version 1.46
133 ------------
134 Support deep tree mounts.  Better support OS/2, Win9x (DOS) time stamps.
135 Allow null user to be specified on mount ("username="). Do not return
136 EINVAL on readdir when filldir fails due to overwritten blocksize
137 (fixes FC problem).  Return error in rename 2nd attempt retry (ie report
138 if rename by handle also fails, after rename by path fails, we were
139 not reporting whether the retry worked or not). Fix NTLMv2 to
140 work to Windows servers (mount with option "sec=ntlmv2").
141
142 Version 1.45
143 ------------
144 Do not time out lockw calls when using posix extensions. Do not
145 time out requests if server still responding reasonably fast
146 on requests on other threads.  Improve POSIX locking emulation,
147 (lock cancel now works, and unlock of merged range works even
148 to Windows servers now).  Fix oops on mount to lanman servers
149 (win9x, os/2 etc.) when null password.  Do not send listxattr
150 (SMB to query all EAs) if nouser_xattr specified.  Fix SE Linux
151 problem (instantiate inodes/dentries in right order for readdir).
152
153 Version 1.44
154 ------------
155 Rewritten sessionsetup support, including support for legacy SMB
156 session setup needed for OS/2 and older servers such as Windows 95 and 98.
157 Fix oops on ls to OS/2 servers.  Add support for level 1 FindFirst
158 so we can do search (ls etc.) to OS/2.  Do not send NTCreateX
159 or recent levels of FindFirst unless server says it supports NT SMBs
160 (instead use legacy equivalents from LANMAN dialect). Fix to allow
161 NTLMv2 authentication support (now can use stronger password hashing
162 on mount if corresponding /proc/fs/cifs/SecurityFlags is set (0x4004).
163 Allow override of global cifs security flags on mount via "sec=" option(s).
164
165 Version 1.43
166 ------------
167 POSIX locking to servers which support CIFS POSIX Extensions
168 (disabled by default controlled by proc/fs/cifs/Experimental).
169 Handle conversion of long share names (especially Asian languages)
170 to Unicode during mount. Fix memory leak in sess struct on reconnect.
171 Fix rare oops after acpi suspend.  Fix O_TRUNC opens to overwrite on
172 cifs open which helps rare case when setpathinfo fails or server does
173 not support it. 
174
175 Version 1.42
176 ------------
177 Fix slow oplock break when mounted to different servers at the same time and
178 the tids match and we try to find matching fid on wrong server. Fix read
179 looping when signing required by server (2.6.16 kernel only). Fix readdir
180 vs. rename race which could cause each to hang. Return . and .. even
181 if server does not.  Allow searches to skip first three entries and
182 begin at any location. Fix oops in find_writeable_file.
183
184 Version 1.41
185 ------------
186 Fix NTLMv2 security (can be enabled in /proc/fs/cifs) so customers can
187 configure stronger authentication.  Fix sfu symlinks so they can
188 be followed (not just recognized).  Fix wraparound of bcc on
189 read responses when buffer size over 64K and also fix wrap of
190 max smb buffer size when CIFSMaxBufSize over 64K.  Fix oops in
191 cifs_user_read and cifs_readpages (when EAGAIN on send of smb
192 on socket is returned over and over).  Add POSIX (advisory) byte range
193 locking support (requires server with newest CIFS UNIX Extensions
194 to the protocol implemented). Slow down negprot slightly in port 139
195 RFC1001 case to give session_init time on buggy servers.
196
197 Version 1.40
198 ------------
199 Use fsuid (fsgid) more consistently instead of uid (gid). Improve performance
200 of readpages by eliminating one extra memcpy. Allow update of file size
201 from remote server even if file is open for write as long as mount is
202 directio.  Recognize share mode security and send NTLM encrypted password
203 on tree connect if share mode negotiated.
204
205 Version 1.39
206 ------------
207 Defer close of a file handle slightly if pending writes depend on that handle
208 (this reduces the EBADF bad file handle errors that can be logged under heavy
209 stress on writes). Modify cifs Kconfig options to expose CONFIG_CIFS_STATS2 
210 Fix SFU style symlinks and mknod needed for servers which do not support the
211 CIFS Unix Extensions.  Fix setfacl/getfacl on bigendian. Timeout negative
212 dentries so files that the client sees as deleted but that later get created
213 on the server will be recognized.  Add client side permission check on setattr.
214 Timeout stuck requests better (where server has never responded or sent corrupt
215 responses)
216
217 Version 1.38
218 ------------
219 Fix tcp socket retransmission timeouts (e.g. on ENOSPACE from the socket)
220 to be smaller at first (but increasing) so large write performance performance
221 over GigE is better.  Do not hang thread on illegal byte range lock response
222 from Windows (Windows can send an RFC1001 size which does not match smb size) by
223 allowing an SMBs TCP length to be up to a few bytes longer than it should be.
224 wsize and rsize can now be larger than negotiated buffer size if server
225 supports large readx/writex, even when directio mount flag not specified.
226 Write size will in many cases now be 16K instead of 4K which greatly helps
227 file copy performance on lightly loaded networks.  Fix oops in dnotify
228 when experimental config flag enabled. Make cifsFYI more granular.
229
230 Version 1.37
231 ------------
232 Fix readdir caching when unlink removes file in current search buffer,
233 and this is followed by a rewind search to just before the deleted entry.
234 Do not attempt to set ctime unless atime and/or mtime change requested
235 (most servers throw it away anyway). Fix length check of received smbs
236 to be more accurate. Fix big endian problem with mapchars mount option,
237 and with a field returned by statfs.
238
239 Version 1.36
240 ------------
241 Add support for mounting to older pre-CIFS servers such as Windows9x and ME.
242 For these older servers, add option for passing netbios name of server in
243 on mount (servernetbiosname).  Add suspend support for power management, to
244 avoid cifsd thread preventing software suspend from working.
245 Add mount option for disabling the default behavior of sending byte range lock
246 requests to the server (necessary for certain applications which break with
247 mandatory lock behavior such as Evolution), and also mount option for
248 requesting case insensitive matching for path based requests (requesting
249 case sensitive is the default).
250
251 Version 1.35
252 ------------
253 Add writepage performance improvements.  Fix path name conversions
254 for long filenames on mounts which were done with "mapchars" mount option
255 specified.  Ensure multiplex ids do not collide.  Fix case in which 
256 rmmod can oops if done soon after last unmount.  Fix truncated
257 search (readdir) output when resume filename was a long filename.
258 Fix filename conversion when mapchars mount option was specified and
259 filename was a long filename.
260
261 Version 1.34
262 ------------
263 Fix error mapping of the TOO_MANY_LINKS (hardlinks) case.
264 Do not oops if root user kills cifs oplock kernel thread or
265 kills the cifsd thread (NB: killing the cifs kernel threads is not
266 recommended, unmount and rmmod cifs will kill them when they are
267 no longer needed).  Fix readdir to ASCII servers (ie older servers
268 which do not support Unicode) and also require asterisk.
269 Fix out of memory case in which data could be written one page
270 off in the page cache.
271
272 Version 1.33
273 ------------
274 Fix caching problem, in which readdir of directory containing a file
275 which was cached could cause the file's time stamp to be updated
276 without invalidating the readahead data (so we could get stale
277 file data on the client for that file even as the server copy changed).
278 Cleanup response processing so cifsd can not loop when abnormally
279 terminated.
280
281
282 Version 1.32
283 ------------
284 Fix oops in ls when Transact2 FindFirst (or FindNext) returns more than one
285 transact response for an SMB request and search entry split across two frames.
286 Add support for lsattr (getting ext2/ext3/reiserfs attr flags from the server)
287 as new protocol extensions. Do not send Get/Set calls for POSIX ACLs
288 unless server explicitly claims to support them in CIFS Unix extensions
289 POSIX ACL capability bit. Fix packet signing when multiuser mounting with
290 different users from the same client to the same server. Fix oops in
291 cifs_close. Add mount option for remapping reserved characters in
292 filenames (also allow recognizing files with created by SFU which have any
293 of these seven reserved characters, except backslash, to be recognized).
294 Fix invalid transact2 message (we were sometimes trying to interpret
295 oplock breaks as SMB responses). Add ioctl for checking that the
296 current uid matches the uid of the mounter (needed by umount.cifs).
297 Reduce the number of large buffer allocations in cifs response processing
298 (significantly reduces memory pressure under heavy stress with multiple
299 processes accessing the same server at the same time).
300
301 Version 1.31
302 ------------
303 Fix updates of DOS attributes and time fields so that files on NT4 servers
304 do not get marked delete on close. Display sizes of cifs buffer pools in
305 cifs stats. Fix oops in unmount when cifsd thread being killed by 
306 shutdown. Add generic readv/writev and aio support. Report inode numbers 
307 consistently in readdir and lookup (when serverino mount option is
308 specified use the inode number that the server reports - for both lookup
309 and readdir, otherwise by default the locally generated inode number is used
310 for inodes created in either path since servers are not always able to 
311 provide unique inode numbers when exporting multiple volumes from under one
312 sharename).
313
314 Version 1.30
315 ------------
316 Allow new nouser_xattr mount parm to disable xattr support for user namespace.
317 Do not flag user_xattr mount parm in dmesg.  Retry failures setting file time  
318 (mostly affects NT4 servers) by retry with handle based network operation. 
319 Add new POSIX Query FS Info for returning statfs info more accurately.
320 Handle passwords with multiple commas in them.
321
322 Version 1.29
323 ------------
324 Fix default mode in sysfs of cifs module parms.  Remove old readdir routine.
325 Fix capabilities flags for large readx so as to allow reads larger than 64K.
326
327 Version 1.28
328 ------------
329 Add module init parm for large SMB buffer size (to allow it to be changed
330 from its default of 16K) which is especially useful for large file copy
331 when mounting with the directio mount option. Fix oops after 
332 returning from mount when experimental ExtendedSecurity enabled and
333 SpnegoNegotiated returning invalid error. Fix case to retry better when 
334 peek returns from 1 to 3 bytes on socket which should have more data.
335 Fixed path based calls (such as cifs lookup) to handle path names
336 longer than 530 (now can handle PATH_MAX). Fix pass through authentication
337 from Samba server to DC (Samba required dummy LM password).
338
339 Version 1.27
340 ------------
341 Turn off DNOTIFY (directory change notification support) by default
342 (unless built with the experimental flag) to fix hang with KDE
343 file browser. Fix DNOTIFY flag mappings.  Fix hang (in wait_event
344 waiting on an SMB response) in SendReceive when session dies but
345 reconnects quickly from another task.  Add module init  parms for
346 minimum number of large and small network buffers in the buffer pools,
347 and for the maximum number of simultaneous requests.
348
349 Version 1.26
350 ------------
351 Add setfacl support to allow setting of ACLs remotely to Samba 3.10 and later
352 and other POSIX CIFS compliant servers.  Fix error mapping for getfacl 
353 to EOPNOTSUPP when server does not support posix acls on the wire. Fix 
354 improperly zeroed buffer in CIFS Unix extensions set times call. 
355
356 Version 1.25
357 ------------
358 Fix internationalization problem in cifs readdir with filenames that map to 
359 longer UTF-8 strings than the string on the wire was in Unicode.  Add workaround
360 for readdir to netapp servers. Fix search rewind (seek into readdir to return 
361 non-consecutive entries).  Do not do readdir when server negotiates 
362 buffer size to small to fit filename. Add support for reading POSIX ACLs from
363 the server (add also acl and noacl mount options).
364
365 Version 1.24
366 ------------
367 Optionally allow using server side inode numbers, rather than client generated
368 ones by specifying mount option "serverino" - this is required for some apps
369 to work which double check hardlinked files and have persistent inode numbers.
370
371 Version 1.23
372 ------------
373 Multiple bigendian fixes. On little endian systems (for reconnect after
374 network failure) fix tcp session reconnect code so we do not try first
375 to reconnect on reverse of port 445. Treat reparse points (NTFS junctions)
376 as directories rather than symlinks because we can do follow link on them.
377
378 Version 1.22
379 ------------
380 Add config option to enable XATTR (extended attribute) support, mapping
381 xattr names in the "user." namespace space to SMB/CIFS EAs. Lots of
382 minor fixes pointed out by the Stanford SWAT checker (mostly missing
383 or out of order NULL pointer checks in little used error paths).
384
385 Version 1.21
386 ------------
387 Add new mount parm to control whether mode check (generic_permission) is done
388 on the client.  If Unix extensions are enabled and the uids on the client
389 and server do not match, client permission checks are meaningless on
390 server uids that do not exist on the client (this does not affect the
391 normal ACL check which occurs on the server).  Fix default uid
392 on mknod to match create and mkdir. Add optional mount parm to allow
393 override of the default uid behavior (in which the server sets the uid
394 and gid of newly created files). Normally for network filesystem mounts
395 user want the server to set the uid/gid on newly created files (rather than 
396 using uid of the client processes you would in a local filesystem).
397
398 Version 1.20
399 ------------
400 Make transaction counts more consistent. Merge /proc/fs/cifs/SimultaneousOps
401 info into /proc/fs/cifs/DebugData.  Fix oops in rare oops in readdir 
402 (in build_wildcard_path_from_dentry).  Fix mknod to pass type field
403 (block/char/fifo) properly.  Remove spurious mount warning log entry when
404 credentials passed as mount argument. Set major/minor device number in
405 inode for block and char devices when unix extensions enabled.
406
407 Version 1.19
408 ------------
409 Fix /proc/fs/cifs/Stats and DebugData display to handle larger
410 amounts of return data. Properly limit requests to MAX_REQ (50
411 is the usual maximum active multiplex SMB/CIFS requests per server).
412 Do not kill cifsd (and thus hurt the other SMB session) when more than one
413 session to the same server (but with different userids) exists and one
414 of the two user's smb sessions is being removed while leaving the other.
415 Do not loop reconnecting in cifsd demultiplex thread when admin
416 kills the thread without going through unmount.
417
418 Version 1.18
419 ------------
420 Do not rename hardlinked files (since that should be a noop). Flush
421 cached write behind data when reopening a file after session abend,
422 except when already in write. Grab per socket sem during reconnect 
423 to avoid oops in sendmsg if overlapping with reconnect. Do not
424 reset cached inode file size on readdir for files open for write on 
425 client.
426
427
428 Version 1.17
429 ------------
430 Update number of blocks in file so du command is happier (in Linux a fake
431 blocksize of 512 is required for calculating number of blocks in inode).
432 Fix prepare write of partial pages to read in data from server if possible.
433 Fix race on tcpStatus field between unmount and reconnection code, causing
434 cifsd process sometimes to hang around forever. Improve out of memory
435 checks in cifs_filldir
436
437 Version 1.16
438 ------------
439 Fix incorrect file size in file handle based setattr on big endian hardware.
440 Fix oops in build_path_from_dentry when out of memory.  Add checks for invalid
441 and closing file structs in writepage/partialpagewrite.  Add statistics
442 for each mounted share (new menuconfig option). Fix endianness problem in
443 volume information displayed in /proc/fs/cifs/DebugData (only affects
444 affects big endian architectures). Prevent renames while constructing
445 path names for open, mkdir and rmdir.
446
447 Version 1.15
448 ------------
449 Change to mempools for alloc smb request buffers and multiplex structs
450 to better handle low memory problems (and potential deadlocks).
451
452 Version 1.14
453 ------------
454 Fix incomplete listings of large directories on Samba servers when Unix
455 extensions enabled.  Fix oops when smb_buffer can not be allocated. Fix
456 rename deadlock when writing out dirty pages at same time.
457
458 Version 1.13
459 ------------
460 Fix open of files in which O_CREATE can cause the mode to change in
461 some cases. Fix case in which retry of write overlaps file close.
462 Fix PPC64 build error.  Reduce excessive stack usage in smb password
463 hashing. Fix overwrite of Linux user's view of file mode to Windows servers.
464
465 Version 1.12
466 ------------
467 Fixes for large file copy, signal handling, socket retry, buffer
468 allocation and low memory situations.
469
470 Version 1.11
471 ------------
472 Better port 139 support to Windows servers (RFC1001/RFC1002 Session_Initialize)
473 also now allowing support for specifying client netbiosname.  NT4 support added.
474
475 Version 1.10
476 ------------
477 Fix reconnection (and certain failed mounts) to properly wake up the
478 blocked users thread so it does not seem hung (in some cases was blocked
479 until the cifs receive timeout expired). Fix spurious error logging
480 to kernel log when application with open network files killed. 
481
482 Version 1.09
483 ------------
484 Fix /proc/fs module unload warning message (that could be logged
485 to the kernel log). Fix intermittent failure in connectathon
486 test7 (hardlink count not immediately refreshed in case in which
487 inode metadata can be incorrectly kept cached when time near zero)
488
489 Version 1.08
490 ------------
491 Allow file_mode and dir_mode (specified at mount time) to be enforced
492 locally (the server already enforced its own ACLs too) for servers
493 that do not report the correct mode (do not support the 
494 CIFS Unix Extensions).
495
496 Version 1.07
497 ------------
498 Fix some small memory leaks in some unmount error paths. Fix major leak
499 of cache pages in readpages causing multiple read oriented stress
500 testcases (including fsx, and even large file copy) to fail over time. 
501
502 Version 1.06
503 ------------
504 Send NTCreateX with ATTR_POSIX if Linux/Unix extensions negotiated with server.
505 This allows files that differ only in case and improves performance of file
506 creation and file open to such servers.  Fix semaphore conflict which causes 
507 slow delete of open file to Samba (which unfortunately can cause an oplock
508 break to self while vfs_unlink held i_sem) which can hang for 20 seconds.
509
510 Version 1.05
511 ------------
512 fixes to cifs_readpages for fsx test case
513
514 Version 1.04
515 ------------
516 Fix caching data integrity bug when extending file size especially when no
517 oplock on file.  Fix spurious logging of valid already parsed mount options
518 that are parsed outside of the cifs vfs such as nosuid.
519
520
521 Version 1.03
522 ------------
523 Connect to server when port number override not specified, and tcp port
524 unitialized.  Reset search to restart at correct file when kernel routine
525 filldir returns error during large directory searches (readdir). 
526
527 Version 1.02
528 ------------
529 Fix caching problem when files opened by multiple clients in which 
530 page cache could contain stale data, and write through did
531 not occur often enough while file was still open when read ahead
532 (read oplock) not allowed.  Treat "sep=" when first mount option
533 as an override of comma as the default separator between mount
534 options. 
535
536 Version 1.01
537 ------------
538 Allow passwords longer than 16 bytes. Allow null password string.
539
540 Version 1.00
541 ------------
542 Gracefully clean up failed mounts when attempting to mount to servers such as
543 Windows 98 that terminate tcp sessions during protocol negotiation.  Handle
544 embedded commas in mount parsing of passwords.
545
546 Version 0.99
547 ------------
548 Invalidate local inode cached pages on oplock break and when last file
549 instance is closed so that the client does not continue using stale local
550 copy rather than later modified server copy of file.  Do not reconnect
551 when server drops the tcp session prematurely before negotiate
552 protocol response.  Fix oops in reopen_file when dentry freed.  Allow
553 the support for CIFS Unix Extensions to be disabled via proc interface.
554
555 Version 0.98
556 ------------
557 Fix hang in commit_write during reconnection of open files under heavy load.
558 Fix unload_nls oops in a mount failure path. Serialize writes to same socket
559 which also fixes any possible races when cifs signatures are enabled in SMBs
560 being sent out of signature sequence number order.    
561
562 Version 0.97
563 ------------
564 Fix byte range locking bug (endian problem) causing bad offset and
565 length.
566
567 Version 0.96
568 ------------
569 Fix oops (in send_sig) caused by CIFS unmount code trying to
570 wake up the demultiplex thread after it had exited. Do not log
571 error on harmless oplock release of closed handle.
572
573 Version 0.95
574 ------------
575 Fix unsafe global variable usage and password hash failure on gcc 3.3.1
576 Fix problem reconnecting secondary mounts to same server after session 
577 failure.  Fix invalid dentry - race in mkdir when directory gets created
578 by another client between the lookup and mkdir.
579  
580 Version 0.94
581 ------------
582 Fix to list processing in reopen_files. Fix reconnection when server hung
583 but tcpip session still alive.  Set proper timeout on socket read.
584
585 Version 0.93
586 ------------
587 Add missing mount options including iocharset.  SMP fixes in write and open. 
588 Fix errors in reconnecting after TCP session failure.  Fix module unloading
589 of default nls codepage
590
591 Version 0.92
592 ------------
593 Active smb transactions should never go negative (fix double FreeXid). Fix
594 list processing in file routines. Check return code on kmalloc in open.
595 Fix spinlock usage for SMP.
596
597 Version 0.91
598 ------------
599 Fix oops in reopen_files when invalid dentry. drop dentry on server rename 
600 and on revalidate errors. Fix cases where pid is now tgid.  Fix return code
601 on create hard link when server does not support them. 
602
603 Version 0.90
604 ------------
605 Fix scheduling while atomic error in getting inode info on newly created file. 
606 Fix truncate of existing files opened with O_CREAT but not O_TRUNC set.
607
608 Version 0.89
609 ------------
610 Fix oops on write to dead tcp session. Remove error log write for case when file open
611 O_CREAT but not O_EXCL
612
613 Version 0.88
614 ------------
615 Fix non-POSIX behavior on rename of open file and delete of open file by taking 
616 advantage of trans2 SetFileInfo rename facility if available on target server.
617 Retry on ENOSPC and EAGAIN socket errors.
618
619 Version 0.87
620 ------------
621 Fix oops on big endian readdir.  Set blksize to be even power of two (2**blkbits) to fix
622 allocation size miscalculation. After oplock token lost do not read through
623 cache. 
624
625 Version 0.86
626 ------------
627 Fix oops on empty file readahead.  Fix for file size handling for locally cached files.
628
629 Version 0.85
630 ------------
631 Fix oops in mkdir when server fails to return inode info. Fix oops in reopen_files
632 during auto reconnection to server after server recovered from failure.
633
634 Version 0.84
635 ------------
636 Finish support for Linux 2.5 open/create changes, which removes the
637 redundant NTCreate/QPathInfo/close that was sent during file create.
638 Enable oplock by default. Enable packet signing by default (needed to 
639 access many recent Windows servers)
640
641 Version 0.83
642 ------------
643 Fix oops when mounting to long server names caused by inverted parms to kmalloc.
644 Fix MultiuserMount (/proc/fs/cifs configuration setting) so that when enabled
645 we will choose a cifs user session (smb uid) that better matches the local
646 uid if a) the mount uid does not match the current uid and b) we have another
647 session to the same server (ip address) for a different mount which
648 matches the current local uid.
649
650 Version 0.82
651 ------------
652 Add support for mknod of block or character devices.  Fix oplock
653 code (distributed caching) to properly send response to oplock
654 break from server.
655
656 Version 0.81
657 ------------
658 Finish up CIFS packet digital signing for the default
659 NTLM security case. This should help Windows 2003
660 network interoperability since it is common for
661 packet signing to be required now. Fix statfs (stat -f)
662 which recently started returning errors due to 
663 invalid value (-1 instead of 0) being set in the
664 struct kstatfs f_ffiles field.
665
666 Version 0.80
667 -----------
668 Fix oops on stopping oplock thread when removing cifs when
669 built as module.
670
671 Version 0.79
672 ------------
673 Fix mount options for ro (readonly), uid, gid and file and directory mode. 
674
675 Version 0.78
676 ------------
677 Fix errors displayed on failed mounts to be more understandable.
678 Fixed various incorrect or misleading smb to posix error code mappings.
679
680 Version 0.77
681 ------------
682 Fix display of NTFS DFS junctions to display as symlinks.
683 They are the network equivalent.  Fix oops in 
684 cifs_partialpagewrite caused by missing spinlock protection
685 of openfile linked list.  Allow writebehind caching errors to 
686 be returned to the application at file close.
687
688 Version 0.76
689 ------------
690 Clean up options displayed in /proc/mounts by show_options to
691 be more consistent with other filesystems.
692
693 Version 0.75
694 ------------
695 Fix delete of readonly file to Windows servers.  Reflect
696 presence or absence of read only dos attribute in mode
697 bits for servers that do not support CIFS Unix extensions.
698 Fix shortened results on readdir of large directories to
699 servers supporting CIFS Unix extensions (caused by
700 incorrect resume key).
701
702 Version 0.74
703 ------------
704 Fix truncate bug (set file size) that could cause hangs e.g. running fsx
705
706 Version 0.73
707 ------------
708 unload nls if mount fails.
709
710 Version 0.72
711 ------------
712 Add resume key support to search (readdir) code to workaround
713 Windows bug.  Add /proc/fs/cifs/LookupCacheEnable which
714 allows disabling caching of attribute information for
715 lookups.
716
717 Version 0.71
718 ------------
719 Add more oplock handling (distributed caching code).  Remove
720 dead code.  Remove excessive stack space utilization from
721 symlink routines.
722
723 Version 0.70
724 ------------
725 Fix oops in get dfs referral (triggered when null path sent in to
726 mount).  Add support for overriding rsize at mount time.
727
728 Version 0.69
729 ------------
730 Fix buffer overrun in readdir which caused intermittent kernel oopses.
731 Fix writepage code to release kmap on write data.  Allow "-ip=" new 
732 mount option to be passed in on parameter distinct from the first part
733 (server name portion of) the UNC name.  Allow override of the
734 tcp port of the target server via new mount option "-port="  
735
736 Version 0.68
737 ------------
738 Fix search handle leak on rewind.  Fix setuid and gid so that they are 
739 reflected in the local inode immediately.  Cleanup of whitespace
740 to make 2.4 and 2.5 versions more consistent.
741
742
743 Version 0.67
744 ------------
745 Fix signal sending so that captive thread (cifsd) exits on umount 
746 (which was causing the warning in kmem_cache_free of the request buffers
747 at rmmod time).  This had broken as a sideeffect of the recent global
748 kernel change to daemonize.  Fix memory leak in readdir code which
749 showed up in "ls -R" (and applications that did search rewinding).
750
751 Version 0.66
752 ------------
753 Reconnect tids and fids after session reconnection (still do not
754 reconnect byte range locks though).  Fix problem caching
755 lookup information for directory inodes, improving performance,
756 especially in deep directory trees.  Fix various build warnings.
757
758 Version 0.65
759 ------------
760 Finish fixes to commit write for caching/readahead consistency.  fsx 
761 now works to Samba servers.  Fix oops caused when readahead
762 was interrupted by a signal.
763
764 Version 0.64
765 ------------
766 Fix data corruption (in partial page after truncate) that caused fsx to
767 fail to Windows servers.  Cleaned up some extraneous error logging in
768 common error paths.  Add generic sendfile support.
769
770 Version 0.63
771 ------------
772 Fix memory leak in AllocMidQEntry.
773 Finish reconnection logic, so connection with server can be dropped
774 (or server rebooted) and the cifs client will reconnect.  
775
776 Version 0.62
777 ------------
778 Fix temporary socket leak when bad userid or password specified 
779 (or other SMBSessSetup failure).  Increase maximum buffer size to slightly
780 over 16K to allow negotiation of up to Samba and Windows server default read 
781 sizes.  Add support for readpages
782
783 Version 0.61
784 ------------
785 Fix oops when username not passed in on mount.  Extensive fixes and improvements
786 to error logging (strip redundant newlines, change debug macros to ensure newline
787 passed in and to be more consistent).  Fix writepage wrong file handle problem,
788 a readonly file handle could be incorrectly used to attempt to write out
789 file updates through the page cache to multiply open files.  This could cause
790 the iozone benchmark to fail on the fwrite test. Fix bug mounting two different
791 shares to the same Windows server when using different usernames
792 (doing this to Samba servers worked but Windows was rejecting it) - now it is
793 possible to use different userids when connecting to the same server from a
794 Linux client. Fix oops when treeDisconnect called during unmount on
795 previously freed socket.
796
797 Version 0.60
798 ------------
799 Fix oops in readpages caused by not setting address space operations in inode in 
800 rare code path. 
801
802 Version 0.59
803 ------------
804 Includes support for deleting of open files and renaming over existing files (per POSIX
805 requirement).  Add readlink support for Windows junction points (directory symlinks).
806
807 Version 0.58
808 ------------
809 Changed read and write to go through pagecache. Added additional address space operations.
810 Memory mapped operations now working.
811
812 Version 0.57
813 ------------
814 Added writepage code for additional memory mapping support.  Fixed leak in xids causing
815 the simultaneous operations counter (/proc/fs/cifs/SimultaneousOps) to increase on 
816 every stat call.  Additional formatting cleanup. 
817
818 Version 0.56
819 ------------
820 Fix bigendian bug in order of time conversion. Merge 2.5 to 2.4 version.  Formatting cleanup.   
821
822 Version 0.55
823 ------------
824 Fixes from Zwane Mwaikambo for adding missing return code checking in a few places.
825 Also included a modified version of his fix to protect global list manipulation of
826 the smb session and tree connection and mid related global variables.
827
828 Version 0.54
829 ------------
830 Fix problem with captive thread hanging around at unmount time.  Adjust to 2.5.42-pre
831 changes to superblock layout.   Remove wasteful allocation of smb buffers (now the send 
832 buffer is reused for responses).  Add more oplock handling. Additional minor cleanup.
833
834 Version 0.53
835 ------------
836 More stylistic updates to better match kernel style.  Add additional statistics
837 for filesystem which can be viewed via /proc/fs/cifs.  Add more pieces of NTLMv2
838 and CIFS Packet Signing enablement.
839
840 Version 0.52
841 ------------
842 Replace call to sleep_on with safer wait_on_event.
843 Make stylistic changes to better match kernel style recommendations.
844 Remove most typedef usage (except for the PDUs themselves).
845
846 Version 0.51
847 ------------
848 Update mount so the -unc mount option is no longer required (the ip address can be specified
849 in a UNC style device name.   Implementation of readpage/writepage started.
850
851 Version 0.50
852 ------------
853 Fix intermittent problem with incorrect smb header checking on badly 
854 fragmented tcp responses
855
856 Version 0.49
857 ------------
858 Fixes to setting of allocation size and file size.
859
860 Version 0.48
861 ------------
862 Various 2.5.38 fixes.  Now works on 2.5.38
863
864 Version 0.47
865 ------------
866 Prepare for 2.5 kernel merge.  Remove ifdefs.
867
868 Version 0.46
869 ------------
870 Socket buffer management fixes.  Fix dual free.
871
872 Version 0.45
873 ------------
874 Various big endian fixes for hardlinks and symlinks and also for dfs.
875
876 Version 0.44
877 ------------
878 Various big endian fixes for servers with Unix extensions such as Samba
879
880 Version 0.43
881 ------------
882 Various FindNext fixes for incorrect filenames on large directory searches on big endian
883 clients.  basic posix file i/o tests now work on big endian machines, not just le
884
885 Version 0.42
886 ------------
887 SessionSetup and NegotiateProtocol now work from Big Endian machines.
888 Various Big Endian fixes found during testing on the Linux on 390.  Various fixes for compatibility with older
889 versions of 2.4 kernel (now builds and works again on kernels at least as early as 2.4.7).
890
891 Version 0.41
892 ------------
893 Various minor fixes for Connectathon Posix "basic" file i/o test suite.  Directory caching fixed so hardlinked
894 files now return the correct number of links on fstat as they are repeatedly linked and unlinked.
895
896 Version 0.40
897 ------------
898 Implemented "Raw" (i.e. not encapsulated in SPNEGO) NTLMSSP (i.e. the Security Provider Interface used to negotiate
899 session advanced session authentication).  Raw NTLMSSP is preferred by Windows 2000 Professional and Windows XP.
900 Began implementing support for SPNEGO encapsulation of NTLMSSP based session authentication blobs
901 (which is the mechanism preferred by Windows 2000 server in the absence of Kerberos).
902
903 Version 0.38
904 ------------
905 Introduced optional mount helper utility mount.cifs and made coreq changes to cifs vfs to enable
906 it. Fixed a few bugs in the DFS code (e.g. bcc two bytes too short and incorrect uid in PDU).
907
908 Version 0.37
909 ------------
910 Rewrote much of connection and mount/unmount logic to handle bugs with
911 multiple uses to same share, multiple users to same server etc.
912
913 Version 0.36
914 ------------
915 Fixed major problem with dentry corruption (missing call to dput)
916
917 Version 0.35
918 ------------
919 Rewrite of readdir code to fix bug. Various fixes for bigendian machines.
920 Begin adding oplock support.  Multiusermount and oplockEnabled flags added to /proc/fs/cifs
921 although corresponding function not fully implemented in the vfs yet
922
923 Version 0.34
924 ------------
925 Fixed dentry caching bug, misc. cleanup 
926
927 Version 0.33
928 ------------
929 Fixed 2.5 support to handle build and configure changes as well as misc. 2.5 changes.  Now can build
930 on current 2.5 beta version (2.5.24) of the Linux kernel as well as on 2.4 Linux kernels.
931 Support for STATUS codes (newer 32 bit NT error codes) added.  DFS support begun to be added.
932
933 Version 0.32
934 ------------
935 Unix extensions (symlink, readlink, hardlink, chmod and some chgrp and chown) implemented
936 and tested against Samba 2.2.5
937
938
939 Version 0.31
940 ------------
941 1) Fixed lockrange to be correct (it was one byte too short)
942
943 2) Fixed GETLK (i.e. the fcntl call to test a range of bytes in a file to see if locked) to correctly 
944 show range as locked when there is a conflict with an existing lock.
945
946 3) default file perms are now 2767 (indicating support for mandatory locks) instead of 777 for directories
947 in most cases.  Eventually will offer optional ability to query server for the correct perms.
948
949 3) Fixed eventual trap when mounting twice to different shares on the same server when the first succeeded 
950 but the second one was invalid and failed (the second one was incorrectly disconnecting the tcp and smb
951 session) 
952
953 4) Fixed error logging of valid mount options
954
955 5) Removed logging of password field.
956
957 6) Moved negotiate, treeDisconnect and uloggoffX (only tConx and SessSetup remain in connect.c) to cifssmb.c
958 and cleaned them up and made them more consistent with other cifs functions. 
959
960 7) Server support for Unix extensions is now fully detected and FindFirst is implemented both ways 
961 (with or without Unix extensions) but FindNext and QueryPathInfo with the Unix extensions are not completed,
962 nor is the symlink support using the Unix extensions
963
964 8) Started adding the readlink and follow_link code 
965
966 Version 0.3 
967 -----------
968 Initial drop
969