diff options
author | Akinobu Mita <akinobu.mita@gmail.com> | 2011-03-02 06:35:28 -0500 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@suse.de> | 2011-03-02 19:52:28 -0500 |
commit | 962f3ffa927f2e777a4193843c45ffa6e52ff4b6 (patch) | |
tree | c28bc6eb94b6e4d4de5a4e918b7cf170f4e2485f /drivers/usb | |
parent | 60b0bf0f11a02a6c288c7a923b2521aa7cfdc6c3 (diff) |
wusb: fix find_first_zero_bit() return value check
In wusb_cluster_id_get(), if no zero bits exist in wusb_cluster_id_table,
find_first_zero_bit() returns CLUSTER_IDS.
But it is impossible to detect that the bitmap is full because there
is an off-by-one error in the return value check. It will cause
unexpected memory access by setting bit out of wusb_cluster_id_table
bitmap, and caller will get wrong cluster id.
Signed-off-by: Akinobu Mita <akinobu.mita@gmail.com>
Cc: linux-usb@vger.kernel.org
Cc: Greg Kroah-Hartman <gregkh@suse.de>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'drivers/usb')
-rw-r--r-- | drivers/usb/wusbcore/wusbhc.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/usb/wusbcore/wusbhc.c b/drivers/usb/wusbcore/wusbhc.c index 2054d4ee977..0faca16df76 100644 --- a/drivers/usb/wusbcore/wusbhc.c +++ b/drivers/usb/wusbcore/wusbhc.c | |||
@@ -320,7 +320,7 @@ u8 wusb_cluster_id_get(void) | |||
320 | u8 id; | 320 | u8 id; |
321 | spin_lock(&wusb_cluster_ids_lock); | 321 | spin_lock(&wusb_cluster_ids_lock); |
322 | id = find_first_zero_bit(wusb_cluster_id_table, CLUSTER_IDS); | 322 | id = find_first_zero_bit(wusb_cluster_id_table, CLUSTER_IDS); |
323 | if (id > CLUSTER_IDS) { | 323 | if (id >= CLUSTER_IDS) { |
324 | id = 0; | 324 | id = 0; |
325 | goto out; | 325 | goto out; |
326 | } | 326 | } |