Overview of the CeroWrt Project

Bufferbloat is a huge drag on Internet performance created, ironically, by previous attempts to make it work better. Eric Raymond wrote this one-sentence summary of the problem: "Bloated buffers lead to network-crippling latency spikes." You can read more about this problem at the main Bufferbloat site.

CeroWrt is a project built upon the OpenWrt firmware to resolve these endemic problems in home networking today, and to push the state of the art of edge networks and routers forward. Projects include proper IPv6 support, tighter integration with DNSSEC, and most importantly, reducing bufferbloat in both the wired and wireless components of the stack.

The code is 100% open source, top to bottom. No binary blobs whatsoever. Every aspect of the code and hardware can be inspected and/or modified. The work is woefully underfunded, please help if you can.

News

The current CeroWrt 3.7.5-2 is build 3.7.5-2 , codenamed "Modena", built Feb 3, 2013. Read the CeroWrt 3.7 Release Notes or the News Page for details.

This is a solid release. We believe it offers a significant improvement to the bufferbloat problem, and deserves wider testing.

Roadmap

Our plan is to produce a stable build that can be used as both a production router, and as a platform for further research into algorithms for solving state of the art problems in networking. The CeroWrt 3.7 series of builds include the following features and capabilities:

  • Linux 3.7.5 kernel. Many of the fixes for bufferbloat are being implemented in this 3.7 kernel, so we are tracking these developments carefully. http://kernel.org
  • We have included a version of the CoDel algorithm from Kathie Nicols and Van Jacobson, along with Eric Dumazet's fair queueing enhancements. These in turn rely on the Byte Queue Limits code that's in the Linux Kernel 3.3. These replace earlier Active Queue Management fixes for bufferbloat including: Stochastic Fair Queueing-Random Early Drop (SFQRED), working ECN, and other queue disciplines
  • There are also two newer versions of fq_codel under test, as well as an implementation of the current ns2 model of codel itself.
  • IPv6 support. Another major goal of CeroWrt is to make IPv6 networking in the home as simple as IPv4.
  • Babel mesh routing protocol (Quagga RE-0.99.17.11 release). RA, bgp, rip, ripng, and ospf are also supported
  • DNSSEC and DNSSEC proxying - Secure extensions to the DNS system. Proxying is currently in testing.
  • OpenWrt features. Because we track the OpenWrt code base carefully, we incorporate most of the capabilities of that distribution. We actively push our changes/enhancements back toward the OpenWrt trunk. http://openwrt.org
  • An attractive web GUI for configuration - LuCI

Sources of Information about the project

Glossary for Bufferbloat Topics: Glossary
General Bufferbloat list: https://lists.bufferbloat.net/listinfo/bloat
CeroWrt-devel list: https://lists.bufferbloat.net/listinfo/cerowrt-devel
CeroWrt-Commits list: https://lists.bufferbloat.net/pipermail/cerowrt-commits/
Lab Notebook in Github: https://github.com/dtaht/deBloat
IRC: Find us on IRC on chat.freenode.net, #bufferbloat channel
Assorted Bufferbloat Videos

Try the Software

The current Linux 3.7 build is a solid release. We believe it offers a significant improvement to the bufferbloat problem, and deserves wider testing. Lots of people are using these builds as a second router in their homes. Many are using it as their production router.

Download the current CeroWrt 3.7 build: http://snapon.lab.bufferbloat.net/~cero2/cerowrt/wndr/3.7.5-2/

Hardware Requirements

To minimize the effects of hardware dependencies, we have chosen the Netgear WNDR3700v2 or WNDR3800 as the sole hardware for the experiments. The open source support for it is extensive, it has a capable processor with 16MB of flash and 64MB of RAM, it supports a USB flash stick, they are inexpensive (around $120-130). The WNDR3800 has more RAM (128MB instead of 64), but either of these models will be fine for these experiments. The WNDR3700v3 and v4 models that have recently appeared on the market do not work with CeroWrt; purchase the WNDR3800 if you want to be future-proof.

There are ubnt builds available as well, but specialized for a specific deployment scenario. Ask if you want them.

Documents

The documents below describe the current Linux 3.7 builds.

Tech Notes for CeroWrt

The following give detailed descriptions of CeroWrt's operation.

Older Information

The Historical Documents page links to many documents that describe the history and earlier releases of the project.

flanders320fade.jpg (18.4 kB) Rich Brown, 01/22/2012 12:14 pm