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