mirror of https://gitee.com/openkylin/linux.git
wlcore: fix occasional AP TX stop after recovery
The fw_status wasn't zeroed during allocation, resulting in uninitialized var usage, and finally causing AP traffic stop after recovery. The wrong value in fw_status_2->counters.tx_lnk_free_pkts led to a bad lnk->allocated_pkts calculation in wlcore_fw_status(), causing wl18xx_lnk_low_prio() to return FALSE (lnk->allocated_pkts > thold). This eventually blocked the link in wlcore_tx_work_locked(), as wl1271_skb_dequeue() continuously returned NULL. Fix it by zeroing wl->fw_status_1/2 during allocation. Signed-off-by: Victor Goldenshtein <victorg@ti.com> Signed-off-by: Eliad Peller <eliad@wizery.com> Signed-off-by: Luciano Coelho <coelho@ti.com>
This commit is contained in:
parent
2baf53c6e3
commit
5cbba2d48a
|
@ -970,7 +970,7 @@ static int wlcore_fw_wakeup(struct wl1271 *wl)
|
|||
|
||||
static int wl1271_setup(struct wl1271 *wl)
|
||||
{
|
||||
wl->fw_status_1 = kmalloc(WLCORE_FW_STATUS_1_LEN(wl->num_rx_desc) +
|
||||
wl->fw_status_1 = kzalloc(WLCORE_FW_STATUS_1_LEN(wl->num_rx_desc) +
|
||||
sizeof(*wl->fw_status_2) +
|
||||
wl->fw_status_priv_len, GFP_KERNEL);
|
||||
if (!wl->fw_status_1)
|
||||
|
@ -980,7 +980,7 @@ static int wl1271_setup(struct wl1271 *wl)
|
|||
(((u8 *) wl->fw_status_1) +
|
||||
WLCORE_FW_STATUS_1_LEN(wl->num_rx_desc));
|
||||
|
||||
wl->tx_res_if = kmalloc(sizeof(*wl->tx_res_if), GFP_KERNEL);
|
||||
wl->tx_res_if = kzalloc(sizeof(*wl->tx_res_if), GFP_KERNEL);
|
||||
if (!wl->tx_res_if) {
|
||||
kfree(wl->fw_status_1);
|
||||
return -ENOMEM;
|
||||
|
|
Loading…
Reference in New Issue