X-Git-Url: http://pileus.org/git/?a=blobdiff_plain;f=fs%2Flocks.c;h=814c51d0de4739e4b89e9091e00c17f284c0e2ba;hb=3b876c8f2a361ceeed3fed894980c69066f903a0;hp=0d68f1f817996bef79ab16a4b0c51ceecd409d65;hpb=1e20932a23578bb1ec59107843574e259b96193f;p=~andy%2Flinux diff --git a/fs/locks.c b/fs/locks.c index 0d68f1f8179..814c51d0de4 100644 --- a/fs/locks.c +++ b/fs/locks.c @@ -1446,7 +1446,7 @@ int generic_setlease(struct file *filp, long arg, struct file_lock **flp) struct inode *inode = dentry->d_inode; int error; - if ((current_fsuid() != inode->i_uid) && !capable(CAP_LEASE)) + if ((!uid_eq(current_fsuid(), inode->i_uid)) && !capable(CAP_LEASE)) return -EACCES; if (!S_ISREG(inode->i_mode)) return -EINVAL; @@ -1636,12 +1636,13 @@ EXPORT_SYMBOL(flock_lock_file_wait); SYSCALL_DEFINE2(flock, unsigned int, fd, unsigned int, cmd) { struct file *filp; + int fput_needed; struct file_lock *lock; int can_sleep, unlock; int error; error = -EBADF; - filp = fget(fd); + filp = fget_light(fd, &fput_needed); if (!filp) goto out; @@ -1674,7 +1675,7 @@ SYSCALL_DEFINE2(flock, unsigned int, fd, unsigned int, cmd) locks_free_lock(lock); out_putf: - fput(filp); + fput_light(filp, fput_needed); out: return error; }