aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAl Viro <viro@zeniv.linux.org.uk>2012-07-25 16:39:50 -0400
committerAl Viro <viro@zeniv.linux.org.uk>2012-07-29 15:09:57 -0400
commit446945ab9a82515af4b099107eda27050e077c58 (patch)
tree1be9a17759fc754d44a10549a2b43a5aa84a8e2f
parenta51d9eaa41866ab6b4b6ecad7b621f8b66ece0dc (diff)
lockd: shift grabbing a reference to nlm_host into nlm_alloc_call()
It's used both for client and server hosts; we can't do nlmclnt_release_host() on failure exits, since the host might need nlmsvc_release_host(), with BUG_ON() for calling the wrong one. Makes life simpler for callers, actually... Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
-rw-r--r--fs/lockd/clntproc.c9
-rw-r--r--fs/lockd/svc4proc.c1
-rw-r--r--fs/lockd/svclock.c1
-rw-r--r--fs/lockd/svcproc.c1
4 files changed, 4 insertions, 8 deletions
diff --git a/fs/lockd/clntproc.c b/fs/lockd/clntproc.c
index 8392cb85bd54..27c74f32671b 100644
--- a/fs/lockd/clntproc.c
+++ b/fs/lockd/clntproc.c
@@ -156,7 +156,6 @@ int nlmclnt_proc(struct nlm_host *host, int cmd, struct file_lock *fl)
156 struct nlm_rqst *call; 156 struct nlm_rqst *call;
157 int status; 157 int status;
158 158
159 nlm_get_host(host);
160 call = nlm_alloc_call(host); 159 call = nlm_alloc_call(host);
161 if (call == NULL) 160 if (call == NULL)
162 return -ENOMEM; 161 return -ENOMEM;
@@ -185,9 +184,6 @@ EXPORT_SYMBOL_GPL(nlmclnt_proc);
185 184
186/* 185/*
187 * Allocate an NLM RPC call struct 186 * Allocate an NLM RPC call struct
188 *
189 * Note: the caller must hold a reference to host. In case of failure,
190 * this reference will be released.
191 */ 187 */
192struct nlm_rqst *nlm_alloc_call(struct nlm_host *host) 188struct nlm_rqst *nlm_alloc_call(struct nlm_host *host)
193{ 189{
@@ -199,7 +195,7 @@ struct nlm_rqst *nlm_alloc_call(struct nlm_host *host)
199 atomic_set(&call->a_count, 1); 195 atomic_set(&call->a_count, 1);
200 locks_init_lock(&call->a_args.lock.fl); 196 locks_init_lock(&call->a_args.lock.fl);
201 locks_init_lock(&call->a_res.lock.fl); 197 locks_init_lock(&call->a_res.lock.fl);
202 call->a_host = host; 198 call->a_host = nlm_get_host(host);
203 return call; 199 return call;
204 } 200 }
205 if (signalled()) 201 if (signalled())
@@ -207,7 +203,6 @@ struct nlm_rqst *nlm_alloc_call(struct nlm_host *host)
207 printk("nlm_alloc_call: failed, waiting for memory\n"); 203 printk("nlm_alloc_call: failed, waiting for memory\n");
208 schedule_timeout_interruptible(5*HZ); 204 schedule_timeout_interruptible(5*HZ);
209 } 205 }
210 nlmclnt_release_host(host);
211 return NULL; 206 return NULL;
212} 207}
213 208
@@ -750,7 +745,7 @@ static int nlmclnt_cancel(struct nlm_host *host, int block, struct file_lock *fl
750 dprintk("lockd: blocking lock attempt was interrupted by a signal.\n" 745 dprintk("lockd: blocking lock attempt was interrupted by a signal.\n"
751 " Attempting to cancel lock.\n"); 746 " Attempting to cancel lock.\n");
752 747
753 req = nlm_alloc_call(nlm_get_host(host)); 748 req = nlm_alloc_call(host);
754 if (!req) 749 if (!req)
755 return -ENOMEM; 750 return -ENOMEM;
756 req->a_flags = RPC_TASK_ASYNC; 751 req->a_flags = RPC_TASK_ASYNC;
diff --git a/fs/lockd/svc4proc.c b/fs/lockd/svc4proc.c
index 9a41fdc19511..185fda894789 100644
--- a/fs/lockd/svc4proc.c
+++ b/fs/lockd/svc4proc.c
@@ -256,6 +256,7 @@ static __be32 nlm4svc_callback(struct svc_rqst *rqstp, u32 proc, struct nlm_args
256 return rpc_system_err; 256 return rpc_system_err;
257 257
258 call = nlm_alloc_call(host); 258 call = nlm_alloc_call(host);
259 nlmsvc_release_host(host);
259 if (call == NULL) 260 if (call == NULL)
260 return rpc_system_err; 261 return rpc_system_err;
261 262
diff --git a/fs/lockd/svclock.c b/fs/lockd/svclock.c
index e46353f41a42..b54acaf65987 100644
--- a/fs/lockd/svclock.c
+++ b/fs/lockd/svclock.c
@@ -219,7 +219,6 @@ nlmsvc_create_block(struct svc_rqst *rqstp, struct nlm_host *host,
219 struct nlm_block *block; 219 struct nlm_block *block;
220 struct nlm_rqst *call = NULL; 220 struct nlm_rqst *call = NULL;
221 221
222 nlm_get_host(host);
223 call = nlm_alloc_call(host); 222 call = nlm_alloc_call(host);
224 if (call == NULL) 223 if (call == NULL)
225 return NULL; 224 return NULL;
diff --git a/fs/lockd/svcproc.c b/fs/lockd/svcproc.c
index d27aab11f324..90cfe9a0bf55 100644
--- a/fs/lockd/svcproc.c
+++ b/fs/lockd/svcproc.c
@@ -294,6 +294,7 @@ static __be32 nlmsvc_callback(struct svc_rqst *rqstp, u32 proc, struct nlm_args
294 return rpc_system_err; 294 return rpc_system_err;
295 295
296 call = nlm_alloc_call(host); 296 call = nlm_alloc_call(host);
297 nlmsvc_release_host(host);
297 if (call == NULL) 298 if (call == NULL)
298 return rpc_system_err; 299 return rpc_system_err;
299 300