Jeff Layton 48f7418654 locks: turn the blocked_list into a hashtable
Break up the blocked_list into a hashtable, using the fl_owner as a key.
This speeds up searching the hash chains, which is especially significant
for deadlock detection.

Note that the initial implementation assumes that hashing on fl_owner is
sufficient. In most cases it should be, with the notable exception being
server-side lockd, which compares ownership using a tuple of the
nlm_host and the pid sent in the lock request. So, this may degrade to a
single hash bucket when you only have a single NFS client. That will be
addressed in a later patch.

The careful observer may note that this patch leaves the file_lock_list
alone. There's much less of a case for turning the file_lock_list into a
hashtable. The only user of that list is the code that generates
/proc/locks, and it always walks the entire list.

Signed-off-by: Jeff Layton <jlayton@redhat.com>
Acked-by: J. Bruce Fields <bfields@fieldses.org>
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
2013-06-29 12:57:44 +04:00
..
2013-06-29 12:56:45 +04:00
2013-06-29 12:56:55 +04:00
2013-06-29 12:56:33 +04:00
2013-06-29 12:57:24 +04:00
2013-06-29 12:56:30 +04:00
2013-06-29 12:56:46 +04:00
2013-06-29 12:56:31 +04:00
2013-06-29 12:56:34 +04:00
2013-06-29 12:57:05 +04:00
2013-06-29 12:57:12 +04:00
2013-06-29 12:56:40 +04:00
2013-06-29 12:56:46 +04:00
2013-06-29 12:56:53 +04:00
2013-06-29 12:56:59 +04:00
2013-06-29 12:56:32 +04:00
2013-06-29 12:56:47 +04:00
2013-06-29 12:56:43 +04:00
2013-06-29 12:56:36 +04:00
2013-06-29 12:56:48 +04:00
2013-06-29 12:57:02 +04:00
2013-06-29 12:56:37 +04:00
2013-06-29 12:56:32 +04:00
2013-05-09 16:42:10 -07:00
2013-06-29 12:56:38 +04:00
2013-06-29 12:56:39 +04:00
2013-06-29 12:56:29 +04:00
2013-06-29 12:56:28 +04:00
2013-06-29 12:56:36 +04:00
2013-06-29 12:56:25 +04:00
2013-06-29 12:57:12 +04:00
2013-06-29 12:57:00 +04:00
2013-06-29 12:57:34 +04:00
2013-06-29 12:57:04 +04:00
2013-04-29 15:40:23 -04:00
2013-06-29 12:57:05 +04:00
2013-03-03 23:00:23 -05:00
2013-02-22 23:31:31 -05:00
2013-06-29 12:57:34 +04:00
2013-02-22 23:31:31 -05:00
2013-04-17 13:25:09 +01:00
2013-05-07 20:16:25 -07:00
2013-05-31 15:16:33 -04:00
2013-06-29 12:57:34 +04:00
2013-06-29 12:57:05 +04:00
2013-04-09 14:13:29 -04:00
2013-02-26 02:46:08 -05:00