Commit 14a20e5
net/ipv6: Fix the RT cache flush via sysctl using a previous delay
The net.ipv6.route.flush system parameter takes a value which specifies
a delay used during the flush operation for aging exception routes. The
written value is however not used in the currently requested flush and
instead utilized only in the next one.
A problem is that ipv6_sysctl_rtcache_flush() first reads the old value
of net->ipv6.sysctl.flush_delay into a local delay variable and then
calls proc_dointvec() which actually updates the sysctl based on the
provided input.
Fix the problem by switching the order of the two operations.
Fixes: 4990509 ("[NETNS][IPV6]: Make sysctls route per namespace.")
Signed-off-by: Petr Pavlu <petr.pavlu@suse.com>
Reviewed-by: David Ahern <dsahern@kernel.org>
Link: https://lore.kernel.org/r/20240607112828.30285-1-petr.pavlu@suse.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>1 parent d92589f commit 14a20e5
1 file changed
Lines changed: 2 additions & 2 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
6343 | 6343 | | |
6344 | 6344 | | |
6345 | 6345 | | |
6346 | | - | |
6347 | | - | |
6348 | 6346 | | |
6349 | 6347 | | |
6350 | 6348 | | |
6351 | 6349 | | |
| 6350 | + | |
| 6351 | + | |
6352 | 6352 | | |
6353 | 6353 | | |
6354 | 6354 | | |
| |||
0 commit comments