Page MenuHomeFreeBSD

if_vxlan(4): Add checking for nesting of tunnels
ClosedPublic

Authored by zlei on May 14 2024, 10:12 AM.
Tags
None
Referenced Files
F106968018: D45197.id138770.diff
Wed, Jan 8, 5:57 AM
F106967998: D45197.id138529.diff
Wed, Jan 8, 5:57 AM
F106967993: D45197.id.diff
Wed, Jan 8, 5:57 AM
F106955883: D45197.diff
Wed, Jan 8, 1:15 AM
Unknown Object (File)
Nov 25 2024, 8:10 AM
Unknown Object (File)
Nov 24 2024, 9:30 AM
Unknown Object (File)
Nov 23 2024, 2:57 AM
Unknown Object (File)
Nov 23 2024, 2:57 AM

Details

Summary

User misconfiguration can introduce tunnel loops, which may lead to
kernel stack overflow. Prevent that by checking nesting levels and
dropping packets to be encapsulated, which is the same with current
practices for existing tunnel implementations.

PR: 278422
MFC after: 1 week

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

zlei requested review of this revision.May 14 2024, 10:12 AM
zlei added a subscriber: gshapiro.

@kp has just made similar fix 59a6666ec91d for if_ovpn.

I'm not sure I'd have bothered to make the nesting level configurable, but now that you've done the work it'd be silly to not use it.

It'd also be nice to get a test for this, but it looks like there are no tests at all for vxlan now, so it might be a bit more work than is justified for this issue.

sys/net/if_vxlan.c
440

It's not quite that risky, because if_tunnel_check_nesting() checks if the last tunnel hop was this struct ifnet, so if users configure a loop the packet will be discarded immediately, not when it hits the nesting limit.

We do still need the limit, because users might configure a large number of different nested tunnels, which could still run us out of stack space, but that's harder to do by accident.

This revision is now accepted and ready to land.May 14 2024, 10:41 AM
sys/net/if_vxlan.c
440

It's not quite that risky, because if_tunnel_check_nesting() checks if the last tunnel hop was this struct ifnet, so if users configure a loop the packet will be discarded immediately, not when it hits the nesting limit.

I rechecked implementation of if_tunnel_check_nesting() and you are right :) Thanks for catching that.

We do still need the limit, because users might configure a large number of different nested tunnels, which could still run us out of stack space, but that's harder to do by accident.

True indeed.

Just a quick note that the PR listed on this is incorrect. This fix addresses PR 278394.

Just a quick note that the PR listed on this is incorrect. This fix addresses PR 278394.

My bad. Thanks for catching that !