Commit 9b0c290e78d667e6a483bde8c7cef7dd15f49017
Committed by
David S. Miller
1 parent
7b5edbc4cf
Exists in
master
and in
7 other branches
fib: introduce fib_alias_accessed() helper
Perf tools session at NFWS 2010 pointed out a false sharing on struct fib_alias that can be avoided pretty easily, if we set FA_S_ACCESSED bit only if needed (ie : not already set) Signed-off-by: Eric Dumazet <eric.dumazet@gmail.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Showing 4 changed files with 12 additions and 3 deletions Side-by-side Diff
net/ipv4/fib_hash.c
net/ipv4/fib_lookup.h
... | ... | @@ -17,6 +17,13 @@ |
17 | 17 | |
18 | 18 | #define FA_S_ACCESSED 0x01 |
19 | 19 | |
20 | +/* Dont write on fa_state unless needed, to keep it shared on all cpus */ | |
21 | +static inline void fib_alias_accessed(struct fib_alias *fa) | |
22 | +{ | |
23 | + if (!(fa->fa_state & FA_S_ACCESSED)) | |
24 | + fa->fa_state |= FA_S_ACCESSED; | |
25 | +} | |
26 | + | |
20 | 27 | /* Exported by fib_semantics.c */ |
21 | 28 | extern int fib_semantic_match(struct list_head *head, |
22 | 29 | const struct flowi *flp, |
net/ipv4/fib_semantics.c
net/ipv4/fib_trie.c