mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2026-05-02 08:39:08 -04:00
Merge tag 'locks-v3.15-4' of git://git.samba.org/jlayton/linux
Pull file locking fix from Jeff Layton: "Fix for regression in handling of F_GETLK commands" * tag 'locks-v3.15-4' of git://git.samba.org/jlayton/linux: locks: only validate the lock vs. f_mode in F_SETLK codepaths
This commit is contained in:
36
fs/locks.c
36
fs/locks.c
@@ -389,18 +389,6 @@ static int flock64_to_posix_lock(struct file *filp, struct file_lock *fl,
|
||||
fl->fl_ops = NULL;
|
||||
fl->fl_lmops = NULL;
|
||||
|
||||
/* Ensure that fl->fl_filp has compatible f_mode */
|
||||
switch (l->l_type) {
|
||||
case F_RDLCK:
|
||||
if (!(filp->f_mode & FMODE_READ))
|
||||
return -EBADF;
|
||||
break;
|
||||
case F_WRLCK:
|
||||
if (!(filp->f_mode & FMODE_WRITE))
|
||||
return -EBADF;
|
||||
break;
|
||||
}
|
||||
|
||||
return assign_type(fl, l->l_type);
|
||||
}
|
||||
|
||||
@@ -2034,6 +2022,22 @@ static int do_lock_file_wait(struct file *filp, unsigned int cmd,
|
||||
return error;
|
||||
}
|
||||
|
||||
/* Ensure that fl->fl_filp has compatible f_mode for F_SETLK calls */
|
||||
static int
|
||||
check_fmode_for_setlk(struct file_lock *fl)
|
||||
{
|
||||
switch (fl->fl_type) {
|
||||
case F_RDLCK:
|
||||
if (!(fl->fl_file->f_mode & FMODE_READ))
|
||||
return -EBADF;
|
||||
break;
|
||||
case F_WRLCK:
|
||||
if (!(fl->fl_file->f_mode & FMODE_WRITE))
|
||||
return -EBADF;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
/* Apply the lock described by l to an open file descriptor.
|
||||
* This implements both the F_SETLK and F_SETLKW commands of fcntl().
|
||||
*/
|
||||
@@ -2071,6 +2075,10 @@ int fcntl_setlk(unsigned int fd, struct file *filp, unsigned int cmd,
|
||||
if (error)
|
||||
goto out;
|
||||
|
||||
error = check_fmode_for_setlk(file_lock);
|
||||
if (error)
|
||||
goto out;
|
||||
|
||||
/*
|
||||
* If the cmd is requesting file-private locks, then set the
|
||||
* FL_OFDLCK flag and override the owner.
|
||||
@@ -2206,6 +2214,10 @@ int fcntl_setlk64(unsigned int fd, struct file *filp, unsigned int cmd,
|
||||
if (error)
|
||||
goto out;
|
||||
|
||||
error = check_fmode_for_setlk(file_lock);
|
||||
if (error)
|
||||
goto out;
|
||||
|
||||
/*
|
||||
* If the cmd is requesting file-private locks, then set the
|
||||
* FL_OFDLCK flag and override the owner.
|
||||
|
||||
Reference in New Issue
Block a user