staging: wilc1000: handle freeing of key data in wep add key
authorAjay Singh <ajay.kathat@microchip.com>
Tue, 26 Jun 2018 06:07:09 +0000 (11:37 +0530)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 28 Jun 2018 12:55:51 +0000 (21:55 +0900)
Modified the code to free the allocated memory, used to store the key in
wilc_add_wep_key_bss_sta() and wilc_add_wep_key_bss_ap().
After work completion notification is received, free the
memory allocated to avoid missing of free in work function.

Signed-off-by: Ajay Singh <ajay.kathat@microchip.com>
Reviewed-by: Claudiu Beznea <claudiu.beznea@microchip.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/staging/wilc1000/host_interface.c

index 6d27a9dc246f9529181120e00dd0de2af8bc9d25..2cc968953ba0cb43472f852b0361fd15db745513 100644 (file)
@@ -1551,8 +1551,6 @@ static void handle_key(struct work_struct *work)
                        memcpy(&key_buf[2], hif_key->attr.wep.key,
                               hif_key->attr.wep.key_len);
 
-                       kfree(hif_key->attr.wep.key);
-
                        wid_list[2].id = (u16)WID_WEP_KEY_VALUE;
                        wid_list[2].type = WID_STR;
                        wid_list[2].size = hif_key->attr.wep.key_len + 2;
@@ -1573,7 +1571,6 @@ static void handle_key(struct work_struct *work)
                        memcpy(key_buf + 1, &hif_key->attr.wep.key_len, 1);
                        memcpy(key_buf + 2, hif_key->attr.wep.key,
                               hif_key->attr.wep.key_len);
-                       kfree(hif_key->attr.wep.key);
 
                        wid.id = (u16)WID_ADD_WEP_KEY;
                        wid.type = WID_STR;
@@ -2629,8 +2626,6 @@ int wilc_add_wep_key_bss_sta(struct wilc_vif *vif, const u8 *key, u8 len,
                goto free_key;
 
        wait_for_completion(&msg->work_comp);
-       kfree(msg);
-       return 0;
 
 free_key:
        kfree(msg->body.key_info.attr.wep.key);
@@ -2674,8 +2669,6 @@ int wilc_add_wep_key_bss_ap(struct wilc_vif *vif, const u8 *key, u8 len,
                goto free_key;
 
        wait_for_completion(&msg->work_comp);
-       kfree(msg);
-       return 0;
 
 free_key:
        kfree(msg->body.key_info.attr.wep.key);