Skip site navigation (1)Skip section navigation (2)
Date:      Mon, 13 Dec 2004 18:30:47 +0100
From:      Andre Oppermann <andre@freebsd.org>
To:        freebsd-current@freebsd.org
Cc:        gallatin@cs.duke.edu
Subject:   Re: Rewritten TCP reassembly
Message-ID:  <41BDD1C7.7060105@freebsd.org>
In-Reply-To: <41BA0088.9000107@freebsd.org>
References:  <41BA0088.9000107@freebsd.org>

next in thread | previous in thread | raw e-mail | index | archive | help
Andre Oppermann wrote:
> I've totally rewritten the TCP reassembly function to be a lot more
> efficient.  In tests with normal bw*delay products and packet loss
> plus severe reordering I've measured an improvment of at least 30% in
> performance.  For high and very high bw*delay product links the
> performance improvement is most likely much higher.
> 
> The main property of the new code is O(1) insert for 95% of all normal
> reassembly cases.  If there is more than one hole the insert time is
> O(holes).  If a packet arrives that closes a hole the chains to the left
> and right are merged.  Artificially constructed worst case is O(n).  No
> malloc's are done for new segments.  The old code was O(n) in all cases
> plus n*malloc for a describing structure.
> 
> There are some problems with the new code I will fix before committing
> it to the tree.  One is it can't handle non-writeable mbuf's and the
> other is too little leading space in the mbuf (found only on loopback
> interface, but there we don't have packet loss).  Once these two are
> dealed with it is ready to go in.
> 
> Nothing is perfect and this code is only a first significant step over
> what we have currently in the tree, especially for transfers over lossy
> (wireless) and high speed links with and without packet reordering.
> I have the next steps already in the works which will further optimize
> (worst case O(windowsize/mclusters) instead of O(n)) and simplify a bit
> more again.
> 
> The patch can be found here:
> 
>  http://www.nrg4u.com/freebsd/tcp_reass-20041210.patch
> 
> Please test and report good and bad news back.

I've got some excellent review feedback from Mike Spengler and he found
a off-by-one queue limit tracking error.

  http://www.nrg4u.com/freebsd/tcp_reass-20041213.patch

Please test again.

-- 
Andre



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?41BDD1C7.7060105>