forked from Minki/linux
Staging: vt6656: add some range checks before memcpy()
We need to verify that we're not writing past the end of the array. Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
This commit is contained in:
parent
883aeecc9d
commit
44ec5d2916
@ -81,6 +81,8 @@ int private_ioctl(PSDevice pDevice, struct ifreq *rq)
|
||||
}
|
||||
|
||||
pItemSSID = (PWLAN_IE_SSID)sScanCmd.ssid;
|
||||
if (pItemSSID->len > WLAN_SSID_MAXLEN + 1)
|
||||
return -EINVAL;
|
||||
if (pItemSSID->len != 0) {
|
||||
memset(abyScanSSID, 0, WLAN_IEHDR_LEN + WLAN_SSID_MAXLEN + 1);
|
||||
memcpy(abyScanSSID, pItemSSID, pItemSSID->len + WLAN_IEHDR_LEN);
|
||||
@ -155,6 +157,8 @@ int private_ioctl(PSDevice pDevice, struct ifreq *rq)
|
||||
}
|
||||
|
||||
pItemSSID = (PWLAN_IE_SSID)sJoinCmd.ssid;
|
||||
if (pItemSSID->len > WLAN_SSID_MAXLEN + 1)
|
||||
return -EINVAL;
|
||||
memset(pMgmt->abyDesireSSID, 0, WLAN_IEHDR_LEN + WLAN_SSID_MAXLEN + 1);
|
||||
memcpy(pMgmt->abyDesireSSID, pItemSSID, pItemSSID->len + WLAN_IEHDR_LEN);
|
||||
if (sJoinCmd.wBSSType == ADHOC) {
|
||||
@ -476,6 +480,8 @@ int private_ioctl(PSDevice pDevice, struct ifreq *rq)
|
||||
}
|
||||
|
||||
pItemSSID = (PWLAN_IE_SSID)sStartAPCmd.ssid;
|
||||
if (pItemSSID->len > WLAN_SSID_MAXLEN + 1)
|
||||
return -EINVAL;
|
||||
memset(pMgmt->abyDesireSSID, 0, WLAN_IEHDR_LEN + WLAN_SSID_MAXLEN + 1);
|
||||
memcpy(pMgmt->abyDesireSSID, pItemSSID, pItemSSID->len + WLAN_IEHDR_LEN);
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user