339-v4.16-netfilter-nft_flow_offload-wait-for-garbage-collecto.patch 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. From: Pablo Neira Ayuso <pablo@netfilter.org>
  2. Date: Thu, 1 Feb 2018 18:49:00 +0100
  3. Subject: [PATCH] netfilter: nft_flow_offload: wait for garbage collector
  4. to run after cleanup
  5. If netdevice goes down, then flowtable entries are scheduled to be
  6. removed. Wait for garbage collector to have a chance to run so it can
  7. delete them from the hashtable.
  8. The flush call might sleep, so hold the nfnl mutex from
  9. nft_flow_table_iterate() instead of rcu read side lock. The use of the
  10. nfnl mutex is also implicitly fixing races between updates via nfnetlink
  11. and netdevice event.
  12. Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
  13. ---
  14. --- a/net/netfilter/nf_tables_api.c
  15. +++ b/net/netfilter/nf_tables_api.c
  16. @@ -4914,13 +4914,13 @@ void nft_flow_table_iterate(struct net *
  17. struct nft_flowtable *flowtable;
  18. const struct nft_table *table;
  19. - rcu_read_lock();
  20. - list_for_each_entry_rcu(table, &net->nft.tables, list) {
  21. - list_for_each_entry_rcu(flowtable, &table->flowtables, list) {
  22. + nfnl_lock(NFNL_SUBSYS_NFTABLES);
  23. + list_for_each_entry(table, &net->nft.tables, list) {
  24. + list_for_each_entry(flowtable, &table->flowtables, list) {
  25. iter(&flowtable->data, data);
  26. }
  27. }
  28. - rcu_read_unlock();
  29. + nfnl_unlock(NFNL_SUBSYS_NFTABLES);
  30. }
  31. EXPORT_SYMBOL_GPL(nft_flow_table_iterate);
  32. --- a/net/netfilter/nft_flow_offload.c
  33. +++ b/net/netfilter/nft_flow_offload.c
  34. @@ -208,6 +208,7 @@ static void nft_flow_offload_iterate_cle
  35. void *data)
  36. {
  37. nf_flow_table_iterate(flowtable, flow_offload_iterate_cleanup, data);
  38. + flush_delayed_work(&flowtable->gc_work);
  39. }
  40. static int flow_offload_netdev_event(struct notifier_block *this,