staging: wilc1000: Increase the size of wid_list array

Increase by one the size of wid_list array as index variable can reach a
value of 5. If this happens, an out-of-bounds access is performed.

Also, use a #define instead of a hard-coded literal for the new array
size.

Addresses-Coverity-ID: 1451981 ("Out-of-bounds access")
Fixes: f5a3cb90b8 ("staging: wilc1000: add passive scan support")
Acked-by: Ajay Singh <ajay.kathat@microchip.com>
Signed-off-by: Oscar Carter <oscar.carter@gmx.com>
Link: https://lore.kernel.org/r/20200504150911.4470-1-oscar.carter@gmx.com
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
Oscar Carter 2020-05-04 17:09:11 +02:00 committed by Greg Kroah-Hartman
parent 8d8a1424a0
commit a4338ed2e1
1 changed files with 3 additions and 1 deletions

View File

@ -11,6 +11,8 @@
#define WILC_FALSE_FRMWR_CHANNEL 100 #define WILC_FALSE_FRMWR_CHANNEL 100
#define WILC_SCAN_WID_LIST_SIZE 6
struct wilc_rcvd_mac_info { struct wilc_rcvd_mac_info {
u8 status; u8 status;
}; };
@ -151,7 +153,7 @@ int wilc_scan(struct wilc_vif *vif, u8 scan_source, u8 scan_type,
void *user_arg, struct cfg80211_scan_request *request) void *user_arg, struct cfg80211_scan_request *request)
{ {
int result = 0; int result = 0;
struct wid wid_list[5]; struct wid wid_list[WILC_SCAN_WID_LIST_SIZE];
u32 index = 0; u32 index = 0;
u32 i, scan_timeout; u32 i, scan_timeout;
u8 *buffer; u8 *buffer;