MacTCP 2.0.4 Update The enclosed file is a self-extracting archive. To use, download, double-click the downloaded file (this decompresses it). Read Me for MacTCP 2.0.4 Patches Copyright ©1993, Apple Computer, Inc. All rights reserved. October 21, 1993 What Is This For? =============== The applications: "MacTCP 2.0 -> 2.0.4" and "MacTCP 2.0.2 -> 2.0.4" are ResCompare resource patching applications. Applying the appropriate patch to a copy of your original MacTCP control panel will upgrade your copy MacTCP to version 2.0.4. What Can Be Upgraded? ==================== The following versions of MacTCP may be upgraded: ¥ MacTCP 2.0.2, distributed in "TCP/IP Connection for Macintosh", on E.T.O. 12, and copies obtained through developer/publisher redistribution under license from Apple. ¥ MacTCP 2.0, distributed on E.T.O. 11, and copies obtained through developer/publisher redistribution under license from Apple. What Cannot Be Upgraded? ======================= Any other version of MacTCP 2.0 (i.e, 2.0.1... 2.0.3... etc.), any MacTCP alpha, beta, or development version, or any version of MacTCP v1.x may not be upgraded. What's The Difference? ==================== The changes between MacTCP 2.0.2 and MacTCP 2.0.4 are described in the Release Notes document. MacTCP 2.0.3 was an interim release, only distributed internally at Apple. What If I Need MacTCP? ===================== TCP/IP Connection for Macintosh is currently available from Apple as a retail product in both single-user and 20-user license packs. - M8113Z/A TCP/IP Connection for Macintosh $59.00 - M8115Z/A TCP/IP Connection for Macintosh 20 user license req's purchase of M8113Z/A $69.00 TCP/IP Connection for Macintosh is also available as a part of Apple USA's Tier Volume License and Apple Master Software Site License programs. There is no site license upgrade from MacTCP v1.x to MacTCP v2.x. - B1109LL/A TCP/IP Volume License 25-1999 users $3,000.00 (includes 1 yr free maintenance for 500 users or greater) - B1108LL/A TCP/IP Volume License 2000-4999 users $4,500.00 (includes 1 yr free maintenance) - B1108LL/A TCP/IP Volume License 5000-9999 users $7,500.00 (includes 1 yr free maintenance) Prices are suggested retail, and educational pricing is different. Volume licenses may not be available outside the United States. For more information contact your Apple account representative or authorized Apple dealer, or Apple Education Consultant. Inquire about volume software licensing, and reference the part numbers listed below. Release Notes for MacTCP 2.0.4 Copyright ©1993, Apple Computer, Inc. All rights reserved. October 21, 1993 MacTCP version 2.0.4 is an update release. MacTCP version 2.0.3 was released internal to Apple. MacTCP 2.0.4 contains the following improvements over MacTCP 2.0.2 and earlier versions: Performance: ------------ ¥ Earlier versions of MacTCP had several problems associated with setting lower bounds for retransmission times on TCP connections. This was particularly apparent when using MacTCP over serial lines which tend to have both long round trip times and a tendency to corrupt packets. The lower bounding for retransmission timeouts was frequently set to 20 seconds or more. MacTCP 2.0.4 corrects these problems, and sets the retransmission lower bound to 1 second regardless of link type. This allows MacTCP to correctly calculate the retransmission time as SRTT + 4(RTTV). Note that this may result in an increased number of retransmission on some connections, but the overall performance is much more acceptable. ¥ When set to large sizes, the disk cache included in System 7 and 7.1 does not work well with networking. Doing an FTP copy to a Mac with a 1 megabyte disk cache will result in cache flush delays of 30 seconds or longer, during which time the receive window will become full and no additional data can flow over the connection. We recommend that users of MacTCP set their disk cache size to 128k or less within the Memory control panel for optimal network performance. This should be fixed in a future release of the Mac OS. ¥ Earlier versions of MacTCP incorrectly implemented TCP congestion avoidance by reopening the congestion window too quickly. MacTCP 2.0.4 corrects this problem. Configuration: ------------- ¥ BootP requests are (again) sent to the Ethernet broadcast address as they were in MacTCP 1.x. MacTCP 2.0 and 2.0.2 sent BootP requests to an Ethernet multicast address. ¥ If MacTCP is set up to run over Ethernet, and server configuration mode is chosen in the MacTCP control panel, MacTCP attempts to configure itself using BootP. If that fails, it will attempt configuration using RARP. Previous versions of MacTCP used RARP initially, and if that failed, attempted BootP. Domain Name Resolver: --------------------- ¥ If a domain name server cannot resolve a name but can provide references to more appropriate name servers, the MacTCP Domain Name Resolver (DNR) will recursively follow those references until it resolves the name, runs out of servers and references, or times out. Earlier versions of MacTCP did not recursively follow references. ¥ The DNR is now compliant with the domain name syntax portions of RFC 1123 with respect to decimal digits and hyphens. Previous versions of the DNR did not accept hyphens and assumed that names beginning with numbers were dot format internet addresses. ¥ In earlier versions of the DNR, the processing of MXInfo and HInfo replies leaked memory if more than one record was received in the answer section. ¥ Earlier versions of the DNR corrupted the higher order bits of MXInfo preferences greater than 255. ¥ When resolving an alias, the DNR will now follow up on any CNAMES which are returned. ¥ The DNR manages cached resource record (RR) memory more efficiently than previous versions. Program Interfaces: ------------------ ¥ Earlier versions of MacTCP ignored the ULP timeout parameter in the TCPClose call. ¥ Previous versions of MacTCP dynamically allocated TCP and UDP ports in the range between 256 and 65535, inclusive. For consistency with most UNIX hosts, MacTCP 2.0.4 has been changed to first attempt to allocate ports in the range between 1025 and 5000. This does not impact programs which request specific ports. ¥ In earlier versions of MacTCP, it was possible for the UDP Create call to allocate a UDP port number which was already in use if a UDP Multiport stream existed. ¥ Previously, UDP did not call the application's completion routine if a driver error caused an IP Write call to fail. ¥ PBControl calls with csCode ipctlWrite now set the IOResult correctly. ¥ The UDP notify routine is called when an ICMP destination unreachable is received. In previous versions of MacTCP, the notify routine might not get called. Odds & Ends: ----------- ¥ MacTCP 2.0.2 sometimes sent packets greater than 576 bytes long to hosts which were not on the same subnet. Earlier versions of MacTCP did not have this problem. It has been corrected in MacTCP 2.0.4. ¥ The TCP/IP protocol prohibits IP precedence level changes once a TCP connection is established. Some DEC Alphas running OSF/1 have been observed to do this when acting as FTP servers. MacTCP has always correctly sent a reset in response, but previous versions hung after doing so. Now MacTCP sends the reset but does not hang.