1 User-Visible OpenAFS Changes
3 OpenAFS 1.6.0 (in progress)
7 * vos now properly deals with matching sites when servers are
10 * Don't stop Rx keepalives after an ackall is received, avoiding
11 spurious connection timeouts. (128848)
13 * Don't retry Rx calls on channels returning busy errors and improve
14 Rx busy call channel error handling. (128671)
16 * Properly enable Rx connection hard timeouts.
18 * Initialize rx_multi lock before use.
20 * Avoid spurious crashes when initializing in "backup" client.
22 * Revert UUID support in vos.
24 * pt_util fixed to properly create new databases.
26 * MTU discovery now properly shut down on call reset.
28 * Documentation updates.
32 * A file descriptor leak which could result in corrupted files in the
33 fileserver was fixed. An IMMEDIATE upgrade from previous 1.6 release
34 candidates as well as 1.5 release fileserver is recommended.
36 * Fix ptserver supergroups support on 64 bit platforms.
38 * Demand attach salvaging doesn't use freed volume pointers.
40 * Properly hold host lock during host enumeration in fileserver.
42 * Attempt to recovery more quickly from timed out volume release
45 * Auditing now properly byte order swaps IP addresses when printing.
47 * vos split now has improved error handling.
49 * Many changes to again support Windows fileservers.
51 * During volume removal, data removal speed improved.
53 * Improve CPU utilization during volume attaching by DAFS.
55 * In salvager check-only mode, avoid potentially fixing a vnode.
57 * Fix support for large (greater than 2gb) volume special files.
59 * Salvager will not crash if multiple or bad volume link tables are
62 * Avoid erroneous full dump by remembering which sites were out of
63 date at the start of the release.
65 * A deleted volume can now be recreated properly.
67 * Callbacks are again not broken during whole partition salvages.
69 * Positional vectored IO fixed for largefile (>2GB) capable systems.
71 * Fileserver per-client thread usage again properly enforced.
73 * Anonymous dropbox support improved and drawbacks documented.
75 * Demand attach: ensure vnodes are not reallocated while in use due to
78 * Properly support large volume numbers (larger than 2147483647).
80 * Allow salvager to be run manually again when DAFS is being
85 * afs_config will not longer set the Tray Icon State in the registry
86 if the checkbox is not present in the dialog. (128591)
88 * AFS Explorer Shell Extension now works from folder backgrounds.
89 Overlays for mount points and symlinks are present in the dll, but
90 are not registered at present by the installers.
92 * Do not use RankServerInterval registry value as the value for
93 PerformanceTuningInterval.
95 * When the data version of a mountpoint or symlink changes, the target
96 string in the cm_scache_t object must be cleared.
98 * "fs checkservers" now includes vldb servers in the output and only
99 lists multi-homed servers once. A multi-homed server that has at
100 least one up interface is no longer considered to be down.
102 * When asynchronously storing dirty data buffers to the file server
103 ensure that (a) the cm_scache_t object and the cm_buf_t object are
104 for the same File ID so that locking and signalling work properly;
105 and (b) if the FID no longer exists on the file server, do not
106 panic, just discard the buffer.
108 * When processing VNOVOL, VMOVED and VOFFLINE errors perform server
109 comparisons by UUID or address and not simply by cm_server_t
110 pointer. Otherwise, server failover may not succeed.
112 * Do not preserve status information for cm_scache_t objects when the
113 issuing server is multi-homed.
115 * Giving up all callbacks when shutting down or suspending the machine
116 is now significantly faster due to the use of an rx_multi
117 implementation. (This functionality is still off by default and
118 must be activated by a registry value.)
120 * Race conditions were possible when updating the state of the
121 cm_volume_t flags and when moving the volumes within the least
124 * Ensure that the lanahelper library does not perform a NCBRESET of
125 each lan adapter when enumerating the current network bindings.
126 Correcting this permits OpenAFS to work on Windows 7 when the
127 network adapter settings change.
129 * Fix creation of mount points and symlinks as \\AFS\xxxx
131 * Icon tray state now conditionally set. (128591)
133 * Properly create new cell mount points in freelance mode.
135 * Avoid recursive offline volume checks.
137 All UNIX client platforms
139 * Servers now marked down when GetCapabilities returns error.
141 * In-use vcache count is now properly tracked.
143 * Check for /afs existance before starting, unless -nomount is
146 * Avoid a potential panic when using /afs/.:mount syntax.
148 * Avoid a panic in memcache mode due to missing CellItems file.
150 * FUSE client support fixed for non-/afs mounts.
154 * Fix socket termination on shutdown.
156 * Support for 7.2, 7.3, 7.4 and 8.2 included.
158 * References to vcaches are no longer leaked during root or reclaim.
160 * Remove support for "Giant" lock as we no longer need to use it.
162 * Don't sleep with AFS GLOCK.
164 * Properly enable 64 bit long long support.
166 * Restore support for FreeBSD 7 (128612)
168 * Fix locking issues at shutdown.
170 * New RC script, updated packaging.
174 * Support through kernel 2.6.38.
176 * Red Hat init script allows deferring for a new binary restart.
178 * Red Hat packaging now properly supports RHEL6.
180 * Use rx_Readv in cache bypass to improve performance.
182 * Properly handle 0-length replies during cache bypass operations.
184 * Properly handle non-contiguous readpage cache bypass operations.
186 * Do proper locking when transitioning to or from cache bypass.
188 * Avoid extra runs of vcache freeing routine. (128756)
190 * Perform vcache eviction via a fast path before visiting vcaches
191 where sleep is needed.
193 * Improve RPM building tools.
195 * setpag() errors are now properly reported.
199 * Properly handle setpag errors. PAGs are not supported.
201 * Check for unloaded kernel extensions when decoding AFS panics.
203 * Disable "get tokens at login" in prefs pane if AD authentication
204 plugin is configured.
206 * aklog AuthorizationPlugin now provided.
208 * Preferences Pane behavior fixed for 1.6 series (version detection is
209 used to select default behavior).
211 * A potential kernel panic during bulkstat operations is
214 * 64-bit MacOS kernel performance is greatly improved. (128934)
218 * Bug fixes for issues introduced previously in 1.5 series.
220 * Support through OpenBSD 4.8.
224 * Switch to ioctl() syscall replacement for Solaris 11 since syscall
227 * Fix support for Solaris pre-10.
229 * Corrected Solaris 11 startup script.
231 * vcache mappings freed on shutdown to avoid panic.
233 * Properly report errors for AFS system call callers.
236 OpenAFS 1.5.78 (2010-11-04)
240 * Revisions to Rx to fix performance issues.
242 * Make fs getfid behave consistently across all platforms. (128372)
244 * Properly check IDs handed to pts when creating users or groups so
245 useful error messages can be provided. (128343)
247 * Correct byte order handling of port in afsconf_LookupServer for SRV
250 * Force a full dump when releasing to a site which was previously
251 marked "don't use", in case the previous clone was out of date.
255 * Demand salvage of attached volumes now correctly track attachment
258 * Avoid a potential crash due to failure to hold a lock when attaching
263 * Track SMB connections by SID rather than username.
265 * Error write attempts to known-readonly volumes earlier.
267 * Validate directory buffers to avoid potential crashes.
269 * Handle VIO errors from bulkstatus.
271 * Make PMTU discovery configurable and register error handlers for it.
273 All UNIX client platforms
275 * Use larger I/O sizes in memcache to improve performance.
277 * Avoid potential alignment issues doing I/O for pioctl calls.
281 * Avoid panicing if the listener process is not findable.
283 * Avoid deadlock issues while performing lookups.
287 * Handle stale file handle errors for some cache partition types.
289 * Avoid blocking with xvcache lock when attempting to free in-use
292 * Build fixes for older kernels.
294 * Properly configure LWP to use ucontext() on platforms where it
297 * Eliminate spurious errors from AFS system call returns. (126230)
301 * Attempt to honor configured Kerberos defaults in Preferences Pane.
304 OpenAFS 1.5.77 (2010-09-08)
308 * Rx path MTU detection will terminate detection in cases where the
309 minimum required packet size cannot be transferred.
311 * vos dryrun mode now shows effects for syncvldb single volume case.
313 * vos dryrun mode now shows "status after" for syncvldb and syncserv.
317 * RXAFS_GetStatistics64 now returns statistics properly.
321 * Attempt to properly identify the local system SMB connection for
324 * Remap timeout and offline errors to proper NT RPC errors.
326 * Properly fail over to other replicas on bulkstat IO errors.
328 * Properly error delete-mode createfile if a file is set readonly.
330 * Validate directory entry buffers to avoid crashing the service.
332 * Log file modes properly.
334 * Log cell name when logging server information.
336 All UNIX client platforms
338 * cacheout program for discarding callbacks is now built.
340 * bulkstatus kernel locking is corrected to avoid a potential panic.
344 * userspace support update
348 * Updated vnode locking for children returned via lookup().
350 * Avoid file open undercount with needed calls to
351 FakeOpen/FakeClose().
353 * Use vnode_pager_setsize to properly track file size during kernel
356 * Update system call installation.
358 * Fix shutdown of Rx kernel listener to avoid potential dereference
361 * Avoid closing vnodes during vnode recycle.
363 * Fix bogus call to FlushVS for vnode reclaims.
367 * Packaging updated for current configure options and built files.
369 * Cache bypass now holds reference on pages during readpage.
371 * s390x setgroups32 patching update.
375 * DNS resolver is reinitialized on IP address change. (126440)
378 OpenAFS 1.5.76 (2010-08-16)
382 * Updates to build-time configuration.
384 * Fix XDR support in Rx to match header definition.
386 * vos status now shows transaction creation, not action creation.
388 * Rx avoids reporting loopback adapters when listing interfaces.
392 * Demand-Attach Fileserver always built and installed (dafileserver,
393 davolserver, dasalvager).
395 * Return VNOVOL from fileserver when a volume is deleted.
397 * Ignore duplicate tags during volume restore operation.
399 * Update inode array after salvage repairs volume.
401 * Zero a corrupted header in memory during salvage to avoid further
404 * Fix NAMEI backend to allow low-numbered volumes to work properly.
406 * ptserver does not include cell name as part of length check for
409 * Updated error messages for unblessed volumes.
411 * vlserver avoids buffer overflow with regex pattern
413 * Attach-time failures now note failures as the rest of the fileserver
416 * Server argument logging will no longer overflow stack.
418 * Provide fast-restart-like unsafe-nosalvage option for DAFS.
420 * Deal with host hash collisions in the fileserver.
424 * Avoid crashing when interpreting a drive letter as potentially
425 matching a cell name.
427 * Properly handle volume package errors.
429 * Allow page recycling from known-readonly content without ensuring
432 * 32 bit tools installer should not override client configuration.
434 * Ensure root scache item has a valid callback when use is attempted.
436 * Freelance directory changes now properly invalidate and replace the
439 All UNIX client platforms
441 * Support disconnected reconnecting with specified UID for PAGless
444 * Proper disconnected vnode reference tracking.
446 * Update server site blacklisting to not return success if nothing was
449 * Avoid a panic during vcache contention due to CVInit vcache
454 * Update for network stack in 8.1/9.0.
464 * Disable PMTU error packet handling.
468 * Debian packaging updated.
470 * freezer interface updates.
474 * Hold references to disconnected mode written vnodes properly.
478 * Handle NFS translator module references for amd64.
480 * INODE fileserver backend support now exists for amd64.
483 OpenAFS 1.5.75 (2010-07-07)
487 * Prevent rx_rpc_stats global lock from being a bottleneck.
489 * Path MTU discovery is now provided to allow traffic to pass networks
490 with sub-1500 byte MTUs and poor fragment handling.
492 * Further reduce Rx NAT ping transmission when enabled.
494 * Update Kerberos 5-based token handling in rxkad from upstream
497 * Update version numbers emitted during build to reflect what is
498 actually being built.
500 * Add "-human" switch for human-readable units in fs diskfree and
503 * vos provides reasons for locked volumes when known.
505 * Do not count retransmission and ping acks as non-idle for Rx
508 * Rx: provide service-specific data getter and setter routines.
510 * Update build-time Kerberos detection.
512 * Updated userspace AFS client.
514 * Beginning of a modernized test suite.
516 * Additional documentation.
518 * Updated documentation, notably the Administrators Guide.
520 * Substantial code cleanup.
524 * Update handling of vnode allocation failures.
526 * DAFS: allow salvaging volumes not known to the fileserver, to allow
527 cleanup of data not attached to a current volume.
529 * Properly handle volumes slated for destruction.
531 * Handle volumes with many files properly.
533 * Force core file generation in bosserver by overriding default
534 resource limits when possible.
536 * Update vlclient and vldb_check.
538 * Avoid potentially corrupting a volume on creation if files are left
539 from previous failed cleanup.
541 * Note volume changed during salvage as needed.
543 * DAFS: do not assume invalid addresses are in fileserver address hash
546 * Avoid tying up fileserver threads with volumes that are being taken
549 * Do not set inUse on volumes for non-DAFS other than in fileserver.
551 * Break origin's callback on target of rename operation.
553 * Avoid unneeded parent directory link updates during some rename
556 * Do not open /dev/console for writing in the fileserver.
558 * DAFS: avoid spurious restarts when binary restarts are configured.
560 * Avoid spurious and unneeded calls to sync(), which can slow down the
565 * Revised SMB QuerySecurityInfo to address issues caused by MS10-020
566 (http://support.microsoft.com/kb/980232)
568 * Prevent use of the AFSCache file contents if mapped to a new
571 * Make fs newcell include behavior compatible with the non-Windows
574 * Provide a registry option (FreelanceImportCellServDB) to pre-create
575 mount points in the AFS root for all cells in CellServDB.
577 * Fix a memory leak in the cm_FreeServerList() routine.
579 * Reduce privilege when reading registry CellServDB.
581 * Add support for RPC Pipe Service NetWkstaGetInfo levels needed for
584 * Prevent overflow when computing quota percentage in Explorer Shell.
587 * Generate meaningful errors for ACL operations on freelance AFS root.
589 * Fix error handling on InlineBulkStatus RPCs.
591 * Show configuration pages for all types of MSI installations.
593 * Improve freemount AFS root directory handling and operations.
595 * Properly validate GetVolumeStatus pioctl responses.
597 * Commit file length changes and dirty buffers when flushing a file.
599 All UNIX client platforms
601 * Update version of files for disk cache.
603 * Do not call afs_FlushVCBs with xvcache lock held, to improve
606 * Add mariner log messages for creating and removing files.
608 * Don't hold xvcache lock while creating symlinks, to improve
611 * Provide -dynroot-sparse mode to not show all cells in CellServDB in
614 * Avoid a potential crash in aklog in linked cell handling.
616 * Log MTU-caused packet retransmission.
618 * Prevent crashes caused be fs checkservers while cache is being set
621 * fs getserverprefs now has a buffer large enough for the default
624 * Report server address when logging warnings.
626 * Avoid panic in GetCapabilities when cell is not known.
628 * Lock process name and id for advisory lock warnings when possible.
630 * Handle need for allocating additional Rx packets.
632 * Properly handle errors from InlineBulkStatus operations.
634 * Fix errors returned from fcntl() on readonly files locked for write.
636 * Flush pending changes to the server on LOCK_EX unlock.
638 * Reflect length changes as a result of callbacks even when file is
641 * Avoid hanging due to error exit when attempting to store a large
642 file to a non-largefile fileserver.
644 * Recover from afs_GetVolSlot errors.
648 * Bugfixes for kernel VFS and network routines.
652 * Provide makesname().
656 * Avoid syscall probes when keyrings are present, by default. (125215)
658 * Remove "Big Kernel Lock" from VFS operations.
660 * Use filehandles for all Linux 2.6 versions to avoid need for matched
663 * Updated RPM packaging.
665 * Fix dkms configuration provided with RPMs.
667 * Hold reference on pages during background I/O for cache bypass.
669 * Fix cache bypass handling of non-largefile fileservers.
671 * Protect truncate_inode_pages mappings with mutex or semaphore as
674 * Fix pagevec use in cache bypass. (127505)
680 * Improve launchd configuration.
682 * Avoid hanging on recursive cache file lock acquisition when user
683 notification is enabled.
685 * Fix and re-enable bulkstat mode.
693 * Precluding unmount while AFS is busy.
695 * Avoid deadlocking when releasing the VFS object.
697 * Stop network interface poller in kernel on AFS shutdown.
699 * Avoid issues with lookups on empty directory names. (127356)
702 OpenAFS 1.5.74 (2010-04-22)
706 * Add "vos setaddrs" command.
708 * Rx library lock contention avoidance between rx_NewCall and
711 * Rx library races due to inconsistent use of rx_connection
712 conn_data_lock to protect the flags field.
714 * Rx library inconsistent use of RX_CALL_TQ_WAIT which could result in
717 * Rx library must signal transmit queue waiters when flushing.
719 * afsmonitor shows busy counts now.
721 * afsmonitor displays xstat callback statistics.
723 * Provide expandgroups for pts mem on a supergroups server.
725 * Provide supergroup option to liste nested groups during pts mem.
729 * Avoid volume lock contention during DAFS startup.
733 * Avoid a race when updating cell vldb server lists that can result in
736 * Avoid a deadlock when managing CM_SCACHESYNC_STOREDATA state
737 operations for directory objects.
739 * Add new Windows Application Event log messages for VBUSY,
740 VRESTARTING, ALL_BUSY, ALL_OFFLINE, and ALL_DOWN.
742 * Reduce lock contention by waiting for cm_buf_t I/O operations.
744 * Split the cm_buf_t flags field to separate the flags that are
745 protected by the cm_buf_t mutex from those protected by the
748 * In cm_UpdateVolumeLocation, avoid searching for a ".readonly" volume
749 on a numeric volume name.
751 * File buffer allocations whose offsets are beyond server EOF should
752 be locally allocated and zero filled. The file server should not be
753 issued a FetchData rpc which is guaranteed to fail.
755 * Enable integrated logon to work with Windows 7/2008 when user logons
756 are performed with a non-Domain Kerberos principal.
758 * Add Protection Error messages to aklog output.
760 All UNIX client platforms
762 * Provide a FUSE-interfacing userspace afs client.
764 * Updates to libuafs userspace cache manager.
766 * Probe servers using GetCapabilities instead of GetTime, thus
767 requiring fewer RPCs.
769 * Fix DNS SRV record handling for cell lookup.
773 * Fix sleep/wakeup routines.
775 * Update for 8.0 release.
779 * Handle high memory addresses correctly.
783 * Make 32 bit AFS syscalls work again.
785 * Work around finder "Duplicate" failure (caused by setting modes on
788 * Disable bulkstat again (will be re-enabled at or before .75).
790 * Provide symlink type hints during readdir.
793 OpenAFS 1.5.73 (2010-03-24)
797 * NAT keepalive support at Rx level.
799 * Corrected SRV record support for cell name canonicalization.
803 * Fix volume callback notification to not notify unaffected clients.
806 * Allow root directory recreation by salvager. (94658)
808 * Numerous DAFS fixes.
810 * Improvements to callback table overflow handling. (126451)
812 * bosserver now shuts down cleanly on SIGTERM.
816 * Prevent the Explorer Shell extension from crashing if symlink
817 creation failed. (126406)
819 * A Rx level NAT ping has been implemented. A registry value enables.
821 * Adds krb5 error message translation to aklog, afscreds,
822 afslogon.dll, the network identity manager afs provider and
825 * Default mode bit settings for file and directory creation are now
826 provided, and can be configured.
828 * An SMB request trace facility is provided and can be enabled for
831 All UNIX client platforms
833 * Rx idle deadtime does not stop file writes.
835 * Disconnected AFS no longer has a race condition during remove ops.
837 * Fakestat avoids a condition which could cause it to block on network
840 * Several fixes to handle interruptions in vos operations. (33360,
843 * Allow more sysnames in a sysname list.
845 * Attempt to enforce timeouts on AFSDB lookups.
849 * Clean up properly on mount failure.
851 * Add entry to /etc/vfs to allow umount to work.
855 * Several issues to deal with older kernels.
857 * Avoid leaking the global lock in the /proc cellservdb code.
859 * Keyring destruction now cleans up all tokens.
861 * Keyring quotas are not enforced against root.
865 * Some FSEvents hinting for authentication events now done. (23781)
867 * Update uninstaller. (125634)
869 * Rewrite afssettings and fstab code to avoid licensing issue with
872 * Growl client for user monitoring of AFS events included.
874 * Properly support insert-only dropboxes.
876 * Add bulkstat support.
878 * Include support for moving in Finder across mount points.
880 * Preferences Pane includes support for Kerberos 5 ticket renewal.
883 OpenAFS 1.5.72 (2010-02-15)
887 * Provide internationalization support in com_err.
889 * Fix array length checking to avoid crashes when checking for a
890 volume type based on name in vos.
894 * Provide backward compatible "-f" flag to salvager for force mode.
898 * Restore use of DNS AFSDB and SRV records by kaserver clients.
900 All UNIX client platforms
902 * Fix client cache file truncation to not lose chunks when truncating
905 * Ensure a cache writeback hook is installed in the client (bug from
908 * Avoid spurious free memory warnings during clean shutdown.
910 * Fakestat mode avoids AFSDB lookups.
912 * "fs storebehind" now correctly reports errors on readonly volumes.
914 * Additional documentation for "fs getcacheparms"
916 * Forced new uuid generation with "fs uuid -generate" now works
917 enforced permission correctly.
921 * Add optimized Rx event handler in kernel.
923 * Installer now allows installing an older version.
925 * Panic decoder can now deal with MacOS 10.5 again.
927 * MacOS ._ files are now correctly not looked up as cellnames.
931 * To deal with SELinux file labeling, try cache accesses with current
932 credentials in event of failure.
934 * Rx XDR encoding bug on i386 Linux is fixed (bug introduced in
939 * Code compilation fixes.
943 * Update for OpenBSD 4.6.
946 OpenAFS 1.5.69 (2010-01-19)
950 * Configuration of BOSserver no longer defaults to weekly restarts
953 * Provide BOS restricted mode by default.
955 * Add support for "vos endtrans" command.
957 * Default to providing full output from vos listvol.
959 * Correct additional-address tracking in the fileserver.
961 * Improve Rx performance by not unnecessarily dropping and reacquiring
962 call locks in read and write processes.
964 * Avoid crashes when monitoring volserver transactions across
965 potential transaction garbage collection.
967 * Numerous warning fixes.
971 * Avoid saving fileserver state in demand attach fileserver when
974 * Demand attach fileserver allows other callers to schedule salvages.
976 * Demand attach "bos salvage" now works correctly with restricted
981 * Numerous changes to the client-internal btree directory handling to
984 * fs examine reports owner and group ids as signed values (PTS groups
987 * Preclude corruption due to races writing to smb buffers.
989 * Allow MTU settings in registry to be used.
991 * Apply MTU to both send and receive sizes.
993 All UNIX client platforms
995 * Avoid double-freeing Rx call structure if reading a response from
996 the file server results in a short read.
998 * Handle negative lengths in FetchStatus results correctly.
1000 * Properly clean up allocated memory at shutdown.
1002 * Default to AFSDB compiled into the cache manager.
1004 * Avoid inadvertant disclosure of stat() information to clients not so
1007 * Correct a bug with AFSDB lookups introduced with SRV record support.
1011 * Install kernel panic processing tool in /Library/OpenAFS/Tools.
1013 * Include debugging symbols for kernel extension in additional package.
1015 * Support "Application Firewall" users.
1017 * Avoid ._cellname AFSDB lookups.
1019 * Compile preferences pane as a universal binary.
1023 * Use splice to speed up storing files.
1025 * When using memcache, avoid duplicating work in readpages.
1027 * Use dget_parent to safely find an inode's parent.
1029 * Disable access time updates in our superblock.
1031 * Avoid crashing doing writeback if no credentials were stashed at
1034 * Simplify keyring support.
1036 * Properly clean up vcache in event of failed mount.
1040 * Update for current FreeBSD 8.
1044 * Abstractly manipulate groups as now required.
1046 * Abstractly access time instead of using lbolt directly.
1049 OpenAFS 1.5.68 (2009-12-08)
1053 * aklog now attempts to convert non-AFS errors to human-readable
1056 * Make stack not executable when compiling assembler source with GCC.
1058 * Numerous source warning cleanups and code reorganization.
1060 All server platforms
1062 * Compute midnight for volume statistics calculation from local time.
1064 * Salvager now orphans duplicate special inodes when running to allow
1065 recovery in event of a problem, instead of simply ignoring the
1068 * Support to ensure a server panic attempt leaves a core and thus
1069 restarts in a timely manner, rather than potentially hanging. Use
1070 panic to attempt cleanup before leaving a core when possible.
1072 * Volume sync data reported during bulkstatus is now set correctly.
1074 * Provide better tuning for fileserver file descriptor caching.
1076 * Allow more than 128 threads in fileserver by modifying host
1077 structure in-use tracking.
1079 * Avoid crashes getting volume server status during transaction
1082 * Improved logging of offline volume conditions.
1084 * Correct volume statistics when cloning a volume.
1086 * Avoid referencing host structures in the fileserver which are marked
1089 * Demand attach fileserver corrections to avoid coring during an
1092 * host array bounds checking corrections to avoid buffer overflow.
1094 * Handle special inodes correctly when promoting an inode fileserver
1095 readonly volume to read-write.
1099 * Set the DOS Readonly attribute on a file/directory whenever the unix
1100 mode combined with the mask 0200 is true. Previously there was a
1101 discrepency between the mask used for testing for readonly behavior
1102 and that used for setting the attribute.
1104 * Disable AFSVolSync based .readonly "whole-volume callback" support
1105 because the all file servers prior to 1.5.67 (and perhaps 1.4.12) do
1106 not properly assign a value to the AFSVolSync structure in bulk
1107 status RPC responses.
1109 * Improve the error output from aklog to output the value from krb5
1110 error_message() if the afs_com_err output indicates an unknown
1113 * Convert VBUSY and VRESTARTING to CM_ERROR_ALLBUSY and do not permit
1114 them to be exposed to the smb redirector.
1116 * Convert STATUS_TIMEOUT responses to STATUS_IO_TIMEOUT to avoid
1117 confusion within the smb redirector.
1119 * Fix the byte order assigned to port numbers associated with AFSDB
1120 record lookups. They must be network byte order not host byte
1123 * Add dynamic server ranking based on RPC round trip time
1126 All UNIX client platforms
1128 * Additional shutdown-time memory leaks removed.
1130 * Improved logging of resource contention.
1132 * Provide dumping for Rx debug packet tracking support in source.
1134 * Update afscp test client to build, and provide an unlock client.
1136 * Client buffers for directory parsing can now be allocated beyond the
1137 fixed set formerly provided.
1139 * Work around race condition when manipulating read-only volume
1142 * Bugfixes to get PAG value pioctl.
1144 * Bugfixes to SRV record support.
1148 * Path MTU tracking code cleanup.
1150 * Avoid an oops due to racing with vcache recycling thread.
1152 * Changes to keyring PAG handling: for sufficiently new kernels, use
1153 only keyring-based PAGs, and disable group PAGs entirely.
1155 * Updates to the kernel page cache interface: writing pages will now
1156 not spuriously leak page locks, and will avoid requiring duplicate
1159 * Credential references are now tracked using native atomic counters.
1161 * Kernel mutex/semaphore lock ordering fix to avoid deadlocks.
1163 * Manipulate disk cache with credentials used to initialize it, to
1164 avoid security issues.
1168 * Fix fstrace message catalog location.
1170 * Fix kernel fstrace logging.
1173 OpenAFS 1.5.66 (2009-10-25)
1177 * Avoid calling exit() in library code.
1179 * Add rx window size and peer timeout tuning APIs.
1181 * Correct rx peer timeout handling to disallow 0ms timeouts.
1183 * Correct calculation of rx RTT by disregarding retransmitted packets.
1185 * vos manpages updated to reflect changes in recent versions.
1187 * GNU-style long options (e.g. --cell) are now supported in all
1190 * fs listacl can now print a command to recreate the current ACL.
1192 All server platforms
1194 * Fix a race on transaction objects in the volserver which can cause a
1197 * Avoid destroying and setting to NULL the callback connection when it
1198 could still be being used.
1200 * Correct unlink handling in salvager.
1202 * Improve error messages due to I/O errors in the volserver.
1204 * Correct an issue which caused converted RO to RW volumes on namei
1205 fileservers to not come online immediately.
1209 * Official support for Windows 7 and Server 2008 R2.
1211 * Prevent a file server bug (FetchData returning an invalid length
1212 instead of zero) from causing an "unexpected network error" when
1215 * Promote DNS SRV records as superior to DNS AFSDB records. Support
1216 arbitrary port numbers for vldb servers.
1218 * Add AFSVolSync based .readonly "whole-volume callback" support.
1219 With this functionality, multiple objects from a .readonly volume
1220 can have their status validated by issuing a single
1221 RXAFS_FetchStatus RPC.
1223 * Remove drive mapping functionality and service start/stop from
1226 * Remove drive mapping functionality from afs_config.exe.
1228 * Use {HKLM,HKCU}\SOFTWARE\OpenAFS\Client DWORD "ShowMountTab" to
1229 restore access to drive mapping functionality in afscreds.exe and
1232 * Adjust SMB error return codes to avoid returning STATUS_TIMEOUT
1233 which results in the SMB redirector disconnecting.
1235 * Network Identity Manager OpenAFS Provider now provides its own "AFS
1236 lock" notification icon to report the status of "have tokens, have
1237 no tokens, service not started, service started but inaccessible".
1238 Hovering over the icon lists the cells for which tokens exist (if
1239 any) and the OpenAFS version number. Double-clicking executes the
1240 Network Identity Manager default action.
1242 * Prevent pioctl calls from retrying indefinitely when a sharing
1243 violation error occurs.
1245 All UNIX client platforms
1247 * Correct a condition which could discard the error from initializing
1250 * Avoid using invalid references to afs_Conn connection structures,
1251 and thus potentially producing invalid data when a retry is needed.
1253 * SRV records are now supported for discovering AFS servers.
1257 * Correct writepage behavior.
1259 * Fix error code handling in the writepage code.
1261 * Avoid leaking page locks, which could potentially hang a machine.
1265 * Preferences Pane improvements.
1269 * Avoiding attempting to handle critical signals in servers, so that
1270 core file handling works correctly.
1273 OpenAFS 1.5.65 (2009-10-06)
1277 * Code compilation warning fixes, to enable better finding and
1280 * Provide configure-time switch to enable code warning compilation.
1282 All server platforms
1284 * Demand-attach fileserver now makes volume LRU list operations
1285 exclusive operations to avoid races during adding to the list.
1287 * Fileservers now avoid potential "negative length" fetches.
1289 * A leak in host tracking objects in the fileserver has been fixed.
1291 * Salvager now unlinks all files by full path, to deal with the change
1292 to not chdir for core file tracking.
1294 * Salvager avoids asserting if the volume header is unreadable.
1296 * Demand-attach fileserver puts back volume references from fssync
1301 * Improved service response to suspend and shutdown event
1304 * Avoid a bug in the file server that can result in an invalid length
1305 being returned as part of a fetch data response if the client
1306 attempts to read beyond the length of the file.
1308 * Do not publish a default stream object for directories and mount
1309 point objects. This was impacting the ability of some Windows XP
1310 systems to save roaming profiles.
1312 All UNIX client platforms
1314 * A bug which could cause erroneous handling of lengths on data reads
1317 * A bug where erroneous length returns from the fileserver could
1318 result in a false error has been fixed.
1322 * Background page copies are now supported for enhanced disk cache
1325 * Blocking readahead is supported in readpages() to reduce overhead.
1327 * Use readpage() instead of read() to access cache data to avail disk
1328 cache users of the kernel backing cache for improved performance.
1330 * Minimize credential handling for improved performance.
1334 * Preferences Pane cleanup.
1338 * Provide a fs_pathconf method with sensible defaults.
1340 * Provide a _PC_FILESIZEBITS method to fix some NFS translator
1344 OpenAFS 1.5.64 (2009-09-22)
1346 All server platforms
1348 * The demand attach fileserver now puts back volume references gotten
1349 via the fssync interface.
1351 * The demand attach fileserver had a structure reference error, which
1352 has been correected.
1356 * Restores Windows 2000 compatibility.
1358 * Fixes a data consistency error between the output of NetWkstaGetInfo
1359 and NetServerGetInfo RPCs, specify the Lan workstation group name
1360 "AFS", and report server name as "AFS" instead of "\\AFS" when the
1361 caller asks for "\\AFS".
1363 * Enables executables to be run from \\AFS on Windows 7. Returns
1364 "Name not found" instead of "File not found" when a directory or
1365 file name cannot be found. This avoids loader errors when system
1366 dlls cannot be located in the executable directory.
1368 * Prevents cache manager from marking the file server "down" when the
1369 data returned in response to either RXAFS_FetchData64 or
1370 RXAFS_StoreData64 is invalid.
1372 * Adds pioctl data validation to the AFS Explorer Shell extension.
1374 All UNIX client platforms
1376 * A bug which could cause a kernel panic in 1.5.63 has been corrected.
1377 This would manifest as a GetDCache panic or oops.
1381 * aklog -setpag works again with recent kernels when keyring is in
1386 * When Fast User Switch is in use, AFS login is now handled correctly
1387 by the integration tool included with the preferences pane.
1389 * Several packaging bugs have been corrected.
1392 OpenAFS 1.5.63 (2009-09-11)
1396 * The restorevol command is now documented and installed as a user
1399 * The uss command now properly translates vldb entries to its expected
1400 format when handling them in all cases.
1402 * Documentation now refers to Kerberos instead of kaserver.
1404 All server platforms
1406 * bosserver now handles BosConfig.new when restarting, allowing
1407 configuration to be replaced at restart time rather than with bos
1408 delete and bos create. Documentation is updated to reflect this.
1410 * The demand attach fileservice not longer potentially hangs trying to
1411 terminate demand-salvages which have already exited.
1413 * The demand attach fileservice has been modified to avoid spurious
1414 'SYNC_putRes: write failed' warnings when some protocol messages
1415 cannot be acknowledged due to the sender terminating the connection.
1417 * In the event of failure to contact the vlserver or ptserver, the
1418 fileserver will not exit and trigger a forced salvage. It will
1419 continue to try in the background to contact the needed services.
1421 * The salvager can now repair certain cases of a damamged vnode index.
1423 * The accessDate metadata for a volume is now updated correctly.
1427 * CRITICAL: Some applications for example those based on Cygwin were
1428 unable to access data stored in the AFS name space. Explorer Shell
1429 also experienced inconsistent behavior. This is fixed.
1431 * CRITICAL: Multiple AFS pioctl requests issued nearly simultaneously
1432 by applications could result in pioctl responses being received by
1433 the wrong requester. This in turn could result in application
1434 crashes. symlink.exe, fs.exe, afslogon.dll, afscreds.exe, and the
1435 netidmgr afscred.dll plugin were all affected.
1437 * Some XP machines running 1.5.62 had trouble saving roaming profile
1438 data. This is fixed.
1440 * Integrated Logon (afslogon.dll) did not function with domain
1441 specific configurations.
1443 * Ensure that access denied and over quota errors experienced while
1444 storing data to the file server do not result in on-going retry
1447 All UNIX client platforms
1449 * Except on Solaris and AIX, the compiler may now be overriden at
1450 configure time by setting the CC environment variable.
1452 * afsd now properly deals with large cache partitions.
1456 * Build shared libafsauthent and libafsrpc.
1460 * Kernel module DKMS support now installs an unstripped module to
1461 allow debugging information to be collected.
1465 * Preferences pane properly updates token information.
1469 * klog will now properly handle passwords of 8 or fewer characters
1470 with an AFS string to key on hosts able to run 64 bit binaries.
1472 * A panic at AFS shutdown due to "NO PCB" on a udp_lock has been
1475 * The panic decoder script included in the source now properly handles
1476 32 and 64 bit panics.
1480 * Avoid defining AFS_KERBEROS_ENV globally as it creates a circular
1483 * Build shared libafsauthent and libafsrpc.
1487 * Build shared libafsauthent and libafsrpc.
1490 OpenAFS 1.5.62 (2009-08-28)
1494 * Numerous invisible changes to improve code maintainability,
1495 portability and enhanceability.
1499 * CRITICAL: Fixes two errors that can result in data loss when storing
1500 data to the file server.
1501 1. Failure to Store Portions of Unaligned Writes
1502 2. Failure to Store Data to File Servers Lacking Large File Support
1503 Read the announcement for more details:
1504 http://www.openafs.org/pipermail/openafs-announce/2009/000305.html
1506 * CRITICAL: The cache manager daemon thread could terminate when the
1507 machine enters suspend mode. This daemon thread performs the
1508 background check of down servers, offline volumes, callback
1511 * CRITICAL: Integrated Logon (afslogon.dll) was terminating
1512 unexpectedly. Error checking has been improved and NULL pointer
1513 dereferences after Lsa API calls fail have been eliminated.
1515 * For the first time, the OpenAFS SMB Server supports the DCE RPC
1516 services SRVSVC and WKSSVC. Browsing \\AFS with the Explorer Shell
1517 or NET VIEW will now be faster and provide additional functionality.
1518 No longer will cell names longer than 12 characters be truncated.
1520 * Improvements to DFS Referral request processing have been
1523 * Unnecessary DNS lookups of share names are avoided improving
1526 All UNIX client platforms
1528 * Non-Kerberos PAM modules work correctly again.
1532 * MacOS 10.6 (Snowleopard) is now supported, both 32 and 64 bit mode.
1534 * Updates to the AFSCommander preferences pane.
1536 * Installer now permits cell names with dashes.
1539 OpenAFS 1.5.61 (2009-08-06)
1543 * Correct another race condition in the Rx library that could result
1544 in an unexpected panic while freeing the Rx call iovq.
1546 * rx packet resend and data packets sent counts were incorrect.
1548 * fs setquota, fs setcachesize, vos setfields, and vos create now
1549 accept human readable orders of magnitude. (K, M, G)
1551 * fs listquota fixed to permit large quota sizes to be displayed.
1553 * Correct documentation of bosserver permissions requirements.
1555 * Modify vlserver to avoid potentially corrupting the database through
1558 * Generalized support for fast Rx timeout due to network
1561 All server platforms
1563 * Allow audit logs to be sent via sys5 IPC message queues instead of
1568 * If a file server becomes inaccessible while the cache manager has
1569 dirty buffers to write, the afsd_service buf_IncrSync thread can
1570 attempt to use 100% of the cpu.
1572 * Fix "fs newcell" which was broken in 1.5.60.
1574 * Do not attempt to synchronize dirty buffers if the associated volume
1575 is known to be unavailable.
1577 * Modify behavior of a Freelance mountpoint target that does not
1578 specify a cell. Instead of assuming the target volume is in the
1579 Freelance.Local cell, use the workstation "Cell" specified in the
1580 registry. A mountpoint target of "#root.cell." will now mean the
1581 root.cell volume in the workstation cell for the current session.
1582 If the workstation cell changes from "athena.mit.edu" to
1583 "andrew.cmu.edu", the referenced volume will also change without
1584 requiring that the mount point targets be altered.
1586 * Add cm_FindServerByUuid(). Re-implement RXAFS_InitCallBackState3()
1587 to permit the server Uuid to be used to lookup the server object and
1588 from that determine the cell. This permits callbacks that are
1589 received from alternate addresses to be processed with a known
1590 server object. Previously a request from an unknown server would
1591 clear all callbacks from all cells.
1593 * Fix a bug that prevented optimal performance when using a non-zero
1594 value for 'daemonCheckVolCBInterval'. As a reminder, when
1595 "daemonCheckVolCBInterval" is set to a non-zero value, all .readonly
1596 volume callbacks are automatically renewed 90 minutes before their
1599 * Fix automatic ranking of vldb servers whose values are obtained from
1600 the CellServDB file.
1602 * Add failover for RX CALL TIMEOUT errors when the volume is readonly
1603 or the call is to a vldb server.
1605 * Add registry based cell search functionality to NetIdMgr,
1606 afs_config.exe, and klog.exe.
1608 * afsconf_GetCellInfo() has been modified to perform gethostbyname()
1609 lookups on the host names in the CellServDB instead of using the
1610 specified IP addresses. This provides aklog, pts, vos, etc. the
1611 same CellServDB behavior that the Windows Cache Manager uses.
1613 * When updating the stat cache entry callback of a .readonly object
1614 from the volume group object, update the file server reference to
1615 ensure it matches the most update to date callback.
1617 * Add proper support for processing callbacks from multi-homed file
1618 servers. Instead of comparing servers by cm_server_t pointer,
1619 compare them by UUID when the UUID is known.
1621 * During a shutdown short circuit the offline volume check daemon
1624 * Return the error code of RXAFS_FetchData / RXAFS_StoreData in
1625 preference to an error code reported by rx_EndCall.
1627 * Add "PerFileAccessCheck" registry value to permit testing against
1628 experimental file servers that include per-file acl support. This
1629 value is intentionally undocumented. It is not to be used by
1630 production environment deployments.
1632 * Fix a bug introduced in 1.5.60 that prevents the afs netidmgr
1633 provider from obtaining tokens when referrals are in play.
1635 * Add "fs chown" and "fs chgrp" commands to permit the owner and group
1636 of objects stored in AFS to be set from Windows.
1638 * Avoid performing background daemon operations when the machine is
1639 going into suspend mode.
1641 * Perform offline volume checks in most recently used order.
1643 * Prevent crash when a data version for a cache object goes backwards.
1645 * Multi-thread safe library versions are now being generated and used.
1646 mtafsubik.lib, mtafsutil.lib, mtafsvldb.lib, mtafsvol.lib.
1648 * Microsoft SMB Redirector (mrxsmb.sys) support for
1649 ExtendedSessTimeout values are now available on XP through Windows
1650 7. Add functionality to autodetect if such support is present on
1651 the machine. If so, configure it if necessary and dynamically
1652 adjust the AFS Rx timeout values accordingly.
1654 All UNIX client platforms
1656 * Fix out-of-tree source builds.
1660 * GUI installer now asks for local cell information.
1662 * AFS Commander preferences pane is now installed by default.
1666 * Avoid kernel panics due to null pointer dereferences in the network
1667 interface poller kernel thread.
1670 OpenAFS 1.5.60 (2009-05-31)
1674 * Retry volserver transaction creation on failure.
1676 * Allow building HTML and PDF documentation from included XML copies
1677 of User Guide, Admin Guide and Quick Start Guide for Unix.
1679 * Documentation updates and additional documentation.
1681 * Add -encrypt support to pts client.
1683 * Convert MR-AFS fs commands to OSD commands.
1685 All server platforms
1687 * Updated background sync process in fileserver to avoid a race which
1688 could result in a volume being taken offline.
1692 * On April 9th Microsoft released a Hot Fix for Windows Server 2003
1693 SP2 that corrects a deadlock in the smb redirector and also adds new
1694 functionality that permits the AFS SMB server to be given a longer
1695 timeout than is normally the case. New functionality has been added
1696 to configure these additional LanmanWorkstation\Parameter values.
1697 (This functionality has been backported to XP SP3 and is scheduled
1698 to be released on June 5th.)
1700 * Fix RT#124787, a race condition between "fs flush <dir>", "fs
1701 flushvolume", or "fs flushall" and on-going directory operations
1702 that can result in afsd_service.exe crashing.
1704 * Release Notes, User and Administrator guides are now shipped as
1705 indexed Windows HtmlHelp Files. (.chm). Shortcuts are provided from
1708 * A method of specifying Client CellServDB information within the
1709 registry has been added that can be used to either override the
1710 CellServDB file or force the use of DNS lookups for a given cell.
1711 See the release notes for details.
1713 * The pioctl interface now properly handles drive letter substitution
1714 to UNC paths. (SUBST <d:> <\\afs\cell\path>)
1716 * The BackConnectionHostNames registry value configuration was broken
1717 when dynamic re-establishment of Netbios Name registrations was
1718 added. This release restores the functionality.
1720 * All hidden vos.exe commands are now revealed.
1722 * Attempts to store the same dirty file chunk from multiple threads
1725 * The IsPathInAfs test in Explorer Shell Extension and fs.exe now
1726 permits broken symlinks to be treated as being in AFS.
1728 * vos.exe commands that output 64-bit integer values once again do so.
1729 This was broken in 1.5.59.
1731 * Cygwin Import Libraries are provided in the SDK for all OpenAFS
1732 DLLs. This permits building cygwin applications against OpenAFS
1735 * NSIS installer does a much better job of cleaning up files left over
1736 from previous installs.
1738 * libafsconf.dll moved from Client\Program to Common directory as is
1739 is now used by all modules for CellServDB processing.
1741 All UNIX client platforms
1743 * Write back changes on last store for memcache to avoid discarding
1746 * Abstract disk cache support to allow for path, fh, inode based
1747 caches with no need for messy ifdef structures each time a new type
1752 * Support as a userland port.
1756 * Corrected structure definition for userspace cache manager to allow
1761 * Corrected client locking support.
1763 * Updated patch to stop deadlocking in the kernel during mmap.
1765 * Avoid oops when setting up groups for PAGs to match keyrings.
1767 * Use Linux fh-based cache in cases where possible by default.
1771 * Corrected structure definition for userspace cache manager to allow
1776 * Support for OpenBSD 4.5.
1780 * Corrected support for server-side vos split interface.
1783 OpenAFS 1.5.59 (2009-04-06)
1787 * Increased service priority class to "High" to match the priority of
1788 system components that are dependent upon the a timely response.
1790 * SMB error responses avoid returning errors that could confuse the
1791 Microsoft SMB redirector into disconnecting the connection to \\AFS.
1793 All UNIX client platforms (except MacOS X 10.4 and 10.5)
1795 * OpenAFS 1.5.59 contains fixes for the client issues addressed by the
1796 security advisories OPENAFS-SA-2009-001 and OPENAFS-SA-2009-002.
1800 * Support for prerelease Linux 2.6.30 kernels.
1803 OpenAFS 1.5.58 (2009-03-30)
1807 * Code cleanup and prototyping.
1809 * Avoid unnecessary blocking in Rx periodic cleanup code.
1811 All server platforms
1813 * Fileserver CopyOnWrite routine optimized for performance.
1815 * Make fileserver callback dumps 64 bit safe.
1817 * Fix byte order issues with fileserver host hashing.
1819 * Fix buffer size issues with butc.
1821 * Fix several Ubik recovery issues.
1823 * Avoid leaking file references in the fileserver.
1825 * Fix a race in DAFS while closing vnodes, and another offlining
1828 * volserver interfaces for volume splitting client.
1832 * [RT 124293] A race condition exists which can result in a crash.
1834 * [RT 124276] If the vldb is out of sync with the contents of the file
1835 servers, afsd_service will retry too many times when a file server
1836 reports a volume as not being present. Now if the list reported by
1837 the vldb is the same as the previously seen list, then the retry is
1840 * [RT 124276] Read-only volume failover was broken in 1.5.53 whenever
1841 accessing a volume results in VNOVOL or VMOVED.
1843 * [RT 124276] Prior to 1.3.70 the volume server reference list was not
1844 reference counted and would be prematurely freed while in use. When
1845 reference counting was added in 1.3.70 a bug was introduced that
1846 could result in service reference list corruption.
1848 * Add Windows Application Event Log warning messages for "Client SMB
1849 MPX value too large" and "Client SMB Buffer Size too small".
1851 * Renaming of files across directory boundaries would result in an
1852 invalid handle error when attempting to access the files after the
1855 * Fix the handling of Tran2 Set Path Info RPCs. Do not fail when a
1856 smb file descriptor cannot be found. The whole point of using a
1857 Path Info function is because an smb file descriptor wasn't
1860 * More edge cases in which dynamic addition of Freelance root.afs
1861 entries would get the wrong FID or where the root.afs directory
1862 would not be refreshed.
1864 * Buffer overflow could occur if the workstation cell name was longer
1865 than 64 characters. Crashes could occur in afscreds.exe,
1866 afslogon.dll, and afsd_service.exe.
1868 * VNOSERVICE and VOFFLINE errors were leaking and were exposed to the
1871 * Log file server uuid values as part of the cm_server object when
1872 available. Dump the cm_server object list in response to "fs
1875 * Optimize the performance of resetting access control lists when
1876 tokens are set or removed.
1878 * Remove symlink recursion tests and increase max symlink count to 64
1881 * Windows specific Rx performance improvements.
1883 * Support for Network Identity Manager 2.0
1885 All UNIX client platforms
1887 * Avoid issues with freeing resources at shutdown.
1889 * Numerous fixes to disconnected AFS.
1891 * Disconnected AFS fixes for replaying changes without double-freeing.
1893 * Attempt to use krb524 principal conversion in aklog if available.
1897 * Kerberos configuration at build time corrected.
1901 * Default to dynamic allocation of AFS kernel cache entries to allow
1902 growth for inotify()-pinned entries. (beagle, famd, etc)
1904 * Change client truncation routines to avoid locking issues.
1906 * IA64 port clients fixed on Linux 2.6.
1908 * RPMs now install fstrace message catalog.
1910 * Support through kernel 2.6.29 tested.
1912 * Fix locking issues on CellServDB file in /proc.
1916 * Support OpenBSD 4.4
1919 OpenAFS 1.5.57 (2009-01-23)
1923 * Conditional compilation of rxdebug support is now possible.
1925 * Documentation updates.
1927 * Further race connditions in Rx have been corrected.
1929 All server platforms
1931 * Salvager no longer attempts to recreate headers in the wrong
1934 * Volumes are properly marked in use on creation and subsequently on
1935 examination with vos.
1939 * Undo the "UAC manifest fix" applied to afs_config.exe.
1941 * Ensure that Freelance allocation of vnodes follow the AFS convention
1942 of odd vnodes are directories and everything else is an even vnode.
1944 * Add Freelance logic to mount point and symlink evaluation functions.
1946 * Enhance smb_ParseASCIIBlock() so that it can handle all of the
1947 STRING formats defined by the CIFS Technical Report 1.0.
1949 * Validate the output of smb_ParseASCIIBlock() in all callers. Return
1950 CM_ERROR_BADSMB if the STRING field cannot be parsed.
1951 CM_ERROR_BADSMB will cause the contents of the packet to be logged.
1953 * If multiple SMB Raw Write operations were taking place at the same
1954 time, there could be data corruption because unique event objects
1955 were not generated for each Netbios receive operation.
1957 All UNIX client platforms
1959 * Userspace AFS library can now deal with large files when supported
1962 * Numerous updates to disconnected AFS support, including changes to
1963 allow reconnection to work in more circumstances.
1967 * FreeBSD unstrategy code has been updated.
1971 * A race during file truncation has been corrected.
1973 * System call probing routines have been updated.
1975 * 2.6.29 is now supported.
1979 * 10.3 support has been corrected.
1983 * Initial OpenBSD 4.4 support.
1987 * Updates to allow compiling on newer OpenSolaris are now included.
1990 OpenAFS 1.5.56 (2008-12-30)
1994 * libuafs (userspace cache manager) updated to correct several errors.
1996 * Additional rx debugging support is available as a conditional
1999 * A race condition in Rx leading to a panic has been corrected.
2001 * Rx idle time tracking has been corrected.
2003 * ubik clone server support has been corrected.
2005 All server platforms
2007 * Salvager no longer leaves cores in vice partitions.
2009 * The vol-dump tool now supports dumps larger than 2gb where possible.
2011 * Operations on multiple files now report all FIDs in the audit log.
2013 * butc XBSA support now works correctly on amd64.
2017 * The NetIDMgr AFS Provider automated configuration logic was broken
2018 by the introduction of Kerberos referrals. If the realm of the
2019 identity cannot be determined, the workstation cell is now assumed
2020 to belong to the newly created identity.
2022 * Avoid a reference count under flow during rename operations.
2024 * Avoid a crash caused by treating an arbitrary length directory
2025 search mask as an 8.3 mask.
2027 * Prevent rename operations if a case insensitive match for the target
2028 name already exists and does not refer to the object being renamed.
2030 * Increase the maximum number of background daemons to 64.
2032 * Fix the UAC manifest applied to afs_config.exe
2034 All UNIX client platforms
2036 * Updates to disconnected AFS support.
2040 * FreeBSD 7.1 is now supported.
2042 * amd64 FreeBSD is now supported.
2046 * Generic fh (exportfs API) cache type is now available.
2048 * Avoid some oopses due to backing_dev_info inode fields not being
2051 * 2.6.28 is now supported.
2055 * 10.3 support has been corrected.
2059 * Large partition support has been corrected.
2061 * Filesystem-agnostic cache is now available on Solaris 10 and 11.
2064 OpenAFS 1.5.55 (2009-11-10)
2068 * Salvager avoids leaving core files in vice partitions.
2070 * NFS translator fixes.
2072 * Unresponsive server handling fixes.
2074 * A volserver race which could result in duplicate transactions is
2079 * Fixes a panic caused by corruption of the SMB virtual circuit list.
2082 * Fixes a panic caused by receipt of a UTF-16 string that cannot be
2085 * Implements a more aggressive recovery algorithm for Netbios errors
2086 that result in loss of communication to the AFS SMB server.
2088 * Improve pioctl response time when testing whether or not a PATH is
2091 * Adds support for linked cells.
2093 * Increases the length of the cell and realm names that can be input
2094 into the Network Identity Manage AFS provider configuration dialog.
2096 All UNIX client platforms
2098 * Disconnected AFS avoids infinite recursion during rmdir.
2102 * Support for 2.6.28 (not complete for NFS translator modules).
2104 * Support for using exportfs API for filesystem-agnostic cache.
2106 * Disable backing store readahead.
2108 * Avoid deadlocks when writing back mmapped files larger than the
2111 * Avoid Oops when doing PAG garbage collection.
2114 OpenAFS 1.5.54 (2008-10-08)
2118 * Updates for new Tivoli X/Open API finding.
2120 * A double-free is corrected in Rx.
2122 All server platforms
2124 * Ubik cleans up file descriptor cache correctly when doing recovery.
2126 * Enhanced vldb error checker included.
2130 * Prevent a crash that could occur when multiple file / directory
2131 change notifications are processed simultaneously.
2135 * AFS claims more free space so Finder will attempt file copies.
2139 * Avoid spurious ENOENT when calling gwtcwd() on a volume root.
2141 * Avoid spurious ENOTDIR during fakestat.
2144 OpenAFS 1.5.53 (2008-09-26)
2148 * rx avoids many packet leaks.
2150 * rx jumbogram disabling now works (and is the default).
2152 All server platforms
2154 * Demand Attach fileserver tries to avoid issues tracking offline
2159 * Many potential deadlock conditions due to out of order lock
2160 acquisitions have been corrected.
2162 * A race condition resulting in an undercount on the cm_scache_t
2163 reference counts has been corrected.
2165 * An empty string when sent as an ioctl path is now properly
2166 interpreted as meaning the current directory. This affects "fs
2167 lsm", "symlink list", etc.
2169 * Fix smb string parsing differences where the smb protocol
2170 documentation does not match the actual Windows implementation.
2172 * Random access denied errors fixed.
2174 * A file server lock synchronization issue was corrected in SMB
2175 NTCreateX and NTTranCreate operations. This bug prevented properly
2176 operation when loading roaming profiles.
2178 * Fix a heap overwrite error during server probe operations if a new
2179 server is added while a probe operation is in progress.
2181 * Fix an LSA memory leak that was the result of an LSA error.
2183 * Do not leak cm_cell_t objects if the VLDB server lookup fails.
2185 * Only initialize rx mutex/lock objects once.
2187 * Do not nul terminate the AFS volume name when reported to Windows.
2189 * Improve VNOVOL error handling. Prevent updated vl information from
2190 being destroyed immediately after it was acquired. This bug
2191 prevented proper fail over when volumes are moved or removed from a
2194 * Remove volume id from the server volume list in response to VMOVED
2197 * "fs flushXXX" commands now destroy locally built B+ directory trees.
2199 * Prevent mixture of locally modified directory pages and file server
2202 * Fail over to alternate vl servers if a ubik error is returned.
2204 All UNIX client platforms
2206 * Disconnected AFS now supports read-write mode.
2208 * volserver now builds correctly.
2212 * AIX 6 is now supported.
2216 * FreeBSD 7 is now supported.
2220 * cache bypass is now supported.
2222 * 2.6.x kmod compilation now uses kernel compile options always.
2224 * Support through 2.6.27.
2228 * Show more space free so Finder doesn't get confused.
2232 * Default to namei rather than inode.
2235 OpenAFS 1.5.52 (2008-08-18)
2239 * Initialize volume updateDate at volume creation.
2241 * Avoid potential corruption of directories during salvage.
2243 * Check for out of memory condition during allocation of additional Rx
2248 * Restore support for Windows 2000 (broken in 1.5.50).
2250 * Perform additional validation on volume names in mount points during
2251 creation and evaluation.
2253 * Fix several deadlocks, races, and reference count issues.
2255 * Further optimize SMB Directory Search processing and minimize the
2256 number of InlineBulkStatus RPCs sent to the file server.
2258 * Enable "bos restricted" operations.
2260 * Fix the create of submounts used by the AFSCreds and afs_config
2263 * Fix a short name truncation bug. (1.5.50)
2265 * Fix the error code reported when attempting to delete a file on a
2266 readonly volume or one that is marked with the readonly DOS
2269 * Fix a heap corruption error when reading the CellServDB file
2272 * Add the "RxUdpBufSize" registry value. The new default is 256KB.
2274 * Do not include trailing NULs in the directory search output.
2277 * Pre-allocate 64 Rx Packet buffers per thread in order to improve
2280 * For debugging: add smb lock requests and stat cache lock allocations
2281 to the output from "fs memdump".
2285 * Workaround broken sigwait() to allow fileserver to shut down
2286 correctly pre NetBSD 5.0.
2290 * Default to namei fileserver; Allow inode fileserver at configure
2295 * Try harder to avoid kernel panics for malformed requests.
2298 OpenAFS 1.5.51 (2008-07-29)
2302 * salvager tries harder to arrange for clients to get VBUSY while
2303 salvaging single volumes.
2305 * salvager avoids certain corruption when salvaging directories.
2307 * Rx connection clones disabled.
2311 * The 32-bit EXE 1.5.50 installer failed to properly install the C
2312 Runtime library. When used as an upgrade OpenAFS would continue to
2313 work but when used as a new installation, OpenAFS binaries would
2316 * Fixes the "fs" and "symlink" commands to properly parse Unicode path
2317 prefixes during the pioctl remote procedure call. This bug would
2318 result in file not found errors for files and directories that
2319 clearly exist. (Bug introduced in 1.5.50)
2321 * Large File support is disabled. (Bug introduced in 1.5.50)
2323 * Removes the possibility of a deadlock during volume location update
2324 operation if all of the reported file servers are unreachable at the
2327 * Ensures that reference counts are properly incremented/decremented
2328 on Rx connection objects used for volume location RPCs.
2330 * Over Quota errors during cm_FSync() calls would lead to an infinite
2331 loop as the error was never propagated to the caller.
2333 All UNIX client platforms
2335 * Bugfixes to disconnected AFS support in the cache manager.
2338 OpenAFS 1.5.50 (2008-07-16)
2342 * volserver puts recloned volumes back online before returning the
2343 volume to the fileserver, avoiding spurious VNOVOL errors.
2345 * Updated TSM X/Open API support available.
2347 * Demand Attach fileserver will not crash due to accesses during
2350 * Substantial documentation updates.
2352 * Demand Attach fileserver state tracking and analyzer tool
2355 * UAFS userspace cachemanager updates.
2357 * Corrected support for anti-meltdown protection in the client.
2361 * UNICODE Character Set Support.
2363 * Pioctl interfaces to the cache manager have been refactored to
2364 provide layering between the SMB specific code and the general
2365 purpose ioctl operation.
2367 * Garbage collect dead SMB virtual circuits as soon as they are no
2368 longer being referenced. This avoids problems with outstanding
2369 locks not being dropped when the virtual circuit becomes invalid.
2371 * Remove the IBM Administration Reference documentation and replace it
2372 with the OpenAFS Command Reference Manual.
2374 * Avoid calling rx_SetDeadTime and rx_SetHardDeadTime functions each
2375 time a connection is about to be used. Do not hold a lock on the rx
2376 connection object while it is being selected. This avoids a race
2377 between threads attempting to set the timeout values and removes a
2378 bottleneck that was hampering performance.
2380 * Ensure that the smb directory attribute is set for all directory
2383 * Replace the VC Runtime EXE installer with the MSI installer in the
2384 NSIS installer scripts.
2388 * Support for updates to OpenSolaris.
2392 * Correct dentry revalidation for cross-directory renames.
2394 * Updated rpm packaging materials for 1.5 release series and 2.4
2397 * Corrected syscall table probing.
2399 * NFS translator updates for current kernels.
2402 OpenAFS 1.5.39 (2008-06-24)
2406 * Updates for Demand Attach fileserver.
2410 * Fix two memory leaks.
2412 * Fix one missing lock.
2414 * Handle access denied errors when writing dirty buffers.
2416 * Fix two errors that would cause the *experimental* AFS Servers
2420 OpenAFS 1.5.38 (2008-05-24)
2424 * Add read-only disconnected support.
2427 OpenAFS 1.5.37 (2008-05-21)
2431 * Includes a number of optimizations for testing.
2434 OpenAFS 1.5.36 (2008-05-09)
2438 * Rx optimizations now attempt to deal with high latency WANs.
2440 * Client will not wait infinitely for a server which is not providing
2441 data. Additional servers will be polled without marking the server
2442 which is not providing data down.
2444 * vos move will not erroneously unlock locked vldb entries on failure.
2446 All server platforms
2448 * Fileserver avoids a potential infinite loop when a client
2449 relinquishes an address.
2451 * Fileserver large setting now configures more threads.
2453 * Fileserver properly registers uuids of new clients.
2455 * Ubik servers do not improperly hide updates from clients.
2457 * Fileservers reserve enough file descriptors such that each thread
2458 can cache one to avoid spurious errors.
2462 * Fix a cm_buf_t reference count leak when attempts to write dirty
2463 buffers to the file server from within cm_IncrSyncer() fail.
2465 * Prevent udebug from crashing.
2467 * Another VNOVNODE issue fixed. When writing a dirty buffer to the
2468 file server, if VNOVNODE is received, mark all buffers as invalid
2469 without further attempts to contact the file server.
2472 =======> Changes back to 1.3 have not yet been incorporated here <=======
2477 * -nosettime is now the default for afsd. Use "-settime" to get the
2480 * OpenBSD is now supported.
2482 * Mountpoint directory information is now only faked for cross-cell
2483 mountpoints when using the -fakestat flag (e.g. for the directories
2484 under /afs, but not for most other volumes mounted inside the cell).
2485 The -fakestat-all switch can be used to fake information for all
2488 * When fakestat is enabled on MacOSX, the Finder can be used to browse
2489 a fully-populated /afs directory. However, this precludes reliable
2490 use of entire volumes as MacOS bundles (i.e. containing a Contents
2491 directory in the root of the volume).
2493 * Mountpoint directory information can be faked by the cache manager,
2494 making operations such as stat'ing all cells under /afs much faster.
2495 This is enabled by passing -fakestat to afsd, but might not be stable
2501 * The kaserver now defaults to not allowing interrealm authentication,
2502 due to security vulnerabilities in the krb4 protocol. The new
2503 "-crossrealm" flag to the kaserver is provided to reenable interrealm
2504 authentication if desired.
2506 * RedHat Linux 9.0 is now supported.
2508 * Solaris 9 12/02 is now supported. Solaris 7 and 8 x86 should now
2511 * On Linux machines using 2.2 series kernels, 2.2.19 or higher is now
2514 * An OpenAFS 1.2.9 afsd will not work with kernel modules built from
2515 an earlier OpenAFS release. In general, using a mismatched afsd and
2516 kernel modules set is unsupported; it is not recommended that you use
2517 such a configuration on a regular basis.
2522 * Mountpoint directory information is now only faked for cross-cell
2523 mountpoits when using the -fakestat flag (e.g. for the directories
2524 under /afs, but not for most other volumes mounted inside the cell).
2525 The -fakestat-all switch can be used to fake information for all
2528 * HPUX 11.0 is now supported.
2530 * It is now possible for AFS to use Kerberos 5 directly, via rxkad 2b.
2531 See the OpenAFS 1.2.8 Release Notes for more information on using this
2534 * An NFS translator kernel module is now included and compiled by
2535 default for Solaris only.
2540 * MacOS X 10.2 is now supported. FreeBSD 4.3 and later support is
2541 included in this release, but is still under active development and
2542 should only be used by those doing active development on the OpenAFS
2545 * When fakestat is enabled on MacOSX, the Finder can be used to browse a
2546 fully-populated /afs directory. However, this precludes reliable use
2547 of entire volumes as MacOS bundles (i.e. containing a Contents
2548 directory in the root of the volume).
2550 * The fileserver will now use Rx pings to determine if clients are
2551 reachable prior to allocating resources to them, to prevent asymmetric
2552 clients from consuming all fileserver resources.
2557 * Mountpoint directory information can be faked by the cache manager,
2558 making operations such as stat'ing all cells under /afs much faster.
2559 This is enabled by passing -fakestat to afsd.
2561 * Solaris 9 FCS and Solaris 7 and 8 x86 are now supported.
2566 * A remote denial of service attack in the AIX and IRIX clients has been
2567 fixed. Users of those platforms are strongly encouraged to upgrade.
2569 * Fixed race conditions in fileserver that could result in crash.
2574 * Server logfiles now more consistant about format in which hosts are
2577 * vfsck on Solaris will now allow force runs (using -y flag) even if old
2583 * Cell aliases for dynroot can be specified in the CellAlias file in
2584 /usr/vice/etc or /usr/local/etc/openafs, in format "realname alias",
2585 one per line. They can also be managed at runtime with "fs newalias"
2586 and "fs listaliases".
2591 * Solaris 9 and Linux PA-RISC are now supported.
2593 * fileserver will not erroneously delay legitimate errors for 3 seconds
2594 after 10 errors are returned (e.g. stat() on a directory you can't
2597 * Rx MTU calculation now works for Irix, Solaris and Linux
2599 * If afsd is started with the -dynroot flag, /afs will be locally
2600 generated from the CellServDB. AFSDB cells will be mounted
2601 automatically upon access.
2603 * The namei fileserver allows vice "partitions" to be directories
2604 instead of partitions and will attach and display accordingly.
2605 Creating the file "AlwaysAttach" in the /vicepX directory is used as
2606 the trigger to attach it.
2608 * TSM support for butc no longer requires editing a Makefile, simply
2609 specify the --enable-tivoli-tsm configure option.
2611 * Linux builds no longer require source changes every time the kernel
2612 inode structure changes; the OpenAFS sources will now configure itself
2613 to the actual inode structure as defined in the kernel sources.
2618 * vfsck on Digital UNIX and Solaris will now refuse to fsck mounted
2624 * AFS now supports --prefix and the other directory options of
2625 configure. By default AFS builds assuming it will be installed in
2626 /usr/local. In order to get traditional AFS directory paths (/usr/afs
2627 and /usr/vice/etc) use the --enable-transarc-paths option to
2628 configure. More details on the new directory layout are found in
2634 * Windows 95/98/ME/NT/2000 - Consistent versioning: Installation, AFS
2635 Control Center, Client dialog boxes and properties pages for
2636 executables display a consistent OpenAFS version number. Installation
2637 detects previous installation and prompts the user for upgrade
2640 * Windows 95/98/ME/NT/2000 - Installation features: During installation
2641 the user can select the source of the CellservDB file, AFS home cell,
2642 and drive mappings. During installation a drive path mapping can
2643 include a variable that will be substituted with the current UserName
2646 * Windows 2000/NT - Integrated logon: The Integrated Logon feature
2649 * Windows 95/98/ME - Logon script features: The Windows 95/98/ME client
2650 now offers a command-line option for starting up the AFS client
2651 without authenication. It is now possilbe to start the AFS client
2652 first and obtain tokens, and map drives all through Windows scripts.
2653 This helps using Windows 95/98/ME client in Kerberos 5 environment.
2655 * Windows 2000/NT - LANA numbers: AFS client now scans the LANA numbers
2656 to establish the correct NETBIOS connection. NetBEUI is no longer
2657 needed. The user no longer needs to find the correct LANA number.
2659 * Windows 2000/NT - OpenAFS naming consistancy: Further progress has
2660 been made to remove references to "Transarc AFS" and replace with
2666 * AFS now builds with configure. The README for building has been
2667 updated and includes full details.
2669 * A client system can now have multiple sysname values for @sys. They
2670 will be searched in order when looking up files in AFS. The
2671 -newsysname argument to fs sysname can be repeated to set multiple
2674 * A new system group is created for new cells (system:ptsviewers with id
2675 -203). If this group exists, members of this group can examine and
2676 read the entire protection database. They can examine all users and
2677 groups and can get the membership of any group.
2679 * A new program, pt_util has been added to the distribution. This
2680 program allows users to print the contents of the protection database
2681 or to edit the protection database without running a ptserver. It can
2682 be used to set up a new cell without ever running in noauth mode. Run
2683 pt_util -h for help.
2685 * The fs setcrypt and fs getcrypt commands have been added. These
2686 commands allow the system administrator to require that the client
2687 encrypt all authenticated traffic between the client workstation and
2688 AFS. The encryption used is weak, but is likely better than sending
2689 unencrypted traffic in most environments. Some functions, such as
2690 looking for a volume may not be encrypted, but data transfer certainly
2691 is. By default data is not encrypted. At this time no significant
2692 experimentation with server performance has been conducted.
2694 * By default AFS is compiled with AFS_AFSDB_ENV, enabling the -afsdb
2695 option to be given to afsd on startup. If this option is used, then
2696 new cells will be looked up using AFSDB records stored in DNS if they
2697 are not found in CellServDB. This means that users can create
2698 cross-cell mountpoints in directories they control to access cells not
2699 in root.afs, and that cells in root.afs need not be in the client's
2702 * AFS database servers can be marked as read-only clones. Surround the
2703 hostname in square brackets on the bos addhost command and the
2704 database server will never be elected sync site. This is useful for
2705 cells distributed over a wide region.
2707 * The AFS servers now support the -syslog flag. This flag causes them
2708 to log to syslog rather than to files. This flag is not supported on
2709 NT. For all servers besides the salvager, the flag can also be
2710 specified as -syslog=facility, where facility is an integer facility
2711 code from syslog.h. A -syslogfacility option is provided for the
2712 salvager to accomplish the same goal.
2714 * If the --enable-fast-restart flag is given when configuring AFS, then
2715 the salvager supports the -dontsalvage flag which causes it to exit
2716 without salvaging any volumes. If this is configured into the third
2717 command of a fs process, then the fileserver will start without
2718 salvaging. It will fail to attach volumes that need salvaging and
2719 they can be salvaged manually. This provides significantly better
2720 server startup performance at the cost of administrative complexity.
2722 * If the --enable-bitmap-later flag is given when configuring AFS, then
2723 the fileserver creates bitmaps for free vnodes on demand, allowing
2726 * If bosserver finds a BosConfig.new file at startup, it reads this file
2727 and renames it to BosConfig. This allows bosserver to be reconfigured
2730 * The bosserver can be placed in a restricted mode in which AFS
2731 superusers are only granted limited access to the server host. The
2732 following functionality is disabled when restricted mode is in use:
2735 bos getlog (except for files with no '/'s in their name)*
2741 specific exceptions are made for functionality that "bos salvage"
2744 A cron bnode who's name is "salvage-tmp", time is now, and command
2745 begins with "/usr/afs/bin/salvager" may be created. This bnode deletes
2746 itself when complete, so no special "delete" support is needed. This
2747 functionality may be removed in the future if a "Salvage" RPC is
2750 The file with the exact path /usr/afs/logs/SalvageLog may be fetched,
2751 since that is how bos salvage [...] -showlog is implimented.
2753 Restricted mode is enabled using a new bos command (bos setrestricted)
2754 or bossever command line switch (bosserver -restricted). Restricted
2755 mode can be disabled by a) sending the bosserver process a SIGFPE
2756 (which will then allow restricted operations until the next restart or
2757 setrestricted command) or b) editing /usr/afs/local/BosConfig (or
2758 BosConfig.new), and restarting the bosserver.
2760 * The bos UserList of trusted administrators can now contain cross-realm
2761 Kerberos principals.
2763 * udebug now takes --server not --servers.
2765 * Several error messages have been improved to include volume numbers.
2767 * Several new ports have been included for UNIX platforms: Darwin
2768 (ppc_darwin_12 and ppc_darwin_13), Linux 2.4 (i386_linux24), Linux on
2769 the Powerpc (ppc_linux22 and ppc_linux24), Linux on the Sparc
2770 (sparc_linux22, sparc64_linux22 and sparc64_linux24).
2772 * Incomplete FreeBSD and Alpha Linux ports are included. The FreeBSD
2773 port has a working server and the Alpha Linux port has a partially
2776 * A native client for Windows 95/98/ME has been added to the
2777 distribution. With this program, a gateway machine is no longer
2778 required for Windows 9x to access AFS files. One drive letter will be
2779 created on your machine by default - Z:. The Z: drive will be the
2780 root of the AFS tree, allowing you to browse all sites that have AFS
2781 servers available. Additional drive letters can be defined for other
2782 AFS directories. A Windows Explorer shell extension is included that
2783 allows you to right click on items within an AFS tree to bring up an
2784 "AFS" menu item and perform various operations on a file or directory.
2785 The most useful item is "Access Control Lists", which allows you to
2786 view and edit the permissions of a particular directory. Command line
2787 tools are also available in the install directory. These commands
2788 include klog, unlog, tokens, kpasswd, symlink, fs and pts. The
2789 installable includes a readme file that contains more information on
2790 how to use the client program and known issues.
2792 * Support for large caches in afsd. Cachefiles are stored in
2793 subdirectories. The default is 2048 files per subdirectory, which
2794 should work fine in most situations. You can use the new afsd option
2795 -files_per_subdir to change this number. Note that the first time you
2796 run afsd with this patch, your cachefiles will get moved into
2797 subdirectories. If you subsequently run an older version of afsd, you
2798 will lose all your cached files.