Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit c7f0030b authored by Pablo Neira Ayuso's avatar Pablo Neira Ayuso
Browse files

netfilter: nft_flow_offload: wait for garbage collector to run after cleanup



If netdevice goes down, then flowtable entries are scheduled to be
removed. Wait for garbage collector to have a chance to run so it can
delete them from the hashtable.

The flush call might sleep, so hold the nfnl mutex from
nft_flow_table_iterate() instead of rcu read side lock. The use of the
nfnl mutex is also implicitly fixing races between updates via nfnetlink
and netdevice event.

Signed-off-by: default avatarPablo Neira Ayuso <pablo@netfilter.org>
parent ba7cd5d9
Loading
Loading
Loading
Loading
+4 −4
Original line number Diff line number Diff line
@@ -5006,13 +5006,13 @@ void nft_flow_table_iterate(struct net *net,
	struct nft_flowtable *flowtable;
	const struct nft_table *table;

	rcu_read_lock();
	list_for_each_entry_rcu(table, &net->nft.tables, list) {
		list_for_each_entry_rcu(flowtable, &table->flowtables, list) {
	nfnl_lock(NFNL_SUBSYS_NFTABLES);
	list_for_each_entry(table, &net->nft.tables, list) {
		list_for_each_entry(flowtable, &table->flowtables, list) {
			iter(&flowtable->data, data);
		}
	}
	rcu_read_unlock();
	nfnl_unlock(NFNL_SUBSYS_NFTABLES);
}
EXPORT_SYMBOL_GPL(nft_flow_table_iterate);

+1 −0
Original line number Diff line number Diff line
@@ -208,6 +208,7 @@ static void nft_flow_offload_iterate_cleanup(struct nf_flowtable *flowtable,
					     void *data)
{
	nf_flow_table_iterate(flowtable, flow_offload_iterate_cleanup, data);
	flush_delayed_work(&flowtable->gc_work);
}

static int flow_offload_netdev_event(struct notifier_block *this,