diff options
Diffstat (limited to 'fs/coda/file.c')
-rw-r--r-- | fs/coda/file.c | 65 |
1 files changed, 6 insertions, 59 deletions
diff --git a/fs/coda/file.c b/fs/coda/file.c index 7594962604c2..29137ff3ca67 100644 --- a/fs/coda/file.c +++ b/fs/coda/file.c | |||
@@ -25,10 +25,6 @@ | |||
25 | 25 | ||
26 | #include "coda_int.h" | 26 | #include "coda_int.h" |
27 | 27 | ||
28 | /* if CODA_STORE fails with EOPNOTSUPP, venus clearly doesn't support | ||
29 | * CODA_STORE/CODA_RELEASE and we fall back on using the CODA_CLOSE upcall */ | ||
30 | static int use_coda_close; | ||
31 | |||
32 | static ssize_t | 28 | static ssize_t |
33 | coda_file_read(struct file *coda_file, char __user *buf, size_t count, loff_t *ppos) | 29 | coda_file_read(struct file *coda_file, char __user *buf, size_t count, loff_t *ppos) |
34 | { | 30 | { |
@@ -163,47 +159,6 @@ int coda_open(struct inode *coda_inode, struct file *coda_file) | |||
163 | return 0; | 159 | return 0; |
164 | } | 160 | } |
165 | 161 | ||
166 | int coda_flush(struct file *coda_file, fl_owner_t id) | ||
167 | { | ||
168 | unsigned short flags = coda_file->f_flags & ~O_EXCL; | ||
169 | unsigned short coda_flags = coda_flags_to_cflags(flags); | ||
170 | struct coda_file_info *cfi; | ||
171 | struct inode *coda_inode; | ||
172 | int err = 0, fcnt; | ||
173 | |||
174 | lock_kernel(); | ||
175 | |||
176 | /* last close semantics */ | ||
177 | fcnt = file_count(coda_file); | ||
178 | if (fcnt > 1) | ||
179 | goto out; | ||
180 | |||
181 | /* No need to make an upcall when we have not made any modifications | ||
182 | * to the file */ | ||
183 | if ((coda_file->f_flags & O_ACCMODE) == O_RDONLY) | ||
184 | goto out; | ||
185 | |||
186 | if (use_coda_close) | ||
187 | goto out; | ||
188 | |||
189 | cfi = CODA_FTOC(coda_file); | ||
190 | BUG_ON(!cfi || cfi->cfi_magic != CODA_MAGIC); | ||
191 | |||
192 | coda_inode = coda_file->f_path.dentry->d_inode; | ||
193 | |||
194 | err = venus_store(coda_inode->i_sb, coda_i2f(coda_inode), coda_flags, | ||
195 | coda_file->f_uid); | ||
196 | |||
197 | if (err == -EOPNOTSUPP) { | ||
198 | use_coda_close = 1; | ||
199 | err = 0; | ||
200 | } | ||
201 | |||
202 | out: | ||
203 | unlock_kernel(); | ||
204 | return err; | ||
205 | } | ||
206 | |||
207 | int coda_release(struct inode *coda_inode, struct file *coda_file) | 162 | int coda_release(struct inode *coda_inode, struct file *coda_file) |
208 | { | 163 | { |
209 | unsigned short flags = (coda_file->f_flags) & (~O_EXCL); | 164 | unsigned short flags = (coda_file->f_flags) & (~O_EXCL); |
@@ -215,21 +170,11 @@ int coda_release(struct inode *coda_inode, struct file *coda_file) | |||
215 | 170 | ||
216 | lock_kernel(); | 171 | lock_kernel(); |
217 | 172 | ||
218 | if (!use_coda_close) { | ||
219 | err = venus_release(coda_inode->i_sb, coda_i2f(coda_inode), | ||
220 | coda_flags); | ||
221 | if (err == -EOPNOTSUPP) { | ||
222 | use_coda_close = 1; | ||
223 | err = 0; | ||
224 | } | ||
225 | } | ||
226 | |||
227 | cfi = CODA_FTOC(coda_file); | 173 | cfi = CODA_FTOC(coda_file); |
228 | BUG_ON(!cfi || cfi->cfi_magic != CODA_MAGIC); | 174 | BUG_ON(!cfi || cfi->cfi_magic != CODA_MAGIC); |
229 | 175 | ||
230 | if (use_coda_close) | 176 | err = venus_close(coda_inode->i_sb, coda_i2f(coda_inode), |
231 | err = venus_close(coda_inode->i_sb, coda_i2f(coda_inode), | 177 | coda_flags, coda_file->f_uid); |
232 | coda_flags, coda_file->f_uid); | ||
233 | 178 | ||
234 | host_inode = cfi->cfi_container->f_path.dentry->d_inode; | 179 | host_inode = cfi->cfi_container->f_path.dentry->d_inode; |
235 | cii = ITOC(coda_inode); | 180 | cii = ITOC(coda_inode); |
@@ -246,7 +191,10 @@ int coda_release(struct inode *coda_inode, struct file *coda_file) | |||
246 | coda_file->private_data = NULL; | 191 | coda_file->private_data = NULL; |
247 | 192 | ||
248 | unlock_kernel(); | 193 | unlock_kernel(); |
249 | return err; | 194 | |
195 | /* VFS fput ignores the return value from file_operations->release, so | ||
196 | * there is no use returning an error here */ | ||
197 | return 0; | ||
250 | } | 198 | } |
251 | 199 | ||
252 | int coda_fsync(struct file *coda_file, struct dentry *coda_dentry, int datasync) | 200 | int coda_fsync(struct file *coda_file, struct dentry *coda_dentry, int datasync) |
@@ -288,7 +236,6 @@ const struct file_operations coda_file_operations = { | |||
288 | .write = coda_file_write, | 236 | .write = coda_file_write, |
289 | .mmap = coda_file_mmap, | 237 | .mmap = coda_file_mmap, |
290 | .open = coda_open, | 238 | .open = coda_open, |
291 | .flush = coda_flush, | ||
292 | .release = coda_release, | 239 | .release = coda_release, |
293 | .fsync = coda_fsync, | 240 | .fsync = coda_fsync, |
294 | .splice_read = coda_file_splice_read, | 241 | .splice_read = coda_file_splice_read, |