Re: IPv4 and IPv6 stack multi-FIB, scalable in the million of entries.

From: Mathieu Giguere
Date: Thu Apr 08 2004 - 13:13:30 EST


Hi,

Why we need a routing cache? A patricia tree or radix tree is not fast
enough with the kind of memory speed we have in PC technologies now???

The main goal to remove the routing cache is to avoid to have 4096 routes
limitation + all problem of the cache is not flush correclty when default
route/next-hop for a particular route are change in the middle of a TCP
connection and are not consider at all. Also, when the routing cache is
finally flush, all the information about the PMTU of the other entries are
lost and must be rebuild. So it's a lot of rebuilding of information for
nothing when you have a lot of peer to talk with.

It's may look like overkill for a home user, but for commercial server, 4k
routes can be really fast exhauted. For us, we talking more about million
of routes in the system. Also, the patch I provide exploit already the
plug/and/pray of the fib. But doesn't give at all the flexibility to remove
the _unclean_ hack: the routing cache.

What is dirty form the current implementation, quick example spagetti code
with goto going back at the beginning of the function in route.c in IPV6.
All the mtu/pmtu put in the cache entries instead in the fib himself. Just
to name few examples.

/mathieu

----- Original Message -----
From: "Andi Kleen" <ak@xxxxxx>
To: "Mathieu Giguere" <Mathieu.Giguere@xxxxxxxxxxx>
Cc: <netdev@xxxxxxxxxxx>; <linux-kernel@xxxxxxxxxxxxxxx>
Sent: Thursday, April 08, 2004 1:18 PM
Subject: Re: IPv4 and IPv6 stack multi-FIB, scalable in the million of
entries.


> "Mathieu Giguere" <Mathieu.Giguere@xxxxxxxxxxx> writes:
>
> [you should probably discuss that on netdev@xxxxxxxxxxx instead, cc'ed]
>
> > We currently looking for a multi-FIB, scalable routing table in the
> > million of entries, no routing cache for IPv4 and IPv6. We want a IP
stack
>
> No routing cache? Doesn't sound like a good idea.
>
> > that can have a log(n) (or better) insertion/deletion and lookup
> > performance. Predictable performance, even in the million of entries.
>
> And even more vast overkill for most linux users than the existing
> routing code already is. Linux has at least the beginnings of a pluggable
> FIB interface (fib_table), which has slightly bit rotted, but probably
> not too bad. I would suggest you clean that up, make the existing
> hash table really optional and then you can just plug in anything you
want.
>
> > I join a patch with the fib_hash in IPv4 replace with a patricia
tree
> > ready for multi-FIB base on a 2.4.22 kernel. This is the beginning of a
> > long cleanup.
>
> What do you consider dirty in the current stack?
>
> -Andi
>
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/