Commit e75b6189 authored by Dan Carpenter's avatar Dan Carpenter Committed by Ben Hutchings

USB: cxacru: potential underflow in cxacru_cm_get_array()

commit 2a0ebf80 upstream.

The value of "offd" comes off the instance->rcv_buf[] and we used it as
the offset into an array.  The problem is that we check the upper bound
but not for negative values.
Signed-off-by: default avatarDan Carpenter <dan.carpenter@oracle.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: default avatarBen Hutchings <ben@decadent.org.uk>
parent cba40e7f
...@@ -686,7 +686,8 @@ static int cxacru_cm_get_array(struct cxacru_data *instance, enum cxacru_cm_requ ...@@ -686,7 +686,8 @@ static int cxacru_cm_get_array(struct cxacru_data *instance, enum cxacru_cm_requ
{ {
int ret, len; int ret, len;
__le32 *buf; __le32 *buf;
int offb, offd; int offb;
unsigned int offd;
const int stride = CMD_PACKET_SIZE / (4 * 2) - 1; const int stride = CMD_PACKET_SIZE / (4 * 2) - 1;
int buflen = ((size - 1) / stride + 1 + size * 2) * 4; int buflen = ((size - 1) / stride + 1 + size * 2) * 4;
......
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