]> git.karo-electronics.de Git - mv-sheeva.git/blobdiff - drivers/staging/brcm80211/brcmfmac/wl_cfg80211.c
staging: brcm80211: move sdio related suspend/resume code to bus interface layer
[mv-sheeva.git] / drivers / staging / brcm80211 / brcmfmac / wl_cfg80211.c
index 1827b0bf9201e1b868f404172d4cf71ed1b93b59..a3c2e8703a5149138f8e8305d61a2a19d9b47e64 100644 (file)
 
 #include <linux/kernel.h>
 #include <linux/if_arp.h>
-
-#include <bcmutils.h>
-
-#include <asm/uaccess.h>
-
-#include <dngl_stats.h>
-#include <dhd.h>
-#include <dhdioctl.h>
-#include <wlioctl.h>
-
+#include <linux/sched.h>
 #include <linux/kthread.h>
 #include <linux/netdevice.h>
 #include <linux/sched.h>
 #include <linux/etherdevice.h>
 #include <linux/wireless.h>
 #include <linux/ieee80211.h>
-#include <net/cfg80211.h>
-
-#include <net/rtnetlink.h>
 #include <linux/mmc/sdio_func.h>
 #include <linux/firmware.h>
-#include <wl_cfg80211.h>
+#include <linux/uaccess.h>
+#include <net/cfg80211.h>
+#include <net/rtnetlink.h>
 
-void sdioh_sdio_set_host_pm_flags(int flag);
+#include <brcmu_utils.h>
+#include <defs.h>
+#include <brcmu_wifi.h>
+#include "dngl_stats.h"
+#include "dhd.h"
+#include "wl_cfg80211.h"
 
 static struct sdio_func *cfg80211_sdio_func;
 static struct wl_dev *wl_cfg80211_dev;
 static const u8 ether_bcast[ETH_ALEN] = {255, 255, 255, 255, 255, 255};
 
-u32 wl_dbg_level = WL_DBG_ERR;
+u32 brcmf_dbg_level = WL_DBG_ERR;
 
 #define WL_4329_FW_FILE "brcm/bcm4329-fullmac-4.bin"
 #define WL_4329_NVRAM_FILE "brcm/bcm4329-fullmac-4.txt"
@@ -104,7 +99,8 @@ static s32 wl_cfg80211_config_default_mgmt_key(struct wiphy *wiphy,
                                                 struct net_device *dev,
                                                 u8 key_idx);
 static s32 wl_cfg80211_resume(struct wiphy *wiphy);
-static s32 wl_cfg80211_suspend(struct wiphy *wiphy);
+static s32 wl_cfg80211_suspend(struct wiphy *wiphy,
+                                struct cfg80211_wowlan *wow);
 static s32 wl_cfg80211_set_pmksa(struct wiphy *wiphy, struct net_device *dev,
                                   struct cfg80211_pmksa *pmksa);
 static s32 wl_cfg80211_del_pmksa(struct wiphy *wiphy, struct net_device *dev,
@@ -125,24 +121,24 @@ static void wl_init_eq_lock(struct wl_priv *wl);
 static void wl_init_eloop_handler(struct wl_event_loop *el);
 static struct wl_event_q *wl_deq_event(struct wl_priv *wl);
 static s32 wl_enq_event(struct wl_priv *wl, u32 type,
-                         const wl_event_msg_t *msg, void *data);
+                         const brcmf_event_msg_t *msg, void *data);
 static void wl_put_event(struct wl_event_q *e);
 static void wl_wakeup_event(struct wl_priv *wl);
 static s32 wl_notify_connect_status(struct wl_priv *wl,
                                      struct net_device *ndev,
-                                     const wl_event_msg_t *e, void *data);
+                                     const brcmf_event_msg_t *e, void *data);
 static s32 wl_notify_roaming_status(struct wl_priv *wl,
                                      struct net_device *ndev,
-                                     const wl_event_msg_t *e, void *data);
+                                     const brcmf_event_msg_t *e, void *data);
 static s32 wl_notify_scan_status(struct wl_priv *wl, struct net_device *ndev,
-                                  const wl_event_msg_t *e, void *data);
+                                  const brcmf_event_msg_t *e, void *data);
 static s32 wl_bss_connect_done(struct wl_priv *wl, struct net_device *ndev,
-                                const wl_event_msg_t *e, void *data,
+                                const brcmf_event_msg_t *e, void *data,
                                bool completed);
 static s32 wl_bss_roaming_done(struct wl_priv *wl, struct net_device *ndev,
-                                const wl_event_msg_t *e, void *data);
+                                const brcmf_event_msg_t *e, void *data);
 static s32 wl_notify_mic_status(struct wl_priv *wl, struct net_device *ndev,
-                                 const wl_event_msg_t *e, void *data);
+                                 const brcmf_event_msg_t *e, void *data);
 
 /*
 ** register/deregister sdio function
@@ -173,7 +169,7 @@ static s32 wl_set_retry(struct net_device *dev, u32 retry, bool l);
 /*
 ** wl profile utilities
 */
-static s32 wl_update_prof(struct wl_priv *wl, const wl_event_msg_t *e,
+static s32 wl_update_prof(struct wl_priv *wl, const brcmf_event_msg_t *e,
                            void *data, s32 item);
 static void *wl_read_prof(struct wl_priv *wl, s32 item);
 static void wl_init_prof(struct wl_profile *prof);
@@ -239,9 +235,9 @@ static bool wl_is_ibssmode(struct wl_priv *wl);
 /*
 ** dongle up/down , default configuration utilities
 */
-static bool wl_is_linkdown(struct wl_priv *wl, const wl_event_msg_t *e);
-static bool wl_is_linkup(struct wl_priv *wl, const wl_event_msg_t *e);
-static bool wl_is_nonetwork(struct wl_priv *wl, const wl_event_msg_t *e);
+static bool wl_is_linkdown(struct wl_priv *wl, const brcmf_event_msg_t *e);
+static bool wl_is_linkup(struct wl_priv *wl, const brcmf_event_msg_t *e);
+static bool wl_is_nonetwork(struct wl_priv *wl, const brcmf_event_msg_t *e);
 static void wl_link_down(struct wl_priv *wl);
 static s32 wl_dongle_mode(struct net_device *ndev, s32 iftype);
 static s32 __wl_cfg80211_up(struct wl_priv *wl);
@@ -252,20 +248,6 @@ static void wl_init_conf(struct wl_conf *conf);
 /*
 ** dongle configuration utilities
 */
-#ifndef EMBEDDED_PLATFORM
-static s32 wl_dongle_mode(struct net_device *ndev, s32 iftype);
-static s32 wl_dongle_country(struct net_device *ndev, u8 ccode);
-static s32 wl_dongle_up(struct net_device *ndev, u32 up);
-static s32 wl_dongle_power(struct net_device *ndev, u32 power_mode);
-static s32 wl_dongle_glom(struct net_device *ndev, u32 glom,
-                           u32 dongle_align);
-static s32 wl_dongle_offload(struct net_device *ndev, s32 arpoe,
-                              s32 arp_ol);
-static s32 wl_pattern_atoh(s8 *src, s8 *dst);
-static s32 wl_dongle_filter(struct net_device *ndev, u32 filter_mode);
-static s32 wl_update_wiphybands(struct wl_priv *wl);
-#endif                         /* !EMBEDDED_PLATFORM */
-
 static s32 wl_dongle_eventmsg(struct net_device *ndev);
 static s32 wl_dongle_scantime(struct net_device *ndev, s32 scan_assoc_time,
                                s32 scan_unassoc_time, s32 scan_passive_time);
@@ -324,14 +306,13 @@ static void wl_set_mpc(struct net_device *ndev, int mpc);
 static int wl_debugfs_add_netdev_params(struct wl_priv *wl);
 static void wl_debugfs_remove_netdev(struct wl_priv *wl);
 
-#define WL_PRIV_GET()                                                  \
+#define WL_PRIV_GET()                                                  \
        ({                                                              \
-       struct wl_iface *ci;                                            \
-       if (unlikely(!(wl_cfg80211_dev &&                               \
-               (ci = wl_get_drvdata(wl_cfg80211_dev))))) {             \
+       struct wl_iface *ci = wl_get_drvdata(wl_cfg80211_dev);          \
+       if (unlikely(!ci)) {                                            \
                WL_ERR("wl_cfg80211_dev is unavailable\n");             \
                BUG();                                                  \
-       }                                                               \
+       }                                                               \
        ci_to_wl(ci);                                                   \
 })
 
@@ -345,7 +326,6 @@ do {                                                                        \
        }                                                               \
 } while (0)
 
-extern int dhd_wait_pend8021x(struct net_device *dev);
 #define CHAN2G(_channel, _freq, _flags) {                      \
        .band                   = IEEE80211_BAND_2GHZ,          \
        .center_freq            = (_freq),                      \
@@ -599,7 +579,7 @@ wl_cfg80211_change_iface(struct wiphy *wiphy, struct net_device *ndev,
        }
 
        infra = cpu_to_le32(infra);
-       err = wl_dev_ioctl(ndev, WLC_SET_INFRA, &infra, sizeof(infra));
+       err = wl_dev_ioctl(ndev, BRCMF_C_SET_INFRA, &infra, sizeof(infra));
        if (unlikely(err)) {
                WL_ERR("WLC_SET_INFRA error (%d)\n", err);
                err = -EAGAIN;
@@ -643,10 +623,10 @@ wl_dev_iovar_setbuf(struct net_device *dev, s8 * iovar, void *param,
 {
        s32 iolen;
 
-       iolen = bcm_mkiovar(iovar, param, paramlen, bufptr, buflen);
+       iolen = brcmu_mkiovar(iovar, param, paramlen, bufptr, buflen);
        BUG_ON(!iolen);
 
-       return wl_dev_ioctl(dev, WLC_SET_VAR, bufptr, iolen);
+       return wl_dev_ioctl(dev, BRCMF_C_SET_VAR, bufptr, iolen);
 }
 
 static s32
@@ -655,10 +635,10 @@ wl_dev_iovar_getbuf(struct net_device *dev, s8 * iovar, void *param,
 {
        s32 iolen;
 
-       iolen = bcm_mkiovar(iovar, param, paramlen, bufptr, buflen);
+       iolen = brcmu_mkiovar(iovar, param, paramlen, bufptr, buflen);
        BUG_ON(!iolen);
 
-       return wl_dev_ioctl(dev, WLC_GET_VAR, bufptr, buflen);
+       return wl_dev_ioctl(dev, BRCMF_C_GET_VAR, bufptr, buflen);
 }
 
 static s32
@@ -674,7 +654,7 @@ wl_run_iscan(struct wl_iscan_ctrl *iscan, struct wlc_ssid *ssid, u16 action)
        params = kzalloc(params_size, GFP_KERNEL);
        if (unlikely(!params))
                return -ENOMEM;
-       BUG_ON(params_size >= WLC_IOCTL_SMLEN);
+       BUG_ON(params_size >= BRCMF_C_IOCTL_SMLEN);
 
        wl_iscan_prep(&params->params, ssid);
 
@@ -684,7 +664,7 @@ wl_run_iscan(struct wl_iscan_ctrl *iscan, struct wlc_ssid *ssid, u16 action)
 
        /* params_size += offsetof(wl_iscan_params_t, params); */
        err = wl_dev_iovar_setbuf(iscan->dev, "iscan", params, params_size,
-                               iscan->ioctl_buf, WLC_IOCTL_SMLEN);
+                               iscan->ioctl_buf, BRCMF_C_IOCTL_SMLEN);
        if (unlikely(err)) {
                if (err == -EBUSY) {
                        WL_INFO("system busy : iscan canceled\n");
@@ -710,7 +690,7 @@ static s32 wl_do_iscan(struct wl_priv *wl)
        iscan->state = WL_ISCAN_STATE_SCANING;
 
        passive_scan = wl->active_scan ? 0 : 1;
-       err = wl_dev_ioctl(wl_to_ndev(wl), WLC_SET_PASSIVE_SCAN,
+       err = wl_dev_ioctl(wl_to_ndev(wl), BRCMF_C_SET_PASSIVE_SCAN,
                        &passive_scan, sizeof(passive_scan));
        if (unlikely(err)) {
                WL_ERR("error (%d)\n", err);
@@ -789,14 +769,14 @@ __wl_cfg80211_scan(struct wiphy *wiphy, struct net_device *ndev,
                }
 
                passive_scan = wl->active_scan ? 0 : 1;
-               err = wl_dev_ioctl(ndev, WLC_SET_PASSIVE_SCAN,
+               err = wl_dev_ioctl(ndev, BRCMF_C_SET_PASSIVE_SCAN,
                                &passive_scan, sizeof(passive_scan));
                if (unlikely(err)) {
                        WL_ERR("WLC_SET_PASSIVE_SCAN error (%d)\n", err);
                        goto scan_out;
                }
                wl_set_mpc(ndev, 0);
-               err = wl_dev_ioctl(ndev, WLC_SCAN, &sr->ssid,
+               err = wl_dev_ioctl(ndev, BRCMF_C_SCAN, &sr->ssid,
                                sizeof(sr->ssid));
                if (err) {
                        if (err == -EBUSY) {
@@ -838,15 +818,16 @@ wl_cfg80211_scan(struct wiphy *wiphy, struct net_device *ndev,
 
 static s32 wl_dev_intvar_set(struct net_device *dev, s8 *name, s32 val)
 {
-       s8 buf[WLC_IOCTL_SMLEN];
+       s8 buf[BRCMF_C_IOCTL_SMLEN];
        u32 len;
        s32 err = 0;
 
        val = cpu_to_le32(val);
-       len = bcm_mkiovar(name, (char *)(&val), sizeof(val), buf, sizeof(buf));
+       len = brcmu_mkiovar(name, (char *)(&val), sizeof(val), buf,
+                           sizeof(buf));
        BUG_ON(!len);
 
-       err = wl_dev_ioctl(dev, WLC_SET_VAR, buf, len);
+       err = wl_dev_ioctl(dev, BRCMF_C_SET_VAR, buf, len);
        if (unlikely(err))
                WL_ERR("error (%d)\n", err);
 
@@ -857,7 +838,7 @@ static s32
 wl_dev_intvar_get(struct net_device *dev, s8 *name, s32 *retval)
 {
        union {
-               s8 buf[WLC_IOCTL_SMLEN];
+               s8 buf[BRCMF_C_IOCTL_SMLEN];
                s32 val;
        } var;
        u32 len;
@@ -865,10 +846,10 @@ wl_dev_intvar_get(struct net_device *dev, s8 *name, s32 *retval)
        s32 err = 0;
 
        len =
-           bcm_mkiovar(name, (char *)(&data_null), 0, (char *)(&var),
+           brcmu_mkiovar(name, (char *)(&data_null), 0, (char *)(&var),
                        sizeof(var.buf));
        BUG_ON(!len);
-       err = wl_dev_ioctl(dev, WLC_GET_VAR, &var, len);
+       err = wl_dev_ioctl(dev, BRCMF_C_GET_VAR, &var, len);
        if (unlikely(err))
                WL_ERR("error (%d)\n", err);
 
@@ -977,6 +958,8 @@ wl_cfg80211_join_ibss(struct wiphy *wiphy, struct net_device *dev,
                return -EOPNOTSUPP;
        }
 
+       set_bit(WL_STATUS_CONNECTING, &wl->status);
+
        if (params->bssid)
                WL_CONN("BSSID: %02X %02X %02X %02X %02X %02X\n",
                params->bssid[0], params->bssid[1], params->bssid[2],
@@ -1084,15 +1067,16 @@ wl_cfg80211_join_ibss(struct wiphy *wiphy, struct net_device *dev,
        wl->ibss_starter = false;
 
 
-       err = wl_dev_ioctl(dev, WLC_SET_SSID, &join_params, join_params_size);
+       err = wl_dev_ioctl(dev, BRCMF_C_SET_SSID,
+                          &join_params, join_params_size);
        if (unlikely(err)) {
                WL_ERR("WLC_SET_SSID failed (%d)\n", err);
                goto done;
        }
 
-       set_bit(WL_STATUS_CONNECTING, &wl->status);
-
 done:
+       if (err)
+               clear_bit(WL_STATUS_CONNECTING, &wl->status);
        WL_TRACE("Exit\n");
        return err;
 }
@@ -1343,7 +1327,7 @@ wl_set_set_sharedkey(struct net_device *dev,
                               key.len, key.index, key.algo);
                        WL_CONN("key \"%s\"\n", key.data);
                        swap_key_from_BE(&key);
-                       err = wl_dev_ioctl(dev, WLC_SET_KEY, &key,
+                       err = wl_dev_ioctl(dev, BRCMF_C_SET_KEY, &key,
                                        sizeof(key));
                        if (unlikely(err)) {
                                WL_ERR("WLC_SET_KEY error (%d)\n", err);
@@ -1382,6 +1366,8 @@ wl_cfg80211_connect(struct wiphy *wiphy, struct net_device *dev,
                return -EOPNOTSUPP;
        }
 
+       set_bit(WL_STATUS_CONNECTING, &wl->status);
+
        if (chan) {
                wl->channel =
                        ieee80211_frequency_to_channel(chan->center_freq);
@@ -1393,24 +1379,34 @@ wl_cfg80211_connect(struct wiphy *wiphy, struct net_device *dev,
        WL_INFO("ie (%p), ie_len (%zd)\n", sme->ie, sme->ie_len);
 
        err = wl_set_wpa_version(dev, sme);
-       if (unlikely(err))
-               return err;
+       if (err) {
+               WL_ERR("wl_set_wpa_version failed (%d)\n", err);
+               goto done;
+       }
 
        err = wl_set_auth_type(dev, sme);
-       if (unlikely(err))
-               return err;
+       if (err) {
+               WL_ERR("wl_set_auth_type failed (%d)\n", err);
+               goto done;
+       }
 
        err = wl_set_set_cipher(dev, sme);
-       if (unlikely(err))
-               return err;
+       if (err) {
+               WL_ERR("wl_set_set_cipher failed (%d)\n", err);
+               goto done;
+       }
 
        err = wl_set_key_mgmt(dev, sme);
-       if (unlikely(err))
-               return err;
+       if (err) {
+               WL_ERR("wl_set_key_mgmt failed (%d)\n", err);
+               goto done;
+       }
 
        err = wl_set_set_sharedkey(dev, sme);
-       if (unlikely(err))
-               return err;
+       if (err) {
+               WL_ERR("wl_set_set_sharedkey failed (%d)\n", err);
+               goto done;
+       }
 
        wl_update_prof(wl, NULL, sme->bssid, WL_PROF_BSSID);
        /*
@@ -1436,13 +1432,14 @@ wl_cfg80211_connect(struct wiphy *wiphy, struct net_device *dev,
        }
 
        wl_ch_to_chanspec(wl->channel, &join_params, &join_params_size);
-       err = wl_dev_ioctl(dev, WLC_SET_SSID, &join_params, join_params_size);
-       if (unlikely(err)) {
-               WL_ERR("error (%d)\n", err);
-               return err;
-       }
-       set_bit(WL_STATUS_CONNECTING, &wl->status);
+       err = wl_dev_ioctl(dev, BRCMF_C_SET_SSID,
+                          &join_params, join_params_size);
+       if (err)
+               WL_ERR("WLC_SET_SSID failed (%d)\n", err);
 
+done:
+       if (err)
+               clear_bit(WL_STATUS_CONNECTING, &wl->status);
        WL_TRACE("Exit\n");
        return err;
 }
@@ -1463,7 +1460,7 @@ wl_cfg80211_disconnect(struct wiphy *wiphy, struct net_device *dev,
        scbval.val = reason_code;
        memcpy(&scbval.ea, wl_read_prof(wl, WL_PROF_BSSID), ETH_ALEN);
        scbval.val = cpu_to_le32(scbval.val);
-       err = wl_dev_ioctl(dev, WLC_DISASSOC, &scbval,
+       err = wl_dev_ioctl(dev, BRCMF_C_DISASSOC, &scbval,
                        sizeof(scb_val_t));
        if (unlikely(err))
                WL_ERR("error (%d)\n", err);
@@ -1509,7 +1506,7 @@ wl_cfg80211_set_tx_power(struct wiphy *wiphy,
        /* Make sure radio is off or on as far as software is concerned */
        disable = WL_RADIO_SW_DISABLE << 16;
        disable = cpu_to_le32(disable);
-       err = wl_dev_ioctl(ndev, WLC_SET_RADIO, &disable, sizeof(disable));
+       err = wl_dev_ioctl(ndev, BRCMF_C_SET_RADIO, &disable, sizeof(disable));
        if (unlikely(err))
                WL_ERR("WLC_SET_RADIO error (%d)\n", err);
 
@@ -1518,7 +1515,7 @@ wl_cfg80211_set_tx_power(struct wiphy *wiphy,
        else
                txpwrmw = (u16) dbm;
        err = wl_dev_intvar_set(ndev, "qtxpower",
-                       (s32) (bcm_mw_to_qdbm(txpwrmw)));
+                       (s32) (brcmu_mw_to_qdbm(txpwrmw)));
        if (unlikely(err))
                WL_ERR("qtxpower error (%d)\n", err);
        wl->conf->tx_power = dbm;
@@ -1546,7 +1543,7 @@ static s32 wl_cfg80211_get_tx_power(struct wiphy *wiphy, s32 *dbm)
        }
 
        result = (u8) (txpwrdbm & ~WL_TXPWR_OVERRIDE);
-       *dbm = (s32) bcm_qdbm_to_mw(result);
+       *dbm = (s32) brcmu_qdbm_to_mw(result);
 
 done:
        WL_TRACE("Exit\n");
@@ -1565,7 +1562,7 @@ wl_cfg80211_config_default_key(struct wiphy *wiphy, struct net_device *dev,
        WL_CONN("key index (%d)\n", key_idx);
        CHECK_SYS_UP();
 
-       err = wl_dev_ioctl(dev, WLC_GET_WSEC, &wsec, sizeof(wsec));
+       err = wl_dev_ioctl(dev, BRCMF_C_GET_WSEC, &wsec, sizeof(wsec));
        if (unlikely(err)) {
                WL_ERR("WLC_GET_WSEC error (%d)\n", err);
                goto done;
@@ -1576,7 +1573,7 @@ wl_cfg80211_config_default_key(struct wiphy *wiphy, struct net_device *dev,
                /* Just select a new current key */
                index = (u32) key_idx;
                index = cpu_to_le32(index);
-               err = wl_dev_ioctl(dev, WLC_SET_KEY_PRIMARY, &index,
+               err = wl_dev_ioctl(dev, BRCMF_C_SET_KEY_PRIMARY, &index,
                                sizeof(index));
                if (unlikely(err))
                        WL_ERR("error (%d)\n", err);
@@ -1604,7 +1601,7 @@ wl_add_keyext(struct wiphy *wiphy, struct net_device *dev,
        if (key.len == 0) {
                /* key delete */
                swap_key_from_BE(&key);
-               err = wl_dev_ioctl(dev, WLC_SET_KEY, &key, sizeof(key));
+               err = wl_dev_ioctl(dev, BRCMF_C_SET_KEY, &key, sizeof(key));
                if (unlikely(err)) {
                        WL_ERR("key delete error (%d)\n", err);
                        return err;
@@ -1663,8 +1660,8 @@ wl_add_keyext(struct wiphy *wiphy, struct net_device *dev,
                }
                swap_key_from_BE(&key);
 
-               dhd_wait_pend8021x(dev);
-               err = wl_dev_ioctl(dev, WLC_SET_KEY, &key, sizeof(key));
+               brcmf_netdev_wait_pend8021x(dev);
+               err = wl_dev_ioctl(dev, BRCMF_C_SET_KEY, &key, sizeof(key));
                if (unlikely(err)) {
                        WL_ERR("WLC_SET_KEY error (%d)\n", err);
                        return err;
@@ -1737,7 +1734,7 @@ wl_cfg80211_add_key(struct wiphy *wiphy, struct net_device *dev,
 
        /* Set the new key/index */
        swap_key_from_BE(&key);
-       err = wl_dev_ioctl(dev, WLC_SET_KEY, &key, sizeof(key));
+       err = wl_dev_ioctl(dev, BRCMF_C_SET_KEY, &key, sizeof(key));
        if (unlikely(err)) {
                WL_ERR("WLC_SET_KEY error (%d)\n", err);
                goto done;
@@ -1759,7 +1756,7 @@ wl_cfg80211_add_key(struct wiphy *wiphy, struct net_device *dev,
 
        val = 1;                /* assume shared key. otherwise 0 */
        val = cpu_to_le32(val);
-       err = wl_dev_ioctl(dev, WLC_SET_AUTH, &val, sizeof(val));
+       err = wl_dev_ioctl(dev, BRCMF_C_SET_AUTH, &val, sizeof(val));
        if (unlikely(err))
                WL_ERR("WLC_SET_AUTH error (%d)\n", err);
 done:
@@ -1787,7 +1784,7 @@ wl_cfg80211_del_key(struct wiphy *wiphy, struct net_device *dev,
        WL_CONN("key index (%d)\n", key_idx);
        /* Set the new key/index */
        swap_key_from_BE(&key);
-       err = wl_dev_ioctl(dev, WLC_SET_KEY, &key, sizeof(key));
+       err = wl_dev_ioctl(dev, BRCMF_C_SET_KEY, &key, sizeof(key));
        if (unlikely(err)) {
                if (err == -EINVAL) {
                        if (key.index >= DOT11_MAX_DEFAULT_KEYS)
@@ -1821,7 +1818,7 @@ wl_cfg80211_del_key(struct wiphy *wiphy, struct net_device *dev,
 
        val = 0;                /* assume open key. otherwise 1 */
        val = cpu_to_le32(val);
-       err = wl_dev_ioctl(dev, WLC_SET_AUTH, &val, sizeof(val));
+       err = wl_dev_ioctl(dev, BRCMF_C_SET_AUTH, &val, sizeof(val));
        if (unlikely(err)) {
                WL_ERR("WLC_SET_AUTH error (%d)\n", err);
                /* Ignore this error, may happen during DISASSOC */
@@ -1855,7 +1852,7 @@ wl_cfg80211_get_key(struct wiphy *wiphy, struct net_device *dev,
        params.key_len = (u8) min_t(u8, WLAN_MAX_KEY_LEN, key.len);
        memcpy(params.key, key.data, params.key_len);
 
-       err = wl_dev_ioctl(dev, WLC_GET_WSEC, &wsec, sizeof(wsec));
+       err = wl_dev_ioctl(dev, BRCMF_C_GET_WSEC, &wsec, sizeof(wsec));
        if (unlikely(err)) {
                WL_ERR("WLC_GET_WSEC error (%d)\n", err);
                /* Ignore this error, may happen during DISASSOC */
@@ -1930,7 +1927,7 @@ wl_cfg80211_get_station(struct wiphy *wiphy, struct net_device *dev,
        }
 
        /* Report the current tx rate */
-       err = wl_dev_ioctl(dev, WLC_GET_RATE, &rate, sizeof(rate));
+       err = wl_dev_ioctl(dev, BRCMF_C_GET_RATE, &rate, sizeof(rate));
        if (err) {
                WL_ERR("Could not get rate (%d)\n", err);
        } else {
@@ -1942,7 +1939,7 @@ wl_cfg80211_get_station(struct wiphy *wiphy, struct net_device *dev,
 
        if (test_bit(WL_STATUS_CONNECTED, &wl->status)) {
                scb_val.val = 0;
-               err = wl_dev_ioctl(dev, WLC_GET_RSSI, &scb_val,
+               err = wl_dev_ioctl(dev, BRCMF_C_GET_RSSI, &scb_val,
                                sizeof(scb_val_t));
                if (unlikely(err)) {
                        WL_ERR("Could not get rssi (%d)\n", err);
@@ -1972,7 +1969,7 @@ wl_cfg80211_set_power_mgmt(struct wiphy *wiphy, struct net_device *dev,
        pm = cpu_to_le32(pm);
        WL_INFO("power save %s\n", (pm ? "enabled" : "disabled"));
 
-       err = wl_dev_ioctl(dev, WLC_SET_PM, &pm, sizeof(pm));
+       err = wl_dev_ioctl(dev, BRCMF_C_SET_PM, &pm, sizeof(pm));
        if (unlikely(err)) {
                if (err == -ENODEV)
                        WL_ERR("net_device is not ready yet\n");
@@ -2072,7 +2069,6 @@ done:
 static s32 wl_cfg80211_resume(struct wiphy *wiphy)
 {
        struct wl_priv *wl = wiphy_to_wl(wiphy);
-       struct net_device *ndev = wl_to_ndev(wl);
 
        /*
         * Check for WL_STATUS_READY before any function call which
@@ -2082,20 +2078,17 @@ static s32 wl_cfg80211_resume(struct wiphy *wiphy)
        WL_TRACE("Enter\n");
 
 #if defined(CONFIG_PM_SLEEP)
-       atomic_set(&dhd_mmc_suspend, false);
+       atomic_set(&brcmf_mmc_suspend, false);
 #endif /*  defined(CONFIG_PM_SLEEP) */
 
-       if (test_bit(WL_STATUS_READY, &wl->status)) {
-               /* Turn on Watchdog timer */
-               wl_os_wd_timer(ndev, dhd_watchdog_ms);
+       if (test_bit(WL_STATUS_READY, &wl->status))
                wl_invoke_iscan(wiphy_to_wl(wiphy));
-       }
 
        WL_TRACE("Exit\n");
        return 0;
 }
 
-static s32 wl_cfg80211_suspend(struct wiphy *wiphy)
+static s32 wl_cfg80211_suspend(struct wiphy *wiphy, struct cfg80211_wowlan *wow)
 {
        struct wl_priv *wl = wiphy_to_wl(wiphy);
        struct net_device *ndev = wl_to_ndev(wl);
@@ -2112,8 +2105,9 @@ static s32 wl_cfg80211_suspend(struct wiphy *wiphy)
         * While going to suspend if associated with AP disassociate
         * from AP to save power while system is in suspended state
         */
-       if (test_bit(WL_STATUS_CONNECTED, &wl->status) &&
-               test_bit(WL_STATUS_READY, &wl->status)) {
+       if ((test_bit(WL_STATUS_CONNECTED, &wl->status) ||
+            test_bit(WL_STATUS_CONNECTING, &wl->status)) &&
+            test_bit(WL_STATUS_READY, &wl->status)) {
                WL_INFO("Disassociating from AP"
                        " while entering suspend state\n");
                wl_link_down(wl);
@@ -2140,21 +2134,15 @@ static s32 wl_cfg80211_suspend(struct wiphy *wiphy)
        }
        clear_bit(WL_STATUS_SCANNING, &wl->status);
        clear_bit(WL_STATUS_SCAN_ABORTING, &wl->status);
-       clear_bit(WL_STATUS_CONNECTING, &wl->status);
-       clear_bit(WL_STATUS_CONNECTED, &wl->status);
-
-       /* Inform SDIO stack not to switch off power to the chip */
-       sdioh_sdio_set_host_pm_flags(MMC_PM_KEEP_POWER);
 
        /* Turn off watchdog timer */
        if (test_bit(WL_STATUS_READY, &wl->status)) {
-               WL_INFO("Terminate watchdog timer and enable MPC\n");
+               WL_INFO("Enable MPC\n");
                wl_set_mpc(ndev, 1);
-               wl_os_wd_timer(ndev, 0);
        }
 
 #if defined(CONFIG_PM_SLEEP)
-       atomic_set(&dhd_mmc_suspend, true);
+       atomic_set(&brcmf_mmc_suspend, true);
 #endif /*  defined(CONFIG_PM_SLEEP) */
 
        WL_TRACE("Exit\n");
@@ -2511,7 +2499,7 @@ wl_inform_ibss(struct wl_priv *wl, struct net_device *dev, const u8 *bssid)
 
        *(u32 *)buf = cpu_to_le32(WL_BSS_INFO_MAX);
 
-       err = wl_dev_ioctl(dev, WLC_GET_BSS_INFO, buf, WL_BSS_INFO_MAX);
+       err = wl_dev_ioctl(dev, BRCMF_C_GET_BSS_INFO, buf, WL_BSS_INFO_MAX);
        if (unlikely(err)) {
                WL_ERR("WLC_GET_BSS_INFO failed: %d\n", err);
                goto CleanUp;
@@ -2556,12 +2544,12 @@ CleanUp:
        return err;
 }
 
-static bool wl_is_linkup(struct wl_priv *wl, const wl_event_msg_t *e)
+static bool wl_is_linkup(struct wl_priv *wl, const brcmf_event_msg_t *e)
 {
        u32 event = be32_to_cpu(e->event_type);
        u32 status = be32_to_cpu(e->status);
 
-       if (event == WLC_E_SET_SSID && status == WLC_E_STATUS_SUCCESS) {
+       if (event == BRCMF_E_SET_SSID && status == BRCMF_E_STATUS_SUCCESS) {
                WL_CONN("Processing set ssid\n");
                wl->link_up = true;
                return true;
@@ -2570,31 +2558,31 @@ static bool wl_is_linkup(struct wl_priv *wl, const wl_event_msg_t *e)
        return false;
 }
 
-static bool wl_is_linkdown(struct wl_priv *wl, const wl_event_msg_t *e)
+static bool wl_is_linkdown(struct wl_priv *wl, const brcmf_event_msg_t *e)
 {
        u32 event = be32_to_cpu(e->event_type);
        u16 flags = be16_to_cpu(e->flags);
 
-       if (event == WLC_E_LINK && (!(flags & WLC_EVENT_MSG_LINK))) {
+       if (event == BRCMF_E_LINK && (!(flags & BRCMF_EVENT_MSG_LINK))) {
                WL_CONN("Processing link down\n");
                return true;
        }
        return false;
 }
 
-static bool wl_is_nonetwork(struct wl_priv *wl, const wl_event_msg_t *e)
+static bool wl_is_nonetwork(struct wl_priv *wl, const brcmf_event_msg_t *e)
 {
        u32 event = be32_to_cpu(e->event_type);
        u32 status = be32_to_cpu(e->status);
-       u16 flags = be16_to_cpu(e->flags);
 
-       if (event == WLC_E_LINK && status == WLC_E_STATUS_NO_NETWORKS) {
+       if (event == BRCMF_E_LINK && status == BRCMF_E_STATUS_NO_NETWORKS) {
                WL_CONN("Processing Link %s & no network found\n",
-                               flags & WLC_EVENT_MSG_LINK ? "up" : "down");
+                               be16_to_cpu(e->flags) & BRCMF_EVENT_MSG_LINK ?
+                               "up" : "down");
                return true;
        }
 
-       if (event == WLC_E_SET_SSID && status != WLC_E_STATUS_SUCCESS) {
+       if (event == BRCMF_E_SET_SSID && status != BRCMF_E_STATUS_SUCCESS) {
                WL_CONN("Processing connecting & no network found\n");
                return true;
        }
@@ -2604,7 +2592,7 @@ static bool wl_is_nonetwork(struct wl_priv *wl, const wl_event_msg_t *e)
 
 static s32
 wl_notify_connect_status(struct wl_priv *wl, struct net_device *ndev,
-                        const wl_event_msg_t *e, void *data)
+                        const brcmf_event_msg_t *e, void *data)
 {
        s32 err = 0;
 
@@ -2622,10 +2610,12 @@ wl_notify_connect_status(struct wl_priv *wl, struct net_device *ndev,
        } else if (wl_is_linkdown(wl, e)) {
                WL_CONN("Linkdown\n");
                if (wl_is_ibssmode(wl)) {
+                       clear_bit(WL_STATUS_CONNECTING, &wl->status);
                        if (test_and_clear_bit(WL_STATUS_CONNECTED,
                                &wl->status))
                                wl_link_down(wl);
                } else {
+                       wl_bss_connect_done(wl, ndev, e, data, false);
                        if (test_and_clear_bit(WL_STATUS_CONNECTED,
                                &wl->status)) {
                                cfg80211_disconnected(ndev, 0, NULL, 0,
@@ -2646,13 +2636,13 @@ wl_notify_connect_status(struct wl_priv *wl, struct net_device *ndev,
 
 static s32
 wl_notify_roaming_status(struct wl_priv *wl, struct net_device *ndev,
-                        const wl_event_msg_t *e, void *data)
+                        const brcmf_event_msg_t *e, void *data)
 {
        s32 err = 0;
        u32 event = be32_to_cpu(e->event_type);
        u32 status = be32_to_cpu(e->status);
 
-       if (event == WLC_E_ROAM && status == WLC_E_STATUS_SUCCESS) {
+       if (event == BRCMF_E_ROAM && status == BRCMF_E_STATUS_SUCCESS) {
                if (test_bit(WL_STATUS_CONNECTED, &wl->status))
                        wl_bss_roaming_done(wl, ndev, e, data);
                else
@@ -2668,10 +2658,10 @@ wl_dev_bufvar_set(struct net_device *dev, s8 *name, s8 *buf, s32 len)
        struct wl_priv *wl = ndev_to_wl(dev);
        u32 buflen;
 
-       buflen = bcm_mkiovar(name, buf, len, wl->ioctl_buf, WL_IOCTL_LEN_MAX);
+       buflen = brcmu_mkiovar(name, buf, len, wl->ioctl_buf, WL_IOCTL_LEN_MAX);
        BUG_ON(!buflen);
 
-       return wl_dev_ioctl(dev, WLC_SET_VAR, wl->ioctl_buf, buflen);
+       return wl_dev_ioctl(dev, BRCMF_C_SET_VAR, wl->ioctl_buf, buflen);
 }
 
 static s32
@@ -2682,9 +2672,9 @@ wl_dev_bufvar_get(struct net_device *dev, s8 *name, s8 *buf,
        u32 len;
        s32 err = 0;
 
-       len = bcm_mkiovar(name, NULL, 0, wl->ioctl_buf, WL_IOCTL_LEN_MAX);
+       len = brcmu_mkiovar(name, NULL, 0, wl->ioctl_buf, WL_IOCTL_LEN_MAX);
        BUG_ON(!len);
-       err = wl_dev_ioctl(dev, WLC_GET_VAR, (void *)wl->ioctl_buf,
+       err = wl_dev_ioctl(dev, BRCMF_C_GET_VAR, (void *)wl->ioctl_buf,
                        WL_IOCTL_LEN_MAX);
        if (unlikely(err)) {
                WL_ERR("error (%d)\n", err);
@@ -2800,7 +2790,7 @@ static s32 wl_update_bss_info(struct wl_priv *wl)
 {
        struct wl_bss_info *bi;
        struct wlc_ssid *ssid;
-       struct bcm_tlv *tim;
+       struct brcmu_tlv *tim;
        u16 beacon_interval;
        u8 dtim_period;
        size_t ie_len;
@@ -2814,7 +2804,7 @@ static s32 wl_update_bss_info(struct wl_priv *wl)
        ssid = (struct wlc_ssid *)wl_read_prof(wl, WL_PROF_SSID);
 
        *(u32 *)wl->extra_buf = cpu_to_le32(WL_EXTRA_BUF_MAX);
-       err = wl_dev_ioctl(wl_to_ndev(wl), WLC_GET_BSS_INFO,
+       err = wl_dev_ioctl(wl_to_ndev(wl), BRCMF_C_GET_BSS_INFO,
                        wl->extra_buf, WL_EXTRA_BUF_MAX);
        if (unlikely(err)) {
                WL_ERR("Could not get bss info %d\n", err);
@@ -2830,7 +2820,7 @@ static s32 wl_update_bss_info(struct wl_priv *wl)
        ie_len = bi->ie_length;
        beacon_interval = cpu_to_le16(bi->beacon_period);
 
-       tim = bcm_parse_tlvs(ie, ie_len, WLAN_EID_TIM);
+       tim = brcmu_parse_tlvs(ie, ie_len, WLAN_EID_TIM);
        if (tim)
                dtim_period = tim->data[1];
        else {
@@ -2858,7 +2848,7 @@ update_bss_info_out:
 
 static s32
 wl_bss_roaming_done(struct wl_priv *wl, struct net_device *ndev,
-                   const wl_event_msg_t *e, void *data)
+                   const brcmf_event_msg_t *e, void *data)
 {
        struct wl_connect_info *conn_info = wl_to_conn(wl);
        s32 err = 0;
@@ -2882,7 +2872,7 @@ wl_bss_roaming_done(struct wl_priv *wl, struct net_device *ndev,
 
 static s32
 wl_bss_connect_done(struct wl_priv *wl, struct net_device *ndev,
-                   const wl_event_msg_t *e, void *data, bool completed)
+                   const brcmf_event_msg_t *e, void *data, bool completed)
 {
        struct wl_connect_info *conn_info = wl_to_conn(wl);
        s32 err = 0;
@@ -2914,13 +2904,13 @@ wl_bss_connect_done(struct wl_priv *wl, struct net_device *ndev,
 
 static s32
 wl_notify_mic_status(struct wl_priv *wl, struct net_device *ndev,
-                    const wl_event_msg_t *e, void *data)
+                    const brcmf_event_msg_t *e, void *data)
 {
        u16 flags = be16_to_cpu(e->flags);
        enum nl80211_key_type key_type;
 
        rtnl_lock();
-       if (flags & WLC_EVENT_MSG_GROUP)
+       if (flags & BRCMF_EVENT_MSG_GROUP)
                key_type = NL80211_KEYTYPE_GROUP;
        else
                key_type = NL80211_KEYTYPE_PAIRWISE;
@@ -2934,7 +2924,7 @@ wl_notify_mic_status(struct wl_priv *wl, struct net_device *ndev,
 
 static s32
 wl_notify_scan_status(struct wl_priv *wl, struct net_device *ndev,
-                     const wl_event_msg_t *e, void *data)
+                     const brcmf_event_msg_t *e, void *data)
 {
        struct channel_info channel_inform;
        struct wl_scan_results *bss_list;
@@ -2956,7 +2946,7 @@ wl_notify_scan_status(struct wl_priv *wl, struct net_device *ndev,
                goto scan_done_out;
        }
 
-       err = wl_dev_ioctl(ndev, WLC_GET_CHANNEL, &channel_inform,
+       err = wl_dev_ioctl(ndev, BRCMF_C_GET_CHANNEL, &channel_inform,
                        sizeof(channel_inform));
        if (unlikely(err)) {
                WL_ERR("scan busy (%d)\n", err);
@@ -2974,7 +2964,7 @@ wl_notify_scan_status(struct wl_priv *wl, struct net_device *ndev,
        memset(bss_list, 0, len);
        bss_list->buflen = cpu_to_le32(len);
 
-       err = wl_dev_ioctl(ndev, WLC_SCAN_RESULTS, bss_list, len);
+       err = wl_dev_ioctl(ndev, BRCMF_C_SCAN_RESULTS, bss_list, len);
        if (unlikely(err)) {
                WL_ERR("%s Scan_results error (%d)\n", ndev->name, err);
                err = -EINVAL;
@@ -3022,11 +3012,11 @@ static void wl_init_prof(struct wl_profile *prof)
 static void wl_init_eloop_handler(struct wl_event_loop *el)
 {
        memset(el, 0, sizeof(*el));
-       el->handler[WLC_E_SCAN_COMPLETE] = wl_notify_scan_status;
-       el->handler[WLC_E_LINK] = wl_notify_connect_status;
-       el->handler[WLC_E_ROAM] = wl_notify_roaming_status;
-       el->handler[WLC_E_MIC_ERROR] = wl_notify_mic_status;
-       el->handler[WLC_E_SET_SSID] = wl_notify_connect_status;
+       el->handler[BRCMF_E_SCAN_COMPLETE] = wl_notify_scan_status;
+       el->handler[BRCMF_E_LINK] = wl_notify_connect_status;
+       el->handler[BRCMF_E_ROAM] = wl_notify_roaming_status;
+       el->handler[BRCMF_E_MIC_ERROR] = wl_notify_mic_status;
+       el->handler[BRCMF_E_SET_SSID] = wl_notify_connect_status;
 }
 
 static s32 wl_init_priv_mem(struct wl_priv *wl)
@@ -3515,7 +3505,8 @@ static s32 wl_event_handler(void *data)
 }
 
 void
-wl_cfg80211_event(struct net_device *ndev, const wl_event_msg_t * e, void *data)
+wl_cfg80211_event(struct net_device *ndev,
+                 const brcmf_event_msg_t *e, void *data)
 {
        u32 event_type = be32_to_cpu(e->event_type);
        struct wl_priv *wl = ndev_to_wl(ndev);
@@ -3566,7 +3557,7 @@ static struct wl_event_q *wl_deq_event(struct wl_priv *wl)
 */
 
 static s32
-wl_enq_event(struct wl_priv *wl, u32 event, const wl_event_msg_t *msg,
+wl_enq_event(struct wl_priv *wl, u32 event, const brcmf_event_msg_t *msg,
             void *data)
 {
        struct wl_event_q *e;
@@ -3579,7 +3570,7 @@ wl_enq_event(struct wl_priv *wl, u32 event, const wl_event_msg_t *msg,
        }
 
        e->etype = event;
-       memcpy(&e->emsg, msg, sizeof(wl_event_msg_t));
+       memcpy(&e->emsg, msg, sizeof(brcmf_event_msg_t));
        if (data) {
        }
        wl_lock_eq(wl);
@@ -3633,7 +3624,7 @@ static s32 wl_dongle_mode(struct net_device *ndev, s32 iftype)
                return err;
        }
        infra = cpu_to_le32(infra);
-       err = wl_dev_ioctl(ndev, WLC_SET_INFRA, &infra, sizeof(infra));
+       err = wl_dev_ioctl(ndev, BRCMF_C_SET_INFRA, &infra, sizeof(infra));
        if (unlikely(err)) {
                WL_ERR("WLC_SET_INFRA error (%d)\n", err);
                return err;
@@ -3642,211 +3633,6 @@ static s32 wl_dongle_mode(struct net_device *ndev, s32 iftype)
        return 0;
 }
 
-#ifndef EMBEDDED_PLATFORM
-static s32 wl_dongle_country(struct net_device *ndev, u8 ccode)
-{
-
-       s32 err = 0;
-
-       return err;
-}
-
-static s32 wl_dongle_up(struct net_device *ndev, u32 up)
-{
-       s32 err = 0;
-
-       err = wl_dev_ioctl(ndev, WLC_UP, &up, sizeof(up));
-       if (unlikely(err)) {
-               WL_ERR("WLC_UP error (%d)\n", err);
-       }
-       return err;
-}
-
-static s32 wl_dongle_power(struct net_device *ndev, u32 power_mode)
-{
-       s32 err = 0;
-
-       err = wl_dev_ioctl(ndev, WLC_SET_PM, &power_mode, sizeof(power_mode));
-       if (unlikely(err)) {
-               WL_ERR("WLC_SET_PM error (%d)\n", err);
-       }
-       return err;
-}
-
-static s32
-wl_dongle_glom(struct net_device *ndev, u32 glom, u32 dongle_align)
-{
-       s8 iovbuf[WL_EVENTING_MASK_LEN + 12];   /*  Room for "event_msgs" +
-                                                '\0' + bitvec  */
-       s32 err = 0;
-
-       /* Match Host and Dongle rx alignment */
-       bcm_mkiovar("bus:txglomalign", (char *)&dongle_align, 4, iovbuf,
-                   sizeof(iovbuf));
-       err = wl_dev_ioctl(ndev, WLC_SET_VAR, iovbuf, sizeof(iovbuf));
-       if (unlikely(err)) {
-               WL_ERR("txglomalign error (%d)\n", err);
-               goto dongle_glom_out;
-       }
-       /* disable glom option per default */
-       bcm_mkiovar("bus:txglom", (char *)&glom, 4, iovbuf, sizeof(iovbuf));
-       err = wl_dev_ioctl(ndev, WLC_SET_VAR, iovbuf, sizeof(iovbuf));
-       if (unlikely(err)) {
-               WL_ERR("txglom error (%d)\n", err);
-               goto dongle_glom_out;
-       }
-dongle_glom_out:
-       return err;
-}
-
-static s32
-wl_dongle_offload(struct net_device *ndev, s32 arpoe, s32 arp_ol)
-{
-       s8 iovbuf[WL_EVENTING_MASK_LEN + 12];   /*  Room for "event_msgs" +
-                                                        '\0' + bitvec  */
-       s32 err = 0;
-
-       /* Set ARP offload */
-       bcm_mkiovar("arpoe", (char *)&arpoe, 4, iovbuf, sizeof(iovbuf));
-       err = wl_dev_ioctl(ndev, WLC_SET_VAR, iovbuf, sizeof(iovbuf));
-       if (err) {
-               if (err == -EOPNOTSUPP)
-                       WL_INFO("arpoe is not supported\n");
-               else
-                       WL_ERR("arpoe error (%d)\n", err);
-
-               goto dongle_offload_out;
-       }
-       bcm_mkiovar("arp_ol", (char *)&arp_ol, 4, iovbuf, sizeof(iovbuf));
-       err = wl_dev_ioctl(ndev, WLC_SET_VAR, iovbuf, sizeof(iovbuf));
-       if (err) {
-               if (err == -EOPNOTSUPP)
-                       WL_INFO("arp_ol is not supported\n");
-               else
-                       WL_ERR("arp_ol error (%d)\n", err);
-
-               goto dongle_offload_out;
-       }
-
-dongle_offload_out:
-       return err;
-}
-
-static s32 wl_pattern_atoh(s8 *src, s8 *dst)
-{
-       int i;
-       if (strncmp(src, "0x", 2) != 0 && strncmp(src, "0X", 2) != 0) {
-               WL_ERR("Mask invalid format. Needs to start with 0x\n");
-               return -1;
-       }
-       src = src + 2;          /* Skip past 0x */
-       if (strlen(src) % 2 != 0) {
-               WL_ERR("Mask invalid format. Needs to be of even length\n");
-               return -1;
-       }
-       for (i = 0; *src != '\0'; i++) {
-               char num[3];
-               strncpy(num, src, 2);
-               num[2] = '\0';
-               dst[i] = (u8) simple_strtoul(num, NULL, 16);
-               src += 2;
-       }
-       return i;
-}
-
-static s32 wl_dongle_filter(struct net_device *ndev, u32 filter_mode)
-{
-       s8 iovbuf[WL_EVENTING_MASK_LEN + 12];   /*  Room for "event_msgs" +
-                                                        '\0' + bitvec  */
-       const s8 *str;
-       struct wl_pkt_filter pkt_filter;
-       struct wl_pkt_filter *pkt_filterp;
-       s32 buf_len;
-       s32 str_len;
-       u32 mask_size;
-       u32 pattern_size;
-       s8 buf[256];
-       s32 err = 0;
-
-/* add a default packet filter pattern */
-       str = "pkt_filter_add";
-       str_len = strlen(str);
-       strncpy(buf, str, str_len);
-       buf[str_len] = '\0';
-       buf_len = str_len + 1;
-
-       pkt_filterp = (struct wl_pkt_filter *)(buf + str_len + 1);
-
-       /* Parse packet filter id. */
-       pkt_filter.id = cpu_to_le32(100);
-
-       /* Parse filter polarity. */
-       pkt_filter.negate_match = cpu_to_le32(0);
-
-       /* Parse filter type. */
-       pkt_filter.type = cpu_to_le32(0);
-
-       /* Parse pattern filter offset. */
-       pkt_filter.u.pattern.offset = cpu_to_le32(0);
-
-       /* Parse pattern filter mask. */
-       mask_size = cpu_to_le32(wl_pattern_atoh("0xff",
-                                               (char *)pkt_filterp->u.pattern.
-                                               mask_and_pattern));
-
-       /* Parse pattern filter pattern. */
-       pattern_size = cpu_to_le32(wl_pattern_atoh("0x00",
-                                                  (char *)&pkt_filterp->u.
-                                                  pattern.
-                                                  mask_and_pattern
-                                                  [mask_size]));
-
-       if (mask_size != pattern_size) {
-               WL_ERR("Mask and pattern not the same size\n");
-               err = -EINVAL;
-               goto dongle_filter_out;
-       }
-
-       pkt_filter.u.pattern.size_bytes = mask_size;
-       buf_len += WL_PKT_FILTER_FIXED_LEN;
-       buf_len += (WL_PKT_FILTER_PATTERN_FIXED_LEN + 2 * mask_size);
-
-       /* Keep-alive attributes are set in local
-        * variable (keep_alive_pkt), and
-        * then memcpy'ed into buffer (keep_alive_pktp) since there is no
-        * guarantee that the buffer is properly aligned.
-        */
-       memcpy((char *)pkt_filterp, &pkt_filter,
-              WL_PKT_FILTER_FIXED_LEN + WL_PKT_FILTER_PATTERN_FIXED_LEN);
-
-       err = wl_dev_ioctl(ndev, WLC_SET_VAR, buf, buf_len);
-       if (err) {
-               if (err == -EOPNOTSUPP) {
-                       WL_INFO("filter not supported\n");
-               } else {
-                       WL_ERR("filter (%d)\n", err);
-               }
-               goto dongle_filter_out;
-       }
-
-       /* set mode to allow pattern */
-       bcm_mkiovar("pkt_filter_mode", (char *)&filter_mode, 4, iovbuf,
-                   sizeof(iovbuf));
-       err = wl_dev_ioctl(ndev, WLC_SET_VAR, iovbuf, sizeof(iovbuf));
-       if (err) {
-               if (err == -EOPNOTSUPP) {
-                       WL_INFO("filter_mode not supported\n");
-               } else {
-                       WL_ERR("filter_mode (%d)\n", err);
-               }
-               goto dongle_filter_out;
-       }
-
-dongle_filter_out:
-       return err;
-}
-#endif                         /* !EMBEDDED_PLATFORM */
-
 static s32 wl_dongle_eventmsg(struct net_device *ndev)
 {
        s8 iovbuf[WL_EVENTING_MASK_LEN + 12];   /*  Room for "event_msgs" +
@@ -3857,38 +3643,38 @@ static s32 wl_dongle_eventmsg(struct net_device *ndev)
        WL_TRACE("Enter\n");
 
        /* Setup event_msgs */
-       bcm_mkiovar("event_msgs", eventmask, WL_EVENTING_MASK_LEN, iovbuf,
+       brcmu_mkiovar("event_msgs", eventmask, WL_EVENTING_MASK_LEN, iovbuf,
                    sizeof(iovbuf));
-       err = wl_dev_ioctl(ndev, WLC_GET_VAR, iovbuf, sizeof(iovbuf));
+       err = wl_dev_ioctl(ndev, BRCMF_C_GET_VAR, iovbuf, sizeof(iovbuf));
        if (unlikely(err)) {
                WL_ERR("Get event_msgs error (%d)\n", err);
                goto dongle_eventmsg_out;
        }
        memcpy(eventmask, iovbuf, WL_EVENTING_MASK_LEN);
 
-       setbit(eventmask, WLC_E_SET_SSID);
-       setbit(eventmask, WLC_E_ROAM);
-       setbit(eventmask, WLC_E_PRUNE);
-       setbit(eventmask, WLC_E_AUTH);
-       setbit(eventmask, WLC_E_REASSOC);
-       setbit(eventmask, WLC_E_REASSOC_IND);
-       setbit(eventmask, WLC_E_DEAUTH_IND);
-       setbit(eventmask, WLC_E_DISASSOC_IND);
-       setbit(eventmask, WLC_E_DISASSOC);
-       setbit(eventmask, WLC_E_JOIN);
-       setbit(eventmask, WLC_E_ASSOC_IND);
-       setbit(eventmask, WLC_E_PSK_SUP);
-       setbit(eventmask, WLC_E_LINK);
-       setbit(eventmask, WLC_E_NDIS_LINK);
-       setbit(eventmask, WLC_E_MIC_ERROR);
-       setbit(eventmask, WLC_E_PMKID_CACHE);
-       setbit(eventmask, WLC_E_TXFAIL);
-       setbit(eventmask, WLC_E_JOIN_START);
-       setbit(eventmask, WLC_E_SCAN_COMPLETE);
-
-       bcm_mkiovar("event_msgs", eventmask, WL_EVENTING_MASK_LEN, iovbuf,
+       setbit(eventmask, BRCMF_E_SET_SSID);
+       setbit(eventmask, BRCMF_E_ROAM);
+       setbit(eventmask, BRCMF_E_PRUNE);
+       setbit(eventmask, BRCMF_E_AUTH);
+       setbit(eventmask, BRCMF_E_REASSOC);
+       setbit(eventmask, BRCMF_E_REASSOC_IND);
+       setbit(eventmask, BRCMF_E_DEAUTH_IND);
+       setbit(eventmask, BRCMF_E_DISASSOC_IND);
+       setbit(eventmask, BRCMF_E_DISASSOC);
+       setbit(eventmask, BRCMF_E_JOIN);
+       setbit(eventmask, BRCMF_E_ASSOC_IND);
+       setbit(eventmask, BRCMF_E_PSK_SUP);
+       setbit(eventmask, BRCMF_E_LINK);
+       setbit(eventmask, BRCMF_E_NDIS_LINK);
+       setbit(eventmask, BRCMF_E_MIC_ERROR);
+       setbit(eventmask, BRCMF_E_PMKID_CACHE);
+       setbit(eventmask, BRCMF_E_TXFAIL);
+       setbit(eventmask, BRCMF_E_JOIN_START);
+       setbit(eventmask, BRCMF_E_SCAN_COMPLETE);
+
+       brcmu_mkiovar("event_msgs", eventmask, WL_EVENTING_MASK_LEN, iovbuf,
                    sizeof(iovbuf));
-       err = wl_dev_ioctl(ndev, WLC_SET_VAR, iovbuf, sizeof(iovbuf));
+       err = wl_dev_ioctl(ndev, BRCMF_C_SET_VAR, iovbuf, sizeof(iovbuf));
        if (unlikely(err)) {
                WL_ERR("Set event_msgs error (%d)\n", err);
                goto dongle_eventmsg_out;
@@ -3912,9 +3698,10 @@ wl_dongle_roam(struct net_device *ndev, u32 roamvar, u32 bcn_timeout)
         * off to report link down
         */
        if (roamvar) {
-               bcm_mkiovar("bcn_timeout", (char *)&bcn_timeout,
+               brcmu_mkiovar("bcn_timeout", (char *)&bcn_timeout,
                        sizeof(bcn_timeout), iovbuf, sizeof(iovbuf));
-               err = wl_dev_ioctl(ndev, WLC_SET_VAR, iovbuf, sizeof(iovbuf));
+               err = wl_dev_ioctl(ndev, BRCMF_C_SET_VAR,
+                                  iovbuf, sizeof(iovbuf));
                if (unlikely(err)) {
                        WL_ERR("bcn_timeout error (%d)\n", err);
                        goto dongle_rom_out;
@@ -3926,9 +3713,9 @@ wl_dongle_roam(struct net_device *ndev, u32 roamvar, u32 bcn_timeout)
         * to take care of roaming
         */
        WL_INFO("Internal Roaming = %s\n", roamvar ? "Off" : "On");
-       bcm_mkiovar("roam_off", (char *)&roamvar,
+       brcmu_mkiovar("roam_off", (char *)&roamvar,
                                sizeof(roamvar), iovbuf, sizeof(iovbuf));
-       err = wl_dev_ioctl(ndev, WLC_SET_VAR, iovbuf, sizeof(iovbuf));
+       err = wl_dev_ioctl(ndev, BRCMF_C_SET_VAR, iovbuf, sizeof(iovbuf));
        if (unlikely(err)) {
                WL_ERR("roam_off error (%d)\n", err);
                goto dongle_rom_out;
@@ -3936,7 +3723,7 @@ wl_dongle_roam(struct net_device *ndev, u32 roamvar, u32 bcn_timeout)
 
        roamtrigger[0] = WL_ROAM_TRIGGER_LEVEL;
        roamtrigger[1] = WLC_BAND_ALL;
-       err = wl_dev_ioctl(ndev, WLC_SET_ROAM_TRIGGER,
+       err = wl_dev_ioctl(ndev, BRCMF_C_SET_ROAM_TRIGGER,
                        (void *)roamtrigger, sizeof(roamtrigger));
        if (unlikely(err)) {
                WL_ERR("WLC_SET_ROAM_TRIGGER error (%d)\n", err);
@@ -3945,7 +3732,7 @@ wl_dongle_roam(struct net_device *ndev, u32 roamvar, u32 bcn_timeout)
 
        roam_delta[0] = WL_ROAM_DELTA;
        roam_delta[1] = WLC_BAND_ALL;
-       err = wl_dev_ioctl(ndev, WLC_SET_ROAM_DELTA,
+       err = wl_dev_ioctl(ndev, BRCMF_C_SET_ROAM_DELTA,
                                (void *)roam_delta, sizeof(roam_delta));
        if (unlikely(err)) {
                WL_ERR("WLC_SET_ROAM_DELTA error (%d)\n", err);
@@ -3962,8 +3749,8 @@ wl_dongle_scantime(struct net_device *ndev, s32 scan_assoc_time,
 {
        s32 err = 0;
 
-       err = wl_dev_ioctl(ndev, WLC_SET_SCAN_CHANNEL_TIME, &scan_assoc_time,
-                       sizeof(scan_assoc_time));
+       err = wl_dev_ioctl(ndev, BRCMF_C_SET_SCAN_CHANNEL_TIME,
+                          &scan_assoc_time, sizeof(scan_assoc_time));
        if (err) {
                if (err == -EOPNOTSUPP)
                        WL_INFO("Scan assoc time is not supported\n");
@@ -3971,8 +3758,8 @@ wl_dongle_scantime(struct net_device *ndev, s32 scan_assoc_time,
                        WL_ERR("Scan assoc time error (%d)\n", err);
                goto dongle_scantime_out;
        }
-       err = wl_dev_ioctl(ndev, WLC_SET_SCAN_UNASSOC_TIME, &scan_unassoc_time,
-                       sizeof(scan_unassoc_time));
+       err = wl_dev_ioctl(ndev, BRCMF_C_SET_SCAN_UNASSOC_TIME,
+                          &scan_unassoc_time, sizeof(scan_unassoc_time));
        if (err) {
                if (err == -EOPNOTSUPP)
                        WL_INFO("Scan unassoc time is not supported\n");
@@ -3981,8 +3768,8 @@ wl_dongle_scantime(struct net_device *ndev, s32 scan_assoc_time,
                goto dongle_scantime_out;
        }
 
-       err = wl_dev_ioctl(ndev, WLC_SET_SCAN_PASSIVE_TIME, &scan_passive_time,
-                       sizeof(scan_passive_time));
+       err = wl_dev_ioctl(ndev, BRCMF_C_SET_SCAN_PASSIVE_TIME,
+                          &scan_passive_time, sizeof(scan_passive_time));
        if (err) {
                if (err == -EOPNOTSUPP)
                        WL_INFO("Scan passive time is not supported\n");
@@ -3997,9 +3784,6 @@ dongle_scantime_out:
 
 s32 wl_config_dongle(struct wl_priv *wl, bool need_lock)
 {
-#ifndef DHD_SDALIGN
-#define DHD_SDALIGN    32
-#endif
        struct net_device *ndev;
        struct wireless_dev *wdev;
        s32 err = 0;
@@ -4012,24 +3796,6 @@ s32 wl_config_dongle(struct wl_priv *wl, bool need_lock)
        if (need_lock)
                rtnl_lock();
 
-#ifndef EMBEDDED_PLATFORM
-       err = wl_dongle_up(ndev, 0);
-       if (unlikely(err))
-               goto default_conf_out;
-       err = wl_dongle_country(ndev, 0);
-       if (unlikely(err))
-               goto default_conf_out;
-       err = wl_dongle_power(ndev, PM_FAST);
-       if (unlikely(err))
-               goto default_conf_out;
-       err = wl_dongle_glom(ndev, 0, DHD_SDALIGN);
-       if (unlikely(err))
-               goto default_conf_out;
-
-       wl_dongle_offload(ndev, 1, 0xf);
-       wl_dongle_filter(ndev, 1);
-#endif /* !EMBEDDED_PLATFORM */
-
        wl_dongle_scantime(ndev, WL_SCAN_CHANNEL_TIME,
                        WL_SCAN_UNASSOC_TIME, WL_SCAN_PASSIVE_TIME);
 
@@ -4101,6 +3867,25 @@ static s32 __wl_cfg80211_up(struct wl_priv *wl)
 
 static s32 __wl_cfg80211_down(struct wl_priv *wl)
 {
+       /*
+        * While going down, if associated with AP disassociate
+        * from AP to save power
+        */
+       if ((test_bit(WL_STATUS_CONNECTED, &wl->status) ||
+            test_bit(WL_STATUS_CONNECTING, &wl->status)) &&
+            test_bit(WL_STATUS_READY, &wl->status)) {
+               WL_INFO("Disassociating from AP");
+               wl_link_down(wl);
+
+               /* Make sure WPA_Supplicant receives all the event
+                  generated due to DISASSOC call to the fw to keep
+                  the state fw and WPA_Supplicant state consistent
+                */
+               rtnl_unlock();
+               wl_delay(500);
+               rtnl_lock();
+       }
+
        set_bit(WL_STATUS_SCAN_ABORTING, &wl->status);
        wl_term_iscan(wl);
        if (wl->scan_request) {
@@ -4112,8 +3897,6 @@ static s32 __wl_cfg80211_down(struct wl_priv *wl)
        clear_bit(WL_STATUS_READY, &wl->status);
        clear_bit(WL_STATUS_SCANNING, &wl->status);
        clear_bit(WL_STATUS_SCAN_ABORTING, &wl->status);
-       clear_bit(WL_STATUS_CONNECTING, &wl->status);
-       clear_bit(WL_STATUS_CONNECTED, &wl->status);
 
        wl_debugfs_remove_netdev(wl);
 
@@ -4148,13 +3931,7 @@ s32 wl_cfg80211_down(void)
 
 static s32 wl_dongle_probecap(struct wl_priv *wl)
 {
-       s32 err = 0;
-
-       err = wl_update_wiphybands(wl);
-       if (unlikely(err))
-               return err;
-
-       return err;
+       return wl_update_wiphybands(wl);
 }
 
 static void *wl_read_prof(struct wl_priv *wl, s32 item)
@@ -4172,7 +3949,7 @@ static void *wl_read_prof(struct wl_priv *wl, s32 item)
 }
 
 static s32
-wl_update_prof(struct wl_priv *wl, const wl_event_msg_t *e, void *data,
+wl_update_prof(struct wl_priv *wl, const brcmf_event_msg_t *e, void *data,
               s32 item)
 {
        s32 err = 0;
@@ -4232,19 +4009,17 @@ static __used s32 wl_add_ie(struct wl_priv *wl, u8 t, u8 l, u8 *v)
        return err;
 }
 
-
 static void wl_link_down(struct wl_priv *wl)
 {
        struct net_device *dev = NULL;
        s32 err = 0;
 
        WL_TRACE("Enter\n");
-       clear_bit(WL_STATUS_CONNECTED, &wl->status);
 
        if (wl->link_up) {
                dev = wl_to_ndev(wl);
                WL_INFO("Call WLC_DISASSOC to stop excess roaming\n ");
-               err = wl_dev_ioctl(dev, WLC_DISASSOC, NULL, 0);
+               err = wl_dev_ioctl(dev, BRCMF_C_DISASSOC, NULL, 0);
                if (unlikely(err))
                        WL_ERR("WLC_DISASSOC failed (%d)\n", err);
                wl->link_up = false;
@@ -4284,7 +4059,11 @@ static void wl_set_drvdata(struct wl_dev *dev, void *data)
 
 static void *wl_get_drvdata(struct wl_dev *dev)
 {
-       return dev->driver_data;
+       void *data = NULL;
+
+       if (dev)
+               data = dev->driver_data;
+       return data;
 }
 
 s32 wl_cfg80211_read_fw(s8 *buf, u32 size)