aboutsummaryrefslogtreecommitdiffstats
path: root/fs/9p
diff options
context:
space:
mode:
authorAneesh Kumar K.V <aneesh.kumar@linux.vnet.ibm.com>2010-03-29 19:13:59 -0400
committerEric Van Hensbergen <ericvh@gmail.com>2010-04-05 11:37:36 -0400
commit6d96d3ab7aea5f0e75205a0c97f8d1fdf82c5287 (patch)
treea4dfa0472e2e670de1da7e7c0905da12d4608ab4 /fs/9p
parentd994f4058d9f9be7e44529b55fc6be6552901ead (diff)
9p: Make sure we are able to clunk the cached fid on umount
dcache prune happen on umount. So we cannot mark the client satus disconnect. That will prevent a 9p call to the server Signed-off-by: Aneesh Kumar K.V <aneesh.kumar@linux.vnet.ibm.com> Signed-off-by: Eric Van Hensbergen <ericvh@gmail.com>
Diffstat (limited to 'fs/9p')
-rw-r--r--fs/9p/v9fs.c13
-rw-r--r--fs/9p/v9fs.h1
-rw-r--r--fs/9p/vfs_super.c3
3 files changed, 16 insertions, 1 deletions
diff --git a/fs/9p/v9fs.c b/fs/9p/v9fs.c
index 2f814cf0c731..0b78ae8157b9 100644
--- a/fs/9p/v9fs.c
+++ b/fs/9p/v9fs.c
@@ -342,6 +342,19 @@ void v9fs_session_cancel(struct v9fs_session_info *v9ses) {
342 p9_client_disconnect(v9ses->clnt); 342 p9_client_disconnect(v9ses->clnt);
343} 343}
344 344
345/**
346 * v9fs_session_begin_cancel - Begin terminate of a session
347 * @v9ses: session to terminate
348 *
349 * After this call we don't allow any request other than clunk.
350 */
351
352void v9fs_session_begin_cancel(struct v9fs_session_info *v9ses)
353{
354 P9_DPRINTK(P9_DEBUG_ERROR, "begin cancel session %p\n", v9ses);
355 p9_client_begin_disconnect(v9ses->clnt);
356}
357
345extern int v9fs_error_init(void); 358extern int v9fs_error_init(void);
346 359
347static struct kobject *v9fs_kobj; 360static struct kobject *v9fs_kobj;
diff --git a/fs/9p/v9fs.h b/fs/9p/v9fs.h
index 6b801d1ddf4b..a0a8d3dd1361 100644
--- a/fs/9p/v9fs.h
+++ b/fs/9p/v9fs.h
@@ -108,6 +108,7 @@ struct p9_fid *v9fs_session_init(struct v9fs_session_info *, const char *,
108 char *); 108 char *);
109void v9fs_session_close(struct v9fs_session_info *v9ses); 109void v9fs_session_close(struct v9fs_session_info *v9ses);
110void v9fs_session_cancel(struct v9fs_session_info *v9ses); 110void v9fs_session_cancel(struct v9fs_session_info *v9ses);
111void v9fs_session_begin_cancel(struct v9fs_session_info *v9ses);
111 112
112#define V9FS_MAGIC 0x01021997 113#define V9FS_MAGIC 0x01021997
113 114
diff --git a/fs/9p/vfs_super.c b/fs/9p/vfs_super.c
index 69357c0d9899..d1a3c809a291 100644
--- a/fs/9p/vfs_super.c
+++ b/fs/9p/vfs_super.c
@@ -193,6 +193,7 @@ static void v9fs_kill_super(struct super_block *s)
193 193
194 kill_anon_super(s); 194 kill_anon_super(s);
195 195
196 v9fs_session_cancel(v9ses);
196 v9fs_session_close(v9ses); 197 v9fs_session_close(v9ses);
197 kfree(v9ses); 198 kfree(v9ses);
198 s->s_fs_info = NULL; 199 s->s_fs_info = NULL;
@@ -205,7 +206,7 @@ v9fs_umount_begin(struct super_block *sb)
205 struct v9fs_session_info *v9ses; 206 struct v9fs_session_info *v9ses;
206 207
207 v9ses = sb->s_fs_info; 208 v9ses = sb->s_fs_info;
208 v9fs_session_cancel(v9ses); 209 v9fs_session_begin_cancel(v9ses);
209} 210}
210 211
211static const struct super_operations v9fs_super_ops = { 212static const struct super_operations v9fs_super_ops = {