[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-Id: <1451949056-15500-1-git-send-email-noureddine@arista.com>
Date: Mon, 4 Jan 2016 15:10:52 -0800
From: Salam Noureddine <noureddine@...sta.com>
To: "David S. Miller" <davem@...emloft.net>,
Eric Dumazet <edumazet@...gle.com>,
Jiri Pirko <jiri@...lanox.com>,
Alexei Starovoitov <ast@...mgrid.com>,
Daniel Borkmann <daniel@...earbox.net>,
"Eric W. Biederman" <ebiederm@...ssion.com>, netdev@...r.kernel.org
Cc: Salam Noureddine <noureddine@...sta.com>
Subject: [PATCH net-next 0/4] batch calls to fib_flush and arp_ifdown
fib_flush walks the whole fib in a net_namespace and is called for
each net_device being closed or unregistered. This can be very expensive
when dealing with 100k or more routes in the fib and removal of a lot
of interfaces. These four patches deal with this issue by calling fib_flush
just once for each net namespace and introduce a new function arp_ifdown_all
that does a similar optimization for the neighbour table.
Salam Noureddine (4):
net: add event_list to struct net and provide utility functions
net: dev: add batching to net_device notifiers
net: core: introduce neigh_ifdown_all for all down interfaces
net: fib: avoid calling fib_flush for each device when doing batch
close and unregister
include/linux/netdevice.h | 2 ++
include/net/arp.h | 1 +
include/net/neighbour.h | 1 +
include/net/net_namespace.h | 22 ++++++++++++++++++++++
include/net/netns/ipv4.h | 1 +
net/core/dev.c | 39 ++++++++++++++++++++++++++++++++++++---
net/core/neighbour.c | 38 +++++++++++++++++++++++++++++++-------
net/ipv4/arp.c | 4 ++++
net/ipv4/fib_frontend.c | 16 ++++++++++++++--
9 files changed, 112 insertions(+), 12 deletions(-)
--
1.8.1.4
--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists