Skip to content

Commit c30b5b8

Browse files
committed
Merge tag 'staging-5.17-rc8' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/staging
Pull staging driver fixes from Greg KH: "Here are three small fixes for staging drivers for 5.17-rc8 or -final, which ever comes next. They resolve some reported problems: - rtl8723bs wifi driver deadlock fix for reported problem that is a revert of a previous patch. Also a documentation fix is added so that the same problem hopefully can not come back again. - gdm724x driver use-after-free fix for a reported problem. All of these have been in linux-next for a while with no reported problems" * tag 'staging-5.17-rc8' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/staging: staging: rtl8723bs: Improve the comment explaining the locking rules staging: rtl8723bs: Fix access-point mode deadlock staging: gdm724x: fix use after free in gdm_lte_rx()
2 parents 55b4083 + 342e7c6 commit c30b5b8

7 files changed

Lines changed: 42 additions & 28 deletions

File tree

drivers/staging/gdm724x/gdm_lte.c

Lines changed: 3 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -76,14 +76,15 @@ static void tx_complete(void *arg)
7676

7777
static int gdm_lte_rx(struct sk_buff *skb, struct nic *nic, int nic_type)
7878
{
79-
int ret;
79+
int ret, len;
8080

81+
len = skb->len + ETH_HLEN;
8182
ret = netif_rx_ni(skb);
8283
if (ret == NET_RX_DROP) {
8384
nic->stats.rx_dropped++;
8485
} else {
8586
nic->stats.rx_packets++;
86-
nic->stats.rx_bytes += skb->len + ETH_HLEN;
87+
nic->stats.rx_bytes += len;
8788
}
8889

8990
return 0;

drivers/staging/rtl8723bs/core/rtw_mlme_ext.c

Lines changed: 5 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -5907,6 +5907,7 @@ u8 chk_bmc_sleepq_hdl(struct adapter *padapter, unsigned char *pbuf)
59075907
struct sta_info *psta_bmc;
59085908
struct list_head *xmitframe_plist, *xmitframe_phead, *tmp;
59095909
struct xmit_frame *pxmitframe = NULL;
5910+
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
59105911
struct sta_priv *pstapriv = &padapter->stapriv;
59115912

59125913
/* for BC/MC Frames */
@@ -5917,7 +5918,8 @@ u8 chk_bmc_sleepq_hdl(struct adapter *padapter, unsigned char *pbuf)
59175918
if ((pstapriv->tim_bitmap&BIT(0)) && (psta_bmc->sleepq_len > 0)) {
59185919
msleep(10);/* 10ms, ATIM(HIQ) Windows */
59195920

5920-
spin_lock_bh(&psta_bmc->sleep_q.lock);
5921+
/* spin_lock_bh(&psta_bmc->sleep_q.lock); */
5922+
spin_lock_bh(&pxmitpriv->lock);
59215923

59225924
xmitframe_phead = get_list_head(&psta_bmc->sleep_q);
59235925
list_for_each_safe(xmitframe_plist, tmp, xmitframe_phead) {
@@ -5940,7 +5942,8 @@ u8 chk_bmc_sleepq_hdl(struct adapter *padapter, unsigned char *pbuf)
59405942
rtw_hal_xmitframe_enqueue(padapter, pxmitframe);
59415943
}
59425944

5943-
spin_unlock_bh(&psta_bmc->sleep_q.lock);
5945+
/* spin_unlock_bh(&psta_bmc->sleep_q.lock); */
5946+
spin_unlock_bh(&pxmitpriv->lock);
59445947

59455948
/* check hi queue and bmc_sleepq */
59465949
rtw_chk_hi_queue_cmd(padapter);

drivers/staging/rtl8723bs/core/rtw_recv.c

Lines changed: 7 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -957,8 +957,10 @@ static signed int validate_recv_ctrl_frame(struct adapter *padapter, union recv_
957957
if ((psta->state&WIFI_SLEEP_STATE) && (pstapriv->sta_dz_bitmap&BIT(psta->aid))) {
958958
struct list_head *xmitframe_plist, *xmitframe_phead;
959959
struct xmit_frame *pxmitframe = NULL;
960+
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
960961

961-
spin_lock_bh(&psta->sleep_q.lock);
962+
/* spin_lock_bh(&psta->sleep_q.lock); */
963+
spin_lock_bh(&pxmitpriv->lock);
962964

963965
xmitframe_phead = get_list_head(&psta->sleep_q);
964966
xmitframe_plist = get_next(xmitframe_phead);
@@ -989,10 +991,12 @@ static signed int validate_recv_ctrl_frame(struct adapter *padapter, union recv_
989991
update_beacon(padapter, WLAN_EID_TIM, NULL, true);
990992
}
991993

992-
spin_unlock_bh(&psta->sleep_q.lock);
994+
/* spin_unlock_bh(&psta->sleep_q.lock); */
995+
spin_unlock_bh(&pxmitpriv->lock);
993996

994997
} else {
995-
spin_unlock_bh(&psta->sleep_q.lock);
998+
/* spin_unlock_bh(&psta->sleep_q.lock); */
999+
spin_unlock_bh(&pxmitpriv->lock);
9961000

9971001
if (pstapriv->tim_bitmap&BIT(psta->aid)) {
9981002
if (psta->sleepq_len == 0) {

drivers/staging/rtl8723bs/core/rtw_sta_mgt.c

Lines changed: 10 additions & 12 deletions
Original file line numberDiff line numberDiff line change
@@ -293,48 +293,46 @@ u32 rtw_free_stainfo(struct adapter *padapter, struct sta_info *psta)
293293

294294
/* list_del_init(&psta->wakeup_list); */
295295

296-
spin_lock_bh(&psta->sleep_q.lock);
296+
spin_lock_bh(&pxmitpriv->lock);
297+
297298
rtw_free_xmitframe_queue(pxmitpriv, &psta->sleep_q);
298299
psta->sleepq_len = 0;
299-
spin_unlock_bh(&psta->sleep_q.lock);
300-
301-
spin_lock_bh(&pxmitpriv->lock);
302300

303301
/* vo */
304-
spin_lock_bh(&pstaxmitpriv->vo_q.sta_pending.lock);
302+
/* spin_lock_bh(&(pxmitpriv->vo_pending.lock)); */
305303
rtw_free_xmitframe_queue(pxmitpriv, &pstaxmitpriv->vo_q.sta_pending);
306304
list_del_init(&(pstaxmitpriv->vo_q.tx_pending));
307305
phwxmit = pxmitpriv->hwxmits;
308306
phwxmit->accnt -= pstaxmitpriv->vo_q.qcnt;
309307
pstaxmitpriv->vo_q.qcnt = 0;
310-
spin_unlock_bh(&pstaxmitpriv->vo_q.sta_pending.lock);
308+
/* spin_unlock_bh(&(pxmitpriv->vo_pending.lock)); */
311309

312310
/* vi */
313-
spin_lock_bh(&pstaxmitpriv->vi_q.sta_pending.lock);
311+
/* spin_lock_bh(&(pxmitpriv->vi_pending.lock)); */
314312
rtw_free_xmitframe_queue(pxmitpriv, &pstaxmitpriv->vi_q.sta_pending);
315313
list_del_init(&(pstaxmitpriv->vi_q.tx_pending));
316314
phwxmit = pxmitpriv->hwxmits+1;
317315
phwxmit->accnt -= pstaxmitpriv->vi_q.qcnt;
318316
pstaxmitpriv->vi_q.qcnt = 0;
319-
spin_unlock_bh(&pstaxmitpriv->vi_q.sta_pending.lock);
317+
/* spin_unlock_bh(&(pxmitpriv->vi_pending.lock)); */
320318

321319
/* be */
322-
spin_lock_bh(&pstaxmitpriv->be_q.sta_pending.lock);
320+
/* spin_lock_bh(&(pxmitpriv->be_pending.lock)); */
323321
rtw_free_xmitframe_queue(pxmitpriv, &pstaxmitpriv->be_q.sta_pending);
324322
list_del_init(&(pstaxmitpriv->be_q.tx_pending));
325323
phwxmit = pxmitpriv->hwxmits+2;
326324
phwxmit->accnt -= pstaxmitpriv->be_q.qcnt;
327325
pstaxmitpriv->be_q.qcnt = 0;
328-
spin_unlock_bh(&pstaxmitpriv->be_q.sta_pending.lock);
326+
/* spin_unlock_bh(&(pxmitpriv->be_pending.lock)); */
329327

330328
/* bk */
331-
spin_lock_bh(&pstaxmitpriv->bk_q.sta_pending.lock);
329+
/* spin_lock_bh(&(pxmitpriv->bk_pending.lock)); */
332330
rtw_free_xmitframe_queue(pxmitpriv, &pstaxmitpriv->bk_q.sta_pending);
333331
list_del_init(&(pstaxmitpriv->bk_q.tx_pending));
334332
phwxmit = pxmitpriv->hwxmits+3;
335333
phwxmit->accnt -= pstaxmitpriv->bk_q.qcnt;
336334
pstaxmitpriv->bk_q.qcnt = 0;
337-
spin_unlock_bh(&pstaxmitpriv->bk_q.sta_pending.lock);
335+
/* spin_unlock_bh(&(pxmitpriv->bk_pending.lock)); */
338336

339337
spin_unlock_bh(&pxmitpriv->lock);
340338

drivers/staging/rtl8723bs/core/rtw_xmit.c

Lines changed: 9 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -1734,12 +1734,15 @@ void rtw_free_xmitframe_queue(struct xmit_priv *pxmitpriv, struct __queue *pfram
17341734
struct list_head *plist, *phead, *tmp;
17351735
struct xmit_frame *pxmitframe;
17361736

1737+
spin_lock_bh(&pframequeue->lock);
1738+
17371739
phead = get_list_head(pframequeue);
17381740
list_for_each_safe(plist, tmp, phead) {
17391741
pxmitframe = list_entry(plist, struct xmit_frame, list);
17401742

17411743
rtw_free_xmitframe(pxmitpriv, pxmitframe);
17421744
}
1745+
spin_unlock_bh(&pframequeue->lock);
17431746
}
17441747

17451748
s32 rtw_xmitframe_enqueue(struct adapter *padapter, struct xmit_frame *pxmitframe)
@@ -1794,7 +1797,6 @@ s32 rtw_xmit_classifier(struct adapter *padapter, struct xmit_frame *pxmitframe)
17941797
struct sta_info *psta;
17951798
struct tx_servq *ptxservq;
17961799
struct pkt_attrib *pattrib = &pxmitframe->attrib;
1797-
struct xmit_priv *xmit_priv = &padapter->xmitpriv;
17981800
struct hw_xmit *phwxmits = padapter->xmitpriv.hwxmits;
17991801
signed int res = _SUCCESS;
18001802

@@ -1812,14 +1814,12 @@ s32 rtw_xmit_classifier(struct adapter *padapter, struct xmit_frame *pxmitframe)
18121814

18131815
ptxservq = rtw_get_sta_pending(padapter, psta, pattrib->priority, (u8 *)(&ac_index));
18141816

1815-
spin_lock_bh(&xmit_priv->lock);
18161817
if (list_empty(&ptxservq->tx_pending))
18171818
list_add_tail(&ptxservq->tx_pending, get_list_head(phwxmits[ac_index].sta_queue));
18181819

18191820
list_add_tail(&pxmitframe->list, get_list_head(&ptxservq->sta_pending));
18201821
ptxservq->qcnt++;
18211822
phwxmits[ac_index].accnt++;
1822-
spin_unlock_bh(&xmit_priv->lock);
18231823

18241824
exit:
18251825

@@ -2202,10 +2202,11 @@ void wakeup_sta_to_xmit(struct adapter *padapter, struct sta_info *psta)
22022202
struct list_head *xmitframe_plist, *xmitframe_phead, *tmp;
22032203
struct xmit_frame *pxmitframe = NULL;
22042204
struct sta_priv *pstapriv = &padapter->stapriv;
2205+
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
22052206

22062207
psta_bmc = rtw_get_bcmc_stainfo(padapter);
22072208

2208-
spin_lock_bh(&psta->sleep_q.lock);
2209+
spin_lock_bh(&pxmitpriv->lock);
22092210

22102211
xmitframe_phead = get_list_head(&psta->sleep_q);
22112212
list_for_each_safe(xmitframe_plist, tmp, xmitframe_phead) {
@@ -2306,7 +2307,7 @@ void wakeup_sta_to_xmit(struct adapter *padapter, struct sta_info *psta)
23062307

23072308
_exit:
23082309

2309-
spin_unlock_bh(&psta->sleep_q.lock);
2310+
spin_unlock_bh(&pxmitpriv->lock);
23102311

23112312
if (update_mask)
23122313
update_beacon(padapter, WLAN_EID_TIM, NULL, true);
@@ -2318,8 +2319,9 @@ void xmit_delivery_enabled_frames(struct adapter *padapter, struct sta_info *pst
23182319
struct list_head *xmitframe_plist, *xmitframe_phead, *tmp;
23192320
struct xmit_frame *pxmitframe = NULL;
23202321
struct sta_priv *pstapriv = &padapter->stapriv;
2322+
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
23212323

2322-
spin_lock_bh(&psta->sleep_q.lock);
2324+
spin_lock_bh(&pxmitpriv->lock);
23232325

23242326
xmitframe_phead = get_list_head(&psta->sleep_q);
23252327
list_for_each_safe(xmitframe_plist, tmp, xmitframe_phead) {
@@ -2372,7 +2374,7 @@ void xmit_delivery_enabled_frames(struct adapter *padapter, struct sta_info *pst
23722374
}
23732375
}
23742376

2375-
spin_unlock_bh(&psta->sleep_q.lock);
2377+
spin_unlock_bh(&pxmitpriv->lock);
23762378
}
23772379

23782380
void enqueue_pending_xmitbuf(struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf)

drivers/staging/rtl8723bs/hal/rtl8723bs_xmit.c

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -502,7 +502,9 @@ s32 rtl8723bs_hal_xmit(
502502
rtw_issue_addbareq_cmd(padapter, pxmitframe);
503503
}
504504

505+
spin_lock_bh(&pxmitpriv->lock);
505506
err = rtw_xmitframe_enqueue(padapter, pxmitframe);
507+
spin_unlock_bh(&pxmitpriv->lock);
506508
if (err != _SUCCESS) {
507509
rtw_free_xmitframe(pxmitpriv, pxmitframe);
508510

drivers/staging/rtl8723bs/include/rtw_mlme.h

Lines changed: 6 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -102,13 +102,17 @@ there are several "locks" in mlme_priv,
102102
since mlme_priv is a shared resource between many threads,
103103
like ISR/Call-Back functions, the OID handlers, and even timer functions.
104104
105-
106105
Each struct __queue has its own locks, already.
107-
Other items are protected by mlme_priv.lock.
106+
Other items in mlme_priv are protected by mlme_priv.lock, while items in
107+
xmit_priv are protected by xmit_priv.lock.
108108
109109
To avoid possible dead lock, any thread trying to modifiying mlme_priv
110110
SHALL not lock up more than one locks at a time!
111111
112+
The only exception is that queue functions which take the __queue.lock
113+
may be called with the xmit_priv.lock held. In this case the order
114+
MUST always be first lock xmit_priv.lock and then call any queue functions
115+
which take __queue.lock.
112116
*/
113117

114118

0 commit comments

Comments
 (0)