diff options
author | Al Viro <viro@zeniv.linux.org.uk> | 2012-08-26 20:13:36 -0400 |
---|---|---|
committer | Al Viro <viro@zeniv.linux.org.uk> | 2012-09-26 21:10:02 -0400 |
commit | bf2965d5b5950d09e934ea5d961d79d0ed1fae7e (patch) | |
tree | abff32286098495fe01355186bde557a70c2e088 /fs/open.c | |
parent | f6d2ac5ca79d1fd468dbc77e488aec06e86f3035 (diff) | |
download | lwn-bf2965d5b5950d09e934ea5d961d79d0ed1fae7e.tar.gz lwn-bf2965d5b5950d09e934ea5d961d79d0ed1fae7e.zip |
switch ftruncate(2) to fget_light
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
Diffstat (limited to 'fs/open.c')
-rw-r--r-- | fs/open.c | 10 |
1 files changed, 5 insertions, 5 deletions
diff --git a/fs/open.c b/fs/open.c index 03028d0e7487..9f61d7269d39 100644 --- a/fs/open.c +++ b/fs/open.c @@ -132,16 +132,16 @@ SYSCALL_DEFINE2(truncate, const char __user *, path, long, length) static long do_sys_ftruncate(unsigned int fd, loff_t length, int small) { - struct inode * inode; + struct inode *inode; struct dentry *dentry; - struct file * file; - int error; + struct file *file; + int error, fput_needed; error = -EINVAL; if (length < 0) goto out; error = -EBADF; - file = fget(fd); + file = fget_light(fd, &fput_needed); if (!file) goto out; @@ -172,7 +172,7 @@ static long do_sys_ftruncate(unsigned int fd, loff_t length, int small) error = do_truncate(dentry, length, ATTR_MTIME|ATTR_CTIME, file); sb_end_write(inode->i_sb); out_putf: - fput(file); + fput_light(file, fput_needed); out: return error; } |