diff options
author | Ralph Campbell | 2006-07-18 03:21:24 +0200 |
---|---|---|
committer | Roland Dreier | 2006-07-24 18:18:07 +0200 |
commit | 16c59419a09f0140a07a1828d6a45656265e07c7 (patch) | |
tree | 561234eaf2a32f143566f62ef660f1cac2b68ebf | |
parent | IB/ipath: Fix ib_ipath driver to work with SRP (diff) | |
download | kernel-qcow2-linux-16c59419a09f0140a07a1828d6a45656265e07c7.tar.gz kernel-qcow2-linux-16c59419a09f0140a07a1828d6a45656265e07c7.tar.xz kernel-qcow2-linux-16c59419a09f0140a07a1828d6a45656265e07c7.zip |
IB/ipath: ipath_skip_sge() can break if num_sge > 1
ipath_skip_sge() doesn't exactly duplicate the side effects of
ipath_copy_sge() if num_sge > 1 since it doesn't decrement ss->num_sge.
This could result in the sg_list being accessed out of bounds.
Since ipath_skip_sge() is almost always called with num_sge == 1,
the original "optimization" is almost never used.
Signed-off-by: Ralph Campbell <ralph.campbell@qlogic.com>
Signed-off-by: Roland Dreier <rolandd@cisco.com>
-rw-r--r-- | drivers/infiniband/hw/ipath/ipath_verbs.c | 4 |
1 files changed, 0 insertions, 4 deletions
diff --git a/drivers/infiniband/hw/ipath/ipath_verbs.c b/drivers/infiniband/hw/ipath/ipath_verbs.c index 70bce7a8d538..d70a9b6b5239 100644 --- a/drivers/infiniband/hw/ipath/ipath_verbs.c +++ b/drivers/infiniband/hw/ipath/ipath_verbs.c @@ -191,10 +191,6 @@ void ipath_skip_sge(struct ipath_sge_state *ss, u32 length) { struct ipath_sge *sge = &ss->sge; - while (length > sge->sge_length) { - length -= sge->sge_length; - ss->sge = *ss->sg_list++; - } while (length) { u32 len = sge->length; |