Staging: rtl8192e: array overflow in rtl92e_set_swcam()
"EntryNo" is comes from the user in the ioctl and it's a number between 0-255. The ieee->swcamtable[] array only has 32 elements so it can result in memory corruption. Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
881bf28123
commit
d1f0f3118e
|
@ -78,6 +78,10 @@ void rtl92e_set_swcam(struct net_device *dev, u8 EntryNo, u8 KeyIndex,
|
||||||
RT_TRACE(COMP_DBG,
|
RT_TRACE(COMP_DBG,
|
||||||
"===========>%s():EntryNo is %d,KeyIndex is %d,KeyType is %d,is_mesh is %d\n",
|
"===========>%s():EntryNo is %d,KeyIndex is %d,KeyType is %d,is_mesh is %d\n",
|
||||||
__func__, EntryNo, KeyIndex, KeyType, is_mesh);
|
__func__, EntryNo, KeyIndex, KeyType, is_mesh);
|
||||||
|
|
||||||
|
if (EntryNo >= TOTAL_CAM_ENTRY)
|
||||||
|
return;
|
||||||
|
|
||||||
if (!is_mesh) {
|
if (!is_mesh) {
|
||||||
ieee->swcamtable[EntryNo].bused = true;
|
ieee->swcamtable[EntryNo].bused = true;
|
||||||
ieee->swcamtable[EntryNo].key_index = KeyIndex;
|
ieee->swcamtable[EntryNo].key_index = KeyIndex;
|
||||||
|
|
Loading…
Reference in New Issue