diff options
author | Nicolas Dichtel <[email protected]> | 2014-12-10 15:45:01 -0800 |
---|---|---|
committer | Linus Torvalds <[email protected]> | 2014-12-10 17:41:09 -0800 |
commit | 710585d4922fd315f2cada8fbe550ae8ed23e994 (patch) | |
tree | dd783ed159fcf3be1463c41637b12345d60cd1de /tools/perf/scripts/python/failed-syscalls-by-pid.py | |
parent | 9edad6ea0f1416415f6fe31cc9d1dbc3817803ed (diff) |
fs/proc: use a rb tree for the directory entries
When a lot of netdevices are created, one of the bottleneck is the
creation of proc entries. This serie aims to accelerate this part.
The current implementation for the directories in /proc is using a single
linked list. This is slow when handling directories with large numbers of
entries (eg netdevice-related entries when lots of tunnels are opened).
This patch replaces this linked list by a red-black tree.
Here are some numbers:
dummy30000.batch contains 30 000 times 'link add type dummy'.
Before the patch:
$ time ip -b dummy30000.batch
real 2m31.950s
user 0m0.440s
sys 2m21.440s
$ time rmmod dummy
real 1m35.764s
user 0m0.000s
sys 1m24.088s
After the patch:
$ time ip -b dummy30000.batch
real 2m0.874s
user 0m0.448s
sys 1m49.720s
$ time rmmod dummy
real 1m13.988s
user 0m0.000s
sys 1m1.008s
The idea of improving this part was suggested by Thierry Herbelot.
[[email protected]: initialise proc_root.subdir at compile time]
Signed-off-by: Nicolas Dichtel <[email protected]>
Acked-by: David S. Miller <[email protected]>
Cc: Thierry Herbelot <[email protected]>.
Acked-by: "Eric W. Biederman" <[email protected]>
Signed-off-by: Andrew Morton <[email protected]>
Signed-off-by: Linus Torvalds <[email protected]>
Diffstat (limited to 'tools/perf/scripts/python/failed-syscalls-by-pid.py')
0 files changed, 0 insertions, 0 deletions