Under The Hood: I/O Priority and Networking

Along with working to modify the traditional cache hierarchy for better performance, Vista includes the introduction of several new technologies designed to help applications better utilize disk and network bandwidth. For disk bandwidth, Vista now includes an I/O priority system that allows applications to specify the priority of their I/O operations so that Vista can service the most important operations first, not unlike the priority system for applications. This is in comparison to XP which executes all I/O operations as if they have the same priority, which results in other applications having their own I/O operations slowed down even if they're more important.

With only four levels of priority (two of which are effectively for exclusive use by Vista), the I/O priority system in Vista isn't nearly as refined as the application priority system, but it's enough to get the job done. With two remaining priority levels, the benefit of the priority system to users is that traditional background tasks such as virus scanning can not only be low-priority tasks for the CPU, but now the disk too; anyone who has attempted two I/O heavy operations before has seen firsthand how they often cause the operations to take longer than their sums to complete. The new I/O priority system won't entirely alleviate any slowdowns caused by background applications as these requests have to be serviced at some point, but by reducing the interruptions caused by background applications these applications can be run without bringing a system to quite as much of a halt.

Somewhat related, I/O operation size has also been increased. Previously, Windows broke all I/O operations down to 64KB requests, which causes some overhead as each chunk of a larger operation needs to be processed separately. Vista no longer has a cap on I/O operation sizes, and will now attempt to execute I/O operations with the size a program requests. Microsoft has used Explorer as an example, where the copy command now uses 1MB operations.

Networking

Along with the changes in disk I/O to better maximize disk performance, Vista also implements a new TCP/IP stack - the so-called "Next Generation TCP/IP stack" - that includes new features to better maximize network utilization. However, since networking changes can affect entire networks and not just a single machine, only one of these features - Receive Window Auto-Tuning - is enabled. The other feature - Compound TCP - is disabled due to the potential to interrupt other machines on a network and/or hurt the client's network performance.

To discuss Receive Window Auto-Tuning, we must first quickly talk about TCP/IP networking and what a receive window is. In the most basic of terms, the receive window is the maximum amount of data that a sender can transmit at once before it must wait for an acknowledgement (ACK) from the receiver signaling that the data was received successfully. Once an ACK is received, the sender can begin transmitting more data. This process is intended to keep the sender from flooding the receiver with data, which could cause lost packets and other performance-reducing problems. The ideal size of this window varies upon network conditions and must be continuously renegotiated to maintain a transfer and maximize bandwidth usage; factors include both bandwidth and latency of a connection between two devices. For example, a computer using a dial-up modem can't send or receive data anywhere near as fast as a typical Internet server, so it would seldom have more than about 6 kB of data in-flight at once. Conversely, a high-speed broadband home computer might have several hundred kB of data in transit at once.

With Windows XP, the receive window could be scaled as needed, but it was not a fine-grained system. Except in specific cases, the maximum receive window size was a global value for all TCP connections. While on average it was usually good enough, it could be a poor value for specific connections. This is especially the case on high latency and high bandwidth connections, which is why one common tweak to improve networking performance for Windows machines with a broadband connection is to manually adjust this value - Windows simply didn't allow a window to normally scale to a large enough size to best utilize some broadband connections.

Auto-Tuning is a resolution to the inefficiencies of XP's scaling system, and it makes window scaling a more finely-grained operation. As the ideal receive window size is exactly the amount of data that can be in-flight between a sender and a receiver - the bandwidth-delay product (the product of the speed of a connection and its latency) - Vista's auto-turning system is designed to surpass XP's scaling system by not only allowing larger windows, but by also attempting to make a best-guess on the bandwidth-delay product in order to maximize bandwidth usage. Additionally, this is now a per-TCP connection attribute instead of a global attribute, allowing each connection to be more efficient rather than using the average connection values. As this is a safe optimization (QoS issues notwithstanding), this is one of the networking features enabled by default under Vista.

Compound TCP

The other significant addition to Vista's TCP/IP stack is Compound TCP, the product of an earlier research project by Microsoft in combining several different known techniques for maximizing bandwidth usage under high latency conditions. Under these conditions, traditional TCP traffic algorithms are reliable but slow to let the sender and receiver increase their windows to fill very large bandwidth-delay products. This is because traditional TCP is inherently a conservative and well behaved system based on reliability and sharing as the most important properties.

Compound TCP on the other hand is the merger of several aggressive algorithms - including Fast TCP, High Speed TCP, TCP Vegas, and TCP Reno - which when combined are far more aggressive at trying to quickly maximize bandwidth usage while maintaining reliability; unfortunately, these algorithms weren't originally designed to work all that well with traditional TCP. To that extent, in order to make Compound TCP safe for use on larger networks, Microsoft has reworked these algorithms so that they are effectively a single algorithm under Compound TCP, and their over-aggressive nature has been removed so that they will not dominate over traditional TCP traffic.

The end result is that while Compound TCP is designed to be safe, it's a cutting-edge technology that is not well tested, and for this reason it is disabled by default on Vista. Longhorn Server will be the first Windows product to ship with it enabled by default when it ships later this year. In our network tests, we have tested Vista both with Compound TCP enabled and disabled so that you can see the results of using it; however, until Compound TCP has undergone some more rigorous testing we would caution that it's not advisable to enable it on home computers or in production environments.

Hard Drive Performance and ReadyBoost Networking Performance
Comments Locked

105 Comments

View All Comments

  • Zak - Thursday, February 1, 2007 - link

    I've finally got around to installing RC2 last week: Dell Inspiron 2GHz CoreDuo, 2GB RAM, 7200RPM HD, 256 Nivdia video. Vista is slow, network transfers are 50% slower or so than in XP, GUI is sluggish and all the improvements are pretty annoying. Interface is too busy and overdone. A simple copy message contains a long unnecessary explanation of what's about to happen. Even after turning off the security features one can't escape the annoying popups and messages. And my hard drive was crunching non-stop all day, I can't even imagine what it does to battery life. I haven't had a virus or spyware in years and I don't see any compelling reasons to switch to Vista. I haven't even tried any multimedia features as none of my DVD and video playback software worked properly and I will not use WMP if my life depended on it, so I can't comment nt on DRM and stuff but I've had enough after few days and restored my XP image back to the laptop. If MS tries to force this on people as its, without major improvements, I see Apple and Linux getting lots of switchers. But them XP was bad at first too so maybe Vista will become usable with SP2:) I myself will desperately look for an alternative to Vista. I don't play games that much any more so this won't be "a must" for me.

    Z.
  • Zebo - Thursday, February 1, 2007 - link

    I'm very afraid Zak. I will upgrade due to Microsoft forcing the issue on us gamers with dx10 vista only but with total dread. I may have to start listening to those console fans and linux fans after all. But the lack of TBS games kills consoles for me...SIGH..

    I totally agree with you about Virus and spy/malware issues. All are resolved or blocked with free third party apps many years now for anyone with the slightest clue. Same goes for Firewall/searching and other features MS lists on their "100 advantages" site. Vista is just late to the party with what we all know how to do and cripples your computer performance and makes everything so dumbed down visually and practically.
  • mlambert890 - Saturday, February 3, 2007 - link

    You guys must be using a different OS. I havent heard of anyone with this dismal of an experience at all. If you hate the UI, just run it in legacy mode and it will look like XP. Disable all of the security add ins and they ARE gone. Ive take a Vista machine and set it up to the point that the person using it had no real clue it was Vista but did notice that their laptop seemed quicker.

    Have fun on Linux though. Linux is a LOT easier to use/live with than any MS OS! (I need an eyeroll smiley here)
  • jonp - Monday, February 5, 2007 - link

    I would be interested to know if you have installed and worked with SUSE 10.2? as I assume your "...a LOT easier..." is sarcasm.
  • kalrith - Thursday, February 1, 2007 - link

    The second sentence of the third paragraph states, "The reason the low end AMD cards look better off here".

    I think you meant ATI instead of AMD.
  • kalrith - Thursday, February 1, 2007 - link

    Another typo is in the last sentence on the first page. It says, "What's a question we hope to answer..." What's should be That's.
  • JarredWalton - Friday, February 2, 2007 - link

    Technically, ATI is now AMD, which is why we are now referring to the cards as AMD cards. Same thing as ATI, but since they were bought out.... :)
  • kalrith - Friday, February 2, 2007 - link

    You're right...I completely forgot about that.
  • stash - Thursday, February 1, 2007 - link

    WMDC was RTM'ed yesterday: http://www.microsoft.com/downloads/details.aspx?Fa...">http://www.microsoft.com/downloads/deta...0-af33-3...
  • stash - Thursday, February 1, 2007 - link

    quote:

    Similarly, launching an application that requires administrative rights is still more difficult than it needs to be. As we touched upon this briefly last time, with the launch of Vista a lot of common 3rd-party applications will continue to require administrative privileges to run correctly, and it will continue to be this way for some time until everyone has had a chance to retrofit their applications for Vista


    Which common 3rd-party apps are you referring to here?

Log in

Don't have an account? Sign up now