Thread (36 messages) 36 messages, 7 authors, 2013-05-03

Re: [net-next PATCH 1/4] Revert "inet: limit length of fragment queue hash table bucket lists"

From: Jesper Dangaard Brouer <hidden>
Date: 2013-05-03 09:15:16

On Thu, 02 May 2013 08:16:41 -0700
Eric Dumazet [off-list ref] wrote:
On Thu, 2013-05-02 at 09:59 +0200, Jesper Dangaard Brouer wrote:
quoted
On Wed, 24 Apr 2013 17:00:30 -0700 Eric Dumazet
[off-list ref] wrote:
quoted
On Wed, 2013-04-24 at 17:48 +0200, Jesper Dangaard Brouer wrote:
quoted
This reverts commit 5a3da1fe9561828d0ca7eca664b16ec2b9bf0055.

The problem with commit 5a3da1fe (inet: limit length of fragment
queue hash table bucket lists) is that, once we hit the hash
depth limit (of 128), the we *keep* the existing frag queues,
not allowing new frag queues to be created.  Thus, an attacker
can effectivly block handling of fragments for 30 sec (as each
frag queue have a timeout of 30 sec)
I do not think its good to revert this patch. It was a step in
right direction.
We need a revert, because we are too close to the merge window, and
cannot complete the needed "steps" to make this patch safe, sorry.
[...]
For people willing to allow more memory to be used, the only way is to
resize hash table, or using a bigger INETFRAGS_HASHSZ

I do not think there is a hurry, current defrag code is already better
than what we had years ago.
 
Eric I think we agree that:
 1) we need resizing of hash table based on mem limit
 2) mem limit per netns "blocks" the hash resize patch

Without these two patches/changes, the static 128 depth limit
introduces an undocumented limit on the max mem limit
setting (/proc/sys/net/ipv4/ipfrag_high_thresh).

I think we only disagree on the order of the patches.

But lets keep this, because after we have increased hash
size (INETFRAGS_HASHSZ) to 1024, we have pushed the "undocumented
limit" so-far that is very unlikely to be hit.  We would have to
start >36 netns instances, all being overloaded with small
incomplete fragments at the same time (30 sec time window).

--Jesper
Keyboard shortcuts
hback out one level
jnext message in thread
kprevious message in thread
ldrill in
Escclose help / fold thread tree
?toggle this help