Commit a9cd4e74 authored by Ben Hutchings's avatar Ben Hutchings Committed by Kamal Mostafa

ipath: Restrict use of the write() interface

BugLink: http://bugs.launchpad.net/bugs/1614560

Commit e6bd18f5 ("IB/security: Restrict use of the write()
interface") fixed a security problem with various write()
implementations in the Infiniband subsystem.  In older kernel versions
the ipath_write() function has the same problem and needs the same
restriction.  (The ipath driver has been completely removed upstream.)
Signed-off-by: default avatarBen Hutchings <ben@decadent.org.uk>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: default avatarTim Gardner <tim.gardner@canonical.com>
Signed-off-by: default avatarKamal Mostafa <kamal@canonical.com>
parent 9ad33284
...@@ -45,6 +45,8 @@ ...@@ -45,6 +45,8 @@
#include <linux/uio.h> #include <linux/uio.h>
#include <asm/pgtable.h> #include <asm/pgtable.h>
#include <rdma/ib.h>
#include "ipath_kernel.h" #include "ipath_kernel.h"
#include "ipath_common.h" #include "ipath_common.h"
#include "ipath_user_sdma.h" #include "ipath_user_sdma.h"
...@@ -2243,6 +2245,9 @@ static ssize_t ipath_write(struct file *fp, const char __user *data, ...@@ -2243,6 +2245,9 @@ static ssize_t ipath_write(struct file *fp, const char __user *data,
ssize_t ret = 0; ssize_t ret = 0;
void *dest; void *dest;
if (WARN_ON_ONCE(!ib_safe_file_access(fp)))
return -EACCES;
if (count < sizeof(cmd.type)) { if (count < sizeof(cmd.type)) {
ret = -EINVAL; ret = -EINVAL;
goto bail; goto bail;
......
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