diff options
-rw-r--r-- | fs/9p/fid.c | 12 |
1 files changed, 10 insertions, 2 deletions
diff --git a/fs/9p/fid.c b/fs/9p/fid.c index 08b2eb157048..b0a23c7e736e 100644 --- a/fs/9p/fid.c +++ b/fs/9p/fid.c | |||
@@ -110,7 +110,7 @@ struct p9_fid *v9fs_fid_lookup(struct dentry *dentry) | |||
110 | { | 110 | { |
111 | int i, n, l, clone, any, access; | 111 | int i, n, l, clone, any, access; |
112 | u32 uid; | 112 | u32 uid; |
113 | struct p9_fid *fid; | 113 | struct p9_fid *fid, *old_fid = NULL; |
114 | struct dentry *d, *ds; | 114 | struct dentry *d, *ds; |
115 | struct v9fs_session_info *v9ses; | 115 | struct v9fs_session_info *v9ses; |
116 | char **wnames, *uname; | 116 | char **wnames, *uname; |
@@ -183,10 +183,18 @@ struct p9_fid *v9fs_fid_lookup(struct dentry *dentry) | |||
183 | l = min(n - i, P9_MAXWELEM); | 183 | l = min(n - i, P9_MAXWELEM); |
184 | fid = p9_client_walk(fid, l, &wnames[i], clone); | 184 | fid = p9_client_walk(fid, l, &wnames[i], clone); |
185 | if (IS_ERR(fid)) { | 185 | if (IS_ERR(fid)) { |
186 | if (old_fid) { | ||
187 | /* | ||
188 | * If we fail, clunk fid which are mapping | ||
189 | * to path component and not the last component | ||
190 | * of the path. | ||
191 | */ | ||
192 | p9_client_clunk(old_fid); | ||
193 | } | ||
186 | kfree(wnames); | 194 | kfree(wnames); |
187 | return fid; | 195 | return fid; |
188 | } | 196 | } |
189 | 197 | old_fid = fid; | |
190 | i += l; | 198 | i += l; |
191 | clone = 0; | 199 | clone = 0; |
192 | } | 200 | } |