The UMTS Radio Resource Control (RRC) is a state machine that governs the transmission capabilities and power consumption state of a UMTS (i.e. 3G) modem. For a good reference on this state machine, read this paper.
The software available in this page is a Linux kernel module that emulates all the characteristics of UMTS networking by modeling the RRC state machine. With it, you can turn a regular host and network interface into an UMTS modem, and emulate cellular 3G networking for fun and for experiments.
The characteristics you can emulate are: upstream and downstream bandwidth, packet loss, latency, jitter, RLC FACH buffer thresholds, RRC state machine timers, RRC transition periods with average and standard deviation, and fast dormancy.
This software was written entirely by Andres Lagar-Cavilla (andres at lagarcavilla dot org), whose page you're visiting. It was written while employed at AT&T Labs Research, who own the Intellectual Property and have graciously agreed to open source this code under the GPL license. The kernel module and iproute bindings are explicitly GPL v2, as indicated in the patches and code headers.
This work builds on the standard Linux Traffic Control infrastructure of qdiscs and classes. I don't dispute it could have been built in a more modular fashion, but what I offer here is quite powerful, and clean enough.
There are three main components to the software: the Linux Kernel module, the iproute tc modifications, and a set of convenience scripts.
The Linux Kernel module can be built applying these three patches in the order specified. If you don't know how to work with patches or patch queues, follow this or this reference.
The patches apply against a 2.6.18 kernel, your mileage may vary (but hopefully not greatly) for newer kernels. As you'll see, patches are fairly trivial to rebase.
Once applied, 'make menuconfig', go to Networking -- Networking Options -- QoS and/or fair queueing -- UMTS RRC state machine emulator (RRC), and choose to build that as a module. Then you need to rebuild modules and install sch_rrc.ko where appropriate (make modules_install would do that with a big hammer).
/usr/sbin/tc qdisc add dev eth0 root rrc help
Usage: ... rrc [ dchtail SECONDS (5) ]
[ fachtail SECONDS (12) ]
[ fachdchmu MILISECS (1500) ]
[ fachdchsigma MILISECS (500) ]
[ idlepromomu MILISECS (2000) ]
[ idlepromosigma MILISECS (1000) ]
[ rlcul BYTES (540) ]
[ rlcdl BYTES(475) ]
[ idletodch INTBOOL (yes) ]
[ inverted INTBOOL (yes) ]
[ delay MILISECS (30) ]
[ jitter MILISECS (10) ]
[ drop PERCENT (8) ]
[ dchdlrate MBPS (7) ]
[ dchulrate MBPS (1) ]
Best way to use this is through a set of scripts I've cooked. They all have a hardcoded path (/home/andres/src/cscripts/) you can sed (and a few other site-specific params like certain IP addresses):
vif sets general parameters for the virtual NIC (VM case) to which we will attach the emulation module.
filterio creates a set of iptables and ebtables rules that will prevent any Ethernet LAN-specific traffic from reaching the emulated NIC, thus more faithfully emulating an UMTS environment.
filterclean clears the filtering rules set by filterio.
redir_all_ifb the primary setup script, with a RULE statement you can suit to your liking. See comments and examples.
tcclear clears the rules that set up the emulation.
showoff shows all relevant stats out of the emulation and traffic control modules.
The first block is the current parameters, but the second block shows you the goods about what has been going on: number of packets and bytes sent in each direction and each mode, number of switches, time spent in each mode. And number of fast dormancy calls and their effects.
Try 'tc qdisc change dev ifb0 root rrc fastdormancy'. This will emulate a fast dormancy call, which abruptly drops the state machine out of whatever state it was into IDLE. Useful for experimenting to see what the impact of that is on a traffic workload!