Files
kernel_xiaomi_sm8250/include/linux
Chuck Lever 1093a60ef3 NLM/NFS: Use cached nlm_host when calling nlmclnt_proc()
Now that each NFS mount point caches its own nlm_host structure, it can be
passed to nlmclnt_proc() for each lock request.  By pinning an nlm_host for
each mount point, we trade the overhead of looking up or creating a fresh
nlm_host struct during every NLM procedure call for a little extra memory.

We also restrict the nlmclnt_proc symbol to limit the use of this call to
in-tree modules.

Note that nlm_lookup_host() (just removed from the client's per-request
NLM processing) could also trigger an nlm_host garbage collection.  Now
client-side nlm_host garbage collection occurs only during NFS mount
processing.  Since the NFS client now holds a reference on these nlm_host
structures, they wouldn't have been affected by garbage collection
anyway.

Given that nlm_lookup_host() reorders the global nlm_host chain after
every successful lookup, and that a garbage collection could be triggered
during the call, we've removed a significant amount of per-NLM-request
CPU processing overhead.

Sidebar: there are only a few remaining references to the internals of
NFS inodes in the client-side NLM code.  The only references I found are
related to extracting or comparing the inode's file handle via NFS_FH().
One is in nlmclnt_grant(); the other is in nlmclnt_setlockargs().

Signed-off-by: Chuck Lever <chuck.lever@oracle.com>
Signed-off-by: Trond Myklebust <Trond.Myklebust@netapp.com>
2008-01-30 02:06:07 -05:00
..
2008-01-28 14:54:13 -08:00
2007-10-14 20:17:39 -07:00
2007-12-26 19:36:35 -08:00
2007-10-10 16:51:59 -07:00
2008-01-23 05:24:15 -05:00
2008-01-28 15:00:14 -08:00
2005-04-16 15:20:36 -07:00
2007-10-19 11:53:42 -07:00
2007-10-19 11:53:42 -07:00
2008-01-29 21:55:15 +01:00
2008-01-28 14:54:10 -08:00
2007-01-30 08:26:45 -08:00
2008-01-23 05:24:14 -05:00
2005-04-16 15:20:36 -07:00
2008-01-28 23:21:18 +01:00
2008-01-28 23:21:18 +01:00
2008-01-28 23:21:18 +01:00
2005-04-16 15:20:36 -07:00
2007-10-17 08:42:52 -07:00
2008-01-25 21:08:02 +01:00
2007-12-20 17:32:12 +00:00
2008-01-23 21:23:13 -05:00
2007-02-11 11:18:07 -08:00
2008-01-28 23:21:18 +01:00
2005-04-16 15:20:36 -07:00
2005-04-16 15:20:36 -07:00
2008-01-28 23:58:27 -05:00
2006-10-02 07:57:12 -07:00
2008-01-25 21:08:33 +01:00
2008-01-28 14:51:22 +01:00
2008-01-27 18:14:50 +01:00
2008-01-27 18:14:52 +01:00
2008-01-28 15:08:27 -08:00
2008-01-28 15:07:58 -08:00
2008-01-28 15:07:57 -08:00
2008-01-28 14:55:09 -08:00
2008-01-28 14:55:09 -08:00
2007-12-05 05:37:32 -08:00
2005-04-16 15:20:36 -07:00
2008-01-28 23:58:27 -05:00
2008-01-08 16:10:35 -08:00
2008-01-24 20:40:05 -08:00
2007-05-09 12:30:53 -07:00
2008-01-25 21:08:34 +01:00
2007-12-07 09:06:53 +00:00
2007-07-17 10:23:03 -07:00
2007-07-17 10:23:13 -07:00
2007-07-24 12:24:59 -07:00
2005-10-28 08:16:47 -07:00
2007-10-23 15:49:54 +10:00
2005-04-16 15:20:36 -07:00
2008-01-28 23:21:18 +01:00
2006-11-30 04:40:22 +01:00
2007-01-23 00:34:54 -05:00
2008-01-28 14:56:29 -08:00
2008-01-08 23:30:07 -08:00
2008-01-28 14:54:18 -08:00
2006-08-27 11:01:32 -07:00
2005-04-16 15:20:36 -07:00
2007-05-05 14:15:32 -07:00
2008-01-28 15:09:35 -08:00
2008-01-28 23:21:18 +01:00
2005-04-16 15:20:36 -07:00
2007-10-19 11:53:41 -07:00
2007-10-19 11:53:41 -07:00
2007-12-27 23:55:13 -05:00
2006-10-03 23:01:26 +02:00
2007-07-16 09:05:50 -07:00
2008-01-28 15:01:36 -08:00
2008-01-25 21:08:24 +01:00
2008-01-25 21:08:24 +01:00
2008-01-25 21:08:24 +01:00
2008-01-25 21:08:24 +01:00
2005-04-16 15:20:36 -07:00
2007-10-16 09:43:17 -07:00
2007-10-19 11:53:44 -07:00
2005-04-16 15:20:36 -07:00
2008-01-02 13:04:48 -08:00
2008-01-02 13:04:48 -08:00
2008-01-02 13:04:48 -08:00
2008-01-25 21:08:33 +01:00
2005-04-16 15:20:36 -07:00
2008-01-25 21:08:34 +01:00
2007-05-08 11:15:18 -07:00
2005-04-16 15:20:36 -07:00
2007-05-11 08:29:36 -07:00
2008-01-24 20:40:26 -08:00
2007-12-17 10:47:15 -08:00
2005-04-16 15:20:36 -07:00
2005-04-16 15:20:36 -07:00
2007-12-26 19:36:35 -08:00
2005-04-16 15:20:36 -07:00
2007-07-09 18:52:01 +02:00
2008-01-28 14:58:25 -08:00