Rajiv Chakravorty, Sachin Katti, Jon Crowcroft, Ian Pratt
{firstname.lastname}@cl.cam.ac.uk
University of Cambridge Computer Laboratory,
JJ Thomson Avenue, Cambridge CB3 0FD, U.K.
In this paper we examine the performance of TCP and HTTP over GPRS, and show how certain network characteristics interact badly with TCP to yield problems such as: link under-utilization for short-lived flows, excess queueing for long-lived flows, ACK compression, poor loss recovery, and gross unfairness between competing flows.
We present the design and implementation of a transparent TCP proxy that mitigates many of these problems without requiring any changes to the TCP implementations in either mobile or fixed-wire end systems.
The proxy transparently splits TCP connections into two halves, the wired and wireless sides. Connections destined for the same mobile host are treated as an aggregate due to their statistical dependence. We demonstrate packet scheduling and flow control algorithms that use information shared between the connections to maximise performance of the wireless link while inter-working with unmodified TCP peers. We also demonstrate how fairness between flows and response to loss is improved, and that queueing and hence network latency is reduced. We conclude that installing such a proxy into GPRS network would be of significant benefit to users.
World over, GSM cellular networks are being upgraded to support the General Packet Radio Service (GPRS). GPRS offers ``always on" connectivity to mobile users, with wide-area coverage and data rates comparable to that of conventional fixed-line telephone modems. This holds the promise of making ubiquitous mobile access to IP-based applications and services a reality.
However, despite the momentum behind GPRS, surprisingly little has been done to evaluate TCP/IP performance over GPRS. There are some interesting simulation studies [1,4], but we have found actual deployed network performance to be somewhat different.
Some of the performance issues observed with GPRS are shared with wireless LANs like 802.11b, satellite systems, and other wide-area wireless schemes such as Metricom Ricochet and Cellular Digital Packet Data (CDPD). However, GPRS presents a particularly challenging environment for achieving good application performance.
In this paper, we present our practical experiences using GPRS networks, and our attempts to improve their performance. In section II we briefly report on work to characterize GPRS link behaviour (see [30] for a fuller treatment). Section III identifies particular problems experienced by TCP running over GPRS, and examines how these are exacerbated by application-layer protocols such as HTTP.
In section IV we introduce the design of our TCP proxy, which is inserted into the network near the wired-wireless border and aims to transparently improve the performance of TCP flows running over the network without requiring modifications to either the wired or wireless end systems. In particular, we demonstrate how there are significant advantages to treating all TCP flows to a particular mobile host as an aggregate, taking advantage of the flows' statistical dependence to perform better scheduling and flow control in order to maximise link utilizaton, reduce latency, and improve fairness between flows.
Sections V and VI describe the experimental setup and present an evaluation of our proxy's performance. The paper goes on to discuss related work, and how flow aggregation could be added as an extension to existing TCP implementations.
GPRS [1,2,3], like other wide-area wireless networks,
exhibits many of the following characteristics: low and fluctuating
bandwidth, high and variable latency, and occasional link `blackouts' [7,8,9].
To gain clear insight into the characteristics of the GPRS link, we have
conducted a series of link characterization experiments. A comprehensive
report on GPRS link characterization is available in the form of a separate
technical report [30].
Below, we enunciate some key findings:
High and Variable Latency:-
GPRS link latency is very high, 600ms-3000ms for the downlink and
400ms-1300ms on the uplink. Round-trip latencies of 1000ms or more are typical.
The delay distribution is shown in figure 1. The link also has a
strong tendency to `bunch' packets; the first packet in a burst is
likely to be delayed and experience more jitter than following
packets.
The additional latency for the first packet is typically due
to the time taken to allocate the temporary block flow (TBF) [28,29].
Since most current GPRS terminals allocate and release TBFs immediately
(implementation based on GPRS 1997 release), protocols (such as TCP) that
can transfer data (and ack) packets spaced in time may end up creating
many small TBFs that can each add some delay (approx. 100-200ms) during
data transfer.
The latest release (GPRS 1999) does consider an extended TBF
life-time; however, this optimization can lead to inefficient scheduling at
the base station controller (BSC), with some improvement (100ms)
in overall RTTs [28].
![]() ![]() |
Fluctuating Bandwidth:- We observe that signal quality
leads to significant (often sudden) variations in
perceivable bandwidth by the receiver. Sudden signal quality fluctuations (good
or bad) commensurately impact GPRS link performance. Using a ``3+1''
GPRS phone such as the Ericsson T39 (3 downlink channels, 1 uplink),
we observed a maximum raw downlink throughput of about 4.15 KB/s, and
an uplink throughput of 1.4 KB/s. Using a ``4+1'' phone, the Motorola
T280, we measured an improved maximum bandwidth of 5.5 KB/s in the
downlink direction. Conducting these tests at various times
of the day and at different locations revealed no evidence of network
(channel) contention occurring. This is perhaps to be expected due to
the currently small number of GPRS users and the generous time slot
provisioning employed by most operators.
Packet Loss:-
The radio link control (RLC) layer in GPRS uses an automatic repeat
request (ARQ) scheme that works aggressively to recover from link layer
losses. Thus, higher-level protocols (like IP) rarely experience
non-congestive losses.
Link Outages:- Link outages are common while moving at speed or, obviously, when passing through tunnels or other radio obstructions. Nevertheless, we have also noticed outages during stationary conditions. The observed outage interval will typically vary between 5 and 40s. Sudden signal quality degradation, prolonged fades and intra-zone handovers (cell reselections) can lead to such link blackouts. When link outages are of small duration, packets are justly delayed and are lost only in few cases. In contrast, when outages are of higher duration there tend to be burst losses.
Occasionally, we also observed downlink transfers to stop altogether during transfers. We believe this to be a specific case of link-reset, where a mobile terminal would stall and stop listening to its TBF. We believe this to be due to inconsistent timer implementations within mobile terminals and base station controllers (BSCs). Recovering from such cases required the PPP session to be terminated and restarted.
In this section we discuss TCP performance problems over GPRS. In
particular, we concentrate on connections where the majority of data
is being shipped in the downlink direction, as this corresponds to the
prevalent behaviour of mobile applications, such as web browsing, file
download, reading email, news etc. We provide a more complete
treatment on TCP problems over GPRS in [7].
TCP Start-up Performance:- Figure 2(a) shows
a close up of the first few seconds of a connection, displayed
alongside another connection under slightly worse radio conditions.
An estimate of the link bandwidth delay product (BDP) is also marked,
approximately 10KB. This estimate is approximately correct
under both good and bad radio conditions, as although the link
bandwidth drops under poor conditions the RTT tends to rise. For a
TCP connection to fully utilize the available link bandwidth, its
congestion window must be equal or exceed the BDP of the link. We can
observe that in the case of good radio conditions, it takes about 6
seconds from the initial connection request (TCP SYN) to ramp the congestion window up to the link BDP. Hence, for
transfers shorter than about 18KB, TCP fails to even exploit the
meagre bandwidth that GPRS makes available to it. Since many HTTP
objects are smaller than this size, the effect on web browsing
performance can be substantial.
![]() ![]() |
ACK Compression:- A further point to note in figure
2(b) is that the sender releases packets in bursts in
response to groups of four ACKs arriving in quick succession.
Receiver-side traces show that the ACKs are generated in a smooth
fashion in response to arriving packets. The `bunching' on the uplink
is due to the GPRS link layer (see, [9]). This effect is not
uncommon, and appears to be an unfortunate interaction that can occur
when the mobile terminal has data to send and receive concurrently.
ACK bunching or compression [15] not only skews upwards
the TCP's RTO measurement but also affects its self-clocking strategy.
Sender side packet bursts can further impair RTT measurements.
Excess Queuing:- Due to its low bandwidth, the GPRS
link is almost always the bottleneck of any TCP connection, hence
packets destined for the downlink get queued at the gateway onto the
wireless network (known as the CGSN node in GPRS terminology, see
figure 8). However, we found that the existing GPRS
infrastructure offers substantial buffering: UDP burst tests indicate
that over 120KB of buffering is available in the downlink direction.
For long-lived sessions, TCP's congestion control algorithm could fill
the entire router buffer before incurring packet loss and reducing its
window. Typically, however, the window is not allowed to become quite
so excessive due to the receiver's flow control window, which in most
TCP implementations is limited to 64KB unless window scaling is
explicitly enabled. Even so, this still amounts to several times the
BDP of unnecessary buffering, leading to grossly inflated RTTs due to
queueing delay. Figure 3 (b) shows a TCP connection in such a
state, where there is 40KB of outstanding data leading to a measured
RTT of tens of seconds. Excess queueing exacerbates other issues:
RTT Inflation - Higher queueing delays can severely degrade TCP performance [10]. A second TCP connection established over the same link is likely to have its initial connection request time-out [5].
Inflated Retransmit Timer Value - RTT inflation results in an inflated retransmit timer value that impacts TCP performance, for instance, in cases of multiple loss of the same packet [5].
Problems of Leftover (Stale) Data - For downlink channels, the queued data may become obsolete when a user aborts a web download and abnormally terminates the connection. Draining leftover data from such a link may take many seconds.
Higher Recovery Time - Recovery from timeouts due
to dupacks (or sacks) or coarse timeouts in TCP over a saturated GPRS
link takes many seconds. This is depicted in figure 3(a) where the
drain time is about 30s.
![]() ![]() |
TCP loss recovery over GPRS:- Figure 3(a)-(b)
depicts TCP's performance during recovery due to reception of a dupack
(in this case a SACK). Note the long time it takes TCP to recover
from the loss, on account of the excess quantity of outstanding data.
Fortunately, use of SACKs ensures that packets transferred during the
recovery period are not discarded, and the effect on throughput is
minimal. This emphasises the importance of SACKs in the GPRS
environment. In this particular instance, the link condition happened
to improve significantly just after the packet loss, resulting in
higher available bandwidth during the recovery phase.
![]() |
Fairness between flows:- Excess queueing can lead to gross unfairness between competing flows. Figure 4 shows a file transfer (f2) initiated 10 seconds after transfer (f1). When TCP transfer (f2) is initiated, it struggles to get going. In fact it times out twice on initial connection setup (SYN) before being able to send data. Even after establishing the connection, the few initial data packets of f2 are queued at the CGSN node behind a large number of f1 packets. As a result, packets of f2 perceive very high RTTs (16-20 seconds) and bear the full brunt of excess queueing delays due to f1. Flow f2 continues to badly underperform until f1 terminates. Flow fairness turns out to be an important issue for web browsing performance, since most browsers open multiple concurrent HTTP connections [19]. The implicit favouring of long-lived flows often has the effect of delaying the ``important'' objects that the browser needs to be able to start displaying the partially downloaded page, leading to decreased user perception of performance.
Having identified the causes of poor TCP performance over GPRS, we set out to determine whether the situation could be improved. Our fundamental constraint was that we wanted to improve performance without requiring any changes to be made to the network protocol stacks of either the fixed or mobile TCP end systems: Experience shows that the vast majority of schemes that require such changes are doomed to never see widespread deployment.
Instead, we focused on what could be achieved through the use of a proxy located close to the wired-wireless network boundary, able to see all traffic heading to and from the mobile host. A `split TCP' [6] approach was adopted, whereby the proxy transparently divides the connection into two halves: one from the fixed host to the proxy and the other from the proxy to the mobile host. The TCP stacks on both the mobile and wired-facing sides of the proxy can be modified as necessary, providing they can still communicate with conventional implementations. We can exploit the fact that the packet-input code in all TCP stacks we have encountered will accept and process all validly formed TCP packets it receives without concern as to whether the transmitter is actually operating the congestion control algorithms mandated in the various TCP RFCs.
Concentrating on the critical mobile downlink direction, the goals for the proxy were as follows:
Improved Utilization - Failing to utilize the available bandwidth on `long-thin' links when there is data to send is clearly wasteful.
Fairness - A `fair' allocation of bandwidth to competing flows regardless of their age or RTT.
Error Detection and Recovery - GPRS link performance is characterised by occasional link stalls during hand-offs and the occurrence of burst losses. A loss detection and recovery scheme tailored for this environment might avoid unnecessary backing-off or packet retransmission.
Effective Flow Control Mechanism - We wished to avoid the problems with excessive buffering at the wired-wireless gateway, and have the proxy take responsibility for effective buffer management using `smart' techniques.
In conventional TCP implementations, every connection is independent, and separate state information (such as srtt, cwnd, ssthresh etc.) is kept for each. However, since all TCP connections to a mobile host are statistically dependent (since they share the same wireless link), certain TCP state information might best be shared between flows to the same mobile host. On the wireless-facing side, our proxy treats flows to the same mobile host as a single aggregate. The scheme is depicted in figure 5. Hari Balakrishnan et al. [13] show that flows can learn from each other and share information about the congestion state along the network path, which they call shared state learning. They use it as a basis for their congestion manager.
On similar lines, our proxy can share state including a single congestion window and RTT estimates across all TCP connections within the aggregate. Sharing state information enables all the connections in an aggregate to have better, reliable, and more recent knowledge of the wireless link. We therefore take all the state information and group it together into one structure that we call an Aggregate Control Block (ACB). All individual TCP connections reference this structure as part of their local state. Details of this structure are given in figure 6.
The wired-facing side of the proxy is known as the AggregateTCP (ATCP) client, while the mobile-facing side is called the ATCP sender. The ATCP client receives packets into small per-connection queues, that feed into a scheduler operating on behalf of the whole aggregate. A single congestion window for the whole aggregate is maintained, and whenever the level of unacknowledged data on the wireless link drops one MSS (Maximum Segment Size) below the size of the current congestion window the scheduler selects a connection with queued data from which a further segment will be sent. Of course, while making the selection the scheduler must respect the mobile host's receive window for each of the individual flows. Once transmitted, segments are kept in a queue of unacknowledged data until ACK'ed by the mobile host. The ATCP sender can perform retransmissions from this queue in the event of loss being signalled by the mobile host, or from the expiry of the aggregate's retransmission timer.
The ATCP client employs `early ACKing', acknowledging most packets it receives from hosts as soon as they are accepted into the per-flow queues, before the destination end system receives them. The practical effect this has on TCP's end-to-end semantics is mitigated by never using early acknowledgement for FINs. Since the per-connection queues contain re-assembled data, the proxy can sometimes coalesce multiple small packets from the sender into a single segment by the time it is sent over the wireless link. This can help to reduce protocol header overhead.
![]() |
Our proxy can employ different connection scheduling strategies depending on the nature of the incoming traffic. Presently, we use a combination of priority-based and ticket-based stride scheduling [11] to select which connection to transmit from. This enables us to give strict priority to interactive flows (such as telnet) while, for example, sharing out the remaining bandwidth in a fixed ratio between WWW and FTP flows.
Within this framework, the proxy optimizes GPRS link performance using three key mechanisms described in the following sections.
A major cause of poor performance with TCP over GPRS is link under utilization during the first few seconds of a connection due to the pessimistic nature of the slow start algorithm.
Slow start is an appropriate mechanism for the Internet in general, but within the proxy, information is available with which we can make better informed decisions as to congestion window size.
The ATCP Sender uses a fixed size congestion window (cwnd), shared across all connections in the aggregate. The size is fixed to a relatively static estimate of the Bandwidth Delay Product (BDP) of the link. Thus, slow start is eliminated, and further unnecessary growth of the congestion window beyond the BDP is avoided. We call this TCP cwnd clamping.
The underlying GPRS network ensures that bandwidth is shared fairly amongst different users (or according to some other QoS policy), and hence there is no need for TCP to be trying to do the same based on less accurate information. Ideally, the CGSN could provide feedback to the proxy about current radio conditions and time slot contention, enabling it to adjust the `fixed' size congestion window, but in practice this is currently unnecessary.
Once the mobile proxy is successful in sending amount of
data it goes into a self-clocking state in which it clocks out one
segment (from whatever connection the scheduler has selected) each
time its receives an ACK for an equivalent amount of data from the
receiver. With an ideal value of
, the link should never
be under utilised if there is data to send, and there should only ever
be minimal queueing at the CGSN gateway. Typically, the ideal
ends up being around 30% larger than the value calculated
by multiplying the maximum link bandwidth by the typical link
RTT. This excess is required due to link jitter, use of delayed
ACKs by the TCP receiver in the mobile host, and ACK compression
occurring due to the link layer.
While starting with a fixed value of cwnd, the mobile proxy
needs to ensure that any initial packet burst does not overrun CGSN
buffers. Since the BDP of current GPRS links is small
(10KB), this is not a significant problem at this
time. Future GPRS devices supporting more downlink channels may
require the proxy to employ traffic shaping to smooth
the initial burst of
packets to a conservative estimate of the link bandwidth. The error
detection and recovery mechanisms used by the ATCP Sender are
discussed in section IV-E.
When the proxy `early ACKs' a packet from a client it is committing buffer space that can not be released until the packet is successfully delivered to the mobile host. Hence, the proxy must be careful how much data it accepts on each connection if it is to avoid being swamped. Fortunately, it can control the amount of data it accepts through the receive window it advertises to hosts.
The proxy must try to ensure that sufficient data from connections is buffered so that the link is not left to go idle unnecessarily (for example, it may need to buffer more data from senders with long RTTs - perhaps other mobile hosts), but also limit the total amount of buffer space committed to each mobile host. Furthermore, we wish to control the window advertised to the sending host in as smooth a fashion as possible. Zero window advertisements should only be used as a last resort, for example, during an extended wireless link stall.
Some studies in the past have investigated receiver advertized window adaptation schemes. In [17], L. Kalampoukas et al. present Explicit Window Adaptation (EWA), which controls the end-to-end receiver advertized window size in TCP to correspond to the delay-bandwidth product of the link. In this scheme, active TCP connections are allowed to adapt automatically to the traffic load, the buffer size and bandwidth-delay product of the network without maintaining any per-connection state. Likewise, L.L.H. Andrew et al. [18] propose a TCP flow-control scheme that takes feedback available from an access router to set the TCP receiver window. The scheme claims a higher utilization for TCP flows while still preserving system stability. Following a similar approach, we build on this flow control scheme, utilising feedback available from the aggregate about the wireless link performance.
The pseudo code for the flow control scheme is given. Notice the algorithm used
during connection startup (denoted by Connection_Start_Phase) is different
from that used during the later phase. During the connection start-phase, each
received packet is ACKed as early as possible and the advertised window is
calculated as follows:
Consider to be current average sending rate of the aggregate
per connection and
the running average of the sending rates
over the wireless link for connection
. We calculate
as
a sliding window averaging function given by:
We consider the case of a single (first) TCP connection in an aggregate.
To start with, we can use an initial value of advertized window of
=
, where
(
) corresponds to the bandwidth-delay
product of the GPRS downlink. A fixed GPRS-specific
value
can be used initially and later estimated (using appropriate estimation
filters [22]), while
- the initial sending rate can also
be intially estimated.
is the over-provision factor, and gives control over an
aggregate's buffer target set-point. In experiments, we have
over-provisioned each aggregate buffer by 50% of the link BDP, which
has ensured that there is always sufficient data to avoid
under-utilization of the GPRS link.
When more new connections join the aggregate (as typically
happens in web-sessions), any new connection `' will likely satisfy
the condition,
where is a function of maximum segment size (MSS), and is calculated
as
,
where
is number of connections in the aggregate at time
. For the first
advertized window value for any connection,
, hence
.
This ensures that new and small connections are not discriminated
against during the initial start phase by bringing the
connection up to the average sending rate of the aggregate so that it achieves parity
with other already `established' connections.
For those TCP flows that
eventually
have a sending rate equal to or
exceeding the average sending rate over the GPRS link, the flow control algorithm
described below takes over.
The steady-state flow control algorithm advertises a window size
for connection calculated using:
where is the instant when the last packet was sent over the wireless link
for the
connection.
is the constant rate at which
the window increases and
is the overall queue occupancy of
the aggregate buffer (shown in the Pseudocode as Queue_Occupancy) at
time instant
.
Also the cost function is calculated as:
As also shown in the pseudocode, the scheme is modified to make
use of feedback from the wireless link to a particular mobile host
from the aggregate. So in the case of link stalls, a timeout
at the wireless side (shown as Wireless_Link_Timeout in pseudocode)
would result in the advertised window being set to zero. Upon recovery,
we restore the previously advertized window size. Normal flow control takes
over after recovery and brings the system state to equilibrium. This flow
control scheme works effectively to control the proxy's buffer
utilization, and although a little elaborate for that required by
current GPRS networks should scale to much higher bandwidths, and can
be easily applied to other split TCP applications.
Packet losses over a wireless link like GPRS can usually occur due to two reasons: (1) bursty radio losses that persist for longer than the link-layer is prepared to keep retransmitting a packet, and (2) during cell reselections due to cell update procedure (or routing area update) that can lead to a `link-stall' condition from few to many seconds [28]. In both cases, consecutive packets in a window are frequently lost. TCP detects these losses through duplicate ACKs, or timeouts in the extreme case. Not knowing the `nature' of the loss, it reacts by invoking congestion control measures such as fast retransmit or slow start. However, since the link frequently returns to a healthy state after the loss, unnecessary back-off is often employed resulting in under-utilization.
The split TCP aggregate approach of our proxy affords us the opportunity of improved detection of the nature of wireless losses, and hence make a better job of recovery. The aim is to recover aggressively from transient losses, keeping the link at full utilization, but be careful during extensive stalls or blackouts not to trigger unnecessary retransmission.
TCP-SACK enables the receiver to inform the sender of packets which it has received out of order. The sender can then selectively retransmit in order to fill in the gaps. When this feature is used along with the flow aggregation concept, it gives us an elegant mechanism to discover sequence gaps across the entire gamut of packets sent by the Aggregate TCP Sender, and thereby improves our ability to determine the nature of the loss. This improved diagnosis coupled with a recovery strategy fine tuned for the wireless link results in good utilization. The scheme is described further below, and figure 7 depicts a snapshot of it in action.
Normal Ack -
The ACB maintains a list of unacknowledged packets. Associated with
each packet in the list is a field called . Whenever an ACK
is received for a packet in the list it is removed. The
variable of packets which were sent before the acknowledged packet are
then incremented. We do this based on the observation that due to the
nature of the GPRS link-layer, packet re-ordering does not occur. We
assume packets belonging to the same connection are processed by the
mobile host in FIFO order. Thus, an ACK received for a newer packet
implies loss or corruption of older packets in the same connection.
Bursty Error Period -
When there is a bursty error period on the wireless link, multiple
packets will be lost. This will result in the generation of duplicate
ACKs with SACK information. Packets which are SACKed are marked so
that they are not retransmitted later by setting . UnSACKed
packets (
) sent before the packet which was SACKed
have their
counter incremented. The key point is
that this is done not for the packets of just that particular connection,
but for the whole list of unacknowledged packets for
the aggregate. Thus when a dupack with SACK is received
for a particular connection the
counter for the packets of
all connections which were sent before that packet and have not been
SACKed are incremented. This is justified since sending order
is maintained during reception of ACKs.
However, care must be taken since TCP connections to a mobile host are
independent, so ACKs of packets for connections sent later to the host
might arrive before packets that were sent earlier. This is not
unusual as connections may be employing delayed ACKs. However, if
further such `early ACKs' are received, it is increasingly indicative
of a transient loss necessitating recovery. Our recovery strategy
retransmits aggressively during a transient loss: We wait for the
counter to reach 3 then retransmit all packets having this
value in the list. A higher
retransmit counter value would
make the recovery scheme less agile, while lowering its value would
result in redundant retransmissions. Empirically, a value of 3 seems
to work well for the characteristics of GPRS.
Timeouts - Bursty error periods tend to be short compared to
round trip times. As described above, if the counter reaches
3 we can recover from a loss without resorting to an expensive
timeout. Hence by keeping the timeout value relatively conservative,
we can avoid timeouts after bursty error periods. Thus, timeouts only
occur during extensive blackouts or link stalls. It would be highly
wasteful to keep transmitting during a link blackout (for e.g. due to deep fading or during cell-reselection)
since a large proportion of the packets will likely be lost. Hence after a timeout
the cwnd is reduced to one. A single packet is transmitted until an
ACK is received. Once an ACK is received the cwnd is set back to
the original size since the reception of the ACK implies restoration
of the link. Hence after the first timeout, the timeout value is made
aggressive by setting it to
. Thus, after a
timeout the single packet being transmitted is effectively a `probe'
packet, and we should resume normal operation as soon as the link
recovers. Hence instead of exponentially backing off, a more aggressive
timeout value (linear backoff) is used to enable quick detection of link recovery.
Recovery strategy - In normal TCP, 3 duplicate ACKs trigger
fast retransmit. On our link, reception of duplicate ACKs signifies
that the link is currently in an operational state. Application of
fast retransmit would result in unnecessary back-off and hence
under-utilisation. Hence, we maintain cwnd at the same value -
packets whose counter has reached 3 are simply
retransmitted.
Our experimental test bed for evaluating the transparent proxy is shown in figure 8. The mobile terminal was connected to the GPRS network via a Motorola T260 GPRS phone (3 downlink channels, 1 uplink). Tests were performed with different mobile terminals, using Linux 2.4, Windows 2000 and WinCE 3.0. Vodafone UK's GPRS network was used as the infrastructure.
Base stations are linked to the SGSN (Serving GPRS Support Node) which is connected to a GGSN (Gateway GPRS Support node). Both the SGSN and GGSN nodes are co-located in a CGSN (Combined GPRS Support Node) in the current Vodafone configuration [31].
Since we were unable to install equipment next to the CGSN we made use of a well provisioned IPSec VPN tunnel to route all traffic via the Computer Laboratory. The proxy was then located at 5A 5A 5A 5A 5A 5A 5A the end of the tunnel, with routing configured so that all packets flowing to and from the mobile host are passed to it for processing. Packets arriving at the proxy that are to/from hosts in the mobile host address range are passed to the user-space proxy daemon by means of Linux's netfilter [32] module.
In the test described, a number of different remote `fixed' hosts were used, some located in the Lab, some elsewhere on the public Internet, and others were in fact other mobile hosts.
In this section, we discuss some preliminary results from experiments conducted over the GPRS testbed using our proxy. We evaluate how our transparent proxy achieves its goals of: faster flow startup; higher down-link utilization; improved fairness (and controllable priority); reduced queuing delays; and better loss recovery.
To quantify the benefits of avoiding slow-start for short TCP sessions, we performed a series of short (5KB-30KB) downloads from a test server that reflect web session behaviour. Each transfer for a given size was repeated 25 times, with traces recorded using tcpdump and later analysed.
![]() |
Figure 9 plots the transfer times with and without the mobile
proxy. The times shown include the full TCP connection establishment
and termination overhead, which constitutes a significant fraction of
the overall time for shorter transfers. However, the clamped
congestion window ( around 10KB in this case) can be seen to still
yield clear performance benefits.
The results reported above were performed using a mobile host running Linux 2.4, where we noted that the performance gain was less than with other platforms. This is due to Linux offering an initial receive window of just 5392 bytes. When used with a normal TCP sender, Linux expands the window sufficiently quickly for it to never be the limiting factor. However, since we skip slow start there is not time for the window to grow and it thus limits the quantity of data we can initially inject into the network, and hence we do not quite achieve our goal of full link utilization. We considered sending further data `optimistically', but rejected the idea as distasteful, and a potential source of compatibility problems.
Even with the Linux 2.4 receiver, the proxy provides significant performance gains for short lived flows as are prevalent with HTTP/1.0 transfers. This benefit is maintained and even enhanced when using HTTP/1.1 persistent TCP connections [8]. When using persistent connections it is normally the case that the server has to let the TCP connection go idle between object transfers since `pipelining' is rarely supported. Normally this results in the congestion window being set back to its initial two segment value. The proxy avoids this, and the resultant benefit is more pronounced due to the lack of connection establishment and termination phases.
![]() ![]() ![]() ![]() |
We configured the proxy to distribute equal tickets to incoming flows and hence demonstrate that fairness can be achieved between multiple connections. In the following experiments, we initiated one transfer, then started a second 20 seconds later.
Without the proxy, the top half of figure 10 shows the second flow taking a long time to connect, and then suffering very poor performance; it makes little progress until the first flow terminates at time 60 seconds. With the proxy, the second flow connects quickly, then receives a fair share of the bandwidth. The bottom left graph shows the bandwidth to the first flow being halved during the duration of the second flow. Thus, the proxy works as expected, enabling interactive applications to make progress in the face of background bulk transfers such as FTP.
In these tests, we demonstrate how the proxy can achieve reduced queueing (and hence RTT) while maintaining high throughput. A 600KB file is downloaded with and without the proxy. To demonstrate the effect the congestion window has on performance, the experiment has been repeated with the proxy configured such that it uses a static window of various nominated sizes. The experiments were performed under ideal radio conditions so as to minimise chances of packet loss.
|
Figure 11(a) shows that under these conditions the transfer takes 155 seconds with any window size greater than equal to 10KB. Below this size, the link is under utilized and throughput drops. If the window size is increased beyond 10KB the level of queueing increases, approaching that of the case without the proxy for a window size of 32KB. Figure 11(b) shows how these queues translate into elevated RTT.
We developed our TCP aggregate error recovery scheme using NS2 simulation of test cases. Further work to provide a thorough real-world evaluation of the scheme is on-going. Here, we show the implementation's response to a simple loss scenario (see figure 12). Around 90 seconds into a file transfer the link stalls, presumably due to a cell hand-off. A single retransmission occurs, and then the link recovers swiftly. This should be compared with the similar scenario without the proxy previously shown in figure 3 - recovery is significantly quicker.
![]() ![]() ![]() ![]() |
The academic literature contains a plethora of solutions for elevating performance over wireless links. Berkeley's SNOOP [14], delayed dupAcks scheme [26], M-TCP [23], I-TCP [20], Freeze-TCP [25], FDA [27], W-TCP [16], WTCP [24] and TCP Westwood [21] are some of the more important ones. Careful examination of existing schemes suggests four broadly different approaches: link-layer based schemes (both TCP aware and unaware) (e.g. [14,26]), split connection based approaches (e.g. I-TCP [20], W-TCP [16]) and early warning based approaches (e.g. FreezeTCP [25]) and finally those necessitating end system changes (e.g. WTCP [24], Freeze-TCP [25], TCP Westwood [21]).
|
Snoop [14] is a TCP aware link-layer scheme that `sniffs' packets in the base station and buffers them. If duplicate acknowledgements are detected, incoming packets from the mobile host are retransmitted if they are present in a local cache. On the wired side, dupacks are suppressed from the sender, thus avoiding unnecessary fast retransmissions and the consequent invocation of congestion control mechanisms. End-to-end semantics are preserved. However, when bursty errors are frequent, the wired sender is not completely shielded, leading to conflicting behaviour with TCP's retransmission mechanisms.
The Snoop protocol scheme was originally designed for wireless LANs rather than `long-thin' wide-area wireless links. As such, it does not address the problems of excess queueing at base stations or proxies. Jian-Hao et. al. developed FDA [27], which uses a Snoop-like strategy, but uses a novel flow-control scheme which goes some way to prevent excess queueing. Further, Snoop's link layer retransmissions and suppression of ACKs can inflate the TCP sender's RTT estimates and hence its timeout value, adversely affecting TCP's ability to detect error free conditions.
Delayed DupAcks [26] is a TCP unaware link-layer scheme: it
provides lower link-layer support for data retransmissions and a
receiver or mobile host side TCP modification that enables the
receiver to suppress DupAck's for some interval when packet(s)
are lost over radio. However, interval
is difficult to determine
as it depends on frequency of losses over the wireless medium. The
base station is not TCP aware, thus a receiver can not determine
whether a loss is due to radio errors or congestion, which can force
the sender to timeout in such situations. Further, DupAck bursts can
also aggravate congestion over wire-line links that have high BDP.
The second broad approach is to split the TCP connection into two sections. This allows wireless losses to be completely shielded from the wired ones. I-TCP [20] uses TCP over the wireless link albeit with some modifications. Since TCP is not tuned to the wireless link, it often leads to timeouts eventually causing stalls on the wired side. Due to the timeouts, valuable transmission time and bandwidth is also wasted. I-TCP could also run short of buffer space during periods of extended timeouts due to the lack of an appropriate flow control scheme.
M-TCP [23] is similar to I-TCP except it better preserves end-to-end semantics. M-TCP uses a simple zero window ACK scheme to throttle transmission of data from the wired sender. This leads to stop-start-stop bursty traffic on the wired connection, and the lack of buffering in the proxy can lead to link under-utilization for want of packets to send. Holding back ACKs also affects sender's RTT estimates, affecting TCP's ability to recover from non-wireless related packet losses.
Ratnam and Matta propose W-TCP [16], which also splits the connection at the base station. However, it acknowledges a packet to the sender only after receiving an acknowledgement from the mobile host. W-TCP changes the timestamp field in the packet to account for the time spent idling at the base station. Retransmission characteristics have been adjusted to be aggressive on the wireless side so that the link is not under-utilised.
WTCP [24] is an end-to-end scheme which primarily uses inter-packet separation as the metric for rate control at the receiver. Congestion related loss detection is also provided as a backup mechanism. The biggest drawback of WTCP is that it entails changes at both the wired sender and the mobile host. Even if a receiver side change can be envisaged, widespread adoption by wired senders seems unlikely.
TCP Westwood [21] is a scheme that improves TCP performance under random and sporadic losses, by desisting from overly shrinking the congestion window on packet loss. It does so by simultaneously estimating end-to-end bandwidth available to TCP, and uses it as a feedback measure to control the congestion window. However, it requires modification to TCP at the end-system.
The third broad approach identified covers schemes that use various kinds of early warning signals. Freeze TCP uses Zero Window Probes (ZWP) like M-TCP, but is proactive since the mobile host detects signal degradation and sends a Zero Window Warning Probe. The warning period i.e. the time before which actual degradation occurs should be sufficient for the ZWP to reach the sender so that it can freeze its window. The warning period is estimated on the basis of RTT values. One pitfall is the reliability of this calculation and Freeze-TCP's inability to deal with sudden random losses. Furthermore, Freeze-TCP requires end-system changes.
In this paper we have proposed a flow aggregation scheme to transparently enhance performance of TCP over wide area wireless links such as GPRS. The proposed scheme was implemented in a split TCP proxy and evaluated on a GPRS network testbed. The key features of the scheme are summarised below:
We are currently considering ways of improving our wireless link BDP estimation algorithm. Although not particularly critical for GPRS where the BDP stays roughly constant even under changing radio conditions and during cell re-selections (and/or routing-area updates), we feel that a more dynamic scheme may be required for next generation EDGE and UMTS (3G) systems. Calculating the BDP of the aggregate in a similar manner to that employed by TCP Vegas or Westwood seems a promising approach.
We have used the proxy with only a limited set of concurrent clients. It would be interesting to perform tests (part of our ongoing work) to identify how well the transparent proxy scales to a wider client base. We are recording tcpdump traces of all GPRS traffic generated by our user community, which will assist in evaluating system scalability and resulting user experience from using the proxy.
Work is also ongoing to perform more thorough evaluation of the flow control and error recovery schemes, using a combination of simulation and empirical analysis of the long-term packet traces we are collecting. Fine tuning of the scheme is bound to result.
Our current work has concentrated on the downlink direction as we perceive this as being the most critical direction for performance of most applications. We are considering how the split TCP approach could be used to improve the uplink, but the options without modifying the mobile host are rather more limited. Fortunately, vanilla uplink performance does not exhibit many of the gross issues posed by the downlink.
We wish to thank Vodafone Group R&D, Sun Microsystems Inc. and BenchMark Capital for supporting this work. Thanks also go to Tim Harris for comments on an earlier version of this paper and the INFOCOM'03 reviewers for their constructive input.
Mobile Radio Networks, Networking and Protocols (2. Ed.),
John Wiley & Sons, Chichester 2001
Source: http://www.cl.cam.ac.uk/users/rc277/gprs.html
Source: http://www.cl.cam.ac.uk/users/rc277/gprs.html
Source: http://www.cl.cam.ac.uk/users/rc277/gprs.html
Source: http://www.ee.mu.oz.au/staff/lha/LAicp.html
Source: http://www.cl.cam.ac.uk/users/rc277/linkchar.html
tcptrace(http://www.tcptrace.org),
ttcp+(http://www.cl.cam.ac.uk/Research/SRG/netos/netx/)
This document was generated using the LaTeX2HTML translator Version 2K.1beta (1.50)
Copyright © 1993, 1994, 1995, 1996,
Nikos Drakos,
Computer Based Learning Unit, University of Leeds.
Copyright © 1997, 1998, 1999,
Ross Moore,
Mathematics Department, Macquarie University, Sydney.
The command line arguments were:
latex2html -split 0 paper.tex
The translation was initiated by Rajiv Chakravorty on 2003-03-02