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