diff options
author | Paul Gortmaker <paul.gortmaker@windriver.com> | 2011-06-20 09:02:11 -0400 |
---|---|---|
committer | Paul Gortmaker <paul.gortmaker@windriver.com> | 2011-06-20 09:31:22 -0400 |
commit | 2d6722a26f59acdf60df1a95218cdfa6cdf644d3 (patch) | |
tree | 00b0500e761b4ba5aec1a6372b5f3337e5f4219a | |
parent | e6bb8389738decb19abda6a814b57b71e46c2431 (diff) | |
download | longterm-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.patch | 85 | ||||
-rw-r--r-- | queue/series | 3 |
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 |