diff options
author | Jia-Ju Bai <baijiaju1990@gmail.com> | 2019-05-29 09:39:54 -0400 |
---|---|---|
committer | Kalle Valo <kvalo@codeaurora.org> | 2019-06-01 01:04:50 -0400 |
commit | a8627176b0de7ba3f4524f641ddff4abf23ae4e4 (patch) | |
tree | e762eb13b0a2e0048644de85829f841ee4e11f75 /drivers/net/wireless | |
parent | b17dc0632a17fbfe66b34ee7c24e1cc10cfc503e (diff) |
iwlwifi: Fix double-free problems in iwl_req_fw_callback()
In the error handling code of iwl_req_fw_callback(), iwl_dealloc_ucode()
is called to free data. In iwl_drv_stop(), iwl_dealloc_ucode() is called
again, which can cause double-free problems.
To fix this bug, the call to iwl_dealloc_ucode() in
iwl_req_fw_callback() is deleted.
This bug is found by a runtime fuzzing tool named FIZZER written by us.
Signed-off-by: Jia-Ju Bai <baijiaju1990@gmail.com>
Signed-off-by: Luca Coelho <luciano.coelho@intel.com>
Signed-off-by: Kalle Valo <kvalo@codeaurora.org>
Diffstat (limited to 'drivers/net/wireless')
-rw-r--r-- | drivers/net/wireless/intel/iwlwifi/iwl-drv.c | 1 |
1 files changed, 0 insertions, 1 deletions
diff --git a/drivers/net/wireless/intel/iwlwifi/iwl-drv.c b/drivers/net/wireless/intel/iwlwifi/iwl-drv.c index 852d3cbfc719..fba242284507 100644 --- a/drivers/net/wireless/intel/iwlwifi/iwl-drv.c +++ b/drivers/net/wireless/intel/iwlwifi/iwl-drv.c | |||
@@ -1597,7 +1597,6 @@ static void iwl_req_fw_callback(const struct firmware *ucode_raw, void *context) | |||
1597 | goto free; | 1597 | goto free; |
1598 | 1598 | ||
1599 | out_free_fw: | 1599 | out_free_fw: |
1600 | iwl_dealloc_ucode(drv); | ||
1601 | release_firmware(ucode_raw); | 1600 | release_firmware(ucode_raw); |
1602 | out_unbind: | 1601 | out_unbind: |
1603 | complete(&drv->request_firmware_complete); | 1602 | complete(&drv->request_firmware_complete); |