Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 5bd28bc2 authored by Jes Sorensen's avatar Jes Sorensen Committed by Greg Kroah-Hartman
Browse files

staging: rtl8723au: Check kmalloc return value and fix size of memcpy()



Check kmalloc() return before dereferencing bssid in
rtw_check_bcn_info23a() and use the correct size to copy
rtw_basic_rate_ofdm in update_bmc_sta_support_rate23a()

Reported-by: default avatarDan Carpenter <dan.carpenter@oracle.com>
Signed-off-by: default avatarJes Sorensen <Jes.Sorensen@redhat.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 7591ba8b
Loading
Loading
Loading
Loading
+1 −1
Original line number Diff line number Diff line
@@ -4510,7 +4510,7 @@ u8 collect_bss_info23a(struct rtw_adapter *padapter,
	}
	ie_offset -= offsetof(struct ieee80211_mgmt, u);

	bssid->Length = sizeof(struct wlan_bssid_ex) - MAX_IE_SZ + length;
	bssid->Length = offsetof(struct wlan_bssid_ex, IEs) + length;

	/* below is to copy the information element */
	bssid->IELength = length;
+9 −5
Original line number Diff line number Diff line
@@ -900,14 +900,16 @@ int rtw_check_bcn_info23a(struct rtw_adapter *Adapter,

	bssid = (struct wlan_bssid_ex *)kzalloc(sizeof(struct wlan_bssid_ex),
						GFP_ATOMIC);
	if (!bssid)
		return _FAIL;

	bssid->reserved = 1;

	bssid->Length = sizeof(struct wlan_bssid_ex) - MAX_IE_SZ + len;
	bssid->Length = offsetof(struct wlan_bssid_ex, IEs) + len;

	/* below is to copy the information element */
	bssid->IELength = len;
	memcpy(bssid->IEs, &mgmt->u, bssid->IELength);
	memcpy(bssid->IEs, &mgmt->u, len);

	/* check bw and channel offset */
	/* parsing HT_CAP_IE */
@@ -1589,9 +1591,11 @@ void update_bmc_sta_support_rate23a(struct rtw_adapter *padapter, u32 mac_id)

	if (pmlmeext->cur_wireless_mode & WIRELESS_11B) {
		/*  Only B, B/G, and B/G/N AP could use CCK rate */
		memcpy((pmlmeinfo->FW_sta_info[mac_id].SupportedRates), rtw_basic_rate_cck, 4);
		memcpy((pmlmeinfo->FW_sta_info[mac_id].SupportedRates),
		       rtw_basic_rate_cck, 4);
	} else {
		memcpy((pmlmeinfo->FW_sta_info[mac_id].SupportedRates), rtw_basic_rate_ofdm, 4);
		memcpy((pmlmeinfo->FW_sta_info[mac_id].SupportedRates),
		       rtw_basic_rate_ofdm, 3);
	}
}