Mateusz Guzik b088a4d6f9 cache: avoid excessive relocking on entry removal during lookup
Due to lock ordering issues (bucket lock held, vnode locks wanted) the code
starts with trylocking which in face of contention often fails. Prior to
the change it would loop back with a possible yield.

Instead note we know what locks are needed and can take them in the right
order, avoiding retries. Then we can safely re-lookup and see if the entry
we are looking for is still there.

On a 104-way box poudriere would result in constant retries during an 11h
run as seen in the vfs.cache.zap_and_exit_bucket_fail counter.

before: 408866592
after :         0

However, a new stat reports:
vfs.cache.zap_and_exit_bucket_relock_success: 32638

Note this is only a bandaid over current design issues.

Tested by:	pho
Sponsored by:	The FreeBSD Foundation
2019-09-10 20:19:29 +00:00
..
2019-09-03 04:16:30 +00:00
2019-09-03 04:16:30 +00:00
2019-01-27 00:46:06 +00:00
2019-09-03 18:56:25 +00:00
2019-06-24 20:52:21 +00:00
2019-08-28 16:18:23 +00:00
2019-09-03 18:56:25 +00:00
2019-08-28 16:18:23 +00:00
2018-12-05 16:43:03 +00:00
2019-09-03 04:16:30 +00:00
2019-03-12 05:10:41 +00:00
2018-10-12 00:32:45 +00:00
2019-07-24 23:04:59 +00:00
2018-08-18 19:45:56 +00:00
2018-06-01 13:26:45 +00:00
2019-02-20 09:38:19 +00:00
2019-07-24 23:04:59 +00:00
2018-11-20 14:58:41 +00:00
2019-08-05 20:31:17 +00:00
2019-09-03 04:16:30 +00:00
2019-09-03 04:16:30 +00:00
2019-09-03 04:16:30 +00:00
2018-06-01 13:26:45 +00:00
2018-10-23 21:43:41 +00:00
2019-09-05 18:19:51 +00:00
2019-08-28 20:34:24 +00:00