netdev.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH net-next v2 0/5] Support for fdb ECMP nexthop groups
@ 2020-05-20  4:33 Roopa Prabhu
  2020-05-20  4:33 ` [PATCH net-next v2 1/5] nexthop: support for fdb ecmp nexthops Roopa Prabhu
                   ` (4 more replies)
  0 siblings, 5 replies; 9+ messages in thread
From: Roopa Prabhu @ 2020-05-20  4:33 UTC (permalink / raw)
  To: dsahern, davem; +Cc: netdev, nikolay, jiri, idosch, petrm

From: Roopa Prabhu <roopa@cumulusnetworks.com>

This series introduces ecmp nexthops and nexthop groups
for mac fdb entries. In subsequent patches this is used
by the vxlan driver fdb entries. The use case is
E-VPN multihoming [1,2,3] which requires bridged vxlan traffic
to be load balanced to remote switches (vteps) belonging to
the same multi-homed ethernet segment (This is analogous to
a multi-homed LAG but over vxlan).

Changes include new nexthop flag NHA_FDB for nexthops
referenced by fdb entries. These nexthops only have ip.
The patches make sure that routes dont reference such nexthops.

example:
$ip nexthop add id 12 via 172.16.1.2 fdb
$ip nexthop add id 13 via 172.16.1.3 fdb
$ip nexthop add id 102 group 12/13 fdb

$bridge fdb add 02:02:00:00:00:13 dev vxlan1000 nhid 101 self

[1] E-VPN https://tools.ietf.org/html/rfc7432
[2] E-VPN VxLAN: https://tools.ietf.org/html/rfc8365
[3] LPC talk with mention of nexthop groups for L2 ecmp
http://vger.kernel.org/lpc_net2018_talks/scaling_bridge_fdb_database_slidesV3.pdf

v2 -
	- dropped nikolays fixes for nexthop multipath null pointer deref
	  (he will send those separately)
	- Fixes for a few fdb replace conditions found during more testing today
          (mostly check for more error cases)
	- address review comments from davidA and nikolay
	- added negative tests for route add with fdb nexthop + a few more
	- Moved to rcu_dereference_rtnl in vxlan_fdb_info and consolidate rcu
	  dereferences
	- Fixes to build failures Reported-by: kbuild test robot <lkp@intel.com>
	- DavidA, I am going to send a separate patch for the neighbor code validation
	  for NDA_NH_ID if thats ok.

Roopa Prabhu (5):
  nexthop: support for fdb ecmp nexthops
  vxlan: ecmp support for mac fdb entries
  nexthop: add support for notifiers
  vxlan: support for nexthop notifiers
  selftests: net: add fdb nexthop tests

 drivers/net/vxlan.c                         | 334 ++++++++++++++++++++++------
 include/net/ip6_fib.h                       |   1 +
 include/net/netns/nexthop.h                 |   1 +
 include/net/nexthop.h                       |  44 ++++
 include/net/vxlan.h                         |  25 +++
 include/uapi/linux/neighbour.h              |   1 +
 include/uapi/linux/nexthop.h                |   3 +
 net/core/neighbour.c                        |   2 +
 net/ipv4/nexthop.c                          | 158 ++++++++++---
 net/ipv6/route.c                            |   5 +
 tools/testing/selftests/net/fib_nexthops.sh | 160 ++++++++++++-
 11 files changed, 644 insertions(+), 90 deletions(-)

-- 
2.1.4


^ permalink raw reply	[flat|nested] 9+ messages in thread

end of thread, other threads:[~2020-05-21 10:22 UTC | newest]

Thread overview: 9+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2020-05-20  4:33 [PATCH net-next v2 0/5] Support for fdb ECMP nexthop groups Roopa Prabhu
2020-05-20  4:33 ` [PATCH net-next v2 1/5] nexthop: support for fdb ecmp nexthops Roopa Prabhu
2020-05-20  4:33 ` [PATCH net-next v2 2/5] vxlan: ecmp support for mac fdb entries Roopa Prabhu
2020-05-21  8:55   ` Nikolay Aleksandrov
2020-05-20  4:33 ` [PATCH net-next v2 3/5] nexthop: add support for notifiers Roopa Prabhu
2020-05-20  4:33 ` [PATCH net-next v2 4/5] vxlan: support for nexthop notifiers Roopa Prabhu
2020-05-21  8:46   ` [vxlan] dcf6d31edc: BUG:spinlock_bad_magic_on_CPU kernel test robot
2020-05-20  4:33 ` [PATCH net-next v2 5/5] selftests: net: add fdb nexthop tests Roopa Prabhu
2020-05-20 14:58   ` David Ahern

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).