mirror of
git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-09-04 20:19:47 +08:00
staging: rtlwifi: check for array overflow
Smatch is distrustful of the "capab" value and marks it as user controlled. I think it actually comes from the firmware? Anyway, I looked at other drivers and they added a bounds check and it seems like a harmless thing to have so I have added it here as well. Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com> Acked-by: Larry Finger <Larry.Finger@lwfinger.net> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
cec8bb22fb
commit
dc33bd4309
@ -1414,6 +1414,10 @@ bool rtl_action_proc(struct ieee80211_hw *hw, struct sk_buff *skb, u8 is_tx)
|
|||||||
le16_to_cpu(mgmt->u.action.u.addba_req.capab);
|
le16_to_cpu(mgmt->u.action.u.addba_req.capab);
|
||||||
tid = (capab &
|
tid = (capab &
|
||||||
IEEE80211_ADDBA_PARAM_TID_MASK) >> 2;
|
IEEE80211_ADDBA_PARAM_TID_MASK) >> 2;
|
||||||
|
if (tid >= MAX_TID_COUNT) {
|
||||||
|
rcu_read_unlock();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
tid_data = &sta_entry->tids[tid];
|
tid_data = &sta_entry->tids[tid];
|
||||||
if (tid_data->agg.rx_agg_state ==
|
if (tid_data->agg.rx_agg_state ==
|
||||||
RTL_RX_AGG_START)
|
RTL_RX_AGG_START)
|
||||||
|
Loading…
Reference in New Issue
Block a user