From: Dave Taht <dave.taht@gmail.com>
To: make-wifi-fast@lists.bufferbloat.net
Subject: [Make-wifi-fast] Fwd: [PATCH] mac80211: prevent skb/txq mismatch
Date: Thu, 12 Jan 2017 10:44:12 -0800 [thread overview]
Message-ID: <CAA93jw6zJ3WObdvnOqE=VQ3Cs5emf9qyUVMLbTg4QWL9r5TOPg@mail.gmail.com> (raw)
In-Reply-To: <1484231321-3179-1-git-send-email-michal.kazior@tieto.com>
yea! (I think)
---------- Forwarded message ----------
From: Michal Kazior <michal.kazior@tieto.com>
Date: Thu, Jan 12, 2017 at 6:28 AM
Subject: [PATCH] mac80211: prevent skb/txq mismatch
To: johannes@sipsolutions.net
Cc: linux-wireless@vger.kernel.org, greearb@candelatech.com,
mohammed@qti.qualcomm.com, Michal Kazior <michal.kazior@tieto.com>
Station structure is considered as not uploaded
(to driver) until drv_sta_state() finishes. This
call is however done after the structure is
attached to mac80211 internal lists and hashes.
This means mac80211 can lookup (and use) station
structure before it is uploaded to a driver.
If this happens (structure exists, but
sta->uploaded is false) fast_tx path can still be
taken. Deep in the fastpath call the sta->uploaded
is checked against to derive "pubsta" argument for
ieee80211_get_txq(). If sta->uploaded is false
(and sta is actually non-NULL) ieee80211_get_txq()
effectively downgraded to vif->txq.
At first glance this may look innocent but coerces
mac80211 into a state that is almost guaranteed
(codel may drop offending skb) to crash because a
station-oriented skb gets queued up on
vif-oriented txq. The ieee80211_tx_dequeue() ends
up looking at info->control.flags and tries to use
txq->sta which in the fail case is NULL.
It's probably pointless to pretend one can
downgrade skb from sta-txq to vif-txq.
Only drivers using wake_tx_queue were affected.
Example crash dump before fix:
Unable to handle kernel paging request at virtual address ffffe26c
PC is at ieee80211_tx_dequeue+0x204/0x690 [mac80211]
[<bf4252a4>] (ieee80211_tx_dequeue [mac80211]) from
[<bf4b1388>] (ath10k_mac_tx_push_txq+0x54/0x1c0 [ath10k_core])
[<bf4b1388>] (ath10k_mac_tx_push_txq [ath10k_core]) from
[<bf4bdfbc>] (ath10k_htt_txrx_compl_task+0xd78/0x11d0 [ath10k_core])
[<bf4bdfbc>] (ath10k_htt_txrx_compl_task [ath10k_core])
[<bf51c5a4>] (ath10k_pci_napi_poll+0x54/0xe8 [ath10k_pci])
[<bf51c5a4>] (ath10k_pci_napi_poll [ath10k_pci]) from
[<c0572e90>] (net_rx_action+0xac/0x160)
Reported-by: Mohammed Shafi Shajakhan <mohammed@qti.qualcomm.com>
Signed-off-by: Michal Kazior <michal.kazior@tieto.com>
---
net/mac80211/tx.c | 17 +++++++----------
1 file changed, 7 insertions(+), 10 deletions(-)
diff --git a/net/mac80211/tx.c b/net/mac80211/tx.c
index 4dea18be385c..c77fcf83d004 100644
--- a/net/mac80211/tx.c
+++ b/net/mac80211/tx.c
@@ -1244,13 +1244,16 @@ ieee80211_tx_prepare(struct
ieee80211_sub_if_data *sdata,
static struct txq_info *ieee80211_get_txq(struct ieee80211_local *local,
struct ieee80211_vif *vif,
- struct ieee80211_sta *pubsta,
+ struct sta_info *sta,
struct sk_buff *skb)
{
struct ieee80211_hdr *hdr = (struct ieee80211_hdr *) skb->data;
struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb);
struct ieee80211_txq *txq = NULL;
+ if (sta && !sta->uploaded)
+ return NULL;
+
if ((info->flags & IEEE80211_TX_CTL_SEND_AFTER_DTIM) ||
(info->control.flags & IEEE80211_TX_CTRL_PS_RESPONSE))
return NULL;
@@ -1258,10 +1261,10 @@ static struct txq_info
*ieee80211_get_txq(struct ieee80211_local *local,
if (!ieee80211_is_data(hdr->frame_control))
return NULL;
- if (pubsta) {
+ if (sta) {
u8 tid = skb->priority & IEEE80211_QOS_CTL_TID_MASK;
- txq = pubsta->txq[tid];
+ txq = sta->sta.txq[tid];
} else if (vif) {
txq = vif->txq;
}
@@ -1504,23 +1507,17 @@ static bool ieee80211_queue_skb(struct
ieee80211_local *local,
struct fq *fq = &local->fq;
struct ieee80211_vif *vif;
struct txq_info *txqi;
- struct ieee80211_sta *pubsta;
if (!local->ops->wake_tx_queue ||
sdata->vif.type == NL80211_IFTYPE_MONITOR)
return false;
- if (sta && sta->uploaded)
- pubsta = &sta->sta;
- else
- pubsta = NULL;
-
if (sdata->vif.type == NL80211_IFTYPE_AP_VLAN)
sdata = container_of(sdata->bss,
struct ieee80211_sub_if_data, u.ap);
vif = &sdata->vif;
- txqi = ieee80211_get_txq(local, vif, pubsta, skb);
+ txqi = ieee80211_get_txq(local, vif, sta, skb);
if (!txqi)
return false;
--
2.1.4
--
Dave Täht
Let's go make home routers and wifi faster! With better software!
http://blog.cerowrt.org
next parent reply other threads:[~2017-01-12 18:44 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
[not found] <1484231321-3179-1-git-send-email-michal.kazior@tieto.com>
2017-01-12 18:44 ` Dave Taht [this message]
[not found] <CALukJKSMpY11yKZXeyV=P=LmVh_xb3HGwp7c-G9Yv+POETEFeA@mail.gmail.com>
[not found] ` <CALukJKRToYyExFZ+Xp1n9CjF59+X=m12ZNru-MQA+Ldnd1EW+g@mail.gmail.com>
[not found] ` <CALukJKS7RHiXiDFUjxqy1Xh7XdxxTh8fRz9wj8xszOuEcGcO3g@mail.gmail.com>
[not found] ` <CALukJKRvvdFAMCx0TbfaTzBzZBgfdH39wVe2+E7B76T+rdWS1g@mail.gmail.com>
[not found] ` <CALukJKSqPT2++52njn61bjy6=NjRCbjCzrgQEmQyM5iXu6tEFg@mail.gmail.com>
[not found] ` <CALukJKQobOZDkCjyG3v1_+kujiOnbaeQe+G9DRf2GM7cG_1JMQ@mail.gmail.com>
[not found] ` <CALukJKR_DpqM5bCJg30t4aXySQGnc0BUj8Wy4fZh+hnF34n4jg@mail.gmail.com>
[not found] ` <CALukJKRuZJk91zUTsxH3M3k0v3U4fGWQmoqxHJMVXXcoZVQF3A@mail.gmail.com>
[not found] ` <CALukJKRbgsRFa7fjSmDAhvQnOnV3uh0y6OuvUzV59RqAjwJxLg@mail.gmail.com>
[not found] ` <CALukJKRRGD_ptHFvJWPE-e_s7gRVU3mhTxb3Op4Go047WNieXg@mail.gmail.com>
[not found] ` <CALukJKS=bEYTF7tCkJcHbzZ5KczEPr9UehbH=6R9_vm6n7eyEA@mail.gmail.com>
[not found] ` <CALukJKQ2+kivDek=6Zaj33R0AHCCjrMWiGSu5Ynuw7Vxoe3RDw@mail.gmail.com>
[not found] ` <CALukJKTjbvPeTd2jaPStQunbnqKz33B_YYRiLKrTcQAnnJchRg@mail.gmail.com>
[not found] ` <CALukJKSdVwQRA01m2=HdvXXSgrc6L1+XcPk5rna6qtuaZWU0hw@mail.gmail.com>
[not found] ` <CALukJKT3kSZvSe0BXE3AC6e9dtzwyN=MPgQkPH-ewc9218RusQ@mail.gmail.com>
[not found] ` <CALukJKRCu+O+NaGxiWbhRD73t0E4cAE8rVuCqn_iLzS0FxpKJA@mail.gmail.com>
[not found] ` <CALukJKSSPfUh4B55z_j8kPb_8YLULdKgknmwRB-ZDEqVX8cJSQ@mail.gmail.com>
[not found] ` <CALukJKQjuyVuD1mORVXiDFSD_Y7bp4Mo-DjspRsOoHQ8Zq-uQQ@mail.gmail.com>
[not found] ` <CALukJKQgdBwZgSHSHAW=j4jM5YX41JEKvR=MwvOwVRrO3Y-v9g@mail.gmail.com>
[not found] ` <CALukJKSrVyO=xU1DvO55_1wsmEm3K-H9FqMW+keRA+qHrq3T2A@mail.gmail.com>
[not found] ` <CALukJKSEmAXMKWeKB87DeDaVQMAC_zH0MSCWGsn8zF39sFzRgQ@mail.gmail.com>
[not found] ` <CALukJKTn3jV6LPYEEqWXquLTTV2QeUKxjcHWLpF8j0NFcNM+GQ@mail.gmail.com>
[not found] ` <CALukJKTKxLLgCSye1ndN9MrnjVf=UKYK0_Z1VPxfpGqnKZjuAg@mail.gmail.com>
[not found] ` <CALukJKTtxaQNVsX41XiwzzvrG6XaP=yVh7XaBYvvBA=26GBqnw@mail.gmail.com>
[not found] ` <CALukJKTLW6PUVZziC+WL977zz=M4FKxqqTuNSK0dPQ4kpJD4CQ@mail.gmail.com>
[not found] ` <CALukJKR1hju8wsLwGjhJYHom_DSCCmMrFDtmEyoT8y0q6T_Edw@mail.gmail.com>
[not found] ` <CALukJKSqB8HUuFQaSz-HTOPd6vm=doYhOkiVhHg7x0gPztCWnQ@mail.gmail.com>
[not found] ` <CALukJKTQ82-+FYahUPf=xOeCPf_oHWOSD0-ESi2FigCm5UJV_Q@mail.gmail.com>
[not found] ` <CALukJKTMgoaLR5o06Z=MWxSESiOFUVngO3uceBk+1rY2KQfsZg@mail.gmail.com>
2017-01-18 6:58 ` Jon Pike
[not found] <CALukJKSHN+kjdYBJ8w3yi7-z_FzeXM607ABP5Kzr5CgYamMJZQ@mail.gmail.com>
2017-01-18 17:38 ` Jon Pike
2017-01-18 21:28 Dave Taht
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
List information: https://lists.bufferbloat.net/postorius/lists/make-wifi-fast.lists.bufferbloat.net/
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to='CAA93jw6zJ3WObdvnOqE=VQ3Cs5emf9qyUVMLbTg4QWL9r5TOPg@mail.gmail.com' \
--to=dave.taht@gmail.com \
--cc=make-wifi-fast@lists.bufferbloat.net \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox