[Bridge] bridging with gre tunnel
timo.teras at iki.fi
Mon Jul 14 02:44:22 PDT 2008
Philip Craig wrote:
> Timo Teräs wrote:
>> There is an essential difference in this patch compared to the one
>> I referred to. This patch adds a new way to create GRE devices which
>> results in ethernet style device whereas the older patch modifies
>> transmit and receive paths to detect packets coming from bridging
>> code and does not need userland changes at all.
>> I kind of like the fact that userland tools work as-is and that
>> I don't need any special flags for the GRE tunnel creation. However
>> your patch does look way cleaner.
>> Any comments on what the solution to merged in should look like?
> I posted a cleaner version that's similar to what the old patch
> did, see http://marc.info/?l=linux-netdev&m=115449948503549&w=2
That's a third way to do it. The patch I referred to changed
ip_gre mostly (only change to bridging was the device type check).
But it has the same limitation that ether encapsulation is only
usable in association with bridging.
> But I don't think that is the right approach:
> - it forces you to use bridging if you only want ethernet over GRE
> - the change fundamentally has nothing to do with bridging
Yes, I would not do the ethernet header stuff in bridging code
> Actually, this change doesn't really belong in GRE either, because
> that forces you to choose between ethernet encapsulation and not.
> It could be a new device that sits on top of GRE and simply does
> ethernet encapsulation then passes it to the raw GRE device.
> That's a lot of infrastructure for something so simple though,
> and I don't think people will want to use both devices at once.
This sounds as the most robust way to do it. But yes, it sounds
unlikely that both devices would be used simultaneously.
Not sure how easy it would be to add a new tunnel type. Apparently
they use IPPROTO_* to differentiate type and it would be the same
in this case.
Thanks for the feedback so far.
More information about the Bridge