iwmc3200wifi: fix a use-after-free bug
authorZhu Yi <yi.zhu@intel.com>
Mon, 20 Jul 2009 03:47:47 +0000 (11:47 +0800)
committerJohn W. Linville <linville@tuxdriver.com>
Fri, 24 Jul 2009 19:05:29 +0000 (15:05 -0400)
The patch fixes a use-after-free bug for cmd->seq_num;

Reported-by: Dan Carpenter <error27@gmail.com>
Signed-off-by: Zhu Yi <yi.zhu@intel.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
drivers/net/wireless/iwmc3200wifi/hal.c

index ee127fe..c430418 100644 (file)
 #include "umac.h"
 #include "debug.h"
 
-static void iwm_nonwifi_cmd_init(struct iwm_priv *iwm,
-                                struct iwm_nonwifi_cmd *cmd,
-                                struct iwm_udma_nonwifi_cmd *udma_cmd)
+static int iwm_nonwifi_cmd_init(struct iwm_priv *iwm,
+                               struct iwm_nonwifi_cmd *cmd,
+                               struct iwm_udma_nonwifi_cmd *udma_cmd)
 {
        INIT_LIST_HEAD(&cmd->pending);
 
@@ -118,7 +118,7 @@ static void iwm_nonwifi_cmd_init(struct iwm_priv *iwm,
        cmd->seq_num = iwm->nonwifi_seq_num;
        udma_cmd->seq_num = cpu_to_le16(cmd->seq_num);
 
-       cmd->seq_num = iwm->nonwifi_seq_num++;
+       iwm->nonwifi_seq_num++;
        iwm->nonwifi_seq_num %= UMAC_NONWIFI_SEQ_NUM_MAX;
 
        if (udma_cmd->resp)
@@ -130,6 +130,8 @@ static void iwm_nonwifi_cmd_init(struct iwm_priv *iwm,
        cmd->buf.len = 0;
 
        memcpy(&cmd->udma_cmd, udma_cmd, sizeof(*udma_cmd));
+
+       return cmd->seq_num;
 }
 
 u16 iwm_alloc_wifi_cmd_seq(struct iwm_priv *iwm)
@@ -369,7 +371,7 @@ int iwm_hal_send_target_cmd(struct iwm_priv *iwm,
                            const void *payload)
 {
        struct iwm_nonwifi_cmd *cmd;
-       int ret;
+       int ret, seq_num;
 
        cmd = kzalloc(sizeof(struct iwm_nonwifi_cmd), GFP_KERNEL);
        if (!cmd) {
@@ -377,7 +379,7 @@ int iwm_hal_send_target_cmd(struct iwm_priv *iwm,
                return -ENOMEM;
        }
 
-       iwm_nonwifi_cmd_init(iwm, cmd, udma_cmd);
+       seq_num = iwm_nonwifi_cmd_init(iwm, cmd, udma_cmd);
 
        if (cmd->udma_cmd.opcode == UMAC_HDI_OUT_OPCODE_WRITE ||
            cmd->udma_cmd.opcode == UMAC_HDI_OUT_OPCODE_WRITE_PERSISTENT) {
@@ -393,7 +395,7 @@ int iwm_hal_send_target_cmd(struct iwm_priv *iwm,
        if (ret < 0)
                return ret;
 
-       return cmd->seq_num;
+       return seq_num;
 }
 
 static void iwm_build_lmac_hdr(struct iwm_priv *iwm, struct iwm_lmac_hdr *hdr,