Commit e59164b8 authored by J. Bruce Fields's avatar J. Bruce Fields Committed by Willy Tarreau

locks: fix checking of fcntl_setlease argument

commit 0ec4f431 upstream.

The only checks of the long argument passed to fcntl(fd,F_SETLEASE,.)
are done after converting the long to an int.  Thus some illegal values
may be let through and cause problems in later code.

[ They actually *don't* cause problems in mainline, as of Dave Jones's
  commit 8d657eb3 "Remove easily user-triggerable BUG from
  generic_setlease", but we should fix this anyway.  And this patch will
  be necessary to fix real bugs on earlier kernels. ]
Signed-off-by: default avatarJ. Bruce Fields <bfields@redhat.com>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: default avatarWilly Tarreau <w@1wt.eu>
parent 105ef39b
...@@ -291,7 +291,7 @@ static int flock_make_lock(struct file *filp, struct file_lock **lock, ...@@ -291,7 +291,7 @@ static int flock_make_lock(struct file *filp, struct file_lock **lock,
return 0; return 0;
} }
static int assign_type(struct file_lock *fl, int type) static int assign_type(struct file_lock *fl, long type)
{ {
switch (type) { switch (type) {
case F_RDLCK: case F_RDLCK:
...@@ -444,7 +444,7 @@ static const struct lock_manager_operations lease_manager_ops = { ...@@ -444,7 +444,7 @@ static const struct lock_manager_operations lease_manager_ops = {
/* /*
* Initialize a lease, use the default lock manager operations * Initialize a lease, use the default lock manager operations
*/ */
static int lease_init(struct file *filp, int type, struct file_lock *fl) static int lease_init(struct file *filp, long type, struct file_lock *fl)
{ {
if (assign_type(fl, type) != 0) if (assign_type(fl, type) != 0)
return -EINVAL; return -EINVAL;
...@@ -462,7 +462,7 @@ static int lease_init(struct file *filp, int type, struct file_lock *fl) ...@@ -462,7 +462,7 @@ static int lease_init(struct file *filp, int type, struct file_lock *fl)
} }
/* Allocate a file_lock initialised to this type of lease */ /* Allocate a file_lock initialised to this type of lease */
static struct file_lock *lease_alloc(struct file *filp, int type) static struct file_lock *lease_alloc(struct file *filp, long type)
{ {
struct file_lock *fl = locks_alloc_lock(); struct file_lock *fl = locks_alloc_lock();
int error = -ENOMEM; int error = -ENOMEM;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment