1. Computers
  2. Display Drivers
  3. Graphics Cards
  4. Memory
  5. Motherboards
  6. Processors
  7. Software
  8. Storage
  9. Operating Systems


Facebook RSS Twitter Twitter Google Plus


Phoronix Test Suite

OpenBenchmarking.org

Bufferbloat To Be Fought In Linux 3.3 With BQL

Linux Kernel

Published on 07 January 2012 12:29 PM EST
Written by Michael Larabel in Linux Kernel
9 Comments

Another feature coming to the Linux 3.3 kernel is Byte Queue Limits (BQL), which attempts to fight "bufferbloat" in networking.

Byte Queue Limits is reported to bring significant performance improvements across nearly all Linux package schedulers and AQMs. Byte Queue Limits is a way to limit a network controller's hardware queues by number of bytes rather than number of packets, which can reduce buffer bloat. A much more detailed description of BQL can be found from the 2011 LPC page. This is merged into the Linux 3.3 kernel with the "net-next" pull.

Dave Taht, a Linux kernel network developer working to fight the "bufferbloat" problems has written into Phoronix about BQL in the Linux 3.3 kernel. Since networking isn't one of my areas of interest, I'll leave it at this and let those interested to read more about Linux Byte Queue Limits from his provided resources.
You may or may not be aware of the latest efforts towards defeating 'bufferbloat' [1] that have gone into the linux 3.3 kernel.

They are - Byte Queue Limits [2], and huge improvements across nearly all the packet schedulers and AQMs in Linux.

The test results thus far for 'latency under load' are *compelling*.

http://www.teklibre.com/~d/bloat/pfifo_fast_vs_sfq_qfq_linear.png

Someone doing more extensive testing of various subsystems affected... network I/O, network filesystems, web performance, voip... would be *comforting*. I'm curious if it were possible to sign you up to evaluate some scenarios using this new stuff?

(after this test, SFQ was fixed to perform equivalently to QFQ [3], and in either case, now, we see about a 65x improvement vs the default pfifo_fast qdisc... and there is more in the loop for 3.3, notably SFQRED [5])

While I am writing some tests on my own, my own efforts are focused on fixing the home router disaster[4], and the beneficial effects of all the new stuff extend out to servers and desktops as well, and I lack the hardware and time to play with your test suite all that much, although I'm going to try a few things in the coming weeks.

I can, however, suggest several useful test scenarios for you... this is the simplest

Build a couple 3.3 kernels, test for a baseline, then in order:

1) switch the qdiscs to 'sfq' (tc qdisc add dev whatever root sfq) run your network related tests

2) Turn off GSO and TSO (via ethtool) and with sfq on, run your network related tests.

3) Hammer down on BQL's controller some with max_limit

There are many other options available to play with such as qfq, and sfq can be tuned up to handle bigger workloads soon [5] but that requires somewhat more setup than what I describe above.

I figure fixing bufferbloat would be of deep interest to your readers, particularly the network gamers.

Footnotes:

1: two bloat articles in acm queue
http://queue.acm.org/detail.cfm?id=2076798
http://queue.acm.org/detail.cfm?id=2071893
2: http://linuxplumbersconf.org/2011/ocw/proposals/171
3: http://www.spinics.net/lists/netdev/msg184613.html
4: http://www.bufferbloat.net/projects/cerowrt
5: http://www.spinics.net/lists/netdev/msg185147.html

If any Phoronix readers do do some further exploring of Byte Queue Limits, feel free to share your findings within the forums.

About The Author
Michael Larabel is the principal author of Phoronix.com and founded the web-site in 2004 with a focus on enriching the Linux hardware experience and being the largest web-site devoted to Linux hardware reviews, particularly for products relevant to Linux gamers and enthusiasts but also commonly reviewing servers/workstations and embedded Linux devices. Michael has written more than 10,000 articles covering the state of Linux hardware support, Linux performance, graphics hardware drivers, and other topics. Michael is also the lead developer of the Phoronix Test Suite, Phoromatic, and OpenBenchmarking.org automated testing software. He can be followed via and or contacted via .
Latest Articles & Reviews
  1. Ubuntu vs. Fedora Linux On Lenovo's X1 Carbon With Core i7 Broadwell
  2. Ubuntu 15.04 Is The Easy Path To Better Performance On Intel Broadwell
  3. NVIDIA's Latest Maxwell Line-Up Against AMD With Catalyst On Linux
  4. Preliminary Tests Of Intel Sandy Bridge & Ivy Bridge vs. Broadwell
  5. AMD FX-8320E Performance On Linux
  6. Linux Compiler Benchmarks Of LLVM Clang 3.5 vs. LLVM Clang 3.6-rc1
Latest Linux News
  1. DNF Plugins Extend The Functionality Of Fedora's Yum Successor
  2. LibreOffice 4.4 Released With Better OOXML Support, UI Improvements
  3. Inkscape 0.91 Goes Through C++ Code Conversion, New Cairo Rendering, OpenMP Filters
  4. New Mesa Patch To Improve CPU-Bound Applications
  5. LLVM Adds Options To Do Fuzz Testing
  6. Coreboot Now Supports Another Dual-Socket AMD Motherboard
  7. Atomic Mode-Setting/Display Support Progresses In Linux 3.20
  8. NVIDIA 340.76 Brings Three Stable Fixes
  9. Intel Broadwell-U P-State vs. ACPI CPUFreq Scaling Linux Performance
  10. DragonFlyBSD Is Almost To Linux 3.10 Era Intel Graphics Support
Most Viewed News This Week
  1. PlayStation 4 System Compiler Support Landing In LLVM
  2. LibreOffice 4.4 Is Coming Soon With New Features
  3. My Initial Intel Broadwell Linux Experience With The ThinkPad X1 Carbon
  4. Broadwell Linux Ultrabook Running MUCH Cooler Than Haswell
  5. LZHAM 1.0 Lossless Data Compression Codec Released
  6. Linux Users Upset By Chromium's Busted HiDPI Support
  7. Interstellar Marines On Linux With Catalyst: Bull S*#@
  8. Faster VP9 Decoding Is On The Horizon