Slower than expected 802.11n wireless network speeds

The rule of thumb for TCP throughput over Wi-Fi is that you can get 50-60% of your signaling rate. So in your case, you should see 75-90 megabits per second of TCP throughput.

Wait, why is your TCP window size just 8 KibiBytes? That strikes me as an absurdly low default.

Let's see what yours should be by calculating a "Bandwidth x Delay product" for your connection.

If Windows 7 is reporting that you're getting a 150 mbps signaling rate, that's 150,000,000 bits per second, so let's use that as the bandwidth number.

As for delay, well, my average ping round trip time over Wi-Fi to my AP is a little under 3 milliseconds. But you're going from one wireless client to another, which gets relayed by the AP (to avoid the hidden node problem), so I'm guessing if you pinged one of your wireless clients from the other one, you'd get a round trip time of up to 6ms.

So 150,000,000 bits/sec of bandwidth * 0.006 seconds of delay = 900,000 bits you need to be able to put "in flight" before getting an Ack back, in order to keep the pipe full.

900,000 bits / 8192 bits per KibiByte = about 110 KibiBytes of TCP window needed. Let's be generous and make it a nice round 128.

Try adding -w 128K to your iperf argument lists on both the client and the server to force the TCP window to something reasonable, and see if that helps.

Since wireless is a fickle medium and there can sometimes be latency spikes due to transient noise forcing link-layer packet retransmissions, you could even try going larger than that, maybe up to 512KiB, but at some point there will be diminishing returns.

If increasing your TCP window size gets you up to around 75 megabits/sec of TCP throughput in IPerf, but if Windows 7 is defaulting your window size to 8KiB, then you probably need to figure out how to get Windows 7 to pick a better default TCP window size for all TCP connections.


By default, Windows limits its wireless bandwidth to about 10-12 Mbps (sorry, don't know for sure), even though you have your devices ready for 150 Mbps or 300 Mbps or more. The key is in the registry and you need to edit those to get your best result.

But, not to worry, our friends at SpeedGuide Forums has made it easy for us. If you want to tweak it for yourself, please read this. If you don't want to be bothered with tweaking stuffs, then please download the application called SG TCP/IP Optimizer from this page (and there are also some links for tweaking on that page).

Here's a screenshot of the application: SG TCPOptimizer

To use it, u just simply drag the slider to match the speed you want, choose Optimal option at the bottom, click Apply changes, and you'll be prompted to restart. Restart it when you're ready.

Hope this helps.


Do you have any slower devices connected to the network such as an iPod touch or iPhone? When a slower device associates with the network, the hardware activates a protection mechanism which will make a noticeable difference on transfer speeds. Average downlink for 802.11n is about 40Mbit/s, so there is definitely something wrong with the connection. I've gotten upwards of 35Mbit/s using iperf on an 802.11n network.