Hello *,
I'm the author of the mipip olsrd patch mentioned by rene. The olsrd code
was very close to doing the Right Thing (see below), my patch just fixed a
few minor internal API issues that prevented it from working out correctly.
I haven't seriously looked at the b.a.t.m.a.n. code, so I don't know exactly
why it's causing problems for rene.
Axel Neumann wrote:
IMO that does only work if the interfaces of a node
are NOT connected to the
same physical/logical link (e.g. B1 and B2 are operating on different
channels or with different cell IDs,...). Otherwise specifying the outgoing
interface is not enough. Even if node A has only one interface (A1). If there
is a link A1<->B1 and a link A1<->B2 the problem remains:
> How could it set up the routing table to
ensure that a packet
> to a distant node C should be routed via B1 (and NOT via B2)?
The outgoing
interface of node A is A1, for both cases. Setting the outgoing
interface to A1 has no effect.
Maybe there is a way to configure the next-hop-mac address instead of the
next-hop-ip address. But then you rather have layer 2 routing and not layer
3.
This is an interesting case. You're correct that in this configuration, a
l3
routing daemon on A can't make a deliberate choice of which interface of B
to send data to. This is obviously suboptimal, and should be avoided.
However, there are plenty of cases where this will predictably not occur.
For instance, in the opennet mesh network in Rostock, we have quite a lot of
nodes which have one wired interface and one wireless interface, both of
which are used for communication with other nodes in the mesh cloud.
Assigning separate IP addresses to the different interfaces on those nodes
would be wasteful of our address space.
Imo, the choice whether to assign different IP addresses to the different
interfaces on a specific meshnode should ideally lie with the (hopefully
competent) network admins, and routing daemons should decently support
either configuration, with the implicit understanding that having different
interfaces a) in the same broadcast domain AND b) with the same IP addresses
may lead to silent performance degradation.
That's what the newer versions of olsrd do.
Regards,
Sebastian Hagen