mwifiex: fix use-after-free for FW reinit errors
authorBrian Norris <briannorris@chromium.org>
Tue, 28 Mar 2017 23:59:32 +0000 (16:59 -0700)
committerKalle Valo <kvalo@codeaurora.org>
Wed, 5 Apr 2017 12:44:03 +0000 (15:44 +0300)
commitce8fad9a1f09009ec3918a99685d9e3176f50ce3
treeb907bf425f6e9cebf17c1c17f165bb8e2dd21b39
parent78b9ccb81377ba908b2c18daf6e1a7beddc281e3
mwifiex: fix use-after-free for FW reinit errors

If we fail to reinit the FW when resetting the device (in the
synchronous version of mwifiex_init_hw_fw() -> mwifiex_fw_dpc()),
mwifiex_fw_dpc() will tear down the interface and free up the adapter.
But we don't actually check for all failure cases of mwifiex_fw_dpc(),
so some of them fall through and dereference adapter->fw_done with a
freed adapter, causing a use-after-free bug.

In any case, mwifiex_fw_dpc() will always signal FW completion -- in the
error OR success case -- so at best, this was repeat work. Let's not do
it.

Signed-off-by: Brian Norris <briannorris@chromium.org>
Signed-off-by: Kalle Valo <kvalo@codeaurora.org>
drivers/net/wireless/marvell/mwifiex/main.c