wil6210: missing reinit_completion in wmi_call
authorLior David <qca_liord@qca.qualcomm.com>
Fri, 20 Jan 2017 11:49:48 +0000 (13:49 +0200)
committerKalle Valo <kvalo@qca.qualcomm.com>
Fri, 27 Jan 2017 17:49:39 +0000 (19:49 +0200)
The code in wmi_call uses the wil->wmi_call completion
structure to wait for a reply.
In some scenarios, complete was called twice on the
completion structure. This happened mainly with a disconnect
event which can arrive both unsolicited and as a reply to
a disconnect request. In this case the completion structure
was left marked as "done" and the next wmi_call returned
immediately with a corrupted reply buffer. This caused
unexpected results including crashes.
Fix this by adding the missing call to reinit_completion.

Signed-off-by: Lior David <qca_liord@qca.qualcomm.com>
Signed-off-by: Maya Erez <qca_merez@qca.qualcomm.com>
Signed-off-by: Kalle Valo <kvalo@qca.qualcomm.com>
drivers/net/wireless/ath/wil6210/wmi.c

index 0137ac5b9bb349cf65f581b3c41be4e7d8fdafa0..d30b3fca77499887f6ac1cbf505a791d396ba52c 100644 (file)
@@ -957,6 +957,7 @@ int wmi_call(struct wil6210_priv *wil, u16 cmdid, void *buf, u16 len,
        wil->reply_id = reply_id;
        wil->reply_buf = reply;
        wil->reply_size = reply_size;
+       reinit_completion(&wil->wmi_call);
        spin_unlock(&wil->wmi_ev_lock);
 
        rc = __wmi_send(wil, cmdid, buf, len);