summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPaul Gortmaker <paul.gortmaker@windriver.com>2011-06-20 09:02:11 -0400
committerPaul Gortmaker <paul.gortmaker@windriver.com>2011-06-20 09:31:22 -0400
commit2d6722a26f59acdf60df1a95218cdfa6cdf644d3 (patch)
tree00b0500e761b4ba5aec1a6372b5f3337e5f4219a
parente6bb8389738decb19abda6a814b57b71e46c2431 (diff)
downloadlongterm-queue-2.6.34-2d6722a26f59acdf60df1a95218cdfa6cdf644d3.tar.gz
add mpt2sas CVE fix
Signed-off-by: Paul Gortmaker <paul.gortmaker@windriver.com>
-rw-r--r--queue/mpt2sas-prevent-heap-overflows-and-unchecked-reads.patch85
-rw-r--r--queue/series3
2 files changed, 88 insertions, 0 deletions
diff --git a/queue/mpt2sas-prevent-heap-overflows-and-unchecked-reads.patch b/queue/mpt2sas-prevent-heap-overflows-and-unchecked-reads.patch
new file mode 100644
index 0000000..0554fbf
--- /dev/null
+++ b/queue/mpt2sas-prevent-heap-overflows-and-unchecked-reads.patch
@@ -0,0 +1,85 @@
+From 77fc9b17c6e6aafee6faae68364538ba87d2cc16 Mon Sep 17 00:00:00 2001
+From: Dan Rosenberg <drosenberg@vsecurity.com>
+Date: Tue, 5 Apr 2011 12:45:59 -0400
+Subject: [PATCH] mpt2sas: prevent heap overflows and unchecked reads
+
+commit a1f74ae82d133ebb2aabb19d181944b4e83e9960 upstream.
+
+At two points in handling device ioctls via /dev/mpt2ctl, user-supplied
+length values are used to copy data from userspace into heap buffers
+without bounds checking, allowing controllable heap corruption and
+subsequently privilege escalation.
+
+Additionally, user-supplied values are used to determine the size of a
+copy_to_user() as well as the offset into the buffer to be read, with no
+bounds checking, allowing users to read arbitrary kernel memory.
+
+Signed-off-by: Dan Rosenberg <drosenberg@vsecurity.com>
+Acked-by: Eric Moore <eric.moore@lsi.com>
+Signed-off-by: James Bottomley <James.Bottomley@suse.de>
+Signed-off-by: Paul Gortmaker <paul.gortmaker@windriver.com>
+
+diff --git a/drivers/scsi/mpt2sas/mpt2sas_ctl.c b/drivers/scsi/mpt2sas/mpt2sas_ctl.c
+index fa9bf83..3742ac9 100644
+--- a/drivers/scsi/mpt2sas/mpt2sas_ctl.c
++++ b/drivers/scsi/mpt2sas/mpt2sas_ctl.c
+@@ -636,6 +636,13 @@ _ctl_do_mpt_command(struct MPT2SAS_ADAPTER *ioc,
+ data_out_sz = karg.data_out_size;
+ data_in_sz = karg.data_in_size;
+
++ /* Check for overflow and wraparound */
++ if (karg.data_sge_offset * 4 > ioc->request_sz ||
++ karg.data_sge_offset > (UINT_MAX / 4)) {
++ ret = -EINVAL;
++ goto out;
++ }
++
+ /* copy in request message frame from user */
+ if (copy_from_user(mpi_request, mf, karg.data_sge_offset*4)) {
+ printk(KERN_ERR "failure at %s:%d/%s()!\n", __FILE__, __LINE__,
+@@ -1877,7 +1884,7 @@ _ctl_diag_read_buffer(void __user *arg, enum block_state state)
+ Mpi2DiagBufferPostReply_t *mpi_reply;
+ int rc, i;
+ u8 buffer_type;
+- unsigned long timeleft;
++ unsigned long timeleft, request_size, copy_size;
+ u16 smid;
+ u16 ioc_status;
+ u8 issue_reset = 0;
+@@ -1913,6 +1920,8 @@ _ctl_diag_read_buffer(void __user *arg, enum block_state state)
+ return -ENOMEM;
+ }
+
++ request_size = ioc->diag_buffer_sz[buffer_type];
++
+ if ((karg.starting_offset % 4) || (karg.bytes_to_read % 4)) {
+ printk(MPT2SAS_ERR_FMT "%s: either the starting_offset "
+ "or bytes_to_read are not 4 byte aligned\n", ioc->name,
+@@ -1920,13 +1929,23 @@ _ctl_diag_read_buffer(void __user *arg, enum block_state state)
+ return -EINVAL;
+ }
+
++ if (karg.starting_offset > request_size)
++ return -EINVAL;
++
+ diag_data = (void *)(request_data + karg.starting_offset);
+ dctlprintk(ioc, printk(MPT2SAS_DEBUG_FMT "%s: diag_buffer(%p), "
+ "offset(%d), sz(%d)\n", ioc->name, __func__,
+ diag_data, karg.starting_offset, karg.bytes_to_read));
+
++ /* Truncate data on requests that are too large */
++ if ((diag_data + karg.bytes_to_read < diag_data) ||
++ (diag_data + karg.bytes_to_read > request_data + request_size))
++ copy_size = request_size - karg.starting_offset;
++ else
++ copy_size = karg.bytes_to_read;
++
+ if (copy_to_user((void __user *)uarg->diagnostic_data,
+- diag_data, karg.bytes_to_read)) {
++ diag_data, copy_size)) {
+ printk(MPT2SAS_ERR_FMT "%s: Unable to write "
+ "mpt_diag_read_buffer_t data @ %p\n", ioc->name,
+ __func__, diag_data);
+--
+1.7.4.4
+
diff --git a/queue/series b/queue/series
index 2a7d7f6..07be2fd 100644
--- a/queue/series
+++ b/queue/series
@@ -233,6 +233,9 @@ procfs-fix-proc-pid-maps-heap-check.patch
ext3-skip-orphan-cleanup-on-rocompat-fs.patch
PCI-return-correct-value-when-writing-to-the-reset-a.patch
+# Content taken from v2.6.32.40
+mpt2sas-prevent-heap-overflows-and-unchecked-reads.patch
+
# Content taken from v2.6.35.11
arch-x86-oprofile-op_model_amd.c-Perform-initialisat.patch