wlcore: add generic_cfg_feature command definitions
authorEliad Peller <eliad@wizery.com>
Thu, 30 Jul 2015 19:38:21 +0000 (22:38 +0300)
committerKalle Valo <kvalo@codeaurora.org>
Mon, 10 Aug 2015 19:16:25 +0000 (22:16 +0300)
Add definitions and function prototypes for generic_cfg
command.

Signed-off-by: Eliad Peller <eliad@wizery.com>
Signed-off-by: Kalle Valo <kvalo@codeaurora.org>
drivers/net/wireless/ti/wlcore/cmd.c
drivers/net/wireless/ti/wlcore/cmd.h

index 68919f8d4310455fad623381ee16e2f1c96dac69..dbc55a0aa9058a3597a7a094fedf247b09fbff5a 100644 (file)
@@ -2059,3 +2059,33 @@ int wl12xx_stop_dev(struct wl1271 *wl, struct wl12xx_vif *wlvif)
 out:
        return ret;
 }
+
+int wlcore_cmd_generic_cfg(struct wl1271 *wl, struct wl12xx_vif *wlvif,
+                          u8 feature, u8 enable, u8 value)
+{
+       struct wlcore_cmd_generic_cfg *cmd;
+       int ret;
+
+       wl1271_debug(DEBUG_CMD,
+                    "cmd generic cfg (role %d feature %d enable %d value %d)",
+                    wlvif->role_id, feature, enable, value);
+
+       cmd = kzalloc(sizeof(*cmd), GFP_KERNEL);
+       if (!cmd)
+               return -ENOMEM;
+
+       cmd->role_id = wlvif->role_id;
+       cmd->feature = feature;
+       cmd->enable = enable;
+       cmd->value = value;
+
+       ret = wl1271_cmd_send(wl, CMD_GENERIC_CFG, cmd, sizeof(*cmd), 0);
+       if (ret < 0) {
+               wl1271_error("failed to send generic cfg command");
+               goto out_free;
+       }
+out_free:
+       kfree(cmd);
+       return ret;
+}
+EXPORT_SYMBOL_GPL(wlcore_cmd_generic_cfg);
index e14cd407a6aea6295f786033a63a234c12bc6f6c..8dc46c0a489a1b6ea8d3e6ef752d13906e670feb 100644 (file)
@@ -92,6 +92,8 @@ int wl12xx_cmd_remove_peer(struct wl1271 *wl, struct wl12xx_vif *wlvif,
 void wlcore_set_pending_regdomain_ch(struct wl1271 *wl, u16 channel,
                                     enum ieee80211_band band);
 int wlcore_cmd_regdomain_config_locked(struct wl1271 *wl);
+int wlcore_cmd_generic_cfg(struct wl1271 *wl, struct wl12xx_vif *wlvif,
+                          u8 feature, u8 enable, u8 value);
 int wl12xx_cmd_config_fwlog(struct wl1271 *wl);
 int wl12xx_cmd_start_fwlog(struct wl1271 *wl);
 int wl12xx_cmd_stop_fwlog(struct wl1271 *wl);
@@ -652,6 +654,19 @@ struct wl12xx_cmd_regdomain_dfs_config {
        u8 padding[3];
 } __packed;
 
+enum wlcore_generic_cfg_feature {
+       WLCORE_CFG_FEATURE_RADAR_DEBUG = 2,
+};
+
+struct wlcore_cmd_generic_cfg {
+       struct wl1271_cmd_header header;
+
+       u8 role_id;
+       u8 feature;
+       u8 enable;
+       u8 value;
+} __packed;
+
 struct wl12xx_cmd_config_fwlog {
        struct wl1271_cmd_header header;