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