[patch 1/4] - Potential performance bottleneck for Linxu TCP
From: Wenji Wu
Date: Wed Nov 29 2006 - 18:29:13 EST
From: Wenji Wu <wenji@xxxxxxxx>
Greetings,
For Linux TCP, when the network applcaiton make system call to move data
from
socket's receive buffer to user space by calling tcp_recvmsg(). The socket
will
be locked. During the period, all the incoming packet for the TCP socket
will go
to the backlog queue without being TCP processed. Since Linux 2.6 can be
inerrupted mid-task, if the network application expires, and moved to the
expired array with the socket locked, all the packets within the backlog
queue
will not be TCP processed till the network applicaton resume its execution.
If
the system is heavily loaded, TCP can easily RTO in the Sender Side.
Attached is the patch 1/4
best regards,
wenji
Wenji Wu
Network Researcher
Fermilab, MS-368
P.O. Box 500
Batavia, IL, 60510
(Email): wenji@xxxxxxxx
(O): 001-630-840-4541
Attachment:
tcp.c.patch
Description: Binary data