aboutsummaryrefslogtreecommitdiffstats
path: root/fs/file_table.c
diff options
context:
space:
mode:
Diffstat (limited to 'fs/file_table.c')
-rw-r--r--fs/file_table.c28
1 files changed, 23 insertions, 5 deletions
diff --git a/fs/file_table.c b/fs/file_table.c
index 5c7d10ead4ad..2fc3b3c08911 100644
--- a/fs/file_table.c
+++ b/fs/file_table.c
@@ -230,6 +230,15 @@ static void __fput(struct file *file)
230 might_sleep(); 230 might_sleep();
231 231
232 fsnotify_close(file); 232 fsnotify_close(file);
233
234 /*
235 * fsnotify_create_event may have taken one or more references on this
236 * file. If it did so it left one reference for us to drop to make sure
237 * its calls to fput could not prematurely destroy the file.
238 */
239 if (atomic_long_read(&file->f_count))
240 return fput(file);
241
233 /* 242 /*
234 * The function eventpoll_release() should be the first called 243 * The function eventpoll_release() should be the first called
235 * in the file cleanup chain. 244 * in the file cleanup chain.
@@ -289,11 +298,20 @@ struct file *fget(unsigned int fd)
289EXPORT_SYMBOL(fget); 298EXPORT_SYMBOL(fget);
290 299
291/* 300/*
292 * Lightweight file lookup - no refcnt increment if fd table isn't shared. 301 * Lightweight file lookup - no refcnt increment if fd table isn't shared.
293 * You can use this only if it is guranteed that the current task already 302 *
294 * holds a refcnt to that file. That check has to be done at fget() only 303 * You can use this instead of fget if you satisfy all of the following
295 * and a flag is returned to be passed to the corresponding fput_light(). 304 * conditions:
296 * There must not be a cloning between an fget_light/fput_light pair. 305 * 1) You must call fput_light before exiting the syscall and returning control
306 * to userspace (i.e. you cannot remember the returned struct file * after
307 * returning to userspace).
308 * 2) You must not call filp_close on the returned struct file * in between
309 * calls to fget_light and fput_light.
310 * 3) You must not clone the current task in between the calls to fget_light
311 * and fput_light.
312 *
313 * The fput_needed flag returned by fget_light should be passed to the
314 * corresponding fput_light.
297 */ 315 */
298struct file *fget_light(unsigned int fd, int *fput_needed) 316struct file *fget_light(unsigned int fd, int *fput_needed)
299{ 317{