mirror of
https://github.com/hardkernel/linux.git
synced 2026-06-05 18:41:58 +09:00
wifi: iwlwifi: mvm: avoid NULL pointer dereference
commit 557a6cd847645e667f3b362560bd7e7c09aac284 upstream. iwl_mvm_tx_skb_sta() and iwl_mvm_tx_mpdu() verify that the mvmvsta pointer is not NULL. It retrieves this pointer using iwl_mvm_sta_from_mac80211, which is dereferencing the ieee80211_sta pointer. If sta is NULL, iwl_mvm_sta_from_mac80211 will dereference a NULL pointer. Fix this by checking the sta pointer before retrieving the mvmsta from it. If sta is not NULL, then mvmsta isn't either. Signed-off-by: Miri Korenblit <miriam.rachel.korenblit@intel.com> Reviewed-by: Johannes Berg <johannes.berg@intel.com> Link: https://patch.msgid.link/20240825191257.880921ce23b7.I340052d70ab6d3410724ce955eb00da10e08188f@changeid Signed-off-by: Johannes Berg <johannes.berg@intel.com> Signed-off-by: Sasha Levin <sashal@kernel.org> Signed-off-by: Xiangyu Chen <xiangyu.chen@windriver.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
committed by
Greg Kroah-Hartman
parent
4c823e4027
commit
cbc6fc9cfc
@@ -1105,6 +1105,9 @@ static int iwl_mvm_tx_mpdu(struct iwl_mvm *mvm, struct sk_buff *skb,
|
|||||||
bool is_ampdu = false;
|
bool is_ampdu = false;
|
||||||
int hdrlen;
|
int hdrlen;
|
||||||
|
|
||||||
|
if (WARN_ON_ONCE(!sta))
|
||||||
|
return -1;
|
||||||
|
|
||||||
mvmsta = iwl_mvm_sta_from_mac80211(sta);
|
mvmsta = iwl_mvm_sta_from_mac80211(sta);
|
||||||
fc = hdr->frame_control;
|
fc = hdr->frame_control;
|
||||||
hdrlen = ieee80211_hdrlen(fc);
|
hdrlen = ieee80211_hdrlen(fc);
|
||||||
@@ -1112,9 +1115,6 @@ static int iwl_mvm_tx_mpdu(struct iwl_mvm *mvm, struct sk_buff *skb,
|
|||||||
if (IWL_MVM_NON_TRANSMITTING_AP && ieee80211_is_probe_resp(fc))
|
if (IWL_MVM_NON_TRANSMITTING_AP && ieee80211_is_probe_resp(fc))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
if (WARN_ON_ONCE(!mvmsta))
|
|
||||||
return -1;
|
|
||||||
|
|
||||||
if (WARN_ON_ONCE(mvmsta->sta_id == IWL_MVM_INVALID_STA))
|
if (WARN_ON_ONCE(mvmsta->sta_id == IWL_MVM_INVALID_STA))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
@@ -1242,16 +1242,18 @@ drop:
|
|||||||
int iwl_mvm_tx_skb_sta(struct iwl_mvm *mvm, struct sk_buff *skb,
|
int iwl_mvm_tx_skb_sta(struct iwl_mvm *mvm, struct sk_buff *skb,
|
||||||
struct ieee80211_sta *sta)
|
struct ieee80211_sta *sta)
|
||||||
{
|
{
|
||||||
struct iwl_mvm_sta *mvmsta = iwl_mvm_sta_from_mac80211(sta);
|
struct iwl_mvm_sta *mvmsta;
|
||||||
struct ieee80211_tx_info info;
|
struct ieee80211_tx_info info;
|
||||||
struct sk_buff_head mpdus_skbs;
|
struct sk_buff_head mpdus_skbs;
|
||||||
unsigned int payload_len;
|
unsigned int payload_len;
|
||||||
int ret;
|
int ret;
|
||||||
struct sk_buff *orig_skb = skb;
|
struct sk_buff *orig_skb = skb;
|
||||||
|
|
||||||
if (WARN_ON_ONCE(!mvmsta))
|
if (WARN_ON_ONCE(!sta))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
|
mvmsta = iwl_mvm_sta_from_mac80211(sta);
|
||||||
|
|
||||||
if (WARN_ON_ONCE(mvmsta->sta_id == IWL_MVM_INVALID_STA))
|
if (WARN_ON_ONCE(mvmsta->sta_id == IWL_MVM_INVALID_STA))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user