diff options
author | Kirill Tkhai <ktkhai@virtuozzo.com> | 2018-09-11 13:12:14 +0300 |
---|---|---|
committer | Miklos Szeredi <mszeredi@redhat.com> | 2018-09-28 17:43:23 +0300 |
commit | be2ff42c5d6ebc8552c82a7d1697afae30510ed9 (patch) | |
tree | 34d256dcf2c28957a3a1deefe42cd6658f0ff4a3 /fs/fuse/Makefile | |
parent | 3a5358d1a1b70bb3360578f09894d6856629ecdf (diff) | |
download | linux-be2ff42c5d6ebc8552c82a7d1697afae30510ed9.tar.xz |
fuse: Use hash table to link processing request
We noticed the performance bottleneck in FUSE running our Virtuozzo storage
over rdma. On some types of workload we observe 20% of times spent in
request_find() in profiler. This function is iterating over long requests
list, and it scales bad.
The patch introduces hash table to reduce the number of iterations, we do
in this function. Hash generating algorithm is taken from hash_add()
function, while 256 lines table is used to store pending requests. This
fixes problem and improves the performance.
Reported-by: Alexey Kuznetsov <kuznet@virtuozzo.com>
Signed-off-by: Kirill Tkhai <ktkhai@virtuozzo.com>
Signed-off-by: Miklos Szeredi <mszeredi@redhat.com>
Diffstat (limited to 'fs/fuse/Makefile')
0 files changed, 0 insertions, 0 deletions