Make OpenAFS 1.8.8
[openafs.git] / NEWS
1                        User-Visible OpenAFS Changes
2
3
4 OpenAFS 1.8.8
5
6   All platforms
7
8     * Improved documentation, diagnostics and error messages (14311 14326
9       14331 14367 14399 14419 14420 14427 14434 14436 14437 14438 14439
10       14440 14502 14516 14518 14546)
11
12     * Build fixes, mostly for recent compilers (14217 14298 14299 14668)
13
14     * Avoid some potential performance losses in the wire protocol (14503
15       14514)
16
17     * Avoid client connections hanging forever when the server is
18       restarted while they're active (14504 14505 14506 14507)
19
20   All server platforms
21
22     * Avoid Rx calls getting stuck on the incoming call queue for busy
23       servers (14394)
24
25     * Avoid a possible salvageserver deadlock (14283)
26
27     * Fixed salvageserver's parsing of the "-parallel all<number>" argument
28       (14285)
29
30     * Avoid potential salvager crashes (14515 14614)
31
32     * Fix "bos salvage -forceDAFS" when the BosConfig also contains a legacy
33       'fs' bnode in addition to the 'dafs' bnode (14665)
34
35     * Avoid erratic vlserver behaviour due to overflowing the maximum
36       VLDB size of 2 GB. Log a message and return an error instead (14288)
37
38     * Fixed a ptserver issue where 'pts mem -expandgroups' failed when
39       supergroups were enabled (14345) (RT #135147)
40
41     * Take read-only volumes offline while being converted to read-write
42       ones with "vos convertROtoRW", preventing them from ending up in an
43       inconsistent state when accessed during the conversion (14433)
44
45     * Avoid inconsistent volume states due to interrupted rename operations
46       and other potential issues (14449 14450)
47
48     * Add new variants to asetkey's "delete" command to allow deleting
49       non-des keys (14293)
50
51     * Improved ubik performance and robustness (14141 14142 14365)
52
53     * Fixed building the vol-bless utility, which is now also built by
54       default but still not installed and distributed (14601)
55
56     * Fixed parsing of "-cores none" when bosserver is started this way
57       (14589)
58
59   All client platforms
60
61     * Avoid crashes or panics when potentially recoverable errors
62       during cache I/O are encountered (14286)
63
64     * Avoid flooding servers with NAT pings, which could happen under
65       certain circumstances (14364)
66
67     * Avoid possible panics during client startup or shutdown (14393 14441)
68
69     * Avoid potential buffer overflows by one character in the "bos" client
70       program and in libadmin client programs (14664 14666 14698)
71
72     * Fixed a slow kernel memory leak triggered by retrieving tokens for
73       userspace commands as an authenticated user (14667 14663) (RT #135238)
74
75     * Fixed several potential problems in "aklog -keytab" (14478 14479
76       14480 14481 14482)
77
78     * Performance improvements (14391)
79
80     * Avoid unexpected "cold" shutdowns upon umount /afs on platforms
81       which should perform a "warm" shutdown by default (14610)
82
83     * Avoid memory leaks during shutdown (14615 14616)
84
85     * Fixed building the afscp utility, which is still not built by default
86       though (14627)
87
88   Linux clients
89
90     * Support mainline kernels up to and including 5.13 (14267 14268 14269
91       14315 14563 14564 14565) (RT #135242)
92
93       Note that as of mainline kernel 5.13, OpenAFS currently won't build
94       on PowerPC due to a new ABI restriction.
95
96     * Avoid failures of cache I/O operations in the context of tasks
97       restricted by security mechanisms like AppArmor (14082 14099)
98
99     * Avoid a crash while loading the kernel module when reading from
100       /proc/fs/openafs/CellServDB before afsd has started (14284)
101
102     * Avoid more possible causes of getcwd() failures (14451)
103
104     * Restore the -setpag functionality in some older utilities like klog
105       (14327 14328)
106
107   macOS
108
109     * Added support for release 11.0 "Big Sur" (14597 14598 14605 14600)
110
111   FreeBSD
112
113     * Support releases 11.2, 12.1, 12.2 (14520 14537 14590)
114
115     * Add a wide range of FBSD specific fixes and improvements (14521..36)
116
117 OpenAFS 1.8.7
118
119   All platforms
120
121     * Fix initial Rx Connection ID (CID) generation.
122       Remove stale initialization and overflow detection logic that resulted
123       in connection failures due to all CIDs being set to 0x80000002.
124       (14493, 14494, 14497)
125
126 OpenAFS 1.8.6
127
128   All platforms
129
130     * Address warnings and errors encountered when building OpenAFS with
131       modern compilers like gcc9 or recent clang (13727..45 13749..50 13756
132       13846 13879)
133
134     * Avoid some rare cases of Rx calls getting stuck in the incoming queue
135       (13892)
136
137     * Display the usage of simple commands (commands without subcommands) when
138       run only with the -help option (13894)
139
140     * Fix a memory leak in the cache manager and the fileserver while
141       processing "fs uuid" or "fs setcbaddr" (13899)
142
143     * Fix a memory leak when reopening krb local realms configuration (13900)
144
145     * Avoid possible crashes when freeing kerberos contexts (13902)
146
147   All server platforms
148
149     * Do not leave empty directories behind in the file server vice partition
150       when running the "vos zap -force" command (13897)
151
152     * Fix "vos zap -force" failures when the volume being zapped does not have
153       an entry in the fileserver's volume group cache (e.g., during fileserver
154       startup) (13896)
155
156     * Relax the length limits on some membership lists used in ptserver RPCs,
157       introduced in release 1.8.0 to prevent denial of service attacks, to
158       accommodate use cases of some larger existing sites (13844)
159
160     * Improved diagnostics and error messages (13898 13906..8 13938)
161
162     * Ensure that fileservers running in readonly mode actually reject all
163       write requests, but introduce a -admin-write switch allowing writes
164       by members of the system:administrators group (14018 14019)
165
166   All client platforms
167
168     * Require the -insecure_des switch to be passed to aklog and klog.krb5
169       to make them work with single-DES encryption types (13791)
170
171     * Avoid a panic due to a retryable error - retry in a background request
172       instead (13847)
173
174     * Avoid blocking other functions on the completion of some potentially
175       long-running RPCs issued by the server (13893)
176
177     * Fix a potential memory leak in "fs getserverprefs" when the pioctl fails
178       with E2BIG (13895)
179
180     * Avoid the local cache incorrectly reflecting the state of a file on the
181       fileserver after flushing large chunks of data to the server. This
182       issue was present on FreeBSD clients, but probably not Linux/Solaris
183       ones (13951) (RT #135041)
184
185     * After a VLDB lookup of a read-write volume already failed, don't bother
186       looking up corresponding read-only or backup volumes since those lookups
187       are bound to fail, in order to make the client more responsive and
188       avoid unnecessary load on the vlserver (13968)
189
190     * Allow a "vos rename" to succeed if the new volume name is the same as
191       that in the current VLDB, to make it possible to complete a previously
192       interrupted volume rename (14055)
193
194     * Allow processes which are sleeping due to PAG throttling to be killable
195       (13974).
196
197     * Fix set PAG failures due to signals (13975).
198
199   Linux clients
200
201     * Support mainline kernels up to and including 5.7 (14069 14094 14095
202       14209 14210)
203
204     * Make builds succeed with --enable-checking for mainline kernels
205       5.3-rc2 and later (13910)
206
207     * Avoid possible deadlocks (13748 13765)
208
209     * Fix build of libuafs on ppc64le (14104)
210
211     * Fix build on certain recent 32-bit distributions (14234) (RT #135084)
212
213   macOS
214
215     * Support building, packaging and notarization on macOS 10.15 "Catalina"
216       (14031..7 14068)
217
218   Microsoft Windows
219
220     * Build fixes (13848..52)
221
222
223 OpenAFS 1.8.5
224
225 All platforms
226
227     * Fix OPENAFS-SA-2019-001: information leakage in failed RPC output
228       Generated RPC handler routines ran output variables through XDR encoding
229       even when the call had failed and would shortly be aborted (and for
230       which uninitialized output variables is common); any complete packets
231       assembled in the process would be sent to the peer, leaking the contents
232       of the uninitialized memory in question.
233
234     * Fix OPENAFS-SA-2019-002: information leakage from uninitialized scalars
235       Generated RPC handler routines did not initialize output variables of
236       scalar (fixed-length) type, since they did not require dedicated logic to
237       free.  Such variables allocated on the stack could remain uninitialized
238       in some cases (including those affected by OPENAFS-SA-2019-001), and the
239       contents of uninitialized memory would be returned to the peer.
240
241 All server platforms
242
243     * Fix OPENAFS-SA-2019-003: fix crash in database servers
244       The ubik debugging RPCs prioritize being fast and non-disruptive to
245       database operations over strict correctness, and do not adhere to the
246       usual locking protocol for data access.  A data race could cause a NULL
247       dereference if the second memory load was not optimized out by the
248       compiler.
249
250 OpenAFS 1.8.4
251
252   All platforms
253
254     Build system updates to remove obsolete autoconf macros and remove missing
255     script warning during builds (13480, 13481, 13482, 13483, 13484, 13486,
256     13789, 13790).
257
258     Build system update to fix a conditional check in the pthread.m4 autoconf
259     file (13595)
260
261     Build system update to create the man3 subdirectory, fixing a
262     reported build failure (13535).
263
264     Remove the last reference to src/mcas in the documentation (13558).
265
266   All server platforms
267
268     Fix fileserver's parsing of the options -vlruthresh, -vlruinterval,
269     -vlrumax and -novbc (13680).
270
271     Fixes to make ptserver's behaviour when run in restricted mode consistent
272     with the documentation: Non-members of the system:administrators group
273     are no longer allowed to issue the adduser, setfields and delete pts
274     commands, and all members of system:administrators are now allowed to
275     issue pts commands in this mode, not just the admin principal (13686..88).
276
277   All client platforms
278
279     Fix missing Rx call clean-up after failing to read dcaches from a file
280     server (13511).
281
282     Fix an Rx call leak for calls aborted by a connection abort after the call
283     was initialized but before use (13517).
284
285     Remove the obsolete afs_xosi lock to remove unnecessary serialization of
286     VOP_GETATTR calls. This can lead to improved performance under heavy
287     workloads (13529).
288
289     Increase the size of the Directory Name Lookup Cache (DNLC) to improve
290     cache performance (13559).
291
292     Fix getting tokens for cells with a three character name (13679).
293
294     Avoid a misleading message about the cell being used when aklog is run
295     with the -cell parameter but the AFSCELL environment variable is set to
296     a different cell (13676).
297
298     Build system update to honor the CFLAGS environment variable when building
299     libuafs (13544).
300
301   Linux
302
303     Support for mainline kernels up to 5.3 (13787, 13789).
304
305     More fixes for improper use of ENOENT fixes to avoid incorrect use of linux
306     negative dentry cache, which can lead to false ENOENT errors (13542, 13543,
307     13590, 13692) (RT #134904).
308
309     Return errors instead of returning incomplete directory listings when the
310     directory objects are incomplete in the cache (13591).
311
312     Add ppc64le_linux26 sysname for the ppc64le architecture (13636, 13637,
313     13589).
314
315     Fix configure check for a kernel time function in order to build on
316     Linux 5.0 (13523).
317
318     RPM packaging update for RHEL8 adding a build requirement to ensure the
319     kernel module can be built from the SRPM (13563) (RT #134900).
320
321     On systemd based RHEL/Fedora systems, start the client after dkms startup
322     is finished if the latter is installed and enabled, to avoid attempting
323     starts without the kernel module being available yet (13674) (RT #134974).
324
325   MacOS
326
327     Build system updates for MacOS (13584).
328
329   Solaris
330
331     Add CTF debugging records to userspace objects to improve debugging
332     of servers (13487).
333
334     Convert the cache manager vnodes to be non-embebbed on Solaris 11 in order
335     to make the cache manager more resilient across Solaris 11 changes (13524,
336     13525, 13526, 13527, 13528).
337
338
339 OpenAFS 1.8.3
340
341   All platforms
342
343     * Improved diagnostics and error messages (13186 13411 13417)
344
345     * Avoid sending RX packets with random garbage in the userStatus field
346       (13332)
347
348     * Fixed detection of the RX initialization status (13416)
349
350     * Assorted fixes to avoid segmentation faults and other potential problems
351       by detecting internal errors rather than letting them go unnoticed
352       (13329 13372)
353
354   All server platforms
355
356     * Fixed a build problem accidentally introduced in release 1.8.2 (13328)
357
358     * Assorted efficiency improvements in the ubik implementation (13153 13218
359       13188 13353)
360
361     * Fixed locking around transaction list processing in volserver to avoid
362       segmentation faults and other potential problems (13336 13337)
363
364     * When the volserver attempts to remove a temporary volume after a
365       transaction, but the volume was already removed, e.g., by the salvager,
366       this is no longer treated as an error (13235)
367
368   All client platforms
369
370     * Update the CellServDB to the latest version from grand.central.org from
371       May 14th 2018 (13409)
372
373     * Avoid a panic during cache initialization when allocating the required
374       memory fails (13307)
375
376     * Add back the packet counters and timestamps to "vos status" output
377       which had been missing since release 1.8.0 (13421)
378
379     * Correctly handle errors encountered while reading data from the server
380       and writing it to the cache, e.g., due to a full cache partition (13443)
381
382     * Avoid a panic due to a recoverable error while flushing cache items
383       (13503)
384
385   Linux clients
386
387     * Support mainline kernels 4.20 and 5.0 and distribution kernels with
388       backports from those (13405 13406 13440 13441 13442)
389
390     * DKMS-related fixes in Red Hat packaging (13438 13479)
391
392   macOS
393
394     * Support building and packaging on macOS 10.14 "Mojave" (13412 13413)
395
396
397 OpenAFS 1.8.2
398
399   All platforms
400
401     * Fix OPENAFS-SA-2018-002: information leakage in RPC output variables
402       Various RPC routines did not always initialize all output fields,
403       exposing memory contents to network attackers.  The relevant RPCs include
404       an AFSCB_ RPC, so cache managers are affected as well as servers.
405
406   All server platforms
407
408     * Fix OPENAFS-SA-2018-003: denial of service due to excess resource consumption
409       Various RPCs were defined as allowing unbounded arrays as input, allowing
410       an unauthenticated attacker to cause excess memory allocation and tie up
411       network bandwidth by sending (or claiming to send) large input arrays.
412
413     * Fix OPENAFS-SA-2018-001: unauthenticated volume operations via butc
414       On systems using the in-tree backup system, the butc process was running
415       with administrative credentials, but accepted incoming RPCs over
416       unauthenticated connections; these incoming RPCs in turn triggered
417       outgoing RPCs using the administrative credentials.  Unauthenticated
418       attackers could construct volue dumps containing arbitrary contents
419       and cause these dumps to be restored and overwrite arbitrary volume
420       contents; afterward, the backup database could be restored to its
421       initial state, hiding evidence of the unauthorized changes.
422
423       Running butc with -localauth now requires authenticated incoming
424       connections, and the backup utility makes authenticated connections to
425       the butc.  Audit capabilities have been added to the butc RPC handlers.
426       Command-line arguments are provided to retain the (insecure) historical
427       behavior until all systems have been upgraded.
428
429 OpenAFS 1.8.1.1
430
431   Linux Clients
432
433     * Support for mainline kernel 4.18 and distribution kernels with backports
434       from it (13268)
435
436 OpenAFS 1.8.1
437
438   All Platforms
439
440     * Improve the usability and consistency of the public API: install missing
441       headers, and add additional symbols to the export list for shared libraries.
442
443     * Improved Rx abort generation: use the proper serial number for an existing
444       connection if possible, and 0 otherwise (to improve debugging).
445
446     * Assorted minor fixes in response to static analysis of the codebase.
447
448     * Fix memory-safety error in XDR decoding of enumerated types.
449
450   All Server Platforms
451
452     * Fix reference counting error that could cause an assertion failure
453       in some workloads.
454
455     * vldb_check -fix will no longer corrupt the vldb when multiple MH blocks are present.
456
457     * Assorted cleanups and efficiency improvements in the ubik implementation.
458
459     * Return a valid InlineBulkStatus response in error cases.
460
461     * The fileserver now rejects invalid partition names when attaching partitions.
462
463   All Client Platforms
464
465     * Fix volume callbacks (e.g., when running 'vos release').
466
467     * Treat failure to obtain a DSlot as a hard error for that cache partition,
468       avoiding a flood of "disk cache read error in CacheItems" log messages,
469       and reducing the chance of subsequent panic.
470
471     * Improve error messages for invalid values with -volume-ttl.
472
473     * Remove useless error message:
474       "find_preferred_connection: no connection and !create".
475
476     * Avoid passing NULL to a kernel memory deallocator, which is not guaranteed
477       to be safe on all systems.
478
479   Linux
480
481     * Add support for 64-bit ARM clients ("arm64").
482
483     * Fix panic when cache bypass is enabled.
484
485     * Improve cache manager behavior when unable to open cache files.
486
487     * Improvements to the RPM packaging.
488
489     * Detect out-of-memory when using kernel pages for writing.
490
491   Solaris
492
493     * Fix various issues in the build process for recent Solaris versions.
494
495   MacOS
496
497     * Fix clients on OS X 10.13.
498
499   FreeBSD / NetBSD / OpenBSD
500
501     * Fix panic triggered during periodic cleanup operations and shutdown.
502
503 OpenAFS 1.8.0
504
505   All Platforms
506
507     * Substantial code quality improvements, largely spotted by Coverity and
508       clang's static analysis.
509       - Add new library for platform independent functions (opr).
510       - Remove arbitrary path name length limits.
511       - Convert to Heimdal's roken library for reliability.
512       - Avoid garbage in allocated buffers (calloc).
513       - Modernize signal handling in pthreaded server processes (softsig).
514       - Improve code comments and additional Doxygen style comments.
515       - Reduce compiler warnings, dead code, unused variables, and
516         undefined behavior.
517       - Fix bugs found by static code analyzer (clang-analyzer).
518       - Improved unit test coverage.
519       - Make VLDB flag definitions consistent.
520       - Improve use of run-time assertions and add static assertions.
521       - Add compiler attributes to assist static analyzers.
522       - Clean up include headers in the entire tree.
523       - Improve command-line handling library (libcmd).
524       - Replace hash functions with Jenkin's hash function for faster
525         and more evenly distributed lookups.
526       - Provide a red-black tree data structure to enable algorithmic speedups.
527       - Convert backup and salvage servers to the common logging API (libutil).
528       - Improve volume id data type consistency (VolumeId).
529       - Import APIs for kerberos-style profile configuration support.
530       - Add new APIs to support UserList identities.
531       - Add new APIs to support tabular output from command-line utilities.
532       - Convert vnode macros to inline-functions.
533
534     * Improved support for non-DES encryption types:
535       - Convert to Heimdal's hcrypto library to support RFC 3961.
536       - Add extended key file format replacing rxkad.keytab, and
537         new key management APIs.
538       - Add support for extended key types to asetkey.
539       - Add akeyconvert to assist in upgrading to OpenAFS 1.8.x by converting an
540         existing rxkad.keytab file to an extended key file.
541       - Do not install the kaserver and related utilities by default to
542         discourage the use of these DES-dependent components.
543       - Remove obsolete klogin and klogin.krb programs.
544       - Add new token APIs to support new rx security classes.
545
546     * Migrate from LWP to POSIX threads (pthreads):
547       - Convert the ptserver and vlserver from LWP to pthreads.
548       - Remove LWP version of the file server binary.
549       - Convert afsd, aklog, asetkey, klog.krb5, pts, udebug, and vos, from LWP
550         to pthreads.
551
552     * Improvements to Rx:
553       - Restructure the Rx API to privatize the implementation.
554       - Convert rx events to a red-black tree data structure to improve
555         performance.
556       - Convert from mutexes to atomic operations for counters to reduce lock
557         contention.
558       - Provide per-opcode Rx statistics.
559       - Add an rx_opaque data type to support non-DES encryption types
560         and general code cleanup.
561       - Wake up the application thread after 'twind' is updated to avoid 100ms
562         transmit delays when the receive window transitions from closed to
563         open.
564       - Fix for OPENAFS-SA-2017-001: sanity-check peer transport parmeters
565         received in ack trailers
566
567     * Libraries (both internal and installed) are built using libtool, including
568       libuafs. The resulting shared libraries for libafsrpc and libafsauthent
569       should be more usable than previously.
570
571     * Improvements to the build system:
572       - Convert to libtool to build shared libraries.
573       - Clean up and improve the build system.
574       - Support out of tree builds.
575       - Add a makefile target to generate Doxygen source code documentation.
576       - Link the Java API for OpenAFS with libuafs.a and remove the
577         libjuafs.a library.
578       - Always build the rxperf tool.
579       - Fix man-page generation by make after ./regen.sh -q
580       - Support the SOURCE_DATE_EPOCH environment variable to improve build
581         reproducibility.
582       - Modernize language specific SWIG typemaps for libuafs Perl bindings.
583       - Refactor acinclude.m4 into a set of smaller m4 files (12876, 12877, 12878)
584
585     * Improvements to documentation:
586       - Document the new KeyFileExt file.
587       - Reorganized the README files.
588       - Improvements and fixes to documentation generation.
589       - Add experimental epub and mobi support
590       - Remove obsolete LWP information from the file server documentation.
591       - Update and reorganize the Quick Start Guide.
592       - Update the Admin Guide.
593       - Remove AIX, HP-UX, and IRIX information from the Quick Start Guide.
594       - Document the vldb and prdb (ubik) file formats.
595       - Add PtLog man page.
596       - Corrections and clarifications to man pages.
597       - Add ubik threading analysis doc.
598       - Normalize the location of text documents in the source tree.
599
600     * Improvements for troublshooting, debugging, and testing:
601       - Log more details on volume-server-to-fileserver communication errors
602         when possible.
603       - Set thread names in pthreaded servers on platforms which support
604         thread names.
605       - Add dynroot lock tracking to cmdebug
606       - Fix tracking of an fstrace call site in the cache manager background
607         process.
608       - Add the afsload tool to simulate multiple cache managers for file server
609         load testing.
610       - Add run-time checks for refcount imbalances in the cache manager.
611       - Fix missing newlines in afsd -debug output.
612
613     * Developer tool improvements:
614       - Improvements and fixes for rxgen (used to generate Rx RPC bindings).
615       - Add tool for man page verification of command options.
616       - Add tool to find Unix cache manager lock identification numbers.
617       - Add an option for pretty build output.
618
619     * RPM packaging updates:
620       - Update the spec file to keep up with accumulated changes.
621       - Move the klog.krb5 man page to the openafs-krb5 sub-package.
622       - Remove stray man pages. (12870, 12871)
623       - Prevent double-starting client on RHEL7
624       - Convert rpm spec file from deprecated 'make dest' to 'make install'.
625       - Fix rpmbuild command line option default handling.
626       - Support older versions of rpmbuild which do not support the
627         rpmbuild %exclude directive. (12873)
628       - Move the legacy kaserver and related programs to separate sub-packages,
629         which are only built when rpmbuild is given the '--with kauth' option
630         (12600, 12872)
631       - Package the libuafs perl bindings (12921)
632
633     * Add a new protection error code (PRNAMETOOLONG) instead of silently
634       truncating names which exceed the maximum name length (PR_MAXNAMELEN).
635
636     * Add an implementation limit (50000) on the number of names/ids which can
637       be transmitted by unauthenticated clients to the ptserver, avoiding
638       excessive resource consumption from unauthenticated requests.
639
640     * Add the -config option to vos, pts, and aklog to specify the path to the
641       cell configuration files.
642
643     * Add more details in vos release -verbose output.
644
645     * Add the cacheout -encrypt option to encrypt communication between the
646       cacheout client and the fileserver.
647
648     * Add the command line options to the afsio program to enable encryption of
649       traffic between afsio and the fileserver (-clear, -crypt).
650
651     * Add the vos release -force-reclone option to force recloning the volume to
652       be released without forcing a full volume dump being transmitted to all
653       remote sites.
654
655     * Fix vos to avoid writing loopback addresses into the VLDB in
656       certain cases.
657
658     * Print bos and pts error messages to standard error instead of
659       standard out.
660
661     * Improve formatting of the -help output of all commands.
662
663     * Change -n to -dryrun in all backup subcommands.
664
665     * Change the backup deletedump -port command line option to -portoffset.
666
667     * Add user and build host in the version string returned by
668       rxdebug -version.
669
670     * Support recent versions of gcc (7.2.1) (12897)
671
672   All Server Platforms
673
674     * Ubik servers using pthreads are now available and are used by default
675
676     * As part of improving Ubik reliability in certain edge cases, an extra
677       election cycle (about 60 seconds) may be needed before writes are
678       permitted.  This is a conservative change that may be removed in
679       the future.
680
681     * Avoid continually retransmitting the ubik database to remote sites when
682       a write transaction occurs as remote sites are attempting to rejoin the
683       ubik cluster. (12896)
684
685     * Ensure the ubik database version number is updated on remote sites at the
686       point the database is transferred to remote sites instead of waiting for
687       the next ubik beacon. This avoids write transaction failures during the
688       window between the database transfer and the next ubik beacon (12885).
689
690     * Remove periodic background fsync by the fileserver (ihandle fsync thread).
691
692     * Fix potential file handle leak in the file server ihandle caching layer.
693
694     * Disable the so-called "hot threads" feature in the file server. The hot
695       threads feature was intended as an optimization for dispatching incoming
696       calls to the current listener thread, but has been reported to incur a
697       performance penalty on modern multi-core systems.
698
699     * Do not permit creation of users with id of ANONYMOUSID.
700
701     * Do not save/restore host states in the fsstate.dat file for hosts which
702       are in the process of retrieving CPS information from the ptserver when
703       the fileserver is being shutdown. This fixes a bug in which the fileserver
704       will incorrectly block all threads following a restart.
705
706     * Add the ptserver -restrict_anonymous option to inhibit exposure of user
707       names from the ptserver.
708
709     * Do not truncate server log files by default when server processes
710       are started.  The -transarc-logs option provides backward compatibility
711       with IBM AFS log handling on server startup. Log messages may be lost
712       in back-to- back restarts when a server is running in this mode.
713
714     * Reopen server logs on SIGUSR1. This may be used by third-party log
715       rotation tools, such as logrotate, to reopen the log file handles after
716       log files have been renamed.
717
718     * Fix various bugs when logging with -mrafslogs enabled.
719
720     * Dynamically reload the kerberos realm to AFS cell mapping (krb.conf) and
721       exclusions for mapping kerberos principals to AFS identities (krb.excl)
722       configuration when the CellServDB cell configuration file is touched.
723       Previously, a restart of the file server was required after updating the
724       kerberos mapping configuration files.
725
726     * Add a command line option (-restricted_query) to the vlserver and
727       volserver to restrict information queries about volumes to a specific
728       group of users.
729
730     * Add a command line option to the server programs to specify an alternate
731       fully qualified log file name (-logfile).
732
733     * Add a command line option (-config) to the server programs to specify
734       an alternate path to the server configuration.
735
736     * Add a command line option to the ptserver and vlserver to specify an
737       alternate path to the database data files.
738
739     * Add a command line option to the volume server to enable encryption of
740       volume-server-to-volume-server-traffic (-s2scrypt).
741
742     * Increase the maximum number of LWP threads allowed for the ptserver and
743       vlserver from 16 to 64 (-lwp).
744
745     * Remove an unused file server command line option (-k).
746
747     * Fix an incorrect assertion in Demand Attach File Server which could cause
748       the file server process to abort in certain rare conditions.
749
750     * Deprecate the -bitmap-later configure option for non-Demand-Attach File
751       Servers (DAFS).
752
753     * Add -vhashsize support to non-Demand-Attach File Servers (DAFS).
754
755     * Add support for subnet ranges in the NetInfo and NetRestrict
756       configuration files.
757
758     * Add the GetXStats RPC to the audit log.
759
760     * Fix directory creation by bosserver when built for non-Transarc paths.
761
762     * Fix incomplete list of server addresses retreived by vos listaddr when the
763       vldb contains unreferenced multi-homed server entries.
764
765     * Remove obsolete bos blockscanner and unblockscanner commands that
766       were only needed for the removed MR-AFS functionality.
767
768     * Remove obsolete bos salvage options that were only used by the
769       removed MR-AFS functionality..
770
771     * Remove calls to the deprecated sbrk() function.
772
773     * Add an experimental feature to database servers to support ubik reads
774       while write transactions are in progress, enabled at build time with the
775       --enable-ubik-read-while-write configure option. This feature is not
776       considered ready for production usage at this time.
777
778     * Avoid filling the FileLog with "Volume x offline: not in service" when
779       a volume is administratively taken offline with vos offline.
780
781     * Print an error message when bosserver is started with an unknown
782       command line option.
783
784     * Modify the volume updateDate when the volume is changed by a salvage.
785
786     * Volume usage statistics are now preserved during reclone and restore
787       operations by default, the behavior previously enabled by
788       the -preserve-vol-stats flag to the volserver.  The historical behavior
789       can be retained via the -clear-vol-stats argument.
790
791   All Client Platforms
792
793     * Use rxkad_crypt by default for connections to fileservers.  This matches
794       the existing behavior of the Windows client and has been applied by
795       the distribution packaging on many platforms already.
796
797     * Add support for relative ACL changes with fs setacl. If a single plus (+)
798       or minus (-) character is appended to the rights' letters argument, the
799       new rights are computed relatively to the existing ones.
800
801     * Remove afsd -settime and afsd -nosettime support.
802
803     * Add the afsd -inumcalc option to specify the method used to calculate
804       inode numbers presented by AFS.
805
806     * Add the afsd -volume-ttl option to specify set the maximum amount of time
807       information retrieved from the vlserver will be cached, regardless of
808       callback expiry times.
809
810     * Return EIO on internal errors instead of the misleading ENOENT.
811
812     * Log ICMP errors received, if any, for unreachable servers.
813
814     * Improve performance of clients with multiple PAGs for different cells.
815
816     * Fix race condition between changing and using user tokens among cache
817       manager threads.
818
819     * Fix fs sysname for users with UID 2748 and 2750 when not running
820       in -rmtsys mode.
821
822     * Add Perl bindings for the user-space cache manager library (libuafs).
823
824     * Fixes to the bypasscache feature.
825
826     * Fix fs getcacheparms miscounts.
827
828     * Remove the obsolete Netscape plugin.
829
830     * Fix building gtx when ncurses is linked against libtinfo.
831
832     * Update to the GCO CellServDB update from 14 March 2017.
833
834   Linux
835
836     * Remove Linux 2.2 and 2.4 support.
837
838     * Changes to avoid EIO errors with multiple processes doing intensive mmap
839       writing. (Drop PageReclaim AOP_WRITEPAGE_ACTIVATE.)
840
841     * Prevent fakestat data inconsistencies in certain cases (131855).
842
843     * Fix dentry leak which can cause a crash on shutdown.
844
845     * Fix improper use of ENOENT and avoid incorrect use of linux negative
846       dentry cache.
847
848     * Use a more correct (less aggressive) scheme to react to downward
849       pressure on cache usage, avoiding d_invalidate(), which can cause
850       getcwd() failures on RHEL 7.4.
851
852     * Apply a workaround to be compatible with RHEL 7.5's KABI preservation
853       strategy for reading directories.
854
855     * Improve error reporting when encountering corrupt directories.
856
857     * Improve rx error handling in the Linux cache manager.
858
859     * Rename kpasswd to kapasswd when packaging RPMs to avoid colliding with
860       Kerberos kpasswd.
861
862     * Do not use the obsolete --enable-largefile-fileservers configure option
863       when packaging RPMs.
864
865     * In Red Hat packaging, use a separate rpm for kmod debuginfo,
866       removing a needless tight version dependency on the userspace package.
867       (12822, 12875)
868
869     * Use the RemainAfterExit systemd feature to avoid premature exit
870       when -afsdb is not given, for RPM packages.
871
872     * Remove Debian packaging files from the OpenAFS source tree. Debian
873       packaging files are currently maintained in the downstream Debian
874       infrastructure.
875
876     * Add the sparc_linux26 sysname.
877
878     * Desupport 32-bit Linux kernels on s390/s390x.
879
880     * Fix Debian/Ubuntu build regression on kernel 3.16.39.
881
882     * Fix --enable-kernel-debug for linux 4.8+.
883
884     * Fix a hang encountered when accessing a previously removed
885       directory entry (12811).
886
887     * Support linux 4.10, 4.11, 4.12, 4.13, 4.14, 4.15
888
889   Solaris
890
891     * Remove support for all Solaris and SunOS platforms prior to Solaris 8.
892
893     * Build 64-bit binaries for Solaris x86 by default.
894
895     * Use one-group PAGs on Solaris 11, which is required for PAG support
896       on Solaris 11 since supplemental groups must be sorted starting with
897       Solaris 11.1.
898
899     * Update search paths for solaris cc for recent versions Solaris Studio.
900
901     * Modernize declaration of module dependences by converting from the
902       deprecated _depends_on symbol to ELF dependencies.
903
904     * Avoid BAD TRAP panic due to invalid opcodes on x86 with Studio 12.5.
905
906     * Add ctf debug records to Solaris kernel modules when debug builds
907       are enabled and the ctf tools are present (ctfconvert/ctfmerge).
908
909     * Save kernel module function arguments on x86 for debugging purposes.
910
911   MacOS
912
913     * Stop processing upcalls once rx shutdown starts.
914
915     * Enable atomics for the darwin kernel.
916
917     * Add a syscall to enable/disable bulkstat at run-time, which is
918       disabled by default.
919
920     * Fix path to binaries in the prefpane.
921
922     * Fix builds on MacOS 10.12 by building only the active architecture
923       by default.
924
925     * Support versions up through 10.13 (High Sierra) and APFS
926
927   FreeBSD
928
929     * Use the native kernel module build system instead of an ad hoc
930       replacement build system.
931
932     * Remove FreeBSD packaging files from the OpenAFS source tree. FreeBSD
933       packaging files are currently maintained in the downstream FreeBSD Ports
934       Collection.
935
936     * Stay up to date with new FreeBSD releases (through 10.3).
937
938     * Do not claim AFS_VM_RDWR_ENV
939
940     * Add sysnames and files for i386 and amd64 10.4, 11.1, and 12.0
941      (12-CURRENT, at present). (12887, 12888)
942
943     * Remove trailing semicolons to fix the build on FreeBSD (12899)
944
945   NetBSD
946
947     * Stay up to date with new NetBSD releases (through 7.x)
948
949     * Update to use cprng(9) as the randomness source on NetBSD 6.99/7.x.
950
951     * Build system updates for NetBDS 6.99.x
952
953     * Do not claim AFS_VM_RDWR_ENV
954
955   OpenBSD
956
957     * Stay up to date with new OpenBSD releases (through 4.7)
958
959     * Do not claim AFS_VM_RDWR_ENV
960
961   AIX
962
963     * Updates for AIX support.
964
965     * Fix build system for AIX exports.
966
967     * Add the uidpag and localuid runtime options to the aklog LAM plugin.
968       (These runtime options override the use of UID-based PAGs, which were
969       introduced to appease the CDE screensaver.)
970
971 OpenAFS 1.6.21
972
973   All platforms
974
975     * Avoid a possible 100ms transmit delay in the RX protocol when a peer's
976       receive window transitions from closed to open (12627)
977
978     * Documentation improvements (12476 12477 12559[RT #133339])
979
980   All server platforms
981
982     * When bosserver is started with an unknown option, print an error message
983       and exit with a non-zero value rather than failing silently (12631)
984
985   All DB server platforms
986
987     * Hold the DB lock while checking for an aborted write transaction (12516)
988
989   All file server platforms
990
991     * On demand attach fileservers, don't save or restore a client's host
992       state if CPS ("Current Protection Subdomain") recalculation for it is
993       in progress, to avoid fileserver thread exhaustion (12568)
994
995     * On demand attach fileservers, avoid flooding the log with error messages,
996       which could happen when the fileserver was restarted while a volume was
997       offline (12569)
998
999     * Update a volume's "Last Update" time when its content is modified by
1000       the salvager, to make the change visible in the output of "vos examine"
1001       and to backup services (12633)
1002
1003   All client platforms
1004
1005     * Corrected the DCentries bucket counts for very large and zero length
1006       files in the output of "fs getcacheparms -excessive" (12604 12605)
1007
1008     * Fixed a bug that prevented users with GID 2748 and 2750 from executing
1009       the "fs sysname" command on clients running afsd with -rmtsys (12607)
1010
1011     * Provide a new -inumcalc switch for afsd to allow enabling the alternative
1012       MD5 method of inode number calculation, which was previously only
1013       possible on Linux and through the sysctl interface (12608 12632)
1014
1015   Linux clients
1016
1017     * Support for mainline kernel 4.12 and distribution kernels with backports
1018       from it (12624 12626)
1019
1020     * Re-added the improved algorithm for freeing unused vcaches to reduce
1021       memory consumption first introduced with the 1.6.18 release, together
1022       with a fix for the issue leading to its removal in 1.6.18.2 (12448..12451)
1023
1024   macOS clients
1025
1026     * Fixed a crash while stopping the client on macOS 10.12 "Sierra" (12602)
1027
1028
1029 OpenAFS 1.6.20.2
1030
1031   All platforms
1032
1033     * Build fixes required by recent compilers or platforms (12514 12521 12534
1034       12536 12538)
1035
1036     * Allow the bos server to start successfully in the presence of those, by
1037       accepting a now checked return value indicating that the client ThisCell
1038       and CellServDB already exist (12522)
1039
1040   Linux clients
1041
1042     * Support for mainline kernels 4.10 and - most likely - 4.11 and
1043       distribution kernels with backports from them (12530 12588..12590 12598)
1044
1045     * Support for distribution kernels with partial backports from 4.9 (12535)
1046       (RT #134158)
1047
1048     * In Red Hat packaging, moved the klog.krb5 manual page into the krb5
1049       subpackage (12511)
1050
1051     * In Red Hat packaging, prevent systemd from double-starting the client
1052       (12587)
1053
1054     * Allow aklog to function on current S390/S390x (12499)
1055
1056   Solaris clients
1057
1058     * Make process authentication groups work on Solaris 11, now using a single
1059       group ID (12524..12527)
1060
1061     * Fix a BAD TRAP panic on Solaris 11 clients built with Studio 12.5 (12567)
1062
1063   macOS clients
1064
1065     * Fixed the preference pane for OS X 10.11 and later (12512)
1066
1067 OpenAFS 1.6.20.1
1068
1069   All platforms
1070
1071     * Build fixes required by recent compilers (12482..12484)
1072
1073   Linux clients
1074
1075     * Support for mainline kernel 4.9 and distribution kernels with
1076       backports from it (12478..12480)
1077
1078     * In Red Hat packaging, make systemd deal correctly with the client
1079       when no userland processes remain after starting it (12481)
1080       (RT #133482)
1081
1082   macOS
1083
1084     * Support for release 10.12 "Sierra" (12431 12432)
1085
1086     * Avoid a crash in the Mounts tab of the OpenAFS preference pane (12447)
1087
1088 OpenAFS 1.6.20 (Security Release)
1089
1090   All platforms
1091
1092     * Fix for OPENAFS-SA-2016-003: file and directory names leak due to
1093       reuse of directory objects without zeroing the contents
1094       (12461 12462 12463 12464 12465)
1095
1096 OpenAFS 1.6.19
1097
1098   All platforms
1099
1100     * Documentation improvements (12304)
1101     * Fixes for test failures (12396 12415)
1102
1103   All DB server platforms
1104
1105     * Avoid potentially writing to an out of date volume location or protection
1106       database, or losing a database write, which could happen in rare cases
1107       under special conditions during database leader election
1108       (12339 12389)
1109
1110   Solaris clients
1111
1112     * Allow the fsinfo::: DTrace provider to work with AFS files (12371)
1113
1114   Linux clients
1115
1116     * Don't commit more data to a file than was actually copied during writes,
1117       which could happen on architectures with a page size > 4 KiB (12413)
1118     * Fixed build on PPC64 with GCC 6.1 (12388) (RT #133407)
1119     * Fixed build on x86_64 with recent GCC (12365 12366)
1120
1121
1122 OpenAFS 1.6.18.3
1123
1124   Linux clients
1125
1126     * Support for mainline kernel 4.7 and distribution kernels with
1127       backports from it (12348)
1128
1129   Solaris clients
1130
1131     * Fixed memory mapped I/O on files >= 4 GiB (12349 12350)
1132
1133       Note that there is a suspicion that this might break the client
1134       on very old Solaris releases (2.6). If it does, the breakage should
1135       occur at build time.
1136
1137   OS X
1138
1139     * Added tooling to build a package for OS X 10.10 "Yosemite" and
1140       10.11 "El Capitan" (12335 12351)
1141
1142
1143 OpenAFS 1.6.18.2
1144
1145   Linux clients
1146
1147     * Support for mainline kernel 4.6 and distribution kernels with
1148       backports from it (12332)
1149
1150     * Switch back to the pre-1.6.18 algorithm for freeing unused vcaches.
1151       While the new algorithm is still believed to be correct, it turned
1152       out that at least on some kernels, including 4.5 and 4.6, the dentry
1153       for the current working directory may be erroneously invalidated.
1154       This could lead to errors like "Unable to read current working directory"
1155       when a directory wasn't accessed for a few minutes. (12323)
1156
1157     * Use a secure URL to retrieve the CellServDB in the script to create
1158       the Red Hat source package (12330)
1159
1160   FreeBSD
1161
1162     * Added sysname IDs for 10.2 and 10.3 to fix the build on those platforms
1163       (12322)
1164
1165
1166 OpenAFS 1.6.18.1
1167
1168   Linux clients
1169
1170     * Support for mainline kernel 4.5 and distribution kernels with
1171       backports from it (12300..12302)
1172
1173
1174 OpenAFS 1.6.18
1175
1176   All platforms
1177
1178     * Documentation improvements (12224 11675 11613 12197)
1179
1180     * Improved diagnostics and error messages (12129 12207 12185 12211 12113
1181       12215 12216)
1182
1183     * Check that CellServDB entries are valid IPv4 addresses, to avoid
1184       occasional hangs or potentially other erratic behaviour due to invalid
1185       entries (12210) (RT #131794)
1186
1187   All client platforms
1188
1189     * Gracefully handle cases where a client shutdown sequence is initiated
1190       while the client is already shutting down, rather than cause a panic
1191       (12179)
1192
1193     * Fixed several bugs that could cause erratic behaviour when the write
1194       offset into a file was more than 2 GiB beyond the file's current end
1195       on the server (12213 12214)
1196
1197   All server platforms
1198
1199     * Avoid a possible volserver crash during volume dump or restore due
1200       to invalid ACL entries (12127)
1201
1202     * Allow recovering from a DAFS fileserver operation which allocates a
1203       new vnode but fails to update the vnode index, rather than crashing the
1204       server (12209)
1205
1206     * Fixed a longstanding bug which could damage the volume location database
1207       when "vos changeaddr" was run with "-oldaddr" and "-newaddr" and the
1208       old address was present in a multi-homed entry (12089)
1209
1210   FreeBSD
1211
1212     * Added support for releases 10.2 and 10.3 (12232)
1213
1214   Linux clients
1215
1216     * Support for mainline kernel 4.4 and distribution kernels with
1217       backports from it, alas at a performance penalty (12226 12227 12228)
1218       (RT #132677 #132819)
1219
1220     * Avoid using excessive amounts of kernel memory for dynamically
1221       allocated vcaches, by improving the algorithm to free unused ones
1222       (12256 12257)
1223
1224     * In Red Hat packaging, make the init script use "ip" if available, with
1225       "ifconfig" as a fallback (12193)
1226
1227   OS X
1228
1229     * Basic support for release 10.11 "El Capitan" (12212)
1230
1231   IRIX clients
1232
1233     * Fixed kernel module builds with optimization (12198) (RT #131261)
1234
1235
1236 OpenAFS 1.6.17 (Security Release)
1237
1238   All server platforms
1239
1240     * Fix for OPENAFS-SA-2016-001: foreign users can create groups as
1241       if they were an administrator (RT #132822) (CVE-2016-2860)
1242
1243   All client platforms
1244
1245     * Fix for OPENAFS-SA-2016-002: information leakage from sending
1246       uninitialized memory over the network.  Multiple call sites
1247       were vulnerable, with potential for leaking both kernel and
1248       userland stack data (RT #132847)
1249
1250     * Update to the GCO CellServDB update from 01 January 2016 (12188)
1251
1252   Linux clients
1253
1254     * Fix a crash when the root volume is not found and dynroot is not
1255       in use, a regression introduced in 1.6.14.1 (12166)
1256
1257     * Avoid introducing a dependency on the kernel-devel package corresponding
1258       to the currently running system while building the srpm (12195)
1259
1260     * Create systemd unit files with mode 0644 instead of 0755
1261       (12196) (RT #132662)
1262
1263 OpenAFS 1.6.16
1264
1265   All platforms
1266
1267     * Documentation improvements (11932 12096 12100 12112 12120)
1268
1269     * Improved diagnostics and error messages (11586 11587)
1270
1271     * Distribute the contributor code of conduct with the stable release (12056)
1272
1273   All server platforms
1274
1275     * Create PID files in the right location when bosserver is started with
1276       the "-pidfiles" argument and transarc paths are not being used (12086)
1277
1278     * Several fixes regarding volume dump creation and restore (11433 11553
1279       11825 11826 12082)
1280
1281     * Avoid a reported bosserver crash, and potentially others, by replacing
1282       fixed size buffers with dynamically allocated ones in some user handling
1283       functions (11436) (RT #130719)
1284
1285     * Obey the "-toname" parameter in "vos clone" operations (11434)
1286
1287     * Avoid writing a loopback address into the server CellServDB - search
1288       for a non-loopback one, and fail if none is found (12083 12105)
1289
1290     * Rebuild the vldb free list with "vldb_check -fix" (12084)
1291
1292     * Fixed and improved the "check_sysid" utility (12090)
1293
1294     * Fixed and improved the "prdb_check" utility (12101..04)
1295
1296   All client platforms
1297
1298     * Avoid a potential denial of service issue, by fixing a bug in pioctl
1299       logic that allowed a local user to overrun a kernel buffer with a single
1300       NUL byte (commit 2ef86372) (RT #132256) (CVE-2015-8312)
1301
1302     * Refuse to change multi-homed server entries with "vos changeaddr",
1303       unless "-force" is given, to avoid corruption of those entries (12087)
1304
1305     * Provide a new vos subcommand "remaddrs" for removing server entries, to
1306       replace the slightly confusing "vos changeaddr -remove" (12092 12094)
1307
1308     * Make "fs flushall" actually invalidate all cached data (11894)
1309
1310     * Prevent spurious call aborts due to erroneous idle timeouts (11594)
1311
1312     * Provide a "--disable-gtx" configure switch to avoid building and
1313       installing libgtx and its header files as well as the depending
1314       "scout" and "afsmonitor" applications (12095)
1315
1316     * Fixed building the gtx applications against newer ncurses (12125)
1317
1318     * Allow pioctls to work in environments where the syscall emulation
1319       pseudo file is created in a read-only pseudo filesystem, like in
1320       containers under recent versions of docker (12124)
1321
1322   Linux clients
1323
1324     * In Red Hat packaging, avoid following a symbolic link when writing
1325       the client CellServDB, which could overwrite the server CellServDB,
1326       by removing an existing symlink before writing the file (12081)
1327
1328     * In Red Hat packaging, avoid a conflict of openafs-debuginfo with
1329       krb5-debuginfo by excluding our kpasswd executable from debuginfo
1330       processing (12128) (RT #131771)
1331
1332 OpenAFS 1.6.15 (Security Release)
1333
1334   All client and server platforms
1335
1336     * Fix for OPENAFS-SA-2015-007 "Tattletale"
1337
1338       When constructing an Rx acknowledgment (ACK) packet, Andrew-derived
1339       Rx implementations do not initialize three octets of data that are
1340       padding in the C language structure and were inadvertently included
1341       in the wire protocol (CVE-2015-7762).  Additionally, OpenAFS Rx in
1342       versions 1.5.75 through 1.5.78, 1.6.0 through 1.6.14, and 1.7.0
1343       through 1.7.32 include a variable-length padding at the end of the
1344       ACK packet, in an attempt to detect the path MTU, but only four octets
1345       of the additional padding are initialized (CVE-2015-7763).
1346
1347 OpenAFS 1.6.14.1
1348
1349   Linux clients
1350
1351     * Support kernels up to 4.2
1352
1353       Due to changes to internal data structures with this kernel release,
1354       the OpenAFS client can no longer reset the link count during path
1355       lookups. Since volume root directories must behave like symlinks
1356       instead of normal directories in order to satisfy Linux kernel
1357       invariants, looking up paths containing more than 40 mount points
1358       will fail with ELOOP on such kernels.
1359
1360 OpenAFS 1.6.14
1361
1362   All server platforms
1363
1364     * Prior to the OpenAFS security release 1.6.13, the Volume Location
1365       Server (vlserver) RPC VL_ListAttributesN2() supported wildcard volume
1366       name lookups via regular expression (regex) pattern matching. This
1367       support was completely disabled in 1.6.13 because it was judged to be
1368       a security risk due to buffer overruns in the implementation, as well
1369       as the possibility of denial of service attacks where certain regular
1370       expressions could cause excessive CPU usage in some regex
1371       implementations.
1372
1373       Unfortunately, after 1.6.13 was released, it was discovered that
1374       the native OpenAFS 'backup' system uses the VL_ListAttributesN2()
1375       regex support to evaluate configured volume sets. If you use the
1376       OpenAFS 'backup' system (or another backup system which relies on it,
1377       such as Tivoli Storage Manager (TSM, aka Tivoli ADSM)), and are using
1378       volume sets which require regular expressions for the volume name,
1379       then those volume sets cannot be resolved by OpenAFS 1.6.13. The next
1380       paragraph provides details on how to identify any affected volume sets.
1381
1382       OpenAFS backup volume sets may be described by fileserver, partition
1383       name, and volume name. The fileserver and partition specifications
1384       never require regular expression support. The volume name specification
1385       always requires regular expression support except for when specifying
1386       _all_ volumes via two special cases: the universal wildcard ".*", or "".
1387       For example, volume name "proj" or "*.backup" or "homevol.*" all
1388       require regex support - even if the specification contains no wildcard
1389       characters and/or exactly matches an existing volume name.
1390
1391       As a result of this issue, OpenAFS 1.6.14 replaces the 1.6.13 changes
1392       to VL_ListAttributesN2. 1.6.14 prevents the buffer overruns and
1393       reenables the regex support, but restricts it to OpenAFS super-users
1394       and -localauth only. This is sufficient to restore the OpenAFS 'backup'
1395       system's ability to work correctly with any previously supported volume
1396       set. The OpenAFS 'backup' commands are already documented to require
1397       super-user authorization, so this restriction is moot for the backup
1398       system.
1399
1400       There are no other direct consumers of the VL_ListAttributesN2() regex
1401       support in the OpenAFS tree. However, the VL_ListAttributesN2 RPC is
1402       publicly accessible and might be used by third party tools directly or
1403       indirectly via OpenAFS's libadmin. Any such tools that issue
1404       VL_ListAttributesN2 RPCs must now be executed using super-user or
1405       -localauth tokens.
1406
1407       None of the other security fixes in OpenAFS 1.6.13 are known to have
1408       any issues, and are still included unchanged in OpenAFS 1.6.14.
1409
1410       If there are any questions concerning the possible impact of OpenAFS
1411       1.6.13 or 1.6.14 at your site, please contact your OpenAFS support
1412       provider or the openafs-info@openafs.org mailing list for further
1413       assistance.
1414
1415 OpenAFS 1.6.13
1416
1417   All server platforms
1418
1419     * Fix for CVE-2015-3282: vos leaks stack data onto the wire in the
1420       clear when creating vldb entries
1421
1422     * Workaround for CVE-2015-3283: bos commands can be spoofed, including
1423       some which alter server state
1424
1425     * Disabled searching the VLDB by volume name regular expression to avoid
1426       possible buffer overruns in the volume location server
1427
1428   All client platforms
1429
1430     * Fix for CVE-2015-3284: pioctls leak kernel memory
1431
1432     * Fix for CVE-2015-3285: kernel pioctl support for OSD command passing
1433       can trigger a panic
1434
1435   Solaris clients
1436
1437     * Fix for CVE-2015-3286: Solaris grouplist modifications for PAGs can
1438       panic  or overwrite memory
1439
1440 OpenAFS 1.6.12
1441
1442   All server platforms
1443
1444     * Avoid database corruption if a database server is shut down and then
1445       brought up again quickly with an altered database (11773 11774)
1446       (RT #131997)
1447
1448   All client platforms
1449
1450     * Fixed a potential buffer overflow in aklog (11808)
1451
1452     * Avoid a bogus warning regarding the checkserver daemon, which could be
1453       logged during startup when the cache initialization was very fast (11680)
1454
1455     * Added documentation of the inaccuracy of the 'partition' field in
1456       'fs listquota' output for partitions larger than 2 TiB (11626)
1457
1458   Linux clients
1459
1460     * Support kernels up to 4.1 (11872 11873)
1461
1462     * Avoid spurious EIO errors when writing large chunks of data to
1463       mmapped files (11877)
1464
1465   OS X
1466
1467     * Build fixes required at least on OS X 10.10 Yosemite with the latest
1468       XCode (11859 11876 11842..11845 11863 11878 11879)
1469
1470 OpenAFS 1.6.11.1
1471
1472   Linux clients
1473
1474     * Support kernels up to 4.0 (11760 11761)
1475
1476   FreeBSD clients
1477
1478     * Fixed kernel module build on systems with an updated clang which no
1479       longer accepts the -mno-align-long-strings as a no-op (11809)
1480
1481 OpenAFS 1.6.11
1482
1483   All platforms
1484
1485     * Allow aklog to succeed creating native K5 tokens even when mapping
1486       the K5 principal to a K4 one fails (11538)
1487
1488     * Build fixes (11435 11636)
1489
1490   All client platforms
1491
1492     * Avoid a potential kernel panic due to connection reference overcounts
1493       (11645) (RT #131885)
1494
1495     * Avoid potential corruption of files written using memory mapped I/O
1496       when the file is larger than the cache (11656) (RT #131976)
1497
1498   Linux clients
1499
1500     * Support kernels at least up to 3.19 (11549 11550 11569 11570 11595
1501       11658..11662 11694 11752)
1502
1503       Note: By default this excludes kernels 3.17 to 3.17.2, which will leak
1504             an inode reference when an error occurs in d_splice_alias(). The
1505             module will build and work, but leak kernel memory, leading to
1506             performance degradation and eventually system failure due to
1507             memory exhaustion. Since it's impossible to detect this condition
1508             automatically, the switch --enable-linux-d_splice_alias-extra-iput
1509             must be passed to configure when building the module for those
1510             kernels. The same would be necessary for any kernel with backports
1511             of commit 908790fa3b779d37365e6b28e3aa0f6e833020c3 or commit
1512             95ad5c291313b66a98a44dc92b57e0b37c1dd589 but not the fix in commit
1513             51486b900ee92856b977eacfc5bfbe6565028070 in the linux-stable repo
1514             (git.kernel.org/cgit/linux/kernel/git/stable/linux-stable.git) or
1515             the corresponding changes on other branches.
1516
1517     * Fixed a regression introduced in OpenAFS release 1.6.10 which could
1518       make the spurious "getcwd: cannot access parent directories" problem
1519       return (11558 11568) (RT #131780)
1520
1521     * Avoid leaking memory when scanning a corrupt directory (11707)
1522
1523   OS X clients
1524
1525     * Support OS X 10.10 "Yosemite" (11571 11572 11611) (RT #131946)
1526
1527   Solaris clients
1528
1529     * Avoid reading random data rather than correct cache content when using
1530       ZFS as the cache file system on Solaris >= 11, and fix potential similar
1531       problems on other platforms (11713 11714)
1532
1533   FreeBSD
1534
1535     * Build fix for releases >= 11.0 (11610)
1536
1537   OpenBSD
1538
1539     * Support release 5.4 (11700)
1540
1541
1542 OpenAFS 1.6.10
1543
1544   All platforms
1545
1546     * Don't hide the "version" subcommand in help output (11214)
1547
1548     * Documentation improvements (11126 11216 11222 11223 11225 11226)
1549
1550     * Improved diagnostics and error messages (11154 11246 11247 11249 11181
1551       11182 11183)
1552
1553     * Build system improvements (11158 11221 11224 11225 11227..11241 11282
1554       11342 11350 11353 11242 11367 11392)
1555
1556     * Avoid potentially erratic behaviour under certain error conditions by
1557       either avoiding or at least not ignoring them, in various places (11008
1558       11010..11065 11112 11148 11196 11530)
1559
1560   FreeBSD
1561
1562     * Support releases 9.3 and 10.1 (11368 11369 11402 11403 11404)
1563
1564     * Makes a disk cache more likely to work on FreeBSD, though such
1565       configurations remain not very tested (11448)
1566
1567   All server platforms
1568
1569     * Added volscan(8) (11252..11280 11387 11388)
1570
1571     * Fixed a bug causing subgroups not to function correctly if their
1572       ptdb entry had more than one continuation entry (11352)
1573
1574     * Logging improvements (10946 11153)
1575
1576     * Allow log rotation via copy and truncate (11193)
1577
1578     * Avoid a server crash during startup only observed on a single platform
1579       and when using a 3rd party library under certain circumstances, which is
1580       a collateral effect of the security improvements introduced in OpenAFS
1581       release 1.6.5 (11075) (RT #131852)
1582
1583   All client platforms
1584
1585     * Raised the free space reported for /afs to the maximum possible value of
1586       just under 2 TiB - the old value was 9 GiB on most platforms (10984)
1587
1588     * Reduced the amount of stack space used (11162 11163 11203 11164..11167
1589       11338 11339 11364..11366 11381)
1590
1591     * Sped up a periodic client task which could be problematically slow
1592       on systems with a large number of PAGs and files in use (11307)
1593
1594     * Fixed failure of the up command with large ACLs (11111)
1595
1596     * Avoid a potential crash of aklog (11218)
1597
1598     * Avoid potential crashes of scout and xstat_fs_test (11155)
1599
1600   Linux clients
1601
1602     * Support kernels up to 3.16 (11308 11309)
1603
1604     * Fixed a regression introduced in OpenAFS release 1.6.6 that made
1605       checking for existing write locks incorrectly fail on readonly volumes
1606       (11361)
1607
1608     * Fixed a regression introduced in OpenAFS release 1.6.8 that could
1609       cause VFS cache inconsistencies when a previously-accessed directory
1610       entry was removed and recreated with the same name but pointing to a
1611       different file on another client (11358)
1612
1613     * Use the right path to depmod in Red Hat packaging to avoid dependency
1614       calculation incorrectly failing unless a link /sbin -> /usr/sbin is
1615       present on the system performing it (11171) (RT #131860)
1616
1617     * Do not ignore kernel module build errors (11205)
1618
1619 OpenAFS 1.6.9
1620
1621   All server platforms
1622
1623     * Fix for OPENAFS-SA-2014-002
1624
1625 OpenAFS 1.6.8
1626
1627   All platforms
1628
1629     * Documentation improvements (10751 10875 10931 10897 10883 10954 10955)
1630
1631     * Improved diagnostics and error messages (10756 10814 10949)
1632
1633     * Fixed a bug in RX that could make errors during packet reception go
1634       unnoticed. (10733)
1635
1636     * Fixed a bug that made "vos size -dump" display the wrong size for
1637       large volumes. (10933)  (RT #131819)
1638
1639   All server platforms
1640
1641     * Change the default fileserver sync behavior from "delayed" to "onclose".
1642       This means that explicit syncing only happens when a volume is detached.
1643       (10809)
1644
1645     * Added the -offline-timeout and -offline-shutdown-timeout options to the
1646       fileserver, to implement interrupting clients accessing volumes we are
1647       trying to take offline. (6266 10799)
1648
1649   All client platforms
1650
1651     * When a client is shut down, it will give up its callbacks. The Windows
1652       client has been doing this since 2007. Note that older fileservers
1653       (1.3.50 to 1.4.5 and 1.5.0 to 1.5.27) had a bug in the implementation of
1654       the relevant RPC that could cause crashes or other undefined behavior
1655       when this happens. (6272 8840 10855)
1656
1657     * Restored the pre-1.6 behavior of "vos e" being an alias for "vos examine".
1658       (10886)
1659
1660     * Avoid flooding logs with warnings about byte-range locks, by throttling
1661       them per file. Also, make the messages more useful by including the
1662       FID. (10836..10839)
1663
1664     * Avoid a possible panic during shutdown while tracing. (10932)
1665
1666   Linux clients
1667
1668     * Fixed a bug that could cause the "getcwd: cannot access parent
1669       directories" problem (10804 10984)
1670
1671     * Avoid a delay when accessing uncached data in AFS in a confined
1672       context under SELinux. (10598)
1673
1674     * Red Hat packaging improvements (10600 10767 10807)
1675
1676 OpenAFS 1.6.7
1677
1678   All server platforms
1679
1680     * Fix for OPENAFS-SA-2014-001
1681
1682     * Fix for a potential DOS attack against RX servers
1683
1684 OpenAFS 1.6.6
1685
1686   All platforms
1687
1688     * As of this release, OpenAFS no longer ships uncompressed source tarballs.
1689       Tarballs are still shipped with both compression formats, gzip and bzip2.
1690       (10131)
1691
1692     * Documentation improvements (10136 10314 10601)
1693
1694     * Improved diagnostics and error messages (9412 10085 10274)
1695
1696     * Avoid redefining "assert" in our public header files, which could
1697       cause failures when building some applications using them. (10096)
1698
1699     * Fixes for parallel builds (10005 10309 10337)
1700
1701     * Added a -s switch to afscp (not installed by default) to help simulate
1702       a slow client. (9416 9417)
1703
1704     * Added a -probe switch to vlclient test program (not installed by default)
1705       to ping all vlservers in a cell in parallel. (9570)
1706
1707   All server platforms
1708     * The fileserver now ignores any vice partitions with a NeverAttach flag
1709       file present in the root directory. (RT #130561) (9470 9471)
1710
1711     * Restrict forcing CPS ("Current Protection Subdomain") recalculation in
1712       the fileserver to administrators. Also fixed a bug that could cause this
1713       operation to be incomplete. (9485 9487)
1714
1715     * Allow non-DAFS fileservers to attach unusable volumes, restoring pre-1.6
1716       behaviour. (RT #131505) (9499)
1717
1718     * Restored the pre-1.6 behaviour when running vos examine for a volume
1719       currently in a transaction, showing the volume as busy again rather than
1720       offline. (9685 9915 9916)
1721
1722     * Reduced the minimum time a bos salvage takes from 5 seconds to 1. (9476)
1723
1724     * Fixed buserver to not segfault when started with the -servers option.
1725       (RT #131706) (10166)
1726
1727     * Salvager fixes, addressing a wide variety of possible problems from
1728       unnecessary salvaging to aborts (9282 9283 9457 9458 9459 9461 9462 9480
1729       9481 10165 10167)
1730
1731     * Fixed a bug that could cause saved state information to be discarded
1732       when restarting a large or busy fileserver, which negatively impacted
1733       performance. (9683)
1734
1735     * Fixed a bug that could have caused undefined behaviour in the vlserver
1736       in rare cases when a fileserver registered its addresses in the VLDB.
1737       (9429)
1738
1739     * Added the -preserve-vol-stats switch to volserver, allowing it to keep
1740       the access statistics across volume restore and reclone operations
1741       instead of resetting them. (9477)
1742
1743     * Inserted an exponential delay between retries when bosserver attempts to
1744       restart a server process. (9571 10199)
1745
1746     * Improved vldb_check (not installed by default) to cope with broken
1747       vlentry names and volids, and provide more output to aid debugging.
1748       (10268)
1749
1750     * Releasing a volume after adding a new RO site no longer touches any of
1751       the existing RO sites, if the RW data hasn't changed since the last
1752       release. (10174)
1753
1754     * Make the copyDate field for RO clones have the same meaning as for
1755       remote RO volumes. Previously, the copyDate field for clones was updated
1756       every time we released. (9451)
1757
1758     * Fixed potentially undefined behaviour in ptserver when too many pts
1759       ids are allocated. (10124)
1760
1761     * Note that the server side NAT pings feature present in the prereleases
1762       was removed before the final release, since no positive feedback
1763       was provided during prerelease testing. (9420 10135)
1764
1765   Linux servers
1766
1767     * Start bosserver with -nofork in the systemd unit file, to allow systemd
1768       to track its state (10093)
1769
1770   All client platforms
1771
1772     * No longer track file locks on read-only volumes. Write locks can't
1773       succeed, read locks always will. Avoids log messages about this kind
1774       of lock. (8910)
1775
1776     * Added the "fs flushall" subcommand, which makes the client discard all
1777       cached data. This was previously available on Windows only. (9065 9388
1778       9389 9390)
1779
1780     * Fixed a bug that could make the client incorrectly believe its cache
1781       is up to date. This change could negatively impact AFS <-> DFS
1782       translators, should those still be running anywhere. (8898)
1783
1784     * Several changes to avoid panicing in certain error conditions.
1785       (9131 9287 10354 10355 10356 10357) (partially addressing RT #131747)
1786
1787     * Added the -rxmaxfrags switch to afsd, allowing to limit the number
1788       of UDP fragments sent or received per RX packet. (9430)
1789
1790     * Build fixes for aklog on several platforms (RT #131716) (9917 10107 10275)
1791
1792     * Require that the AFS mountpoint specified in the cacheinfo file is
1793       an absolute path. Relative paths result in a client that basically
1794       works but is not fully functional. (10253)
1795
1796     * Fixed a bug that could cause one of the afsd threads to enter an infinite
1797       loop (10431 .. 10436)
1798
1799   Linux clients
1800
1801     * Support Linux kernels up to 3.13 (10241)
1802
1803     * Fixed a bug that made readv/writev calls in AFS space fail with Linux
1804       kernels where generic_file_aio_read exists but those operations have
1805       not been switched to using aio_read/aio_write. This was a regression
1806       introduced with release 1.6.3 and affected at least RHEL 5.9 kernels.
1807       (10248)
1808
1809     * Fixed a similar bug making core dumps fail in AFS space, affecting
1810       a much wider range of kernels including the most recent ones.
1811       (RT #131729) (10254)
1812
1813     * Enhanced the keyring code to make PAGs work correctly on kernels with a
1814       distribution specific change to the Linux keyring code. This affected at
1815       least SLES 11 SP3 kernels. (10252)
1816
1817     * Fixed a bug that could make failures during PAG instantiation go
1818       unnoticed. (10255)
1819
1820     * Fixed a bug that made compilation fail for Linux kernels without
1821       keyring support. This affected at least the SLE 10 SDK and an
1822       OEM version of SLES 11 SP1. (10325)
1823
1824     * Fixed build for kernels with user namespace support enabled. Likely
1825       to be required for Ubuntu 14.04 and eventually other distributions.
1826       (10456 10457 10458 10518 10472)
1827
1828     * Support RHEL 6.5 kernels, and possibly others with changes backported
1829       from recent mainline kernels that touch getname/putname, by no longer
1830       using those functions. Previously, the client could cause a kernel
1831       panic when syscall auditing was enabled. (10578)
1832
1833     * Make tmpfs usable as the cache filesystem again. This had been broken
1834       since kernel 3.1 (9950 10193)
1835
1836     * When starting the client fails, clean up the backing device information
1837       created in sysfs, to avoid error messages during a subsequent start
1838       and possible system instability later on (10454)
1839
1840     * Update Red Hat packaging to support Fedora >= 20, RHEL >= 7 and
1841       ELrepo kernels (10597 10619 10622 10703 10704)
1842
1843   OS X Clients
1844
1845     * Support OS X 10.9 "Mavericks" (10519 10541 10542 10543 10548 10549)
1846
1847   AIX clients
1848
1849     * Fixed a bug that caused the 1.6 AIX client to never receive any RX
1850       packets in the kernel. (RT #131725)
1851
1852   FUSE client
1853
1854     * Support Solaris 11 (9454 9455)
1855
1856     * Allow other users to access filesystems mounted by root. (9452)
1857
1858   FreeBSD
1859
1860     * Build tvolser and dvolser on this platform (10122)
1861     * Several fixes to catch up with newer releases (10374 .. 10381)
1862
1863   NetBSD
1864
1865     * Build tsalvaged, tvolser and dvolser on this platform (10121)
1866     * Fixed build on NetBSD 5 and newer. (10138)
1867
1868 OpenAFS 1.6.5
1869
1870 All platforms
1871
1872     * Fixes for OpenAFS-SA-2013-0003 and OpenAFS-SA-2013-0004
1873
1874 OpenAFS 1.6.4
1875
1876 All platforms
1877
1878     * Obey the jumbo/nojumbo settings for ubik servers (the DB servers)
1879       too. In previous releases, those servers may have used jumbograms
1880       even if they were not configured to do so. This change corrects
1881       the actual behaviour, and will improve performance and reliability
1882       for sites where jumbograms are problematic. It could cause a decrease
1883       in performance for sites where jumbograms work, but those can turn
1884       them back on manually.
1885
1886     * Dozens of fixes for common coding problems like use after free,
1887       use of possibly uninitialised memory, reading or writing past the
1888       end of arrays and potential NULL pointer derefences. Spotted by
1889       code analysis tools or human inspection.
1890
1891     * Documentation improvements.
1892
1893     * Fixes and improvements to the diagnostic or log messages printed by
1894       vos, the fileserver and others.
1895
1896     * Build fixes, making parallel builds more reliable with certain
1897       configuration options and helping various platforms including
1898       recent releases of IRIX, Solaris and several flavours of Linux.
1899
1900     * Avoid sending a small amount of data over the wire unencrypted
1901       under certain conditions, and emit the correct error message in
1902       this case.
1903
1904 All server platforms
1905
1906     * Avoid generating duplicate IDs for readonly and backup volumes,
1907       which could happen under certain conditions.
1908
1909     * Allow the fileserver to return volume data like quota or free space,
1910       which is available publicly elsewhere, without the additional access
1911       check for read permissions on a volume's root directory the fileserver
1912       performed before.
1913
1914     * The fileserver now emits a log message when it ran out of memory for
1915       callbacks.
1916
1917     * Avoid several potential fileserver problems, including memory
1918       corruption and segmentation faults, due to client bookkeeping.
1919
1920     * Avoid known cases of silent data corruption due to background syncs
1921       on the fileserver, especially during Copy on Write.
1922
1923     * Make the fileserver sync behaviour runtime configurable. Up to 1.4.5,
1924       we had synchronous syncs which were safe but really slow. Since 1.4.5,
1925       we've had asynchronous syncs which are much faster but believed to
1926       be the cause of rare data corruption issues, and while all known cases
1927       of these happening are believed to be fixed in the 1.6.3 release, doubts
1928       remain. This change allows choosing between those, and in addition allows
1929       to turn syncs by the fileserver off altogether, thus relying on the vice
1930       partition's backend filesystem and the operating system, or to just
1931       execute them when a volume is detached. The default behaviour is
1932       unchanged from releases since 1.4.5, but it's highly recommended to
1933       consider the additional options this change provides. Future OpenAFS
1934       releases will default to "-sync=none".
1935
1936     * For dbservers, avoid a situation where misinterpreting transient
1937       network errors causes long-term issues with achieving ubik quorum.
1938
1939 All UNIX client platforms
1940
1941     * Improvements to the detection of an aklog-specific krb5 configuration
1942       file, for the purposes of turning on "weak crypto" for aklog.
1943
1944     * Fixed a regression introduced in release 1.6.2 which caused the
1945       supposedly persistent disk cache to be discarded upon client start.
1946       (RT #131655)
1947
1948 Linux clients
1949
1950     * Support Linux kernels up to 3.10
1951
1952     * Fixed two bugs making it impossible to unmount a disk cache filesystem
1953       after it has been used by the client. (RT #131613)
1954
1955     * Fixed a bug that could cause an oops with kernels 3.6 and later
1956
1957 OpenBSD
1958
1959     * Improved support for OpenBSD 4.9 to 5.3
1960
1961 OpenAFS 1.6.3
1962
1963   This release number had to be skipped for technical reasons.
1964
1965 OpenAFS 1.6.2.1
1966
1967   Linux clients
1968
1969     * Support Linux kernels up to 3.8.
1970
1971     * Make the init script cope with the output of ifconfig on recent Fedora.
1972
1973 OpenAFS 1.6.2
1974
1975   All platforms
1976
1977     * Fix buffer overflows in fileserver and ptserver.
1978
1979     * Abort an rx connection when given an unknown service (Gerrit 7593).
1980
1981     * "idle dead" behavior improvements.
1982
1983     * Documentation updates.
1984
1985   All server platforms
1986
1987     * Fix rare file corruption during background sync (Gerrit 8796).
1988
1989     * Fix corrupting clients' metadata cache during certain errors (Gerrit
1990       6957).
1991
1992     * Avoid saying a volume doesn't exist when accessed as the volume is
1993       going offline (Gerrit 7488).
1994
1995     * Fix fileservers to properly report >2 TiB partitions.
1996
1997     * Fix stale volume info from vos examine on non-DAFS filservers.
1998
1999     * Fix possible volume corruption with vos convertROtoRW.
2000
2001     * Fix bosserver to preserve all command-line options over restart.
2002
2003     * Fix bosserver to properly kill hung processes during shutdown.
2004
2005   All UNIX client platforms
2006
2007     * Fixes for memcache, especially on Solaris.
2008
2009     * Increase the size of the DNS resolver answer buffer to allow sites
2010       with a long response list to use SRV and AFSDB records.
2011
2012     * Fix a crash when a server appears to run out of addresses (Gerrit
2013       7487).
2014
2015     * Fix cache corruption when reading from a file another client is
2016       simultaneously writing to (Gerrit 7994).
2017
2018     * Improve handling of disk cache disk errors.
2019
2020   Linux
2021
2022     * fix DKMS configuration for DKMS 2.2.
2023
2024     * Avoid generating inode number 0 with md5 inodes (Gerrit 7276).
2025
2026     * Fix a crash when reading /proc/fs/openafs/unixusers (Gerrit 7914).
2027
2028     * Make PAG-less access use the real UID of the calling process
2029       instead of the effective UID, when determining what credentials to
2030       use (Gerrit 7931).
2031
2032     * Fix possible abuse of fs mkmount.
2033       Prior to 1.6.2, users could crash a client by nesting volume mounts.
2034
2035     * Fix fileserver memory corruption on RHEL 6
2036       Prior to 1.6.2, fileservers on RHEL 6 may crash under heavy load.
2037
2038     * Fix client page cache corruption on Linux
2039       When multiple clients read and write to a file, the reading client
2040       may see first page (4096 bytes) of a file as nulls.
2041
2042     * Support Linux kernels up to 3.7.
2043
2044     * Support newer glibc versions.
2045
2046     * Improve client systemd unit file.
2047
2048     * Update Red Hat packaging.
2049
2050   OS X
2051
2052     * Fix crashes on shutdown.
2053
2054     * Prevent unloading the module before shutdown completes.
2055
2056     * Security improvement for the OpenAFS preference pane.
2057
2058   Solaris
2059
2060     * Support newer versions of the Sun Studio compiler software.
2061
2062     * Support compiling on newer versions of Solaris 11 and Solaris 10.
2063
2064
2065 OpenAFS 1.6.0 (2011-08-15)
2066
2067   All platforms
2068
2069     * Substantial Rx updates to correct erroneous behavior.
2070
2071     * vos now properly deals with matching sites when servers are
2072       multihomed.
2073
2074     * Don't stop Rx keepalives after an ackall is received, avoiding
2075       spurious connection timeouts. (128848)
2076
2077     * Don't retry Rx calls on channels returning busy errors and improve
2078       Rx busy call channel error handling. (128671)
2079
2080     * Properly enable Rx connection hard timeouts.
2081
2082     * Rx NAT pings are not enabled until peer has answered.
2083
2084     * Initialize rx_multi lock before use.
2085
2086     * Avoid spurious crashes when initializing in "backup" client.
2087
2088     * Revert UUID support in vos.
2089
2090     * pt_util fixed to properly create new databases.
2091
2092     * MTU discovery now properly shut down on call reset.
2093
2094     * Avoid leaking references to hosts during callback break multi-Rx
2095       operations. (129376)
2096
2097     * xstat tools now cope with differing timeval structures between
2098       endpoints.
2099
2100     * Numerous fixes to command argument parsing.
2101
2102     * Documentation updates.
2103
2104   All server platforms
2105
2106     * A file descriptor leak which could result in corrupted files in the
2107       fileserver was fixed. An IMMEDIATE upgrade from previous 1.5 release
2108       fileservers is recommended.
2109
2110     * Fix ptserver supergroups support on 64 bit platforms.
2111
2112     * Demand attach salvaging doesn't use freed volume pointers.
2113
2114     * Properly hold host lock during host enumeration in fileserver.
2115
2116     * Attempt to recovery more quickly from timed out volume release
2117       transactions.
2118
2119     * Auditing now properly byte order swaps IP addresses when printing.
2120
2121     * vos split now has improved error handling.
2122
2123     * Many changes to again support Windows fileservers.
2124
2125     * During volume removal, data removal speed improved.
2126
2127     * Improve CPU utilization during volume attaching by DAFS.
2128
2129     * In salvager check-only mode, avoid potentially fixing a vnode.
2130
2131     * Fix support for large (greater than 2gb) volume special files.
2132
2133     * Salvager will not crash if multiple or bad volume link tables are
2134       encountered.
2135
2136     * Avoid erroneous full dump by remembering which sites were out of
2137       date at the start of the release.
2138
2139     * A deleted volume can now be recreated properly.
2140
2141     * Callbacks are again not broken during whole partition salvages.
2142
2143     * Positional vectored IO fixed for largefile (>2GB) capable systems.
2144
2145     * Fileserver per-client thread usage again properly enforced.
2146
2147     * Anonymous dropbox support improved and drawbacks documented.
2148
2149     * Demand attach: ensure vnodes are not reallocated while in use due to
2150       volume bitmap errors.
2151
2152     * Properly support large volume numbers (larger than 2147483647).
2153
2154     * Allow salvager to be run manually again when DAFS is being
2155       used. (129458)
2156
2157     * Avoid leaking references to hosts during callback break multi-Rx
2158       operations. (129376)
2159
2160     * Demand attach: unlink fileserver state file on standalone salvage.
2161
2162     * Salvager tries harder to detect linktable issues.
2163
2164     * Demand attach: don't attach volumes with special status set.
2165
2166     * Avoid crashing on host table exhaustion. Instead, defer clients.
2167
2168   Microsoft Windows
2169
2170     * afs_config will not longer set the Tray Icon State in the registry
2171       if the checkbox is not present in the dialog. (128591)
2172
2173     * AFS Explorer Shell Extension now works from folder backgrounds.
2174       Overlays for mount points and symlinks are present in the dll, but
2175       are not registered at present by the installers.
2176
2177     * Do not use RankServerInterval registry value as the value for
2178       PerformanceTuningInterval.
2179
2180     * When the data version of a mountpoint or symlink changes, the target
2181       string in the cm_scache_t object must be cleared.
2182
2183     * "fs checkservers" now includes vldb servers in the output and only
2184       lists multi-homed servers once.  A multi-homed server that has at
2185       least one up interface is no longer considered to be down.
2186
2187     * When asynchronously storing dirty data buffers to the file server
2188       ensure that (a) the cm_scache_t object and the cm_buf_t object are
2189       for the same File ID so that locking and signalling work properly;
2190       and (b) if the FID no longer exists on the file server, do not
2191       panic, just discard the buffer.
2192
2193     * When processing VNOVOL, VMOVED and VOFFLINE errors perform server
2194       comparisons by UUID or address and not simply by cm_server_t
2195       pointer.  Otherwise, server failover may not succeed.
2196
2197     * Do not preserve status information for cm_scache_t objects when the
2198       issuing server is multi-homed.
2199
2200     * Giving up all callbacks when shutting down or suspending the machine
2201       is now significantly faster due to the use of an rx_multi
2202       implementation.  (This functionality is still off by default and
2203       must be activated by a registry value.)
2204
2205     * Race conditions were possible when updating the state of the
2206       cm_volume_t flags and when moving the volumes within the least
2207       recently used list.
2208
2209     * Ensure that the lanahelper library does not perform a NCBRESET of
2210       each lan adapter when enumerating the current network bindings.
2211       Correcting this permits OpenAFS to work on Windows 7 when the
2212       network adapter settings change.
2213
2214     * Fix creation of mount points and symlinks as \\AFS\xxxx
2215
2216     * Icon tray state now conditionally set. (128591)
2217
2218     * Properly create new cell mount points in freelance mode.
2219
2220     * Avoid recursive offline volume checks.
2221
2222     * Fix caching of non-existent volumes.  The test to trigger an
2223       immediate CM_ERROR_NOSUCHVOLUME in cm_UpdateVolumeLocation() was
2224       backwards.
2225
2226     * Prevent the background daemon from checking the status of
2227       non-existent volumes.  cm_CheckOfflineVolumes() should skip volume
2228       groups with the CM_VOLUMEFLAG_NOEXIST flag set.
2229
2230     * The afskfw library should return an error immediately if the
2231       krb5_32.dll library cannot be loaded.  Affects afslogon.dll and
2232       afscreds.exe.
2233
2234     * No longer depend on leashw32.dll in afskfw library.
2235
2236     * NPLogonNotify must provide the user password in all calls to
2237       KFW_AFS_get_cred().  It cannot count on a credential cache being
2238       preserved between calls.  Permits tokens to be acquired for all
2239       cells listed in the TheseCells registry value for a domain.
2240
2241     * Improve the trace logging from NPLogonNotify().
2242
2243     * Avoid a race when writing the cm_scache_t mountPointString
2244       when acquiring mount point or symlink target data via
2245       cm_GetData().  The race could result in bogus target
2246       data being cached.
2247
2248     * Permit the use of des-cbc-md5 and des-cbc-md4 enctypes
2249       as DES keys in asetkey.exe.
2250
2251     * aklog supports dotted Kerberos v5 principal names.
2252
2253     * afskfw library always attempts afs/cell@USER-REALM
2254
2255     * afskfw library must test return code from krb5_cc_start_seq_get() or
2256       will trigger a null pointer exception when using Heimdal.
2257
2258     * Lock protected fields must be 32-bit in order to avoid memory
2259       overwrite races.
2260
2261     * Add support for NTFS symlinks.
2262
2263     * Handle file search requests for virtual syscall ioctl file.
2264
2265     * Process SyncOps properly to enforce ordered operations.
2266
2267     * Avoid recursing during NewServer operations.
2268
2269     * Correct lock acquisition order during SMB locking.
2270
2271     * Add shutdown message to event log.
2272
2273     * Check offline volume status by policy rather than on each daemon
2274       thread run.
2275
2276     * Return error on directory object not found instead of crashing.
2277
2278     * Improve error message output.
2279
2280     * afslogin.dll can start afsd_service if it's not starting or started.
2281
2282     * Optimize away release lock RPCs for deleted files.
2283
2284     * Background Daemon will not perform operations on deleted files.
2285
2286     * Resort recently used directories to the top of the LRU if the
2287       directory is larger than the stat cache.
2288
2289     * Resort deleted objects to the bottom of the LRU.
2290
2291     * Use interlocked operations for state and queue fields to allow safe
2292       bit set and clear on multiprocessor systems.
2293
2294   All UNIX client platforms
2295
2296     * Servers now marked down when GetCapabilities returns error.
2297
2298     * In-use vcache count is now properly tracked.
2299
2300     * Check for /afs existance before starting, unless -nomount is
2301       specified.
2302
2303     * Avoid a potential panic when using /afs/.:mount syntax.
2304
2305     * Avoid a panic in memcache mode due to missing CellItems file.
2306
2307     * FUSE client support fixed for non-/afs mounts.
2308
2309     * Avoid a potential deadlock (which times out) when we need to
2310       allocate more callback returns and must flush some already in use.
2311
2312     * Deal with libcom_err conflicts with other packages using it
2313       (e.g. krb5) (128640)
2314
2315     * Fall back to afs3-vlserver SRV record values when afs3-ptserver SRV
2316       record is not available.
2317
2318     * Avoid holding unneeded locks when probing server capabilties.
2319
2320     * Do not attempt page flushes for directories.
2321
2322     * Rx connection reference counting is enabled.
2323
2324     * An Rx connection reference count leak is fixed in bulkstat.
2325
2326     * Handle unparsable directory objects.
2327
2328     * Handle Kerberos cred cache errors in aklog.
2329
2330   AIX
2331
2332     * Fix PAG usage to track by PAG identifier, not group list.
2333
2334   FreeBSD
2335
2336     * Fix socket termination on shutdown.
2337
2338     * Support for 7.2, 7.3, 7.4 and 8.2 included.
2339
2340     * References to vcaches are no longer leaked during root or reclaim.
2341
2342     * Remove support for "Giant" lock as we no longer need to use it.
2343
2344     * Don't sleep with AFS GLOCK.
2345
2346     * Properly enable 64 bit long long support.
2347
2348     * Restore support for FreeBSD 7 (128612)
2349
2350     * Fix locking issues at shutdown and avoid panic at shutdown due to
2351       vcache flushing.
2352
2353     * Support for virtual network stacks.
2354
2355     * New RC script, updated packaging.
2356
2357   IRIX
2358
2359     * Properly create new vnodes to avoid crashing in the client.
2360
2361   Linux
2362
2363     * Support through kernel 2.6.39.  Treat Linux 3.0 as Linux 2.6 for
2364       sysname purposes.
2365
2366     * Use rx_Readv in cache bypass to improve performance.
2367
2368     * Properly handle 0-length replies during cache bypass operations.
2369
2370     * Properly handle non-contiguous readpage cache bypass operations.
2371
2372     * Do proper locking when transitioning to or from cache bypass.
2373
2374     * Avoid extra runs of vcache freeing routine. (128756)
2375
2376     * Perform vcache eviction via a fast path before visiting vcaches
2377       where sleep is needed.
2378
2379     * setpag() errors are now properly reported.
2380
2381     * Avoid attempting to free stat cache entries when we are below
2382       user-specified number of entries in use.
2383
2384     * Properly track user-specified number of stat cache entries to use as
2385       a desired usage target.
2386
2387     * Don't read pages beyond EOF in the cache. (128452)
2388
2389     * Various corrections and improvements to Red Hat packaging, including
2390       modifying the init script to allow deferring for a new binary
2391       restart and properly supporting RHEL6.
2392
2393     * Fix lockup in 2.6.38 due to erroneous kernel feature configure test.
2394
2395     * Improve RPM building tools.
2396
2397     * Attempt to properly handle SELinux in packaging.
2398
2399     * Init script properly returns status as exit code.
2400
2401     * RPM packaging fixes (executable libraries, no postinstall message)
2402
2403     * Kill i386 from RPM packaging.
2404
2405   MacOS
2406
2407     * MacOS 10.7 support.
2408
2409     * Properly handle setpag errors.  PAGs are not supported.
2410
2411     * Check for unloaded kernel extensions when decoding AFS panics.
2412
2413     * Disable "get tokens at login" in prefs pane if AD authentication
2414       plugin is configured.
2415
2416     * aklog AuthorizationPlugin now provided.
2417
2418     * Preferences Pane behavior fixed for 1.6 series (version detection is
2419       used to select default behavior).
2420
2421     * A potential kernel panic during bulkstat operations is
2422       fixed. (128511)
2423
2424     * 64-bit MacOS kernel performance is greatly improved. (128934)
2425
2426     * Properly shut down AFS, closing the Rx socket in the upcall handler
2427       to avoid attempting to process data after we can no longer do so.
2428
2429     * Rework logic for bulk status operations to avoid a potential hang.
2430
2431     * Avoid panic when doing FSEvent synthesis.
2432
2433     * Fix bug when using non-dynroot.
2434
2435     * Update Kerberos support in PreferencesPane.
2436
2437   NetBSD
2438
2439     * Updates for platform support.
2440
2441   OpenBSD
2442
2443     * Bug fixes for issues introduced previously in 1.5 series.
2444
2445     * Support through OpenBSD 4.8.
2446
2447   Solaris
2448
2449     * Switch to ioctl() syscall replacement for Solaris 11 since syscall
2450       65 is not safe.
2451
2452     * Fix support for Solaris pre-10.
2453
2454     * Corrected Solaris 11 startup script.
2455
2456     * vcache mappings freed on shutdown to avoid panic.
2457
2458     * Properly report errors for AFS system call callers.
2459
2460     * Don't leave dangling function references if kernel extension fails
2461       to load.
2462
2463     * Try harder to avoid deadlocks on file-larger-than-cache operations.
2464
2465     * Avoid panic on shutdown when mount failed.
2466
2467
2468 OpenAFS 1.6.0pre2
2469
2470   All systems: Minor bugfixes.
2471
2472   ADDITIONAL CHANGES IN 1.6.0PRE2
2473
2474   All platforms:
2475
2476     - Documentation updates.
2477
2478     - Don't stop Rx keepalives after an ackall is received, avoiding
2479       spurious connection timeouts. (128848)
2480
2481     - Don't retry Rx calls on channels returning busy errors. (128671)
2482
2483     - vos will not die with a double free error at command completion.
2484
2485     - Properly enable Rx connection hard timeouts.
2486
2487     - Initialize rx_multi lock before use.
2488
2489     - Avoid spurious crashes when initializing in "backup" client.
2490
2491   All unix platforms:
2492
2493     - Check for /afs existance before starting, unless -nomount is specified.
2494
2495     - Avoid a potential panic when using /afs/.:mount syntax.
2496
2497     - Avoid a panic in memcache mode due to missing CellItems file.
2498
2499   All server platforms:
2500
2501     - Attempt to recovery more quickly from timed out volume release
2502       transactions.
2503
2504     - Auditing now properly byte order swaps IP addresses when printing.
2505
2506     - vos split now has improved error handling.
2507
2508     - Many changes to again support Windows fileservers.
2509
2510     - During volume removal, data removal speed improved.
2511
2512     - Improve CPU utilization during volume attaching by DAFS.
2513
2514     - In salvager check-only mode, avoid potentially fixing a vnode.
2515
2516     - Fix support for large (greater than 2gb) volume special files.
2517
2518     - Salvager will not crash if multiple or bad volume link tables
2519       are encountered.
2520
2521     - Avoid erroneous full dump by remembering which sites were out of date
2522       at the start of the release.
2523
2524   FreeBSD:
2525
2526     - Remove support for "Giant" lock as we no longer need to use it.
2527
2528     - Don't sleep with AFS GLOCK.
2529
2530     - Properly enable 64 bit long long support.
2531
2532     - Restore support for FreeBSD 7 (128612)
2533
2534     - Fix locking issues at shutdown.
2535
2536   Linux:
2537
2538     - support through kernel 2.6.38.
2539
2540     - RedHat packaging now properly supports RHEL6.
2541
2542     - Use rx_Readv in cache bypass to improve performance.
2543
2544     - Properly handle 0-length replies during cache bypass operations.
2545
2546     - Properly handle non-contiguous readpage cache bypass operations.
2547
2548     - Do proper locking when transitioning to or from cache bypass.
2549
2550     - Avoid extra runs of vcache freeing routine. (128756)
2551
2552   MacOS:
2553
2554     - Check for unloaded kernel extensions when decoding AFS panics.
2555
2556     - Properly handle setpag errors. PAGs are not supported.
2557
2558     - Disable "get tokens at login" in prefs pane if AD authentication
2559       plugin is configured.
2560
2561   OpenBSD:
2562
2563     - support through OpenBSD 4.8.
2564
2565   Solaris:
2566
2567     - Fix support for Solaris pre-10.
2568
2569   Windows:
2570
2571     - afs_config will not longer set the Tray Icon State
2572       in the registry if the checkbox is not present in
2573       the dialog. (128591)
2574
2575     - AFS Explorer Shell Extension now works from folder
2576       backgrounds.  Overlays for mount points and symlinks
2577       are present in the dll, but are not registered at present
2578       by the installers.
2579
2580     - Do not use RankServerInterval registry value as the value for
2581       PerformanceTuningInterval.
2582
2583     - When the data version of a mountpoint or symlink changes,
2584       the target string in the cm_scache_t object must be cleared.
2585
2586     - "fs checkservers" now includes vldb servers in the output
2587       and only lists multi-homed servers once.  A multi-homed
2588       server that has at least one up interface is no longer
2589       considered to be down.
2590
2591     - When asynchronously storing dirty data buffers to the
2592       file server ensure that (a) the cm_scache_t object and
2593       the cm_buf_t object are for the same File ID so that
2594       locking and signalling work properly; and (b) if the
2595       FID no longer exists on the file server, do not panic,
2596       just discard the buffer.
2597
2598     - When processing VNOVOL, VMOVED and VOFFLINE errors perform
2599       server comparisons by UUID or address and not simply by
2600       cm_server_t pointer.  Otherwise, server failover may not
2601       succeed.
2602
2603     - Do not preserve status information for cm_scache_t objects
2604       when the issuing server is multi-homed.
2605
2606     - Giving up all callbacks when shutting down or suspending
2607       the machine is now significantly faster due to the use
2608       of an rx_multi implementation.  (This functionality is
2609       still off by default and must be activated by a registry
2610       value.)
2611
2612     - Race conditions were possible when updating the state
2613       of the cm_volume_t flags and when moving the volumes
2614       within the least recently used list.
2615
2616     - Ensure that the lanahelper library does not perform a
2617       NCBRESET of each lan adapter when enumerating the
2618       current network bindings.  Correcting this permits OpenAFS
2619       to work on Windows 7 when the network adapter settings
2620       change.
2621
2622     - Fix creation of mount points and symlinks as \\AFS\xxxx
2623
2624   PREVIOUS CHANGES:
2625
2626   All platforms:
2627
2628     - vos now properly deals with matching sites when servers are multihomed.
2629
2630   All Unix platforms:
2631
2632     - Servers now marked down when GetCapabilities returns error.
2633
2634     - In-use vcache count is now properly tracked.
2635
2636   All server platforms:
2637
2638     - Fix ptserver supergroups support on 64 bit platforms.
2639
2640     - Demand attach salvaging doesn't use freed volume pointers.
2641
2642     - Properly hold host lock during host enumeration in fileserver.
2643
2644   FreeBSD:
2645
2646     - Fix socket termination on shutdown.
2647
2648     - Support for 7.2, 7.3, 7.4 and 8.2 included.
2649
2650     - References to vcaches are no longer leaked during root or reclaim.
2651
2652   Linux:
2653
2654     - Define llseek handler to avoid ESPIPE error in 2.6.37.
2655
2656     - Mount interface replaces get_sb (new for 2.6.37, not yet required).
2657
2658     - RedHat init script allows deferring for a new binary restart.
2659
2660     - DEFINE_MUTEX replaces DECLARE_MUTEX for 2.6.37.
2661
2662   MacOS:
2663
2664     - Correct return value from setpag syscall.
2665
2666   OpenBSD:
2667
2668     - Bug fixes for issues introduced previously in 1.5 series.
2669
2670   Solaris:
2671
2672     - Switch to ioctl() syscall replacement for Solaris 11 since syscall 65
2673       is not safe.
2674
2675
2676 OpenAFS 1.5.78 (2010-11-04)
2677
2678   All platforms
2679
2680     * Revisions to Rx to fix performance issues.
2681
2682     * Make fs getfid behave consistently across all platforms. (128372)
2683
2684     * Properly check IDs handed to pts when creating users or groups so
2685       useful error messages can be provided. (128343)
2686
2687     * Correct byte order handling of port in afsconf_LookupServer for SRV
2688       records.
2689
2690     * Force a full dump when releasing to a site which was previously
2691       marked "don't use", in case the previous clone was out of date.
2692
2693   All server platforms
2694
2695     * Demand salvage of attached volumes now correctly track attachment
2696       state.
2697
2698     * Avoid a potential crash due to failure to hold a lock when attaching
2699       a volume fails.
2700
2701   Microsoft Windows
2702
2703     * Track SMB connections by SID rather than username.
2704
2705     * Error write attempts to known-readonly volumes earlier.
2706
2707     * Validate directory buffers to avoid potential crashes.
2708
2709     * Handle VIO errors from bulkstatus.
2710
2711     * Make PMTU discovery configurable and register error handlers for it.
2712
2713   All UNIX client platforms
2714
2715     * Use larger I/O sizes in memcache to improve performance.
2716
2717     * Avoid potential alignment issues doing I/O for pioctl calls.
2718
2719   FreeBSD
2720
2721     * Avoid panicing if the listener process is not findable.
2722
2723     * Avoid deadlock issues while performing lookups.
2724
2725   Linux
2726
2727     * Handle stale file handle errors for some cache partition types.
2728
2729     * Avoid blocking with xvcache lock when attempting to free in-use
2730       vcaches.
2731
2732     * Build fixes for older kernels.
2733
2734     * Properly configure LWP to use ucontext() on platforms where it
2735       should.
2736
2737     * Eliminate spurious errors from AFS system call returns. (126230)
2738
2739   MacOS
2740
2741     * Attempt to honor configured Kerberos defaults in Preferences Pane.
2742
2743
2744 OpenAFS 1.5.77 (2010-09-08)
2745
2746   All platforms
2747
2748     * Rx path MTU detection will terminate detection in cases where the
2749       minimum required packet size cannot be transferred.
2750
2751     * vos dryrun mode now shows effects for syncvldb single volume case.
2752
2753     * vos dryrun mode now shows "status after" for syncvldb and syncserv.
2754
2755   All server platforms
2756
2757     * RXAFS_GetStatistics64 now returns statistics properly.
2758
2759   Microsoft Windows
2760
2761     * Attempt to properly identify the local system SMB connection for
2762       token tracking.
2763
2764     * Remap timeout and offline errors to proper NT RPC errors.
2765
2766     * Properly fail over to other replicas on bulkstat IO errors.
2767
2768     * Properly error delete-mode createfile if a file is set readonly.
2769
2770     * Validate directory entry buffers to avoid crashing the service.
2771
2772     * Log file modes properly.
2773
2774     * Log cell name when logging server information.
2775
2776   All UNIX client platforms
2777
2778     * cacheout program for discarding callbacks is now built.
2779
2780     * bulkstatus kernel locking is corrected to avoid a potential panic.
2781
2782   Dragonfly BSD
2783
2784     * userspace support update
2785
2786   FreeBSD
2787
2788     * Updated vnode locking for children returned via lookup().
2789
2790     * Avoid file open undercount with needed calls to
2791       FakeOpen/FakeClose().
2792
2793     * Use vnode_pager_setsize to properly track file size during kernel
2794       IO.
2795
2796     * Update system call installation.
2797
2798     * Fix shutdown of Rx kernel listener to avoid potential dereference
2799       after it's gone.
2800
2801     * Avoid closing vnodes during vnode recycle.
2802
2803     * Fix bogus call to FlushVS for vnode reclaims.
2804
2805   Linux
2806
2807     * Packaging updated for current configure options and built files.
2808
2809     * Cache bypass now holds reference on pages during readpage.
2810
2811     * s390x setgroups32 patching update.
2812
2813   MacOS
2814
2815     * DNS resolver is reinitialized on IP address change. (126440)
2816
2817
2818 OpenAFS 1.5.76 (2010-08-16)
2819
2820   All platforms
2821
2822     * Updates to build-time configuration.
2823
2824     * Fix XDR support in Rx to match header definition.
2825
2826     * vos status now shows transaction creation, not action creation.
2827
2828     * Rx avoids reporting loopback adapters when listing interfaces.
2829
2830   All server platforms
2831
2832     * Demand-Attach Fileserver always built and installed (dafileserver,
2833       davolserver, dasalvager).
2834
2835     * Return VNOVOL from fileserver when a volume is deleted.
2836
2837     * Ignore duplicate tags during volume restore operation.
2838
2839     * Update inode array after salvage repairs volume.
2840
2841     * Zero a corrupted header in memory during salvage to avoid further
2842       corruption.
2843
2844     * Fix NAMEI backend to allow low-numbered volumes to work properly.
2845
2846     * ptserver does not include cell name as part of length check for
2847       names.
2848
2849     * Updated error messages for unblessed volumes.
2850
2851     * vlserver avoids buffer overflow with regex pattern
2852
2853     * Attach-time failures now note failures as the rest of the fileserver
2854       would.
2855
2856     * Server argument logging will no longer overflow stack.
2857
2858     * Provide fast-restart-like unsafe-nosalvage option for DAFS.
2859
2860     * Deal with host hash collisions in the fileserver.
2861
2862   Microsoft Windows
2863
2864     * Avoid crashing when interpreting a drive letter as potentially
2865       matching a cell name.
2866
2867     * Properly handle volume package errors.
2868
2869     * Allow page recycling from known-readonly content without ensuring
2870       they are not dirty.
2871
2872     * 32 bit tools installer should not override client configuration.
2873
2874     * Ensure root scache item has a valid callback when use is attempted.
2875
2876     * Freelance directory changes now properly invalidate and replace the
2877       old root object.
2878
2879   All UNIX client platforms
2880
2881     * Support disconnected reconnecting with specified UID for PAGless
2882       platforms.
2883
2884     * Proper disconnected vnode reference tracking.
2885
2886     * Update server site blacklisting to not return success if nothing was
2887       blacklisted.
2888
2889     * Avoid a panic during vcache contention due to CVInit vcache
2890       racing. (127645)
2891
2892   FreeBSD
2893
2894     * Update for network stack in 8.1/9.0.
2895
2896   HP-UX
2897
2898     * Bug fixes.
2899
2900   Linux
2901
2902     * 2.6.36 support
2903
2904     * Disable PMTU error packet handling.
2905
2906     * flock() fixes.
2907
2908     * Debian packaging updated.
2909
2910     * freezer interface updates.
2911
2912   MacOS
2913
2914     * Hold references to disconnected mode written vnodes properly.
2915
2916   Solaris
2917
2918     * Handle NFS translator module references for amd64.
2919
2920     * INODE fileserver backend support now exists for amd64.
2921
2922
2923 OpenAFS 1.5.75 (2010-07-07)
2924
2925   All platforms
2926
2927     * Prevent rx_rpc_stats global lock from being a bottleneck.
2928
2929     * Path MTU discovery is now provided to allow traffic to pass networks
2930       with sub-1500 byte MTUs and poor fragment handling.
2931
2932     * Further reduce Rx NAT ping transmission when enabled.
2933
2934     * Update Kerberos 5-based token handling in rxkad from upstream
2935       Heimdal.  (127554)
2936
2937     * Update version numbers emitted during build to reflect what is
2938       actually being built.
2939
2940     * Add "-human" switch for human-readable units in fs diskfree and
2941       listquota. (124529)
2942
2943     * vos provides reasons for locked volumes when known.
2944
2945     * Do not count retransmission and ping acks as non-idle for Rx
2946       connections.
2947
2948     * Rx: provide service-specific data getter and setter routines.
2949
2950     * Update build-time Kerberos detection.
2951
2952     * Updated userspace AFS client.
2953
2954     * Beginning of a modernized test suite.
2955
2956     * Additional documentation.
2957
2958     * Updated documentation, notably the Administrators Guide.
2959
2960     * Substantial code cleanup.
2961
2962   All server platforms
2963
2964     * Update handling of vnode allocation failures.
2965
2966     * DAFS: allow salvaging volumes not known to the fileserver, to allow
2967       cleanup of data not attached to a current volume.
2968
2969     * Properly handle volumes slated for destruction.
2970
2971     * Handle volumes with many files properly.
2972
2973     * Force core file generation in bosserver by overriding default
2974       resource limits when possible.
2975
2976     * Update vlclient and vldb_check.
2977
2978     * Avoid potentially corrupting a volume on creation if files are left
2979       from previous failed cleanup.
2980
2981     * Note volume changed during salvage as needed.
2982
2983     * DAFS: do not assume invalid addresses are in fileserver address hash
2984       table.
2985
2986     * Avoid tying up fileserver threads with volumes that are being taken
2987       offline.
2988
2989     * Do not set inUse on volumes for non-DAFS other than in fileserver.
2990
2991     * Break origin's callback on target of rename operation.
2992
2993     * Avoid unneeded parent directory link updates during some rename
2994       operations.
2995
2996     * Do not open /dev/console for writing in the fileserver.
2997
2998     * DAFS: avoid spurious restarts when binary restarts are configured.
2999
3000     * Avoid spurious and unneeded calls to sync(), which can slow down the
3001       fileserver.
3002
3003   Microsoft Windows
3004
3005     * Revised SMB QuerySecurityInfo to address issues caused by MS10-020
3006       (http://support.microsoft.com/kb/980232)
3007
3008     * Prevent use of the AFSCache file contents if mapped to a new
3009       address.
3010
3011     * Make fs newcell include behavior compatible with the non-Windows
3012       version.
3013
3014     * Provide a registry option (FreelanceImportCellServDB) to pre-create
3015       mount points in the AFS root for all cells in CellServDB.
3016
3017     * Fix a memory leak in the cm_FreeServerList() routine.
3018
3019     * Reduce privilege when reading registry CellServDB.
3020
3021     * Add support for RPC Pipe Service NetWkstaGetInfo levels needed for
3022       Windows 7.
3023
3024     * Prevent overflow when computing quota percentage in Explorer Shell.
3025       (126846)
3026
3027     * Generate meaningful errors for ACL operations on freelance AFS root.
3028
3029     * Fix error handling on InlineBulkStatus RPCs.
3030
3031     * Show configuration pages for all types of MSI installations.
3032
3033     * Improve freemount AFS root directory handling and operations.
3034
3035     * Properly validate GetVolumeStatus pioctl responses.
3036
3037     * Commit file length changes and dirty buffers when flushing a file.
3038
3039   All UNIX client platforms
3040
3041     * Update version of files for disk cache.
3042
3043     * Do not call afs_FlushVCBs with xvcache lock held, to improve
3044       parallelization.
3045
3046     * Add mariner log messages for creating and removing files.
3047
3048     * Don't hold xvcache lock while creating symlinks, to improve
3049       parallelization.
3050
3051     * Provide -dynroot-sparse mode to not show all cells in CellServDB in
3052       dynroot mode.
3053
3054     * Avoid a potential crash in aklog in linked cell handling.
3055
3056     * Log MTU-caused packet retransmission.
3057
3058     * Prevent crashes caused be fs checkservers while cache is being set
3059       up.
3060
3061     * fs getserverprefs now has a buffer large enough for the default
3062       CellServDB.
3063
3064     * Report server address when logging warnings.
3065
3066     * Avoid panic in GetCapabilities when cell is not known.
3067
3068     * Lock process name and id for advisory lock warnings when possible.
3069
3070     * Handle need for allocating additional Rx packets.
3071
3072     * Properly handle errors from InlineBulkStatus operations.
3073
3074     * Fix errors returned from fcntl() on readonly files locked for write.
3075
3076     * Flush pending changes to the server on LOCK_EX unlock.
3077
3078     * Reflect length changes as a result of callbacks even when file is
3079       open for write.
3080
3081     * Avoid hanging due to error exit when attempting to store a large
3082       file to a non-largefile fileserver.
3083
3084     * Recover from afs_GetVolSlot errors.
3085
3086   FreeBSD
3087
3088     * Bugfixes for kernel VFS and network routines.
3089
3090   IRIX
3091
3092     * Provide makesname().
3093
3094   Linux
3095
3096     * Avoid syscall probes when keyrings are present, by default. (125215)
3097
3098     * Remove "Big Kernel Lock" from VFS operations.
3099
3100     * Use filehandles for all Linux 2.6 versions to avoid need for matched
3101       afsd. (127530)
3102
3103     * Updated RPM packaging.
3104
3105     * Fix dkms configuration provided with RPMs.
3106
3107     * Hold reference on pages during background I/O for cache bypass.
3108
3109     * Fix cache bypass handling of non-largefile fileservers.
3110
3111     * Protect truncate_inode_pages mappings with mutex or semaphore as
3112       needed.
3113
3114     * Fix pagevec use in cache bypass. (127505)
3115
3116     * Updates for 2.6.35
3117
3118   MacOS
3119
3120     * Improve launchd configuration.
3121
3122     * Avoid hanging on recursive cache file lock acquisition when user
3123       notification is enabled.
3124
3125     * Fix and re-enable bulkstat mode.
3126
3127   OpenBSD
3128
3129     * Build updates.
3130
3131   Solaris
3132
3133     * Precluding unmount while AFS is busy.
3134
3135     * Avoid deadlocking when releasing the VFS object.
3136
3137     * Stop network interface poller in kernel on AFS shutdown.
3138
3139     * Avoid issues with lookups on empty directory names. (127356)
3140
3141
3142 OpenAFS 1.5.74 (2010-04-22)
3143
3144   All platforms
3145
3146     * Add "vos setaddrs" command.
3147
3148     * Rx library lock contention avoidance between rx_NewCall and
3149       rx_EndCall.
3150
3151     * Rx library races due to inconsistent use of rx_connection
3152       conn_data_lock to protect the flags field.
3153
3154     * Rx library inconsistent use of RX_CALL_TQ_WAIT which could result in
3155       deadlocks.
3156
3157     * Rx library must signal transmit queue waiters when flushing.
3158
3159     * afsmonitor shows busy counts now.
3160
3161     * afsmonitor displays xstat callback statistics.
3162
3163     * Provide expandgroups for pts mem on a supergroups server.
3164
3165     * Provide supergroup option to liste nested groups during pts mem.
3166
3167   All server platforms
3168
3169     * Avoid volume lock contention during DAFS startup.
3170
3171   Microsoft Windows
3172
3173     * Avoid a race when updating cell vldb server lists that can result in
3174       a crash.
3175
3176     * Avoid a deadlock when managing CM_SCACHESYNC_STOREDATA state
3177       operations for directory objects.
3178
3179     * Add new Windows Application Event log messages for VBUSY,
3180       VRESTARTING, ALL_BUSY, ALL_OFFLINE, and ALL_DOWN.
3181
3182     * Reduce lock contention by waiting for cm_buf_t I/O operations.
3183
3184     * Split the cm_buf_t flags field to separate the flags that are
3185       protected by the cm_buf_t mutex from those protected by the
3186       buf_globalLock.
3187
3188     * In cm_UpdateVolumeLocation, avoid searching for a ".readonly" volume
3189       on a numeric volume name.
3190
3191     * File buffer allocations whose offsets are beyond server EOF should
3192       be locally allocated and zero filled.  The file server should not be
3193       issued a FetchData rpc which is guaranteed to fail.
3194
3195     * Enable integrated logon to work with Windows 7/2008 when user logons
3196       are performed with a non-Domain Kerberos principal.
3197
3198     * Add Protection Error messages to aklog output.
3199
3200   All UNIX client platforms
3201
3202     * Provide a FUSE-interfacing userspace afs client.
3203
3204     * Updates to libuafs userspace cache manager.
3205
3206     * Probe servers using GetCapabilities instead of GetTime, thus
3207       requiring fewer RPCs.
3208
3209     * Fix DNS SRV record handling for cell lookup.
3210
3211   FreeBSD
3212
3213     * Fix sleep/wakeup routines.
3214
3215     * Update for 8.0 release.
3216
3217   Linux
3218
3219     * Handle high memory addresses correctly.
3220
3221   MacOS
3222
3223     * Make 32 bit AFS syscalls work again.
3224
3225     * Work around finder "Duplicate" failure (caused by setting modes on
3226       symlinks).
3227
3228     * Disable bulkstat again (will be re-enabled at or before .75).
3229
3230     * Provide symlink type hints during readdir.
3231
3232
3233 OpenAFS 1.5.73 (2010-03-24)
3234
3235   All systems: Minor bugfixes. New features.
3236
3237   * New functionality:
3238
3239   All systems:
3240
3241     - NAT keepalive support at Rx level.
3242
3243     * Bugfixes:
3244
3245   All systems:
3246
3247     - Corrected server IP address output in vos syncvldb verbose mode.
3248
3249     - Corrected server IP address output for last "yes" host in udebug.
3250
3251     - Corrected SRV record support for canonicalizing cell names.
3252
3253   All UNIX clients:
3254
3255     - Fixed a potential race in Disconnected AFS "remove" support.
3256
3257     - Fix a potential blocking condition in fakestat mode.
3258
3259     - Avoid some errors and stack overflow reports when vos is interrupted.
3260       (33360,125535)
3261
3262     - Clean up several minor memory leaks.
3263
3264     - If a large file is stored to a non-largefile fileserver, avoid
3265       a potential deadlock.
3266
3267     - Increase maximum number of sysnames to 32.
3268
3269     - Readd fs mariner "storing" message, missing since AFS 3.3.
3270
3271     - Attempt timeouts on AFSDB lookups in userspace.
3272
3273     - Avoid interrupting writes due to an idle deadtime timeout.
3274
3275   All server platforms:
3276
3277     - Properly notify only affected hosts for volume callbacks. (126497)
3278
3279     - Allow volumes with trashed root directory to be recovered. (94658)
3280
3281     - Hold lock in file and volservers when traversing partition list.
3282
3283     - Use finer-grained locking in DAFS: volume, instead of partition locks.
3284
3285     - Schedule all DAFS salvages via FSSYNC.
3286
3287     - Avoid stale ptserver credential caching issue on keyfile update.
3288
3289     - Improve callback table overflow handling. (126451)
3290
3291     - Preclude deadlocks on when attempting to save DAFS state.
3292
3293     - Avoid races deleting hosts. (126454)
3294
3295     - Improve salvage speed for DAFS (124488)
3296
3297     - The bosserver now handles SIGTERM.
3298
3299   Microsoft Windows
3300
3301     - Prevent the Explorer Shell extension from crashing if symlink
3302       creation failed.  (126406)
3303
3304     - A Rx level NAT ping has been implemented. A registry value enables.
3305
3306     - Adds krb5 error message translation to aklog, afscreds,
3307       afslogon.dll, the network identity manager afs provider and
3308       translate_et.
3309
3310     - Default mode bit settings for file and directory creation are now
3311       provided, and can be configured.
3312
3313     - An SMB request trace facility is provided and can be enabled for
3314       debugging.
3315
3316   AIX:
3317
3318     - Clean up properly on mount failure.
3319
3320     - Add entry to /etc/vfs to allow umount to work.
3321
3322   FreeBSD:
3323
3324     - Additional work to support FreeBSD 8-current.
3325
3326   IRIX:
3327
3328     - Fix build issues with library order.
3329
3330   Linux:
3331
3332     - Fix s390 support conflict with executable stack patches.
3333
3334     - Don't count root's AFS session keyrings against quota.
3335
3336     - Correct dkms support in RPM config file.
3337
3338     - Keyring destructor now properly cleans up all tokens.
3339
3340     - Build again on old 2.6 kernels.
3341
3342     - Avoid GLOCK leak when updating CellServDB in-core.
3343
3344     - Fix byte-range lock handling.
3345
3346     - Attempt to deal with bdi issues. (126514)
3347
3348   MacOS:
3349
3350     - Some FSEvents hinting for authentication events now done. (23781)
3351
3352     - Update uninstaller. (125634)
3353
3354     - Rewrite afssettings and fstab code to avoid licensing issue with APSL.
3355
3356     - Growl client for user monitoring of AFS events included.
3357
3358     - Properly support insert-only dropboxes.
3359
3360     - Add bulkstat support.
3361
3362     - Include support for moving in Finder across mount points.
3363
3364     - Preferences Pane includes support for Kerberos 5 ticket renewal.
3365
3366   OpenBSD:
3367
3368     - Some support for OpenBSD 4.7.
3369
3370
3371 OpenAFS 1.5.72 (2010-02-15)
3372
3373   All platforms
3374
3375     * Provide internationalization support in com_err.
3376
3377     * Fix array length checking to avoid crashes when checking for a
3378       volume type based on name in vos.
3379
3380   All server platforms
3381
3382     * Provide backward compatible "-f" flag to salvager for force mode.
3383
3384   Microsoft Windows
3385
3386     * Restore use of DNS AFSDB and SRV records by kaserver clients.
3387
3388   All UNIX client platforms
3389
3390     * Fix client cache file truncation to not lose chunks when truncating
3391       a large file.
3392
3393     * Ensure a cache writeback hook is installed in the client (bug from
3394       1.5.71).
3395
3396     * Avoid spurious free memory warnings during clean shutdown.
3397
3398     * Fakestat mode avoids AFSDB lookups.
3399
3400     * "fs storebehind" now correctly reports errors on readonly volumes.
3401
3402     * Additional documentation for "fs getcacheparms"
3403
3404     * Forced new uuid generation with "fs uuid -generate" now works
3405       enforced permission correctly.
3406
3407   MacOS
3408
3409     * Add optimized Rx event handler in kernel.
3410
3411     * Installer now allows installing an older version.
3412
3413     * Panic decoder can now deal with MacOS 10.5 again.
3414
3415     * MacOS ._ files are now correctly not looked up as cellnames.
3416
3417   Linux
3418
3419     * To deal with SELinux file labeling, try cache accesses with current
3420       credentials in event of failure.
3421
3422     * Rx XDR encoding bug on i386 Linux is fixed (bug introduced in
3423       1.5.71).
3424
3425   IRIX
3426
3427     * Code compilation fixes.
3428
3429   OpenBSD
3430
3431     * Update for OpenBSD 4.6.
3432
3433
3434 OpenAFS 1.5.69 (2010-01-19)
3435
3436   All platforms
3437
3438     * Configuration of BOSserver no longer defaults to weekly restarts
3439       enabled.
3440
3441     * Provide BOS restricted mode by default.
3442
3443     * Add support for "vos endtrans" command.
3444
3445     * Default to providing full output from vos listvol.
3446
3447     * Correct additional-address tracking in the fileserver.
3448
3449     * Improve Rx performance by not unnecessarily dropping and reacquiring
3450       call locks in read and write processes.
3451
3452     * Avoid crashes when monitoring volserver transactions across
3453       potential transaction garbage collection.
3454
3455     * Numerous warning fixes.
3456
3457   All server platforms
3458
3459     * Avoid saving fileserver state in demand attach fileserver when
3460       panicing.
3461
3462     * Demand attach fileserver allows other callers to schedule salvages.
3463
3464     * Demand attach "bos salvage" now works correctly with restricted
3465       mode.
3466
3467   Microsoft Windows:
3468
3469     * Numerous changes to the client-internal btree directory handling to
3470       prevent errors.
3471
3472     * fs examine reports owner and group ids as signed values (PTS groups
3473       are negative).
3474
3475     * Preclude corruption due to races writing to smb buffers.
3476
3477     * Allow MTU settings in registry to be used.
3478
3479     * Apply MTU to both send and receive sizes.
3480
3481   All UNIX client platforms
3482
3483     * Avoid double-freeing Rx call structure if reading a response from
3484       the file server results in a short read.
3485
3486     * Handle negative lengths in FetchStatus results correctly.
3487
3488     * Properly clean up allocated memory at shutdown.
3489
3490     * Default to AFSDB compiled into the cache manager.
3491
3492     * Avoid inadvertant disclosure of stat() information to clients not so
3493       entitled.
3494
3495     * Correct a bug with AFSDB lookups introduced with SRV record support.
3496
3497   MacOS
3498
3499     * Install kernel panic processing tool in /Library/OpenAFS/Tools.
3500
3501     * Include debugging symbols for kernel extension in additional package.
3502
3503     * Support "Application Firewall" users.
3504
3505     * Avoid ._cellname AFSDB lookups.
3506
3507     * Compile preferences pane as a universal binary.
3508
3509   Linux
3510
3511     * Use splice to speed up storing files.
3512
3513     * When using memcache, avoid duplicating work in readpages.
3514
3515     * Use dget_parent to safely find an inode's parent.
3516
3517     * Disable access time updates in our superblock.
3518
3519     * Avoid crashing doing writeback if no credentials were stashed at
3520       file open.
3521
3522     * Simplify keyring support.
3523
3524     * Properly clean up vcache in event of failed mount.
3525
3526   FreeBSD
3527
3528     * Update for current FreeBSD 8.
3529
3530   Solaris
3531
3532     * Abstractly manipulate groups as now required.
3533
3534     * Abstractly access time instead of using lbolt directly.
3535
3536
3537 OpenAFS 1.5.68 (2009-12-08)
3538
3539   All platforms
3540
3541     * aklog now attempts to convert non-AFS errors to human-readable
3542       strings.
3543
3544     * Make stack not executable when compiling assembler source with GCC.
3545
3546     * Numerous source warning cleanups and code reorganization.
3547
3548   All server platforms
3549
3550     * Compute midnight for volume statistics calculation from local time.
3551
3552     * Salvager now orphans duplicate special inodes when running to allow
3553       recovery in event of a problem, instead of simply ignoring the
3554       issue.
3555
3556     * Support to ensure a server panic attempt leaves a core and thus
3557       restarts in a timely manner, rather than potentially hanging. Use
3558       panic to attempt cleanup before leaving a core when possible.
3559
3560     * Volume sync data reported during bulkstatus is now set correctly.
3561
3562     * Provide better tuning for fileserver file descriptor caching.
3563
3564     * Allow more than 128 threads in fileserver by modifying host
3565       structure in-use tracking.
3566
3567     * Avoid crashes getting volume server status during transaction
3568       cleanup.
3569
3570     * Improved logging of offline volume conditions.
3571
3572     * Correct volume statistics when cloning a volume.
3573
3574     * Avoid referencing host structures in the fileserver which are marked
3575       for deletion.
3576
3577     * Demand attach fileserver corrections to avoid coring during an
3578       aborted startup.
3579
3580     * host array bounds checking corrections to avoid buffer overflow.
3581
3582     * Handle special inodes correctly when promoting an inode fileserver
3583       readonly volume to read-write.
3584
3585   Microsoft Windows
3586
3587     * Set the DOS Readonly attribute on a file/directory whenever the unix
3588       mode combined with the mask 0200 is true.  Previously there was a
3589       discrepency between the mask used for testing for readonly behavior
3590       and that used for setting the attribute.
3591
3592     * Disable AFSVolSync based .readonly "whole-volume callback" support
3593       because the all file servers prior to 1.5.67 (and perhaps 1.4.12) do
3594       not properly assign a value to the AFSVolSync structure in bulk
3595       status RPC responses.
3596
3597     * Improve the error output from aklog to output the value from krb5
3598       error_message() if the afs_com_err output indicates an unknown
3599       value.
3600
3601     * Convert VBUSY and VRESTARTING to CM_ERROR_ALLBUSY and do not permit
3602       them to be exposed to the smb redirector.
3603
3604     * Convert STATUS_TIMEOUT responses to STATUS_IO_TIMEOUT to avoid
3605       confusion within the smb redirector.
3606
3607     * Fix the byte order assigned to port numbers associated with AFSDB
3608       record lookups.  They must be network byte order not host byte
3609       order.
3610
3611     * Add dynamic server ranking based on RPC round trip time
3612       measurements.
3613
3614   All UNIX client platforms
3615
3616     * Additional shutdown-time memory leaks removed.
3617
3618     * Improved logging of resource contention.
3619
3620     * Provide dumping for Rx debug packet tracking support in source.
3621
3622     * Update afscp test client to build, and provide an unlock client.
3623
3624     * Client buffers for directory parsing can now be allocated beyond the
3625       fixed set formerly provided.
3626
3627     * Work around race condition when manipulating read-only volume
3628       callbacks.
3629
3630     * Bugfixes to get PAG value pioctl.
3631
3632     * Bugfixes to SRV record support.
3633
3634   Linux
3635
3636     * Path MTU tracking code cleanup.
3637
3638     * Avoid an oops due to racing with vcache recycling thread.
3639
3640     * Changes to keyring PAG handling: for sufficiently new kernels, use
3641       only keyring-based PAGs, and disable group PAGs entirely.
3642
3643     * Updates to the kernel page cache interface: writing pages will now
3644       not spuriously leak page locks, and will avoid requiring duplicate
3645       work.
3646
3647     * Credential references are now tracked using native atomic counters.
3648
3649     * Kernel mutex/semaphore lock ordering fix to avoid deadlocks.
3650
3651     * Manipulate disk cache with credentials used to initialize it, to
3652       avoid security issues.
3653
3654   MacOS
3655
3656     * Fix fstrace message catalog location.
3657
3658     * Fix kernel fstrace logging.
3659
3660
3661 OpenAFS 1.5.66 (2009-10-25)
3662
3663   All platforms
3664
3665     * Avoid calling exit() in library code.
3666
3667     * Add rx window size and peer timeout tuning APIs.
3668
3669     * Correct rx peer timeout handling to disallow 0ms timeouts.
3670
3671     * Correct calculation of rx RTT by disregarding retransmitted packets.
3672
3673     * vos manpages updated to reflect changes in recent versions.
3674
3675     * GNU-style long options (e.g. --cell) are now supported in all
3676       commands.
3677
3678     * fs listacl can now print a command to recreate the current ACL.
3679
3680   All server platforms
3681
3682     * Fix a race on transaction objects in the volserver which can cause a
3683       crash.
3684
3685     * Avoid destroying and setting to NULL the callback connection when it
3686       could still be being used.
3687
3688     * Correct unlink handling in salvager.
3689
3690     * Improve error messages due to I/O errors in the volserver.
3691
3692     * Correct an issue which caused converted RO to RW volumes on namei
3693       fileservers to not come online immediately.
3694
3695   Microsoft Windows
3696
3697     * Official support for Windows 7 and Server 2008 R2.
3698
3699     * Prevent a file server bug (FetchData returning an invalid length
3700       instead of zero) from causing an "unexpected network error" when
3701       writing to files.
3702
3703     * Promote DNS SRV records as superior to DNS AFSDB records.  Support
3704       arbitrary port numbers for vldb servers.
3705
3706     * Add AFSVolSync based .readonly "whole-volume callback" support.
3707       With this functionality, multiple objects from a .readonly volume
3708       can have their status validated by issuing a single
3709       RXAFS_FetchStatus RPC.
3710
3711     * Remove drive mapping functionality and service start/stop from
3712       afscreds.exe.
3713
3714     * Remove drive mapping functionality from afs_config.exe.
3715
3716     * Use {HKLM,HKCU}\SOFTWARE\OpenAFS\Client DWORD "ShowMountTab" to
3717       restore access to drive mapping functionality in afscreds.exe and
3718       afs_config.exe.
3719
3720     * Adjust SMB error return codes to avoid returning STATUS_TIMEOUT
3721       which results in the SMB redirector disconnecting.
3722
3723     * Network Identity Manager OpenAFS Provider now provides its own "AFS
3724       lock" notification icon to report the status of "have tokens, have
3725       no tokens, service not started, service started but inaccessible".
3726       Hovering over the icon lists the cells for which tokens exist (if
3727       any) and the OpenAFS version number.  Double-clicking executes the
3728       Network Identity Manager default action.
3729
3730     * Prevent pioctl calls from retrying indefinitely when a sharing
3731       violation error occurs.
3732
3733   All UNIX client platforms
3734
3735     * Correct a condition which could discard the error from initializing
3736       a fetch request.
3737
3738     * Avoid using invalid references to afs_Conn connection structures,
3739       and thus potentially producing invalid data when a retry is needed.
3740
3741     * SRV records are now supported for discovering AFS servers.
3742
3743   Linux
3744
3745     * Correct writepage behavior.
3746
3747     * Fix error code handling in the writepage code.
3748
3749     * Avoid leaking page locks, which could potentially hang a machine.
3750
3751   MacOS X
3752
3753     * Preferences Pane improvements.
3754
3755   HP-UX
3756
3757     * Avoiding attempting to handle critical signals in servers, so that
3758       core file handling works correctly.
3759
3760
3761 OpenAFS 1.5.65 (2009-10-06)
3762
3763   All platforms
3764
3765     * Code compilation warning fixes, to enable better finding and
3766       tracking bugs.
3767
3768     * Provide configure-time switch to enable code warning compilation.
3769
3770   All server platforms
3771
3772     * Demand-attach fileserver now makes volume LRU list operations
3773       exclusive operations to avoid races during adding to the list.
3774
3775     * Fileservers now avoid potential "negative length" fetches.
3776
3777     * A leak in host tracking objects in the fileserver has been fixed.
3778
3779     * Salvager now unlinks all files by full path, to deal with the change
3780       to not chdir for core file tracking.
3781
3782     * Salvager avoids asserting if the volume header is unreadable.
3783
3784     * Demand-attach fileserver puts back volume references from fssync
3785       handlers when done.
3786
3787   Microsoft Windows
3788
3789     * Improved service response to suspend and shutdown event
3790       notifications.
3791
3792     * Avoid a bug in the file server that can result in an invalid length
3793       being returned as part of a fetch data response if the client
3794       attempts to read beyond the length of the file.
3795
3796     * Do not publish a default stream object for directories and mount
3797       point objects.  This was impacting the ability of some Windows XP
3798       systems to save roaming profiles.
3799
3800   All UNIX client platforms
3801
3802     * A bug which could cause erroneous handling of lengths on data reads
3803       has been fixed.
3804
3805     * A bug where erroneous length returns from the fileserver could
3806       result in a false error has been fixed.
3807
3808   Linux
3809
3810     * Background page copies are now supported for enhanced disk cache
3811       read performance.
3812
3813     * Blocking readahead is supported in readpages() to reduce overhead.
3814
3815     * Use readpage() instead of read() to access cache data to avail disk
3816       cache users of the kernel backing cache for improved performance.
3817
3818     * Minimize credential handling for improved performance.
3819
3820   MacOS X
3821
3822     * Preferences Pane cleanup.
3823
3824   Solaris
3825
3826     * Provide a fs_pathconf method with sensible defaults.
3827
3828     * Provide a _PC_FILESIZEBITS method to fix some NFS translator
3829       consumers.
3830
3831
3832 OpenAFS 1.5.64 (2009-09-22)
3833
3834   All server platforms
3835
3836     * The demand attach fileserver now puts back volume references gotten
3837       via the fssync interface.
3838
3839     * The demand attach fileserver had a structure reference error, which
3840       has been correected.
3841
3842   Microsoft Windows
3843
3844     * Restores Windows 2000 compatibility.
3845
3846     * Fixes a data consistency error between the output of NetWkstaGetInfo
3847       and NetServerGetInfo RPCs, specify the Lan workstation group name
3848       "AFS", and report server name as "AFS" instead of "\\AFS" when the
3849       caller asks for "\\AFS".
3850
3851     * Enables executables to be run from \\AFS on Windows 7.  Returns
3852       "Name not found" instead of "File not found" when a directory or
3853       file name cannot be found.  This avoids loader errors when system
3854       dlls cannot be located in the executable directory.
3855
3856     * Prevents cache manager from marking the file server "down" when the
3857       data returned in response to either RXAFS_FetchData64 or
3858       RXAFS_StoreData64 is invalid.
3859
3860     * Adds pioctl data validation to the AFS Explorer Shell extension.
3861
3862   All UNIX client platforms
3863
3864     * A bug which could cause a kernel panic in 1.5.63 has been corrected.
3865       This would manifest as a GetDCache panic or oops.
3866
3867   Linux
3868
3869     * aklog -setpag works again with recent kernels when keyring is in
3870       use.
3871
3872   MacOS
3873
3874     * When Fast User Switch is in use, AFS login is now handled correctly
3875       by the integration tool included with the preferences pane.
3876
3877     * Several packaging bugs have been corrected.
3878
3879
3880 OpenAFS 1.5.63 (2009-09-11)
3881
3882   All platforms
3883
3884     * The restorevol command is now documented and installed as a user
3885       command.
3886
3887     * The uss command now properly translates vldb entries to its expected
3888       format when handling them in all cases.
3889
3890     * Documentation now refers to Kerberos instead of kaserver.
3891
3892   All server platforms
3893
3894     * bosserver now handles BosConfig.new when restarting, allowing
3895       configuration to be replaced at restart time rather than with bos
3896       delete and bos create.  Documentation is updated to reflect this.
3897
3898     * The demand attach fileservice not longer potentially hangs trying to
3899       terminate demand-salvages which have already exited.
3900
3901     * The demand attach fileservice has been modified to avoid spurious
3902       'SYNC_putRes: write failed' warnings when some protocol messages
3903       cannot be acknowledged due to the sender terminating the connection.
3904
3905     * In the event of failure to contact the vlserver or ptserver, the
3906       fileserver will not exit and trigger a forced salvage. It will
3907       continue to try in the background to contact the needed services.
3908
3909     * The salvager can now repair certain cases of a damamged vnode index.
3910
3911     * The accessDate metadata for a volume is now updated correctly.
3912
3913   Microsoft Windows
3914
3915     * CRITICAL: Some applications for example those based on Cygwin were
3916       unable to access data stored in the AFS name space.  Explorer Shell
3917       also experienced inconsistent behavior.  This is fixed.
3918
3919     * CRITICAL: Multiple AFS pioctl requests issued nearly simultaneously
3920       by applications could result in pioctl responses being received by
3921       the wrong requester.  This in turn could result in application
3922       crashes.  symlink.exe, fs.exe, afslogon.dll, afscreds.exe, and the
3923       netidmgr afscred.dll plugin were all affected.
3924
3925     * Some XP machines running 1.5.62 had trouble saving roaming profile
3926       data.  This is fixed.
3927
3928     * Integrated Logon (afslogon.dll) did not function with domain
3929       specific configurations.
3930
3931     * Ensure that access denied and over quota errors experienced while
3932       storing data to the file server do not result in on-going retry
3933       attempts.
3934
3935   All UNIX client platforms
3936
3937     * Except on Solaris and AIX, the compiler may now be overriden at
3938       configure time by setting the CC environment variable.
3939
3940     * afsd now properly deals with large cache partitions.
3941
3942   FreeBSD
3943
3944     * Build shared libafsauthent and libafsrpc.
3945
3946   Linux
3947
3948     * Kernel module DKMS support now installs an unstripped module to
3949       allow debugging information to be collected.
3950
3951   MacOS
3952
3953     * Preferences pane properly updates token information.
3954
3955   MacOS 10.6
3956
3957     * klog will now properly handle passwords of 8 or fewer characters
3958       with an AFS string to key on hosts able to run 64 bit binaries.
3959
3960     * A panic at AFS shutdown due to "NO PCB" on a udp_lock has been
3961       addressed.
3962
3963     * The panic decoder script included in the source now properly handles
3964       32 and 64 bit panics.
3965
3966   NetBSD
3967
3968     * Avoid defining AFS_KERBEROS_ENV globally as it creates a circular
3969       dependency.
3970
3971     * Build shared libafsauthent and libafsrpc.
3972
3973   OpenBSD
3974
3975     * Build shared libafsauthent and libafsrpc.
3976
3977
3978 OpenAFS 1.5.62 (2009-08-28)
3979
3980   All platforms
3981
3982     * Numerous invisible changes to improve code maintainability,
3983       portability and enhanceability.
3984
3985   Microsoft Windows
3986
3987     * CRITICAL: Fixes two errors that can result in data loss when storing
3988       data to the file server.
3989       1. Failure to Store Portions of Unaligned Writes
3990       2. Failure to Store Data to File Servers Lacking Large File Support
3991       Read the announcement for more details:
3992         http://www.openafs.org/pipermail/openafs-announce/2009/000305.html
3993
3994     * CRITICAL: The cache manager daemon thread could terminate when the
3995       machine enters suspend mode.  This daemon thread performs the
3996       background check of down servers, offline volumes, callback
3997       expirations, etc.
3998
3999     * CRITICAL: Integrated Logon (afslogon.dll) was terminating
4000       unexpectedly.  Error checking has been improved and NULL pointer
4001       dereferences after Lsa API calls fail have been eliminated.
4002
4003     * For the first time, the OpenAFS SMB Server supports the DCE RPC
4004       services SRVSVC and WKSSVC.  Browsing \\AFS with the Explorer Shell
4005       or NET VIEW will now be faster and provide additional functionality.
4006       No longer will cell names longer than 12 characters be truncated.
4007
4008     * Improvements to DFS Referral request processing have been
4009       implemented.
4010
4011     * Unnecessary DNS lookups of share names are avoided improving
4012       performance.
4013
4014   All UNIX client platforms
4015
4016     * Non-Kerberos PAM modules work correctly again.
4017
4018   MacOS X
4019
4020     * MacOS 10.6 (Snowleopard) is now supported, both 32 and 64 bit mode.
4021
4022     * Updates to the AFSCommander preferences pane.
4023
4024     * Installer now permits cell names with dashes.
4025
4026
4027 OpenAFS 1.5.61 (2009-08-06)
4028
4029   All platforms
4030
4031     * Correct another race condition in the Rx library that could result
4032       in an unexpected panic while freeing the Rx call iovq.
4033
4034     * rx packet resend and data packets sent counts were incorrect.
4035
4036     * fs setquota, fs setcachesize, vos setfields, and vos create now
4037       accept human readable orders of magnitude. (K, M, G)
4038
4039     * fs listquota fixed to permit large quota sizes to be displayed.
4040
4041     * Correct documentation of bosserver permissions requirements.
4042
4043     * Modify vlserver to avoid potentially corrupting the database through
4044       volume id reuse.
4045
4046     * Generalized support for fast Rx timeout due to network
4047       down/unreachable.
4048
4049   All server platforms
4050
4051     * Allow audit logs to be sent via sys5 IPC message queues instead of
4052       logged directly.
4053
4054   Microsoft Windows
4055
4056     * If a file server becomes inaccessible while the cache manager has
4057       dirty buffers to write, the afsd_service buf_IncrSync thread can
4058       attempt to use 100% of the cpu.
4059
4060     * Fix "fs newcell" which was broken in 1.5.60.
4061
4062     * Do not attempt to synchronize dirty buffers if the associated volume
4063       is known to be unavailable.
4064
4065     * Modify behavior of a Freelance mountpoint target that does not
4066       specify a cell.  Instead of assuming the target volume is in the
4067       Freelance.Local cell, use the workstation "Cell" specified in the
4068       registry. A mountpoint target of "#root.cell." will now mean the
4069       root.cell volume in the workstation cell for the current session.
4070       If the workstation cell changes from "athena.mit.edu" to
4071       "andrew.cmu.edu", the referenced volume will also change without
4072       requiring that the mount point targets be altered.
4073
4074     * Add cm_FindServerByUuid().  Re-implement RXAFS_InitCallBackState3()
4075       to permit the server Uuid to be used to lookup the server object and
4076       from that determine the cell.  This permits callbacks that are
4077       received from alternate addresses to be processed with a known
4078       server object.  Previously a request from an unknown server would
4079       clear all callbacks from all cells.
4080
4081     * Fix a bug that prevented optimal performance when using a non-zero
4082       value for 'daemonCheckVolCBInterval'.  As a reminder, when
4083       "daemonCheckVolCBInterval" is set to a non-zero value, all .readonly
4084       volume callbacks are automatically renewed 90 minutes before their
4085       expiration.
4086
4087     * Fix automatic ranking of vldb servers whose values are obtained from
4088       the CellServDB file.
4089
4090     * Add failover for RX CALL TIMEOUT errors when the volume is readonly
4091       or the call is to a vldb server.
4092
4093     * Add registry based cell search functionality to NetIdMgr,
4094       afs_config.exe, and klog.exe.
4095
4096     * afsconf_GetCellInfo() has been modified to perform gethostbyname()
4097       lookups on the host names in the CellServDB instead of using the
4098       specified IP addresses.  This provides aklog, pts, vos, etc. the
4099       same CellServDB behavior that the Windows Cache Manager uses.
4100
4101     * When updating the stat cache entry callback of a .readonly object
4102       from the volume group object, update the file server reference to
4103       ensure it matches the most update to date callback.
4104
4105     * Add proper support for processing callbacks from multi-homed file
4106       servers.  Instead of comparing servers by cm_server_t pointer,
4107       compare them by UUID when the UUID is known.
4108
4109     * During a shutdown short circuit the offline volume check daemon
4110       functionality.
4111
4112     * Return the error code of RXAFS_FetchData / RXAFS_StoreData in
4113       preference to an error code reported by rx_EndCall.
4114
4115     * Add "PerFileAccessCheck" registry value to permit testing against
4116       experimental file servers that include per-file acl support.  This
4117       value is intentionally undocumented.  It is not to be used by
4118       production environment deployments.
4119
4120     * Fix a bug introduced in 1.5.60 that prevents the afs netidmgr
4121       provider from obtaining tokens when referrals are in play.
4122
4123     * Add "fs chown" and "fs chgrp" commands to permit the owner and group
4124       of objects stored in AFS to be set from Windows.
4125
4126     * Avoid performing background daemon operations when the machine is
4127       going into suspend mode.
4128
4129     * Perform offline volume checks in most recently used order.
4130
4131     * Prevent crash when a data version for a cache object goes backwards.
4132
4133     * Multi-thread safe library versions are now being generated and used.
4134       mtafsubik.lib, mtafsutil.lib, mtafsvldb.lib, mtafsvol.lib.
4135
4136     * Microsoft SMB Redirector (mrxsmb.sys) support for
4137       ExtendedSessTimeout values are now available on XP through Windows
4138       7.  Add functionality to autodetect if such support is present on
4139       the machine.  If so, configure it if necessary and dynamically
4140       adjust the AFS Rx timeout values accordingly.
4141
4142   All UNIX client platforms
4143
4144     * Fix out-of-tree source builds.
4145
4146   MacOS
4147
4148     * GUI installer now asks for local cell information.
4149
4150     * AFS Commander preferences pane is now installed by default.
4151
4152   Solaris
4153
4154     * Avoid kernel panics due to null pointer dereferences in the network
4155       interface poller kernel thread.
4156
4157
4158 OpenAFS 1.5.60 (2009-05-31)
4159
4160   All platforms
4161
4162     * Retry volserver transaction creation on failure.
4163
4164     * Allow building HTML and PDF documentation from included XML copies
4165       of User Guide, Admin Guide and Quick Start Guide for Unix.
4166
4167     * Documentation updates and additional documentation.
4168
4169     * Add -encrypt support to pts client.
4170
4171     * Convert MR-AFS fs commands to OSD commands.
4172
4173   All server platforms
4174
4175     * Updated background sync process in fileserver to avoid a race which
4176       could result in a volume being taken offline.
4177
4178   Microsoft Windows
4179
4180     * On April 9th Microsoft released a Hot Fix for Windows Server 2003
4181       SP2 that corrects a deadlock in the smb redirector and also adds new
4182       functionality that permits the AFS SMB server to be given a longer
4183       timeout than is normally the case.  New functionality has been added
4184       to configure these additional LanmanWorkstation\Parameter values.
4185       (This functionality has been backported to XP SP3 and is scheduled
4186       to be released on June 5th.)
4187
4188     * Fix RT#124787, a race condition between "fs flush <dir>", "fs
4189       flushvolume", or "fs flushall" and on-going directory operations
4190       that can result in afsd_service.exe crashing.
4191
4192     * Release Notes, User and Administrator guides are now shipped as
4193       indexed Windows HtmlHelp Files. (.chm).  Shortcuts are provided from
4194       the Start Menu.
4195
4196     * A method of specifying Client CellServDB information within the
4197       registry has been added that can be used to either override the
4198       CellServDB file or force the use of DNS lookups for a given cell.
4199       See the release notes for details.
4200
4201     * The pioctl interface now properly handles drive letter substitution
4202       to UNC paths.  (SUBST <d:> <\\afs\cell\path>)
4203
4204     * The BackConnectionHostNames registry value configuration was broken
4205       when dynamic re-establishment of Netbios Name registrations was
4206       added.  This release restores the functionality.
4207
4208     * All hidden vos.exe commands are now revealed.
4209
4210     * Attempts to store the same dirty file chunk from multiple threads
4211       are now prevented.
4212
4213     * The IsPathInAfs test in Explorer Shell Extension and fs.exe now
4214       permits broken symlinks to be treated as being in AFS.
4215
4216     * vos.exe commands that output 64-bit integer values once again do so.
4217       This was broken in 1.5.59.
4218
4219     * Cygwin Import Libraries are provided in the SDK for all OpenAFS
4220       DLLs.  This permits building cygwin applications against OpenAFS
4221       libraries.
4222
4223     * NSIS installer does a much better job of cleaning up files left over
4224       from previous installs.
4225
4226     * libafsconf.dll moved from Client\Program to Common directory as is
4227       is now used by all modules for CellServDB processing.
4228
4229   All UNIX client platforms
4230
4231     * Write back changes on last store for memcache to avoid discarding
4232       changes.
4233
4234     * Abstract disk cache support to allow for path, fh, inode based
4235       caches with no need for messy ifdef structures each time a new type
4236       is added.
4237
4238   DragonflyBSD
4239
4240     * Support as a userland port.
4241
4242   FreeBSD
4243
4244     * Corrected structure definition for userspace cache manager to allow
4245       builds to complete.
4246
4247   Linux
4248
4249     * Corrected client locking support.
4250
4251     * Updated patch to stop deadlocking in the kernel during mmap.
4252
4253     * Avoid oops when setting up groups for PAGs to match keyrings.
4254
4255     * Use Linux fh-based cache in cases where possible by default.
4256
4257   MacOS 10.3:
4258
4259     * Corrected structure definition for userspace cache manager to allow
4260       builds to complete.
4261
4262   OpenBSD
4263
4264     * Support for OpenBSD 4.5.
4265
4266   Solaris
4267
4268     * Corrected support for server-side vos split interface.
4269
4270
4271 OpenAFS 1.5.59 (2009-04-06)
4272
4273   Microsoft Windows
4274
4275     * Increased service priority class to "High" to match the priority of
4276       system components that are dependent upon the a timely response.
4277
4278     * SMB error responses avoid returning errors that could confuse the
4279       Microsoft SMB redirector into disconnecting the connection to \\AFS.
4280
4281   All UNIX client platforms (except MacOS X 10.4 and 10.5)
4282
4283     * OpenAFS 1.5.59 contains fixes for the client issues addressed by the
4284       security advisories OPENAFS-SA-2009-001 and OPENAFS-SA-2009-002.
4285
4286   Linux platforms
4287
4288     * Support for prerelease Linux 2.6.30 kernels.
4289
4290
4291 OpenAFS 1.5.58 (2009-03-30)
4292
4293   All platforms
4294
4295     * Code cleanup and prototyping.
4296
4297     * Avoid unnecessary blocking in Rx periodic cleanup code.
4298
4299   All server platforms
4300
4301     * Fileserver CopyOnWrite routine optimized for performance.
4302
4303     * Make fileserver callback dumps 64 bit safe.
4304
4305     * Fix byte order issues with fileserver host hashing.
4306
4307     * Fix buffer size issues with butc.
4308
4309     * Fix several Ubik recovery issues.
4310
4311     * Avoid leaking file references in the fileserver.
4312
4313     * Fix a race in DAFS while closing vnodes, and another offlining
4314       volumes.
4315
4316     * volserver interfaces for volume splitting client.
4317
4318   Microsoft Windows
4319
4320     * [RT 124293] A race condition exists which can result in a crash.
4321
4322     * [RT 124276] If the vldb is out of sync with the contents of the file
4323       servers, afsd_service will retry too many times when a file server
4324       reports a volume as not being present.  Now if the list reported by
4325       the vldb is the same as the previously seen list, then the retry is
4326       aborted.
4327
4328     * [RT 124276] Read-only volume failover was broken in 1.5.53 whenever
4329       accessing a volume results in VNOVOL or VMOVED.
4330
4331     * [RT 124276] Prior to 1.3.70 the volume server reference list was not
4332       reference counted and would be prematurely freed while in use.  When
4333       reference counting was added in 1.3.70 a bug was introduced that
4334       could result in service reference list corruption.
4335
4336     * Add Windows Application Event Log warning messages for "Client SMB
4337       MPX value too large" and "Client SMB Buffer Size too small".
4338
4339     * Renaming of files across directory boundaries would result in an
4340       invalid handle error when attempting to access the files after the
4341       move.
4342
4343     * Fix the handling of Tran2 Set Path Info RPCs.  Do not fail when a
4344       smb file descriptor cannot be found.  The whole point of using a
4345       Path Info function is because an smb file descriptor wasn't
4346       allocated.
4347
4348     * More edge cases in which dynamic addition of Freelance root.afs
4349       entries would get the wrong FID or where the root.afs directory
4350       would not be refreshed.
4351
4352     * Buffer overflow could occur if the workstation cell name was longer
4353       than 64 characters.  Crashes could occur in afscreds.exe,
4354       afslogon.dll, and afsd_service.exe.
4355
4356     * VNOSERVICE and VOFFLINE errors were leaking and were exposed to the
4357       smb client.
4358
4359     * Log file server uuid values as part of the cm_server object when
4360       available.  Dump the cm_server object list in response to "fs
4361       memdump".
4362
4363     * Optimize the performance of resetting access control lists when
4364       tokens are set or removed.
4365
4366     * Remove symlink recursion tests and increase max symlink count to 64
4367       from 16.
4368
4369     * Windows specific Rx performance improvements.
4370
4371     * Support for Network Identity Manager 2.0
4372
4373   All UNIX client platforms
4374
4375     * Avoid issues with freeing resources at shutdown.
4376
4377     * Numerous fixes to disconnected AFS.
4378
4379     * Disconnected AFS fixes for replaying changes without double-freeing.
4380
4381     * Attempt to use krb524 principal conversion in aklog if available.
4382
4383   AIX
4384
4385     * Kerberos configuration at build time corrected.
4386
4387   Linux
4388
4389     * Default to dynamic allocation of AFS kernel cache entries to allow
4390       growth for inotify()-pinned entries. (beagle, famd, etc)
4391
4392     * Change client truncation routines to avoid locking issues.
4393
4394     * IA64 port clients fixed on Linux 2.6.
4395
4396     * RPMs now install fstrace message catalog.
4397
4398     * Support through kernel 2.6.29 tested.
4399
4400     * Fix locking issues on CellServDB file in /proc.
4401
4402   OpenBSD
4403
4404     * Support OpenBSD 4.4
4405
4406
4407 OpenAFS 1.5.57 (2009-01-23)
4408
4409   All platforms
4410
4411     * Conditional compilation of rxdebug support is now possible.
4412
4413     * Documentation updates.
4414
4415     * Further race connditions in Rx have been corrected.
4416
4417   All server platforms
4418
4419     * Salvager no longer attempts to recreate headers in the wrong
4420       partition.
4421
4422     * Volumes are properly marked in use on creation and subsequently on
4423       examination with vos.
4424
4425   Microsoft Windows
4426
4427     * Undo the "UAC manifest fix" applied to afs_config.exe.
4428
4429     * Ensure that Freelance allocation of vnodes follow the AFS convention
4430       of odd vnodes are directories and everything else is an even vnode.
4431
4432     * Add Freelance logic to mount point and symlink evaluation functions.
4433
4434     * Enhance smb_ParseASCIIBlock() so that it can handle all of the
4435       STRING formats defined by the CIFS Technical Report 1.0.
4436
4437     * Validate the output of smb_ParseASCIIBlock() in all callers.  Return
4438       CM_ERROR_BADSMB if the STRING field cannot be parsed.
4439       CM_ERROR_BADSMB will cause the contents of the packet to be logged.
4440
4441     * If multiple SMB Raw Write operations were taking place at the same
4442       time, there could be data corruption because unique event objects
4443       were not generated for each Netbios receive operation.
4444
4445   All UNIX client platforms
4446
4447     * Userspace AFS library can now deal with large files when supported
4448       by the platform.
4449
4450     * Numerous updates to disconnected AFS support, including changes to
4451       allow reconnection to work in more circumstances.
4452
4453   FreeBSD
4454
4455     * FreeBSD unstrategy code has been updated.
4456
4457   Linux
4458
4459     * A race during file truncation has been corrected.
4460
4461     * System call probing routines have been updated.
4462
4463     * 2.6.29 is now supported.
4464
4465   MacOS
4466
4467     * 10.3 support has been corrected.
4468
4469   OpenBSD
4470
4471     * Initial OpenBSD 4.4 support.
4472
4473   Solaris
4474
4475     * Updates to allow compiling on newer OpenSolaris are now included.
4476
4477
4478 OpenAFS 1.5.56 (2008-12-30)
4479
4480   All platforms
4481
4482     * libuafs (userspace cache manager) updated to correct several errors.
4483
4484     * Additional rx debugging support is available as a conditional
4485       compile.
4486
4487     * A race condition in Rx leading to a panic has been corrected.
4488
4489     * Rx idle time tracking has been corrected.
4490
4491     * ubik clone server support has been corrected.
4492
4493   All server platforms
4494
4495     * Salvager no longer leaves cores in vice partitions.
4496
4497     * The vol-dump tool now supports dumps larger than 2gb where possible.
4498
4499     * Operations on multiple files now report all FIDs in the audit log.
4500
4501     * butc XBSA support now works correctly on amd64.
4502
4503   Microsoft Windows
4504
4505     * The NetIDMgr AFS Provider automated configuration logic was broken
4506       by the introduction of Kerberos referrals.  If the realm of the
4507       identity cannot be determined, the workstation cell is now assumed
4508       to belong to the newly created identity.
4509
4510     * Avoid a reference count under flow during rename operations.
4511
4512     * Avoid a crash caused by treating an arbitrary length directory
4513       search mask as an 8.3 mask.
4514
4515     * Prevent rename operations if a case insensitive match for the target
4516       name already exists and does not refer to the object being renamed.
4517
4518     * Increase the maximum number of background daemons to 64.
4519
4520     * Fix the UAC manifest applied to afs_config.exe
4521
4522   All UNIX client platforms
4523
4524     * Updates to disconnected AFS support.
4525
4526   FreeBSD
4527
4528     * FreeBSD 7.1 is now supported.
4529
4530     * amd64 FreeBSD is now supported.
4531
4532   Linux
4533
4534     * Generic fh (exportfs API) cache type is now available.
4535
4536     * Avoid some oopses due to backing_dev_info inode fields not being
4537       filled.
4538
4539     * 2.6.28 is now supported.
4540
4541   MacOS
4542
4543     * 10.3 support has been corrected.
4544
4545   Solaris
4546
4547     * Large partition support has been corrected.
4548
4549     * Filesystem-agnostic cache is now available on Solaris 10 and 11.
4550
4551
4552 OpenAFS 1.5.55 (2009-11-10)
4553
4554   All platforms
4555
4556     * Salvager avoids leaving core files in vice partitions.
4557
4558     * NFS translator fixes.
4559
4560     * Unresponsive server handling fixes.
4561
4562     * A volserver race which could result in duplicate transactions is
4563       fixed.
4564
4565   Microsoft Windows
4566
4567     * Fixes a panic caused by corruption of the SMB virtual circuit list.
4568       (race condition)
4569
4570     * Fixes a panic caused by receipt of a UTF-16 string that cannot be
4571       converted to UTF-8.
4572
4573     * Implements a more aggressive recovery algorithm for Netbios errors
4574       that result in loss of communication to the AFS SMB server.
4575
4576     * Improve pioctl response time when testing whether or not a PATH is
4577       in AFS.
4578
4579     * Adds support for linked cells.
4580
4581     * Increases the length of the cell and realm names that can be input
4582       into the Network Identity Manage AFS provider configuration dialog.
4583
4584   All UNIX client platforms
4585
4586     * Disconnected AFS avoids infinite recursion during rmdir.
4587
4588   Linux
4589
4590     * Support for 2.6.28 (not complete for NFS translator modules).
4591
4592     * Support for using exportfs API for filesystem-agnostic cache.
4593
4594     * Disable backing store readahead.
4595
4596     * Avoid deadlocks when writing back mmapped files larger than the
4597       cache.
4598
4599     * Avoid Oops when doing PAG garbage collection.
4600
4601
4602 OpenAFS 1.5.54 (2008-10-08)
4603
4604   All platforms
4605
4606     * Updates for new Tivoli X/Open API finding.
4607
4608     * A double-free is corrected in Rx.
4609
4610   All server platforms
4611
4612     * Ubik cleans up file descriptor cache correctly when doing recovery.
4613
4614     * Enhanced vldb error checker included.
4615
4616   Microsoft Windows
4617
4618     * Prevent a crash that could occur when multiple file / directory
4619       change notifications are processed simultaneously.
4620
4621   MacOS
4622
4623     * AFS claims more free space so Finder will attempt file copies.
4624
4625   Linux
4626
4627     * Avoid spurious ENOENT when calling gwtcwd() on a volume root.
4628
4629     * Avoid spurious ENOTDIR during fakestat.
4630
4631
4632 OpenAFS 1.5.53 (2008-09-26)
4633
4634   All platforms
4635
4636     * rx avoids many packet leaks.
4637
4638     * rx jumbogram disabling now works (and is the default).
4639
4640   All server platforms
4641
4642     * Demand Attach fileserver tries to avoid issues tracking offline
4643       status of volumes.
4644
4645   Microsoft Windows
4646
4647     * Many potential deadlock conditions due to out of order lock
4648       acquisitions have been corrected.
4649
4650     * A race condition resulting in an undercount on the cm_scache_t
4651       reference counts has been corrected.
4652
4653     * An empty string when sent as an ioctl path is now properly
4654       interpreted as meaning the current directory.  This affects "fs
4655       lsm", "symlink list", etc.
4656
4657     * Fix smb string parsing differences where the smb protocol
4658       documentation does not match the actual Windows implementation.
4659
4660     * Random access denied errors fixed.
4661
4662     * A file server lock synchronization issue was corrected in SMB
4663       NTCreateX and NTTranCreate operations.  This bug prevented properly
4664       operation when loading roaming profiles.
4665
4666     * Fix a heap overwrite error during server probe operations if a new
4667       server is added while a probe operation is in progress.
4668
4669     * Fix an LSA memory leak that was the result of an LSA error.
4670
4671     * Do not leak cm_cell_t objects if the VLDB server lookup fails.
4672
4673     * Only initialize rx mutex/lock objects once.
4674
4675     * Do not nul terminate the AFS volume name when reported to Windows.
4676
4677     * Improve VNOVOL error handling.  Prevent updated vl information from
4678       being destroyed immediately after it was acquired.  This bug
4679       prevented proper fail over when volumes are moved or removed from a
4680       server.
4681
4682     * Remove volume id from the server volume list in response to VMOVED
4683       and VNOVOL errors.
4684
4685     * "fs flushXXX" commands now destroy locally built B+ directory trees.
4686
4687     * Prevent mixture of locally modified directory pages and file server
4688       directory pages.
4689
4690     * Fail over to alternate vl servers if a ubik error is returned.
4691
4692   All UNIX client platforms
4693
4694     * Disconnected AFS now supports read-write mode.
4695
4696     * volserver now builds correctly.
4697
4698   AIX
4699
4700     * AIX 6 is now supported.
4701
4702   FreeBSD
4703
4704     * FreeBSD 7 is now supported.
4705
4706   Linux
4707
4708     * cache bypass is now supported.
4709
4710     * 2.6.x kmod compilation now uses kernel compile options always.
4711
4712     * Support through 2.6.27.
4713
4714   MacOS
4715
4716     * Show more space free so Finder doesn't get confused.
4717
4718   Solaris 10
4719
4720     * Default to namei rather than inode.
4721
4722
4723 OpenAFS 1.5.52 (2008-08-18)
4724
4725   All platforms
4726
4727     * Initialize volume updateDate at volume creation.
4728
4729     * Avoid potential corruption of directories during salvage.
4730
4731     * Check for out of memory condition during allocation of additional Rx
4732       packets.
4733
4734   Microsoft Windows
4735
4736     * Restore support for Windows 2000 (broken in 1.5.50).
4737
4738     * Perform additional validation on volume names in mount points during
4739       creation and evaluation.
4740
4741     * Fix several deadlocks, races, and reference count issues.
4742
4743     * Further optimize SMB Directory Search processing and minimize the
4744       number of InlineBulkStatus RPCs sent to the file server.
4745
4746     * Enable "bos restricted" operations.
4747
4748     * Fix the create of submounts used by the AFSCreds and afs_config
4749       drive mapping tabs.
4750
4751     * Fix a short name truncation bug. (1.5.50)
4752
4753     * Fix the error code reported when attempting to delete a file on a
4754       readonly volume or one that is marked with the readonly DOS
4755       attribute.
4756
4757     * Fix a heap corruption error when reading the CellServDB file
4758       location.
4759
4760     * Add the "RxUdpBufSize" registry value.  The new default is 256KB.
4761
4762     * Do not include trailing NULs in the directory search output.
4763       (1.5.50)
4764
4765     * Pre-allocate 64 Rx Packet buffers per thread in order to improve
4766       performance.
4767
4768     * For debugging: add smb lock requests and stat cache lock allocations
4769       to the output from "fs memdump".
4770
4771   NetBSD
4772
4773     * Workaround broken sigwait() to allow fileserver to shut down
4774       correctly pre NetBSD 5.0.
4775
4776   Solaris 10
4777
4778     * Default to namei fileserver; Allow inode fileserver at configure
4779       time by override.
4780
4781   NFS translator
4782
4783     * Try harder to avoid kernel panics for malformed requests.
4784
4785
4786 OpenAFS 1.5.51 (2008-07-29)
4787
4788   All platforms
4789
4790     * salvager tries harder to arrange for clients to get VBUSY while
4791       salvaging single volumes.
4792
4793     * salvager avoids certain corruption when salvaging directories.
4794
4795     * Rx connection clones disabled.
4796
4797   Microsoft Windows
4798
4799     * The 32-bit EXE 1.5.50 installer failed to properly install the C
4800       Runtime library.  When used as an upgrade OpenAFS would continue to
4801       work but when used as a new installation, OpenAFS binaries would
4802       fail to load.
4803
4804     * Fixes the "fs" and "symlink" commands to properly parse Unicode path
4805       prefixes during the pioctl remote procedure call.  This bug would
4806       result in file not found errors for files and directories that
4807       clearly exist.  (Bug introduced in 1.5.50)
4808
4809     * Large File support is disabled. (Bug introduced in 1.5.50)
4810
4811     * Removes the possibility of a deadlock during volume location update
4812       operation if all of the reported file servers are unreachable at the
4813       time of the update.
4814
4815     * Ensures that reference counts are properly incremented/decremented
4816       on Rx connection objects used for volume location RPCs.
4817
4818     * Over Quota errors during cm_FSync() calls would lead to an infinite
4819       loop as the error was never propagated to the caller.
4820
4821   All UNIX client platforms
4822
4823     * Bugfixes to disconnected AFS support in the cache manager.
4824
4825
4826 OpenAFS 1.5.50 (2008-07-16)
4827
4828   All platforms
4829
4830     * volserver puts recloned volumes back online before returning the
4831       volume to the fileserver, avoiding spurious VNOVOL errors.
4832
4833     * Updated TSM X/Open API support available.
4834
4835     * Demand Attach fileserver will not crash due to accesses during
4836       volume cloning.
4837
4838     * Substantial documentation updates.
4839
4840     * Demand Attach fileserver state tracking and analyzer tool
4841       improvements.
4842
4843     * UAFS userspace cachemanager updates.
4844
4845     * Corrected support for anti-meltdown protection in the client.
4846
4847   Microsoft Windows
4848
4849     * UNICODE Character Set Support.
4850
4851     * Pioctl interfaces to the cache manager have been refactored to
4852       provide layering between the SMB specific code and the general
4853       purpose ioctl operation.
4854
4855     * Garbage collect dead SMB virtual circuits as soon as they are no
4856       longer being referenced.  This avoids problems with outstanding
4857       locks not being dropped when the virtual circuit becomes invalid.
4858
4859     * Remove the IBM Administration Reference documentation and replace it
4860       with the OpenAFS Command Reference Manual.
4861
4862     * Avoid calling rx_SetDeadTime and rx_SetHardDeadTime functions each
4863       time a connection is about to be used.  Do not hold a lock on the rx
4864       connection object while it is being selected.  This avoids a race
4865       between threads attempting to set the timeout values and removes a
4866       bottleneck that was hampering performance.
4867
4868     * Ensure that the smb directory attribute is set for all directory
4869       objects.
4870
4871     * Replace the VC Runtime EXE installer with the MSI installer in the
4872       NSIS installer scripts.
4873
4874   Solaris
4875
4876     * Support for updates to OpenSolaris.
4877
4878   Linux
4879
4880     * Correct dentry revalidation for cross-directory renames.
4881
4882     * Updated rpm packaging materials for 1.5 release series and 2.4
4883       kernels.
4884
4885     * Corrected syscall table probing.
4886
4887     * NFS translator updates for current kernels.
4888
4889
4890 OpenAFS 1.5.39 (2008-06-24)
4891
4892   All platforms
4893
4894     * Updates for Demand Attach fileserver.
4895
4896   Microsoft Windows
4897
4898     * Fix two memory leaks.
4899
4900     * Fix one missing lock.
4901
4902     * Handle access denied errors when writing dirty buffers.
4903
4904     * Fix two errors that would cause the *experimental* AFS Servers
4905       to crash.
4906
4907
4908 OpenAFS 1.5.38 (2008-05-24)
4909
4910   All platforms
4911
4912     * Add read-only disconnected support.
4913
4914
4915 OpenAFS 1.5.37 (2008-05-21)
4916
4917   All platforms
4918
4919     * Includes a number of optimizations for testing.
4920
4921
4922 OpenAFS 1.5.36 (2008-05-09)
4923
4924   All platforms
4925
4926     * Rx optimizations now attempt to deal with high latency WANs.
4927
4928     * Client will not wait infinitely for a server which is not providing
4929       data.  Additional servers will be polled without marking the server
4930       which is not providing data down.
4931
4932     * vos move will not erroneously unlock locked vldb entries on failure.
4933
4934   All server platforms
4935
4936     * Fileserver avoids a potential infinite loop when a client
4937       relinquishes an address.
4938
4939     * Fileserver large setting now configures more threads.
4940
4941     * Fileserver properly registers uuids of new clients.
4942
4943     * Ubik servers do not improperly hide updates from clients.
4944
4945     * Fileservers reserve enough file descriptors such that each thread
4946       can cache one to avoid spurious errors.
4947
4948   Microsoft Windows
4949
4950     * Fix a cm_buf_t reference count leak when attempts to write dirty
4951       buffers to the file server from within cm_IncrSyncer() fail.
4952
4953     * Prevent udebug from crashing.
4954
4955     * Another VNOVNODE issue fixed.  When writing a dirty buffer to the
4956       file server, if VNOVNODE is received, mark all buffers as invalid
4957       without further attempts to contact the file server.
4958
4959
4960 OpenAFS 1.4.12
4961
4962   All client systems: Major bugfixes.
4963   File servers: Major bugfixes.
4964
4965   * New functionality:
4966
4967   All systems:
4968
4969     - Provide portable (pioctl) method for discovering what PAG a user is
4970       in. Required to support userspace PAG information collection on AIX
4971       5.1, and knowing whether Linux uses one group, two group, or only
4972       keyring based PAGs. (124709)
4973
4974     * Bugfixes:
4975
4976   All systems:
4977
4978     - Fixes to avoid issues cleaning up deleted hosts in the fileserver (126454)
4979
4980     - Fixes to avoid dropping writes due to server idle timeouts.
4981
4982     - Don't miss cache chunks of large files while truncating.
4983
4984     - Avoid null pointer dereference for unexpected volume names in volume
4985       utilities.
4986
4987     - Don't mark connections waiting for additional packet window availability
4988       idle.
4989
4990     - Kerberos 5 utilities (klog.krb5, aklog) enable weak encryption support.
4991
4992     - Avoid a double-free of an Rx call structure during a client fetch error.
4993
4994     - Avoid losing hosts during address changes. (125215)
4995
4996     - Clients shouldn't trust Fetchdata replies for the size of returned data.
4997
4998     - fileserver will not hang when attempting to cleanup and dump core.
4999
5000     - salvager will not leave core files in random directories.
5001
5002     - avoid letting retransmit timer get to 0 seconds.
5003
5004     - in event of dbserver contact failure, shut fileserver down cleanly.
5005
5006     - handle large partitions during check for needed disk space at
5007       client start.
5008
5009     - time out Rx connections if network unreachable error received.
5010
5011     - avoid dereferencing NULL pointer freeing Rx packets in receive. (125110)
5012
5013     - mark stack not executable in LWP. (125491)
5014
5015     - return a correct VolumeSync structure from Bulkstat RPCs in fileserver.
5016
5017     - client attempts to better free memory at shutdown.
5018
5019     - clear rx call queue safely. (125110)
5020
5021     - retry VLserver registration on failure in fileserver.
5022
5023     - update accessdate for volumes on access in fileserver.
5024
5025     - additional safety checks on vlserver operations to avoid
5026       database corruption.
5027
5028     - make ktc_curpag available on all builds. (125155)
5029
5030   FreeBSD:
5031
5032     - Build fixes.
5033
5034   Linux:
5035
5036     - Handle kernel changes through 2.6.33.
5037
5038     - Fix oops in clear_inode due to missed locking. (125589)
5039
5040     - Better handle /afs mount failures.
5041
5042     - Clean up after failures creating our kernel kmem cache.
5043
5044     - Work around memory management issues with some kernels when configuring
5045       the buffer cache/bdi (126514)
5046
5047     - Rename compile_et to afs_compile_et to avoid RPM conflicts.
5048
5049     - Handle whole-file locks properly. (126561)
5050
5051     - Deal with kernel autoconf header renaming.
5052
5053     - Handle SELinux cache backing file labels better to avoid potential oops.
5054       (92944,125544)
5055
5056   MacOS:
5057
5058     - klog now works correctly on 64 bit machines.
5059
5060     - launchd now used to launch AFS at boot.
5061
5062     - Preferences pane included for 10.4 and later.
5063
5064     - Older versions can now be installed from packages.
5065
5066     - Finder does not trigger bogus AFSDB lookups in /afs in dynroot mode.
5067
5068     - Include package with debug kernel module symbols.
5069
5070   OpenBSD:
5071
5072     - Build fixes.
5073
5074     - Support for x86_64.
5075
5076   Solaris:
5077
5078     - Handle ZFS caches usefully. (125365)
5079
5080     - Implement additional pathconf support.
5081
5082 OpenAFS 1.4.11
5083
5084   Linux client systems: Major bugfixes.
5085   All client systems: Minor bugfixes.
5086   File servers: Major bugfixes.
5087
5088   * New functionality:
5089
5090   All systems:
5091
5092     - Provide portable (pioctl) method for discovering what PAG a user is
5093       in. Required to support userspace PAG information collection on AIX
5094       5.1, and knowing whether Linux uses one group, two group, or only
5095       keyring based PAGs. (124709)
5096
5097     * Bugfixes:
5098
5099   All systems:
5100
5101     - Fix bosserver to invoke salvager with "-force" instead of ambiguous
5102       "-f". (124916)
5103
5104     - Cleanup for ptserver argument parsing to allow debug mode to work. (124893)
5105
5106     - Sanity checking for ptserver log levels. (124894)
5107
5108     - Fix for uninitialized memory dereference in klog.krb5.
5109
5110     - Fix an overflow in the cellconfig code used by client and server. (124891)
5111
5112     - Fix an erroneous vos verbose mode format string.
5113
5114     - Avoid losing writes on mmap()ed files when cache is memcache. (124671)
5115
5116     - Provide an afsd switch to allow override of the maximum MTU. (124880)
5117
5118     - Provide support for encrypt mode in pts.
5119
5120     - Fix race in background sync code which could cause volumes to go offline.
5121       (124359)
5122
5123     - Fix fileserver to avoid a null pointer dereference in client identity
5124       lookup routines. (125020)
5125
5126     - Improve handling of moves of volumes from 1.5 series fileservers. (18349)
5127
5128   FreeBSD:
5129
5130     - UKERNEL build fix. (124681)
5131
5132   Linux:
5133
5134     - Allow syscall probing to be disabled by switch to configure at build time.
5135
5136     - Fix bug in anti-recursion protection for mmap clients. (124627)
5137
5138     - Avoid a panic caused by changing credentials during VFS operations. (124737)
5139
5140     - Avoid need for rcu subsystem when unavailable. (124986)
5141
5142     - Improve keyring PAG setup code. (125001)
5143
5144     - Avoid possible ext3 cache truncation issues. (124942)
5145
5146   MacOS:
5147
5148     - MacOS 10.3 UKERNEL build fix. (124681)
5149
5150   OpenBSD:
5151
5152     - Update support for 4.5 (124719)
5153
5154   OpenSolaris:
5155
5156     - Updates for newer OpenSolaris kernels. (124116, 124924)
5157
5158 OpenAFS 1.4.10
5159
5160   All client systems: Security fixes.
5161   File servers: Major bugfixes.
5162   All systems: Minor bugfixes.
5163
5164   * Security fixes:
5165
5166   All client systems:
5167
5168     - Avoid a potential kernel memory overrun if more items than requested are
5169       returned from an InlineBulk or BulkStatus message. (124579)
5170
5171   Linux client systems:
5172
5173     - Avoid converting negative errors into invalid kernel memory pointers. (124580)
5174
5175     * Bugfixes:
5176
5177   AIX:
5178
5179     - Don't build aklog NAS module when krb5 is not available. (124522)
5180
5181   FreeBSD:
5182
5183     - Additional fixes and support. (124107, 123917)
5184
5185   Linux:
5186
5187     - Support 2.6.28. (123580)
5188
5189     - Support 2.6.29. (124115)
5190
5191     - Attempt to support 2.6.30 (124560)
5192
5193     - Avoid race during truncation. (124094)
5194
5195     - Dynamic vcache allocation support, to deal with inotify vcache pinning. (124334)
5196
5197     - Correct use of truncate_inode_pages to vmtruncate for locking issues. (124128)
5198
5199     - Update RPM configuration. (123650, 102673, 124272)
5200
5201     - Update kernel feature detection. (124507, 123604)
5202
5203     - Do appropriate locking for CellServDB in /proc. (124407)
5204
5205   MacOS:
5206
5207     - Fix MacOS 10.3 support.
5208
5209     - Add candidate Darwin 10 support.
5210
5211   NetBSD:
5212
5213     - Corrected NetBSD version tests. (123647)
5214
5215   OpenBSD:
5216
5217     - Update support for 4.4 (124541)
5218
5219   Solaris:
5220
5221     - Support cache filesystems which do not allow open by inode number, enabled by
5222       default on Solaris 9 and later. (123677)
5223
5224     - Improve error code return quality. (124426)
5225
5226     - Allow large partitions on Solaris servers.
5227
5228   All client systems:
5229
5230     - Avoid improper error messages about key version when krb5 is in use. (124220)
5231
5232     - Avoid attempting to free kernel memory which was already freed. (124531)
5233
5234     - Properly count offline volumes in vos client. (124333)
5235
5236   All server systems:
5237
5238     - Avoid 64 bit time issues in callback dump files. (124451)
5239
5240     - Support more than one local Kerberos realm; Usernames are assumed to be the
5241       same across realms.
5242
5243     - Ubik recovery is corrected to avoid spurious errors. (123723)
5244
5245     - Do proper host address hashing for little endian machines in fileserver. (124447)
5246
5247     - Update backup utility to properly compute header needs in the backup buffer.
5248       (124425)
5249
5250     - Avoid blocking during Rx unused connection reaping.
5251
5252     - Avoid leaking file handles in the fileserver when closing a volume. (124359)
5253
5254     - Fix bosserver corefile naming to be y2k-safe. (124340)
5255
5256     - Avoid potential infinite loop in deleted host handling in the fileserver.
5257
5258     - Support large volume dumps in vol-dump. (123984)
5259
5260     - Build butc XBSA support on 64 bit systems.
5261
5262   All systems:
5263
5264     - Properly track Rx connection idleness for timeouts.
5265
5266     - Additional documentation. (124472)
5267
5268     - Avoid a race which may result in an in-use Rx packet being freed. (123799)
5269
5270 OpenAFS 1.4.9
5271
5272   All client systems: Security fixes.
5273
5274   * Security fixes:
5275
5276   All client systems:
5277
5278     - Avoid a potential kernel memory overrun if more items than requested are
5279       returned from an InlineBulk or BulkStatus message. (124579)
5280
5281   Linux client systems:
5282
5283     - Avoid converting negative errors into invalid kernel memory pointers. (124580)
5284
5285 OpenAFS 1.4.8
5286
5287   File servers: Major bugfixes.
5288   All systems: Minor bugfixes.
5289
5290   * Bugfixes:
5291
5292   AIX:
5293
5294     - AIX 6.1 is now supported.
5295
5296     - Unpin kernel memory references after free. (99456)
5297
5298     FreeBSD:
5299
5300     - FreeBSD 7 is now supported.
5301
5302   Linux:
5303
5304     - Avoid deadlock when writing back pages in an mmap()ed file larger than
5305       the cache. (120491)
5306
5307     - Update process tree walking for PAG garbage collection to avoid oopses.
5308       (116603)
5309
5310     - fakestat mode now correctly avoids spurious ENOTDIR errors.
5311
5312     - Use kernel build system for all platforms.
5313
5314     - Remove openafs directory from proc in correct order. (112910)
5315
5316     - Handle renames across directories correctly in the linux dcache. (74672)
5317
5318     - Probe syscall table when possible. (105457)
5319
5320     - Mount point parsing is now updated to handle only well-formed mount
5321       points rather than similarly-formed symlinks. (113558, 100836)
5322
5323     - ucontext-style LWP is now anbled for glibc versions newer than 2.3.
5324
5325   MacOS:
5326
5327     - Update available space shown. (112910)
5328
5329   NetBSD:
5330
5331     - Work around broken SIGWAIT. (111404)
5332
5333   Solaris:
5334
5335     - Solaris 10 now defaults to namei fileservers.
5336
5337     - NFS translator issues fixed.
5338
5339     - Changes to address Solaris updates. (105495)
5340
5341   All client systems:
5342
5343     - udebug correctly displays the last "yes" host.
5344
5345     - Allow more vldb lookups to be cached in the client.
5346
5347     - Fix aklog to not be excessively verbose when not requested.
5348
5349     - Add support for timing out accesses which are not completing in a timely
5350       manner.
5351
5352     - Properly flag backup volumes being added to the vldb by vos syncvldb.
5353
5354   All server systems:
5355
5356     - fileserver "large" setting now implies 128 threads instead of 12.
5357
5358     - fileserver check for duplicate uuids is now applied correctly.
5359
5360     - Newer xbsa APIs are supported for TSM integration in butc.
5361
5362     - salvager avoids corrupting length of directory objects. (111585, 107767)
5363
5364     - volserver avoids a race during volume release so a volume will not
5365       appear to be offline. (107258)
5366
5367     - Add support for returning errors when accesses are not completing
5368       in a timely manner.
5369
5370     - Avoid potential race in the volserver when creating transactions. (121263)
5371
5372     - Return sensible error when a release or restore exhausts server
5373       resources. (121040)
5374
5375     - volserver now returns EXDEV if a new replica would duplicate one which
5376       already existed elsewhere on the server.
5377
5378     - Disable jumbograms by default.
5379
5380     - volserver updates a volume's updateDate on volume creation. (110943)
5381
5382     - Partitions over 2tb are now supported. (88811)
5383
5384   All systems:
5385
5386     - Re-enable Rx client keepalives. (20727)
5387
5388     - Support autoconf 2.62. (118058)
5389
5390     - Update Rx to avoid leaking packets.
5391
5392     - vos supports the -noresolve options to avoid issues with 127.0.0.1 being
5393       named in /etc/hosts.
5394
5395     - Additional documentation. (104110)
5396
5397 OpenAFS 1.4.7
5398
5399   File servers: Major bugfixes.
5400   All systems: Minor bugfixes.
5401
5402   * Bugfixes:
5403
5404   AIX:
5405
5406     - Kerberos as included in AIX has missing symbols. AFS krb5 tools now
5407       deal correctly.
5408
5409     - AIX LAM aklog plugin can now be used CDE screenlocker.
5410
5411     - Add support for getting the current PAG in pagsh and PAM.
5412
5413     - Avoid sending a terminal hangup to STREAMS in aklog.
5414
5415     - Fix afsdb support in the client.
5416
5417   Linux:
5418
5419     - Kernels through 2.6.25 are now supported. (77370,88000,83716,83890,80463)
5420
5421     - Client now only hashes dirty inodes. (78544)
5422
5423     - Fix to avoid returning invalid mount point data when -fakestat-all is in use.
5424       (93898)
5425
5426     - RPM build system updates. (93616)
5427
5428     - Restored write-on-close-or-fsync semantics when possible. (17509)
5429
5430     - Enabled support for flock() on files in AFS. (53457)
5431
5432     - ARM Linux now supported.
5433
5434     - Kernel keyring support updated.
5435
5436     - Fix client-displayed timestamp ordering by zeroing nanosecond field.
5437
5438   MacOS:
5439
5440     - Boot time init script now uses afs.conf to store config options. (81825)
5441
5442     - Avoid kernel panic due to excessive lock tracking when removing files.
5443
5444     - Avoid leaking kernel memory when trying to read() a directory.
5445
5446   Solaris:
5447
5448     - Avoid potential kernel panic if the root vnode of AFS changes.
5449
5450     - Avoid potential kernel panic when shutting down if contracts are in use.
5451
5452     - Avoid potential delays when creating new PAGs if the system clock
5453       has gone backwards.
5454
5455   All client systems:
5456
5457     - At client shutdown, try harder to clean up in-use resources. (74479)
5458
5459     - When fakestat is in use, enable optimization for Gnome Nautilus lookups.
5460
5461     - Properly hold lock when updating disk cache metadata to avoid
5462       kernel panic. (59136)
5463
5464     - Avoid wrapping to the start of a file when attempting to write a large file
5465       to a pre-largefile fileserver. (73720)
5466
5467   All server systems:
5468
5469     - Fixed to avoid truncating ubik databases during recovery. (77183)
5470
5471     - fileserver issue with internal file cache filling has been fixed. (87977)
5472
5473     - fileserver thread quota enforcement now done in all cases. (87416)
5474
5475     - fileserver avoids potential network-related deadlock when breaking
5476       callbacks.
5477
5478     - fileserver avoids crash due to race of resource creation and user requests
5479       at startup.
5480
5481     - fileserver avoids crash when reinitializing Ubik connections.
5482
5483     - volserver fixed to avoid leaving orphaned files during restore. (46937)
5484
5485     - volserver now supports convertROtoRW for inode fileservers.
5486
5487     - Support disabling kerberos 4 style username protection in servers. (75101)
5488
5489   All systems:
5490
5491     - Fix to butc to avoid crash due to threaded library variant.
5492
5493     - Fix to avoid network retransmission issues if the system clock goes
5494       backwards.
5495
5496     - vos syncvldb and syncserver now support a dryrun (do nothing) mode.
5497
5498     - vos addsite now supports adding a site where a replica is already
5499       available.
5500
5501     - vos clone now supports creating properly-named readonly and backup clones.
5502
5503     - vos restore now allows an older copy of a volume at an alternate site to
5504       not be removed.
5505
5506     - cmdebug now supports dumping a client's CellServDB.
5507
5508     - cmdebug now supports showing human-readable expiration times.
5509
5510     - aklog now handles Kerberos referrals.
5511
5512     - Additional documentation now included. (89288,89289,86677)
5513
5514 OpenAFS 1.4.6
5515
5516   All systems: Major bugfixes.
5517
5518   * Bugfixes:
5519
5520   All systems:
5521
5522     - fileserver host tracking code had a missing lock on a host structure;
5523       that lock has been added.
5524
5525     - fileserver handling for clients which are giving up callbacks did not
5526       hold a lock, making it unsafe and allowing clients to potentially
5527       crash the server by racing.
5528
5529     - fileserver will now leave a corefile when it is doing a shutdown due
5530       to error conditions.
5531
5532     - fileserver again allows ufs as a valid filesystem type (regression in 1.4.5).
5533
5534     - cbd handler for fileserver status data has an interpretation error which
5535       could cause crashes corrected.
5536
5537     - fileserver accurately tracks number of callbacks on a given file.
5538
5539 OpenAFS 1.4.5
5540
5541   All systems: Minor bugfixes.
5542   New systems: MacOS 10.5.
5543
5544   All systems:
5545
5546     - fileserver address tracking is improved to avoid potentially merging
5547       unrelated hosts.
5548
5549     - Documentation updates.
5550
5551     - namei fileserver now does fsync()s in background batches for performance
5552       improvements.
5553
5554     - Kerberos ticket support corrected in bundled Kerberos 4 utilities on 64
5555       bit platforms.
5556
5557     - fileserver includes limited per-host thread quota support to avoid
5558       resource starvation.
5559
5560     - fileserver deals with more damaged volumes without asserting.
5561
5562     - vos validates dumpfiles before attempting restores.
5563
5564     - vos clone will no longer potentially delete the parent volume.
5565
5566     - Client no longer permits empty UUID to be created.
5567
5568     - fs uuid command for checking, regenerating UUID added.
5569
5570     - Updates for gcc 4.2.
5571
5572     - fileserver treats w (write) permission as granting read lock permission
5573       in addition to write.
5574
5575   AIX:
5576
5577     - Bundled NAS Kerberos is now supported. (5.x)
5578
5579     - LAM aklog module is provided. (5.x)
5580
5581     - Associate cache files with correct filesystem to avoid snapshots when
5582       performing maintenance on local filesystems.
5583
5584   Irix:
5585
5586     - Makefile updates.
5587
5588   Linux:
5589
5590     - Kernels throigh 2.6.23 are known to work.
5591
5592     - Updates to syscall table probing.
5593
5594     - Bug fix in keyring PAG support to avoid oops.
5595
5596     - updated sample RPM configuration.
5597
5598     - sparc32 lwp support updated.
5599
5600     - Avoid potential oops in symlink support in certain older kernels.
5601
5602     - Avoid potential deadlock during vmalloc.
5603
5604     - Corrected locking while interacting with kernel task list.
5605
5606   MacOS:
5607
5608     - Several panics fixed, including remove_fsref. (10.4 and later)
5609
5610     - IP address changes now tracked.
5611
5612     - Corrected support for dropboxes (li access without r) with cp and Finder.
5613
5614     - fstrace and ancillary files now included.
5615
5616     - man pages are now installed in the default MANPATH.
5617
5618     - Servers will be timed out quickly if there is no route available.
5619
5620     - Temporary files from remove-while-busy now cleaned up correctly.
5621
5622   Solaris:
5623
5624     - Updates to accomodate kernel interface changes. (10u4 and later)
5625
5626     - knfs and NFS translator support updated.
5627
5628     - Changes to accomodate version 5.4 xbsa library.
5629
5630     - Updates for new SunStudio defaults.
5631
5632 OpenAFS 1.4.2
5633
5634   All systems: Major bugfixes.
5635
5636   * Bugfixes:
5637
5638   All systems:
5639
5640     * A bug in the namei volserver which could erroneously make a replicated or
5641       moved volume go offline has been fixed.
5642
5643     * Volume package users (fileserver, volserver, salvager) avoid using lockf to
5644       avoid leaking byte range locks on volume internal files.
5645
5646   MacOS 10.4:
5647
5648     * A bug where the client kernel module could free stack memory (which caused
5649       issues with 64 bit Intel most commonly) has been fixed.
5650
5651   Linux:
5652
5653     * A missing kernel feature test has been fixed.
5654
5655     * group based PAG support is still enabled when possible.
5656
5657     * ia32 syscall table support for amd64 has build fixes for modern kernels.
5658
5659   Solaris:
5660
5661     * fopen() is not safe for use with more than 255 file descriptors open;
5662       Emulate it in the afsconf package so afsconf can be used in the fileserver.
5663
5664   Windows:
5665
5666     * DNS registration is disabled for the loopback adapter, and we make sure
5667       Netbios is turned on.
5668
5669   Since 1.4.1:
5670
5671   All platforms:
5672     * Remove use of ubik_Call in the source code so prototypes are used.
5673
5674     * Avoid synchrony in call from the fileserver to the ptserver.
5675
5676     * Fix a bug in the backup suite when restoring.
5677
5678     * fileserver and volserver now log for error conditions which may cause
5679       exiting.
5680
5681     * rx avoids a stack overrun when more packets are needed.
5682
5683     * volserver avoids holding a lock too long when purging volumes.
5684
5685     * volserver lock initialization fixes
5686
5687     * volserver volume nuke fixes to avoid leaving files behind
5688
5689     * fileserver avoids error when authenticating ptserver requests
5690
5691     * fileserver no longer crashes when GetCPS fails
5692
5693     * salvager enhancements to deal better with corrupt volumes for namei
5694
5695   Unix:
5696
5697     * aklog deals with KDCs which give "generic" replies to principals not
5698       existing.
5699
5700     * Fix bug in cache parameter autotuning
5701
5702   RedHat:
5703
5704     * packaging fixes
5705
5706   Linux:
5707
5708     * amd64 pthread library family updates.
5709
5710     * autoconf fixes for kernel feature testing
5711
5712     * keyring PAG support now only enabled if needed features are present
5713       and other updates
5714
5715     * inline a version of BUG() so we get better oopses
5716
5717   AIX:
5718
5719     * tsm is updated to work with the new AIX 5 interface.
5720
5721   MacOS:
5722
5723     * Cross compile fixes
5724
5725     * Packaging improvements
5726
5727     * Large file support fixed (Thanks to Chaskiel Grundman)
5728
5729     * Fixes for Leopard seed.
5730
5731     * Installer image updates
5732
5733   Windows:
5734
5735     * Removes race conditions and a deadlock introduced in 1.4.1
5736
5737     * Fixes ANSI filename option.
5738
5739     * Establishes new connections to file servers when
5740       IP address configuration changes are detected.
5741
5742     * Improved CIFS compatibility
5743
5744     * Cache Manager optimizations
5745
5746     * Fixes vlserver failover when mounting 'root.afs'
5747       (Freelance mode disabled)
5748
5749     * Installs help files in the correct location for use by afscreds.exe
5750       and afs control panel.
5751
5752     * Improve reporting of "over quota" and "disk full" errors.
5753
5754     * Prevent crash when evaluating mount points to volumes that do
5755       not exist
5756
5757     * Removes auto-registration of AFS ID in foreign ptservers from
5758       Integrated Logon DLL.  This prevents crashes if the DLL is loaded
5759       and unloaded prior to termination of the process.
5760
5761     * SDK moved to \Program Files\OpenAFS\SDK
5762
5763     * NSIS and WiX Installer Frameworks update to the latest versions
5764
5765     * Improvements to the Kerberos Logon Integration
5766
5767     * Prevents exception in Integrated Logon DLL during SysPrep
5768
5769     * Prevents displays of MessageBox dialogs in response to Network Adapter
5770       errors
5771
5772     * Hard Dead and Connection Timeout values restricted to the CIFS Session
5773       Timeout value.
5774
5775     * Correct writing of BackConnectionsHostNames registry value.
5776
5777     * Properly recycles Volume entries
5778
5779     * The AFS Explorer Shell Extension always finds its resource library.
5780
5781     * The export list for AFSAUTHENT.DLL has been corrected.  (The AFS
5782       plugin for NetIDMgr will no longer use 100% of CPU.)
5783
5784     * Renaming files on Microsoft Vista Build 5536 works.
5785
5786     * Better handling of "." directory in fs commands
5787
5788     * Add OpenAFS License text to installers
5789
5790     * fs setquota and fs mkmount commands behave the same as the UNIX
5791       version
5792
5793 OpenAFS 1.4.2
5794
5795   All systems: Major bugfixes.
5796
5797   * Bugfixes:
5798
5799   All systems:
5800
5801     - Volume dump parsing code in the volserver has better error checking.
5802
5803     - salvager has improved damaged volume handling on namei fileservers.
5804
5805     - fileserver has size validity checks for when large file support is disabled.
5806
5807     - fileserver avoids potentially multiply adding a host to its hash table.
5808
5809     - rxkad client private data storage is allocated dynamically on ticket size.
5810
5811     - Handle universal error code translation for file locking.
5812
5813     - fileserver needs to swap callback connections on a client IP change.
5814
5815     - fileserver host package revised to reduce lock contention.
5816
5817     - Rx has been fixed to count hard acks, thus opening the congestion window.
5818
5819     - All servers support bound Rx sockets (on one interface).
5820
5821     - namei fileserver no longer use lockf() to avoid range locking issues.
5822
5823     - most binaries now support the -version switch.
5824
5825     - backup suite fixes for 64 bit platforms.
5826
5827     - volserver avoids holding holds during volume purges.
5828
5829     - volserver avoids losing files on namei during vos zap.
5830
5831   AIX:
5832
5833     - fileserver now properly supports large files.
5834
5835     - TSM updates for AIX 5
5836
5837     - Kernel module avoids leaking Rx packets.
5838
5839     - Avoid use of global ubik client structure in fileserver.
5840
5841     - Update ubik call client interface to allow for prototyping.
5842
5843     - audit logging fixes when stdarg does not provide integral va_list type.
5844
5845   MacOS 10.4:
5846
5847     - A bug where the client kernel module could free stack memory (which
5848       caused issues with 64 bit Intel most commonly) has been fixed.
5849
5850     - Packaging fixes and updates.
5851
5852     - Uninstaller added.
5853
5854     - Fix large file support.
5855
5856   Linux:
5857
5858     - autoconf kernel feature testing has been restructured.
5859
5860     - PAG garbage collection is enabled by default.
5861
5862     - Kerberos updates for RHEL3.
5863
5864     - Fix POSIX lock enrollment for older Linux kernels.
5865
5866     - Updates for new 2.6 kernels.
5867
5868     - Avoid deadlocks in put_inode handler.
5869
5870     - Keyring-based PAG support.
5871
5872     - Fixes to avoid getting better oops info in the kernel.
5873
5874   Solaris:
5875
5876     - Remove some kernel symbol bindings for symbols we don't use.
5877
5878     - Cleanup for loopback mount of AFS on Solaris 10.
5879
5880     - Avoid issues with stdio not supporting file descriptors above 255 on
5881       Solaris 8 and lower in the fileserver.
5882
5883 OpenAFS 1.4.1
5884
5885   All systems: Major bugfixes.
5886   New systems: MacOS 10.4 (PowerPC and Intel)
5887
5888   * Bugfixes:
5889
5890   All systems:
5891
5892     - Several race conditions in the host tracking and handling in the fileserver
5893       which could cause inconsistent behavior and crashes have been fixed.
5894
5895     - A fileserver bug where a reference to a volume could be leaked and later
5896       cause a deadlock as a result of a bulk status call
5897
5898     - Reference counting of fileserver objects in unsigned 32 bit integers
5899       instead of signed 16 bit integers.
5900
5901     - Avoid type mismatches when handling time values (betweemn 32 bit and 64 bit
5902       variables).
5903
5904     - Fix a memory leak during multilevel packet queue handling.
5905
5906     - Audit log output had been updated to include FIDs for newly created files.
5907
5908   HP-UX 11i:
5909
5910     - 64 bit (large file) inodes are supported.
5911
5912     - Salvager will now handle large (>4gb) partitions.
5913
5914     * New features:
5915
5916   All systems:
5917
5918     - asetkey is now included to ease Kerberos 5 integration for server
5919       administrators.
5920
5921     - A new fileserver statistics collection including callback statistics was
5922       added.
5923
5924     - man pages are now generated.
5925
5926   Microsoft Windows:
5927
5928     - Fixes error message problems experienced by fs.exe and the AFS Explorer
5929       Shell Extensions related to the use of Universal Error Codes by the
5930       AFS File Server
5931
5932     - Adds full SMB/CIFS support for byte range locking.  In this implementation
5933       all locks are allocated locally and the AFS lock privilege is ignored.
5934       While this will not prevent two processes on different machines from
5935       simultaneously writing to the same file, it will prevent two processes
5936       on the same machine from doing so.
5937
5938     - The UP server check period has been reduced to once every ten minutes to
5939       match the period used by the UNIX clients.  The shorter period will
5940       assist clients maintain RX connections through NATs.
5941
5942     - Fixes the DOWN server check logic to ensure that any server that responds
5943       to a check is marked UP unless it is in the process of restarting.
5944
5945     - Add logic to better handle objects that no longer exist on the file server.
5946       (VNOVNODE errors.)
5947
5948     - Prevent the removal of existing drive mappings by "afscreds.exe -M"
5949
5950     - Fixes the procmgmt library so that it doesn't cause applications that
5951       unload it to crash.
5952
5953     - Improves the warnings written to the afsd_init.log file when the
5954       Windows RPC Protocol drivers are improperly configured.
5955
5956     - Fixes "fs setserverprefs -vlserver".  Multiple calls with the same
5957       server parameter could result in a crash of afsd_service.exe.
5958
5959     - The SMB/CIFS layer was audited for reference miscounts and memory leaks.
5960       All SMB objects are now properly counted, locked, and released when
5961       their work is done.
5962
5963     - Prevent file truncation of the user does not have the appropriate access.
5964
5965     - Token management was re-written to allow user tokens to be preserved
5966       during integrated login and freed after logoff is complete.
5967
5968     - Added a mechanism by which abandoned SMB virtual circuits can be
5969       detected and the associated resources cleaned up.
5970
5971     - Prevent the allocation of SMB file handles with a value of 0 or 0xFFFF
5972       which would be considered invalid by Windows applications.
5973
5974     - Fixed the processing of cell names to ensure that they are always
5975       treated as case insensitive strings.
5976
5977     - Fixed the network provider code to avoid querying the profile location
5978       if integrated login is disabled.
5979
5980     - If a mount point string is empty, return Path Not Found to the application.
5981
5982     - Windows returns WSAECONNRESET when an ICMP packet is received in response
5983       to a transmitted UDP packet that cannot be delivered.  Do not mark the
5984       connection as bad but instead retry the request.
5985
5986     - Fix the data written to the registry as part of the BackConnectionHostnames
5987       values.
5988
5989     - Fixed the rx-lwp implementation to always generate unique rx call
5990       identitiers.
5991
5992     - The default "fs minidump" type now includes data segments.
5993
5994
5995 OpenAFS 1.3
5996
5997   * -nosettime is now the default for afsd.  Use "-settime" to get the
5998     old behavior.
5999
6000   * OpenBSD is now supported.
6001
6002   * Mountpoint directory information is now only faked for cross-cell
6003     mountpoints when using the -fakestat flag (e.g. for the directories
6004     under /afs, but not for most other volumes mounted inside the cell).
6005     The -fakestat-all switch can be used to fake information for all
6006     mountpoints.
6007
6008   * When fakestat is enabled on MacOSX, the Finder can be used to browse
6009     a fully-populated /afs directory.  However, this precludes reliable
6010     use of entire volumes as MacOS bundles (i.e. containing a Contents
6011     directory in the root of the volume).
6012
6013   * Mountpoint directory information can be faked by the cache manager,
6014     making operations such as stat'ing all cells under /afs much faster.
6015     This is enabled by passing -fakestat to afsd, but might not be stable
6016     on all platforms.
6017
6018
6019 OpenAFS 1.2.9
6020
6021   * The kaserver now defaults to not allowing interrealm authentication,
6022     due to security vulnerabilities in the krb4 protocol.  The new
6023     "-crossrealm" flag to the kaserver is provided to reenable interrealm
6024     authentication if desired.
6025
6026   * RedHat Linux 9.0 is now supported.
6027
6028   * Solaris 9 12/02 is now supported.  Solaris 7 and 8 x86 should now
6029     work again.
6030
6031   * On Linux machines using 2.2 series kernels, 2.2.19 or higher is now
6032     required.
6033
6034   * An OpenAFS 1.2.9 afsd will not work with kernel modules built from
6035     an earlier OpenAFS release.  In general, using a mismatched afsd and
6036     kernel modules set is unsupported; it is not recommended that you use
6037     such a configuration on a regular basis.
6038
6039
6040 OpenAFS 1.2.8
6041
6042   * Mountpoint directory information is now only faked for cross-cell
6043     mountpoits when using the -fakestat flag (e.g. for the directories
6044     under /afs, but not for most other volumes mounted inside the cell).
6045     The -fakestat-all switch can be used to fake information for all
6046     mountpoints.
6047
6048   * HPUX 11.0 is now supported.
6049
6050   * It is now possible for AFS to use Kerberos 5 directly, via rxkad 2b.
6051     See the OpenAFS 1.2.8 Release Notes for more information on using this
6052     capability.
6053
6054   * An NFS translator kernel module is now included and compiled by
6055     default for Solaris only.
6056
6057
6058 OpenAFS 1.2.7
6059
6060   * MacOS X 10.2 is now supported.  FreeBSD 4.3 and later support is
6061     included in this release, but is still under active development and
6062     should only be used by those doing active development on the OpenAFS
6063     FreeBSD client.
6064
6065   * When fakestat is enabled on MacOSX, the Finder can be used to browse a
6066     fully-populated /afs directory.  However, this precludes reliable use
6067     of entire volumes as MacOS bundles (i.e. containing a Contents
6068     directory in the root of the volume).
6069
6070   * The fileserver will now use Rx pings to determine if clients are
6071     reachable prior to allocating resources to them, to prevent asymmetric
6072     clients from consuming all fileserver resources.
6073
6074
6075 OpenAFS 1.2.6
6076
6077   * Mountpoint directory information can be faked by the cache manager,
6078     making operations such as stat'ing all cells under /afs much faster.
6079     This is enabled by passing -fakestat to afsd.
6080
6081   * Solaris 9 FCS and Solaris 7 and 8 x86 are now supported.
6082
6083
6084 OpenAFS 1.2.5
6085
6086   * A remote denial of service attack in the AIX and IRIX clients has been
6087     fixed.  Users of those platforms are strongly encouraged to upgrade.
6088
6089   * Fixed race conditions in fileserver that could result in crash.
6090
6091
6092 OpenAFS 1.2.4
6093
6094   * Server logfiles now more consistant about format in which hosts are
6095     referred to.
6096
6097   * vfsck on Solaris will now allow force runs (using -y flag) even if old
6098     inodes exist.
6099
6100
6101 OpenAFS 1.2.3
6102
6103   * Cell aliases for dynroot can be specified in the CellAlias file in
6104     /usr/vice/etc or /usr/local/etc/openafs, in format "realname alias",
6105     one per line.  They can also be managed at runtime with "fs newalias"
6106     and "fs listaliases".
6107
6108
6109 OpenAFS 1.2.2
6110
6111   * Solaris 9 and Linux PA-RISC are now supported.
6112
6113   * fileserver will not erroneously delay legitimate errors for 3 seconds
6114     after 10 errors are returned (e.g. stat() on a directory you can't
6115     read).
6116
6117   * Rx MTU calculation now works for Irix, Solaris and Linux
6118
6119   * If afsd is started with the -dynroot flag, /afs will be locally
6120     generated from the CellServDB.  AFSDB cells will be mounted
6121     automatically upon access.
6122
6123   * The namei fileserver allows vice "partitions" to be directories
6124     instead of partitions and will attach and display accordingly.
6125     Creating the file "AlwaysAttach" in the /vicepX directory is used as
6126     the trigger to attach it.
6127
6128   * TSM support for butc no longer requires editing a Makefile, simply
6129     specify the --enable-tivoli-tsm configure option.
6130
6131   * Linux builds no longer require source changes every time the kernel
6132     inode structure changes; the OpenAFS sources will now configure itself
6133     to the actual inode structure as defined in the kernel sources.
6134
6135
6136 OpenAFS 1.2.1
6137
6138   * vfsck on Digital UNIX and Solaris will now refuse to fsck mounted
6139     mounted partitions.
6140
6141
6142 OpenAFS 1.2.0
6143
6144   * AFS now supports --prefix and the other directory options of
6145     configure.  By default AFS builds assuming it will be installed in
6146     /usr/local.  In order to get traditional AFS directory paths (/usr/afs
6147     and /usr/vice/etc) use the --enable-transarc-paths option to
6148     configure.  More details on the new directory layout are found in
6149     README.
6150
6151
6152 OpenAFS 1.1.1a
6153
6154   * Windows 95/98/ME/NT/2000 - Consistent versioning:  Installation, AFS
6155     Control Center, Client dialog boxes and properties pages for
6156     executables display a consistent OpenAFS version number.  Installation
6157     detects previous installation and prompts the user for upgrade
6158     options.
6159
6160   * Windows 95/98/ME/NT/2000 - Installation features:  During installation
6161     the user can select the source of the CellservDB file, AFS home cell,
6162     and drive mappings.  During installation a drive path mapping can
6163     include a variable that will be substituted with the current UserName
6164     that is logged in.
6165
6166   * Windows 2000/NT - Integrated logon:  The Integrated Logon feature
6167     works now.
6168
6169   * Windows 95/98/ME - Logon script features:  The Windows 95/98/ME client
6170     now offers a command-line option for starting up the AFS client
6171     without authenication. It is now possilbe to start the AFS client
6172     first and obtain tokens, and map drives all through Windows scripts.
6173     This helps using Windows 95/98/ME client in Kerberos 5 environment.
6174
6175   * Windows 2000/NT - LANA numbers:  AFS client now scans the LANA numbers
6176     to establish the correct NETBIOS connection.  NetBEUI is no longer
6177     needed.  The user no longer needs to find the correct LANA number.
6178
6179   * Windows 2000/NT - OpenAFS naming consistancy:  Further progress has
6180     been made to remove references to "Transarc AFS" and replace with
6181     "OpenAFS".
6182
6183
6184 OpenAFS 1.0
6185
6186   * AFS now builds with configure. The README for building has been
6187     updated and includes full details.
6188
6189   * A client system can now have multiple sysname values for @sys.  They
6190     will be searched in order when looking up files in AFS.  The
6191     -newsysname argument to fs sysname can be repeated to set multiple
6192     sysnames.
6193
6194   * A new system group is created for new cells (system:ptsviewers with id
6195     -203).  If this group exists, members of this group can examine and
6196     read the entire protection database.  They can examine all users and
6197     groups and can get the membership of any group.
6198
6199   * A new program, pt_util has been added to the distribution.  This
6200     program allows users to print the contents of the protection database
6201     or to edit the protection database without running a ptserver.  It can
6202     be used to set up a new cell without ever running in noauth mode.  Run
6203     pt_util -h for help.
6204
6205   * The fs setcrypt and fs getcrypt commands have been added.  These
6206     commands allow the system administrator to require that the client
6207     encrypt all authenticated traffic between the client workstation and
6208     AFS.  The encryption used is weak, but is likely better than sending
6209     unencrypted traffic in most environments.  Some functions, such as
6210     looking for a volume may not be encrypted, but data transfer certainly
6211     is.  By default data is not encrypted.  At this time no significant
6212     experimentation with server performance has been conducted.
6213
6214   * By default AFS is compiled with AFS_AFSDB_ENV, enabling the -afsdb
6215     option to be given to afsd on startup.  If this option is used, then
6216     new cells will be looked up using AFSDB records stored in DNS if they
6217     are not found in CellServDB.  This means that users can create
6218     cross-cell mountpoints in directories they control to access cells not
6219     in root.afs, and that cells in root.afs need not be in the client's
6220     CellServDB.
6221
6222   * AFS database servers can be marked as read-only clones.  Surround the
6223     hostname in square brackets on the bos addhost command and the
6224     database server will never be elected sync site.  This is useful for
6225     cells distributed over a wide region.
6226
6227   * The AFS servers now support the -syslog flag.  This flag causes them
6228     to log to syslog rather than to files.  This flag is not supported on
6229     NT.  For all servers besides the salvager, the flag can also be
6230     specified as -syslog=facility, where facility is an integer facility
6231     code from syslog.h.  A -syslogfacility option is provided for the
6232     salvager to accomplish the same goal.
6233
6234   * If the --enable-fast-restart flag is given when configuring AFS, then
6235     the salvager supports the -dontsalvage flag which causes it to exit
6236     without salvaging any volumes.  If this is configured into the third
6237     command of a fs process, then the fileserver will start without
6238     salvaging.  It will fail to attach volumes that need salvaging and
6239     they can be salvaged manually.  This provides significantly better
6240     server startup performance at the cost of administrative complexity.
6241
6242   * If the --enable-bitmap-later flag is given when configuring AFS, then
6243     the fileserver creates bitmaps for free vnodes on demand, allowing
6244     faster starts.
6245
6246   * If bosserver finds a BosConfig.new file at startup, it reads this file
6247     and renames it to BosConfig.  This allows bosserver to be reconfigured
6248     at next restart.
6249
6250   * The bosserver can be placed in a restricted mode in which AFS
6251     superusers are only granted limited access to the server host. The
6252     following functionality is disabled when restricted mode is in use:
6253
6254       bos exec
6255       bos getlog (except for files with no '/'s in their name)*
6256       bos create *
6257       bos delete
6258       bos install
6259       bos uninstall
6260
6261     specific exceptions are made for functionality that "bos salvage"
6262     uses:
6263
6264     A cron bnode who's name is "salvage-tmp", time is now, and command
6265     begins with "/usr/afs/bin/salvager" may be created. This bnode deletes
6266     itself when complete, so no special "delete" support is needed.  This
6267     functionality may be removed in the future if a "Salvage" RPC is
6268     implimented.
6269
6270     The file with the exact path /usr/afs/logs/SalvageLog may be fetched,
6271     since that is how bos salvage [...] -showlog is implimented.
6272
6273     Restricted mode is enabled using a new bos command (bos setrestricted)
6274     or bossever command line switch (bosserver -restricted). Restricted
6275     mode can be disabled by a) sending the bosserver process a SIGFPE
6276     (which will then allow restricted operations until the next restart or
6277     setrestricted command) or b) editing /usr/afs/local/BosConfig (or
6278     BosConfig.new), and restarting the bosserver.
6279
6280   * The bos UserList of trusted administrators can now contain cross-realm
6281     Kerberos principals.
6282
6283   * udebug now takes --server not --servers.
6284
6285   * Several error messages have been improved to include volume numbers.
6286
6287   * Several new ports have been included for UNIX platforms: Darwin
6288     (ppc_darwin_12 and ppc_darwin_13), Linux 2.4 (i386_linux24), Linux on
6289     the Powerpc (ppc_linux22 and ppc_linux24), Linux on the Sparc
6290     (sparc_linux22, sparc64_linux22 and sparc64_linux24).
6291
6292   * Incomplete FreeBSD and Alpha Linux ports are included.  The FreeBSD
6293     port has a working server and the Alpha Linux port has a partially
6294     working client.
6295
6296   * A native client for Windows 95/98/ME has been added to the
6297     distribution.  With this program, a gateway machine is no longer
6298     required for Windows 9x to access AFS files.  One drive letter will be
6299     created on your machine by default - Z:.  The Z: drive will be the
6300     root of the AFS tree, allowing you to browse all sites that have AFS
6301     servers available.  Additional drive letters can be defined for other
6302     AFS directories.  A Windows Explorer shell extension is included that
6303     allows you to right click on items within an AFS tree to bring up an
6304     "AFS" menu item and perform various operations on a file or directory.
6305     The most useful item is "Access Control Lists", which allows you to
6306     view and edit the permissions of a particular directory.  Command line
6307     tools are also available in the install directory.  These commands
6308     include klog, unlog, tokens, kpasswd, symlink, fs and pts.  The
6309     installable includes a readme file that contains more information on
6310     how to use the client program and known issues.
6311
6312   * Support for large caches in afsd.  Cachefiles are stored in
6313     subdirectories.  The default is 2048 files per subdirectory, which
6314     should work fine in most situations.  You can use the new afsd option
6315     -files_per_subdir to change this number.  Note that the first time you
6316     run afsd with this patch, your cachefiles will get moved into
6317     subdirectories.  If you subsequently run an older version of afsd, you
6318     will lose all your cached files.