Windows: AFSInitCcb redefinition
[openafs.git] / NEWS
1                        User-Visible OpenAFS Changes
2
3 OpenAFS 1.6.2 (in progress)
4
5   All platforms
6
7     * Abort an rx connection when given an unknown service (Gerrit 7593).
8
9     * "idle dead" behavior improvements.
10
11     * Documentation updates.
12
13   All server platforms
14
15     * Fix rare file corruption during background sync (Gerrit 8796).
16
17     * Fix corrupting clients' metadata cache during certain errors (Gerrit
18       6957).
19
20     * Avoid saying a volume doesn't exist when accessed as the volume is
21       going offline (Gerrit 7488).
22
23     * Fix fileservers to properly report >2 TiB partitions.
24
25     * Fix stale volume info from vos examine on non-DAFS filservers.
26
27     * Fix possible volume corruption with vos convertROtoRW.
28
29     * Fix bosserver to preserve all command-line options over restart.
30
31     * Fix bosserver to properly kill hung processes during shutdown.
32
33   All UNIX client platforms
34
35     * Fixes for memcache, especially on Solaris.
36
37     * Increase the size of the DNS resolver answer buffer to allow sites
38       with a long response list to use SRV and AFSDB records.
39
40     * Fix a crash when a server appears to run out of addresses (Gerrit
41       7487).
42
43     * Fix cache corruption when reading from a file another client is
44       simultaneously writing to (Gerrit 7994).
45
46     * Improve handling of disk cache disk errors.
47
48   Linux
49
50     * fix DKMS configuration for DKMS 2.2.
51
52     * Avoid generating inode number 0 with md5 inodes (Gerrit 7276).
53
54     * Fix a crash when reading /proc/fs/openafs/unixusers (Gerrit 7914).
55
56     * Make PAG-less access use the real UID of the calling process
57       instead of the effective UID, when determining what credentials to
58       use (Gerrit 7931).
59
60     * Fix possible abuse of fs mkmount.
61       Prior to 1.6.2, users could crash a client by nesting volume mounts.
62
63     * Fix fileserver memory corruption on RHEL 6
64       Prior to 1.6.2, fileservers on RHEL 6 may crash under heavy load.
65
66     * Fix client page cache corruption on Linux
67       When multiple clients read and write to a file, the reading client
68       may see first page (4096 bytes) of a file as nulls.
69
70     * Support Linux kernels up to 3.7.
71
72     * Support newer glibc versions.
73
74     * Improve client systemd unit file.
75
76     * Update Red Hat packaging.
77
78   OS X
79
80     * Fix crashes on shutdown.
81
82     * Prevent unloading the module before shutdown completes.
83
84     * Security improvement for the OpenAFS preference pane.
85
86   Solaris
87
88     * Support newer versions of the Sun Studio compiler software.
89
90     * Support compiling on newer versions of Solaris 11 and Solaris 10.
91
92
93 OpenAFS 1.6.0 (2011-08-15)
94
95   All platforms
96
97     * Substantial Rx updates to correct erroneous behavior.
98
99     * vos now properly deals with matching sites when servers are
100       multihomed.
101
102     * Don't stop Rx keepalives after an ackall is received, avoiding
103       spurious connection timeouts. (128848)
104
105     * Don't retry Rx calls on channels returning busy errors and improve
106       Rx busy call channel error handling. (128671)
107
108     * Properly enable Rx connection hard timeouts.
109
110     * Rx NAT pings are not enabled until peer has answered.
111
112     * Initialize rx_multi lock before use.
113
114     * Avoid spurious crashes when initializing in "backup" client.
115
116     * Revert UUID support in vos.
117
118     * pt_util fixed to properly create new databases.
119
120     * MTU discovery now properly shut down on call reset.
121
122     * Avoid leaking references to hosts during callback break multi-Rx
123       operations. (129376)
124
125     * xstat tools now cope with differing timeval structures between
126       endpoints.
127
128     * Numerous fixes to command argument parsing.
129
130     * Documentation updates.
131
132   All server platforms
133
134     * A file descriptor leak which could result in corrupted files in the
135       fileserver was fixed. An IMMEDIATE upgrade from previous 1.5 release
136       fileservers is recommended.
137
138     * Fix ptserver supergroups support on 64 bit platforms.
139
140     * Demand attach salvaging doesn't use freed volume pointers.
141
142     * Properly hold host lock during host enumeration in fileserver.
143
144     * Attempt to recovery more quickly from timed out volume release
145       transactions.
146
147     * Auditing now properly byte order swaps IP addresses when printing.
148
149     * vos split now has improved error handling.
150
151     * Many changes to again support Windows fileservers.
152
153     * During volume removal, data removal speed improved.
154
155     * Improve CPU utilization during volume attaching by DAFS.
156
157     * In salvager check-only mode, avoid potentially fixing a vnode.
158
159     * Fix support for large (greater than 2gb) volume special files.
160
161     * Salvager will not crash if multiple or bad volume link tables are
162       encountered.
163
164     * Avoid erroneous full dump by remembering which sites were out of
165       date at the start of the release.
166
167     * A deleted volume can now be recreated properly.
168
169     * Callbacks are again not broken during whole partition salvages.
170
171     * Positional vectored IO fixed for largefile (>2GB) capable systems.
172
173     * Fileserver per-client thread usage again properly enforced.
174
175     * Anonymous dropbox support improved and drawbacks documented.
176
177     * Demand attach: ensure vnodes are not reallocated while in use due to
178       volume bitmap errors.
179
180     * Properly support large volume numbers (larger than 2147483647).
181
182     * Allow salvager to be run manually again when DAFS is being
183       used. (129458)
184
185     * Avoid leaking references to hosts during callback break multi-Rx
186       operations. (129376)
187
188     * Demand attach: unlink fileserver state file on standalone salvage.
189
190     * Salvager tries harder to detect linktable issues.
191
192     * Demand attach: don't attach volumes with special status set.
193
194     * Avoid crashing on host table exhaustion. Instead, defer clients.
195
196   Microsoft Windows
197
198     * afs_config will not longer set the Tray Icon State in the registry
199       if the checkbox is not present in the dialog. (128591)
200
201     * AFS Explorer Shell Extension now works from folder backgrounds.
202       Overlays for mount points and symlinks are present in the dll, but
203       are not registered at present by the installers.
204
205     * Do not use RankServerInterval registry value as the value for
206       PerformanceTuningInterval.
207
208     * When the data version of a mountpoint or symlink changes, the target
209       string in the cm_scache_t object must be cleared.
210
211     * "fs checkservers" now includes vldb servers in the output and only
212       lists multi-homed servers once.  A multi-homed server that has at
213       least one up interface is no longer considered to be down.
214
215     * When asynchronously storing dirty data buffers to the file server
216       ensure that (a) the cm_scache_t object and the cm_buf_t object are
217       for the same File ID so that locking and signalling work properly;
218       and (b) if the FID no longer exists on the file server, do not
219       panic, just discard the buffer.
220
221     * When processing VNOVOL, VMOVED and VOFFLINE errors perform server
222       comparisons by UUID or address and not simply by cm_server_t
223       pointer.  Otherwise, server failover may not succeed.
224
225     * Do not preserve status information for cm_scache_t objects when the
226       issuing server is multi-homed.
227
228     * Giving up all callbacks when shutting down or suspending the machine
229       is now significantly faster due to the use of an rx_multi
230       implementation.  (This functionality is still off by default and
231       must be activated by a registry value.)
232
233     * Race conditions were possible when updating the state of the
234       cm_volume_t flags and when moving the volumes within the least
235       recently used list.
236
237     * Ensure that the lanahelper library does not perform a NCBRESET of
238       each lan adapter when enumerating the current network bindings.
239       Correcting this permits OpenAFS to work on Windows 7 when the
240       network adapter settings change.
241
242     * Fix creation of mount points and symlinks as \\AFS\xxxx
243
244     * Icon tray state now conditionally set. (128591)
245
246     * Properly create new cell mount points in freelance mode.
247
248     * Avoid recursive offline volume checks.
249
250     * Fix caching of non-existent volumes.  The test to trigger an
251       immediate CM_ERROR_NOSUCHVOLUME in cm_UpdateVolumeLocation() was
252       backwards.
253
254     * Prevent the background daemon from checking the status of
255       non-existent volumes.  cm_CheckOfflineVolumes() should skip volume
256       groups with the CM_VOLUMEFLAG_NOEXIST flag set.
257
258     * The afskfw library should return an error immediately if the
259       krb5_32.dll library cannot be loaded.  Affects afslogon.dll and
260       afscreds.exe.
261
262     * No longer depend on leashw32.dll in afskfw library.
263
264     * NPLogonNotify must provide the user password in all calls to
265       KFW_AFS_get_cred().  It cannot count on a credential cache being
266       preserved between calls.  Permits tokens to be acquired for all
267       cells listed in the TheseCells registry value for a domain.
268
269     * Improve the trace logging from NPLogonNotify().
270
271     * Avoid a race when writing the cm_scache_t mountPointString
272       when acquiring mount point or symlink target data via
273       cm_GetData().  The race could result in bogus target
274       data being cached.
275
276     * Permit the use of des-cbc-md5 and des-cbc-md4 enctypes
277       as DES keys in asetkey.exe.
278
279     * aklog supports dotted Kerberos v5 principal names.
280
281     * afskfw library always attempts afs/cell@USER-REALM
282
283     * afskfw library must test return code from krb5_cc_start_seq_get() or
284       will trigger a null pointer exception when using Heimdal.
285
286     * Lock protected fields must be 32-bit in order to avoid memory
287       overwrite races.
288
289     * Add support for NTFS symlinks.
290
291     * Handle file search requests for virtual syscall ioctl file.
292
293     * Process SyncOps properly to enforce ordered operations.
294
295     * Avoid recursing during NewServer operations.
296
297     * Correct lock acquisition order during SMB locking.
298
299     * Add shutdown message to event log.
300
301     * Check offline volume status by policy rather than on each daemon
302       thread run.
303
304     * Return error on directory object not found instead of crashing.
305
306     * Improve error message output.
307
308     * afslogin.dll can start afsd_service if it's not starting or started.
309
310     * Optimize away release lock RPCs for deleted files.
311
312     * Background Daemon will not perform operations on deleted files.
313
314     * Resort recently used directories to the top of the LRU if the
315       directory is larger than the stat cache.
316
317     * Resort deleted objects to the bottom of the LRU.
318
319     * Use interlocked operations for state and queue fields to allow safe
320       bit set and clear on multiprocessor systems.
321
322   All UNIX client platforms
323
324     * Servers now marked down when GetCapabilities returns error.
325
326     * In-use vcache count is now properly tracked.
327
328     * Check for /afs existance before starting, unless -nomount is
329       specified.
330
331     * Avoid a potential panic when using /afs/.:mount syntax.
332
333     * Avoid a panic in memcache mode due to missing CellItems file.
334
335     * FUSE client support fixed for non-/afs mounts.
336
337     * Avoid a potential deadlock (which times out) when we need to
338       allocate more callback returns and must flush some already in use.
339
340     * Deal with libcom_err conflicts with other packages using it
341       (e.g. krb5) (128640)
342
343     * Fall back to afs3-vlserver SRV record values when afs3-ptserver SRV
344       record is not available.
345
346     * Avoid holding unneeded locks when probing server capabilties.
347
348     * Do not attempt page flushes for directories.
349
350     * Rx connection reference counting is enabled.
351
352     * An Rx connection reference count leak is fixed in bulkstat.
353
354     * Handle unparsable directory objects.
355
356     * Handle Kerberos cred cache errors in aklog.
357
358   AIX
359
360     * Fix PAG usage to track by PAG identifier, not group list.
361
362   FreeBSD
363
364     * Fix socket termination on shutdown.
365
366     * Support for 7.2, 7.3, 7.4 and 8.2 included.
367
368     * References to vcaches are no longer leaked during root or reclaim.
369
370     * Remove support for "Giant" lock as we no longer need to use it.
371
372     * Don't sleep with AFS GLOCK.
373
374     * Properly enable 64 bit long long support.
375
376     * Restore support for FreeBSD 7 (128612)
377
378     * Fix locking issues at shutdown and avoid panic at shutdown due to
379       vcache flushing.
380
381     * Support for virtual network stacks.
382
383     * New RC script, updated packaging.
384
385   IRIX
386
387     * Properly create new vnodes to avoid crashing in the client.
388
389   Linux
390
391     * Support through kernel 2.6.39.  Treat Linux 3.0 as Linux 2.6 for
392       sysname purposes.
393
394     * Use rx_Readv in cache bypass to improve performance.
395
396     * Properly handle 0-length replies during cache bypass operations.
397
398     * Properly handle non-contiguous readpage cache bypass operations.
399
400     * Do proper locking when transitioning to or from cache bypass.
401
402     * Avoid extra runs of vcache freeing routine. (128756)
403
404     * Perform vcache eviction via a fast path before visiting vcaches
405       where sleep is needed.
406
407     * setpag() errors are now properly reported.
408
409     * Avoid attempting to free stat cache entries when we are below
410       user-specified number of entries in use.
411
412     * Properly track user-specified number of stat cache entries to use as
413       a desired usage target.
414
415     * Don't read pages beyond EOF in the cache. (128452)
416
417     * Various corrections and improvements to Red Hat packaging, including
418       modifying the init script to allow deferring for a new binary
419       restart and properly supporting RHEL6.
420
421     * Fix lockup in 2.6.38 due to erroneous kernel feature configure test.
422
423     * Improve RPM building tools.
424
425     * Attempt to properly handle SELinux in packaging.
426
427     * Init script properly returns status as exit code.
428
429     * RPM packaging fixes (executable libraries, no postinstall message)
430
431     * Kill i386 from RPM packaging.
432
433   MacOS
434
435     * MacOS 10.7 support.
436
437     * Properly handle setpag errors.  PAGs are not supported.
438
439     * Check for unloaded kernel extensions when decoding AFS panics.
440
441     * Disable "get tokens at login" in prefs pane if AD authentication
442       plugin is configured.
443
444     * aklog AuthorizationPlugin now provided.
445
446     * Preferences Pane behavior fixed for 1.6 series (version detection is
447       used to select default behavior).
448
449     * A potential kernel panic during bulkstat operations is
450       fixed. (128511)
451
452     * 64-bit MacOS kernel performance is greatly improved. (128934)
453
454     * Properly shut down AFS, closing the Rx socket in the upcall handler
455       to avoid attempting to process data after we can no longer do so.
456
457     * Rework logic for bulk status operations to avoid a potential hang.
458
459     * Avoid panic when doing FSEvent synthesis.
460
461     * Fix bug when using non-dynroot.
462
463     * Update Kerberos support in PreferencesPane.
464
465   NetBSD
466
467     * Updates for platform support.
468
469   OpenBSD
470
471     * Bug fixes for issues introduced previously in 1.5 series.
472
473     * Support through OpenBSD 4.8.
474
475   Solaris
476
477     * Switch to ioctl() syscall replacement for Solaris 11 since syscall
478       65 is not safe.
479
480     * Fix support for Solaris pre-10.
481
482     * Corrected Solaris 11 startup script.
483
484     * vcache mappings freed on shutdown to avoid panic.
485
486     * Properly report errors for AFS system call callers.
487
488     * Don't leave dangling function references if kernel extension fails
489       to load.
490
491     * Try harder to avoid deadlocks on file-larger-than-cache operations.
492
493     * Avoid panic on shutdown when mount failed.
494
495
496 OpenAFS 1.5.78 (2010-11-04)
497
498   All platforms
499
500     * Revisions to Rx to fix performance issues.
501
502     * Make fs getfid behave consistently across all platforms. (128372)
503
504     * Properly check IDs handed to pts when creating users or groups so
505       useful error messages can be provided. (128343)
506
507     * Correct byte order handling of port in afsconf_LookupServer for SRV
508       records.
509
510     * Force a full dump when releasing to a site which was previously
511       marked "don't use", in case the previous clone was out of date.
512
513   All server platforms
514
515     * Demand salvage of attached volumes now correctly track attachment
516       state.
517
518     * Avoid a potential crash due to failure to hold a lock when attaching
519       a volume fails.
520
521   Microsoft Windows
522
523     * Track SMB connections by SID rather than username.
524
525     * Error write attempts to known-readonly volumes earlier.
526
527     * Validate directory buffers to avoid potential crashes.
528
529     * Handle VIO errors from bulkstatus.
530
531     * Make PMTU discovery configurable and register error handlers for it.
532
533   All UNIX client platforms
534
535     * Use larger I/O sizes in memcache to improve performance.
536
537     * Avoid potential alignment issues doing I/O for pioctl calls.
538
539   FreeBSD
540
541     * Avoid panicing if the listener process is not findable.
542
543     * Avoid deadlock issues while performing lookups.
544
545   Linux
546
547     * Handle stale file handle errors for some cache partition types.
548
549     * Avoid blocking with xvcache lock when attempting to free in-use
550       vcaches.
551
552     * Build fixes for older kernels.
553
554     * Properly configure LWP to use ucontext() on platforms where it
555       should.
556
557     * Eliminate spurious errors from AFS system call returns. (126230)
558
559   MacOS
560
561     * Attempt to honor configured Kerberos defaults in Preferences Pane.
562
563
564 OpenAFS 1.5.77 (2010-09-08)
565
566   All platforms
567
568     * Rx path MTU detection will terminate detection in cases where the
569       minimum required packet size cannot be transferred.
570
571     * vos dryrun mode now shows effects for syncvldb single volume case.
572
573     * vos dryrun mode now shows "status after" for syncvldb and syncserv.
574
575   All server platforms
576
577     * RXAFS_GetStatistics64 now returns statistics properly.
578
579   Microsoft Windows
580
581     * Attempt to properly identify the local system SMB connection for
582       token tracking.
583
584     * Remap timeout and offline errors to proper NT RPC errors.
585
586     * Properly fail over to other replicas on bulkstat IO errors.
587
588     * Properly error delete-mode createfile if a file is set readonly.
589
590     * Validate directory entry buffers to avoid crashing the service.
591
592     * Log file modes properly.
593
594     * Log cell name when logging server information.
595
596   All UNIX client platforms
597
598     * cacheout program for discarding callbacks is now built.
599
600     * bulkstatus kernel locking is corrected to avoid a potential panic.
601
602   Dragonfly BSD
603
604     * userspace support update
605
606   FreeBSD
607
608     * Updated vnode locking for children returned via lookup().
609
610     * Avoid file open undercount with needed calls to
611       FakeOpen/FakeClose().
612
613     * Use vnode_pager_setsize to properly track file size during kernel
614       IO.
615
616     * Update system call installation.
617
618     * Fix shutdown of Rx kernel listener to avoid potential dereference
619       after it's gone.
620
621     * Avoid closing vnodes during vnode recycle.
622
623     * Fix bogus call to FlushVS for vnode reclaims.
624
625   Linux
626
627     * Packaging updated for current configure options and built files.
628
629     * Cache bypass now holds reference on pages during readpage.
630
631     * s390x setgroups32 patching update.
632
633   MacOS
634
635     * DNS resolver is reinitialized on IP address change. (126440)
636
637
638 OpenAFS 1.5.76 (2010-08-16)
639
640   All platforms
641
642     * Updates to build-time configuration.
643
644     * Fix XDR support in Rx to match header definition.
645
646     * vos status now shows transaction creation, not action creation.
647
648     * Rx avoids reporting loopback adapters when listing interfaces.
649
650   All server platforms
651
652     * Demand-Attach Fileserver always built and installed (dafileserver,
653       davolserver, dasalvager).
654
655     * Return VNOVOL from fileserver when a volume is deleted.
656
657     * Ignore duplicate tags during volume restore operation.
658
659     * Update inode array after salvage repairs volume.
660
661     * Zero a corrupted header in memory during salvage to avoid further
662       corruption.
663
664     * Fix NAMEI backend to allow low-numbered volumes to work properly.
665
666     * ptserver does not include cell name as part of length check for
667       names.
668
669     * Updated error messages for unblessed volumes.
670
671     * vlserver avoids buffer overflow with regex pattern
672
673     * Attach-time failures now note failures as the rest of the fileserver
674       would.
675
676     * Server argument logging will no longer overflow stack.
677
678     * Provide fast-restart-like unsafe-nosalvage option for DAFS.
679
680     * Deal with host hash collisions in the fileserver.
681
682   Microsoft Windows
683
684     * Avoid crashing when interpreting a drive letter as potentially
685       matching a cell name.
686
687     * Properly handle volume package errors.
688
689     * Allow page recycling from known-readonly content without ensuring
690       they are not dirty.
691
692     * 32 bit tools installer should not override client configuration.
693
694     * Ensure root scache item has a valid callback when use is attempted.
695
696     * Freelance directory changes now properly invalidate and replace the
697       old root object.
698
699   All UNIX client platforms
700
701     * Support disconnected reconnecting with specified UID for PAGless
702       platforms.
703
704     * Proper disconnected vnode reference tracking.
705
706     * Update server site blacklisting to not return success if nothing was
707       blacklisted.
708
709     * Avoid a panic during vcache contention due to CVInit vcache
710       racing. (127645)
711
712   FreeBSD
713
714     * Update for network stack in 8.1/9.0.
715
716   HP-UX
717
718     * Bug fixes.
719
720   Linux
721
722     * 2.6.36 support
723
724     * Disable PMTU error packet handling.
725
726     * flock() fixes.
727
728     * Debian packaging updated.
729
730     * freezer interface updates.
731
732   MacOS
733
734     * Hold references to disconnected mode written vnodes properly.
735
736   Solaris
737
738     * Handle NFS translator module references for amd64.
739
740     * INODE fileserver backend support now exists for amd64.
741
742
743 OpenAFS 1.5.75 (2010-07-07)
744
745   All platforms
746
747     * Prevent rx_rpc_stats global lock from being a bottleneck.
748
749     * Path MTU discovery is now provided to allow traffic to pass networks
750       with sub-1500 byte MTUs and poor fragment handling.
751
752     * Further reduce Rx NAT ping transmission when enabled.
753
754     * Update Kerberos 5-based token handling in rxkad from upstream
755       Heimdal.  (127554)
756
757     * Update version numbers emitted during build to reflect what is
758       actually being built.
759
760     * Add "-human" switch for human-readable units in fs diskfree and
761       listquota. (124529)
762
763     * vos provides reasons for locked volumes when known.
764
765     * Do not count retransmission and ping acks as non-idle for Rx
766       connections.
767
768     * Rx: provide service-specific data getter and setter routines.
769
770     * Update build-time Kerberos detection.
771
772     * Updated userspace AFS client.
773
774     * Beginning of a modernized test suite.
775
776     * Additional documentation.
777
778     * Updated documentation, notably the Administrators Guide.
779
780     * Substantial code cleanup.
781
782   All server platforms
783
784     * Update handling of vnode allocation failures.
785
786     * DAFS: allow salvaging volumes not known to the fileserver, to allow
787       cleanup of data not attached to a current volume.
788
789     * Properly handle volumes slated for destruction.
790
791     * Handle volumes with many files properly.
792
793     * Force core file generation in bosserver by overriding default
794       resource limits when possible.
795
796     * Update vlclient and vldb_check.
797
798     * Avoid potentially corrupting a volume on creation if files are left
799       from previous failed cleanup.
800
801     * Note volume changed during salvage as needed.
802
803     * DAFS: do not assume invalid addresses are in fileserver address hash
804       table.
805
806     * Avoid tying up fileserver threads with volumes that are being taken
807       offline.
808
809     * Do not set inUse on volumes for non-DAFS other than in fileserver.
810
811     * Break origin's callback on target of rename operation.
812
813     * Avoid unneeded parent directory link updates during some rename
814       operations.
815
816     * Do not open /dev/console for writing in the fileserver.
817
818     * DAFS: avoid spurious restarts when binary restarts are configured.
819
820     * Avoid spurious and unneeded calls to sync(), which can slow down the
821       fileserver.
822
823   Microsoft Windows
824
825     * Revised SMB QuerySecurityInfo to address issues caused by MS10-020
826       (http://support.microsoft.com/kb/980232)
827
828     * Prevent use of the AFSCache file contents if mapped to a new
829       address.
830
831     * Make fs newcell include behavior compatible with the non-Windows
832       version.
833
834     * Provide a registry option (FreelanceImportCellServDB) to pre-create
835       mount points in the AFS root for all cells in CellServDB.
836
837     * Fix a memory leak in the cm_FreeServerList() routine.
838
839     * Reduce privilege when reading registry CellServDB.
840
841     * Add support for RPC Pipe Service NetWkstaGetInfo levels needed for
842       Windows 7.
843
844     * Prevent overflow when computing quota percentage in Explorer Shell.
845       (126846)
846
847     * Generate meaningful errors for ACL operations on freelance AFS root.
848
849     * Fix error handling on InlineBulkStatus RPCs.
850
851     * Show configuration pages for all types of MSI installations.
852
853     * Improve freemount AFS root directory handling and operations.
854
855     * Properly validate GetVolumeStatus pioctl responses.
856
857     * Commit file length changes and dirty buffers when flushing a file.
858
859   All UNIX client platforms
860
861     * Update version of files for disk cache.
862
863     * Do not call afs_FlushVCBs with xvcache lock held, to improve
864       parallelization.
865
866     * Add mariner log messages for creating and removing files.
867
868     * Don't hold xvcache lock while creating symlinks, to improve
869       parallelization.
870
871     * Provide -dynroot-sparse mode to not show all cells in CellServDB in
872       dynroot mode.
873
874     * Avoid a potential crash in aklog in linked cell handling.
875
876     * Log MTU-caused packet retransmission.
877
878     * Prevent crashes caused be fs checkservers while cache is being set
879       up.
880
881     * fs getserverprefs now has a buffer large enough for the default
882       CellServDB.
883
884     * Report server address when logging warnings.
885
886     * Avoid panic in GetCapabilities when cell is not known.
887
888     * Lock process name and id for advisory lock warnings when possible.
889
890     * Handle need for allocating additional Rx packets.
891
892     * Properly handle errors from InlineBulkStatus operations.
893
894     * Fix errors returned from fcntl() on readonly files locked for write.
895
896     * Flush pending changes to the server on LOCK_EX unlock.
897
898     * Reflect length changes as a result of callbacks even when file is
899       open for write.
900
901     * Avoid hanging due to error exit when attempting to store a large
902       file to a non-largefile fileserver.
903
904     * Recover from afs_GetVolSlot errors.
905
906   FreeBSD
907
908     * Bugfixes for kernel VFS and network routines.
909
910   IRIX
911
912     * Provide makesname().
913
914   Linux
915
916     * Avoid syscall probes when keyrings are present, by default. (125215)
917
918     * Remove "Big Kernel Lock" from VFS operations.
919
920     * Use filehandles for all Linux 2.6 versions to avoid need for matched
921       afsd. (127530)
922
923     * Updated RPM packaging.
924
925     * Fix dkms configuration provided with RPMs.
926
927     * Hold reference on pages during background I/O for cache bypass.
928
929     * Fix cache bypass handling of non-largefile fileservers.
930
931     * Protect truncate_inode_pages mappings with mutex or semaphore as
932       needed.
933
934     * Fix pagevec use in cache bypass. (127505)
935
936     * Updates for 2.6.35
937
938   MacOS
939
940     * Improve launchd configuration.
941
942     * Avoid hanging on recursive cache file lock acquisition when user
943       notification is enabled.
944
945     * Fix and re-enable bulkstat mode.
946
947   OpenBSD
948
949     * Build updates.
950
951   Solaris
952
953     * Precluding unmount while AFS is busy.
954
955     * Avoid deadlocking when releasing the VFS object.
956
957     * Stop network interface poller in kernel on AFS shutdown.
958
959     * Avoid issues with lookups on empty directory names. (127356)
960
961
962 OpenAFS 1.5.74 (2010-04-22)
963
964   All platforms
965
966     * Add "vos setaddrs" command.
967
968     * Rx library lock contention avoidance between rx_NewCall and
969       rx_EndCall.
970
971     * Rx library races due to inconsistent use of rx_connection
972       conn_data_lock to protect the flags field.
973
974     * Rx library inconsistent use of RX_CALL_TQ_WAIT which could result in
975       deadlocks.
976
977     * Rx library must signal transmit queue waiters when flushing.
978
979     * afsmonitor shows busy counts now.
980
981     * afsmonitor displays xstat callback statistics.
982
983     * Provide expandgroups for pts mem on a supergroups server.
984
985     * Provide supergroup option to liste nested groups during pts mem.
986
987   All server platforms
988
989     * Avoid volume lock contention during DAFS startup.
990
991   Microsoft Windows
992
993     * Avoid a race when updating cell vldb server lists that can result in
994       a crash.
995
996     * Avoid a deadlock when managing CM_SCACHESYNC_STOREDATA state
997       operations for directory objects.
998
999     * Add new Windows Application Event log messages for VBUSY,
1000       VRESTARTING, ALL_BUSY, ALL_OFFLINE, and ALL_DOWN.
1001
1002     * Reduce lock contention by waiting for cm_buf_t I/O operations.
1003
1004     * Split the cm_buf_t flags field to separate the flags that are
1005       protected by the cm_buf_t mutex from those protected by the
1006       buf_globalLock.
1007
1008     * In cm_UpdateVolumeLocation, avoid searching for a ".readonly" volume
1009       on a numeric volume name.
1010
1011     * File buffer allocations whose offsets are beyond server EOF should
1012       be locally allocated and zero filled.  The file server should not be
1013       issued a FetchData rpc which is guaranteed to fail.
1014
1015     * Enable integrated logon to work with Windows 7/2008 when user logons
1016       are performed with a non-Domain Kerberos principal.
1017
1018     * Add Protection Error messages to aklog output.
1019
1020   All UNIX client platforms
1021
1022     * Provide a FUSE-interfacing userspace afs client.
1023
1024     * Updates to libuafs userspace cache manager.
1025
1026     * Probe servers using GetCapabilities instead of GetTime, thus
1027       requiring fewer RPCs.
1028
1029     * Fix DNS SRV record handling for cell lookup.
1030
1031   FreeBSD
1032
1033     * Fix sleep/wakeup routines.
1034
1035     * Update for 8.0 release.
1036
1037   Linux
1038
1039     * Handle high memory addresses correctly.
1040
1041   MacOS
1042
1043     * Make 32 bit AFS syscalls work again.
1044
1045     * Work around finder "Duplicate" failure (caused by setting modes on
1046       symlinks).
1047
1048     * Disable bulkstat again (will be re-enabled at or before .75).
1049
1050     * Provide symlink type hints during readdir.
1051
1052
1053 OpenAFS 1.5.73 (2010-03-24)
1054
1055   All platforms
1056
1057     * NAT keepalive support at Rx level.
1058
1059     * Corrected SRV record support for cell name canonicalization.
1060
1061   All server platforms
1062
1063     * Fix volume callback notification to not notify unaffected clients.
1064       (126497)
1065
1066     * Allow root directory recreation by salvager. (94658)
1067
1068     * Numerous DAFS fixes.
1069
1070     * Improvements to callback table overflow handling. (126451)
1071
1072     * bosserver now shuts down cleanly on SIGTERM.
1073
1074   Microsoft Windows
1075
1076     * Prevent the Explorer Shell extension from crashing if symlink
1077       creation failed.  (126406)
1078
1079     * A Rx level NAT ping has been implemented. A registry value enables.
1080
1081     * Adds krb5 error message translation to aklog, afscreds,
1082       afslogon.dll, the network identity manager afs provider and
1083       translate_et.
1084
1085     * Default mode bit settings for file and directory creation are now
1086       provided, and can be configured.
1087
1088     * An SMB request trace facility is provided and can be enabled for
1089       debugging.
1090
1091   All UNIX client platforms
1092
1093     * Rx idle deadtime does not stop file writes.
1094
1095     * Disconnected AFS no longer has a race condition during remove ops.
1096
1097     * Fakestat avoids a condition which could cause it to block on network
1098       activity.
1099
1100     * Several fixes to handle interruptions in vos operations. (33360,
1101       125535)
1102
1103     * Allow more sysnames in a sysname list.
1104
1105     * Attempt to enforce timeouts on AFSDB lookups.
1106
1107   AIX
1108
1109     * Clean up properly on mount failure.
1110
1111     * Add entry to /etc/vfs to allow umount to work.
1112
1113   Linux
1114
1115     * Several issues to deal with older kernels.
1116
1117     * Avoid leaking the global lock in the /proc cellservdb code.
1118
1119     * Keyring destruction now cleans up all tokens.
1120
1121     * Keyring quotas are not enforced against root.
1122
1123   MacOS
1124
1125     * Some FSEvents hinting for authentication events now done. (23781)
1126
1127     * Update uninstaller. (125634)
1128
1129     * Rewrite afssettings and fstab code to avoid licensing issue with
1130       APSL.
1131
1132     * Growl client for user monitoring of AFS events included.
1133
1134     * Properly support insert-only dropboxes.
1135
1136     * Add bulkstat support.
1137
1138     * Include support for moving in Finder across mount points.
1139
1140     * Preferences Pane includes support for Kerberos 5 ticket renewal.
1141
1142
1143 OpenAFS 1.5.72 (2010-02-15)
1144
1145   All platforms
1146
1147     * Provide internationalization support in com_err.
1148
1149     * Fix array length checking to avoid crashes when checking for a
1150       volume type based on name in vos.
1151
1152   All server platforms
1153
1154     * Provide backward compatible "-f" flag to salvager for force mode.
1155
1156   Microsoft Windows
1157
1158     * Restore use of DNS AFSDB and SRV records by kaserver clients.
1159
1160   All UNIX client platforms
1161
1162     * Fix client cache file truncation to not lose chunks when truncating
1163       a large file.
1164
1165     * Ensure a cache writeback hook is installed in the client (bug from
1166       1.5.71).
1167
1168     * Avoid spurious free memory warnings during clean shutdown.
1169
1170     * Fakestat mode avoids AFSDB lookups.
1171
1172     * "fs storebehind" now correctly reports errors on readonly volumes.
1173
1174     * Additional documentation for "fs getcacheparms"
1175
1176     * Forced new uuid generation with "fs uuid -generate" now works
1177       enforced permission correctly.
1178
1179   MacOS
1180
1181     * Add optimized Rx event handler in kernel.
1182
1183     * Installer now allows installing an older version.
1184
1185     * Panic decoder can now deal with MacOS 10.5 again.
1186
1187     * MacOS ._ files are now correctly not looked up as cellnames.
1188
1189   Linux
1190
1191     * To deal with SELinux file labeling, try cache accesses with current
1192       credentials in event of failure.
1193
1194     * Rx XDR encoding bug on i386 Linux is fixed (bug introduced in
1195       1.5.71).
1196
1197   IRIX
1198
1199     * Code compilation fixes.
1200
1201   OpenBSD
1202
1203     * Update for OpenBSD 4.6.
1204
1205
1206 OpenAFS 1.5.69 (2010-01-19)
1207
1208   All platforms
1209
1210     * Configuration of BOSserver no longer defaults to weekly restarts
1211       enabled.
1212
1213     * Provide BOS restricted mode by default.
1214
1215     * Add support for "vos endtrans" command.
1216
1217     * Default to providing full output from vos listvol.
1218
1219     * Correct additional-address tracking in the fileserver.
1220
1221     * Improve Rx performance by not unnecessarily dropping and reacquiring
1222       call locks in read and write processes.
1223
1224     * Avoid crashes when monitoring volserver transactions across
1225       potential transaction garbage collection.
1226
1227     * Numerous warning fixes.
1228
1229   All server platforms
1230
1231     * Avoid saving fileserver state in demand attach fileserver when
1232       panicing.
1233
1234     * Demand attach fileserver allows other callers to schedule salvages.
1235
1236     * Demand attach "bos salvage" now works correctly with restricted
1237       mode.
1238
1239   Microsoft Windows:
1240
1241     * Numerous changes to the client-internal btree directory handling to
1242       prevent errors.
1243
1244     * fs examine reports owner and group ids as signed values (PTS groups
1245       are negative).
1246
1247     * Preclude corruption due to races writing to smb buffers.
1248
1249     * Allow MTU settings in registry to be used.
1250
1251     * Apply MTU to both send and receive sizes.
1252
1253   All UNIX client platforms
1254
1255     * Avoid double-freeing Rx call structure if reading a response from
1256       the file server results in a short read.
1257
1258     * Handle negative lengths in FetchStatus results correctly.
1259
1260     * Properly clean up allocated memory at shutdown.
1261
1262     * Default to AFSDB compiled into the cache manager.
1263
1264     * Avoid inadvertant disclosure of stat() information to clients not so
1265       entitled.
1266
1267     * Correct a bug with AFSDB lookups introduced with SRV record support.
1268
1269   MacOS
1270
1271     * Install kernel panic processing tool in /Library/OpenAFS/Tools.
1272
1273     * Include debugging symbols for kernel extension in additional package.
1274
1275     * Support "Application Firewall" users.
1276
1277     * Avoid ._cellname AFSDB lookups.
1278
1279     * Compile preferences pane as a universal binary.
1280
1281   Linux
1282
1283     * Use splice to speed up storing files.
1284
1285     * When using memcache, avoid duplicating work in readpages.
1286
1287     * Use dget_parent to safely find an inode's parent.
1288
1289     * Disable access time updates in our superblock.
1290
1291     * Avoid crashing doing writeback if no credentials were stashed at
1292       file open.
1293
1294     * Simplify keyring support.
1295
1296     * Properly clean up vcache in event of failed mount.
1297
1298   FreeBSD
1299
1300     * Update for current FreeBSD 8.
1301
1302   Solaris
1303
1304     * Abstractly manipulate groups as now required.
1305
1306     * Abstractly access time instead of using lbolt directly.
1307
1308
1309 OpenAFS 1.5.68 (2009-12-08)
1310
1311   All platforms
1312
1313     * aklog now attempts to convert non-AFS errors to human-readable
1314       strings.
1315
1316     * Make stack not executable when compiling assembler source with GCC.
1317
1318     * Numerous source warning cleanups and code reorganization.
1319
1320   All server platforms
1321
1322     * Compute midnight for volume statistics calculation from local time.
1323
1324     * Salvager now orphans duplicate special inodes when running to allow
1325       recovery in event of a problem, instead of simply ignoring the
1326       issue.
1327
1328     * Support to ensure a server panic attempt leaves a core and thus
1329       restarts in a timely manner, rather than potentially hanging. Use
1330       panic to attempt cleanup before leaving a core when possible.
1331
1332     * Volume sync data reported during bulkstatus is now set correctly.
1333
1334     * Provide better tuning for fileserver file descriptor caching.
1335
1336     * Allow more than 128 threads in fileserver by modifying host
1337       structure in-use tracking.
1338
1339     * Avoid crashes getting volume server status during transaction
1340       cleanup.
1341
1342     * Improved logging of offline volume conditions.
1343
1344     * Correct volume statistics when cloning a volume.
1345
1346     * Avoid referencing host structures in the fileserver which are marked
1347       for deletion.
1348
1349     * Demand attach fileserver corrections to avoid coring during an
1350       aborted startup.
1351
1352     * host array bounds checking corrections to avoid buffer overflow.
1353
1354     * Handle special inodes correctly when promoting an inode fileserver
1355       readonly volume to read-write.
1356
1357   Microsoft Windows
1358
1359     * Set the DOS Readonly attribute on a file/directory whenever the unix
1360       mode combined with the mask 0200 is true.  Previously there was a
1361       discrepency between the mask used for testing for readonly behavior
1362       and that used for setting the attribute.
1363
1364     * Disable AFSVolSync based .readonly "whole-volume callback" support
1365       because the all file servers prior to 1.5.67 (and perhaps 1.4.12) do
1366       not properly assign a value to the AFSVolSync structure in bulk
1367       status RPC responses.
1368
1369     * Improve the error output from aklog to output the value from krb5
1370       error_message() if the afs_com_err output indicates an unknown
1371       value.
1372
1373     * Convert VBUSY and VRESTARTING to CM_ERROR_ALLBUSY and do not permit
1374       them to be exposed to the smb redirector.
1375
1376     * Convert STATUS_TIMEOUT responses to STATUS_IO_TIMEOUT to avoid
1377       confusion within the smb redirector.
1378
1379     * Fix the byte order assigned to port numbers associated with AFSDB
1380       record lookups.  They must be network byte order not host byte
1381       order.
1382
1383     * Add dynamic server ranking based on RPC round trip time
1384       measurements.
1385
1386   All UNIX client platforms
1387
1388     * Additional shutdown-time memory leaks removed.
1389
1390     * Improved logging of resource contention.
1391
1392     * Provide dumping for Rx debug packet tracking support in source.
1393
1394     * Update afscp test client to build, and provide an unlock client.
1395
1396     * Client buffers for directory parsing can now be allocated beyond the
1397       fixed set formerly provided.
1398
1399     * Work around race condition when manipulating read-only volume
1400       callbacks.
1401
1402     * Bugfixes to get PAG value pioctl.
1403
1404     * Bugfixes to SRV record support.
1405
1406   Linux
1407
1408     * Path MTU tracking code cleanup.
1409
1410     * Avoid an oops due to racing with vcache recycling thread.
1411
1412     * Changes to keyring PAG handling: for sufficiently new kernels, use
1413       only keyring-based PAGs, and disable group PAGs entirely.
1414
1415     * Updates to the kernel page cache interface: writing pages will now
1416       not spuriously leak page locks, and will avoid requiring duplicate
1417       work.
1418
1419     * Credential references are now tracked using native atomic counters.
1420
1421     * Kernel mutex/semaphore lock ordering fix to avoid deadlocks.
1422
1423     * Manipulate disk cache with credentials used to initialize it, to
1424       avoid security issues.
1425
1426   MacOS
1427
1428     * Fix fstrace message catalog location.
1429
1430     * Fix kernel fstrace logging.
1431
1432
1433 OpenAFS 1.5.66 (2009-10-25)
1434
1435   All platforms
1436
1437     * Avoid calling exit() in library code.
1438
1439     * Add rx window size and peer timeout tuning APIs.
1440
1441     * Correct rx peer timeout handling to disallow 0ms timeouts.
1442
1443     * Correct calculation of rx RTT by disregarding retransmitted packets.
1444
1445     * vos manpages updated to reflect changes in recent versions.
1446
1447     * GNU-style long options (e.g. --cell) are now supported in all
1448       commands.
1449
1450     * fs listacl can now print a command to recreate the current ACL.
1451
1452   All server platforms
1453
1454     * Fix a race on transaction objects in the volserver which can cause a
1455       crash.
1456
1457     * Avoid destroying and setting to NULL the callback connection when it
1458       could still be being used.
1459
1460     * Correct unlink handling in salvager.
1461
1462     * Improve error messages due to I/O errors in the volserver.
1463
1464     * Correct an issue which caused converted RO to RW volumes on namei
1465       fileservers to not come online immediately.
1466
1467   Microsoft Windows
1468
1469     * Official support for Windows 7 and Server 2008 R2.
1470
1471     * Prevent a file server bug (FetchData returning an invalid length
1472       instead of zero) from causing an "unexpected network error" when
1473       writing to files.
1474
1475     * Promote DNS SRV records as superior to DNS AFSDB records.  Support
1476       arbitrary port numbers for vldb servers.
1477
1478     * Add AFSVolSync based .readonly "whole-volume callback" support.
1479       With this functionality, multiple objects from a .readonly volume
1480       can have their status validated by issuing a single
1481       RXAFS_FetchStatus RPC.
1482
1483     * Remove drive mapping functionality and service start/stop from
1484       afscreds.exe.
1485
1486     * Remove drive mapping functionality from afs_config.exe.
1487
1488     * Use {HKLM,HKCU}\SOFTWARE\OpenAFS\Client DWORD "ShowMountTab" to
1489       restore access to drive mapping functionality in afscreds.exe and
1490       afs_config.exe.
1491
1492     * Adjust SMB error return codes to avoid returning STATUS_TIMEOUT
1493       which results in the SMB redirector disconnecting.
1494
1495     * Network Identity Manager OpenAFS Provider now provides its own "AFS
1496       lock" notification icon to report the status of "have tokens, have
1497       no tokens, service not started, service started but inaccessible".
1498       Hovering over the icon lists the cells for which tokens exist (if
1499       any) and the OpenAFS version number.  Double-clicking executes the
1500       Network Identity Manager default action.
1501
1502     * Prevent pioctl calls from retrying indefinitely when a sharing
1503       violation error occurs.
1504
1505   All UNIX client platforms
1506
1507     * Correct a condition which could discard the error from initializing
1508       a fetch request.
1509
1510     * Avoid using invalid references to afs_Conn connection structures,
1511       and thus potentially producing invalid data when a retry is needed.
1512
1513     * SRV records are now supported for discovering AFS servers.
1514
1515   Linux
1516
1517     * Correct writepage behavior.
1518
1519     * Fix error code handling in the writepage code.
1520
1521     * Avoid leaking page locks, which could potentially hang a machine.
1522
1523   MacOS X
1524
1525     * Preferences Pane improvements.
1526
1527   HP-UX
1528
1529     * Avoiding attempting to handle critical signals in servers, so that
1530       core file handling works correctly.
1531
1532
1533 OpenAFS 1.5.65 (2009-10-06)
1534
1535   All platforms
1536
1537     * Code compilation warning fixes, to enable better finding and
1538       tracking bugs.
1539
1540     * Provide configure-time switch to enable code warning compilation.
1541
1542   All server platforms
1543
1544     * Demand-attach fileserver now makes volume LRU list operations
1545       exclusive operations to avoid races during adding to the list.
1546
1547     * Fileservers now avoid potential "negative length" fetches.
1548
1549     * A leak in host tracking objects in the fileserver has been fixed.
1550
1551     * Salvager now unlinks all files by full path, to deal with the change
1552       to not chdir for core file tracking.
1553
1554     * Salvager avoids asserting if the volume header is unreadable.
1555
1556     * Demand-attach fileserver puts back volume references from fssync
1557       handlers when done.
1558
1559   Microsoft Windows
1560
1561     * Improved service response to suspend and shutdown event
1562       notifications.
1563
1564     * Avoid a bug in the file server that can result in an invalid length
1565       being returned as part of a fetch data response if the client
1566       attempts to read beyond the length of the file.
1567
1568     * Do not publish a default stream object for directories and mount
1569       point objects.  This was impacting the ability of some Windows XP
1570       systems to save roaming profiles.
1571
1572   All UNIX client platforms
1573
1574     * A bug which could cause erroneous handling of lengths on data reads
1575       has been fixed.
1576
1577     * A bug where erroneous length returns from the fileserver could
1578       result in a false error has been fixed.
1579
1580   Linux
1581
1582     * Background page copies are now supported for enhanced disk cache
1583       read performance.
1584
1585     * Blocking readahead is supported in readpages() to reduce overhead.
1586
1587     * Use readpage() instead of read() to access cache data to avail disk
1588       cache users of the kernel backing cache for improved performance.
1589
1590     * Minimize credential handling for improved performance.
1591
1592   MacOS X
1593
1594     * Preferences Pane cleanup.
1595
1596   Solaris
1597
1598     * Provide a fs_pathconf method with sensible defaults.
1599
1600     * Provide a _PC_FILESIZEBITS method to fix some NFS translator
1601       consumers.
1602
1603
1604 OpenAFS 1.5.64 (2009-09-22)
1605
1606   All server platforms
1607
1608     * The demand attach fileserver now puts back volume references gotten
1609       via the fssync interface.
1610
1611     * The demand attach fileserver had a structure reference error, which
1612       has been correected.
1613
1614   Microsoft Windows
1615
1616     * Restores Windows 2000 compatibility.
1617
1618     * Fixes a data consistency error between the output of NetWkstaGetInfo
1619       and NetServerGetInfo RPCs, specify the Lan workstation group name
1620       "AFS", and report server name as "AFS" instead of "\\AFS" when the
1621       caller asks for "\\AFS".
1622
1623     * Enables executables to be run from \\AFS on Windows 7.  Returns
1624       "Name not found" instead of "File not found" when a directory or
1625       file name cannot be found.  This avoids loader errors when system
1626       dlls cannot be located in the executable directory.
1627
1628     * Prevents cache manager from marking the file server "down" when the
1629       data returned in response to either RXAFS_FetchData64 or
1630       RXAFS_StoreData64 is invalid.
1631
1632     * Adds pioctl data validation to the AFS Explorer Shell extension.
1633
1634   All UNIX client platforms
1635
1636     * A bug which could cause a kernel panic in 1.5.63 has been corrected.
1637       This would manifest as a GetDCache panic or oops.
1638
1639   Linux
1640
1641     * aklog -setpag works again with recent kernels when keyring is in
1642       use.
1643
1644   MacOS
1645
1646     * When Fast User Switch is in use, AFS login is now handled correctly
1647       by the integration tool included with the preferences pane.
1648
1649     * Several packaging bugs have been corrected.
1650
1651
1652 OpenAFS 1.5.63 (2009-09-11)
1653
1654   All platforms
1655
1656     * The restorevol command is now documented and installed as a user
1657       command.
1658
1659     * The uss command now properly translates vldb entries to its expected
1660       format when handling them in all cases.
1661
1662     * Documentation now refers to Kerberos instead of kaserver.
1663
1664   All server platforms
1665
1666     * bosserver now handles BosConfig.new when restarting, allowing
1667       configuration to be replaced at restart time rather than with bos
1668       delete and bos create.  Documentation is updated to reflect this.
1669
1670     * The demand attach fileservice not longer potentially hangs trying to
1671       terminate demand-salvages which have already exited.
1672
1673     * The demand attach fileservice has been modified to avoid spurious
1674       'SYNC_putRes: write failed' warnings when some protocol messages
1675       cannot be acknowledged due to the sender terminating the connection.
1676
1677     * In the event of failure to contact the vlserver or ptserver, the
1678       fileserver will not exit and trigger a forced salvage. It will
1679       continue to try in the background to contact the needed services.
1680
1681     * The salvager can now repair certain cases of a damamged vnode index.
1682
1683     * The accessDate metadata for a volume is now updated correctly.
1684
1685   Microsoft Windows
1686
1687     * CRITICAL: Some applications for example those based on Cygwin were
1688       unable to access data stored in the AFS name space.  Explorer Shell
1689       also experienced inconsistent behavior.  This is fixed.
1690
1691     * CRITICAL: Multiple AFS pioctl requests issued nearly simultaneously
1692       by applications could result in pioctl responses being received by
1693       the wrong requester.  This in turn could result in application
1694       crashes.  symlink.exe, fs.exe, afslogon.dll, afscreds.exe, and the
1695       netidmgr afscred.dll plugin were all affected.
1696
1697     * Some XP machines running 1.5.62 had trouble saving roaming profile
1698       data.  This is fixed.
1699
1700     * Integrated Logon (afslogon.dll) did not function with domain
1701       specific configurations.
1702
1703     * Ensure that access denied and over quota errors experienced while
1704       storing data to the file server do not result in on-going retry
1705       attempts.
1706
1707   All UNIX client platforms
1708
1709     * Except on Solaris and AIX, the compiler may now be overriden at
1710       configure time by setting the CC environment variable.
1711
1712     * afsd now properly deals with large cache partitions.
1713
1714   FreeBSD
1715
1716     * Build shared libafsauthent and libafsrpc.
1717
1718   Linux
1719
1720     * Kernel module DKMS support now installs an unstripped module to
1721       allow debugging information to be collected.
1722
1723   MacOS
1724
1725     * Preferences pane properly updates token information.
1726
1727   MacOS 10.6
1728
1729     * klog will now properly handle passwords of 8 or fewer characters
1730       with an AFS string to key on hosts able to run 64 bit binaries.
1731
1732     * A panic at AFS shutdown due to "NO PCB" on a udp_lock has been
1733       addressed.
1734
1735     * The panic decoder script included in the source now properly handles
1736       32 and 64 bit panics.
1737
1738   NetBSD
1739
1740     * Avoid defining AFS_KERBEROS_ENV globally as it creates a circular
1741       dependency.
1742
1743     * Build shared libafsauthent and libafsrpc.
1744
1745   OpenBSD
1746
1747     * Build shared libafsauthent and libafsrpc.
1748
1749
1750 OpenAFS 1.5.62 (2009-08-28)
1751
1752   All platforms
1753
1754     * Numerous invisible changes to improve code maintainability,
1755       portability and enhanceability.
1756
1757   Microsoft Windows
1758
1759     * CRITICAL: Fixes two errors that can result in data loss when storing
1760       data to the file server.
1761       1. Failure to Store Portions of Unaligned Writes
1762       2. Failure to Store Data to File Servers Lacking Large File Support
1763       Read the announcement for more details:
1764         http://www.openafs.org/pipermail/openafs-announce/2009/000305.html
1765
1766     * CRITICAL: The cache manager daemon thread could terminate when the
1767       machine enters suspend mode.  This daemon thread performs the
1768       background check of down servers, offline volumes, callback
1769       expirations, etc.
1770
1771     * CRITICAL: Integrated Logon (afslogon.dll) was terminating
1772       unexpectedly.  Error checking has been improved and NULL pointer
1773       dereferences after Lsa API calls fail have been eliminated.
1774
1775     * For the first time, the OpenAFS SMB Server supports the DCE RPC
1776       services SRVSVC and WKSSVC.  Browsing \\AFS with the Explorer Shell
1777       or NET VIEW will now be faster and provide additional functionality.
1778       No longer will cell names longer than 12 characters be truncated.
1779
1780     * Improvements to DFS Referral request processing have been
1781       implemented.
1782
1783     * Unnecessary DNS lookups of share names are avoided improving
1784       performance.
1785
1786   All UNIX client platforms
1787
1788     * Non-Kerberos PAM modules work correctly again.
1789
1790   MacOS X
1791
1792     * MacOS 10.6 (Snowleopard) is now supported, both 32 and 64 bit mode.
1793
1794     * Updates to the AFSCommander preferences pane.
1795
1796     * Installer now permits cell names with dashes.
1797
1798
1799 OpenAFS 1.5.61 (2009-08-06)
1800
1801   All platforms
1802
1803     * Correct another race condition in the Rx library that could result
1804       in an unexpected panic while freeing the Rx call iovq.
1805
1806     * rx packet resend and data packets sent counts were incorrect.
1807
1808     * fs setquota, fs setcachesize, vos setfields, and vos create now
1809       accept human readable orders of magnitude. (K, M, G)
1810
1811     * fs listquota fixed to permit large quota sizes to be displayed.
1812
1813     * Correct documentation of bosserver permissions requirements.
1814
1815     * Modify vlserver to avoid potentially corrupting the database through
1816       volume id reuse.
1817
1818     * Generalized support for fast Rx timeout due to network
1819       down/unreachable.
1820
1821   All server platforms
1822
1823     * Allow audit logs to be sent via sys5 IPC message queues instead of
1824       logged directly.
1825
1826   Microsoft Windows
1827
1828     * If a file server becomes inaccessible while the cache manager has
1829       dirty buffers to write, the afsd_service buf_IncrSync thread can
1830       attempt to use 100% of the cpu.
1831
1832     * Fix "fs newcell" which was broken in 1.5.60.
1833
1834     * Do not attempt to synchronize dirty buffers if the associated volume
1835       is known to be unavailable.
1836
1837     * Modify behavior of a Freelance mountpoint target that does not
1838       specify a cell.  Instead of assuming the target volume is in the
1839       Freelance.Local cell, use the workstation "Cell" specified in the
1840       registry. A mountpoint target of "#root.cell." will now mean the
1841       root.cell volume in the workstation cell for the current session.
1842       If the workstation cell changes from "athena.mit.edu" to
1843       "andrew.cmu.edu", the referenced volume will also change without
1844       requiring that the mount point targets be altered.
1845
1846     * Add cm_FindServerByUuid().  Re-implement RXAFS_InitCallBackState3()
1847       to permit the server Uuid to be used to lookup the server object and
1848       from that determine the cell.  This permits callbacks that are
1849       received from alternate addresses to be processed with a known
1850       server object.  Previously a request from an unknown server would
1851       clear all callbacks from all cells.
1852
1853     * Fix a bug that prevented optimal performance when using a non-zero
1854       value for 'daemonCheckVolCBInterval'.  As a reminder, when
1855       "daemonCheckVolCBInterval" is set to a non-zero value, all .readonly
1856       volume callbacks are automatically renewed 90 minutes before their
1857       expiration.
1858
1859     * Fix automatic ranking of vldb servers whose values are obtained from
1860       the CellServDB file.
1861
1862     * Add failover for RX CALL TIMEOUT errors when the volume is readonly
1863       or the call is to a vldb server.
1864
1865     * Add registry based cell search functionality to NetIdMgr,
1866       afs_config.exe, and klog.exe.
1867
1868     * afsconf_GetCellInfo() has been modified to perform gethostbyname()
1869       lookups on the host names in the CellServDB instead of using the
1870       specified IP addresses.  This provides aklog, pts, vos, etc. the
1871       same CellServDB behavior that the Windows Cache Manager uses.
1872
1873     * When updating the stat cache entry callback of a .readonly object
1874       from the volume group object, update the file server reference to
1875       ensure it matches the most update to date callback.
1876
1877     * Add proper support for processing callbacks from multi-homed file
1878       servers.  Instead of comparing servers by cm_server_t pointer,
1879       compare them by UUID when the UUID is known.
1880
1881     * During a shutdown short circuit the offline volume check daemon
1882       functionality.
1883
1884     * Return the error code of RXAFS_FetchData / RXAFS_StoreData in
1885       preference to an error code reported by rx_EndCall.
1886
1887     * Add "PerFileAccessCheck" registry value to permit testing against
1888       experimental file servers that include per-file acl support.  This
1889       value is intentionally undocumented.  It is not to be used by
1890       production environment deployments.
1891
1892     * Fix a bug introduced in 1.5.60 that prevents the afs netidmgr
1893       provider from obtaining tokens when referrals are in play.
1894
1895     * Add "fs chown" and "fs chgrp" commands to permit the owner and group
1896       of objects stored in AFS to be set from Windows.
1897
1898     * Avoid performing background daemon operations when the machine is
1899       going into suspend mode.
1900
1901     * Perform offline volume checks in most recently used order.
1902
1903     * Prevent crash when a data version for a cache object goes backwards.
1904
1905     * Multi-thread safe library versions are now being generated and used.
1906       mtafsubik.lib, mtafsutil.lib, mtafsvldb.lib, mtafsvol.lib.
1907
1908     * Microsoft SMB Redirector (mrxsmb.sys) support for
1909       ExtendedSessTimeout values are now available on XP through Windows
1910       7.  Add functionality to autodetect if such support is present on
1911       the machine.  If so, configure it if necessary and dynamically
1912       adjust the AFS Rx timeout values accordingly.
1913
1914   All UNIX client platforms
1915
1916     * Fix out-of-tree source builds.
1917
1918   MacOS
1919
1920     * GUI installer now asks for local cell information.
1921
1922     * AFS Commander preferences pane is now installed by default.
1923
1924   Solaris
1925
1926     * Avoid kernel panics due to null pointer dereferences in the network
1927       interface poller kernel thread.
1928
1929
1930 OpenAFS 1.5.60 (2009-05-31)
1931
1932   All platforms
1933
1934     * Retry volserver transaction creation on failure.
1935
1936     * Allow building HTML and PDF documentation from included XML copies
1937       of User Guide, Admin Guide and Quick Start Guide for Unix.
1938
1939     * Documentation updates and additional documentation.
1940
1941     * Add -encrypt support to pts client.
1942
1943     * Convert MR-AFS fs commands to OSD commands.
1944
1945   All server platforms
1946
1947     * Updated background sync process in fileserver to avoid a race which
1948       could result in a volume being taken offline.
1949
1950   Microsoft Windows
1951
1952     * On April 9th Microsoft released a Hot Fix for Windows Server 2003
1953       SP2 that corrects a deadlock in the smb redirector and also adds new
1954       functionality that permits the AFS SMB server to be given a longer
1955       timeout than is normally the case.  New functionality has been added
1956       to configure these additional LanmanWorkstation\Parameter values.
1957       (This functionality has been backported to XP SP3 and is scheduled
1958       to be released on June 5th.)
1959
1960     * Fix RT#124787, a race condition between "fs flush <dir>", "fs
1961       flushvolume", or "fs flushall" and on-going directory operations
1962       that can result in afsd_service.exe crashing.
1963
1964     * Release Notes, User and Administrator guides are now shipped as
1965       indexed Windows HtmlHelp Files. (.chm).  Shortcuts are provided from
1966       the Start Menu.
1967
1968     * A method of specifying Client CellServDB information within the
1969       registry has been added that can be used to either override the
1970       CellServDB file or force the use of DNS lookups for a given cell.
1971       See the release notes for details.
1972
1973     * The pioctl interface now properly handles drive letter substitution
1974       to UNC paths.  (SUBST <d:> <\\afs\cell\path>)
1975
1976     * The BackConnectionHostNames registry value configuration was broken
1977       when dynamic re-establishment of Netbios Name registrations was
1978       added.  This release restores the functionality.
1979
1980     * All hidden vos.exe commands are now revealed.
1981
1982     * Attempts to store the same dirty file chunk from multiple threads
1983       are now prevented.
1984
1985     * The IsPathInAfs test in Explorer Shell Extension and fs.exe now
1986       permits broken symlinks to be treated as being in AFS.
1987
1988     * vos.exe commands that output 64-bit integer values once again do so.
1989       This was broken in 1.5.59.
1990
1991     * Cygwin Import Libraries are provided in the SDK for all OpenAFS
1992       DLLs.  This permits building cygwin applications against OpenAFS
1993       libraries.
1994
1995     * NSIS installer does a much better job of cleaning up files left over
1996       from previous installs.
1997
1998     * libafsconf.dll moved from Client\Program to Common directory as is
1999       is now used by all modules for CellServDB processing.
2000
2001   All UNIX client platforms
2002
2003     * Write back changes on last store for memcache to avoid discarding
2004       changes.
2005
2006     * Abstract disk cache support to allow for path, fh, inode based
2007       caches with no need for messy ifdef structures each time a new type
2008       is added.
2009
2010   DragonflyBSD
2011
2012     * Support as a userland port.
2013
2014   FreeBSD
2015
2016     * Corrected structure definition for userspace cache manager to allow
2017       builds to complete.
2018
2019   Linux
2020
2021     * Corrected client locking support.
2022
2023     * Updated patch to stop deadlocking in the kernel during mmap.
2024
2025     * Avoid oops when setting up groups for PAGs to match keyrings.
2026
2027     * Use Linux fh-based cache in cases where possible by default.
2028
2029   MacOS 10.3:
2030
2031     * Corrected structure definition for userspace cache manager to allow
2032       builds to complete.
2033
2034   OpenBSD
2035
2036     * Support for OpenBSD 4.5.
2037
2038   Solaris
2039
2040     * Corrected support for server-side vos split interface.
2041
2042
2043 OpenAFS 1.5.59 (2009-04-06)
2044
2045   Microsoft Windows
2046
2047     * Increased service priority class to "High" to match the priority of
2048       system components that are dependent upon the a timely response.
2049
2050     * SMB error responses avoid returning errors that could confuse the
2051       Microsoft SMB redirector into disconnecting the connection to \\AFS.
2052
2053   All UNIX client platforms (except MacOS X 10.4 and 10.5)
2054
2055     * OpenAFS 1.5.59 contains fixes for the client issues addressed by the
2056       security advisories OPENAFS-SA-2009-001 and OPENAFS-SA-2009-002.
2057
2058   Linux platforms
2059
2060     * Support for prerelease Linux 2.6.30 kernels.
2061
2062
2063 OpenAFS 1.5.58 (2009-03-30)
2064
2065   All platforms
2066
2067     * Code cleanup and prototyping.
2068
2069     * Avoid unnecessary blocking in Rx periodic cleanup code.
2070
2071   All server platforms
2072
2073     * Fileserver CopyOnWrite routine optimized for performance.
2074
2075     * Make fileserver callback dumps 64 bit safe.
2076
2077     * Fix byte order issues with fileserver host hashing.
2078
2079     * Fix buffer size issues with butc.
2080
2081     * Fix several Ubik recovery issues.
2082
2083     * Avoid leaking file references in the fileserver.
2084
2085     * Fix a race in DAFS while closing vnodes, and another offlining
2086       volumes.
2087
2088     * volserver interfaces for volume splitting client.
2089
2090   Microsoft Windows
2091
2092     * [RT 124293] A race condition exists which can result in a crash.
2093
2094     * [RT 124276] If the vldb is out of sync with the contents of the file
2095       servers, afsd_service will retry too many times when a file server
2096       reports a volume as not being present.  Now if the list reported by
2097       the vldb is the same as the previously seen list, then the retry is
2098       aborted.
2099
2100     * [RT 124276] Read-only volume failover was broken in 1.5.53 whenever
2101       accessing a volume results in VNOVOL or VMOVED.
2102
2103     * [RT 124276] Prior to 1.3.70 the volume server reference list was not
2104       reference counted and would be prematurely freed while in use.  When
2105       reference counting was added in 1.3.70 a bug was introduced that
2106       could result in service reference list corruption.
2107
2108     * Add Windows Application Event Log warning messages for "Client SMB
2109       MPX value too large" and "Client SMB Buffer Size too small".
2110
2111     * Renaming of files across directory boundaries would result in an
2112       invalid handle error when attempting to access the files after the
2113       move.
2114
2115     * Fix the handling of Tran2 Set Path Info RPCs.  Do not fail when a
2116       smb file descriptor cannot be found.  The whole point of using a
2117       Path Info function is because an smb file descriptor wasn't
2118       allocated.
2119
2120     * More edge cases in which dynamic addition of Freelance root.afs
2121       entries would get the wrong FID or where the root.afs directory
2122       would not be refreshed.
2123
2124     * Buffer overflow could occur if the workstation cell name was longer
2125       than 64 characters.  Crashes could occur in afscreds.exe,
2126       afslogon.dll, and afsd_service.exe.
2127
2128     * VNOSERVICE and VOFFLINE errors were leaking and were exposed to the
2129       smb client.
2130
2131     * Log file server uuid values as part of the cm_server object when
2132       available.  Dump the cm_server object list in response to "fs
2133       memdump".
2134
2135     * Optimize the performance of resetting access control lists when
2136       tokens are set or removed.
2137
2138     * Remove symlink recursion tests and increase max symlink count to 64
2139       from 16.
2140
2141     * Windows specific Rx performance improvements.
2142
2143     * Support for Network Identity Manager 2.0
2144
2145   All UNIX client platforms
2146
2147     * Avoid issues with freeing resources at shutdown.
2148
2149     * Numerous fixes to disconnected AFS.
2150
2151     * Disconnected AFS fixes for replaying changes without double-freeing.
2152
2153     * Attempt to use krb524 principal conversion in aklog if available.
2154
2155   AIX
2156
2157     * Kerberos configuration at build time corrected.
2158
2159   Linux
2160
2161     * Default to dynamic allocation of AFS kernel cache entries to allow
2162       growth for inotify()-pinned entries. (beagle, famd, etc)
2163
2164     * Change client truncation routines to avoid locking issues.
2165
2166     * IA64 port clients fixed on Linux 2.6.
2167
2168     * RPMs now install fstrace message catalog.
2169
2170     * Support through kernel 2.6.29 tested.
2171
2172     * Fix locking issues on CellServDB file in /proc.
2173
2174   OpenBSD
2175
2176     * Support OpenBSD 4.4
2177
2178
2179 OpenAFS 1.5.57 (2009-01-23)
2180
2181   All platforms
2182
2183     * Conditional compilation of rxdebug support is now possible.
2184
2185     * Documentation updates.
2186
2187     * Further race connditions in Rx have been corrected.
2188
2189   All server platforms
2190
2191     * Salvager no longer attempts to recreate headers in the wrong
2192       partition.
2193
2194     * Volumes are properly marked in use on creation and subsequently on
2195       examination with vos.
2196
2197   Microsoft Windows
2198
2199     * Undo the "UAC manifest fix" applied to afs_config.exe.
2200
2201     * Ensure that Freelance allocation of vnodes follow the AFS convention
2202       of odd vnodes are directories and everything else is an even vnode.
2203
2204     * Add Freelance logic to mount point and symlink evaluation functions.
2205
2206     * Enhance smb_ParseASCIIBlock() so that it can handle all of the
2207       STRING formats defined by the CIFS Technical Report 1.0.
2208
2209     * Validate the output of smb_ParseASCIIBlock() in all callers.  Return
2210       CM_ERROR_BADSMB if the STRING field cannot be parsed.
2211       CM_ERROR_BADSMB will cause the contents of the packet to be logged.
2212
2213     * If multiple SMB Raw Write operations were taking place at the same
2214       time, there could be data corruption because unique event objects
2215       were not generated for each Netbios receive operation.
2216
2217   All UNIX client platforms
2218
2219     * Userspace AFS library can now deal with large files when supported
2220       by the platform.
2221
2222     * Numerous updates to disconnected AFS support, including changes to
2223       allow reconnection to work in more circumstances.
2224
2225   FreeBSD
2226
2227     * FreeBSD unstrategy code has been updated.
2228
2229   Linux
2230
2231     * A race during file truncation has been corrected.
2232
2233     * System call probing routines have been updated.
2234
2235     * 2.6.29 is now supported.
2236
2237   MacOS
2238
2239     * 10.3 support has been corrected.
2240
2241   OpenBSD
2242
2243     * Initial OpenBSD 4.4 support.
2244
2245   Solaris
2246
2247     * Updates to allow compiling on newer OpenSolaris are now included.
2248
2249
2250 OpenAFS 1.5.56 (2008-12-30)
2251
2252   All platforms
2253
2254     * libuafs (userspace cache manager) updated to correct several errors.
2255
2256     * Additional rx debugging support is available as a conditional
2257       compile.
2258
2259     * A race condition in Rx leading to a panic has been corrected.
2260
2261     * Rx idle time tracking has been corrected.
2262
2263     * ubik clone server support has been corrected.
2264
2265   All server platforms
2266
2267     * Salvager no longer leaves cores in vice partitions.
2268
2269     * The vol-dump tool now supports dumps larger than 2gb where possible.
2270
2271     * Operations on multiple files now report all FIDs in the audit log.
2272
2273     * butc XBSA support now works correctly on amd64.
2274
2275   Microsoft Windows
2276
2277     * The NetIDMgr AFS Provider automated configuration logic was broken
2278       by the introduction of Kerberos referrals.  If the realm of the
2279       identity cannot be determined, the workstation cell is now assumed
2280       to belong to the newly created identity.
2281
2282     * Avoid a reference count under flow during rename operations.
2283
2284     * Avoid a crash caused by treating an arbitrary length directory
2285       search mask as an 8.3 mask.
2286
2287     * Prevent rename operations if a case insensitive match for the target
2288       name already exists and does not refer to the object being renamed.
2289
2290     * Increase the maximum number of background daemons to 64.
2291
2292     * Fix the UAC manifest applied to afs_config.exe
2293
2294   All UNIX client platforms
2295
2296     * Updates to disconnected AFS support.
2297
2298   FreeBSD
2299
2300     * FreeBSD 7.1 is now supported.
2301
2302     * amd64 FreeBSD is now supported.
2303
2304   Linux
2305
2306     * Generic fh (exportfs API) cache type is now available.
2307
2308     * Avoid some oopses due to backing_dev_info inode fields not being
2309       filled.
2310
2311     * 2.6.28 is now supported.
2312
2313   MacOS
2314
2315     * 10.3 support has been corrected.
2316
2317   Solaris
2318
2319     * Large partition support has been corrected.
2320
2321     * Filesystem-agnostic cache is now available on Solaris 10 and 11.
2322
2323
2324 OpenAFS 1.5.55 (2009-11-10)
2325
2326   All platforms
2327
2328     * Salvager avoids leaving core files in vice partitions.
2329
2330     * NFS translator fixes.
2331
2332     * Unresponsive server handling fixes.
2333
2334     * A volserver race which could result in duplicate transactions is
2335       fixed.
2336
2337   Microsoft Windows
2338
2339     * Fixes a panic caused by corruption of the SMB virtual circuit list.
2340       (race condition)
2341
2342     * Fixes a panic caused by receipt of a UTF-16 string that cannot be
2343       converted to UTF-8.
2344
2345     * Implements a more aggressive recovery algorithm for Netbios errors
2346       that result in loss of communication to the AFS SMB server.
2347
2348     * Improve pioctl response time when testing whether or not a PATH is
2349       in AFS.
2350
2351     * Adds support for linked cells.
2352
2353     * Increases the length of the cell and realm names that can be input
2354       into the Network Identity Manage AFS provider configuration dialog.
2355
2356   All UNIX client platforms
2357
2358     * Disconnected AFS avoids infinite recursion during rmdir.
2359
2360   Linux
2361
2362     * Support for 2.6.28 (not complete for NFS translator modules).
2363
2364     * Support for using exportfs API for filesystem-agnostic cache.
2365
2366     * Disable backing store readahead.
2367
2368     * Avoid deadlocks when writing back mmapped files larger than the
2369       cache.
2370
2371     * Avoid Oops when doing PAG garbage collection.
2372
2373
2374 OpenAFS 1.5.54 (2008-10-08)
2375
2376   All platforms
2377
2378     * Updates for new Tivoli X/Open API finding.
2379
2380     * A double-free is corrected in Rx.
2381
2382   All server platforms
2383
2384     * Ubik cleans up file descriptor cache correctly when doing recovery.
2385
2386     * Enhanced vldb error checker included.
2387
2388   Microsoft Windows
2389
2390     * Prevent a crash that could occur when multiple file / directory
2391       change notifications are processed simultaneously.
2392
2393   MacOS
2394
2395     * AFS claims more free space so Finder will attempt file copies.
2396
2397   Linux
2398
2399     * Avoid spurious ENOENT when calling gwtcwd() on a volume root.
2400
2401     * Avoid spurious ENOTDIR during fakestat.
2402
2403
2404 OpenAFS 1.5.53 (2008-09-26)
2405
2406   All platforms
2407
2408     * rx avoids many packet leaks.
2409
2410     * rx jumbogram disabling now works (and is the default).
2411
2412   All server platforms
2413
2414     * Demand Attach fileserver tries to avoid issues tracking offline
2415       status of volumes.
2416
2417   Microsoft Windows
2418
2419     * Many potential deadlock conditions due to out of order lock
2420       acquisitions have been corrected.
2421
2422     * A race condition resulting in an undercount on the cm_scache_t
2423       reference counts has been corrected.
2424
2425     * An empty string when sent as an ioctl path is now properly
2426       interpreted as meaning the current directory.  This affects "fs
2427       lsm", "symlink list", etc.
2428
2429     * Fix smb string parsing differences where the smb protocol
2430       documentation does not match the actual Windows implementation.
2431
2432     * Random access denied errors fixed.
2433
2434     * A file server lock synchronization issue was corrected in SMB
2435       NTCreateX and NTTranCreate operations.  This bug prevented properly
2436       operation when loading roaming profiles.
2437
2438     * Fix a heap overwrite error during server probe operations if a new
2439       server is added while a probe operation is in progress.
2440
2441     * Fix an LSA memory leak that was the result of an LSA error.
2442
2443     * Do not leak cm_cell_t objects if the VLDB server lookup fails.
2444
2445     * Only initialize rx mutex/lock objects once.
2446
2447     * Do not nul terminate the AFS volume name when reported to Windows.
2448
2449     * Improve VNOVOL error handling.  Prevent updated vl information from
2450       being destroyed immediately after it was acquired.  This bug
2451       prevented proper fail over when volumes are moved or removed from a
2452       server.
2453
2454     * Remove volume id from the server volume list in response to VMOVED
2455       and VNOVOL errors.
2456
2457     * "fs flushXXX" commands now destroy locally built B+ directory trees.
2458
2459     * Prevent mixture of locally modified directory pages and file server
2460       directory pages.
2461
2462     * Fail over to alternate vl servers if a ubik error is returned.
2463
2464   All UNIX client platforms
2465
2466     * Disconnected AFS now supports read-write mode.
2467
2468     * volserver now builds correctly.
2469
2470   AIX
2471
2472     * AIX 6 is now supported.
2473
2474   FreeBSD
2475
2476     * FreeBSD 7 is now supported.
2477
2478   Linux
2479
2480     * cache bypass is now supported.
2481
2482     * 2.6.x kmod compilation now uses kernel compile options always.
2483
2484     * Support through 2.6.27.
2485
2486   MacOS
2487
2488     * Show more space free so Finder doesn't get confused.
2489
2490   Solaris 10
2491
2492     * Default to namei rather than inode.
2493
2494
2495 OpenAFS 1.5.52 (2008-08-18)
2496
2497   All platforms
2498
2499     * Initialize volume updateDate at volume creation.
2500
2501     * Avoid potential corruption of directories during salvage.
2502
2503     * Check for out of memory condition during allocation of additional Rx
2504       packets.
2505
2506   Microsoft Windows
2507
2508     * Restore support for Windows 2000 (broken in 1.5.50).
2509
2510     * Perform additional validation on volume names in mount points during
2511       creation and evaluation.
2512
2513     * Fix several deadlocks, races, and reference count issues.
2514
2515     * Further optimize SMB Directory Search processing and minimize the
2516       number of InlineBulkStatus RPCs sent to the file server.
2517
2518     * Enable "bos restricted" operations.
2519
2520     * Fix the create of submounts used by the AFSCreds and afs_config
2521       drive mapping tabs.
2522
2523     * Fix a short name truncation bug. (1.5.50)
2524
2525     * Fix the error code reported when attempting to delete a file on a
2526       readonly volume or one that is marked with the readonly DOS
2527       attribute.
2528
2529     * Fix a heap corruption error when reading the CellServDB file
2530       location.
2531
2532     * Add the "RxUdpBufSize" registry value.  The new default is 256KB.
2533
2534     * Do not include trailing NULs in the directory search output.
2535       (1.5.50)
2536
2537     * Pre-allocate 64 Rx Packet buffers per thread in order to improve
2538       performance.
2539
2540     * For debugging: add smb lock requests and stat cache lock allocations
2541       to the output from "fs memdump".
2542
2543   NetBSD
2544
2545     * Workaround broken sigwait() to allow fileserver to shut down
2546       correctly pre NetBSD 5.0.
2547
2548   Solaris 10
2549
2550     * Default to namei fileserver; Allow inode fileserver at configure
2551       time by override.
2552
2553   NFS translator
2554
2555     * Try harder to avoid kernel panics for malformed requests.
2556
2557
2558 OpenAFS 1.5.51 (2008-07-29)
2559
2560   All platforms
2561
2562     * salvager tries harder to arrange for clients to get VBUSY while
2563       salvaging single volumes.
2564
2565     * salvager avoids certain corruption when salvaging directories.
2566
2567     * Rx connection clones disabled.
2568
2569   Microsoft Windows
2570
2571     * The 32-bit EXE 1.5.50 installer failed to properly install the C
2572       Runtime library.  When used as an upgrade OpenAFS would continue to
2573       work but when used as a new installation, OpenAFS binaries would
2574       fail to load.
2575
2576     * Fixes the "fs" and "symlink" commands to properly parse Unicode path
2577       prefixes during the pioctl remote procedure call.  This bug would
2578       result in file not found errors for files and directories that
2579       clearly exist.  (Bug introduced in 1.5.50)
2580
2581     * Large File support is disabled. (Bug introduced in 1.5.50)
2582
2583     * Removes the possibility of a deadlock during volume location update
2584       operation if all of the reported file servers are unreachable at the
2585       time of the update.
2586
2587     * Ensures that reference counts are properly incremented/decremented
2588       on Rx connection objects used for volume location RPCs.
2589
2590     * Over Quota errors during cm_FSync() calls would lead to an infinite
2591       loop as the error was never propagated to the caller.
2592
2593   All UNIX client platforms
2594
2595     * Bugfixes to disconnected AFS support in the cache manager.
2596
2597
2598 OpenAFS 1.5.50 (2008-07-16)
2599
2600   All platforms
2601
2602     * volserver puts recloned volumes back online before returning the
2603       volume to the fileserver, avoiding spurious VNOVOL errors.
2604
2605     * Updated TSM X/Open API support available.
2606
2607     * Demand Attach fileserver will not crash due to accesses during
2608       volume cloning.
2609
2610     * Substantial documentation updates.
2611
2612     * Demand Attach fileserver state tracking and analyzer tool
2613       improvements.
2614
2615     * UAFS userspace cachemanager updates.
2616
2617     * Corrected support for anti-meltdown protection in the client.
2618
2619   Microsoft Windows
2620
2621     * UNICODE Character Set Support.
2622
2623     * Pioctl interfaces to the cache manager have been refactored to
2624       provide layering between the SMB specific code and the general
2625       purpose ioctl operation.
2626
2627     * Garbage collect dead SMB virtual circuits as soon as they are no
2628       longer being referenced.  This avoids problems with outstanding
2629       locks not being dropped when the virtual circuit becomes invalid.
2630
2631     * Remove the IBM Administration Reference documentation and replace it
2632       with the OpenAFS Command Reference Manual.
2633
2634     * Avoid calling rx_SetDeadTime and rx_SetHardDeadTime functions each
2635       time a connection is about to be used.  Do not hold a lock on the rx
2636       connection object while it is being selected.  This avoids a race
2637       between threads attempting to set the timeout values and removes a
2638       bottleneck that was hampering performance.
2639
2640     * Ensure that the smb directory attribute is set for all directory
2641       objects.
2642
2643     * Replace the VC Runtime EXE installer with the MSI installer in the
2644       NSIS installer scripts.
2645
2646   Solaris
2647
2648     * Support for updates to OpenSolaris.
2649
2650   Linux
2651
2652     * Correct dentry revalidation for cross-directory renames.
2653
2654     * Updated rpm packaging materials for 1.5 release series and 2.4
2655       kernels.
2656
2657     * Corrected syscall table probing.
2658
2659     * NFS translator updates for current kernels.
2660
2661
2662 OpenAFS 1.5.39 (2008-06-24)
2663
2664   All platforms
2665
2666     * Updates for Demand Attach fileserver.
2667
2668   Microsoft Windows
2669
2670     * Fix two memory leaks.
2671
2672     * Fix one missing lock.
2673
2674     * Handle access denied errors when writing dirty buffers.
2675
2676     * Fix two errors that would cause the *experimental* AFS Servers
2677       to crash.
2678
2679
2680 OpenAFS 1.5.38 (2008-05-24)
2681
2682   All platforms
2683
2684     * Add read-only disconnected support.
2685
2686
2687 OpenAFS 1.5.37 (2008-05-21)
2688
2689   All platforms
2690
2691     * Includes a number of optimizations for testing.
2692
2693
2694 OpenAFS 1.5.36 (2008-05-09)
2695
2696   All platforms
2697
2698     * Rx optimizations now attempt to deal with high latency WANs.
2699
2700     * Client will not wait infinitely for a server which is not providing
2701       data.  Additional servers will be polled without marking the server
2702       which is not providing data down.
2703
2704     * vos move will not erroneously unlock locked vldb entries on failure.
2705
2706   All server platforms
2707
2708     * Fileserver avoids a potential infinite loop when a client
2709       relinquishes an address.
2710
2711     * Fileserver large setting now configures more threads.
2712
2713     * Fileserver properly registers uuids of new clients.
2714
2715     * Ubik servers do not improperly hide updates from clients.
2716
2717     * Fileservers reserve enough file descriptors such that each thread
2718       can cache one to avoid spurious errors.
2719
2720   Microsoft Windows
2721
2722     * Fix a cm_buf_t reference count leak when attempts to write dirty
2723       buffers to the file server from within cm_IncrSyncer() fail.
2724
2725     * Prevent udebug from crashing.
2726
2727     * Another VNOVNODE issue fixed.  When writing a dirty buffer to the
2728       file server, if VNOVNODE is received, mark all buffers as invalid
2729       without further attempts to contact the file server.
2730
2731
2732 =======> Changes back to 1.3 have not yet been incorporated here <=======
2733
2734
2735 OpenAFS 1.3
2736
2737   * -nosettime is now the default for afsd.  Use "-settime" to get the
2738     old behavior.
2739
2740   * OpenBSD is now supported.
2741
2742   * Mountpoint directory information is now only faked for cross-cell
2743     mountpoints when using the -fakestat flag (e.g. for the directories
2744     under /afs, but not for most other volumes mounted inside the cell).
2745     The -fakestat-all switch can be used to fake information for all
2746     mountpoints.
2747
2748   * When fakestat is enabled on MacOSX, the Finder can be used to browse
2749     a fully-populated /afs directory.  However, this precludes reliable
2750     use of entire volumes as MacOS bundles (i.e. containing a Contents
2751     directory in the root of the volume).
2752
2753   * Mountpoint directory information can be faked by the cache manager,
2754     making operations such as stat'ing all cells under /afs much faster.
2755     This is enabled by passing -fakestat to afsd, but might not be stable
2756     on all platforms.
2757
2758
2759 OpenAFS 1.2.9
2760
2761   * The kaserver now defaults to not allowing interrealm authentication,
2762     due to security vulnerabilities in the krb4 protocol.  The new
2763     "-crossrealm" flag to the kaserver is provided to reenable interrealm
2764     authentication if desired.
2765
2766   * RedHat Linux 9.0 is now supported.
2767
2768   * Solaris 9 12/02 is now supported.  Solaris 7 and 8 x86 should now
2769     work again.
2770
2771   * On Linux machines using 2.2 series kernels, 2.2.19 or higher is now
2772     required.
2773
2774   * An OpenAFS 1.2.9 afsd will not work with kernel modules built from
2775     an earlier OpenAFS release.  In general, using a mismatched afsd and
2776     kernel modules set is unsupported; it is not recommended that you use
2777     such a configuration on a regular basis.
2778
2779
2780 OpenAFS 1.2.8
2781
2782   * Mountpoint directory information is now only faked for cross-cell
2783     mountpoits when using the -fakestat flag (e.g. for the directories
2784     under /afs, but not for most other volumes mounted inside the cell).
2785     The -fakestat-all switch can be used to fake information for all
2786     mountpoints.
2787
2788   * HPUX 11.0 is now supported.
2789
2790   * It is now possible for AFS to use Kerberos 5 directly, via rxkad 2b.
2791     See the OpenAFS 1.2.8 Release Notes for more information on using this
2792     capability.
2793
2794   * An NFS translator kernel module is now included and compiled by
2795     default for Solaris only.
2796
2797
2798 OpenAFS 1.2.7
2799
2800   * MacOS X 10.2 is now supported.  FreeBSD 4.3 and later support is
2801     included in this release, but is still under active development and
2802     should only be used by those doing active development on the OpenAFS
2803     FreeBSD client.
2804
2805   * When fakestat is enabled on MacOSX, the Finder can be used to browse a
2806     fully-populated /afs directory.  However, this precludes reliable use
2807     of entire volumes as MacOS bundles (i.e. containing a Contents
2808     directory in the root of the volume).
2809
2810   * The fileserver will now use Rx pings to determine if clients are
2811     reachable prior to allocating resources to them, to prevent asymmetric
2812     clients from consuming all fileserver resources.
2813
2814
2815 OpenAFS 1.2.6
2816
2817   * Mountpoint directory information can be faked by the cache manager,
2818     making operations such as stat'ing all cells under /afs much faster.
2819     This is enabled by passing -fakestat to afsd.
2820
2821   * Solaris 9 FCS and Solaris 7 and 8 x86 are now supported.
2822
2823
2824 OpenAFS 1.2.5
2825
2826   * A remote denial of service attack in the AIX and IRIX clients has been
2827     fixed.  Users of those platforms are strongly encouraged to upgrade.
2828
2829   * Fixed race conditions in fileserver that could result in crash.
2830
2831
2832 OpenAFS 1.2.4
2833
2834   * Server logfiles now more consistant about format in which hosts are
2835     referred to.
2836
2837   * vfsck on Solaris will now allow force runs (using -y flag) even if old
2838     inodes exist.
2839
2840
2841 OpenAFS 1.2.3
2842
2843   * Cell aliases for dynroot can be specified in the CellAlias file in
2844     /usr/vice/etc or /usr/local/etc/openafs, in format "realname alias",
2845     one per line.  They can also be managed at runtime with "fs newalias"
2846     and "fs listaliases".
2847
2848
2849 OpenAFS 1.2.2
2850
2851   * Solaris 9 and Linux PA-RISC are now supported.
2852
2853   * fileserver will not erroneously delay legitimate errors for 3 seconds
2854     after 10 errors are returned (e.g. stat() on a directory you can't
2855     read).
2856
2857   * Rx MTU calculation now works for Irix, Solaris and Linux
2858
2859   * If afsd is started with the -dynroot flag, /afs will be locally
2860     generated from the CellServDB.  AFSDB cells will be mounted
2861     automatically upon access.
2862
2863   * The namei fileserver allows vice "partitions" to be directories
2864     instead of partitions and will attach and display accordingly.
2865     Creating the file "AlwaysAttach" in the /vicepX directory is used as
2866     the trigger to attach it.
2867
2868   * TSM support for butc no longer requires editing a Makefile, simply
2869     specify the --enable-tivoli-tsm configure option.
2870
2871   * Linux builds no longer require source changes every time the kernel
2872     inode structure changes; the OpenAFS sources will now configure itself
2873     to the actual inode structure as defined in the kernel sources.
2874
2875
2876 OpenAFS 1.2.1
2877
2878   * vfsck on Digital UNIX and Solaris will now refuse to fsck mounted
2879     mounted partitions.
2880
2881
2882 OpenAFS 1.2.0
2883
2884   * AFS now supports --prefix and the other directory options of
2885     configure.  By default AFS builds assuming it will be installed in
2886     /usr/local.  In order to get traditional AFS directory paths (/usr/afs
2887     and /usr/vice/etc) use the --enable-transarc-paths option to
2888     configure.  More details on the new directory layout are found in
2889     README.
2890
2891
2892 OpenAFS 1.1.1a
2893
2894   * Windows 95/98/ME/NT/2000 - Consistent versioning:  Installation, AFS
2895     Control Center, Client dialog boxes and properties pages for
2896     executables display a consistent OpenAFS version number.  Installation
2897     detects previous installation and prompts the user for upgrade
2898     options.
2899
2900   * Windows 95/98/ME/NT/2000 - Installation features:  During installation
2901     the user can select the source of the CellservDB file, AFS home cell,
2902     and drive mappings.  During installation a drive path mapping can
2903     include a variable that will be substituted with the current UserName
2904     that is logged in.
2905
2906   * Windows 2000/NT - Integrated logon:  The Integrated Logon feature
2907     works now.
2908
2909   * Windows 95/98/ME - Logon script features:  The Windows 95/98/ME client
2910     now offers a command-line option for starting up the AFS client
2911     without authenication. It is now possilbe to start the AFS client
2912     first and obtain tokens, and map drives all through Windows scripts.
2913     This helps using Windows 95/98/ME client in Kerberos 5 environment.
2914
2915   * Windows 2000/NT - LANA numbers:  AFS client now scans the LANA numbers
2916     to establish the correct NETBIOS connection.  NetBEUI is no longer
2917     needed.  The user no longer needs to find the correct LANA number.
2918
2919   * Windows 2000/NT - OpenAFS naming consistancy:  Further progress has
2920     been made to remove references to "Transarc AFS" and replace with
2921     "OpenAFS".
2922
2923
2924 OpenAFS 1.0
2925
2926   * AFS now builds with configure. The README for building has been
2927     updated and includes full details.
2928
2929   * A client system can now have multiple sysname values for @sys.  They
2930     will be searched in order when looking up files in AFS.  The
2931     -newsysname argument to fs sysname can be repeated to set multiple
2932     sysnames.
2933
2934   * A new system group is created for new cells (system:ptsviewers with id
2935     -203).  If this group exists, members of this group can examine and
2936     read the entire protection database.  They can examine all users and
2937     groups and can get the membership of any group.
2938
2939   * A new program, pt_util has been added to the distribution.  This
2940     program allows users to print the contents of the protection database
2941     or to edit the protection database without running a ptserver.  It can
2942     be used to set up a new cell without ever running in noauth mode.  Run
2943     pt_util -h for help.
2944
2945   * The fs setcrypt and fs getcrypt commands have been added.  These
2946     commands allow the system administrator to require that the client
2947     encrypt all authenticated traffic between the client workstation and
2948     AFS.  The encryption used is weak, but is likely better than sending
2949     unencrypted traffic in most environments.  Some functions, such as
2950     looking for a volume may not be encrypted, but data transfer certainly
2951     is.  By default data is not encrypted.  At this time no significant
2952     experimentation with server performance has been conducted.
2953
2954   * By default AFS is compiled with AFS_AFSDB_ENV, enabling the -afsdb
2955     option to be given to afsd on startup.  If this option is used, then
2956     new cells will be looked up using AFSDB records stored in DNS if they
2957     are not found in CellServDB.  This means that users can create
2958     cross-cell mountpoints in directories they control to access cells not
2959     in root.afs, and that cells in root.afs need not be in the client's
2960     CellServDB.
2961
2962   * AFS database servers can be marked as read-only clones.  Surround the
2963     hostname in square brackets on the bos addhost command and the
2964     database server will never be elected sync site.  This is useful for
2965     cells distributed over a wide region.
2966
2967   * The AFS servers now support the -syslog flag.  This flag causes them
2968     to log to syslog rather than to files.  This flag is not supported on
2969     NT.  For all servers besides the salvager, the flag can also be
2970     specified as -syslog=facility, where facility is an integer facility
2971     code from syslog.h.  A -syslogfacility option is provided for the
2972     salvager to accomplish the same goal.
2973
2974   * If the --enable-fast-restart flag is given when configuring AFS, then
2975     the salvager supports the -dontsalvage flag which causes it to exit
2976     without salvaging any volumes.  If this is configured into the third
2977     command of a fs process, then the fileserver will start without
2978     salvaging.  It will fail to attach volumes that need salvaging and
2979     they can be salvaged manually.  This provides significantly better
2980     server startup performance at the cost of administrative complexity.
2981
2982   * If the --enable-bitmap-later flag is given when configuring AFS, then
2983     the fileserver creates bitmaps for free vnodes on demand, allowing
2984     faster starts.
2985
2986   * If bosserver finds a BosConfig.new file at startup, it reads this file
2987     and renames it to BosConfig.  This allows bosserver to be reconfigured
2988     at next restart.
2989
2990   * The bosserver can be placed in a restricted mode in which AFS
2991     superusers are only granted limited access to the server host. The
2992     following functionality is disabled when restricted mode is in use:
2993
2994       bos exec
2995       bos getlog (except for files with no '/'s in their name)*
2996       bos create *
2997       bos delete
2998       bos install
2999       bos uninstall
3000
3001     specific exceptions are made for functionality that "bos salvage"
3002     uses:
3003
3004     A cron bnode who's name is "salvage-tmp", time is now, and command
3005     begins with "/usr/afs/bin/salvager" may be created. This bnode deletes
3006     itself when complete, so no special "delete" support is needed.  This
3007     functionality may be removed in the future if a "Salvage" RPC is
3008     implimented.
3009
3010     The file with the exact path /usr/afs/logs/SalvageLog may be fetched,
3011     since that is how bos salvage [...] -showlog is implimented.
3012
3013     Restricted mode is enabled using a new bos command (bos setrestricted)
3014     or bossever command line switch (bosserver -restricted). Restricted
3015     mode can be disabled by a) sending the bosserver process a SIGFPE
3016     (which will then allow restricted operations until the next restart or
3017     setrestricted command) or b) editing /usr/afs/local/BosConfig (or
3018     BosConfig.new), and restarting the bosserver.
3019
3020   * The bos UserList of trusted administrators can now contain cross-realm
3021     Kerberos principals.
3022
3023   * udebug now takes --server not --servers.
3024
3025   * Several error messages have been improved to include volume numbers.
3026
3027   * Several new ports have been included for UNIX platforms: Darwin
3028     (ppc_darwin_12 and ppc_darwin_13), Linux 2.4 (i386_linux24), Linux on
3029     the Powerpc (ppc_linux22 and ppc_linux24), Linux on the Sparc
3030     (sparc_linux22, sparc64_linux22 and sparc64_linux24).
3031
3032   * Incomplete FreeBSD and Alpha Linux ports are included.  The FreeBSD
3033     port has a working server and the Alpha Linux port has a partially
3034     working client.
3035
3036   * A native client for Windows 95/98/ME has been added to the
3037     distribution.  With this program, a gateway machine is no longer
3038     required for Windows 9x to access AFS files.  One drive letter will be
3039     created on your machine by default - Z:.  The Z: drive will be the
3040     root of the AFS tree, allowing you to browse all sites that have AFS
3041     servers available.  Additional drive letters can be defined for other
3042     AFS directories.  A Windows Explorer shell extension is included that
3043     allows you to right click on items within an AFS tree to bring up an
3044     "AFS" menu item and perform various operations on a file or directory.
3045     The most useful item is "Access Control Lists", which allows you to
3046     view and edit the permissions of a particular directory.  Command line
3047     tools are also available in the install directory.  These commands
3048     include klog, unlog, tokens, kpasswd, symlink, fs and pts.  The
3049     installable includes a readme file that contains more information on
3050     how to use the client program and known issues.
3051
3052   * Support for large caches in afsd.  Cachefiles are stored in
3053     subdirectories.  The default is 2048 files per subdirectory, which
3054     should work fine in most situations.  You can use the new afsd option
3055     -files_per_subdir to change this number.  Note that the first time you
3056     run afsd with this patch, your cachefiles will get moved into
3057     subdirectories.  If you subsequently run an older version of afsd, you
3058     will lose all your cached files.