Merge 1.8.0~pre4 packaging into master
[pkg-k5-afs_openafs.git] / NEWS
blob3f19af9731ae53849e7ffe6be1ce196da6383fb3
1                        User-Visible OpenAFS Changes
3 OpenAFS 1.8.0pre3
5   All Platforms
7     * Substantial code quality improvements, largely spotted by Coverity and
8       clang's static analysis.
9       - Add new library for platform independent functions (opr).
10       - Remove arbitrary path name length limits.
11       - Convert to Heimdal's roken library for reliability.
12       - Avoid garbage in allocated buffers (calloc).
13       - Modernize signal handling in pthreaded server processes (softsig).
14       - Improve code comments and additional Doxygen style comments.
15       - Reduce compiler warnings, dead code, unused variables, and
16         undefined behavior.
17       - Fix bugs found by static code analyzer (clang-analyzer).
18       - Improved unit test coverage.
19       - Make VLDB flag definitions consistent.
20       - Improve use of run-time assertions and add static assertions.
21       - Add compiler attributes to assist static analyzers.
22       - Clean up include headers in the entire tree.
23       - Improve command-line handling library (libcmd).
24       - Replace hash functions with Jenkin's hash function for faster
25         and more evenly distributed lookups.
26       - Provide a red-black tree data structure to enable algorithmic speedups.
27       - Convert backup and salvage servers to the common logging API (libutil).
28       - Improve volume id data type consistency (VolumeId).
29       - Import APIs for kerberos-style profile configuration support.
30       - Add new APIs to support UserList identities.
31       - Add new APIs to support tabular output from command-line utilities.
32       - Convert vnode macros to inline-functions.
34     * Improved support for non-DES encryption types:
35       - Convert to Heimdal's hcrypto library to support RFC 3961.
36       - Add extended key file format replacing rxkad.keytab, and
37         new key management APIs.
38       - Add support for extended key types to asetkey.
39       - Add akeyconvert to assist in upgrading to OpenAFS 1.8.x by converting an
40         existing rxkad.keytab file to an extended key file.
41       - Do not install the kaserver and related utilities by default to
42         discourage the use of these DES-dependent components.
43       - Remove obsolete klogin and klogin.krb programs.
44       - Add new token APIs to support new rx security classes.
46     * Migrate from LWP to POSIX threads (pthreads):
47       - Convert the ptserver and vlserver from LWP to pthreads.
48       - Remove LWP version of the file server binary.
49       - Convert afsd, aklog, asetkey, klog.krb5, pts, udebug, and vos, from LWP
50         to pthreads.
52     * Improvements to Rx:
53       - Restructure the Rx API to privatize the implementation.
54       - Convert rx events to a red-black tree data structure to improve
55         performance.
56       - Convert from mutexes to atomic operations for counters to reduce lock
57         contention.
58       - Provide per-opcode Rx statistics.
59       - Add an rx_opaque data type to support non-DES encryption types
60         and general code cleanup.
61       - Wake up the application thread after 'twind' is updated to avoid 100ms
62         transmit delays when the receive window transitions from closed to
63         open.
64       - Fix for OPENAFS-SA-2017-001: sanity-check peer transport parmeters
65         received in ack trailers
67     * Libraries (both internal and installed) are built using libtool, including
68       libuafs. The resulting shared libraries for libafsrpc and libafsauthent
69       should be more usable than previously.
71     * Improvements to the build system:
72       - Convert to libtool to build shared libraries.
73       - Clean up and improve the build system.
74       - Support out of tree builds.
75       - Add a makefile target to generate Doxygen source code documentation.
76       - Link the Java API for OpenAFS with libuafs.a and remove the
77         libjuafs.a library.
78       - Always build the rxperf tool.
79       - Fix man-page generation by make after ./regen.sh -q
80       - Support the SOURCE_DATE_EPOCH environment variable to improve build
81         reproducibility.
82       - Modernize language specific SWIG typemaps for libuafs Perl bindings.
84     * Improvements to documentation:
85       - Document the new KeyFileExt file.
86       - Reorganized the README files.
87       - Improvements and fixes to documentation generation.
88       - Add experimental epub and mobi support
89       - Remove obsolete LWP information from the file server documentation.
90       - Update and reorganize the Quick Start Guide.
91       - Update the Admin Guide.
92       - Remove AIX, HP-UX, and IRIX information from the Quick Start Guide.
93       - Document the vldb and prdb (ubik) file formats.
94       - Add PtLog man page.
95       - Corrections and clarifications to man pages.
96       - Add ubik threading analysis doc.
97       - Normalize the location of text documents in the source tree.
99     * Improvements for troublshooting, debugging, and testing:
100       - Log more details on volume-server-to-fileserver communication errors
101         when possible.
102       - Set thread names in pthreaded servers on platforms which support
103         thread names.
104       - Add dynroot lock tracking to cmdebug
105       - Fix tracking of an fstrace call site in the cache manager background
106         process.
107       - Add the afsload tool to simulate multiple cache managers for file server
108         load testing.
109       - Add run-time checks for refcount imbalances in the cache manager.
110       - Fix missing newlines in afsd -debug output.
112     * Developer tool improvements:
113       - Improvements and fixes for rxgen (used to generate Rx RPC bindings).
114       - Add tool for man page verification of command options.
115       - Add tool to find Unix cache manager lock identification numbers.
116       - Add an option for pretty build output.
118     * RPM packaging updated:
119       - Update the spec file to keep up with accumulated changes.
120       - Move the klog.krb5 man page to the openafs-krb5 sub-package.
121       - Prevent double-starting client on RHEL7
122       - Convert rpm spec file from deprecated 'make dest' to 'make install'.
123       - Fix rpmbuild command line option default handling.
125     * Add a new protection error code (PRNAMETOOLONG) instead of silently
126       truncating names which exceed the maximum name length (PR_MAXNAMELEN).
128     * Add an implementation limit (50000) on the number of names/ids which can
129       be transmitted by unauthenticated clients to the ptserver, avoiding
130       excessive resource consumption from unauthenticated requests.
132     * Add the -config option to vos, pts, and aklog to specify the path to the
133       cell configuration files.
135     * Add more details in vos release -verbose output.
137     * Add the cacheout -encrypt option to encrypt communication between the
138       cacheout client and the fileserver.
140     * Add the command line options to the afsio program to enable encryption of
141       traffic between afsio and the fileserver (-clear, -crypt).
143     * Add the vos release -force-reclone option to force recloning the volume to
144       be released without forcing a full volume dump being transmitted to all
145       remote sites.
147     * Fix vos to avoid writing loopback addresses into the VLDB in
148       certain cases.
150     * Print bos and pts error messages to standard error instead of
151       standard out.
153     * Improve formatting of the -help output of all commands.
155     * Change -n to -dryrun in all backup subcommands.
157     * Change the backup deletedump -port command line option to -portoffset.
159     * Add user and build host in the version string returned by
160       rxdebug -version.
162   All Server Platforms
164     * Ubik servers using pthreads are now available and are used by default
166     * As part of improving Ubik reliability in certain edge cases, an extra
167       election cycle (about 60 seconds) may be needed before writes are
168       permitted.  This is a conservative change that may be removed in
169       the future.
171     * Remove periodic background fsync by the fileserver (ihandle fsync thread).
173     * Fix potential file handle leak in the file server ihandle caching layer.
175     * Disable the so-called "hot threads" feature in the file server. The hot
176       threads feature was intended as an optimization for dispatching incoming
177       calls to the current listener thread, but has been reported to incur a
178       performance penalty on modern multi-core systems.
180     * Do not permit creation of users with id of ANONYMOUSID.
182     * Do not save/restore host states in the fsstate.dat file for hosts which
183       are in the process of retrieving CPS information from the ptserver when
184       the fileserver is being shutdown. This fixes a bug in which the fileserver
185       will incorrectly block all threads following a restart.
187     * Add the ptserver -restrict_anonymous option to inhibit exposure of user
188       names from the ptserver.
190     * Do not truncate server log files by default when server processes
191       are started.  The -transarc-logs option provides backward compatibility
192       with IBM AFS log handling on server startup. Log messages may be lost
193       in back-to- back restarts when a server is running in this mode.
195     * Reopen server logs on SIGUSR1. This may be used by third-party log
196       rotation tools, such as logrotate, to reopen the log file handles after
197       log files have been renamed.
199     * Fix various bugs when logging with -mrafslogs enabled.
201     * Dynamically reload the kerberos realm to AFS cell mapping (krb.conf) and
202       exclusions for mapping kerberos principals to AFS identities (krb.excl)
203       configuration when the CellServDB cell configuration file is touched.
204       Previously, a restart of the file server was required after updating the
205       kerberos mapping configuration files.
207     * Add a command line option (-restricted_query) to the vlserver and
208       volserver to restrict information queries about volumes to a specific
209       group of users.
211     * Add a command line option to the server programs to specify an alternate
212       fully qualified log file name (-logfile).
214     * Add a command line option (-config) to the server programs to specify
215       an alternate path to the server configuration.
217     * Add a command line option to the ptserver and vlserver to specify an
218       alternate path to the database data files.
220     * Add a command line option to the volume server to enable encryption of
221       volume-server-to-volume-server-traffic (-s2scrypt).
223     * Increase the maximum number of LWP threads allowed for the ptserver and
224       vlserver from 16 to 64 (-lwp).
226     * Remove an unused file server command line option (-k).
228     * Fix an incorrect assertion in Demand Attach File Server which could cause
229       the file server process to abort in certain rare conditions.
231     * Deprecate the -bitmap-later configure option for non-Demand-Attach File
232       Servers (DAFS).
234     * Add -vhashsize support to non-Demand-Attach File Servers (DAFS).
236     * Add support for subnet ranges in the NetInfo and NetRestrict
237       configuration files.
239     * Add the GetXStats RPC to the audit log.
241     * Fix directory creation by bosserver when built for non-Transarc paths.
243     * Fix incomplete list of server addresses retreived by vos listaddr when the
244       vldb contains unreferenced multi-homed server entries.
246     * Remove obsolete bos blockscanner and unblockscanner commands that
247       were only needed for the removed MR-AFS functionality.
249     * Remove obsolete bos salvage options that were only used by the
250       removed MR-AFS functionality..
252     * Remove calls to the deprecated sbrk() function.
254     * Add an experimental feature to database servers to support ubik reads
255       while write transactions are in progress, enabled at build time with the
256       --enable-ubik-read-while-write configure option. This feature is not
257       considered ready for production usage at this time.
259     * Avoid filling the FileLog with "Volume x offline: not in service" when
260       a volume is administratively taken offline with vos offline.
262     * Print an error message when bosserver is started with an unknown
263       command line option.
265     * Modify the volume updateDate when the volume is changed by a salvage.
267     * Volume usage statistics are now preserved during reclone and restore
268       operations by default, the behavior previously enabled by
269       the -preserve-vol-stats flag to the volserver.  The historical behavior
270       can be retained via the -clear-vol-stats argument.
272   All Client Platforms
274     * Use rxkad_crypt by default for connections to fileservers.  This matches
275       the existing behavior of the Windows client and has been applied by
276       the distribution packaging on many platforms already.
278     * Add support for relative ACL changes with fs setacl. If a single plus (+)
279       or minus (-) character is appended to the rights' letters argument, the
280       new rights are computed relatively to the existing ones.
282     * Remove afsd -settime and afsd -nosettime support.
284     * Add the afsd -inumcalc option to specify the method used to calculate
285       inode numbers presented by AFS.
287     * Add the afsd -volume-ttl option to specify set the maximum amount of time
288       information retrieved from the vlserver will be cached, regardless of
289       callback expiry times.
291     * Return EIO on internal errors instead of the misleading ENOENT.
293     * Log ICMP errors received, if any, for unreachable servers.
295     * Improve performance of clients with multiple PAGs for different cells.
297     * Fix race condition between changing and using user tokens among cache
298       manager threads.
300     * Fix fs sysname for users with UID 2748 and 2750 when not running
301       in -rmtsys mode.
303     * Add Perl bindings for the user-space cache manager library (libuafs).
305     * Fixes to the bypasscache feature.
307     * Fix fs getcacheparms miscounts.
309     * Remove the obsolete Netscape plugin.
311     * Fix building gtx when ncurses is linked against libtinfo.
313   Linux
315     * Remove Linux 2.2 and 2.4 support.
317     * Changes to avoid EIO errors with multiple processes doing intensive mmap
318       writing. (Drop PageReclaim AOP_WRITEPAGE_ACTIVATE.)
320     * Prevent fakestat data inconsistencies in certain cases (131855).
322     * Fix dentry leak which can cause a crash on shutdown.
324     * Fix improper use of ENOENT and avoid incorrect use of linux negative
325       dentry cache.
327     * Use a more correct (less aggressive) scheme to react to downward
328       pressure on cache usage, avoiding d_invalidate(), which can cause
329       getcwd() failures on RHEL 7.4.
331     * Improve error reporting when encountering corrupt directories.
333     * Improve rx error handling in the Linux cache manager.
335     * Rename kpasswd to kapasswd when packaging RPMs to avoid colliding with
336       Kerberos kpasswd.
338     * Do not use the obsolete --enable-largefile-fileservers configure option
339       when packaging RPMs.
341     * In Red Hat packaging, use a separate rpm for kmod debuginfo,
342       removing a needless tight version dependency on the userspace package.
344     * Use the RemainAfterExit systemd feature to avoid premature exit
345       when -afsdb is not given, for RPM packages.
347     * Remove Debian packaging files from the OpenAFS source tree. Debian
348       packaging files are currently maintained in the downstream Debian
349       infrastructure.
351     * Add the sparc_linux26 sysname.
353     * Desupport 32-bit Linux kernels on s390/s390x.
355     * Fix Debian/Ubuntu build regression on kernel 3.16.39.
357     * Fix --enable-kernel-debug for linux 4.8+.
359     * Support linux 4.10, 4.11, 4.12, 4.13, 4.14, 4.15
361   Solaris
363     * Remove support for all Solaris and SunOS platforms prior to Solaris 8.
365     * Build 64-bit binaries for Solaris x86 by default.
367     * Use one-group PAGs on Solaris 11, which is required for PAG support
368       on Solaris 11 since supplemental groups must be sorted starting with
369       Solaris 11.1.
371     * Update search paths for solaris cc for recent versions Solaris Studio.
373     * Modernize declaration of module dependences by converting from the
374       deprecated _depends_on symbol to ELF dependencies.
376     * Avoid BAD TRAP panic due to invalid opcodes on x86 with Studio 12.5.
378   MacOS
380     * Stop processing upcalls once rx shutdown starts.
382     * Enable atomics for the darwin kernel.
384     * Add a syscall to enable/disable bulkstat at run-time, which is
385       disabled by default.
387     * Fix path to binaries in the prefpane.
389     * Fix builds on MacOS 10.12 by building only the active architecture
390       by default.
392     * Support versions up through 10.13 (High Sierra) and APFS
394   FreeBSD
396     * Use the native kernel module build system instead of an ad hoc
397       replacement build system.
399     * Remove FreeBSD packaging files from the OpenAFS source tree. FreeBSD
400       packaging files are currently maintained in the downstream FreeBSD Ports
401       Collection.
403     * Stay up to date with new FreeBSD releases (through 10.3).
405     * Do not claim AFS_VM_RDWR_ENV
407   NetBSD
409     * Stay up to date with new NetBSD releases (through 7.x)
411     * Update to use cprng(9) as the randomness source on NetBSD 6.99/7.x.
413     * Build system updates for NetBDS 6.99.x
415     * Do not claim AFS_VM_RDWR_ENV
417   OpenBSD
419     * Stay up to date with new OpenBSD releases (through 4.7)
421     * Do not claim AFS_VM_RDWR_ENV
423   AIX
425     * Updates for AIX support.
427     * Fix build system for AIX exports.
429     * Add the uidpag and localuid runtime options to the aklog LAM plugin.
430       (These runtime options override the use of UID-based PAGs, which were
431       introduced to appease the CDE screensaver.)
433 OpenAFS 1.6.21
435   All platforms
437     * Avoid a possible 100ms transmit delay in the RX protocol when a peer's
438       receive window transitions from closed to open (12627)
440     * Documentation improvements (12476 12477 12559[RT #133339])
442   All server platforms
444     * When bosserver is started with an unknown option, print an error message
445       and exit with a non-zero value rather than failing silently (12631)
447   All DB server platforms
449     * Hold the DB lock while checking for an aborted write transaction (12516)
451   All file server platforms
453     * On demand attach fileservers, don't save or restore a client's host
454       state if CPS ("Current Protection Subdomain") recalculation for it is
455       in progress, to avoid fileserver thread exhaustion (12568)
457     * On demand attach fileservers, avoid flooding the log with error messages,
458       which could happen when the fileserver was restarted while a volume was
459       offline (12569)
461     * Update a volume's "Last Update" time when its content is modified by
462       the salvager, to make the change visible in the output of "vos examine"
463       and to backup services (12633)
465   All client platforms
467     * Corrected the DCentries bucket counts for very large and zero length
468       files in the output of "fs getcacheparms -excessive" (12604 12605)
470     * Fixed a bug that prevented users with GID 2748 and 2750 from executing
471       the "fs sysname" command on clients running afsd with -rmtsys (12607)
473     * Provide a new -inumcalc switch for afsd to allow enabling the alternative
474       MD5 method of inode number calculation, which was previously only
475       possible on Linux and through the sysctl interface (12608 12632)
477   Linux clients
479     * Support for mainline kernel 4.12 and distribution kernels with backports
480       from it (12624 12626)
482     * Re-added the improved algorithm for freeing unused vcaches to reduce
483       memory consumption first introduced with the 1.6.18 release, together
484       with a fix for the issue leading to its removal in 1.6.18.2 (12448..12451)
486   macOS clients
488     * Fixed a crash while stopping the client on macOS 10.12 "Sierra" (12602)
491 OpenAFS 1.6.20.2
493   All platforms
495     * Build fixes required by recent compilers or platforms (12514 12521 12534
496       12536 12538)
498     * Allow the bos server to start successfully in the presence of those, by
499       accepting a now checked return value indicating that the client ThisCell
500       and CellServDB already exist (12522)
502   Linux clients
504     * Support for mainline kernels 4.10 and - most likely - 4.11 and
505       distribution kernels with backports from them (12530 12588..12590 12598)
507     * Support for distribution kernels with partial backports from 4.9 (12535)
508       (RT #134158)
510     * In Red Hat packaging, moved the klog.krb5 manual page into the krb5
511       subpackage (12511)
513     * In Red Hat packaging, prevent systemd from double-starting the client
514       (12587)
516     * Allow aklog to function on current S390/S390x (12499)
518   Solaris clients
520     * Make process authentication groups work on Solaris 11, now using a single
521       group ID (12524..12527)
523     * Fix a BAD TRAP panic on Solaris 11 clients built with Studio 12.5 (12567)
525   macOS clients
527     * Fixed the preference pane for OS X 10.11 and later (12512)
529 OpenAFS 1.6.20.1
531   All platforms
533     * Build fixes required by recent compilers (12482..12484)
535   Linux clients
537     * Support for mainline kernel 4.9 and distribution kernels with
538       backports from it (12478..12480)
540     * In Red Hat packaging, make systemd deal correctly with the client
541       when no userland processes remain after starting it (12481)
542       (RT #133482)
544   macOS
546     * Support for release 10.12 "Sierra" (12431 12432)
548     * Avoid a crash in the Mounts tab of the OpenAFS preference pane (12447)
550 OpenAFS 1.6.20 (Security Release)
552   All platforms
554     * Fix for OPENAFS-SA-2016-003: file and directory names leak due to
555       reuse of directory objects without zeroing the contents
556       (12461 12462 12463 12464 12465)
558 OpenAFS 1.6.19
560   All platforms
562     * Documentation improvements (12304)
563     * Fixes for test failures (12396 12415)
565   All DB server platforms
567     * Avoid potentially writing to an out of date volume location or protection
568       database, or losing a database write, which could happen in rare cases
569       under special conditions during database leader election
570       (12339 12389)
572   Solaris clients
574     * Allow the fsinfo::: DTrace provider to work with AFS files (12371)
576   Linux clients
578     * Don't commit more data to a file than was actually copied during writes,
579       which could happen on architectures with a page size > 4 KiB (12413)
580     * Fixed build on PPC64 with GCC 6.1 (12388) (RT #133407)
581     * Fixed build on x86_64 with recent GCC (12365 12366)
584 OpenAFS 1.6.18.3
586   Linux clients
588     * Support for mainline kernel 4.7 and distribution kernels with
589       backports from it (12348)
591   Solaris clients
593     * Fixed memory mapped I/O on files >= 4 GiB (12349 12350)
595       Note that there is a suspicion that this might break the client
596       on very old Solaris releases (2.6). If it does, the breakage should
597       occur at build time.
599   OS X
601     * Added tooling to build a package for OS X 10.10 "Yosemite" and
602       10.11 "El Capitan" (12335 12351)
605 OpenAFS 1.6.18.2
607   Linux clients
609     * Support for mainline kernel 4.6 and distribution kernels with
610       backports from it (12332)
612     * Switch back to the pre-1.6.18 algorithm for freeing unused vcaches.
613       While the new algorithm is still believed to be correct, it turned
614       out that at least on some kernels, including 4.5 and 4.6, the dentry
615       for the current working directory may be erroneously invalidated.
616       This could lead to errors like "Unable to read current working directory"
617       when a directory wasn't accessed for a few minutes. (12323)
619     * Use a secure URL to retrieve the CellServDB in the script to create
620       the Red Hat source package (12330)
622   FreeBSD
624     * Added sysname IDs for 10.2 and 10.3 to fix the build on those platforms
625       (12322)
628 OpenAFS 1.6.18.1
630   Linux clients
632     * Support for mainline kernel 4.5 and distribution kernels with
633       backports from it (12300..12302)
636 OpenAFS 1.6.18
638   All platforms
640     * Documentation improvements (12224 11675 11613 12197)
642     * Improved diagnostics and error messages (12129 12207 12185 12211 12113
643       12215 12216)
645     * Check that CellServDB entries are valid IPv4 addresses, to avoid
646       occasional hangs or potentially other erratic behaviour due to invalid
647       entries (12210) (RT #131794)
649   All client platforms
651     * Gracefully handle cases where a client shutdown sequence is initiated
652       while the client is already shutting down, rather than cause a panic
653       (12179)
655     * Fixed several bugs that could cause erratic behaviour when the write
656       offset into a file was more than 2 GiB beyond the file's current end
657       on the server (12213 12214)
659   All server platforms
661     * Avoid a possible volserver crash during volume dump or restore due
662       to invalid ACL entries (12127)
664     * Allow recovering from a DAFS fileserver operation which allocates a
665       new vnode but fails to update the vnode index, rather than crashing the
666       server (12209)
668     * Fixed a longstanding bug which could damage the volume location database
669       when "vos changeaddr" was run with "-oldaddr" and "-newaddr" and the
670       old address was present in a multi-homed entry (12089)
672   FreeBSD
674     * Added support for releases 10.2 and 10.3 (12232)
676   Linux clients
678     * Support for mainline kernel 4.4 and distribution kernels with
679       backports from it, alas at a performance penalty (12226 12227 12228)
680       (RT #132677 #132819)
682     * Avoid using excessive amounts of kernel memory for dynamically
683       allocated vcaches, by improving the algorithm to free unused ones
684       (12256 12257)
686     * In Red Hat packaging, make the init script use "ip" if available, with
687       "ifconfig" as a fallback (12193)
689   OS X
691     * Basic support for release 10.11 "El Capitan" (12212)
693   IRIX clients
695     * Fixed kernel module builds with optimization (12198) (RT #131261)
698 OpenAFS 1.6.17 (Security Release)
700   All server platforms
702     * Fix for OPENAFS-SA-2016-001: foreign users can create groups as
703       if they were an administrator (RT #132822) (CVE-2016-2860)
705   All client platforms
707     * Fix for OPENAFS-SA-2016-002: information leakage from sending
708       uninitialized memory over the network.  Multiple call sites
709       were vulnerable, with potential for leaking both kernel and
710       userland stack data (RT #132847)
712     * Update to the GCO CellServDB update from 01 January 2016 (12188)
714   Linux clients
716     * Fix a crash when the root volume is not found and dynroot is not
717       in use, a regression introduced in 1.6.14.1 (12166)
719     * Avoid introducing a dependency on the kernel-devel package corresponding
720       to the currently running system while building the srpm (12195)
722     * Create systemd unit files with mode 0644 instead of 0755
723       (12196) (RT #132662)
725 OpenAFS 1.6.16
727   All platforms
729     * Documentation improvements (11932 12096 12100 12112 12120)
731     * Improved diagnostics and error messages (11586 11587)
733     * Distribute the contributor code of conduct with the stable release (12056)
735   All server platforms
737     * Create PID files in the right location when bosserver is started with
738       the "-pidfiles" argument and transarc paths are not being used (12086)
740     * Several fixes regarding volume dump creation and restore (11433 11553
741       11825 11826 12082)
743     * Avoid a reported bosserver crash, and potentially others, by replacing
744       fixed size buffers with dynamically allocated ones in some user handling
745       functions (11436) (RT #130719)
747     * Obey the "-toname" parameter in "vos clone" operations (11434)
749     * Avoid writing a loopback address into the server CellServDB - search
750       for a non-loopback one, and fail if none is found (12083 12105)
752     * Rebuild the vldb free list with "vldb_check -fix" (12084)
754     * Fixed and improved the "check_sysid" utility (12090)
756     * Fixed and improved the "prdb_check" utility (12101..04)
758   All client platforms
760     * Avoid a potential denial of service issue, by fixing a bug in pioctl
761       logic that allowed a local user to overrun a kernel buffer with a single
762       NUL byte (commit 2ef86372) (RT #132256) (CVE-2015-8312)
764     * Refuse to change multi-homed server entries with "vos changeaddr",
765       unless "-force" is given, to avoid corruption of those entries (12087)
767     * Provide a new vos subcommand "remaddrs" for removing server entries, to
768       replace the slightly confusing "vos changeaddr -remove" (12092 12094)
770     * Make "fs flushall" actually invalidate all cached data (11894)
772     * Prevent spurious call aborts due to erroneous idle timeouts (11594)
774     * Provide a "--disable-gtx" configure switch to avoid building and
775       installing libgtx and its header files as well as the depending
776       "scout" and "afsmonitor" applications (12095)
778     * Fixed building the gtx applications against newer ncurses (12125)
780     * Allow pioctls to work in environments where the syscall emulation
781       pseudo file is created in a read-only pseudo filesystem, like in
782       containers under recent versions of docker (12124)
784   Linux clients
786     * In Red Hat packaging, avoid following a symbolic link when writing
787       the client CellServDB, which could overwrite the server CellServDB,
788       by removing an existing symlink before writing the file (12081)
790     * In Red Hat packaging, avoid a conflict of openafs-debuginfo with
791       krb5-debuginfo by excluding our kpasswd executable from debuginfo
792       processing (12128) (RT #131771)
794 OpenAFS 1.6.15 (Security Release)
796   All client and server platforms
798     * Fix for OPENAFS-SA-2015-007 "Tattletale"
800       When constructing an Rx acknowledgment (ACK) packet, Andrew-derived
801       Rx implementations do not initialize three octets of data that are
802       padding in the C language structure and were inadvertently included
803       in the wire protocol (CVE-2015-7762).  Additionally, OpenAFS Rx in
804       versions 1.5.75 through 1.5.78, 1.6.0 through 1.6.14, and 1.7.0
805       through 1.7.32 include a variable-length padding at the end of the
806       ACK packet, in an attempt to detect the path MTU, but only four octets
807       of the additional padding are initialized (CVE-2015-7763).
809 OpenAFS 1.6.14.1
811   Linux clients
813     * Support kernels up to 4.2
815       Due to changes to internal data structures with this kernel release,
816       the OpenAFS client can no longer reset the link count during path
817       lookups. Since volume root directories must behave like symlinks
818       instead of normal directories in order to satisfy Linux kernel
819       invariants, looking up paths containing more than 40 mount points
820       will fail with ELOOP on such kernels.
822 OpenAFS 1.6.14
824   All server platforms
826     * Prior to the OpenAFS security release 1.6.13, the Volume Location
827       Server (vlserver) RPC VL_ListAttributesN2() supported wildcard volume
828       name lookups via regular expression (regex) pattern matching. This
829       support was completely disabled in 1.6.13 because it was judged to be
830       a security risk due to buffer overruns in the implementation, as well
831       as the possibility of denial of service attacks where certain regular
832       expressions could cause excessive CPU usage in some regex
833       implementations.
835       Unfortunately, after 1.6.13 was released, it was discovered that
836       the native OpenAFS 'backup' system uses the VL_ListAttributesN2()
837       regex support to evaluate configured volume sets. If you use the
838       OpenAFS 'backup' system (or another backup system which relies on it,
839       such as Tivoli Storage Manager (TSM, aka Tivoli ADSM)), and are using
840       volume sets which require regular expressions for the volume name,
841       then those volume sets cannot be resolved by OpenAFS 1.6.13. The next
842       paragraph provides details on how to identify any affected volume sets.
844       OpenAFS backup volume sets may be described by fileserver, partition
845       name, and volume name. The fileserver and partition specifications
846       never require regular expression support. The volume name specification
847       always requires regular expression support except for when specifying
848       _all_ volumes via two special cases: the universal wildcard ".*", or "".
849       For example, volume name "proj" or "*.backup" or "homevol.*" all
850       require regex support - even if the specification contains no wildcard
851       characters and/or exactly matches an existing volume name.
853       As a result of this issue, OpenAFS 1.6.14 replaces the 1.6.13 changes
854       to VL_ListAttributesN2. 1.6.14 prevents the buffer overruns and
855       reenables the regex support, but restricts it to OpenAFS super-users
856       and -localauth only. This is sufficient to restore the OpenAFS 'backup'
857       system's ability to work correctly with any previously supported volume
858       set. The OpenAFS 'backup' commands are already documented to require
859       super-user authorization, so this restriction is moot for the backup
860       system.
862       There are no other direct consumers of the VL_ListAttributesN2() regex
863       support in the OpenAFS tree. However, the VL_ListAttributesN2 RPC is
864       publicly accessible and might be used by third party tools directly or
865       indirectly via OpenAFS's libadmin. Any such tools that issue
866       VL_ListAttributesN2 RPCs must now be executed using super-user or
867       -localauth tokens.
869       None of the other security fixes in OpenAFS 1.6.13 are known to have
870       any issues, and are still included unchanged in OpenAFS 1.6.14.
872       If there are any questions concerning the possible impact of OpenAFS
873       1.6.13 or 1.6.14 at your site, please contact your OpenAFS support
874       provider or the openafs-info@openafs.org mailing list for further
875       assistance.
877 OpenAFS 1.6.13
879   All server platforms
881     * Fix for CVE-2015-3282: vos leaks stack data onto the wire in the
882       clear when creating vldb entries
884     * Workaround for CVE-2015-3283: bos commands can be spoofed, including
885       some which alter server state
887     * Disabled searching the VLDB by volume name regular expression to avoid
888       possible buffer overruns in the volume location server
890   All client platforms
892     * Fix for CVE-2015-3284: pioctls leak kernel memory
894     * Fix for CVE-2015-3285: kernel pioctl support for OSD command passing
895       can trigger a panic
897   Solaris clients
899     * Fix for CVE-2015-3286: Solaris grouplist modifications for PAGs can
900       panic  or overwrite memory
902 OpenAFS 1.6.12
904   All server platforms
906     * Avoid database corruption if a database server is shut down and then
907       brought up again quickly with an altered database (11773 11774)
908       (RT #131997)
910   All client platforms
912     * Fixed a potential buffer overflow in aklog (11808)
914     * Avoid a bogus warning regarding the checkserver daemon, which could be
915       logged during startup when the cache initialization was very fast (11680)
917     * Added documentation of the inaccuracy of the 'partition' field in
918       'fs listquota' output for partitions larger than 2 TiB (11626)
920   Linux clients
922     * Support kernels up to 4.1 (11872 11873)
924     * Avoid spurious EIO errors when writing large chunks of data to
925       mmapped files (11877)
927   OS X
929     * Build fixes required at least on OS X 10.10 Yosemite with the latest
930       XCode (11859 11876 11842..11845 11863 11878 11879)
932 OpenAFS 1.6.11.1
934   Linux clients
936     * Support kernels up to 4.0 (11760 11761)
938   FreeBSD clients
940     * Fixed kernel module build on systems with an updated clang which no
941       longer accepts the -mno-align-long-strings as a no-op (11809)
943 OpenAFS 1.6.11
945   All platforms
947     * Allow aklog to succeed creating native K5 tokens even when mapping
948       the K5 principal to a K4 one fails (11538)
950     * Build fixes (11435 11636)
952   All client platforms
954     * Avoid a potential kernel panic due to connection reference overcounts
955       (11645) (RT #131885)
957     * Avoid potential corruption of files written using memory mapped I/O
958       when the file is larger than the cache (11656) (RT #131976)
960   Linux clients
962     * Support kernels at least up to 3.19 (11549 11550 11569 11570 11595
963       11658..11662 11694 11752)
965       Note: By default this excludes kernels 3.17 to 3.17.2, which will leak
966             an inode reference when an error occurs in d_splice_alias(). The
967             module will build and work, but leak kernel memory, leading to
968             performance degradation and eventually system failure due to
969             memory exhaustion. Since it's impossible to detect this condition
970             automatically, the switch --enable-linux-d_splice_alias-extra-iput
971             must be passed to configure when building the module for those
972             kernels. The same would be necessary for any kernel with backports
973             of commit 908790fa3b779d37365e6b28e3aa0f6e833020c3 or commit
974             95ad5c291313b66a98a44dc92b57e0b37c1dd589 but not the fix in commit
975             51486b900ee92856b977eacfc5bfbe6565028070 in the linux-stable repo
976             (git.kernel.org/cgit/linux/kernel/git/stable/linux-stable.git) or
977             the corresponding changes on other branches.
979     * Fixed a regression introduced in OpenAFS release 1.6.10 which could
980       make the spurious "getcwd: cannot access parent directories" problem
981       return (11558 11568) (RT #131780)
983     * Avoid leaking memory when scanning a corrupt directory (11707)
985   OS X clients
987     * Support OS X 10.10 "Yosemite" (11571 11572 11611) (RT #131946)
989   Solaris clients
991     * Avoid reading random data rather than correct cache content when using
992       ZFS as the cache file system on Solaris >= 11, and fix potential similar
993       problems on other platforms (11713 11714)
995   FreeBSD
997     * Build fix for releases >= 11.0 (11610)
999   OpenBSD
1001     * Support release 5.4 (11700)
1004 OpenAFS 1.6.10
1006   All platforms
1008     * Don't hide the "version" subcommand in help output (11214)
1010     * Documentation improvements (11126 11216 11222 11223 11225 11226)
1012     * Improved diagnostics and error messages (11154 11246 11247 11249 11181
1013       11182 11183)
1015     * Build system improvements (11158 11221 11224 11225 11227..11241 11282
1016       11342 11350 11353 11242 11367 11392)
1018     * Avoid potentially erratic behaviour under certain error conditions by
1019       either avoiding or at least not ignoring them, in various places (11008
1020       11010..11065 11112 11148 11196 11530)
1022   FreeBSD
1024     * Support releases 9.3 and 10.1 (11368 11369 11402 11403 11404)
1026     * Makes a disk cache more likely to work on FreeBSD, though such
1027       configurations remain not very tested (11448)
1029   All server platforms
1031     * Added volscan(8) (11252..11280 11387 11388)
1033     * Fixed a bug causing subgroups not to function correctly if their
1034       ptdb entry had more than one continuation entry (11352)
1036     * Logging improvements (10946 11153)
1038     * Allow log rotation via copy and truncate (11193)
1040     * Avoid a server crash during startup only observed on a single platform
1041       and when using a 3rd party library under certain circumstances, which is
1042       a collateral effect of the security improvements introduced in OpenAFS
1043       release 1.6.5 (11075) (RT #131852)
1045   All client platforms
1047     * Raised the free space reported for /afs to the maximum possible value of
1048       just under 2 TiB - the old value was 9 GiB on most platforms (10984)
1050     * Reduced the amount of stack space used (11162 11163 11203 11164..11167
1051       11338 11339 11364..11366 11381)
1053     * Sped up a periodic client task which could be problematically slow
1054       on systems with a large number of PAGs and files in use (11307)
1056     * Fixed failure of the up command with large ACLs (11111)
1058     * Avoid a potential crash of aklog (11218)
1060     * Avoid potential crashes of scout and xstat_fs_test (11155)
1062   Linux clients
1064     * Support kernels up to 3.16 (11308 11309)
1066     * Fixed a regression introduced in OpenAFS release 1.6.6 that made
1067       checking for existing write locks incorrectly fail on readonly volumes
1068       (11361)
1070     * Fixed a regression introduced in OpenAFS release 1.6.8 that could
1071       cause VFS cache inconsistencies when a previously-accessed directory
1072       entry was removed and recreated with the same name but pointing to a
1073       different file on another client (11358)
1075     * Use the right path to depmod in Red Hat packaging to avoid dependency
1076       calculation incorrectly failing unless a link /sbin -> /usr/sbin is
1077       present on the system performing it (11171) (RT #131860)
1079     * Do not ignore kernel module build errors (11205)
1081 OpenAFS 1.6.9
1083   All server platforms
1085     * Fix for OPENAFS-SA-2014-002
1087 OpenAFS 1.6.8
1089   All platforms
1091     * Documentation improvements (10751 10875 10931 10897 10883 10954 10955)
1093     * Improved diagnostics and error messages (10756 10814 10949)
1095     * Fixed a bug in RX that could make errors during packet reception go
1096       unnoticed. (10733)
1098     * Fixed a bug that made "vos size -dump" display the wrong size for
1099       large volumes. (10933)  (RT #131819)
1101   All server platforms
1103     * Change the default fileserver sync behavior from "delayed" to "onclose".
1104       This means that explicit syncing only happens when a volume is detached.
1105       (10809)
1107     * Added the -offline-timeout and -offline-shutdown-timeout options to the
1108       fileserver, to implement interrupting clients accessing volumes we are
1109       trying to take offline. (6266 10799)
1111   All client platforms
1113     * When a client is shut down, it will give up its callbacks. The Windows
1114       client has been doing this since 2007. Note that older fileservers
1115       (1.3.50 to 1.4.5 and 1.5.0 to 1.5.27) had a bug in the implementation of
1116       the relevant RPC that could cause crashes or other undefined behavior
1117       when this happens. (6272 8840 10855)
1119     * Restored the pre-1.6 behavior of "vos e" being an alias for "vos examine".
1120       (10886)
1122     * Avoid flooding logs with warnings about byte-range locks, by throttling
1123       them per file. Also, make the messages more useful by including the
1124       FID. (10836..10839)
1126     * Avoid a possible panic during shutdown while tracing. (10932)
1128   Linux clients
1130     * Fixed a bug that could cause the "getcwd: cannot access parent
1131       directories" problem (10804 10984)
1133     * Avoid a delay when accessing uncached data in AFS in a confined
1134       context under SELinux. (10598)
1136     * Red Hat packaging improvements (10600 10767 10807)
1138 OpenAFS 1.6.7
1140   All server platforms
1142     * Fix for OPENAFS-SA-2014-001
1144     * Fix for a potential DOS attack against RX servers
1146 OpenAFS 1.6.6
1148   All platforms
1150     * As of this release, OpenAFS no longer ships uncompressed source tarballs.
1151       Tarballs are still shipped with both compression formats, gzip and bzip2.
1152       (10131)
1154     * Documentation improvements (10136 10314 10601)
1156     * Improved diagnostics and error messages (9412 10085 10274)
1158     * Avoid redefining "assert" in our public header files, which could
1159       cause failures when building some applications using them. (10096)
1161     * Fixes for parallel builds (10005 10309 10337)
1163     * Added a -s switch to afscp (not installed by default) to help simulate
1164       a slow client. (9416 9417)
1166     * Added a -probe switch to vlclient test program (not installed by default)
1167       to ping all vlservers in a cell in parallel. (9570)
1169   All server platforms
1170     * The fileserver now ignores any vice partitions with a NeverAttach flag
1171       file present in the root directory. (RT #130561) (9470 9471)
1173     * Restrict forcing CPS ("Current Protection Subdomain") recalculation in
1174       the fileserver to administrators. Also fixed a bug that could cause this
1175       operation to be incomplete. (9485 9487)
1177     * Allow non-DAFS fileservers to attach unusable volumes, restoring pre-1.6
1178       behaviour. (RT #131505) (9499)
1180     * Restored the pre-1.6 behaviour when running vos examine for a volume
1181       currently in a transaction, showing the volume as busy again rather than
1182       offline. (9685 9915 9916)
1184     * Reduced the minimum time a bos salvage takes from 5 seconds to 1. (9476)
1186     * Fixed buserver to not segfault when started with the -servers option.
1187       (RT #131706) (10166)
1189     * Salvager fixes, addressing a wide variety of possible problems from
1190       unnecessary salvaging to aborts (9282 9283 9457 9458 9459 9461 9462 9480
1191       9481 10165 10167)
1193     * Fixed a bug that could cause saved state information to be discarded
1194       when restarting a large or busy fileserver, which negatively impacted
1195       performance. (9683)
1197     * Fixed a bug that could have caused undefined behaviour in the vlserver
1198       in rare cases when a fileserver registered its addresses in the VLDB.
1199       (9429)
1201     * Added the -preserve-vol-stats switch to volserver, allowing it to keep
1202       the access statistics across volume restore and reclone operations
1203       instead of resetting them. (9477)
1205     * Inserted an exponential delay between retries when bosserver attempts to
1206       restart a server process. (9571 10199)
1208     * Improved vldb_check (not installed by default) to cope with broken
1209       vlentry names and volids, and provide more output to aid debugging.
1210       (10268)
1212     * Releasing a volume after adding a new RO site no longer touches any of
1213       the existing RO sites, if the RW data hasn't changed since the last
1214       release. (10174)
1216     * Make the copyDate field for RO clones have the same meaning as for
1217       remote RO volumes. Previously, the copyDate field for clones was updated
1218       every time we released. (9451)
1220     * Fixed potentially undefined behaviour in ptserver when too many pts
1221       ids are allocated. (10124)
1223     * Note that the server side NAT pings feature present in the prereleases
1224       was removed before the final release, since no positive feedback
1225       was provided during prerelease testing. (9420 10135)
1227   Linux servers
1229     * Start bosserver with -nofork in the systemd unit file, to allow systemd
1230       to track its state (10093)
1232   All client platforms
1234     * No longer track file locks on read-only volumes. Write locks can't
1235       succeed, read locks always will. Avoids log messages about this kind
1236       of lock. (8910)
1238     * Added the "fs flushall" subcommand, which makes the client discard all
1239       cached data. This was previously available on Windows only. (9065 9388
1240       9389 9390)
1242     * Fixed a bug that could make the client incorrectly believe its cache
1243       is up to date. This change could negatively impact AFS <-> DFS
1244       translators, should those still be running anywhere. (8898)
1246     * Several changes to avoid panicing in certain error conditions.
1247       (9131 9287 10354 10355 10356 10357) (partially addressing RT #131747)
1249     * Added the -rxmaxfrags switch to afsd, allowing to limit the number
1250       of UDP fragments sent or received per RX packet. (9430)
1252     * Build fixes for aklog on several platforms (RT #131716) (9917 10107 10275)
1254     * Require that the AFS mountpoint specified in the cacheinfo file is
1255       an absolute path. Relative paths result in a client that basically
1256       works but is not fully functional. (10253)
1258     * Fixed a bug that could cause one of the afsd threads to enter an infinite
1259       loop (10431 .. 10436)
1261   Linux clients
1263     * Support Linux kernels up to 3.13 (10241)
1265     * Fixed a bug that made readv/writev calls in AFS space fail with Linux
1266       kernels where generic_file_aio_read exists but those operations have
1267       not been switched to using aio_read/aio_write. This was a regression
1268       introduced with release 1.6.3 and affected at least RHEL 5.9 kernels.
1269       (10248)
1271     * Fixed a similar bug making core dumps fail in AFS space, affecting
1272       a much wider range of kernels including the most recent ones.
1273       (RT #131729) (10254)
1275     * Enhanced the keyring code to make PAGs work correctly on kernels with a
1276       distribution specific change to the Linux keyring code. This affected at
1277       least SLES 11 SP3 kernels. (10252)
1279     * Fixed a bug that could make failures during PAG instantiation go
1280       unnoticed. (10255)
1282     * Fixed a bug that made compilation fail for Linux kernels without
1283       keyring support. This affected at least the SLE 10 SDK and an
1284       OEM version of SLES 11 SP1. (10325)
1286     * Fixed build for kernels with user namespace support enabled. Likely
1287       to be required for Ubuntu 14.04 and eventually other distributions.
1288       (10456 10457 10458 10518 10472)
1290     * Support RHEL 6.5 kernels, and possibly others with changes backported
1291       from recent mainline kernels that touch getname/putname, by no longer
1292       using those functions. Previously, the client could cause a kernel
1293       panic when syscall auditing was enabled. (10578)
1295     * Make tmpfs usable as the cache filesystem again. This had been broken
1296       since kernel 3.1 (9950 10193)
1298     * When starting the client fails, clean up the backing device information
1299       created in sysfs, to avoid error messages during a subsequent start
1300       and possible system instability later on (10454)
1302     * Update Red Hat packaging to support Fedora >= 20, RHEL >= 7 and
1303       ELrepo kernels (10597 10619 10622 10703 10704)
1305   OS X Clients
1307     * Support OS X 10.9 "Mavericks" (10519 10541 10542 10543 10548 10549)
1309   AIX clients
1311     * Fixed a bug that caused the 1.6 AIX client to never receive any RX
1312       packets in the kernel. (RT #131725)
1314   FUSE client
1316     * Support Solaris 11 (9454 9455)
1318     * Allow other users to access filesystems mounted by root. (9452)
1320   FreeBSD
1322     * Build tvolser and dvolser on this platform (10122)
1323     * Several fixes to catch up with newer releases (10374 .. 10381)
1325   NetBSD
1327     * Build tsalvaged, tvolser and dvolser on this platform (10121)
1328     * Fixed build on NetBSD 5 and newer. (10138)
1330 OpenAFS 1.6.5
1332 All platforms
1334     * Fixes for OpenAFS-SA-2013-0003 and OpenAFS-SA-2013-0004
1336 OpenAFS 1.6.4
1338 All platforms
1340     * Obey the jumbo/nojumbo settings for ubik servers (the DB servers)
1341       too. In previous releases, those servers may have used jumbograms
1342       even if they were not configured to do so. This change corrects
1343       the actual behaviour, and will improve performance and reliability
1344       for sites where jumbograms are problematic. It could cause a decrease
1345       in performance for sites where jumbograms work, but those can turn
1346       them back on manually.
1348     * Dozens of fixes for common coding problems like use after free,
1349       use of possibly uninitialised memory, reading or writing past the
1350       end of arrays and potential NULL pointer derefences. Spotted by
1351       code analysis tools or human inspection.
1353     * Documentation improvements.
1355     * Fixes and improvements to the diagnostic or log messages printed by
1356       vos, the fileserver and others.
1358     * Build fixes, making parallel builds more reliable with certain
1359       configuration options and helping various platforms including
1360       recent releases of IRIX, Solaris and several flavours of Linux.
1362     * Avoid sending a small amount of data over the wire unencrypted
1363       under certain conditions, and emit the correct error message in
1364       this case.
1366 All server platforms
1368     * Avoid generating duplicate IDs for readonly and backup volumes,
1369       which could happen under certain conditions.
1371     * Allow the fileserver to return volume data like quota or free space,
1372       which is available publicly elsewhere, without the additional access
1373       check for read permissions on a volume's root directory the fileserver
1374       performed before.
1376     * The fileserver now emits a log message when it ran out of memory for
1377       callbacks.
1379     * Avoid several potential fileserver problems, including memory
1380       corruption and segmentation faults, due to client bookkeeping.
1382     * Avoid known cases of silent data corruption due to background syncs
1383       on the fileserver, especially during Copy on Write.
1385     * Make the fileserver sync behaviour runtime configurable. Up to 1.4.5,
1386       we had synchronous syncs which were safe but really slow. Since 1.4.5,
1387       we've had asynchronous syncs which are much faster but believed to
1388       be the cause of rare data corruption issues, and while all known cases
1389       of these happening are believed to be fixed in the 1.6.3 release, doubts
1390       remain. This change allows choosing between those, and in addition allows
1391       to turn syncs by the fileserver off altogether, thus relying on the vice
1392       partition's backend filesystem and the operating system, or to just
1393       execute them when a volume is detached. The default behaviour is
1394       unchanged from releases since 1.4.5, but it's highly recommended to
1395       consider the additional options this change provides. Future OpenAFS
1396       releases will default to "-sync=none".
1398     * For dbservers, avoid a situation where misinterpreting transient
1399       network errors causes long-term issues with achieving ubik quorum.
1401 All UNIX client platforms
1403     * Improvements to the detection of an aklog-specific krb5 configuration
1404       file, for the purposes of turning on "weak crypto" for aklog.
1406     * Fixed a regression introduced in release 1.6.2 which caused the
1407       supposedly persistent disk cache to be discarded upon client start.
1408       (RT #131655)
1410 Linux clients
1412     * Support Linux kernels up to 3.10
1414     * Fixed two bugs making it impossible to unmount a disk cache filesystem
1415       after it has been used by the client. (RT #131613)
1417     * Fixed a bug that could cause an oops with kernels 3.6 and later
1419 OpenBSD
1421     * Improved support for OpenBSD 4.9 to 5.3
1423 OpenAFS 1.6.3
1425   This release number had to be skipped for technical reasons.
1427 OpenAFS 1.6.2.1
1429   Linux clients
1431     * Support Linux kernels up to 3.8.
1433     * Make the init script cope with the output of ifconfig on recent Fedora.
1435 OpenAFS 1.6.2
1437   All platforms
1439     * Fix buffer overflows in fileserver and ptserver.
1441     * Abort an rx connection when given an unknown service (Gerrit 7593).
1443     * "idle dead" behavior improvements.
1445     * Documentation updates.
1447   All server platforms
1449     * Fix rare file corruption during background sync (Gerrit 8796).
1451     * Fix corrupting clients' metadata cache during certain errors (Gerrit
1452       6957).
1454     * Avoid saying a volume doesn't exist when accessed as the volume is
1455       going offline (Gerrit 7488).
1457     * Fix fileservers to properly report >2 TiB partitions.
1459     * Fix stale volume info from vos examine on non-DAFS filservers.
1461     * Fix possible volume corruption with vos convertROtoRW.
1463     * Fix bosserver to preserve all command-line options over restart.
1465     * Fix bosserver to properly kill hung processes during shutdown.
1467   All UNIX client platforms
1469     * Fixes for memcache, especially on Solaris.
1471     * Increase the size of the DNS resolver answer buffer to allow sites
1472       with a long response list to use SRV and AFSDB records.
1474     * Fix a crash when a server appears to run out of addresses (Gerrit
1475       7487).
1477     * Fix cache corruption when reading from a file another client is
1478       simultaneously writing to (Gerrit 7994).
1480     * Improve handling of disk cache disk errors.
1482   Linux
1484     * fix DKMS configuration for DKMS 2.2.
1486     * Avoid generating inode number 0 with md5 inodes (Gerrit 7276).
1488     * Fix a crash when reading /proc/fs/openafs/unixusers (Gerrit 7914).
1490     * Make PAG-less access use the real UID of the calling process
1491       instead of the effective UID, when determining what credentials to
1492       use (Gerrit 7931).
1494     * Fix possible abuse of fs mkmount.
1495       Prior to 1.6.2, users could crash a client by nesting volume mounts.
1497     * Fix fileserver memory corruption on RHEL 6
1498       Prior to 1.6.2, fileservers on RHEL 6 may crash under heavy load.
1500     * Fix client page cache corruption on Linux
1501       When multiple clients read and write to a file, the reading client
1502       may see first page (4096 bytes) of a file as nulls.
1504     * Support Linux kernels up to 3.7.
1506     * Support newer glibc versions.
1508     * Improve client systemd unit file.
1510     * Update Red Hat packaging.
1512   OS X
1514     * Fix crashes on shutdown.
1516     * Prevent unloading the module before shutdown completes.
1518     * Security improvement for the OpenAFS preference pane.
1520   Solaris
1522     * Support newer versions of the Sun Studio compiler software.
1524     * Support compiling on newer versions of Solaris 11 and Solaris 10.
1527 OpenAFS 1.6.0 (2011-08-15)
1529   All platforms
1531     * Substantial Rx updates to correct erroneous behavior.
1533     * vos now properly deals with matching sites when servers are
1534       multihomed.
1536     * Don't stop Rx keepalives after an ackall is received, avoiding
1537       spurious connection timeouts. (128848)
1539     * Don't retry Rx calls on channels returning busy errors and improve
1540       Rx busy call channel error handling. (128671)
1542     * Properly enable Rx connection hard timeouts.
1544     * Rx NAT pings are not enabled until peer has answered.
1546     * Initialize rx_multi lock before use.
1548     * Avoid spurious crashes when initializing in "backup" client.
1550     * Revert UUID support in vos.
1552     * pt_util fixed to properly create new databases.
1554     * MTU discovery now properly shut down on call reset.
1556     * Avoid leaking references to hosts during callback break multi-Rx
1557       operations. (129376)
1559     * xstat tools now cope with differing timeval structures between
1560       endpoints.
1562     * Numerous fixes to command argument parsing.
1564     * Documentation updates.
1566   All server platforms
1568     * A file descriptor leak which could result in corrupted files in the
1569       fileserver was fixed. An IMMEDIATE upgrade from previous 1.5 release
1570       fileservers is recommended.
1572     * Fix ptserver supergroups support on 64 bit platforms.
1574     * Demand attach salvaging doesn't use freed volume pointers.
1576     * Properly hold host lock during host enumeration in fileserver.
1578     * Attempt to recovery more quickly from timed out volume release
1579       transactions.
1581     * Auditing now properly byte order swaps IP addresses when printing.
1583     * vos split now has improved error handling.
1585     * Many changes to again support Windows fileservers.
1587     * During volume removal, data removal speed improved.
1589     * Improve CPU utilization during volume attaching by DAFS.
1591     * In salvager check-only mode, avoid potentially fixing a vnode.
1593     * Fix support for large (greater than 2gb) volume special files.
1595     * Salvager will not crash if multiple or bad volume link tables are
1596       encountered.
1598     * Avoid erroneous full dump by remembering which sites were out of
1599       date at the start of the release.
1601     * A deleted volume can now be recreated properly.
1603     * Callbacks are again not broken during whole partition salvages.
1605     * Positional vectored IO fixed for largefile (>2GB) capable systems.
1607     * Fileserver per-client thread usage again properly enforced.
1609     * Anonymous dropbox support improved and drawbacks documented.
1611     * Demand attach: ensure vnodes are not reallocated while in use due to
1612       volume bitmap errors.
1614     * Properly support large volume numbers (larger than 2147483647).
1616     * Allow salvager to be run manually again when DAFS is being
1617       used. (129458)
1619     * Avoid leaking references to hosts during callback break multi-Rx
1620       operations. (129376)
1622     * Demand attach: unlink fileserver state file on standalone salvage.
1624     * Salvager tries harder to detect linktable issues.
1626     * Demand attach: don't attach volumes with special status set.
1628     * Avoid crashing on host table exhaustion. Instead, defer clients.
1630   Microsoft Windows
1632     * afs_config will not longer set the Tray Icon State in the registry
1633       if the checkbox is not present in the dialog. (128591)
1635     * AFS Explorer Shell Extension now works from folder backgrounds.
1636       Overlays for mount points and symlinks are present in the dll, but
1637       are not registered at present by the installers.
1639     * Do not use RankServerInterval registry value as the value for
1640       PerformanceTuningInterval.
1642     * When the data version of a mountpoint or symlink changes, the target
1643       string in the cm_scache_t object must be cleared.
1645     * "fs checkservers" now includes vldb servers in the output and only
1646       lists multi-homed servers once.  A multi-homed server that has at
1647       least one up interface is no longer considered to be down.
1649     * When asynchronously storing dirty data buffers to the file server
1650       ensure that (a) the cm_scache_t object and the cm_buf_t object are
1651       for the same File ID so that locking and signalling work properly;
1652       and (b) if the FID no longer exists on the file server, do not
1653       panic, just discard the buffer.
1655     * When processing VNOVOL, VMOVED and VOFFLINE errors perform server
1656       comparisons by UUID or address and not simply by cm_server_t
1657       pointer.  Otherwise, server failover may not succeed.
1659     * Do not preserve status information for cm_scache_t objects when the
1660       issuing server is multi-homed.
1662     * Giving up all callbacks when shutting down or suspending the machine
1663       is now significantly faster due to the use of an rx_multi
1664       implementation.  (This functionality is still off by default and
1665       must be activated by a registry value.)
1667     * Race conditions were possible when updating the state of the
1668       cm_volume_t flags and when moving the volumes within the least
1669       recently used list.
1671     * Ensure that the lanahelper library does not perform a NCBRESET of
1672       each lan adapter when enumerating the current network bindings.
1673       Correcting this permits OpenAFS to work on Windows 7 when the
1674       network adapter settings change.
1676     * Fix creation of mount points and symlinks as \\AFS\xxxx
1678     * Icon tray state now conditionally set. (128591)
1680     * Properly create new cell mount points in freelance mode.
1682     * Avoid recursive offline volume checks.
1684     * Fix caching of non-existent volumes.  The test to trigger an
1685       immediate CM_ERROR_NOSUCHVOLUME in cm_UpdateVolumeLocation() was
1686       backwards.
1688     * Prevent the background daemon from checking the status of
1689       non-existent volumes.  cm_CheckOfflineVolumes() should skip volume
1690       groups with the CM_VOLUMEFLAG_NOEXIST flag set.
1692     * The afskfw library should return an error immediately if the
1693       krb5_32.dll library cannot be loaded.  Affects afslogon.dll and
1694       afscreds.exe.
1696     * No longer depend on leashw32.dll in afskfw library.
1698     * NPLogonNotify must provide the user password in all calls to
1699       KFW_AFS_get_cred().  It cannot count on a credential cache being
1700       preserved between calls.  Permits tokens to be acquired for all
1701       cells listed in the TheseCells registry value for a domain.
1703     * Improve the trace logging from NPLogonNotify().
1705     * Avoid a race when writing the cm_scache_t mountPointString
1706       when acquiring mount point or symlink target data via
1707       cm_GetData().  The race could result in bogus target
1708       data being cached.
1710     * Permit the use of des-cbc-md5 and des-cbc-md4 enctypes
1711       as DES keys in asetkey.exe.
1713     * aklog supports dotted Kerberos v5 principal names.
1715     * afskfw library always attempts afs/cell@USER-REALM
1717     * afskfw library must test return code from krb5_cc_start_seq_get() or
1718       will trigger a null pointer exception when using Heimdal.
1720     * Lock protected fields must be 32-bit in order to avoid memory
1721       overwrite races.
1723     * Add support for NTFS symlinks.
1725     * Handle file search requests for virtual syscall ioctl file.
1727     * Process SyncOps properly to enforce ordered operations.
1729     * Avoid recursing during NewServer operations.
1731     * Correct lock acquisition order during SMB locking.
1733     * Add shutdown message to event log.
1735     * Check offline volume status by policy rather than on each daemon
1736       thread run.
1738     * Return error on directory object not found instead of crashing.
1740     * Improve error message output.
1742     * afslogin.dll can start afsd_service if it's not starting or started.
1744     * Optimize away release lock RPCs for deleted files.
1746     * Background Daemon will not perform operations on deleted files.
1748     * Resort recently used directories to the top of the LRU if the
1749       directory is larger than the stat cache.
1751     * Resort deleted objects to the bottom of the LRU.
1753     * Use interlocked operations for state and queue fields to allow safe
1754       bit set and clear on multiprocessor systems.
1756   All UNIX client platforms
1758     * Servers now marked down when GetCapabilities returns error.
1760     * In-use vcache count is now properly tracked.
1762     * Check for /afs existance before starting, unless -nomount is
1763       specified.
1765     * Avoid a potential panic when using /afs/.:mount syntax.
1767     * Avoid a panic in memcache mode due to missing CellItems file.
1769     * FUSE client support fixed for non-/afs mounts.
1771     * Avoid a potential deadlock (which times out) when we need to
1772       allocate more callback returns and must flush some already in use.
1774     * Deal with libcom_err conflicts with other packages using it
1775       (e.g. krb5) (128640)
1777     * Fall back to afs3-vlserver SRV record values when afs3-ptserver SRV
1778       record is not available.
1780     * Avoid holding unneeded locks when probing server capabilties.
1782     * Do not attempt page flushes for directories.
1784     * Rx connection reference counting is enabled.
1786     * An Rx connection reference count leak is fixed in bulkstat.
1788     * Handle unparsable directory objects.
1790     * Handle Kerberos cred cache errors in aklog.
1792   AIX
1794     * Fix PAG usage to track by PAG identifier, not group list.
1796   FreeBSD
1798     * Fix socket termination on shutdown.
1800     * Support for 7.2, 7.3, 7.4 and 8.2 included.
1802     * References to vcaches are no longer leaked during root or reclaim.
1804     * Remove support for "Giant" lock as we no longer need to use it.
1806     * Don't sleep with AFS GLOCK.
1808     * Properly enable 64 bit long long support.
1810     * Restore support for FreeBSD 7 (128612)
1812     * Fix locking issues at shutdown and avoid panic at shutdown due to
1813       vcache flushing.
1815     * Support for virtual network stacks.
1817     * New RC script, updated packaging.
1819   IRIX
1821     * Properly create new vnodes to avoid crashing in the client.
1823   Linux
1825     * Support through kernel 2.6.39.  Treat Linux 3.0 as Linux 2.6 for
1826       sysname purposes.
1828     * Use rx_Readv in cache bypass to improve performance.
1830     * Properly handle 0-length replies during cache bypass operations.
1832     * Properly handle non-contiguous readpage cache bypass operations.
1834     * Do proper locking when transitioning to or from cache bypass.
1836     * Avoid extra runs of vcache freeing routine. (128756)
1838     * Perform vcache eviction via a fast path before visiting vcaches
1839       where sleep is needed.
1841     * setpag() errors are now properly reported.
1843     * Avoid attempting to free stat cache entries when we are below
1844       user-specified number of entries in use.
1846     * Properly track user-specified number of stat cache entries to use as
1847       a desired usage target.
1849     * Don't read pages beyond EOF in the cache. (128452)
1851     * Various corrections and improvements to Red Hat packaging, including
1852       modifying the init script to allow deferring for a new binary
1853       restart and properly supporting RHEL6.
1855     * Fix lockup in 2.6.38 due to erroneous kernel feature configure test.
1857     * Improve RPM building tools.
1859     * Attempt to properly handle SELinux in packaging.
1861     * Init script properly returns status as exit code.
1863     * RPM packaging fixes (executable libraries, no postinstall message)
1865     * Kill i386 from RPM packaging.
1867   MacOS
1869     * MacOS 10.7 support.
1871     * Properly handle setpag errors.  PAGs are not supported.
1873     * Check for unloaded kernel extensions when decoding AFS panics.
1875     * Disable "get tokens at login" in prefs pane if AD authentication
1876       plugin is configured.
1878     * aklog AuthorizationPlugin now provided.
1880     * Preferences Pane behavior fixed for 1.6 series (version detection is
1881       used to select default behavior).
1883     * A potential kernel panic during bulkstat operations is
1884       fixed. (128511)
1886     * 64-bit MacOS kernel performance is greatly improved. (128934)
1888     * Properly shut down AFS, closing the Rx socket in the upcall handler
1889       to avoid attempting to process data after we can no longer do so.
1891     * Rework logic for bulk status operations to avoid a potential hang.
1893     * Avoid panic when doing FSEvent synthesis.
1895     * Fix bug when using non-dynroot.
1897     * Update Kerberos support in PreferencesPane.
1899   NetBSD
1901     * Updates for platform support.
1903   OpenBSD
1905     * Bug fixes for issues introduced previously in 1.5 series.
1907     * Support through OpenBSD 4.8.
1909   Solaris
1911     * Switch to ioctl() syscall replacement for Solaris 11 since syscall
1912       65 is not safe.
1914     * Fix support for Solaris pre-10.
1916     * Corrected Solaris 11 startup script.
1918     * vcache mappings freed on shutdown to avoid panic.
1920     * Properly report errors for AFS system call callers.
1922     * Don't leave dangling function references if kernel extension fails
1923       to load.
1925     * Try harder to avoid deadlocks on file-larger-than-cache operations.
1927     * Avoid panic on shutdown when mount failed.
1930 OpenAFS 1.6.0pre2
1932   All systems: Minor bugfixes.
1934   ADDITIONAL CHANGES IN 1.6.0PRE2
1936   All platforms:
1938     - Documentation updates.
1940     - Don't stop Rx keepalives after an ackall is received, avoiding
1941       spurious connection timeouts. (128848)
1943     - Don't retry Rx calls on channels returning busy errors. (128671)
1945     - vos will not die with a double free error at command completion.
1947     - Properly enable Rx connection hard timeouts.
1949     - Initialize rx_multi lock before use.
1951     - Avoid spurious crashes when initializing in "backup" client.
1953   All unix platforms:
1955     - Check for /afs existance before starting, unless -nomount is specified.
1957     - Avoid a potential panic when using /afs/.:mount syntax.
1959     - Avoid a panic in memcache mode due to missing CellItems file.
1961   All server platforms:
1963     - Attempt to recovery more quickly from timed out volume release
1964       transactions.
1966     - Auditing now properly byte order swaps IP addresses when printing.
1968     - vos split now has improved error handling.
1970     - Many changes to again support Windows fileservers.
1972     - During volume removal, data removal speed improved.
1974     - Improve CPU utilization during volume attaching by DAFS.
1976     - In salvager check-only mode, avoid potentially fixing a vnode.
1978     - Fix support for large (greater than 2gb) volume special files.
1980     - Salvager will not crash if multiple or bad volume link tables
1981       are encountered.
1983     - Avoid erroneous full dump by remembering which sites were out of date
1984       at the start of the release.
1986   FreeBSD:
1988     - Remove support for "Giant" lock as we no longer need to use it.
1990     - Don't sleep with AFS GLOCK.
1992     - Properly enable 64 bit long long support.
1994     - Restore support for FreeBSD 7 (128612)
1996     - Fix locking issues at shutdown.
1998   Linux:
2000     - support through kernel 2.6.38.
2002     - RedHat packaging now properly supports RHEL6.
2004     - Use rx_Readv in cache bypass to improve performance.
2006     - Properly handle 0-length replies during cache bypass operations.
2008     - Properly handle non-contiguous readpage cache bypass operations.
2010     - Do proper locking when transitioning to or from cache bypass.
2012     - Avoid extra runs of vcache freeing routine. (128756)
2014   MacOS:
2016     - Check for unloaded kernel extensions when decoding AFS panics.
2018     - Properly handle setpag errors. PAGs are not supported.
2020     - Disable "get tokens at login" in prefs pane if AD authentication
2021       plugin is configured.
2023   OpenBSD:
2025     - support through OpenBSD 4.8.
2027   Solaris:
2029     - Fix support for Solaris pre-10.
2031   Windows:
2033     - afs_config will not longer set the Tray Icon State
2034       in the registry if the checkbox is not present in
2035       the dialog. (128591)
2037     - AFS Explorer Shell Extension now works from folder
2038       backgrounds.  Overlays for mount points and symlinks
2039       are present in the dll, but are not registered at present
2040       by the installers.
2042     - Do not use RankServerInterval registry value as the value for
2043       PerformanceTuningInterval.
2045     - When the data version of a mountpoint or symlink changes,
2046       the target string in the cm_scache_t object must be cleared.
2048     - "fs checkservers" now includes vldb servers in the output
2049       and only lists multi-homed servers once.  A multi-homed
2050       server that has at least one up interface is no longer
2051       considered to be down.
2053     - When asynchronously storing dirty data buffers to the
2054       file server ensure that (a) the cm_scache_t object and
2055       the cm_buf_t object are for the same File ID so that
2056       locking and signalling work properly; and (b) if the
2057       FID no longer exists on the file server, do not panic,
2058       just discard the buffer.
2060     - When processing VNOVOL, VMOVED and VOFFLINE errors perform
2061       server comparisons by UUID or address and not simply by
2062       cm_server_t pointer.  Otherwise, server failover may not
2063       succeed.
2065     - Do not preserve status information for cm_scache_t objects
2066       when the issuing server is multi-homed.
2068     - Giving up all callbacks when shutting down or suspending
2069       the machine is now significantly faster due to the use
2070       of an rx_multi implementation.  (This functionality is
2071       still off by default and must be activated by a registry
2072       value.)
2074     - Race conditions were possible when updating the state
2075       of the cm_volume_t flags and when moving the volumes
2076       within the least recently used list.
2078     - Ensure that the lanahelper library does not perform a
2079       NCBRESET of each lan adapter when enumerating the
2080       current network bindings.  Correcting this permits OpenAFS
2081       to work on Windows 7 when the network adapter settings
2082       change.
2084     - Fix creation of mount points and symlinks as \\AFS\xxxx
2086   PREVIOUS CHANGES:
2088   All platforms:
2090     - vos now properly deals with matching sites when servers are multihomed.
2092   All Unix platforms:
2094     - Servers now marked down when GetCapabilities returns error.
2096     - In-use vcache count is now properly tracked.
2098   All server platforms:
2100     - Fix ptserver supergroups support on 64 bit platforms.
2102     - Demand attach salvaging doesn't use freed volume pointers.
2104     - Properly hold host lock during host enumeration in fileserver.
2106   FreeBSD:
2108     - Fix socket termination on shutdown.
2110     - Support for 7.2, 7.3, 7.4 and 8.2 included.
2112     - References to vcaches are no longer leaked during root or reclaim.
2114   Linux:
2116     - Define llseek handler to avoid ESPIPE error in 2.6.37.
2118     - Mount interface replaces get_sb (new for 2.6.37, not yet required).
2120     - RedHat init script allows deferring for a new binary restart.
2122     - DEFINE_MUTEX replaces DECLARE_MUTEX for 2.6.37.
2124   MacOS:
2126     - Correct return value from setpag syscall.
2128   OpenBSD:
2130     - Bug fixes for issues introduced previously in 1.5 series.
2132   Solaris:
2134     - Switch to ioctl() syscall replacement for Solaris 11 since syscall 65
2135       is not safe.
2138 OpenAFS 1.5.78 (2010-11-04)
2140   All platforms
2142     * Revisions to Rx to fix performance issues.
2144     * Make fs getfid behave consistently across all platforms. (128372)
2146     * Properly check IDs handed to pts when creating users or groups so
2147       useful error messages can be provided. (128343)
2149     * Correct byte order handling of port in afsconf_LookupServer for SRV
2150       records.
2152     * Force a full dump when releasing to a site which was previously
2153       marked "don't use", in case the previous clone was out of date.
2155   All server platforms
2157     * Demand salvage of attached volumes now correctly track attachment
2158       state.
2160     * Avoid a potential crash due to failure to hold a lock when attaching
2161       a volume fails.
2163   Microsoft Windows
2165     * Track SMB connections by SID rather than username.
2167     * Error write attempts to known-readonly volumes earlier.
2169     * Validate directory buffers to avoid potential crashes.
2171     * Handle VIO errors from bulkstatus.
2173     * Make PMTU discovery configurable and register error handlers for it.
2175   All UNIX client platforms
2177     * Use larger I/O sizes in memcache to improve performance.
2179     * Avoid potential alignment issues doing I/O for pioctl calls.
2181   FreeBSD
2183     * Avoid panicing if the listener process is not findable.
2185     * Avoid deadlock issues while performing lookups.
2187   Linux
2189     * Handle stale file handle errors for some cache partition types.
2191     * Avoid blocking with xvcache lock when attempting to free in-use
2192       vcaches.
2194     * Build fixes for older kernels.
2196     * Properly configure LWP to use ucontext() on platforms where it
2197       should.
2199     * Eliminate spurious errors from AFS system call returns. (126230)
2201   MacOS
2203     * Attempt to honor configured Kerberos defaults in Preferences Pane.
2206 OpenAFS 1.5.77 (2010-09-08)
2208   All platforms
2210     * Rx path MTU detection will terminate detection in cases where the
2211       minimum required packet size cannot be transferred.
2213     * vos dryrun mode now shows effects for syncvldb single volume case.
2215     * vos dryrun mode now shows "status after" for syncvldb and syncserv.
2217   All server platforms
2219     * RXAFS_GetStatistics64 now returns statistics properly.
2221   Microsoft Windows
2223     * Attempt to properly identify the local system SMB connection for
2224       token tracking.
2226     * Remap timeout and offline errors to proper NT RPC errors.
2228     * Properly fail over to other replicas on bulkstat IO errors.
2230     * Properly error delete-mode createfile if a file is set readonly.
2232     * Validate directory entry buffers to avoid crashing the service.
2234     * Log file modes properly.
2236     * Log cell name when logging server information.
2238   All UNIX client platforms
2240     * cacheout program for discarding callbacks is now built.
2242     * bulkstatus kernel locking is corrected to avoid a potential panic.
2244   Dragonfly BSD
2246     * userspace support update
2248   FreeBSD
2250     * Updated vnode locking for children returned via lookup().
2252     * Avoid file open undercount with needed calls to
2253       FakeOpen/FakeClose().
2255     * Use vnode_pager_setsize to properly track file size during kernel
2256       IO.
2258     * Update system call installation.
2260     * Fix shutdown of Rx kernel listener to avoid potential dereference
2261       after it's gone.
2263     * Avoid closing vnodes during vnode recycle.
2265     * Fix bogus call to FlushVS for vnode reclaims.
2267   Linux
2269     * Packaging updated for current configure options and built files.
2271     * Cache bypass now holds reference on pages during readpage.
2273     * s390x setgroups32 patching update.
2275   MacOS
2277     * DNS resolver is reinitialized on IP address change. (126440)
2280 OpenAFS 1.5.76 (2010-08-16)
2282   All platforms
2284     * Updates to build-time configuration.
2286     * Fix XDR support in Rx to match header definition.
2288     * vos status now shows transaction creation, not action creation.
2290     * Rx avoids reporting loopback adapters when listing interfaces.
2292   All server platforms
2294     * Demand-Attach Fileserver always built and installed (dafileserver,
2295       davolserver, dasalvager).
2297     * Return VNOVOL from fileserver when a volume is deleted.
2299     * Ignore duplicate tags during volume restore operation.
2301     * Update inode array after salvage repairs volume.
2303     * Zero a corrupted header in memory during salvage to avoid further
2304       corruption.
2306     * Fix NAMEI backend to allow low-numbered volumes to work properly.
2308     * ptserver does not include cell name as part of length check for
2309       names.
2311     * Updated error messages for unblessed volumes.
2313     * vlserver avoids buffer overflow with regex pattern
2315     * Attach-time failures now note failures as the rest of the fileserver
2316       would.
2318     * Server argument logging will no longer overflow stack.
2320     * Provide fast-restart-like unsafe-nosalvage option for DAFS.
2322     * Deal with host hash collisions in the fileserver.
2324   Microsoft Windows
2326     * Avoid crashing when interpreting a drive letter as potentially
2327       matching a cell name.
2329     * Properly handle volume package errors.
2331     * Allow page recycling from known-readonly content without ensuring
2332       they are not dirty.
2334     * 32 bit tools installer should not override client configuration.
2336     * Ensure root scache item has a valid callback when use is attempted.
2338     * Freelance directory changes now properly invalidate and replace the
2339       old root object.
2341   All UNIX client platforms
2343     * Support disconnected reconnecting with specified UID for PAGless
2344       platforms.
2346     * Proper disconnected vnode reference tracking.
2348     * Update server site blacklisting to not return success if nothing was
2349       blacklisted.
2351     * Avoid a panic during vcache contention due to CVInit vcache
2352       racing. (127645)
2354   FreeBSD
2356     * Update for network stack in 8.1/9.0.
2358   HP-UX
2360     * Bug fixes.
2362   Linux
2364     * 2.6.36 support
2366     * Disable PMTU error packet handling.
2368     * flock() fixes.
2370     * Debian packaging updated.
2372     * freezer interface updates.
2374   MacOS
2376     * Hold references to disconnected mode written vnodes properly.
2378   Solaris
2380     * Handle NFS translator module references for amd64.
2382     * INODE fileserver backend support now exists for amd64.
2385 OpenAFS 1.5.75 (2010-07-07)
2387   All platforms
2389     * Prevent rx_rpc_stats global lock from being a bottleneck.
2391     * Path MTU discovery is now provided to allow traffic to pass networks
2392       with sub-1500 byte MTUs and poor fragment handling.
2394     * Further reduce Rx NAT ping transmission when enabled.
2396     * Update Kerberos 5-based token handling in rxkad from upstream
2397       Heimdal.  (127554)
2399     * Update version numbers emitted during build to reflect what is
2400       actually being built.
2402     * Add "-human" switch for human-readable units in fs diskfree and
2403       listquota. (124529)
2405     * vos provides reasons for locked volumes when known.
2407     * Do not count retransmission and ping acks as non-idle for Rx
2408       connections.
2410     * Rx: provide service-specific data getter and setter routines.
2412     * Update build-time Kerberos detection.
2414     * Updated userspace AFS client.
2416     * Beginning of a modernized test suite.
2418     * Additional documentation.
2420     * Updated documentation, notably the Administrators Guide.
2422     * Substantial code cleanup.
2424   All server platforms
2426     * Update handling of vnode allocation failures.
2428     * DAFS: allow salvaging volumes not known to the fileserver, to allow
2429       cleanup of data not attached to a current volume.
2431     * Properly handle volumes slated for destruction.
2433     * Handle volumes with many files properly.
2435     * Force core file generation in bosserver by overriding default
2436       resource limits when possible.
2438     * Update vlclient and vldb_check.
2440     * Avoid potentially corrupting a volume on creation if files are left
2441       from previous failed cleanup.
2443     * Note volume changed during salvage as needed.
2445     * DAFS: do not assume invalid addresses are in fileserver address hash
2446       table.
2448     * Avoid tying up fileserver threads with volumes that are being taken
2449       offline.
2451     * Do not set inUse on volumes for non-DAFS other than in fileserver.
2453     * Break origin's callback on target of rename operation.
2455     * Avoid unneeded parent directory link updates during some rename
2456       operations.
2458     * Do not open /dev/console for writing in the fileserver.
2460     * DAFS: avoid spurious restarts when binary restarts are configured.
2462     * Avoid spurious and unneeded calls to sync(), which can slow down the
2463       fileserver.
2465   Microsoft Windows
2467     * Revised SMB QuerySecurityInfo to address issues caused by MS10-020
2468       (http://support.microsoft.com/kb/980232)
2470     * Prevent use of the AFSCache file contents if mapped to a new
2471       address.
2473     * Make fs newcell include behavior compatible with the non-Windows
2474       version.
2476     * Provide a registry option (FreelanceImportCellServDB) to pre-create
2477       mount points in the AFS root for all cells in CellServDB.
2479     * Fix a memory leak in the cm_FreeServerList() routine.
2481     * Reduce privilege when reading registry CellServDB.
2483     * Add support for RPC Pipe Service NetWkstaGetInfo levels needed for
2484       Windows 7.
2486     * Prevent overflow when computing quota percentage in Explorer Shell.
2487       (126846)
2489     * Generate meaningful errors for ACL operations on freelance AFS root.
2491     * Fix error handling on InlineBulkStatus RPCs.
2493     * Show configuration pages for all types of MSI installations.
2495     * Improve freemount AFS root directory handling and operations.
2497     * Properly validate GetVolumeStatus pioctl responses.
2499     * Commit file length changes and dirty buffers when flushing a file.
2501   All UNIX client platforms
2503     * Update version of files for disk cache.
2505     * Do not call afs_FlushVCBs with xvcache lock held, to improve
2506       parallelization.
2508     * Add mariner log messages for creating and removing files.
2510     * Don't hold xvcache lock while creating symlinks, to improve
2511       parallelization.
2513     * Provide -dynroot-sparse mode to not show all cells in CellServDB in
2514       dynroot mode.
2516     * Avoid a potential crash in aklog in linked cell handling.
2518     * Log MTU-caused packet retransmission.
2520     * Prevent crashes caused be fs checkservers while cache is being set
2521       up.
2523     * fs getserverprefs now has a buffer large enough for the default
2524       CellServDB.
2526     * Report server address when logging warnings.
2528     * Avoid panic in GetCapabilities when cell is not known.
2530     * Lock process name and id for advisory lock warnings when possible.
2532     * Handle need for allocating additional Rx packets.
2534     * Properly handle errors from InlineBulkStatus operations.
2536     * Fix errors returned from fcntl() on readonly files locked for write.
2538     * Flush pending changes to the server on LOCK_EX unlock.
2540     * Reflect length changes as a result of callbacks even when file is
2541       open for write.
2543     * Avoid hanging due to error exit when attempting to store a large
2544       file to a non-largefile fileserver.
2546     * Recover from afs_GetVolSlot errors.
2548   FreeBSD
2550     * Bugfixes for kernel VFS and network routines.
2552   IRIX
2554     * Provide makesname().
2556   Linux
2558     * Avoid syscall probes when keyrings are present, by default. (125215)
2560     * Remove "Big Kernel Lock" from VFS operations.
2562     * Use filehandles for all Linux 2.6 versions to avoid need for matched
2563       afsd. (127530)
2565     * Updated RPM packaging.
2567     * Fix dkms configuration provided with RPMs.
2569     * Hold reference on pages during background I/O for cache bypass.
2571     * Fix cache bypass handling of non-largefile fileservers.
2573     * Protect truncate_inode_pages mappings with mutex or semaphore as
2574       needed.
2576     * Fix pagevec use in cache bypass. (127505)
2578     * Updates for 2.6.35
2580   MacOS
2582     * Improve launchd configuration.
2584     * Avoid hanging on recursive cache file lock acquisition when user
2585       notification is enabled.
2587     * Fix and re-enable bulkstat mode.
2589   OpenBSD
2591     * Build updates.
2593   Solaris
2595     * Precluding unmount while AFS is busy.
2597     * Avoid deadlocking when releasing the VFS object.
2599     * Stop network interface poller in kernel on AFS shutdown.
2601     * Avoid issues with lookups on empty directory names. (127356)
2604 OpenAFS 1.5.74 (2010-04-22)
2606   All platforms
2608     * Add "vos setaddrs" command.
2610     * Rx library lock contention avoidance between rx_NewCall and
2611       rx_EndCall.
2613     * Rx library races due to inconsistent use of rx_connection
2614       conn_data_lock to protect the flags field.
2616     * Rx library inconsistent use of RX_CALL_TQ_WAIT which could result in
2617       deadlocks.
2619     * Rx library must signal transmit queue waiters when flushing.
2621     * afsmonitor shows busy counts now.
2623     * afsmonitor displays xstat callback statistics.
2625     * Provide expandgroups for pts mem on a supergroups server.
2627     * Provide supergroup option to liste nested groups during pts mem.
2629   All server platforms
2631     * Avoid volume lock contention during DAFS startup.
2633   Microsoft Windows
2635     * Avoid a race when updating cell vldb server lists that can result in
2636       a crash.
2638     * Avoid a deadlock when managing CM_SCACHESYNC_STOREDATA state
2639       operations for directory objects.
2641     * Add new Windows Application Event log messages for VBUSY,
2642       VRESTARTING, ALL_BUSY, ALL_OFFLINE, and ALL_DOWN.
2644     * Reduce lock contention by waiting for cm_buf_t I/O operations.
2646     * Split the cm_buf_t flags field to separate the flags that are
2647       protected by the cm_buf_t mutex from those protected by the
2648       buf_globalLock.
2650     * In cm_UpdateVolumeLocation, avoid searching for a ".readonly" volume
2651       on a numeric volume name.
2653     * File buffer allocations whose offsets are beyond server EOF should
2654       be locally allocated and zero filled.  The file server should not be
2655       issued a FetchData rpc which is guaranteed to fail.
2657     * Enable integrated logon to work with Windows 7/2008 when user logons
2658       are performed with a non-Domain Kerberos principal.
2660     * Add Protection Error messages to aklog output.
2662   All UNIX client platforms
2664     * Provide a FUSE-interfacing userspace afs client.
2666     * Updates to libuafs userspace cache manager.
2668     * Probe servers using GetCapabilities instead of GetTime, thus
2669       requiring fewer RPCs.
2671     * Fix DNS SRV record handling for cell lookup.
2673   FreeBSD
2675     * Fix sleep/wakeup routines.
2677     * Update for 8.0 release.
2679   Linux
2681     * Handle high memory addresses correctly.
2683   MacOS
2685     * Make 32 bit AFS syscalls work again.
2687     * Work around finder "Duplicate" failure (caused by setting modes on
2688       symlinks).
2690     * Disable bulkstat again (will be re-enabled at or before .75).
2692     * Provide symlink type hints during readdir.
2695 OpenAFS 1.5.73 (2010-03-24)
2697   All systems: Minor bugfixes. New features.
2699   * New functionality:
2701   All systems:
2703     - NAT keepalive support at Rx level.
2705     * Bugfixes:
2707   All systems:
2709     - Corrected server IP address output in vos syncvldb verbose mode.
2711     - Corrected server IP address output for last "yes" host in udebug.
2713     - Corrected SRV record support for canonicalizing cell names.
2715   All UNIX clients:
2717     - Fixed a potential race in Disconnected AFS "remove" support.
2719     - Fix a potential blocking condition in fakestat mode.
2721     - Avoid some errors and stack overflow reports when vos is interrupted.
2722       (33360,125535)
2724     - Clean up several minor memory leaks.
2726     - If a large file is stored to a non-largefile fileserver, avoid
2727       a potential deadlock.
2729     - Increase maximum number of sysnames to 32.
2731     - Readd fs mariner "storing" message, missing since AFS 3.3.
2733     - Attempt timeouts on AFSDB lookups in userspace.
2735     - Avoid interrupting writes due to an idle deadtime timeout.
2737   All server platforms:
2739     - Properly notify only affected hosts for volume callbacks. (126497)
2741     - Allow volumes with trashed root directory to be recovered. (94658)
2743     - Hold lock in file and volservers when traversing partition list.
2745     - Use finer-grained locking in DAFS: volume, instead of partition locks.
2747     - Schedule all DAFS salvages via FSSYNC.
2749     - Avoid stale ptserver credential caching issue on keyfile update.
2751     - Improve callback table overflow handling. (126451)
2753     - Preclude deadlocks on when attempting to save DAFS state.
2755     - Avoid races deleting hosts. (126454)
2757     - Improve salvage speed for DAFS (124488)
2759     - The bosserver now handles SIGTERM.
2761   Microsoft Windows
2763     - Prevent the Explorer Shell extension from crashing if symlink
2764       creation failed.  (126406)
2766     - A Rx level NAT ping has been implemented. A registry value enables.
2768     - Adds krb5 error message translation to aklog, afscreds,
2769       afslogon.dll, the network identity manager afs provider and
2770       translate_et.
2772     - Default mode bit settings for file and directory creation are now
2773       provided, and can be configured.
2775     - An SMB request trace facility is provided and can be enabled for
2776       debugging.
2778   AIX:
2780     - Clean up properly on mount failure.
2782     - Add entry to /etc/vfs to allow umount to work.
2784   FreeBSD:
2786     - Additional work to support FreeBSD 8-current.
2788   IRIX:
2790     - Fix build issues with library order.
2792   Linux:
2794     - Fix s390 support conflict with executable stack patches.
2796     - Don't count root's AFS session keyrings against quota.
2798     - Correct dkms support in RPM config file.
2800     - Keyring destructor now properly cleans up all tokens.
2802     - Build again on old 2.6 kernels.
2804     - Avoid GLOCK leak when updating CellServDB in-core.
2806     - Fix byte-range lock handling.
2808     - Attempt to deal with bdi issues. (126514)
2810   MacOS:
2812     - Some FSEvents hinting for authentication events now done. (23781)
2814     - Update uninstaller. (125634)
2816     - Rewrite afssettings and fstab code to avoid licensing issue with APSL.
2818     - Growl client for user monitoring of AFS events included.
2820     - Properly support insert-only dropboxes.
2822     - Add bulkstat support.
2824     - Include support for moving in Finder across mount points.
2826     - Preferences Pane includes support for Kerberos 5 ticket renewal.
2828   OpenBSD:
2830     - Some support for OpenBSD 4.7.
2833 OpenAFS 1.5.72 (2010-02-15)
2835   All platforms
2837     * Provide internationalization support in com_err.
2839     * Fix array length checking to avoid crashes when checking for a
2840       volume type based on name in vos.
2842   All server platforms
2844     * Provide backward compatible "-f" flag to salvager for force mode.
2846   Microsoft Windows
2848     * Restore use of DNS AFSDB and SRV records by kaserver clients.
2850   All UNIX client platforms
2852     * Fix client cache file truncation to not lose chunks when truncating
2853       a large file.
2855     * Ensure a cache writeback hook is installed in the client (bug from
2856       1.5.71).
2858     * Avoid spurious free memory warnings during clean shutdown.
2860     * Fakestat mode avoids AFSDB lookups.
2862     * "fs storebehind" now correctly reports errors on readonly volumes.
2864     * Additional documentation for "fs getcacheparms"
2866     * Forced new uuid generation with "fs uuid -generate" now works
2867       enforced permission correctly.
2869   MacOS
2871     * Add optimized Rx event handler in kernel.
2873     * Installer now allows installing an older version.
2875     * Panic decoder can now deal with MacOS 10.5 again.
2877     * MacOS ._ files are now correctly not looked up as cellnames.
2879   Linux
2881     * To deal with SELinux file labeling, try cache accesses with current
2882       credentials in event of failure.
2884     * Rx XDR encoding bug on i386 Linux is fixed (bug introduced in
2885       1.5.71).
2887   IRIX
2889     * Code compilation fixes.
2891   OpenBSD
2893     * Update for OpenBSD 4.6.
2896 OpenAFS 1.5.69 (2010-01-19)
2898   All platforms
2900     * Configuration of BOSserver no longer defaults to weekly restarts
2901       enabled.
2903     * Provide BOS restricted mode by default.
2905     * Add support for "vos endtrans" command.
2907     * Default to providing full output from vos listvol.
2909     * Correct additional-address tracking in the fileserver.
2911     * Improve Rx performance by not unnecessarily dropping and reacquiring
2912       call locks in read and write processes.
2914     * Avoid crashes when monitoring volserver transactions across
2915       potential transaction garbage collection.
2917     * Numerous warning fixes.
2919   All server platforms
2921     * Avoid saving fileserver state in demand attach fileserver when
2922       panicing.
2924     * Demand attach fileserver allows other callers to schedule salvages.
2926     * Demand attach "bos salvage" now works correctly with restricted
2927       mode.
2929   Microsoft Windows:
2931     * Numerous changes to the client-internal btree directory handling to
2932       prevent errors.
2934     * fs examine reports owner and group ids as signed values (PTS groups
2935       are negative).
2937     * Preclude corruption due to races writing to smb buffers.
2939     * Allow MTU settings in registry to be used.
2941     * Apply MTU to both send and receive sizes.
2943   All UNIX client platforms
2945     * Avoid double-freeing Rx call structure if reading a response from
2946       the file server results in a short read.
2948     * Handle negative lengths in FetchStatus results correctly.
2950     * Properly clean up allocated memory at shutdown.
2952     * Default to AFSDB compiled into the cache manager.
2954     * Avoid inadvertant disclosure of stat() information to clients not so
2955       entitled.
2957     * Correct a bug with AFSDB lookups introduced with SRV record support.
2959   MacOS
2961     * Install kernel panic processing tool in /Library/OpenAFS/Tools.
2963     * Include debugging symbols for kernel extension in additional package.
2965     * Support "Application Firewall" users.
2967     * Avoid ._cellname AFSDB lookups.
2969     * Compile preferences pane as a universal binary.
2971   Linux
2973     * Use splice to speed up storing files.
2975     * When using memcache, avoid duplicating work in readpages.
2977     * Use dget_parent to safely find an inode's parent.
2979     * Disable access time updates in our superblock.
2981     * Avoid crashing doing writeback if no credentials were stashed at
2982       file open.
2984     * Simplify keyring support.
2986     * Properly clean up vcache in event of failed mount.
2988   FreeBSD
2990     * Update for current FreeBSD 8.
2992   Solaris
2994     * Abstractly manipulate groups as now required.
2996     * Abstractly access time instead of using lbolt directly.
2999 OpenAFS 1.5.68 (2009-12-08)
3001   All platforms
3003     * aklog now attempts to convert non-AFS errors to human-readable
3004       strings.
3006     * Make stack not executable when compiling assembler source with GCC.
3008     * Numerous source warning cleanups and code reorganization.
3010   All server platforms
3012     * Compute midnight for volume statistics calculation from local time.
3014     * Salvager now orphans duplicate special inodes when running to allow
3015       recovery in event of a problem, instead of simply ignoring the
3016       issue.
3018     * Support to ensure a server panic attempt leaves a core and thus
3019       restarts in a timely manner, rather than potentially hanging. Use
3020       panic to attempt cleanup before leaving a core when possible.
3022     * Volume sync data reported during bulkstatus is now set correctly.
3024     * Provide better tuning for fileserver file descriptor caching.
3026     * Allow more than 128 threads in fileserver by modifying host
3027       structure in-use tracking.
3029     * Avoid crashes getting volume server status during transaction
3030       cleanup.
3032     * Improved logging of offline volume conditions.
3034     * Correct volume statistics when cloning a volume.
3036     * Avoid referencing host structures in the fileserver which are marked
3037       for deletion.
3039     * Demand attach fileserver corrections to avoid coring during an
3040       aborted startup.
3042     * host array bounds checking corrections to avoid buffer overflow.
3044     * Handle special inodes correctly when promoting an inode fileserver
3045       readonly volume to read-write.
3047   Microsoft Windows
3049     * Set the DOS Readonly attribute on a file/directory whenever the unix
3050       mode combined with the mask 0200 is true.  Previously there was a
3051       discrepency between the mask used for testing for readonly behavior
3052       and that used for setting the attribute.
3054     * Disable AFSVolSync based .readonly "whole-volume callback" support
3055       because the all file servers prior to 1.5.67 (and perhaps 1.4.12) do
3056       not properly assign a value to the AFSVolSync structure in bulk
3057       status RPC responses.
3059     * Improve the error output from aklog to output the value from krb5
3060       error_message() if the afs_com_err output indicates an unknown
3061       value.
3063     * Convert VBUSY and VRESTARTING to CM_ERROR_ALLBUSY and do not permit
3064       them to be exposed to the smb redirector.
3066     * Convert STATUS_TIMEOUT responses to STATUS_IO_TIMEOUT to avoid
3067       confusion within the smb redirector.
3069     * Fix the byte order assigned to port numbers associated with AFSDB
3070       record lookups.  They must be network byte order not host byte
3071       order.
3073     * Add dynamic server ranking based on RPC round trip time
3074       measurements.
3076   All UNIX client platforms
3078     * Additional shutdown-time memory leaks removed.
3080     * Improved logging of resource contention.
3082     * Provide dumping for Rx debug packet tracking support in source.
3084     * Update afscp test client to build, and provide an unlock client.
3086     * Client buffers for directory parsing can now be allocated beyond the
3087       fixed set formerly provided.
3089     * Work around race condition when manipulating read-only volume
3090       callbacks.
3092     * Bugfixes to get PAG value pioctl.
3094     * Bugfixes to SRV record support.
3096   Linux
3098     * Path MTU tracking code cleanup.
3100     * Avoid an oops due to racing with vcache recycling thread.
3102     * Changes to keyring PAG handling: for sufficiently new kernels, use
3103       only keyring-based PAGs, and disable group PAGs entirely.
3105     * Updates to the kernel page cache interface: writing pages will now
3106       not spuriously leak page locks, and will avoid requiring duplicate
3107       work.
3109     * Credential references are now tracked using native atomic counters.
3111     * Kernel mutex/semaphore lock ordering fix to avoid deadlocks.
3113     * Manipulate disk cache with credentials used to initialize it, to
3114       avoid security issues.
3116   MacOS
3118     * Fix fstrace message catalog location.
3120     * Fix kernel fstrace logging.
3123 OpenAFS 1.5.66 (2009-10-25)
3125   All platforms
3127     * Avoid calling exit() in library code.
3129     * Add rx window size and peer timeout tuning APIs.
3131     * Correct rx peer timeout handling to disallow 0ms timeouts.
3133     * Correct calculation of rx RTT by disregarding retransmitted packets.
3135     * vos manpages updated to reflect changes in recent versions.
3137     * GNU-style long options (e.g. --cell) are now supported in all
3138       commands.
3140     * fs listacl can now print a command to recreate the current ACL.
3142   All server platforms
3144     * Fix a race on transaction objects in the volserver which can cause a
3145       crash.
3147     * Avoid destroying and setting to NULL the callback connection when it
3148       could still be being used.
3150     * Correct unlink handling in salvager.
3152     * Improve error messages due to I/O errors in the volserver.
3154     * Correct an issue which caused converted RO to RW volumes on namei
3155       fileservers to not come online immediately.
3157   Microsoft Windows
3159     * Official support for Windows 7 and Server 2008 R2.
3161     * Prevent a file server bug (FetchData returning an invalid length
3162       instead of zero) from causing an "unexpected network error" when
3163       writing to files.
3165     * Promote DNS SRV records as superior to DNS AFSDB records.  Support
3166       arbitrary port numbers for vldb servers.
3168     * Add AFSVolSync based .readonly "whole-volume callback" support.
3169       With this functionality, multiple objects from a .readonly volume
3170       can have their status validated by issuing a single
3171       RXAFS_FetchStatus RPC.
3173     * Remove drive mapping functionality and service start/stop from
3174       afscreds.exe.
3176     * Remove drive mapping functionality from afs_config.exe.
3178     * Use {HKLM,HKCU}\SOFTWARE\OpenAFS\Client DWORD "ShowMountTab" to
3179       restore access to drive mapping functionality in afscreds.exe and
3180       afs_config.exe.
3182     * Adjust SMB error return codes to avoid returning STATUS_TIMEOUT
3183       which results in the SMB redirector disconnecting.
3185     * Network Identity Manager OpenAFS Provider now provides its own "AFS
3186       lock" notification icon to report the status of "have tokens, have
3187       no tokens, service not started, service started but inaccessible".
3188       Hovering over the icon lists the cells for which tokens exist (if
3189       any) and the OpenAFS version number.  Double-clicking executes the
3190       Network Identity Manager default action.
3192     * Prevent pioctl calls from retrying indefinitely when a sharing
3193       violation error occurs.
3195   All UNIX client platforms
3197     * Correct a condition which could discard the error from initializing
3198       a fetch request.
3200     * Avoid using invalid references to afs_Conn connection structures,
3201       and thus potentially producing invalid data when a retry is needed.
3203     * SRV records are now supported for discovering AFS servers.
3205   Linux
3207     * Correct writepage behavior.
3209     * Fix error code handling in the writepage code.
3211     * Avoid leaking page locks, which could potentially hang a machine.
3213   MacOS X
3215     * Preferences Pane improvements.
3217   HP-UX
3219     * Avoiding attempting to handle critical signals in servers, so that
3220       core file handling works correctly.
3223 OpenAFS 1.5.65 (2009-10-06)
3225   All platforms
3227     * Code compilation warning fixes, to enable better finding and
3228       tracking bugs.
3230     * Provide configure-time switch to enable code warning compilation.
3232   All server platforms
3234     * Demand-attach fileserver now makes volume LRU list operations
3235       exclusive operations to avoid races during adding to the list.
3237     * Fileservers now avoid potential "negative length" fetches.
3239     * A leak in host tracking objects in the fileserver has been fixed.
3241     * Salvager now unlinks all files by full path, to deal with the change
3242       to not chdir for core file tracking.
3244     * Salvager avoids asserting if the volume header is unreadable.
3246     * Demand-attach fileserver puts back volume references from fssync
3247       handlers when done.
3249   Microsoft Windows
3251     * Improved service response to suspend and shutdown event
3252       notifications.
3254     * Avoid a bug in the file server that can result in an invalid length
3255       being returned as part of a fetch data response if the client
3256       attempts to read beyond the length of the file.
3258     * Do not publish a default stream object for directories and mount
3259       point objects.  This was impacting the ability of some Windows XP
3260       systems to save roaming profiles.
3262   All UNIX client platforms
3264     * A bug which could cause erroneous handling of lengths on data reads
3265       has been fixed.
3267     * A bug where erroneous length returns from the fileserver could
3268       result in a false error has been fixed.
3270   Linux
3272     * Background page copies are now supported for enhanced disk cache
3273       read performance.
3275     * Blocking readahead is supported in readpages() to reduce overhead.
3277     * Use readpage() instead of read() to access cache data to avail disk
3278       cache users of the kernel backing cache for improved performance.
3280     * Minimize credential handling for improved performance.
3282   MacOS X
3284     * Preferences Pane cleanup.
3286   Solaris
3288     * Provide a fs_pathconf method with sensible defaults.
3290     * Provide a _PC_FILESIZEBITS method to fix some NFS translator
3291       consumers.
3294 OpenAFS 1.5.64 (2009-09-22)
3296   All server platforms
3298     * The demand attach fileserver now puts back volume references gotten
3299       via the fssync interface.
3301     * The demand attach fileserver had a structure reference error, which
3302       has been correected.
3304   Microsoft Windows
3306     * Restores Windows 2000 compatibility.
3308     * Fixes a data consistency error between the output of NetWkstaGetInfo
3309       and NetServerGetInfo RPCs, specify the Lan workstation group name
3310       "AFS", and report server name as "AFS" instead of "\\AFS" when the
3311       caller asks for "\\AFS".
3313     * Enables executables to be run from \\AFS on Windows 7.  Returns
3314       "Name not found" instead of "File not found" when a directory or
3315       file name cannot be found.  This avoids loader errors when system
3316       dlls cannot be located in the executable directory.
3318     * Prevents cache manager from marking the file server "down" when the
3319       data returned in response to either RXAFS_FetchData64 or
3320       RXAFS_StoreData64 is invalid.
3322     * Adds pioctl data validation to the AFS Explorer Shell extension.
3324   All UNIX client platforms
3326     * A bug which could cause a kernel panic in 1.5.63 has been corrected.
3327       This would manifest as a GetDCache panic or oops.
3329   Linux
3331     * aklog -setpag works again with recent kernels when keyring is in
3332       use.
3334   MacOS
3336     * When Fast User Switch is in use, AFS login is now handled correctly
3337       by the integration tool included with the preferences pane.
3339     * Several packaging bugs have been corrected.
3342 OpenAFS 1.5.63 (2009-09-11)
3344   All platforms
3346     * The restorevol command is now documented and installed as a user
3347       command.
3349     * The uss command now properly translates vldb entries to its expected
3350       format when handling them in all cases.
3352     * Documentation now refers to Kerberos instead of kaserver.
3354   All server platforms
3356     * bosserver now handles BosConfig.new when restarting, allowing
3357       configuration to be replaced at restart time rather than with bos
3358       delete and bos create.  Documentation is updated to reflect this.
3360     * The demand attach fileservice not longer potentially hangs trying to
3361       terminate demand-salvages which have already exited.
3363     * The demand attach fileservice has been modified to avoid spurious
3364       'SYNC_putRes: write failed' warnings when some protocol messages
3365       cannot be acknowledged due to the sender terminating the connection.
3367     * In the event of failure to contact the vlserver or ptserver, the
3368       fileserver will not exit and trigger a forced salvage. It will
3369       continue to try in the background to contact the needed services.
3371     * The salvager can now repair certain cases of a damamged vnode index.
3373     * The accessDate metadata for a volume is now updated correctly.
3375   Microsoft Windows
3377     * CRITICAL: Some applications for example those based on Cygwin were
3378       unable to access data stored in the AFS name space.  Explorer Shell
3379       also experienced inconsistent behavior.  This is fixed.
3381     * CRITICAL: Multiple AFS pioctl requests issued nearly simultaneously
3382       by applications could result in pioctl responses being received by
3383       the wrong requester.  This in turn could result in application
3384       crashes.  symlink.exe, fs.exe, afslogon.dll, afscreds.exe, and the
3385       netidmgr afscred.dll plugin were all affected.
3387     * Some XP machines running 1.5.62 had trouble saving roaming profile
3388       data.  This is fixed.
3390     * Integrated Logon (afslogon.dll) did not function with domain
3391       specific configurations.
3393     * Ensure that access denied and over quota errors experienced while
3394       storing data to the file server do not result in on-going retry
3395       attempts.
3397   All UNIX client platforms
3399     * Except on Solaris and AIX, the compiler may now be overriden at
3400       configure time by setting the CC environment variable.
3402     * afsd now properly deals with large cache partitions.
3404   FreeBSD
3406     * Build shared libafsauthent and libafsrpc.
3408   Linux
3410     * Kernel module DKMS support now installs an unstripped module to
3411       allow debugging information to be collected.
3413   MacOS
3415     * Preferences pane properly updates token information.
3417   MacOS 10.6
3419     * klog will now properly handle passwords of 8 or fewer characters
3420       with an AFS string to key on hosts able to run 64 bit binaries.
3422     * A panic at AFS shutdown due to "NO PCB" on a udp_lock has been
3423       addressed.
3425     * The panic decoder script included in the source now properly handles
3426       32 and 64 bit panics.
3428   NetBSD
3430     * Avoid defining AFS_KERBEROS_ENV globally as it creates a circular
3431       dependency.
3433     * Build shared libafsauthent and libafsrpc.
3435   OpenBSD
3437     * Build shared libafsauthent and libafsrpc.
3440 OpenAFS 1.5.62 (2009-08-28)
3442   All platforms
3444     * Numerous invisible changes to improve code maintainability,
3445       portability and enhanceability.
3447   Microsoft Windows
3449     * CRITICAL: Fixes two errors that can result in data loss when storing
3450       data to the file server.
3451       1. Failure to Store Portions of Unaligned Writes
3452       2. Failure to Store Data to File Servers Lacking Large File Support
3453       Read the announcement for more details:
3454         http://www.openafs.org/pipermail/openafs-announce/2009/000305.html
3456     * CRITICAL: The cache manager daemon thread could terminate when the
3457       machine enters suspend mode.  This daemon thread performs the
3458       background check of down servers, offline volumes, callback
3459       expirations, etc.
3461     * CRITICAL: Integrated Logon (afslogon.dll) was terminating
3462       unexpectedly.  Error checking has been improved and NULL pointer
3463       dereferences after Lsa API calls fail have been eliminated.
3465     * For the first time, the OpenAFS SMB Server supports the DCE RPC
3466       services SRVSVC and WKSSVC.  Browsing \\AFS with the Explorer Shell
3467       or NET VIEW will now be faster and provide additional functionality.
3468       No longer will cell names longer than 12 characters be truncated.
3470     * Improvements to DFS Referral request processing have been
3471       implemented.
3473     * Unnecessary DNS lookups of share names are avoided improving
3474       performance.
3476   All UNIX client platforms
3478     * Non-Kerberos PAM modules work correctly again.
3480   MacOS X
3482     * MacOS 10.6 (Snowleopard) is now supported, both 32 and 64 bit mode.
3484     * Updates to the AFSCommander preferences pane.
3486     * Installer now permits cell names with dashes.
3489 OpenAFS 1.5.61 (2009-08-06)
3491   All platforms
3493     * Correct another race condition in the Rx library that could result
3494       in an unexpected panic while freeing the Rx call iovq.
3496     * rx packet resend and data packets sent counts were incorrect.
3498     * fs setquota, fs setcachesize, vos setfields, and vos create now
3499       accept human readable orders of magnitude. (K, M, G)
3501     * fs listquota fixed to permit large quota sizes to be displayed.
3503     * Correct documentation of bosserver permissions requirements.
3505     * Modify vlserver to avoid potentially corrupting the database through
3506       volume id reuse.
3508     * Generalized support for fast Rx timeout due to network
3509       down/unreachable.
3511   All server platforms
3513     * Allow audit logs to be sent via sys5 IPC message queues instead of
3514       logged directly.
3516   Microsoft Windows
3518     * If a file server becomes inaccessible while the cache manager has
3519       dirty buffers to write, the afsd_service buf_IncrSync thread can
3520       attempt to use 100% of the cpu.
3522     * Fix "fs newcell" which was broken in 1.5.60.
3524     * Do not attempt to synchronize dirty buffers if the associated volume
3525       is known to be unavailable.
3527     * Modify behavior of a Freelance mountpoint target that does not
3528       specify a cell.  Instead of assuming the target volume is in the
3529       Freelance.Local cell, use the workstation "Cell" specified in the
3530       registry. A mountpoint target of "#root.cell." will now mean the
3531       root.cell volume in the workstation cell for the current session.
3532       If the workstation cell changes from "athena.mit.edu" to
3533       "andrew.cmu.edu", the referenced volume will also change without
3534       requiring that the mount point targets be altered.
3536     * Add cm_FindServerByUuid().  Re-implement RXAFS_InitCallBackState3()
3537       to permit the server Uuid to be used to lookup the server object and
3538       from that determine the cell.  This permits callbacks that are
3539       received from alternate addresses to be processed with a known
3540       server object.  Previously a request from an unknown server would
3541       clear all callbacks from all cells.
3543     * Fix a bug that prevented optimal performance when using a non-zero
3544       value for 'daemonCheckVolCBInterval'.  As a reminder, when
3545       "daemonCheckVolCBInterval" is set to a non-zero value, all .readonly
3546       volume callbacks are automatically renewed 90 minutes before their
3547       expiration.
3549     * Fix automatic ranking of vldb servers whose values are obtained from
3550       the CellServDB file.
3552     * Add failover for RX CALL TIMEOUT errors when the volume is readonly
3553       or the call is to a vldb server.
3555     * Add registry based cell search functionality to NetIdMgr,
3556       afs_config.exe, and klog.exe.
3558     * afsconf_GetCellInfo() has been modified to perform gethostbyname()
3559       lookups on the host names in the CellServDB instead of using the
3560       specified IP addresses.  This provides aklog, pts, vos, etc. the
3561       same CellServDB behavior that the Windows Cache Manager uses.
3563     * When updating the stat cache entry callback of a .readonly object
3564       from the volume group object, update the file server reference to
3565       ensure it matches the most update to date callback.
3567     * Add proper support for processing callbacks from multi-homed file
3568       servers.  Instead of comparing servers by cm_server_t pointer,
3569       compare them by UUID when the UUID is known.
3571     * During a shutdown short circuit the offline volume check daemon
3572       functionality.
3574     * Return the error code of RXAFS_FetchData / RXAFS_StoreData in
3575       preference to an error code reported by rx_EndCall.
3577     * Add "PerFileAccessCheck" registry value to permit testing against
3578       experimental file servers that include per-file acl support.  This
3579       value is intentionally undocumented.  It is not to be used by
3580       production environment deployments.
3582     * Fix a bug introduced in 1.5.60 that prevents the afs netidmgr
3583       provider from obtaining tokens when referrals are in play.
3585     * Add "fs chown" and "fs chgrp" commands to permit the owner and group
3586       of objects stored in AFS to be set from Windows.
3588     * Avoid performing background daemon operations when the machine is
3589       going into suspend mode.
3591     * Perform offline volume checks in most recently used order.
3593     * Prevent crash when a data version for a cache object goes backwards.
3595     * Multi-thread safe library versions are now being generated and used.
3596       mtafsubik.lib, mtafsutil.lib, mtafsvldb.lib, mtafsvol.lib.
3598     * Microsoft SMB Redirector (mrxsmb.sys) support for
3599       ExtendedSessTimeout values are now available on XP through Windows
3600       7.  Add functionality to autodetect if such support is present on
3601       the machine.  If so, configure it if necessary and dynamically
3602       adjust the AFS Rx timeout values accordingly.
3604   All UNIX client platforms
3606     * Fix out-of-tree source builds.
3608   MacOS
3610     * GUI installer now asks for local cell information.
3612     * AFS Commander preferences pane is now installed by default.
3614   Solaris
3616     * Avoid kernel panics due to null pointer dereferences in the network
3617       interface poller kernel thread.
3620 OpenAFS 1.5.60 (2009-05-31)
3622   All platforms
3624     * Retry volserver transaction creation on failure.
3626     * Allow building HTML and PDF documentation from included XML copies
3627       of User Guide, Admin Guide and Quick Start Guide for Unix.
3629     * Documentation updates and additional documentation.
3631     * Add -encrypt support to pts client.
3633     * Convert MR-AFS fs commands to OSD commands.
3635   All server platforms
3637     * Updated background sync process in fileserver to avoid a race which
3638       could result in a volume being taken offline.
3640   Microsoft Windows
3642     * On April 9th Microsoft released a Hot Fix for Windows Server 2003
3643       SP2 that corrects a deadlock in the smb redirector and also adds new
3644       functionality that permits the AFS SMB server to be given a longer
3645       timeout than is normally the case.  New functionality has been added
3646       to configure these additional LanmanWorkstation\Parameter values.
3647       (This functionality has been backported to XP SP3 and is scheduled
3648       to be released on June 5th.)
3650     * Fix RT#124787, a race condition between "fs flush <dir>", "fs
3651       flushvolume", or "fs flushall" and on-going directory operations
3652       that can result in afsd_service.exe crashing.
3654     * Release Notes, User and Administrator guides are now shipped as
3655       indexed Windows HtmlHelp Files. (.chm).  Shortcuts are provided from
3656       the Start Menu.
3658     * A method of specifying Client CellServDB information within the
3659       registry has been added that can be used to either override the
3660       CellServDB file or force the use of DNS lookups for a given cell.
3661       See the release notes for details.
3663     * The pioctl interface now properly handles drive letter substitution
3664       to UNC paths.  (SUBST <d:> <\\afs\cell\path>)
3666     * The BackConnectionHostNames registry value configuration was broken
3667       when dynamic re-establishment of Netbios Name registrations was
3668       added.  This release restores the functionality.
3670     * All hidden vos.exe commands are now revealed.
3672     * Attempts to store the same dirty file chunk from multiple threads
3673       are now prevented.
3675     * The IsPathInAfs test in Explorer Shell Extension and fs.exe now
3676       permits broken symlinks to be treated as being in AFS.
3678     * vos.exe commands that output 64-bit integer values once again do so.
3679       This was broken in 1.5.59.
3681     * Cygwin Import Libraries are provided in the SDK for all OpenAFS
3682       DLLs.  This permits building cygwin applications against OpenAFS
3683       libraries.
3685     * NSIS installer does a much better job of cleaning up files left over
3686       from previous installs.
3688     * libafsconf.dll moved from Client\Program to Common directory as is
3689       is now used by all modules for CellServDB processing.
3691   All UNIX client platforms
3693     * Write back changes on last store for memcache to avoid discarding
3694       changes.
3696     * Abstract disk cache support to allow for path, fh, inode based
3697       caches with no need for messy ifdef structures each time a new type
3698       is added.
3700   DragonflyBSD
3702     * Support as a userland port.
3704   FreeBSD
3706     * Corrected structure definition for userspace cache manager to allow
3707       builds to complete.
3709   Linux
3711     * Corrected client locking support.
3713     * Updated patch to stop deadlocking in the kernel during mmap.
3715     * Avoid oops when setting up groups for PAGs to match keyrings.
3717     * Use Linux fh-based cache in cases where possible by default.
3719   MacOS 10.3:
3721     * Corrected structure definition for userspace cache manager to allow
3722       builds to complete.
3724   OpenBSD
3726     * Support for OpenBSD 4.5.
3728   Solaris
3730     * Corrected support for server-side vos split interface.
3733 OpenAFS 1.5.59 (2009-04-06)
3735   Microsoft Windows
3737     * Increased service priority class to "High" to match the priority of
3738       system components that are dependent upon the a timely response.
3740     * SMB error responses avoid returning errors that could confuse the
3741       Microsoft SMB redirector into disconnecting the connection to \\AFS.
3743   All UNIX client platforms (except MacOS X 10.4 and 10.5)
3745     * OpenAFS 1.5.59 contains fixes for the client issues addressed by the
3746       security advisories OPENAFS-SA-2009-001 and OPENAFS-SA-2009-002.
3748   Linux platforms
3750     * Support for prerelease Linux 2.6.30 kernels.
3753 OpenAFS 1.5.58 (2009-03-30)
3755   All platforms
3757     * Code cleanup and prototyping.
3759     * Avoid unnecessary blocking in Rx periodic cleanup code.
3761   All server platforms
3763     * Fileserver CopyOnWrite routine optimized for performance.
3765     * Make fileserver callback dumps 64 bit safe.
3767     * Fix byte order issues with fileserver host hashing.
3769     * Fix buffer size issues with butc.
3771     * Fix several Ubik recovery issues.
3773     * Avoid leaking file references in the fileserver.
3775     * Fix a race in DAFS while closing vnodes, and another offlining
3776       volumes.
3778     * volserver interfaces for volume splitting client.
3780   Microsoft Windows
3782     * [RT 124293] A race condition exists which can result in a crash.
3784     * [RT 124276] If the vldb is out of sync with the contents of the file
3785       servers, afsd_service will retry too many times when a file server
3786       reports a volume as not being present.  Now if the list reported by
3787       the vldb is the same as the previously seen list, then the retry is
3788       aborted.
3790     * [RT 124276] Read-only volume failover was broken in 1.5.53 whenever
3791       accessing a volume results in VNOVOL or VMOVED.
3793     * [RT 124276] Prior to 1.3.70 the volume server reference list was not
3794       reference counted and would be prematurely freed while in use.  When
3795       reference counting was added in 1.3.70 a bug was introduced that
3796       could result in service reference list corruption.
3798     * Add Windows Application Event Log warning messages for "Client SMB
3799       MPX value too large" and "Client SMB Buffer Size too small".
3801     * Renaming of files across directory boundaries would result in an
3802       invalid handle error when attempting to access the files after the
3803       move.
3805     * Fix the handling of Tran2 Set Path Info RPCs.  Do not fail when a
3806       smb file descriptor cannot be found.  The whole point of using a
3807       Path Info function is because an smb file descriptor wasn't
3808       allocated.
3810     * More edge cases in which dynamic addition of Freelance root.afs
3811       entries would get the wrong FID or where the root.afs directory
3812       would not be refreshed.
3814     * Buffer overflow could occur if the workstation cell name was longer
3815       than 64 characters.  Crashes could occur in afscreds.exe,
3816       afslogon.dll, and afsd_service.exe.
3818     * VNOSERVICE and VOFFLINE errors were leaking and were exposed to the
3819       smb client.
3821     * Log file server uuid values as part of the cm_server object when
3822       available.  Dump the cm_server object list in response to "fs
3823       memdump".
3825     * Optimize the performance of resetting access control lists when
3826       tokens are set or removed.
3828     * Remove symlink recursion tests and increase max symlink count to 64
3829       from 16.
3831     * Windows specific Rx performance improvements.
3833     * Support for Network Identity Manager 2.0
3835   All UNIX client platforms
3837     * Avoid issues with freeing resources at shutdown.
3839     * Numerous fixes to disconnected AFS.
3841     * Disconnected AFS fixes for replaying changes without double-freeing.
3843     * Attempt to use krb524 principal conversion in aklog if available.
3845   AIX
3847     * Kerberos configuration at build time corrected.
3849   Linux
3851     * Default to dynamic allocation of AFS kernel cache entries to allow
3852       growth for inotify()-pinned entries. (beagle, famd, etc)
3854     * Change client truncation routines to avoid locking issues.
3856     * IA64 port clients fixed on Linux 2.6.
3858     * RPMs now install fstrace message catalog.
3860     * Support through kernel 2.6.29 tested.
3862     * Fix locking issues on CellServDB file in /proc.
3864   OpenBSD
3866     * Support OpenBSD 4.4
3869 OpenAFS 1.5.57 (2009-01-23)
3871   All platforms
3873     * Conditional compilation of rxdebug support is now possible.
3875     * Documentation updates.
3877     * Further race connditions in Rx have been corrected.
3879   All server platforms
3881     * Salvager no longer attempts to recreate headers in the wrong
3882       partition.
3884     * Volumes are properly marked in use on creation and subsequently on
3885       examination with vos.
3887   Microsoft Windows
3889     * Undo the "UAC manifest fix" applied to afs_config.exe.
3891     * Ensure that Freelance allocation of vnodes follow the AFS convention
3892       of odd vnodes are directories and everything else is an even vnode.
3894     * Add Freelance logic to mount point and symlink evaluation functions.
3896     * Enhance smb_ParseASCIIBlock() so that it can handle all of the
3897       STRING formats defined by the CIFS Technical Report 1.0.
3899     * Validate the output of smb_ParseASCIIBlock() in all callers.  Return
3900       CM_ERROR_BADSMB if the STRING field cannot be parsed.
3901       CM_ERROR_BADSMB will cause the contents of the packet to be logged.
3903     * If multiple SMB Raw Write operations were taking place at the same
3904       time, there could be data corruption because unique event objects
3905       were not generated for each Netbios receive operation.
3907   All UNIX client platforms
3909     * Userspace AFS library can now deal with large files when supported
3910       by the platform.
3912     * Numerous updates to disconnected AFS support, including changes to
3913       allow reconnection to work in more circumstances.
3915   FreeBSD
3917     * FreeBSD unstrategy code has been updated.
3919   Linux
3921     * A race during file truncation has been corrected.
3923     * System call probing routines have been updated.
3925     * 2.6.29 is now supported.
3927   MacOS
3929     * 10.3 support has been corrected.
3931   OpenBSD
3933     * Initial OpenBSD 4.4 support.
3935   Solaris
3937     * Updates to allow compiling on newer OpenSolaris are now included.
3940 OpenAFS 1.5.56 (2008-12-30)
3942   All platforms
3944     * libuafs (userspace cache manager) updated to correct several errors.
3946     * Additional rx debugging support is available as a conditional
3947       compile.
3949     * A race condition in Rx leading to a panic has been corrected.
3951     * Rx idle time tracking has been corrected.
3953     * ubik clone server support has been corrected.
3955   All server platforms
3957     * Salvager no longer leaves cores in vice partitions.
3959     * The vol-dump tool now supports dumps larger than 2gb where possible.
3961     * Operations on multiple files now report all FIDs in the audit log.
3963     * butc XBSA support now works correctly on amd64.
3965   Microsoft Windows
3967     * The NetIDMgr AFS Provider automated configuration logic was broken
3968       by the introduction of Kerberos referrals.  If the realm of the
3969       identity cannot be determined, the workstation cell is now assumed
3970       to belong to the newly created identity.
3972     * Avoid a reference count under flow during rename operations.
3974     * Avoid a crash caused by treating an arbitrary length directory
3975       search mask as an 8.3 mask.
3977     * Prevent rename operations if a case insensitive match for the target
3978       name already exists and does not refer to the object being renamed.
3980     * Increase the maximum number of background daemons to 64.
3982     * Fix the UAC manifest applied to afs_config.exe
3984   All UNIX client platforms
3986     * Updates to disconnected AFS support.
3988   FreeBSD
3990     * FreeBSD 7.1 is now supported.
3992     * amd64 FreeBSD is now supported.
3994   Linux
3996     * Generic fh (exportfs API) cache type is now available.
3998     * Avoid some oopses due to backing_dev_info inode fields not being
3999       filled.
4001     * 2.6.28 is now supported.
4003   MacOS
4005     * 10.3 support has been corrected.
4007   Solaris
4009     * Large partition support has been corrected.
4011     * Filesystem-agnostic cache is now available on Solaris 10 and 11.
4014 OpenAFS 1.5.55 (2009-11-10)
4016   All platforms
4018     * Salvager avoids leaving core files in vice partitions.
4020     * NFS translator fixes.
4022     * Unresponsive server handling fixes.
4024     * A volserver race which could result in duplicate transactions is
4025       fixed.
4027   Microsoft Windows
4029     * Fixes a panic caused by corruption of the SMB virtual circuit list.
4030       (race condition)
4032     * Fixes a panic caused by receipt of a UTF-16 string that cannot be
4033       converted to UTF-8.
4035     * Implements a more aggressive recovery algorithm for Netbios errors
4036       that result in loss of communication to the AFS SMB server.
4038     * Improve pioctl response time when testing whether or not a PATH is
4039       in AFS.
4041     * Adds support for linked cells.
4043     * Increases the length of the cell and realm names that can be input
4044       into the Network Identity Manage AFS provider configuration dialog.
4046   All UNIX client platforms
4048     * Disconnected AFS avoids infinite recursion during rmdir.
4050   Linux
4052     * Support for 2.6.28 (not complete for NFS translator modules).
4054     * Support for using exportfs API for filesystem-agnostic cache.
4056     * Disable backing store readahead.
4058     * Avoid deadlocks when writing back mmapped files larger than the
4059       cache.
4061     * Avoid Oops when doing PAG garbage collection.
4064 OpenAFS 1.5.54 (2008-10-08)
4066   All platforms
4068     * Updates for new Tivoli X/Open API finding.
4070     * A double-free is corrected in Rx.
4072   All server platforms
4074     * Ubik cleans up file descriptor cache correctly when doing recovery.
4076     * Enhanced vldb error checker included.
4078   Microsoft Windows
4080     * Prevent a crash that could occur when multiple file / directory
4081       change notifications are processed simultaneously.
4083   MacOS
4085     * AFS claims more free space so Finder will attempt file copies.
4087   Linux
4089     * Avoid spurious ENOENT when calling gwtcwd() on a volume root.
4091     * Avoid spurious ENOTDIR during fakestat.
4094 OpenAFS 1.5.53 (2008-09-26)
4096   All platforms
4098     * rx avoids many packet leaks.
4100     * rx jumbogram disabling now works (and is the default).
4102   All server platforms
4104     * Demand Attach fileserver tries to avoid issues tracking offline
4105       status of volumes.
4107   Microsoft Windows
4109     * Many potential deadlock conditions due to out of order lock
4110       acquisitions have been corrected.
4112     * A race condition resulting in an undercount on the cm_scache_t
4113       reference counts has been corrected.
4115     * An empty string when sent as an ioctl path is now properly
4116       interpreted as meaning the current directory.  This affects "fs
4117       lsm", "symlink list", etc.
4119     * Fix smb string parsing differences where the smb protocol
4120       documentation does not match the actual Windows implementation.
4122     * Random access denied errors fixed.
4124     * A file server lock synchronization issue was corrected in SMB
4125       NTCreateX and NTTranCreate operations.  This bug prevented properly
4126       operation when loading roaming profiles.
4128     * Fix a heap overwrite error during server probe operations if a new
4129       server is added while a probe operation is in progress.
4131     * Fix an LSA memory leak that was the result of an LSA error.
4133     * Do not leak cm_cell_t objects if the VLDB server lookup fails.
4135     * Only initialize rx mutex/lock objects once.
4137     * Do not nul terminate the AFS volume name when reported to Windows.
4139     * Improve VNOVOL error handling.  Prevent updated vl information from
4140       being destroyed immediately after it was acquired.  This bug
4141       prevented proper fail over when volumes are moved or removed from a
4142       server.
4144     * Remove volume id from the server volume list in response to VMOVED
4145       and VNOVOL errors.
4147     * "fs flushXXX" commands now destroy locally built B+ directory trees.
4149     * Prevent mixture of locally modified directory pages and file server
4150       directory pages.
4152     * Fail over to alternate vl servers if a ubik error is returned.
4154   All UNIX client platforms
4156     * Disconnected AFS now supports read-write mode.
4158     * volserver now builds correctly.
4160   AIX
4162     * AIX 6 is now supported.
4164   FreeBSD
4166     * FreeBSD 7 is now supported.
4168   Linux
4170     * cache bypass is now supported.
4172     * 2.6.x kmod compilation now uses kernel compile options always.
4174     * Support through 2.6.27.
4176   MacOS
4178     * Show more space free so Finder doesn't get confused.
4180   Solaris 10
4182     * Default to namei rather than inode.
4185 OpenAFS 1.5.52 (2008-08-18)
4187   All platforms
4189     * Initialize volume updateDate at volume creation.
4191     * Avoid potential corruption of directories during salvage.
4193     * Check for out of memory condition during allocation of additional Rx
4194       packets.
4196   Microsoft Windows
4198     * Restore support for Windows 2000 (broken in 1.5.50).
4200     * Perform additional validation on volume names in mount points during
4201       creation and evaluation.
4203     * Fix several deadlocks, races, and reference count issues.
4205     * Further optimize SMB Directory Search processing and minimize the
4206       number of InlineBulkStatus RPCs sent to the file server.
4208     * Enable "bos restricted" operations.
4210     * Fix the create of submounts used by the AFSCreds and afs_config
4211       drive mapping tabs.
4213     * Fix a short name truncation bug. (1.5.50)
4215     * Fix the error code reported when attempting to delete a file on a
4216       readonly volume or one that is marked with the readonly DOS
4217       attribute.
4219     * Fix a heap corruption error when reading the CellServDB file
4220       location.
4222     * Add the "RxUdpBufSize" registry value.  The new default is 256KB.
4224     * Do not include trailing NULs in the directory search output.
4225       (1.5.50)
4227     * Pre-allocate 64 Rx Packet buffers per thread in order to improve
4228       performance.
4230     * For debugging: add smb lock requests and stat cache lock allocations
4231       to the output from "fs memdump".
4233   NetBSD
4235     * Workaround broken sigwait() to allow fileserver to shut down
4236       correctly pre NetBSD 5.0.
4238   Solaris 10
4240     * Default to namei fileserver; Allow inode fileserver at configure
4241       time by override.
4243   NFS translator
4245     * Try harder to avoid kernel panics for malformed requests.
4248 OpenAFS 1.5.51 (2008-07-29)
4250   All platforms
4252     * salvager tries harder to arrange for clients to get VBUSY while
4253       salvaging single volumes.
4255     * salvager avoids certain corruption when salvaging directories.
4257     * Rx connection clones disabled.
4259   Microsoft Windows
4261     * The 32-bit EXE 1.5.50 installer failed to properly install the C
4262       Runtime library.  When used as an upgrade OpenAFS would continue to
4263       work but when used as a new installation, OpenAFS binaries would
4264       fail to load.
4266     * Fixes the "fs" and "symlink" commands to properly parse Unicode path
4267       prefixes during the pioctl remote procedure call.  This bug would
4268       result in file not found errors for files and directories that
4269       clearly exist.  (Bug introduced in 1.5.50)
4271     * Large File support is disabled. (Bug introduced in 1.5.50)
4273     * Removes the possibility of a deadlock during volume location update
4274       operation if all of the reported file servers are unreachable at the
4275       time of the update.
4277     * Ensures that reference counts are properly incremented/decremented
4278       on Rx connection objects used for volume location RPCs.
4280     * Over Quota errors during cm_FSync() calls would lead to an infinite
4281       loop as the error was never propagated to the caller.
4283   All UNIX client platforms
4285     * Bugfixes to disconnected AFS support in the cache manager.
4288 OpenAFS 1.5.50 (2008-07-16)
4290   All platforms
4292     * volserver puts recloned volumes back online before returning the
4293       volume to the fileserver, avoiding spurious VNOVOL errors.
4295     * Updated TSM X/Open API support available.
4297     * Demand Attach fileserver will not crash due to accesses during
4298       volume cloning.
4300     * Substantial documentation updates.
4302     * Demand Attach fileserver state tracking and analyzer tool
4303       improvements.
4305     * UAFS userspace cachemanager updates.
4307     * Corrected support for anti-meltdown protection in the client.
4309   Microsoft Windows
4311     * UNICODE Character Set Support.
4313     * Pioctl interfaces to the cache manager have been refactored to
4314       provide layering between the SMB specific code and the general
4315       purpose ioctl operation.
4317     * Garbage collect dead SMB virtual circuits as soon as they are no
4318       longer being referenced.  This avoids problems with outstanding
4319       locks not being dropped when the virtual circuit becomes invalid.
4321     * Remove the IBM Administration Reference documentation and replace it
4322       with the OpenAFS Command Reference Manual.
4324     * Avoid calling rx_SetDeadTime and rx_SetHardDeadTime functions each
4325       time a connection is about to be used.  Do not hold a lock on the rx
4326       connection object while it is being selected.  This avoids a race
4327       between threads attempting to set the timeout values and removes a
4328       bottleneck that was hampering performance.
4330     * Ensure that the smb directory attribute is set for all directory
4331       objects.
4333     * Replace the VC Runtime EXE installer with the MSI installer in the
4334       NSIS installer scripts.
4336   Solaris
4338     * Support for updates to OpenSolaris.
4340   Linux
4342     * Correct dentry revalidation for cross-directory renames.
4344     * Updated rpm packaging materials for 1.5 release series and 2.4
4345       kernels.
4347     * Corrected syscall table probing.
4349     * NFS translator updates for current kernels.
4352 OpenAFS 1.5.39 (2008-06-24)
4354   All platforms
4356     * Updates for Demand Attach fileserver.
4358   Microsoft Windows
4360     * Fix two memory leaks.
4362     * Fix one missing lock.
4364     * Handle access denied errors when writing dirty buffers.
4366     * Fix two errors that would cause the *experimental* AFS Servers
4367       to crash.
4370 OpenAFS 1.5.38 (2008-05-24)
4372   All platforms
4374     * Add read-only disconnected support.
4377 OpenAFS 1.5.37 (2008-05-21)
4379   All platforms
4381     * Includes a number of optimizations for testing.
4384 OpenAFS 1.5.36 (2008-05-09)
4386   All platforms
4388     * Rx optimizations now attempt to deal with high latency WANs.
4390     * Client will not wait infinitely for a server which is not providing
4391       data.  Additional servers will be polled without marking the server
4392       which is not providing data down.
4394     * vos move will not erroneously unlock locked vldb entries on failure.
4396   All server platforms
4398     * Fileserver avoids a potential infinite loop when a client
4399       relinquishes an address.
4401     * Fileserver large setting now configures more threads.
4403     * Fileserver properly registers uuids of new clients.
4405     * Ubik servers do not improperly hide updates from clients.
4407     * Fileservers reserve enough file descriptors such that each thread
4408       can cache one to avoid spurious errors.
4410   Microsoft Windows
4412     * Fix a cm_buf_t reference count leak when attempts to write dirty
4413       buffers to the file server from within cm_IncrSyncer() fail.
4415     * Prevent udebug from crashing.
4417     * Another VNOVNODE issue fixed.  When writing a dirty buffer to the
4418       file server, if VNOVNODE is received, mark all buffers as invalid
4419       without further attempts to contact the file server.
4422 OpenAFS 1.4.12
4424   All client systems: Major bugfixes.
4425   File servers: Major bugfixes.
4427   * New functionality:
4429   All systems:
4431     - Provide portable (pioctl) method for discovering what PAG a user is
4432       in. Required to support userspace PAG information collection on AIX
4433       5.1, and knowing whether Linux uses one group, two group, or only
4434       keyring based PAGs. (124709)
4436     * Bugfixes:
4438   All systems:
4440     - Fixes to avoid issues cleaning up deleted hosts in the fileserver (126454)
4442     - Fixes to avoid dropping writes due to server idle timeouts.
4444     - Don't miss cache chunks of large files while truncating.
4446     - Avoid null pointer dereference for unexpected volume names in volume
4447       utilities.
4449     - Don't mark connections waiting for additional packet window availability
4450       idle.
4452     - Kerberos 5 utilities (klog.krb5, aklog) enable weak encryption support.
4454     - Avoid a double-free of an Rx call structure during a client fetch error.
4456     - Avoid losing hosts during address changes. (125215)
4458     - Clients shouldn't trust Fetchdata replies for the size of returned data.
4460     - fileserver will not hang when attempting to cleanup and dump core.
4462     - salvager will not leave core files in random directories.
4464     - avoid letting retransmit timer get to 0 seconds.
4466     - in event of dbserver contact failure, shut fileserver down cleanly.
4468     - handle large partitions during check for needed disk space at
4469       client start.
4471     - time out Rx connections if network unreachable error received.
4473     - avoid dereferencing NULL pointer freeing Rx packets in receive. (125110)
4475     - mark stack not executable in LWP. (125491)
4477     - return a correct VolumeSync structure from Bulkstat RPCs in fileserver.
4479     - client attempts to better free memory at shutdown.
4481     - clear rx call queue safely. (125110)
4483     - retry VLserver registration on failure in fileserver.
4485     - update accessdate for volumes on access in fileserver.
4487     - additional safety checks on vlserver operations to avoid
4488       database corruption.
4490     - make ktc_curpag available on all builds. (125155)
4492   FreeBSD:
4494     - Build fixes.
4496   Linux:
4498     - Handle kernel changes through 2.6.33.
4500     - Fix oops in clear_inode due to missed locking. (125589)
4502     - Better handle /afs mount failures.
4504     - Clean up after failures creating our kernel kmem cache.
4506     - Work around memory management issues with some kernels when configuring
4507       the buffer cache/bdi (126514)
4509     - Rename compile_et to afs_compile_et to avoid RPM conflicts.
4511     - Handle whole-file locks properly. (126561)
4513     - Deal with kernel autoconf header renaming.
4515     - Handle SELinux cache backing file labels better to avoid potential oops.
4516       (92944,125544)
4518   MacOS:
4520     - klog now works correctly on 64 bit machines.
4522     - launchd now used to launch AFS at boot.
4524     - Preferences pane included for 10.4 and later.
4526     - Older versions can now be installed from packages.
4528     - Finder does not trigger bogus AFSDB lookups in /afs in dynroot mode.
4530     - Include package with debug kernel module symbols.
4532   OpenBSD:
4534     - Build fixes.
4536     - Support for x86_64.
4538   Solaris:
4540     - Handle ZFS caches usefully. (125365)
4542     - Implement additional pathconf support.
4544 OpenAFS 1.4.11
4546   Linux client systems: Major bugfixes.
4547   All client systems: Minor bugfixes.
4548   File servers: Major bugfixes.
4550   * New functionality:
4552   All systems:
4554     - Provide portable (pioctl) method for discovering what PAG a user is
4555       in. Required to support userspace PAG information collection on AIX
4556       5.1, and knowing whether Linux uses one group, two group, or only
4557       keyring based PAGs. (124709)
4559     * Bugfixes:
4561   All systems:
4563     - Fix bosserver to invoke salvager with "-force" instead of ambiguous
4564       "-f". (124916)
4566     - Cleanup for ptserver argument parsing to allow debug mode to work. (124893)
4568     - Sanity checking for ptserver log levels. (124894)
4570     - Fix for uninitialized memory dereference in klog.krb5.
4572     - Fix an overflow in the cellconfig code used by client and server. (124891)
4574     - Fix an erroneous vos verbose mode format string.
4576     - Avoid losing writes on mmap()ed files when cache is memcache. (124671)
4578     - Provide an afsd switch to allow override of the maximum MTU. (124880)
4580     - Provide support for encrypt mode in pts.
4582     - Fix race in background sync code which could cause volumes to go offline.
4583       (124359)
4585     - Fix fileserver to avoid a null pointer dereference in client identity
4586       lookup routines. (125020)
4588     - Improve handling of moves of volumes from 1.5 series fileservers. (18349)
4590   FreeBSD:
4592     - UKERNEL build fix. (124681)
4594   Linux:
4596     - Allow syscall probing to be disabled by switch to configure at build time.
4598     - Fix bug in anti-recursion protection for mmap clients. (124627)
4600     - Avoid a panic caused by changing credentials during VFS operations. (124737)
4602     - Avoid need for rcu subsystem when unavailable. (124986)
4604     - Improve keyring PAG setup code. (125001)
4606     - Avoid possible ext3 cache truncation issues. (124942)
4608   MacOS:
4610     - MacOS 10.3 UKERNEL build fix. (124681)
4612   OpenBSD:
4614     - Update support for 4.5 (124719)
4616   OpenSolaris:
4618     - Updates for newer OpenSolaris kernels. (124116, 124924)
4620 OpenAFS 1.4.10
4622   All client systems: Security fixes.
4623   File servers: Major bugfixes.
4624   All systems: Minor bugfixes.
4626   * Security fixes:
4628   All client systems:
4630     - Avoid a potential kernel memory overrun if more items than requested are
4631       returned from an InlineBulk or BulkStatus message. (124579)
4633   Linux client systems:
4635     - Avoid converting negative errors into invalid kernel memory pointers. (124580)
4637     * Bugfixes:
4639   AIX:
4641     - Don't build aklog NAS module when krb5 is not available. (124522)
4643   FreeBSD:
4645     - Additional fixes and support. (124107, 123917)
4647   Linux:
4649     - Support 2.6.28. (123580)
4651     - Support 2.6.29. (124115)
4653     - Attempt to support 2.6.30 (124560)
4655     - Avoid race during truncation. (124094)
4657     - Dynamic vcache allocation support, to deal with inotify vcache pinning. (124334)
4659     - Correct use of truncate_inode_pages to vmtruncate for locking issues. (124128)
4661     - Update RPM configuration. (123650, 102673, 124272)
4663     - Update kernel feature detection. (124507, 123604)
4665     - Do appropriate locking for CellServDB in /proc. (124407)
4667   MacOS:
4669     - Fix MacOS 10.3 support.
4671     - Add candidate Darwin 10 support.
4673   NetBSD:
4675     - Corrected NetBSD version tests. (123647)
4677   OpenBSD:
4679     - Update support for 4.4 (124541)
4681   Solaris:
4683     - Support cache filesystems which do not allow open by inode number, enabled by
4684       default on Solaris 9 and later. (123677)
4686     - Improve error code return quality. (124426)
4688     - Allow large partitions on Solaris servers.
4690   All client systems:
4692     - Avoid improper error messages about key version when krb5 is in use. (124220)
4694     - Avoid attempting to free kernel memory which was already freed. (124531)
4696     - Properly count offline volumes in vos client. (124333)
4698   All server systems:
4700     - Avoid 64 bit time issues in callback dump files. (124451)
4702     - Support more than one local Kerberos realm; Usernames are assumed to be the
4703       same across realms.
4705     - Ubik recovery is corrected to avoid spurious errors. (123723)
4707     - Do proper host address hashing for little endian machines in fileserver. (124447)
4709     - Update backup utility to properly compute header needs in the backup buffer.
4710       (124425)
4712     - Avoid blocking during Rx unused connection reaping.
4714     - Avoid leaking file handles in the fileserver when closing a volume. (124359)
4716     - Fix bosserver corefile naming to be y2k-safe. (124340)
4718     - Avoid potential infinite loop in deleted host handling in the fileserver.
4720     - Support large volume dumps in vol-dump. (123984)
4722     - Build butc XBSA support on 64 bit systems.
4724   All systems:
4726     - Properly track Rx connection idleness for timeouts.
4728     - Additional documentation. (124472)
4730     - Avoid a race which may result in an in-use Rx packet being freed. (123799)
4732 OpenAFS 1.4.9
4734   All client systems: Security fixes.
4736   * Security fixes:
4738   All client systems:
4740     - Avoid a potential kernel memory overrun if more items than requested are
4741       returned from an InlineBulk or BulkStatus message. (124579)
4743   Linux client systems:
4745     - Avoid converting negative errors into invalid kernel memory pointers. (124580)
4747 OpenAFS 1.4.8
4749   File servers: Major bugfixes.
4750   All systems: Minor bugfixes.
4752   * Bugfixes:
4754   AIX:
4756     - AIX 6.1 is now supported.
4758     - Unpin kernel memory references after free. (99456)
4760     FreeBSD:
4762     - FreeBSD 7 is now supported.
4764   Linux:
4766     - Avoid deadlock when writing back pages in an mmap()ed file larger than
4767       the cache. (120491)
4769     - Update process tree walking for PAG garbage collection to avoid oopses.
4770       (116603)
4772     - fakestat mode now correctly avoids spurious ENOTDIR errors.
4774     - Use kernel build system for all platforms.
4776     - Remove openafs directory from proc in correct order. (112910)
4778     - Handle renames across directories correctly in the linux dcache. (74672)
4780     - Probe syscall table when possible. (105457)
4782     - Mount point parsing is now updated to handle only well-formed mount
4783       points rather than similarly-formed symlinks. (113558, 100836)
4785     - ucontext-style LWP is now anbled for glibc versions newer than 2.3.
4787   MacOS:
4789     - Update available space shown. (112910)
4791   NetBSD:
4793     - Work around broken SIGWAIT. (111404)
4795   Solaris:
4797     - Solaris 10 now defaults to namei fileservers.
4799     - NFS translator issues fixed.
4801     - Changes to address Solaris updates. (105495)
4803   All client systems:
4805     - udebug correctly displays the last "yes" host.
4807     - Allow more vldb lookups to be cached in the client.
4809     - Fix aklog to not be excessively verbose when not requested.
4811     - Add support for timing out accesses which are not completing in a timely
4812       manner.
4814     - Properly flag backup volumes being added to the vldb by vos syncvldb.
4816   All server systems:
4818     - fileserver "large" setting now implies 128 threads instead of 12.
4820     - fileserver check for duplicate uuids is now applied correctly.
4822     - Newer xbsa APIs are supported for TSM integration in butc.
4824     - salvager avoids corrupting length of directory objects. (111585, 107767)
4826     - volserver avoids a race during volume release so a volume will not
4827       appear to be offline. (107258)
4829     - Add support for returning errors when accesses are not completing
4830       in a timely manner.
4832     - Avoid potential race in the volserver when creating transactions. (121263)
4834     - Return sensible error when a release or restore exhausts server
4835       resources. (121040)
4837     - volserver now returns EXDEV if a new replica would duplicate one which
4838       already existed elsewhere on the server.
4840     - Disable jumbograms by default.
4842     - volserver updates a volume's updateDate on volume creation. (110943)
4844     - Partitions over 2tb are now supported. (88811)
4846   All systems:
4848     - Re-enable Rx client keepalives. (20727)
4850     - Support autoconf 2.62. (118058)
4852     - Update Rx to avoid leaking packets.
4854     - vos supports the -noresolve options to avoid issues with 127.0.0.1 being
4855       named in /etc/hosts.
4857     - Additional documentation. (104110)
4859 OpenAFS 1.4.7
4861   File servers: Major bugfixes.
4862   All systems: Minor bugfixes.
4864   * Bugfixes:
4866   AIX:
4868     - Kerberos as included in AIX has missing symbols. AFS krb5 tools now
4869       deal correctly.
4871     - AIX LAM aklog plugin can now be used CDE screenlocker.
4873     - Add support for getting the current PAG in pagsh and PAM.
4875     - Avoid sending a terminal hangup to STREAMS in aklog.
4877     - Fix afsdb support in the client.
4879   Linux:
4881     - Kernels through 2.6.25 are now supported. (77370,88000,83716,83890,80463)
4883     - Client now only hashes dirty inodes. (78544)
4885     - Fix to avoid returning invalid mount point data when -fakestat-all is in use.
4886       (93898)
4888     - RPM build system updates. (93616)
4890     - Restored write-on-close-or-fsync semantics when possible. (17509)
4892     - Enabled support for flock() on files in AFS. (53457)
4894     - ARM Linux now supported.
4896     - Kernel keyring support updated.
4898     - Fix client-displayed timestamp ordering by zeroing nanosecond field.
4900   MacOS:
4902     - Boot time init script now uses afs.conf to store config options. (81825)
4904     - Avoid kernel panic due to excessive lock tracking when removing files.
4906     - Avoid leaking kernel memory when trying to read() a directory.
4908   Solaris:
4910     - Avoid potential kernel panic if the root vnode of AFS changes.
4912     - Avoid potential kernel panic when shutting down if contracts are in use.
4914     - Avoid potential delays when creating new PAGs if the system clock
4915       has gone backwards.
4917   All client systems:
4919     - At client shutdown, try harder to clean up in-use resources. (74479)
4921     - When fakestat is in use, enable optimization for Gnome Nautilus lookups.
4923     - Properly hold lock when updating disk cache metadata to avoid
4924       kernel panic. (59136)
4926     - Avoid wrapping to the start of a file when attempting to write a large file
4927       to a pre-largefile fileserver. (73720)
4929   All server systems:
4931     - Fixed to avoid truncating ubik databases during recovery. (77183)
4933     - fileserver issue with internal file cache filling has been fixed. (87977)
4935     - fileserver thread quota enforcement now done in all cases. (87416)
4937     - fileserver avoids potential network-related deadlock when breaking
4938       callbacks.
4940     - fileserver avoids crash due to race of resource creation and user requests
4941       at startup.
4943     - fileserver avoids crash when reinitializing Ubik connections.
4945     - volserver fixed to avoid leaving orphaned files during restore. (46937)
4947     - volserver now supports convertROtoRW for inode fileservers.
4949     - Support disabling kerberos 4 style username protection in servers. (75101)
4951   All systems:
4953     - Fix to butc to avoid crash due to threaded library variant.
4955     - Fix to avoid network retransmission issues if the system clock goes
4956       backwards.
4958     - vos syncvldb and syncserver now support a dryrun (do nothing) mode.
4960     - vos addsite now supports adding a site where a replica is already
4961       available.
4963     - vos clone now supports creating properly-named readonly and backup clones.
4965     - vos restore now allows an older copy of a volume at an alternate site to
4966       not be removed.
4968     - cmdebug now supports dumping a client's CellServDB.
4970     - cmdebug now supports showing human-readable expiration times.
4972     - aklog now handles Kerberos referrals.
4974     - Additional documentation now included. (89288,89289,86677)
4976 OpenAFS 1.4.6
4978   All systems: Major bugfixes.
4980   * Bugfixes:
4982   All systems:
4984     - fileserver host tracking code had a missing lock on a host structure;
4985       that lock has been added.
4987     - fileserver handling for clients which are giving up callbacks did not
4988       hold a lock, making it unsafe and allowing clients to potentially
4989       crash the server by racing.
4991     - fileserver will now leave a corefile when it is doing a shutdown due
4992       to error conditions.
4994     - fileserver again allows ufs as a valid filesystem type (regression in 1.4.5).
4996     - cbd handler for fileserver status data has an interpretation error which
4997       could cause crashes corrected.
4999     - fileserver accurately tracks number of callbacks on a given file.
5001 OpenAFS 1.4.5
5003   All systems: Minor bugfixes.
5004   New systems: MacOS 10.5.
5006   All systems:
5008     - fileserver address tracking is improved to avoid potentially merging
5009       unrelated hosts.
5011     - Documentation updates.
5013     - namei fileserver now does fsync()s in background batches for performance
5014       improvements.
5016     - Kerberos ticket support corrected in bundled Kerberos 4 utilities on 64
5017       bit platforms.
5019     - fileserver includes limited per-host thread quota support to avoid
5020       resource starvation.
5022     - fileserver deals with more damaged volumes without asserting.
5024     - vos validates dumpfiles before attempting restores.
5026     - vos clone will no longer potentially delete the parent volume.
5028     - Client no longer permits empty UUID to be created.
5030     - fs uuid command for checking, regenerating UUID added.
5032     - Updates for gcc 4.2.
5034     - fileserver treats w (write) permission as granting read lock permission
5035       in addition to write.
5037   AIX:
5039     - Bundled NAS Kerberos is now supported. (5.x)
5041     - LAM aklog module is provided. (5.x)
5043     - Associate cache files with correct filesystem to avoid snapshots when
5044       performing maintenance on local filesystems.
5046   Irix:
5048     - Makefile updates.
5050   Linux:
5052     - Kernels throigh 2.6.23 are known to work.
5054     - Updates to syscall table probing.
5056     - Bug fix in keyring PAG support to avoid oops.
5058     - updated sample RPM configuration.
5060     - sparc32 lwp support updated.
5062     - Avoid potential oops in symlink support in certain older kernels.
5064     - Avoid potential deadlock during vmalloc.
5066     - Corrected locking while interacting with kernel task list.
5068   MacOS:
5070     - Several panics fixed, including remove_fsref. (10.4 and later)
5072     - IP address changes now tracked.
5074     - Corrected support for dropboxes (li access without r) with cp and Finder.
5076     - fstrace and ancillary files now included.
5078     - man pages are now installed in the default MANPATH.
5080     - Servers will be timed out quickly if there is no route available.
5082     - Temporary files from remove-while-busy now cleaned up correctly.
5084   Solaris:
5086     - Updates to accomodate kernel interface changes. (10u4 and later)
5088     - knfs and NFS translator support updated.
5090     - Changes to accomodate version 5.4 xbsa library.
5092     - Updates for new SunStudio defaults.
5094 OpenAFS 1.4.2
5096   All systems: Major bugfixes.
5098   * Bugfixes:
5100   All systems:
5102     * A bug in the namei volserver which could erroneously make a replicated or
5103       moved volume go offline has been fixed.
5105     * Volume package users (fileserver, volserver, salvager) avoid using lockf to
5106       avoid leaking byte range locks on volume internal files.
5108   MacOS 10.4:
5110     * A bug where the client kernel module could free stack memory (which caused
5111       issues with 64 bit Intel most commonly) has been fixed.
5113   Linux:
5115     * A missing kernel feature test has been fixed.
5117     * group based PAG support is still enabled when possible.
5119     * ia32 syscall table support for amd64 has build fixes for modern kernels.
5121   Solaris:
5123     * fopen() is not safe for use with more than 255 file descriptors open;
5124       Emulate it in the afsconf package so afsconf can be used in the fileserver.
5126   Windows:
5128     * DNS registration is disabled for the loopback adapter, and we make sure
5129       Netbios is turned on.
5131   Since 1.4.1:
5133   All platforms:
5134     * Remove use of ubik_Call in the source code so prototypes are used.
5136     * Avoid synchrony in call from the fileserver to the ptserver.
5138     * Fix a bug in the backup suite when restoring.
5140     * fileserver and volserver now log for error conditions which may cause
5141       exiting.
5143     * rx avoids a stack overrun when more packets are needed.
5145     * volserver avoids holding a lock too long when purging volumes.
5147     * volserver lock initialization fixes
5149     * volserver volume nuke fixes to avoid leaving files behind
5151     * fileserver avoids error when authenticating ptserver requests
5153     * fileserver no longer crashes when GetCPS fails
5155     * salvager enhancements to deal better with corrupt volumes for namei
5157   Unix:
5159     * aklog deals with KDCs which give "generic" replies to principals not
5160       existing.
5162     * Fix bug in cache parameter autotuning
5164   RedHat:
5166     * packaging fixes
5168   Linux:
5170     * amd64 pthread library family updates.
5172     * autoconf fixes for kernel feature testing
5174     * keyring PAG support now only enabled if needed features are present
5175       and other updates
5177     * inline a version of BUG() so we get better oopses
5179   AIX:
5181     * tsm is updated to work with the new AIX 5 interface.
5183   MacOS:
5185     * Cross compile fixes
5187     * Packaging improvements
5189     * Large file support fixed (Thanks to Chaskiel Grundman)
5191     * Fixes for Leopard seed.
5193     * Installer image updates
5195   Windows:
5197     * Removes race conditions and a deadlock introduced in 1.4.1
5199     * Fixes ANSI filename option.
5201     * Establishes new connections to file servers when
5202       IP address configuration changes are detected.
5204     * Improved CIFS compatibility
5206     * Cache Manager optimizations
5208     * Fixes vlserver failover when mounting 'root.afs'
5209       (Freelance mode disabled)
5211     * Installs help files in the correct location for use by afscreds.exe
5212       and afs control panel.
5214     * Improve reporting of "over quota" and "disk full" errors.
5216     * Prevent crash when evaluating mount points to volumes that do
5217       not exist
5219     * Removes auto-registration of AFS ID in foreign ptservers from
5220       Integrated Logon DLL.  This prevents crashes if the DLL is loaded
5221       and unloaded prior to termination of the process.
5223     * SDK moved to \Program Files\OpenAFS\SDK
5225     * NSIS and WiX Installer Frameworks update to the latest versions
5227     * Improvements to the Kerberos Logon Integration
5229     * Prevents exception in Integrated Logon DLL during SysPrep
5231     * Prevents displays of MessageBox dialogs in response to Network Adapter
5232       errors
5234     * Hard Dead and Connection Timeout values restricted to the CIFS Session
5235       Timeout value.
5237     * Correct writing of BackConnectionsHostNames registry value.
5239     * Properly recycles Volume entries
5241     * The AFS Explorer Shell Extension always finds its resource library.
5243     * The export list for AFSAUTHENT.DLL has been corrected.  (The AFS
5244       plugin for NetIDMgr will no longer use 100% of CPU.)
5246     * Renaming files on Microsoft Vista Build 5536 works.
5248     * Better handling of "." directory in fs commands
5250     * Add OpenAFS License text to installers
5252     * fs setquota and fs mkmount commands behave the same as the UNIX
5253       version
5255 OpenAFS 1.4.2
5257   All systems: Major bugfixes.
5259   * Bugfixes:
5261   All systems:
5263     - Volume dump parsing code in the volserver has better error checking.
5265     - salvager has improved damaged volume handling on namei fileservers.
5267     - fileserver has size validity checks for when large file support is disabled.
5269     - fileserver avoids potentially multiply adding a host to its hash table.
5271     - rxkad client private data storage is allocated dynamically on ticket size.
5273     - Handle universal error code translation for file locking.
5275     - fileserver needs to swap callback connections on a client IP change.
5277     - fileserver host package revised to reduce lock contention.
5279     - Rx has been fixed to count hard acks, thus opening the congestion window.
5281     - All servers support bound Rx sockets (on one interface).
5283     - namei fileserver no longer use lockf() to avoid range locking issues.
5285     - most binaries now support the -version switch.
5287     - backup suite fixes for 64 bit platforms.
5289     - volserver avoids holding holds during volume purges.
5291     - volserver avoids losing files on namei during vos zap.
5293   AIX:
5295     - fileserver now properly supports large files.
5297     - TSM updates for AIX 5
5299     - Kernel module avoids leaking Rx packets.
5301     - Avoid use of global ubik client structure in fileserver.
5303     - Update ubik call client interface to allow for prototyping.
5305     - audit logging fixes when stdarg does not provide integral va_list type.
5307   MacOS 10.4:
5309     - A bug where the client kernel module could free stack memory (which
5310       caused issues with 64 bit Intel most commonly) has been fixed.
5312     - Packaging fixes and updates.
5314     - Uninstaller added.
5316     - Fix large file support.
5318   Linux:
5320     - autoconf kernel feature testing has been restructured.
5322     - PAG garbage collection is enabled by default.
5324     - Kerberos updates for RHEL3.
5326     - Fix POSIX lock enrollment for older Linux kernels.
5328     - Updates for new 2.6 kernels.
5330     - Avoid deadlocks in put_inode handler.
5332     - Keyring-based PAG support.
5334     - Fixes to avoid getting better oops info in the kernel.
5336   Solaris:
5338     - Remove some kernel symbol bindings for symbols we don't use.
5340     - Cleanup for loopback mount of AFS on Solaris 10.
5342     - Avoid issues with stdio not supporting file descriptors above 255 on
5343       Solaris 8 and lower in the fileserver.
5345 OpenAFS 1.4.1
5347   All systems: Major bugfixes.
5348   New systems: MacOS 10.4 (PowerPC and Intel)
5350   * Bugfixes:
5352   All systems:
5354     - Several race conditions in the host tracking and handling in the fileserver
5355       which could cause inconsistent behavior and crashes have been fixed.
5357     - A fileserver bug where a reference to a volume could be leaked and later
5358       cause a deadlock as a result of a bulk status call
5360     - Reference counting of fileserver objects in unsigned 32 bit integers
5361       instead of signed 16 bit integers.
5363     - Avoid type mismatches when handling time values (betweemn 32 bit and 64 bit
5364       variables).
5366     - Fix a memory leak during multilevel packet queue handling.
5368     - Audit log output had been updated to include FIDs for newly created files.
5370   HP-UX 11i:
5372     - 64 bit (large file) inodes are supported.
5374     - Salvager will now handle large (>4gb) partitions.
5376     * New features:
5378   All systems:
5380     - asetkey is now included to ease Kerberos 5 integration for server
5381       administrators.
5383     - A new fileserver statistics collection including callback statistics was
5384       added.
5386     - man pages are now generated.
5388   Microsoft Windows:
5390     - Fixes error message problems experienced by fs.exe and the AFS Explorer
5391       Shell Extensions related to the use of Universal Error Codes by the
5392       AFS File Server
5394     - Adds full SMB/CIFS support for byte range locking.  In this implementation
5395       all locks are allocated locally and the AFS lock privilege is ignored.
5396       While this will not prevent two processes on different machines from
5397       simultaneously writing to the same file, it will prevent two processes
5398       on the same machine from doing so.
5400     - The UP server check period has been reduced to once every ten minutes to
5401       match the period used by the UNIX clients.  The shorter period will
5402       assist clients maintain RX connections through NATs.
5404     - Fixes the DOWN server check logic to ensure that any server that responds
5405       to a check is marked UP unless it is in the process of restarting.
5407     - Add logic to better handle objects that no longer exist on the file server.
5408       (VNOVNODE errors.)
5410     - Prevent the removal of existing drive mappings by "afscreds.exe -M"
5412     - Fixes the procmgmt library so that it doesn't cause applications that
5413       unload it to crash.
5415     - Improves the warnings written to the afsd_init.log file when the
5416       Windows RPC Protocol drivers are improperly configured.
5418     - Fixes "fs setserverprefs -vlserver".  Multiple calls with the same
5419       server parameter could result in a crash of afsd_service.exe.
5421     - The SMB/CIFS layer was audited for reference miscounts and memory leaks.
5422       All SMB objects are now properly counted, locked, and released when
5423       their work is done.
5425     - Prevent file truncation of the user does not have the appropriate access.
5427     - Token management was re-written to allow user tokens to be preserved
5428       during integrated login and freed after logoff is complete.
5430     - Added a mechanism by which abandoned SMB virtual circuits can be
5431       detected and the associated resources cleaned up.
5433     - Prevent the allocation of SMB file handles with a value of 0 or 0xFFFF
5434       which would be considered invalid by Windows applications.
5436     - Fixed the processing of cell names to ensure that they are always
5437       treated as case insensitive strings.
5439     - Fixed the network provider code to avoid querying the profile location
5440       if integrated login is disabled.
5442     - If a mount point string is empty, return Path Not Found to the application.
5444     - Windows returns WSAECONNRESET when an ICMP packet is received in response
5445       to a transmitted UDP packet that cannot be delivered.  Do not mark the
5446       connection as bad but instead retry the request.
5448     - Fix the data written to the registry as part of the BackConnectionHostnames
5449       values.
5451     - Fixed the rx-lwp implementation to always generate unique rx call
5452       identitiers.
5454     - The default "fs minidump" type now includes data segments.
5457 OpenAFS 1.3
5459   * -nosettime is now the default for afsd.  Use "-settime" to get the
5460     old behavior.
5462   * OpenBSD is now supported.
5464   * Mountpoint directory information is now only faked for cross-cell
5465     mountpoints when using the -fakestat flag (e.g. for the directories
5466     under /afs, but not for most other volumes mounted inside the cell).
5467     The -fakestat-all switch can be used to fake information for all
5468     mountpoints.
5470   * When fakestat is enabled on MacOSX, the Finder can be used to browse
5471     a fully-populated /afs directory.  However, this precludes reliable
5472     use of entire volumes as MacOS bundles (i.e. containing a Contents
5473     directory in the root of the volume).
5475   * Mountpoint directory information can be faked by the cache manager,
5476     making operations such as stat'ing all cells under /afs much faster.
5477     This is enabled by passing -fakestat to afsd, but might not be stable
5478     on all platforms.
5481 OpenAFS 1.2.9
5483   * The kaserver now defaults to not allowing interrealm authentication,
5484     due to security vulnerabilities in the krb4 protocol.  The new
5485     "-crossrealm" flag to the kaserver is provided to reenable interrealm
5486     authentication if desired.
5488   * RedHat Linux 9.0 is now supported.
5490   * Solaris 9 12/02 is now supported.  Solaris 7 and 8 x86 should now
5491     work again.
5493   * On Linux machines using 2.2 series kernels, 2.2.19 or higher is now
5494     required.
5496   * An OpenAFS 1.2.9 afsd will not work with kernel modules built from
5497     an earlier OpenAFS release.  In general, using a mismatched afsd and
5498     kernel modules set is unsupported; it is not recommended that you use
5499     such a configuration on a regular basis.
5502 OpenAFS 1.2.8
5504   * Mountpoint directory information is now only faked for cross-cell
5505     mountpoits when using the -fakestat flag (e.g. for the directories
5506     under /afs, but not for most other volumes mounted inside the cell).
5507     The -fakestat-all switch can be used to fake information for all
5508     mountpoints.
5510   * HPUX 11.0 is now supported.
5512   * It is now possible for AFS to use Kerberos 5 directly, via rxkad 2b.
5513     See the OpenAFS 1.2.8 Release Notes for more information on using this
5514     capability.
5516   * An NFS translator kernel module is now included and compiled by
5517     default for Solaris only.
5520 OpenAFS 1.2.7
5522   * MacOS X 10.2 is now supported.  FreeBSD 4.3 and later support is
5523     included in this release, but is still under active development and
5524     should only be used by those doing active development on the OpenAFS
5525     FreeBSD client.
5527   * When fakestat is enabled on MacOSX, the Finder can be used to browse a
5528     fully-populated /afs directory.  However, this precludes reliable use
5529     of entire volumes as MacOS bundles (i.e. containing a Contents
5530     directory in the root of the volume).
5532   * The fileserver will now use Rx pings to determine if clients are
5533     reachable prior to allocating resources to them, to prevent asymmetric
5534     clients from consuming all fileserver resources.
5537 OpenAFS 1.2.6
5539   * Mountpoint directory information can be faked by the cache manager,
5540     making operations such as stat'ing all cells under /afs much faster.
5541     This is enabled by passing -fakestat to afsd.
5543   * Solaris 9 FCS and Solaris 7 and 8 x86 are now supported.
5546 OpenAFS 1.2.5
5548   * A remote denial of service attack in the AIX and IRIX clients has been
5549     fixed.  Users of those platforms are strongly encouraged to upgrade.
5551   * Fixed race conditions in fileserver that could result in crash.
5554 OpenAFS 1.2.4
5556   * Server logfiles now more consistant about format in which hosts are
5557     referred to.
5559   * vfsck on Solaris will now allow force runs (using -y flag) even if old
5560     inodes exist.
5563 OpenAFS 1.2.3
5565   * Cell aliases for dynroot can be specified in the CellAlias file in
5566     /usr/vice/etc or /usr/local/etc/openafs, in format "realname alias",
5567     one per line.  They can also be managed at runtime with "fs newalias"
5568     and "fs listaliases".
5571 OpenAFS 1.2.2
5573   * Solaris 9 and Linux PA-RISC are now supported.
5575   * fileserver will not erroneously delay legitimate errors for 3 seconds
5576     after 10 errors are returned (e.g. stat() on a directory you can't
5577     read).
5579   * Rx MTU calculation now works for Irix, Solaris and Linux
5581   * If afsd is started with the -dynroot flag, /afs will be locally
5582     generated from the CellServDB.  AFSDB cells will be mounted
5583     automatically upon access.
5585   * The namei fileserver allows vice "partitions" to be directories
5586     instead of partitions and will attach and display accordingly.
5587     Creating the file "AlwaysAttach" in the /vicepX directory is used as
5588     the trigger to attach it.
5590   * TSM support for butc no longer requires editing a Makefile, simply
5591     specify the --enable-tivoli-tsm configure option.
5593   * Linux builds no longer require source changes every time the kernel
5594     inode structure changes; the OpenAFS sources will now configure itself
5595     to the actual inode structure as defined in the kernel sources.
5598 OpenAFS 1.2.1
5600   * vfsck on Digital UNIX and Solaris will now refuse to fsck mounted
5601     mounted partitions.
5604 OpenAFS 1.2.0
5606   * AFS now supports --prefix and the other directory options of
5607     configure.  By default AFS builds assuming it will be installed in
5608     /usr/local.  In order to get traditional AFS directory paths (/usr/afs
5609     and /usr/vice/etc) use the --enable-transarc-paths option to
5610     configure.  More details on the new directory layout are found in
5611     README.
5614 OpenAFS 1.1.1a
5616   * Windows 95/98/ME/NT/2000 - Consistent versioning:  Installation, AFS
5617     Control Center, Client dialog boxes and properties pages for
5618     executables display a consistent OpenAFS version number.  Installation
5619     detects previous installation and prompts the user for upgrade
5620     options.
5622   * Windows 95/98/ME/NT/2000 - Installation features:  During installation
5623     the user can select the source of the CellservDB file, AFS home cell,
5624     and drive mappings.  During installation a drive path mapping can
5625     include a variable that will be substituted with the current UserName
5626     that is logged in.
5628   * Windows 2000/NT - Integrated logon:  The Integrated Logon feature
5629     works now.
5631   * Windows 95/98/ME - Logon script features:  The Windows 95/98/ME client
5632     now offers a command-line option for starting up the AFS client
5633     without authenication. It is now possilbe to start the AFS client
5634     first and obtain tokens, and map drives all through Windows scripts.
5635     This helps using Windows 95/98/ME client in Kerberos 5 environment.
5637   * Windows 2000/NT - LANA numbers:  AFS client now scans the LANA numbers
5638     to establish the correct NETBIOS connection.  NetBEUI is no longer
5639     needed.  The user no longer needs to find the correct LANA number.
5641   * Windows 2000/NT - OpenAFS naming consistancy:  Further progress has
5642     been made to remove references to "Transarc AFS" and replace with
5643     "OpenAFS".
5646 OpenAFS 1.0
5648   * AFS now builds with configure. The README for building has been
5649     updated and includes full details.
5651   * A client system can now have multiple sysname values for @sys.  They
5652     will be searched in order when looking up files in AFS.  The
5653     -newsysname argument to fs sysname can be repeated to set multiple
5654     sysnames.
5656   * A new system group is created for new cells (system:ptsviewers with id
5657     -203).  If this group exists, members of this group can examine and
5658     read the entire protection database.  They can examine all users and
5659     groups and can get the membership of any group.
5661   * A new program, pt_util has been added to the distribution.  This
5662     program allows users to print the contents of the protection database
5663     or to edit the protection database without running a ptserver.  It can
5664     be used to set up a new cell without ever running in noauth mode.  Run
5665     pt_util -h for help.
5667   * The fs setcrypt and fs getcrypt commands have been added.  These
5668     commands allow the system administrator to require that the client
5669     encrypt all authenticated traffic between the client workstation and
5670     AFS.  The encryption used is weak, but is likely better than sending
5671     unencrypted traffic in most environments.  Some functions, such as
5672     looking for a volume may not be encrypted, but data transfer certainly
5673     is.  By default data is not encrypted.  At this time no significant
5674     experimentation with server performance has been conducted.
5676   * By default AFS is compiled with AFS_AFSDB_ENV, enabling the -afsdb
5677     option to be given to afsd on startup.  If this option is used, then
5678     new cells will be looked up using AFSDB records stored in DNS if they
5679     are not found in CellServDB.  This means that users can create
5680     cross-cell mountpoints in directories they control to access cells not
5681     in root.afs, and that cells in root.afs need not be in the client's
5682     CellServDB.
5684   * AFS database servers can be marked as read-only clones.  Surround the
5685     hostname in square brackets on the bos addhost command and the
5686     database server will never be elected sync site.  This is useful for
5687     cells distributed over a wide region.
5689   * The AFS servers now support the -syslog flag.  This flag causes them
5690     to log to syslog rather than to files.  This flag is not supported on
5691     NT.  For all servers besides the salvager, the flag can also be
5692     specified as -syslog=facility, where facility is an integer facility
5693     code from syslog.h.  A -syslogfacility option is provided for the
5694     salvager to accomplish the same goal.
5696   * If the --enable-fast-restart flag is given when configuring AFS, then
5697     the salvager supports the -dontsalvage flag which causes it to exit
5698     without salvaging any volumes.  If this is configured into the third
5699     command of a fs process, then the fileserver will start without
5700     salvaging.  It will fail to attach volumes that need salvaging and
5701     they can be salvaged manually.  This provides significantly better
5702     server startup performance at the cost of administrative complexity.
5704   * If the --enable-bitmap-later flag is given when configuring AFS, then
5705     the fileserver creates bitmaps for free vnodes on demand, allowing
5706     faster starts.
5708   * If bosserver finds a BosConfig.new file at startup, it reads this file
5709     and renames it to BosConfig.  This allows bosserver to be reconfigured
5710     at next restart.
5712   * The bosserver can be placed in a restricted mode in which AFS
5713     superusers are only granted limited access to the server host. The
5714     following functionality is disabled when restricted mode is in use:
5716       bos exec
5717       bos getlog (except for files with no '/'s in their name)*
5718       bos create *
5719       bos delete
5720       bos install
5721       bos uninstall
5723     specific exceptions are made for functionality that "bos salvage"
5724     uses:
5726     A cron bnode who's name is "salvage-tmp", time is now, and command
5727     begins with "/usr/afs/bin/salvager" may be created. This bnode deletes
5728     itself when complete, so no special "delete" support is needed.  This
5729     functionality may be removed in the future if a "Salvage" RPC is
5730     implimented.
5732     The file with the exact path /usr/afs/logs/SalvageLog may be fetched,
5733     since that is how bos salvage [...] -showlog is implimented.
5735     Restricted mode is enabled using a new bos command (bos setrestricted)
5736     or bossever command line switch (bosserver -restricted). Restricted
5737     mode can be disabled by a) sending the bosserver process a SIGFPE
5738     (which will then allow restricted operations until the next restart or
5739     setrestricted command) or b) editing /usr/afs/local/BosConfig (or
5740     BosConfig.new), and restarting the bosserver.
5742   * The bos UserList of trusted administrators can now contain cross-realm
5743     Kerberos principals.
5745   * udebug now takes --server not --servers.
5747   * Several error messages have been improved to include volume numbers.
5749   * Several new ports have been included for UNIX platforms: Darwin
5750     (ppc_darwin_12 and ppc_darwin_13), Linux 2.4 (i386_linux24), Linux on
5751     the Powerpc (ppc_linux22 and ppc_linux24), Linux on the Sparc
5752     (sparc_linux22, sparc64_linux22 and sparc64_linux24).
5754   * Incomplete FreeBSD and Alpha Linux ports are included.  The FreeBSD
5755     port has a working server and the Alpha Linux port has a partially
5756     working client.
5758   * A native client for Windows 95/98/ME has been added to the
5759     distribution.  With this program, a gateway machine is no longer
5760     required for Windows 9x to access AFS files.  One drive letter will be
5761     created on your machine by default - Z:.  The Z: drive will be the
5762     root of the AFS tree, allowing you to browse all sites that have AFS
5763     servers available.  Additional drive letters can be defined for other
5764     AFS directories.  A Windows Explorer shell extension is included that
5765     allows you to right click on items within an AFS tree to bring up an
5766     "AFS" menu item and perform various operations on a file or directory.
5767     The most useful item is "Access Control Lists", which allows you to
5768     view and edit the permissions of a particular directory.  Command line
5769     tools are also available in the install directory.  These commands
5770     include klog, unlog, tokens, kpasswd, symlink, fs and pts.  The
5771     installable includes a readme file that contains more information on
5772     how to use the client program and known issues.
5774   * Support for large caches in afsd.  Cachefiles are stored in
5775     subdirectories.  The default is 2048 files per subdirectory, which
5776     should work fine in most situations.  You can use the new afsd option
5777     -files_per_subdir to change this number.  Note that the first time you
5778     run afsd with this patch, your cachefiles will get moved into
5779     subdirectories.  If you subsequently run an older version of afsd, you
5780     will lose all your cached files.