提交 c25015c1 编写于 作者: D Dan Carpenter 提交者: Greg Kroah-Hartman

Staging: vt6655-6: shift wrap in hostap_set_encryption()

abySeq is an unsigned char so shifting more than 31 bits will lead to a
shift wrapping bug.
Signed-off-by: NDan Carpenter <dan.carpenter@oracle.com>
Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
上级 ff4573a7
...@@ -596,9 +596,9 @@ static int hostap_set_encryption(PSDevice pDevice, ...@@ -596,9 +596,9 @@ static int hostap_set_encryption(PSDevice pDevice,
if (param->u.crypt.seq) { if (param->u.crypt.seq) {
memcpy(&abySeq, param->u.crypt.seq, 8); memcpy(&abySeq, param->u.crypt.seq, 8);
for (ii = 0 ; ii < 8 ; ii++) { for (ii = 0 ; ii < 8 ; ii++)
KeyRSC |= (abySeq[ii] << (ii * 8)); KeyRSC |= (unsigned long)abySeq[ii] << (ii * 8);
}
dwKeyIndex |= 1 << 29; dwKeyIndex |= 1 << 29;
pMgmt->sNodeDBTable[iNodeIndex].KeyRSC = KeyRSC; pMgmt->sNodeDBTable[iNodeIndex].KeyRSC = KeyRSC;
} }
......
...@@ -542,9 +542,9 @@ static int hostap_set_encryption(PSDevice pDevice, ...@@ -542,9 +542,9 @@ static int hostap_set_encryption(PSDevice pDevice,
if (param->u.crypt.seq) { if (param->u.crypt.seq) {
memcpy(&abySeq, param->u.crypt.seq, 8); memcpy(&abySeq, param->u.crypt.seq, 8);
for (ii = 0 ; ii < 8 ; ii++) { for (ii = 0 ; ii < 8 ; ii++)
KeyRSC |= (abySeq[ii] << (ii * 8)); KeyRSC |= (unsigned long)abySeq[ii] << (ii * 8);
}
dwKeyIndex |= 1 << 29; dwKeyIndex |= 1 << 29;
pMgmt->sNodeDBTable[iNodeIndex].KeyRSC = KeyRSC; pMgmt->sNodeDBTable[iNodeIndex].KeyRSC = KeyRSC;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册