diff options
author | Kuniyuki Iwashima <[email protected]> | 2024-10-16 11:53:57 -0700 |
---|---|---|
committer | Paolo Abeni <[email protected]> | 2024-10-22 11:02:05 +0200 |
commit | 6ab0f866948323724e95cf14d9e47fd77703c192 (patch) | |
tree | e237cbc9f355ef692a274210fe667b5a9a1d00d1 /tools/perf/scripts/python/mem-phys-addr.py | |
parent | 26eebdc4b005ccd4cf63f4fef4c9c0adf9bfa380 (diff) |
rtnetlink: Protect struct rtnl_af_ops with SRCU.
Once RTNL is replaced with rtnl_net_lock(), we need a mechanism to
guarantee that rtnl_af_ops is alive during inflight RTM_SETLINK
even when its module is being unloaded.
Let's use SRCU to protect ops.
rtnl_af_lookup() now iterates rtnl_af_ops under RCU and returns
SRCU-protected ops pointer. The caller must call rtnl_af_put()
to release the pointer after the use.
Also, rtnl_af_unregister() unlinks the ops first and calls
synchronize_srcu() to wait for inflight RTM_SETLINK requests to
complete.
Note that rtnl_af_ops needs to be protected by its dedicated lock
when RTNL is removed.
Note also that BUG_ON() in do_setlink() is changed to the normal
error handling as a different af_ops might be found after
validate_linkmsg().
Signed-off-by: Kuniyuki Iwashima <[email protected]>
Signed-off-by: Paolo Abeni <[email protected]>
Diffstat (limited to 'tools/perf/scripts/python/mem-phys-addr.py')
0 files changed, 0 insertions, 0 deletions