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