提交 2d77bf0a 编写于 作者: J Jeff Layton 提交者: J. Bruce Fields

nfsd: change heuristic for selecting the client_tracking_ops

First, try to use the new usermodehelper upcall. It should succeed or
fail quickly, so there's little cost to doing so.

If it fails, and the legacy tracking dir exists, use that. If it
doesn't exist then fall back to using nfsdcld.
Signed-off-by: NJeff Layton <jlayton@redhat.com>
Signed-off-by: NJ. Bruce Fields <bfields@redhat.com>
上级 2873d214
...@@ -1064,17 +1064,35 @@ nfsd4_client_tracking_init(struct net *net) ...@@ -1064,17 +1064,35 @@ nfsd4_client_tracking_init(struct net *net)
int status; int status;
struct path path; struct path path;
if (!client_tracking_ops) { /* just run the init if it the method is already decided */
client_tracking_ops = &nfsd4_cld_tracking_ops; if (client_tracking_ops)
status = kern_path(nfs4_recoverydir(), LOOKUP_FOLLOW, &path); goto do_init;
if (!status) {
if (S_ISDIR(path.dentry->d_inode->i_mode)) /*
client_tracking_ops = * First, try a UMH upcall. It should succeed or fail quickly, so
&nfsd4_legacy_tracking_ops; * there's little harm in trying that first.
path_put(&path); */
} client_tracking_ops = &nfsd4_umh_tracking_ops;
status = client_tracking_ops->init(net);
if (!status)
return status;
/*
* See if the recoverydir exists and is a directory. If it is,
* then use the legacy ops.
*/
client_tracking_ops = &nfsd4_legacy_tracking_ops;
status = kern_path(nfs4_recoverydir(), LOOKUP_FOLLOW, &path);
if (!status) {
status = S_ISDIR(path.dentry->d_inode->i_mode);
path_put(&path);
if (status)
goto do_init;
} }
/* Finally, try to use nfsdcld */
client_tracking_ops = &nfsd4_cld_tracking_ops;
do_init:
status = client_tracking_ops->init(net); status = client_tracking_ops->init(net);
if (status) { if (status) {
printk(KERN_WARNING "NFSD: Unable to initialize client " printk(KERN_WARNING "NFSD: Unable to initialize client "
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册