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