Skip to content

Commit

Permalink
Merge tag 'locks-v3.15-4' of git://git.samba.org/jlayton/linux
Browse files Browse the repository at this point in the history
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
  • Loading branch information
Linus Torvalds committed May 13, 2014
2 parents 77d9278 + cf01f4e commit 14186fe
Showing 1 changed file with 24 additions and 12 deletions.
36 changes: 24 additions & 12 deletions fs/locks.c
Original file line number Diff line number Diff line change
Expand Up @@ -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);
}

Expand Down Expand Up @@ -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().
*/
Expand Down Expand Up @@ -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.
Expand Down Expand Up @@ -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.
Expand Down

0 comments on commit 14186fe

Please sign in to comment.