wl1271: implement cmd_disconnect
authorLuciano Coelho <luciano.coelho@nokia.com>
Mon, 12 Oct 2009 12:08:42 +0000 (15:08 +0300)
committerJohn W. Linville <linville@tuxdriver.com>
Tue, 27 Oct 2009 20:48:01 +0000 (16:48 -0400)
This patch implements the CMD_DISCONNECT command, which should be sent to the
firmware when we are disassociated.

Signed-off-by: Luciano Coelho <luciano.coelho@nokia.com>
Reviewed-by: Juuso Oikarinen <juuso.oikarinen@nokia.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
drivers/net/wireless/wl12xx/wl1271_cmd.c
drivers/net/wireless/wl12xx/wl1271_cmd.h

index ac93efd53f2a469c819031b11e2254bbd324f859..d09ad12119770c2ade2703a87c993cd60081836a 100644 (file)
@@ -191,7 +191,6 @@ int wl1271_cmd_join(struct wl1271 *wl)
                        do_cal = false;
        }
 
-
        join = kzalloc(sizeof(*join), GFP_KERNEL);
        if (!join) {
                ret = -ENOMEM;
@@ -825,3 +824,34 @@ out:
 
        return ret;
 }
+
+int wl1271_cmd_disconnect(struct wl1271 *wl)
+{
+       struct wl1271_cmd_disconnect *cmd;
+       int ret = 0;
+
+       wl1271_debug(DEBUG_CMD, "cmd disconnect");
+
+       cmd = kzalloc(sizeof(*cmd), GFP_KERNEL);
+       if (!cmd) {
+               ret = -ENOMEM;
+               goto out;
+       }
+
+       cmd->rx_config_options = wl->rx_config;
+       cmd->rx_filter_options = wl->rx_filter;
+       /* disconnect reason is not used in immediate disconnections */
+       cmd->type = DISCONNECT_IMMEDIATE;
+
+       ret = wl1271_cmd_send(wl, CMD_DISCONNECT, cmd, sizeof(*cmd));
+       if (ret < 0) {
+               wl1271_error("failed to send disconnect command");
+               goto out_free;
+       }
+
+out_free:
+       kfree(cmd);
+
+out:
+       return ret;
+}
index 63bc4417deb8318ff03c7d4e3ce97d4ab9e1af02..0219664765ecbf8e970d1c1ae981b097319a0f93 100644 (file)
@@ -50,6 +50,7 @@ int wl1271_cmd_set_default_wep_key(struct wl1271 *wl, u8 id);
 int wl1271_cmd_set_key(struct wl1271 *wl, u16 action, u8 id, u8 key_type,
                       u8 key_size, const u8 *key, const u8 *addr,
                       u32 tx_seq_32, u16 tx_seq_16);
+int wl1271_cmd_disconnect(struct wl1271 *wl);
 
 enum wl1271_commands {
        CMD_INTERROGATE     = 1,    /*use this to read information elements*/
@@ -461,4 +462,30 @@ struct wl1271_cmd_cal_p2g {
        u8  padding2;
 } __attribute__ ((packed));
 
+
+/*
+ * There are three types of disconnections:
+ *
+ * DISCONNECT_IMMEDIATE: the fw doesn't send any frames
+ * DISCONNECT_DEAUTH:    the fw generates a DEAUTH request with the reason
+ *                       we have passed
+ * DISCONNECT_DISASSOC:  the fw generates a DESASSOC request with the reason
+ *                       we have passed
+ */
+enum wl1271_disconnect_type {
+       DISCONNECT_IMMEDIATE,
+       DISCONNECT_DEAUTH,
+       DISCONNECT_DISASSOC
+};
+
+struct wl1271_cmd_disconnect {
+       u32 rx_config_options;
+       u32 rx_filter_options;
+
+       u16 reason;
+       u8  type;
+
+       u8  padding;
+} __attribute__ ((packed));
+
 #endif /* __WL1271_CMD_H__ */