staging: brcm80211: removed last typedefs from fullmac
[deliverable/linux.git] / drivers / staging / brcm80211 / brcmfmac / wl_cfg80211.c
index 1827b0bf9201e1b868f404172d4cf71ed1b93b59..85ff00be1cf59390004130f9563cce22c129ec81 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 <linux/mmc/sdio_func.h>
+#include <linux/uaccess.h>
 #include <net/cfg80211.h>
-
 #include <net/rtnetlink.h>
-#include <linux/mmc/sdio_func.h>
-#include <linux/firmware.h>
-#include <wl_cfg80211.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;
-
-#define WL_4329_FW_FILE "brcm/bcm4329-fullmac-4.bin"
-#define WL_4329_NVRAM_FILE "brcm/bcm4329-fullmac-4.txt"
+u32 brcmf_dbg_level = WL_DBG_ERR;
 
 /*
 ** cfg80211_ops api/callback list
 */
-static s32 wl_cfg80211_change_iface(struct wiphy *wiphy,
+static s32 brcmf_cfg80211_change_iface(struct wiphy *wiphy,
                                      struct net_device *ndev,
                                      enum nl80211_iftype type, u32 *flags,
                                      struct vif_params *params);
-static s32 __wl_cfg80211_scan(struct wiphy *wiphy, struct net_device *ndev,
+static s32 __brcmf_cfg80211_scan(struct wiphy *wiphy, struct net_device *ndev,
                                struct cfg80211_scan_request *request,
                                struct cfg80211_ssid *this_ssid);
-static s32 wl_cfg80211_scan(struct wiphy *wiphy, struct net_device *ndev,
+static s32 brcmf_cfg80211_scan(struct wiphy *wiphy, struct net_device *ndev,
                              struct cfg80211_scan_request *request);
-static s32 wl_cfg80211_set_wiphy_params(struct wiphy *wiphy, u32 changed);
-static s32 wl_cfg80211_join_ibss(struct wiphy *wiphy, struct net_device *dev,
+static s32 brcmf_cfg80211_set_wiphy_params(struct wiphy *wiphy, u32 changed);
+static s32 brcmf_cfg80211_join_ibss(struct wiphy *wiphy, struct net_device *dev,
                                   struct cfg80211_ibss_params *params);
-static s32 wl_cfg80211_leave_ibss(struct wiphy *wiphy,
+static s32 brcmf_cfg80211_leave_ibss(struct wiphy *wiphy,
                                    struct net_device *dev);
-static s32 wl_cfg80211_get_station(struct wiphy *wiphy,
+static s32 brcmf_cfg80211_get_station(struct wiphy *wiphy,
                                     struct net_device *dev, u8 *mac,
                                     struct station_info *sinfo);
-static s32 wl_cfg80211_set_power_mgmt(struct wiphy *wiphy,
+static s32 brcmf_cfg80211_set_power_mgmt(struct wiphy *wiphy,
                                        struct net_device *dev, bool enabled,
                                        s32 timeout);
-static s32 wl_cfg80211_set_bitrate_mask(struct wiphy *wiphy,
+static s32 brcmf_cfg80211_set_bitrate_mask(struct wiphy *wiphy,
                                          struct net_device *dev,
                                          const u8 *addr,
                                          const struct cfg80211_bitrate_mask
                                          *mask);
-static int wl_cfg80211_connect(struct wiphy *wiphy, struct net_device *dev,
+static int brcmf_cfg80211_connect(struct wiphy *wiphy, struct net_device *dev,
                               struct cfg80211_connect_params *sme);
-static s32 wl_cfg80211_disconnect(struct wiphy *wiphy, struct net_device *dev,
+static s32 brcmf_cfg80211_disconnect(struct wiphy *wiphy, struct net_device *dev,
                                    u16 reason_code);
-static s32 wl_cfg80211_set_tx_power(struct wiphy *wiphy,
+static s32 brcmf_cfg80211_set_tx_power(struct wiphy *wiphy,
                                      enum nl80211_tx_power_setting type,
                                      s32 dbm);
-static s32 wl_cfg80211_get_tx_power(struct wiphy *wiphy, s32 *dbm);
-static s32 wl_cfg80211_config_default_key(struct wiphy *wiphy,
+static s32 brcmf_cfg80211_get_tx_power(struct wiphy *wiphy, s32 *dbm);
+static s32 brcmf_cfg80211_config_default_key(struct wiphy *wiphy,
                                          struct net_device *dev, u8 key_idx,
                                          bool unicast, bool multicast);
-static s32 wl_cfg80211_add_key(struct wiphy *wiphy, struct net_device *dev,
+static s32 brcmf_cfg80211_add_key(struct wiphy *wiphy, struct net_device *dev,
                                 u8 key_idx, bool pairwise, const u8 *mac_addr,
                                 struct key_params *params);
-static s32 wl_cfg80211_del_key(struct wiphy *wiphy, struct net_device *dev,
+static s32 brcmf_cfg80211_del_key(struct wiphy *wiphy, struct net_device *dev,
                                 u8 key_idx, bool pairwise, const u8 *mac_addr);
-static s32 wl_cfg80211_get_key(struct wiphy *wiphy, struct net_device *dev,
+static s32 brcmf_cfg80211_get_key(struct wiphy *wiphy, struct net_device *dev,
                                 u8 key_idx, bool pairwise, const u8 *mac_addr,
                                 void *cookie, void (*callback) (void *cookie,
                                                                 struct
                                                                 key_params *
                                                                 params));
-static s32 wl_cfg80211_config_default_mgmt_key(struct wiphy *wiphy,
+static s32 brcmf_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_set_pmksa(struct wiphy *wiphy, struct net_device *dev,
+static s32 brcmf_cfg80211_resume(struct wiphy *wiphy);
+static s32 brcmf_cfg80211_suspend(struct wiphy *wiphy,
+                                struct cfg80211_wowlan *wow);
+static s32 brcmf_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,
+static s32 brcmf_cfg80211_del_pmksa(struct wiphy *wiphy, struct net_device *dev,
                                   struct cfg80211_pmksa *pmksa);
-static s32 wl_cfg80211_flush_pmksa(struct wiphy *wiphy,
+static s32 brcmf_cfg80211_flush_pmksa(struct wiphy *wiphy,
                                     struct net_device *dev);
 /*
 ** event & event Q handlers for cfg80211 interfaces
 */
-static s32 wl_create_event_handler(struct wl_priv *wl);
-static void wl_destroy_event_handler(struct wl_priv *wl);
-static s32 wl_event_handler(void *data);
-static void wl_init_eq(struct wl_priv *wl);
-static void wl_flush_eq(struct wl_priv *wl);
-static void wl_lock_eq(struct wl_priv *wl);
-static void wl_unlock_eq(struct wl_priv *wl);
-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);
-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);
-static s32 wl_notify_roaming_status(struct wl_priv *wl,
-                                     struct net_device *ndev,
-                                     const wl_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);
-static s32 wl_bss_connect_done(struct wl_priv *wl, struct net_device *ndev,
-                                const wl_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);
-static s32 wl_notify_mic_status(struct wl_priv *wl, struct net_device *ndev,
-                                 const wl_event_msg_t *e, void *data);
+static s32 brcmf_create_event_handler(struct wl_priv *wl);
+static void brcmf_destroy_event_handler(struct wl_priv *wl);
+static s32 brcmf_event_handler(void *data);
+static void brcmf_init_eq(struct wl_priv *wl);
+static void brcmf_flush_eq(struct wl_priv *wl);
+static void brcmf_lock_eq(struct wl_priv *wl);
+static void brcmf_unlock_eq(struct wl_priv *wl);
+static void brcmf_init_eq_lock(struct wl_priv *wl);
+static void brcmf_init_eloop_handler(struct wl_event_loop *el);
+static struct wl_event_q *brcmf_deq_event(struct wl_priv *wl);
+static s32 brcmf_enq_event(struct wl_priv *wl, u32 type,
+                          const struct brcmf_event_msg *msg, void *data);
+static void brcmf_put_event(struct wl_event_q *e);
+static void brcmf_wakeup_event(struct wl_priv *wl);
+static s32 brcmf_notify_connect_status(struct wl_priv *wl, struct net_device *ndev,
+                                      const struct brcmf_event_msg *e,
+                                      void *data);
+static s32 brcmf_notify_roaming_status(struct wl_priv *wl, struct net_device *ndev,
+                                   const struct brcmf_event_msg *e,
+                                   void *data);
+static s32 brcmf_notify_scan_status(struct wl_priv *wl, struct net_device *ndev,
+                                   const struct brcmf_event_msg *e, void *data);
+static s32 brcmf_bss_connect_done(struct wl_priv *wl, struct net_device *ndev,
+                                 const struct brcmf_event_msg *e, void *data,
+                                 bool completed);
+static s32 brcmf_bss_roaming_done(struct wl_priv *wl, struct net_device *ndev,
+                                 const struct brcmf_event_msg *e, void *data);
+static s32 brcmf_notify_mic_status(struct wl_priv *wl, struct net_device *ndev,
+                                  const struct brcmf_event_msg *e, void *data);
 
 /*
 ** register/deregister sdio function
 */
 struct sdio_func *wl_cfg80211_get_sdio_func(void);
-static void wl_clear_sdio_func(void);
+static void brcmf_clear_sdio_func(void);
 
 /*
 ** ioctl utilites
 */
-static s32 wl_dev_bufvar_get(struct net_device *dev, s8 *name, s8 *buf,
+static s32 brcmf_dev_bufvar_get(struct net_device *dev, s8 *name, s8 *buf,
                               s32 buf_len);
-static __used s32 wl_dev_bufvar_set(struct net_device *dev, s8 *name,
+static __used s32 brcmf_dev_bufvar_set(struct net_device *dev, s8 *name,
                                      s8 *buf, s32 len);
-static s32 wl_dev_intvar_set(struct net_device *dev, s8 *name, s32 val);
-static s32 wl_dev_intvar_get(struct net_device *dev, s8 *name,
+static s32 brcmf_dev_intvar_set(struct net_device *dev, s8 *name, s32 val);
+static s32 brcmf_dev_intvar_get(struct net_device *dev, s8 *name,
                               s32 *retval);
-static s32 wl_dev_ioctl(struct net_device *dev, u32 cmd, void *arg,
+static s32 brcmf_dev_ioctl(struct net_device *dev, u32 cmd, void *arg,
                          u32 len);
 
 /*
 ** cfg80211 set_wiphy_params utilities
 */
-static s32 wl_set_frag(struct net_device *dev, u32 frag_threshold);
-static s32 wl_set_rts(struct net_device *dev, u32 frag_threshold);
-static s32 wl_set_retry(struct net_device *dev, u32 retry, bool l);
+static s32 brcmf_set_frag(struct net_device *dev, u32 frag_threshold);
+static s32 brcmf_set_rts(struct net_device *dev, u32 frag_threshold);
+static s32 brcmf_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,
-                           void *data, s32 item);
-static void *wl_read_prof(struct wl_priv *wl, s32 item);
-static void wl_init_prof(struct wl_profile *prof);
+static s32 brcmf_update_prof(struct wl_priv *wl, const struct brcmf_event_msg *e,
+                            void *data, s32 item);
+static void *brcmf_read_prof(struct wl_priv *wl, s32 item);
+static void brcmf_init_prof(struct wl_profile *prof);
 
 /*
 ** cfg80211 connect utilites
 */
-static s32 wl_set_wpa_version(struct net_device *dev,
+static s32 brcmf_set_wpa_version(struct net_device *dev,
                        struct cfg80211_connect_params *sme);
-static s32 wl_set_auth_type(struct net_device *dev,
+static s32 brcmf_set_auth_type(struct net_device *dev,
                        struct cfg80211_connect_params *sme);
-static s32 wl_set_set_cipher(struct net_device *dev,
+static s32 brcmf_set_set_cipher(struct net_device *dev,
                        struct cfg80211_connect_params *sme);
-static s32 wl_set_key_mgmt(struct net_device *dev,
+static s32 brcmf_set_key_mgmt(struct net_device *dev,
                        struct cfg80211_connect_params *sme);
-static s32 wl_set_set_sharedkey(struct net_device *dev,
+static s32 brcmf_set_set_sharedkey(struct net_device *dev,
                        struct cfg80211_connect_params *sme);
-static s32 wl_get_assoc_ies(struct wl_priv *wl);
-static void wl_clear_assoc_ies(struct wl_priv *wl);
-static void wl_ch_to_chanspec(int ch,
-       struct wl_join_params *join_params, size_t *join_params_size);
+static s32 brcmf_get_assoc_ies(struct wl_priv *wl);
+static void brcmf_clear_assoc_ies(struct wl_priv *wl);
+static void brcmf_ch_to_chanspec(int ch,
+       struct brcmf_join_params *join_params, size_t *join_params_size);
 
 /*
 ** information element utilities
 */
-static __used s32 wl_add_ie(struct wl_priv *wl, u8 t, u8 l, u8 *v);
-static s32 wl_mode_to_nl80211_iftype(s32 mode);
-static struct wireless_dev *wl_alloc_wdev(s32 sizeof_iface,
+static __used s32 brcmf_add_ie(struct wl_priv *wl, u8 t, u8 l, u8 *v);
+static s32 brcmf_mode_to_nl80211_iftype(s32 mode);
+static struct wireless_dev *brcmf_alloc_wdev(s32 sizeof_iface,
                        struct device *dev);
-static void wl_free_wdev(struct wl_priv *wl);
-static s32 wl_inform_bss(struct wl_priv *wl);
-static s32 wl_inform_single_bss(struct wl_priv *wl, struct wl_bss_info *bi);
-static s32 wl_update_bss_info(struct wl_priv *wl);
-static s32 wl_add_keyext(struct wiphy *wiphy, struct net_device *dev,
+static void brcmf_free_wdev(struct wl_priv *wl);
+static s32 brcmf_inform_bss(struct wl_priv *wl);
+static s32 brcmf_inform_single_bss(struct wl_priv *wl, struct brcmf_bss_info *bi);
+static s32 brcmf_update_bss_info(struct wl_priv *wl);
+static s32 brcmf_add_keyext(struct wiphy *wiphy, struct net_device *dev,
                        u8 key_idx, const u8 *mac_addr,
                        struct key_params *params);
 
 /*
 ** key indianess swap utilities
 */
-static void swap_key_from_BE(struct wl_wsec_key *key);
-static void swap_key_to_BE(struct wl_wsec_key *key);
+static void swap_key_from_BE(struct brcmf_wsec_key *key);
+static void swap_key_to_BE(struct brcmf_wsec_key *key);
 
 /*
 ** wl_priv memory init/deinit utilities
 */
-static s32 wl_init_priv_mem(struct wl_priv *wl);
-static void wl_deinit_priv_mem(struct wl_priv *wl);
+static s32 brcmf_init_priv_mem(struct wl_priv *wl);
+static void brcmf_deinit_priv_mem(struct wl_priv *wl);
 
-static void wl_delay(u32 ms);
+static void brcmf_delay(u32 ms);
 
 /*
 ** store/restore cfg80211 instance data
 */
-static void wl_set_drvdata(struct wl_dev *dev, void *data);
-static void *wl_get_drvdata(struct wl_dev *dev);
+static void brcmf_set_drvdata(struct wl_dev *dev, void *data);
+static void *brcmf_get_drvdata(struct wl_dev *dev);
 
 /*
 ** ibss mode utilities
 */
-static bool wl_is_ibssmode(struct wl_priv *wl);
+static bool brcmf_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 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);
-static s32 __wl_cfg80211_down(struct wl_priv *wl);
-static s32 wl_dongle_probecap(struct wl_priv *wl);
-static void wl_init_conf(struct wl_conf *conf);
+static bool brcmf_is_linkdown(struct wl_priv *wl, const struct brcmf_event_msg *e);
+static bool brcmf_is_linkup(struct wl_priv *wl, const struct brcmf_event_msg *e);
+static bool brcmf_is_nonetwork(struct wl_priv *wl,
+                              const struct brcmf_event_msg *e);
+static void brcmf_link_down(struct wl_priv *wl);
+static s32 brcmf_dongle_mode(struct net_device *ndev, s32 iftype);
+static s32 __brcmf_cfg80211_up(struct wl_priv *wl);
+static s32 __brcmf_cfg80211_down(struct wl_priv *wl);
+static s32 brcmf_dongle_probecap(struct wl_priv *wl);
+static void brcmf_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,
+static s32 brcmf_dongle_eventmsg(struct net_device *ndev);
+static s32 brcmf_dongle_scantime(struct net_device *ndev, s32 scan_assoc_time,
                                s32 scan_unassoc_time, s32 scan_passive_time);
-static s32 wl_config_dongle(struct wl_priv *wl, bool need_lock);
-static s32 wl_dongle_roam(struct net_device *ndev, u32 roamvar,
+static s32 brcmf_config_dongle(struct wl_priv *wl, bool need_lock);
+static s32 brcmf_dongle_roam(struct net_device *ndev, u32 roamvar,
                            u32 bcn_timeout);
 
 /*
 ** iscan handler
 */
-static void wl_iscan_timer(unsigned long data);
-static void wl_term_iscan(struct wl_priv *wl);
-static s32 wl_init_iscan(struct wl_priv *wl);
-static s32 wl_iscan_thread(void *data);
-static s32 wl_dev_iovar_setbuf(struct net_device *dev, s8 *iovar,
+static void brcmf_iscan_timer(unsigned long data);
+static void brcmf_term_iscan(struct wl_priv *wl);
+static s32 brcmf_init_iscan(struct wl_priv *wl);
+static s32 brcmf_iscan_thread(void *data);
+static s32 brcmf_dev_iovar_setbuf(struct net_device *dev, s8 *iovar,
                                 void *param, s32 paramlen, void *bufptr,
                                 s32 buflen);
-static s32 wl_dev_iovar_getbuf(struct net_device *dev, s8 *iovar,
+static s32 brcmf_dev_iovar_getbuf(struct net_device *dev, s8 *iovar,
                                 void *param, s32 paramlen, void *bufptr,
                                 s32 buflen);
-static s32 wl_run_iscan(struct wl_iscan_ctrl *iscan, struct wlc_ssid *ssid,
+static s32 brcmf_run_iscan(struct wl_iscan_ctrl *iscan, struct brcmf_ssid *ssid,
                          u16 action);
-static s32 wl_do_iscan(struct wl_priv *wl);
-static s32 wl_wakeup_iscan(struct wl_iscan_ctrl *iscan);
-static s32 wl_invoke_iscan(struct wl_priv *wl);
-static s32 wl_get_iscan_results(struct wl_iscan_ctrl *iscan, u32 *status,
-                                 struct wl_scan_results **bss_list);
-static void wl_notify_iscan_complete(struct wl_iscan_ctrl *iscan, bool aborted);
-static void wl_init_iscan_eloop(struct wl_iscan_eloop *el);
-static s32 wl_iscan_done(struct wl_priv *wl);
-static s32 wl_iscan_pending(struct wl_priv *wl);
-static s32 wl_iscan_inprogress(struct wl_priv *wl);
-static s32 wl_iscan_aborted(struct wl_priv *wl);
-
-/*
-** fw/nvram downloading handler
-*/
-static void wl_init_fw(struct wl_fw_ctrl *fw);
+static s32 brcmf_do_iscan(struct wl_priv *wl);
+static s32 brcmf_wakeup_iscan(struct wl_iscan_ctrl *iscan);
+static s32 brcmf_invoke_iscan(struct wl_priv *wl);
+static s32 brcmf_get_iscan_results(struct wl_iscan_ctrl *iscan, u32 *status,
+                                 struct brcmf_scan_results **bss_list);
+static void brcmf_notify_iscan_complete(struct wl_iscan_ctrl *iscan, bool aborted);
+static void brcmf_init_iscan_eloop(struct wl_iscan_eloop *el);
+static s32 brcmf_iscan_done(struct wl_priv *wl);
+static s32 brcmf_iscan_pending(struct wl_priv *wl);
+static s32 brcmf_iscan_inprogress(struct wl_priv *wl);
+static s32 brcmf_iscan_aborted(struct wl_priv *wl);
 
 /*
 * find most significant bit set
 */
-static __used u32 wl_find_msb(u16 bit16);
+static __used u32 brcmf_find_msb(u16 bit16);
 
 /*
 * update pmklist to dongle
 */
-static __used s32 wl_update_pmklist(struct net_device *dev,
+static __used s32 brcmf_update_pmklist(struct net_device *dev,
                                      struct wl_pmk_list *pmk_list, s32 err);
 
-static void wl_set_mpc(struct net_device *ndev, int mpc);
+static void brcmf_set_mpc(struct net_device *ndev, int mpc);
 
 /*
 * debufs support
 */
-static int wl_debugfs_add_netdev_params(struct wl_priv *wl);
-static void wl_debugfs_remove_netdev(struct wl_priv *wl);
+static int brcmf_debugfs_add_netdev_params(struct wl_priv *wl);
+static void brcmf_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 = brcmf_get_drvdata(wl_cfg80211_dev);               \
+       if (unlikely(!ci)) {                                            \
                WL_ERR("wl_cfg80211_dev is unavailable\n");             \
                BUG();                                                  \
-       }                                                               \
+       }                                                               \
        ci_to_wl(ci);                                                   \
 })
 
@@ -345,7 +318,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),                      \
@@ -521,7 +493,7 @@ static const u32 __wl_cipher_suites[] = {
        WLAN_CIPHER_SUITE_AES_CMAC,
 };
 
-static void swap_key_from_BE(struct wl_wsec_key *key)
+static void swap_key_from_BE(struct brcmf_wsec_key *key)
 {
        key->index = cpu_to_le32(key->index);
        key->len = cpu_to_le32(key->len);
@@ -532,7 +504,7 @@ static void swap_key_from_BE(struct wl_wsec_key *key)
        key->iv_initialized = cpu_to_le32(key->iv_initialized);
 }
 
-static void swap_key_to_BE(struct wl_wsec_key *key)
+static void swap_key_to_BE(struct brcmf_wsec_key *key)
 {
        key->index = le32_to_cpu(key->index);
        key->len = le32_to_cpu(key->len);
@@ -544,10 +516,10 @@ static void swap_key_to_BE(struct wl_wsec_key *key)
 }
 
 static s32
-wl_dev_ioctl(struct net_device *dev, u32 cmd, void *arg, u32 len)
+brcmf_dev_ioctl(struct net_device *dev, u32 cmd, void *arg, u32 len)
 {
        struct ifreq ifr;
-       struct wl_ioctl ioc;
+       struct brcmf_ioctl ioc;
        mm_segment_t fs;
        s32 err = 0;
 
@@ -567,7 +539,7 @@ wl_dev_ioctl(struct net_device *dev, u32 cmd, void *arg, u32 len)
 }
 
 static s32
-wl_cfg80211_change_iface(struct wiphy *wiphy, struct net_device *ndev,
+brcmf_cfg80211_change_iface(struct wiphy *wiphy, struct net_device *ndev,
                         enum nl80211_iftype type, u32 *flags,
                         struct vif_params *params)
 {
@@ -599,7 +571,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 = brcmf_dev_ioctl(ndev, BRCMF_C_SET_INFRA, &infra, sizeof(infra));
        if (unlikely(err)) {
                WL_ERR("WLC_SET_INFRA error (%d)\n", err);
                err = -EAGAIN;
@@ -617,7 +589,8 @@ done:
        return err;
 }
 
-static void wl_iscan_prep(struct wl_scan_params *params, struct wlc_ssid *ssid)
+static void wl_iscan_prep(struct brcmf_scan_params *params,
+                         struct brcmf_ssid *ssid)
 {
        memcpy(params->bssid, ether_bcast, ETH_ALEN);
        params->bss_type = DOT11_BSSTYPE_ANY;
@@ -633,58 +606,58 @@ static void wl_iscan_prep(struct wl_scan_params *params, struct wlc_ssid *ssid)
        params->passive_time = cpu_to_le32(params->passive_time);
        params->home_time = cpu_to_le32(params->home_time);
        if (ssid && ssid->SSID_len)
-               memcpy(&params->ssid, ssid, sizeof(wlc_ssid_t));
+               memcpy(&params->ssid, ssid, sizeof(struct brcmf_ssid));
 
 }
 
 static s32
-wl_dev_iovar_setbuf(struct net_device *dev, s8 * iovar, void *param,
+brcmf_dev_iovar_setbuf(struct net_device *dev, s8 * iovar, void *param,
                    s32 paramlen, void *bufptr, s32 buflen)
 {
        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 brcmf_dev_ioctl(dev, BRCMF_C_SET_VAR, bufptr, iolen);
 }
 
 static s32
-wl_dev_iovar_getbuf(struct net_device *dev, s8 * iovar, void *param,
+brcmf_dev_iovar_getbuf(struct net_device *dev, s8 * iovar, void *param,
                    s32 paramlen, void *bufptr, s32 buflen)
 {
        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 brcmf_dev_ioctl(dev, BRCMF_C_GET_VAR, bufptr, buflen);
 }
 
 static s32
-wl_run_iscan(struct wl_iscan_ctrl *iscan, struct wlc_ssid *ssid, u16 action)
+brcmf_run_iscan(struct wl_iscan_ctrl *iscan, struct brcmf_ssid *ssid, u16 action)
 {
-       s32 params_size =
-           (WL_SCAN_PARAMS_FIXED_SIZE + offsetof(wl_iscan_params_t, params));
-       struct wl_iscan_params *params;
+       s32 params_size = (BRCMF_SCAN_PARAMS_FIXED_SIZE +
+                               offsetof(struct brcmf_iscan_params, params));
+       struct brcmf_iscan_params *params;
        s32 err = 0;
 
        if (ssid && ssid->SSID_len)
-               params_size += sizeof(struct wlc_ssid);
+               params_size += sizeof(struct brcmf_ssid);
        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);
 
-       params->version = cpu_to_le32(ISCAN_REQ_VERSION);
+       params->version = cpu_to_le32(BRCMF_ISCAN_REQ_VERSION);
        params->action = cpu_to_le16(action);
        params->scan_duration = cpu_to_le16(0);
 
-       /* 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);
+       /* params_size += offsetof(struct brcmf_iscan_params, params); */
+       err = brcmf_dev_iovar_setbuf(iscan->dev, "iscan", params, params_size,
+                               iscan->ioctl_buf, BRCMF_C_IOCTL_SMLEN);
        if (unlikely(err)) {
                if (err == -EBUSY) {
                        WL_INFO("system busy : iscan canceled\n");
@@ -696,11 +669,11 @@ wl_run_iscan(struct wl_iscan_ctrl *iscan, struct wlc_ssid *ssid, u16 action)
        return err;
 }
 
-static s32 wl_do_iscan(struct wl_priv *wl)
+static s32 brcmf_do_iscan(struct wl_priv *wl)
 {
        struct wl_iscan_ctrl *iscan = wl_to_iscan(wl);
        struct net_device *ndev = wl_to_ndev(wl);
-       struct wlc_ssid ssid;
+       struct brcmf_ssid ssid;
        s32 passive_scan;
        s32 err = 0;
 
@@ -710,15 +683,15 @@ 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 = brcmf_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);
                return err;
        }
-       wl_set_mpc(ndev, 0);
+       brcmf_set_mpc(ndev, 0);
        wl->iscan_kickstart = true;
-       wl_run_iscan(iscan, &ssid, WL_SCAN_ACTION_START);
+       brcmf_run_iscan(iscan, &ssid, BRCMF_SCAN_ACTION_START);
        mod_timer(&iscan->timer, jiffies + iscan->timer_ms * HZ / 1000);
        iscan->timer_on = 1;
 
@@ -726,7 +699,7 @@ static s32 wl_do_iscan(struct wl_priv *wl)
 }
 
 static s32
-__wl_cfg80211_scan(struct wiphy *wiphy, struct net_device *ndev,
+__brcmf_cfg80211_scan(struct wiphy *wiphy, struct net_device *ndev,
                   struct cfg80211_scan_request *request,
                   struct cfg80211_ssid *this_ssid)
 {
@@ -769,7 +742,7 @@ __wl_cfg80211_scan(struct wiphy *wiphy, struct net_device *ndev,
        wl->scan_request = request;
        set_bit(WL_STATUS_SCANNING, &wl->status);
        if (iscan_req) {
-               err = wl_do_iscan(wl);
+               err = brcmf_do_iscan(wl);
                if (likely(!err))
                        return err;
                else
@@ -789,14 +762,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 = brcmf_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,
+               brcmf_set_mpc(ndev, 0);
+               err = brcmf_dev_ioctl(ndev, BRCMF_C_SCAN, &sr->ssid,
                                sizeof(sr->ssid));
                if (err) {
                        if (err == -EBUSY) {
@@ -805,7 +778,7 @@ __wl_cfg80211_scan(struct wiphy *wiphy, struct net_device *ndev,
                        } else {
                                WL_ERR("WLC_SCAN error (%d)\n", err);
                        }
-                       wl_set_mpc(ndev, 1);
+                       brcmf_set_mpc(ndev, 1);
                        goto scan_out;
                }
        }
@@ -819,7 +792,7 @@ scan_out:
 }
 
 static s32
-wl_cfg80211_scan(struct wiphy *wiphy, struct net_device *ndev,
+brcmf_cfg80211_scan(struct wiphy *wiphy, struct net_device *ndev,
                 struct cfg80211_scan_request *request)
 {
        s32 err = 0;
@@ -828,7 +801,7 @@ wl_cfg80211_scan(struct wiphy *wiphy, struct net_device *ndev,
 
        CHECK_SYS_UP();
 
-       err = __wl_cfg80211_scan(wiphy, ndev, request, NULL);
+       err = __brcmf_cfg80211_scan(wiphy, ndev, request, NULL);
        if (unlikely(err))
                WL_ERR("scan error (%d)\n", err);
 
@@ -836,17 +809,18 @@ wl_cfg80211_scan(struct wiphy *wiphy, struct net_device *ndev,
        return err;
 }
 
-static s32 wl_dev_intvar_set(struct net_device *dev, s8 *name, s32 val)
+static s32 brcmf_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 = brcmf_dev_ioctl(dev, BRCMF_C_SET_VAR, buf, len);
        if (unlikely(err))
                WL_ERR("error (%d)\n", err);
 
@@ -854,10 +828,10 @@ static s32 wl_dev_intvar_set(struct net_device *dev, s8 *name, s32 val)
 }
 
 static s32
-wl_dev_intvar_get(struct net_device *dev, s8 *name, s32 *retval)
+brcmf_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 +839,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 = brcmf_dev_ioctl(dev, BRCMF_C_GET_VAR, &var, len);
        if (unlikely(err))
                WL_ERR("error (%d)\n", err);
 
@@ -877,35 +851,35 @@ wl_dev_intvar_get(struct net_device *dev, s8 *name, s32 *retval)
        return err;
 }
 
-static s32 wl_set_rts(struct net_device *dev, u32 rts_threshold)
+static s32 brcmf_set_rts(struct net_device *dev, u32 rts_threshold)
 {
        s32 err = 0;
 
-       err = wl_dev_intvar_set(dev, "rtsthresh", rts_threshold);
+       err = brcmf_dev_intvar_set(dev, "rtsthresh", rts_threshold);
        if (unlikely(err))
                WL_ERR("Error (%d)\n", err);
 
        return err;
 }
 
-static s32 wl_set_frag(struct net_device *dev, u32 frag_threshold)
+static s32 brcmf_set_frag(struct net_device *dev, u32 frag_threshold)
 {
        s32 err = 0;
 
-       err = wl_dev_intvar_set(dev, "fragthresh", frag_threshold);
+       err = brcmf_dev_intvar_set(dev, "fragthresh", frag_threshold);
        if (unlikely(err))
                WL_ERR("Error (%d)\n", err);
 
        return err;
 }
 
-static s32 wl_set_retry(struct net_device *dev, u32 retry, bool l)
+static s32 brcmf_set_retry(struct net_device *dev, u32 retry, bool l)
 {
        s32 err = 0;
        u32 cmd = (l ? WLC_SET_LRL : WLC_SET_SRL);
 
        retry = cpu_to_le32(retry);
-       err = wl_dev_ioctl(dev, cmd, &retry, sizeof(retry));
+       err = brcmf_dev_ioctl(dev, cmd, &retry, sizeof(retry));
        if (unlikely(err)) {
                WL_ERR("cmd (%d) , error (%d)\n", cmd, err);
                return err;
@@ -913,7 +887,7 @@ static s32 wl_set_retry(struct net_device *dev, u32 retry, bool l)
        return err;
 }
 
-static s32 wl_cfg80211_set_wiphy_params(struct wiphy *wiphy, u32 changed)
+static s32 brcmf_cfg80211_set_wiphy_params(struct wiphy *wiphy, u32 changed)
 {
        struct wl_priv *wl = wiphy_to_wl(wiphy);
        struct net_device *ndev = wl_to_ndev(wl);
@@ -925,28 +899,28 @@ static s32 wl_cfg80211_set_wiphy_params(struct wiphy *wiphy, u32 changed)
        if (changed & WIPHY_PARAM_RTS_THRESHOLD &&
            (wl->conf->rts_threshold != wiphy->rts_threshold)) {
                wl->conf->rts_threshold = wiphy->rts_threshold;
-               err = wl_set_rts(ndev, wl->conf->rts_threshold);
+               err = brcmf_set_rts(ndev, wl->conf->rts_threshold);
                if (!err)
                        goto done;
        }
        if (changed & WIPHY_PARAM_FRAG_THRESHOLD &&
            (wl->conf->frag_threshold != wiphy->frag_threshold)) {
                wl->conf->frag_threshold = wiphy->frag_threshold;
-               err = wl_set_frag(ndev, wl->conf->frag_threshold);
+               err = brcmf_set_frag(ndev, wl->conf->frag_threshold);
                if (!err)
                        goto done;
        }
        if (changed & WIPHY_PARAM_RETRY_LONG
            && (wl->conf->retry_long != wiphy->retry_long)) {
                wl->conf->retry_long = wiphy->retry_long;
-               err = wl_set_retry(ndev, wl->conf->retry_long, true);
+               err = brcmf_set_retry(ndev, wl->conf->retry_long, true);
                if (!err)
                        goto done;
        }
        if (changed & WIPHY_PARAM_RETRY_SHORT
            && (wl->conf->retry_short != wiphy->retry_short)) {
                wl->conf->retry_short = wiphy->retry_short;
-               err = wl_set_retry(ndev, wl->conf->retry_short, false);
+               err = brcmf_set_retry(ndev, wl->conf->retry_short, false);
                if (!err)
                        goto done;
        }
@@ -957,11 +931,11 @@ done:
 }
 
 static s32
-wl_cfg80211_join_ibss(struct wiphy *wiphy, struct net_device *dev,
+brcmf_cfg80211_join_ibss(struct wiphy *wiphy, struct net_device *dev,
                      struct cfg80211_ibss_params *params)
 {
        struct wl_priv *wl = wiphy_to_wl(wiphy);
-       struct wl_join_params join_params;
+       struct brcmf_join_params join_params;
        size_t join_params_size = 0;
        s32 err = 0;
        s32 wsec = 0;
@@ -977,6 +951,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],
@@ -1018,7 +994,7 @@ wl_cfg80211_join_ibss(struct wiphy *wiphy, struct net_device *dev,
        if (params->privacy)
                wsec |= WEP_ENABLED;
 
-       err = wl_dev_intvar_set(dev, "wsec", wsec);
+       err = brcmf_dev_intvar_set(dev, "wsec", wsec);
        if (unlikely(err)) {
                WL_ERR("wsec failed (%d)\n", err);
                goto done;
@@ -1030,14 +1006,14 @@ wl_cfg80211_join_ibss(struct wiphy *wiphy, struct net_device *dev,
        else
                bcnprd = cpu_to_le32(100);
 
-       err = wl_dev_ioctl(dev, WLC_SET_BCNPRD, &bcnprd, sizeof(bcnprd));
+       err = brcmf_dev_ioctl(dev, WLC_SET_BCNPRD, &bcnprd, sizeof(bcnprd));
        if (unlikely(err)) {
                WL_ERR("WLC_SET_BCNPRD failed (%d)\n", err);
                goto done;
        }
 
        /* Configure required join parameter */
-       memset(&join_params, 0, sizeof(wl_join_params_t));
+       memset(&join_params, 0, sizeof(struct brcmf_join_params));
 
        /* SSID */
        join_params.ssid.SSID_len =
@@ -1045,17 +1021,17 @@ wl_cfg80211_join_ibss(struct wiphy *wiphy, struct net_device *dev,
        memcpy(join_params.ssid.SSID, params->ssid, join_params.ssid.SSID_len);
        join_params.ssid.SSID_len = cpu_to_le32(join_params.ssid.SSID_len);
        join_params_size = sizeof(join_params.ssid);
-       wl_update_prof(wl, NULL, &join_params.ssid, WL_PROF_SSID);
+       brcmf_update_prof(wl, NULL, &join_params.ssid, WL_PROF_SSID);
 
        /* BSSID */
        if (params->bssid) {
                memcpy(join_params.params.bssid, params->bssid, ETH_ALEN);
-               join_params_size =
-                       sizeof(join_params.ssid) + WL_ASSOC_PARAMS_FIXED_SIZE;
+               join_params_size = sizeof(join_params.ssid) +
+                                       BRCMF_ASSOC_PARAMS_FIXED_SIZE;
        } else {
                memcpy(join_params.params.bssid, ether_bcast, ETH_ALEN);
        }
-       wl_update_prof(wl, NULL, &join_params.params.bssid, WL_PROF_BSSID);
+       brcmf_update_prof(wl, NULL, &join_params.params.bssid, WL_PROF_BSSID);
 
        /* Channel */
        if (params->channel) {
@@ -1066,13 +1042,13 @@ wl_cfg80211_join_ibss(struct wiphy *wiphy, struct net_device *dev,
                                params->channel->center_freq);
                if (params->channel_fixed) {
                        /* adding chanspec */
-                       wl_ch_to_chanspec(wl->channel,
+                       brcmf_ch_to_chanspec(wl->channel,
                                &join_params, &join_params_size);
                }
 
                /* set channel for starter */
                target_channel = cpu_to_le32(wl->channel);
-               err = wl_dev_ioctl(dev, WLC_SET_CHANNEL,
+               err = brcmf_dev_ioctl(dev, WLC_SET_CHANNEL,
                        &target_channel, sizeof(target_channel));
                if (unlikely(err)) {
                        WL_ERR("WLC_SET_CHANNEL failed (%d)\n", err);
@@ -1084,20 +1060,21 @@ 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 = brcmf_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;
 }
 
-static s32 wl_cfg80211_leave_ibss(struct wiphy *wiphy, struct net_device *dev)
+static s32 brcmf_cfg80211_leave_ibss(struct wiphy *wiphy, struct net_device *dev)
 {
        struct wl_priv *wl = wiphy_to_wl(wiphy);
        s32 err = 0;
@@ -1105,7 +1082,7 @@ static s32 wl_cfg80211_leave_ibss(struct wiphy *wiphy, struct net_device *dev)
        WL_TRACE("Enter\n");
        CHECK_SYS_UP();
 
-       wl_link_down(wl);
+       brcmf_link_down(wl);
 
        WL_TRACE("Exit\n");
 
@@ -1113,7 +1090,7 @@ static s32 wl_cfg80211_leave_ibss(struct wiphy *wiphy, struct net_device *dev)
 }
 
 static s32
-wl_set_wpa_version(struct net_device *dev, struct cfg80211_connect_params *sme)
+brcmf_set_wpa_version(struct net_device *dev, struct cfg80211_connect_params *sme)
 {
        struct wl_priv *wl = ndev_to_wl(dev);
        struct wl_security *sec;
@@ -1127,18 +1104,18 @@ wl_set_wpa_version(struct net_device *dev, struct cfg80211_connect_params *sme)
        else
                val = WPA_AUTH_DISABLED;
        WL_CONN("setting wpa_auth to 0x%0x\n", val);
-       err = wl_dev_intvar_set(dev, "wpa_auth", val);
+       err = brcmf_dev_intvar_set(dev, "wpa_auth", val);
        if (unlikely(err)) {
                WL_ERR("set wpa_auth failed (%d)\n", err);
                return err;
        }
-       sec = wl_read_prof(wl, WL_PROF_SEC);
+       sec = brcmf_read_prof(wl, WL_PROF_SEC);
        sec->wpa_versions = sme->crypto.wpa_versions;
        return err;
 }
 
 static s32
-wl_set_auth_type(struct net_device *dev, struct cfg80211_connect_params *sme)
+brcmf_set_auth_type(struct net_device *dev, struct cfg80211_connect_params *sme)
 {
        struct wl_priv *wl = ndev_to_wl(dev);
        struct wl_security *sec;
@@ -1166,18 +1143,18 @@ wl_set_auth_type(struct net_device *dev, struct cfg80211_connect_params *sme)
                break;
        }
 
-       err = wl_dev_intvar_set(dev, "auth", val);
+       err = brcmf_dev_intvar_set(dev, "auth", val);
        if (unlikely(err)) {
                WL_ERR("set auth failed (%d)\n", err);
                return err;
        }
-       sec = wl_read_prof(wl, WL_PROF_SEC);
+       sec = brcmf_read_prof(wl, WL_PROF_SEC);
        sec->auth_type = sme->auth_type;
        return err;
 }
 
 static s32
-wl_set_set_cipher(struct net_device *dev, struct cfg80211_connect_params *sme)
+brcmf_set_set_cipher(struct net_device *dev, struct cfg80211_connect_params *sme)
 {
        struct wl_priv *wl = ndev_to_wl(dev);
        struct wl_security *sec;
@@ -1229,13 +1206,13 @@ wl_set_set_cipher(struct net_device *dev, struct cfg80211_connect_params *sme)
        }
 
        WL_CONN("pval (%d) gval (%d)\n", pval, gval);
-       err = wl_dev_intvar_set(dev, "wsec", pval | gval);
+       err = brcmf_dev_intvar_set(dev, "wsec", pval | gval);
        if (unlikely(err)) {
                WL_ERR("error (%d)\n", err);
                return err;
        }
 
-       sec = wl_read_prof(wl, WL_PROF_SEC);
+       sec = brcmf_read_prof(wl, WL_PROF_SEC);
        sec->cipher_pairwise = sme->crypto.ciphers_pairwise[0];
        sec->cipher_group = sme->crypto.cipher_group;
 
@@ -1243,7 +1220,7 @@ wl_set_set_cipher(struct net_device *dev, struct cfg80211_connect_params *sme)
 }
 
 static s32
-wl_set_key_mgmt(struct net_device *dev, struct cfg80211_connect_params *sme)
+brcmf_set_key_mgmt(struct net_device *dev, struct cfg80211_connect_params *sme)
 {
        struct wl_priv *wl = ndev_to_wl(dev);
        struct wl_security *sec;
@@ -1251,7 +1228,7 @@ wl_set_key_mgmt(struct net_device *dev, struct cfg80211_connect_params *sme)
        s32 err = 0;
 
        if (sme->crypto.n_akm_suites) {
-               err = wl_dev_intvar_get(dev, "wpa_auth", &val);
+               err = brcmf_dev_intvar_get(dev, "wpa_auth", &val);
                if (unlikely(err)) {
                        WL_ERR("could not get wpa_auth (%d)\n", err);
                        return err;
@@ -1285,31 +1262,31 @@ wl_set_key_mgmt(struct net_device *dev, struct cfg80211_connect_params *sme)
                }
 
                WL_CONN("setting wpa_auth to %d\n", val);
-               err = wl_dev_intvar_set(dev, "wpa_auth", val);
+               err = brcmf_dev_intvar_set(dev, "wpa_auth", val);
                if (unlikely(err)) {
                        WL_ERR("could not set wpa_auth (%d)\n", err);
                        return err;
                }
        }
-       sec = wl_read_prof(wl, WL_PROF_SEC);
+       sec = brcmf_read_prof(wl, WL_PROF_SEC);
        sec->wpa_auth = sme->crypto.akm_suites[0];
 
        return err;
 }
 
 static s32
-wl_set_set_sharedkey(struct net_device *dev,
+brcmf_set_set_sharedkey(struct net_device *dev,
                     struct cfg80211_connect_params *sme)
 {
        struct wl_priv *wl = ndev_to_wl(dev);
        struct wl_security *sec;
-       struct wl_wsec_key key;
+       struct brcmf_wsec_key key;
        s32 val;
        s32 err = 0;
 
        WL_CONN("key len (%d)\n", sme->key_len);
        if (sme->key_len) {
-               sec = wl_read_prof(wl, WL_PROF_SEC);
+               sec = brcmf_read_prof(wl, WL_PROF_SEC);
                WL_CONN("wpa_versions 0x%x cipher_pairwise 0x%x\n",
                       sec->wpa_versions, sec->cipher_pairwise);
                if (!
@@ -1325,7 +1302,7 @@ wl_set_set_sharedkey(struct net_device *dev,
                                return -EINVAL;
                        }
                        memcpy(key.data, sme->key, key.len);
-                       key.flags = WL_PRIMARY_KEY;
+                       key.flags = BRCMF_PRIMARY_KEY;
                        switch (sec->cipher_pairwise) {
                        case WLAN_CIPHER_SUITE_WEP40:
                                key.algo = CRYPTO_ALGO_WEP1;
@@ -1343,7 +1320,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 = brcmf_dev_ioctl(dev, BRCMF_C_SET_KEY, &key,
                                        sizeof(key));
                        if (unlikely(err)) {
                                WL_ERR("WLC_SET_KEY error (%d)\n", err);
@@ -1352,7 +1329,7 @@ wl_set_set_sharedkey(struct net_device *dev,
                        if (sec->auth_type == NL80211_AUTHTYPE_OPEN_SYSTEM) {
                                WL_CONN("set auth_type to shared key\n");
                                val = 1;        /* shared key */
-                               err = wl_dev_intvar_set(dev, "auth", val);
+                               err = brcmf_dev_intvar_set(dev, "auth", val);
                                if (unlikely(err)) {
                                        WL_ERR("set auth failed (%d)\n", err);
                                        return err;
@@ -1364,12 +1341,12 @@ wl_set_set_sharedkey(struct net_device *dev,
 }
 
 static s32
-wl_cfg80211_connect(struct wiphy *wiphy, struct net_device *dev,
+brcmf_cfg80211_connect(struct wiphy *wiphy, struct net_device *dev,
                    struct cfg80211_connect_params *sme)
 {
        struct wl_priv *wl = wiphy_to_wl(wiphy);
        struct ieee80211_channel *chan = sme->channel;
-       struct wl_join_params join_params;
+       struct brcmf_join_params join_params;
        size_t join_params_size;
 
        s32 err = 0;
@@ -1382,6 +1359,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);
@@ -1392,27 +1371,37 @@ 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;
+       err = brcmf_set_wpa_version(dev, sme);
+       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;
+       err = brcmf_set_auth_type(dev, sme);
+       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;
+       err = brcmf_set_set_cipher(dev, sme);
+       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;
+       err = brcmf_set_key_mgmt(dev, sme);
+       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;
+       err = brcmf_set_set_sharedkey(dev, sme);
+       if (err) {
+               WL_ERR("wl_set_set_sharedkey failed (%d)\n", err);
+               goto done;
+       }
 
-       wl_update_prof(wl, NULL, sme->bssid, WL_PROF_BSSID);
+       brcmf_update_prof(wl, NULL, sme->bssid, WL_PROF_BSSID);
        /*
         **  Join with specific BSSID and cached SSID
         **  If SSID is zero join based on BSSID only
@@ -1423,7 +1412,7 @@ wl_cfg80211_connect(struct wiphy *wiphy, struct net_device *dev,
        join_params.ssid.SSID_len = min(sizeof(join_params.ssid.SSID), sme->ssid_len);
        memcpy(&join_params.ssid.SSID, sme->ssid, join_params.ssid.SSID_len);
        join_params.ssid.SSID_len = cpu_to_le32(join_params.ssid.SSID_len);
-       wl_update_prof(wl, NULL, &join_params.ssid, WL_PROF_SSID);
+       brcmf_update_prof(wl, NULL, &join_params.ssid, WL_PROF_SSID);
 
        if (sme->bssid)
                memcpy(join_params.params.bssid, sme->bssid, ETH_ALEN);
@@ -1435,24 +1424,25 @@ wl_cfg80211_connect(struct wiphy *wiphy, struct net_device *dev,
                       join_params.ssid.SSID, join_params.ssid.SSID_len);
        }
 
-       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);
+       brcmf_ch_to_chanspec(wl->channel, &join_params, &join_params_size);
+       err = brcmf_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;
 }
 
 static s32
-wl_cfg80211_disconnect(struct wiphy *wiphy, struct net_device *dev,
+brcmf_cfg80211_disconnect(struct wiphy *wiphy, struct net_device *dev,
                       u16 reason_code)
 {
        struct wl_priv *wl = wiphy_to_wl(wiphy);
-       scb_val_t scbval;
+       struct brcmf_scb_val scbval;
        s32 err = 0;
 
        WL_TRACE("Enter. Reason code = %d\n", reason_code);
@@ -1461,10 +1451,10 @@ wl_cfg80211_disconnect(struct wiphy *wiphy, struct net_device *dev,
        clear_bit(WL_STATUS_CONNECTED, &wl->status);
 
        scbval.val = reason_code;
-       memcpy(&scbval.ea, wl_read_prof(wl, WL_PROF_BSSID), ETH_ALEN);
+       memcpy(&scbval.ea, brcmf_read_prof(wl, WL_PROF_BSSID), ETH_ALEN);
        scbval.val = cpu_to_le32(scbval.val);
-       err = wl_dev_ioctl(dev, WLC_DISASSOC, &scbval,
-                       sizeof(scb_val_t));
+       err = brcmf_dev_ioctl(dev, BRCMF_C_DISASSOC, &scbval,
+                       sizeof(struct brcmf_scb_val));
        if (unlikely(err))
                WL_ERR("error (%d)\n", err);
 
@@ -1475,7 +1465,7 @@ wl_cfg80211_disconnect(struct wiphy *wiphy, struct net_device *dev,
 }
 
 static s32
-wl_cfg80211_set_tx_power(struct wiphy *wiphy,
+brcmf_cfg80211_set_tx_power(struct wiphy *wiphy,
                         enum nl80211_tx_power_setting type, s32 dbm)
 {
 
@@ -1509,7 +1499,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 = brcmf_dev_ioctl(ndev, BRCMF_C_SET_RADIO, &disable, sizeof(disable));
        if (unlikely(err))
                WL_ERR("WLC_SET_RADIO error (%d)\n", err);
 
@@ -1517,8 +1507,8 @@ wl_cfg80211_set_tx_power(struct wiphy *wiphy,
                txpwrmw = 0xffff;
        else
                txpwrmw = (u16) dbm;
-       err = wl_dev_intvar_set(ndev, "qtxpower",
-                       (s32) (bcm_mw_to_qdbm(txpwrmw)));
+       err = brcmf_dev_intvar_set(ndev, "qtxpower",
+                       (s32) (brcmu_mw_to_qdbm(txpwrmw)));
        if (unlikely(err))
                WL_ERR("qtxpower error (%d)\n", err);
        wl->conf->tx_power = dbm;
@@ -1528,7 +1518,7 @@ done:
        return err;
 }
 
-static s32 wl_cfg80211_get_tx_power(struct wiphy *wiphy, s32 *dbm)
+static s32 brcmf_cfg80211_get_tx_power(struct wiphy *wiphy, s32 *dbm)
 {
        struct wl_priv *wl = wiphy_to_wl(wiphy);
        struct net_device *ndev = wl_to_ndev(wl);
@@ -1539,14 +1529,14 @@ static s32 wl_cfg80211_get_tx_power(struct wiphy *wiphy, s32 *dbm)
        WL_TRACE("Enter\n");
        CHECK_SYS_UP();
 
-       err = wl_dev_intvar_get(ndev, "qtxpower", &txpwrdbm);
+       err = brcmf_dev_intvar_get(ndev, "qtxpower", &txpwrdbm);
        if (unlikely(err)) {
                WL_ERR("error (%d)\n", err);
                goto done;
        }
 
        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");
@@ -1554,7 +1544,7 @@ done:
 }
 
 static s32
-wl_cfg80211_config_default_key(struct wiphy *wiphy, struct net_device *dev,
+brcmf_cfg80211_config_default_key(struct wiphy *wiphy, struct net_device *dev,
                               u8 key_idx, bool unicast, bool multicast)
 {
        u32 index;
@@ -1565,7 +1555,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 = brcmf_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 +1566,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 = brcmf_dev_ioctl(dev, BRCMF_C_SET_KEY_PRIMARY, &index,
                                sizeof(index));
                if (unlikely(err))
                        WL_ERR("error (%d)\n", err);
@@ -1587,10 +1577,10 @@ done:
 }
 
 static s32
-wl_add_keyext(struct wiphy *wiphy, struct net_device *dev,
+brcmf_add_keyext(struct wiphy *wiphy, struct net_device *dev,
              u8 key_idx, const u8 *mac_addr, struct key_params *params)
 {
-       struct wl_wsec_key key;
+       struct brcmf_wsec_key key;
        s32 err = 0;
 
        memset(&key, 0, sizeof(key));
@@ -1604,7 +1594,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 = brcmf_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 +1653,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 = brcmf_dev_ioctl(dev, BRCMF_C_SET_KEY, &key, sizeof(key));
                if (unlikely(err)) {
                        WL_ERR("WLC_SET_KEY error (%d)\n", err);
                        return err;
@@ -1674,11 +1664,11 @@ wl_add_keyext(struct wiphy *wiphy, struct net_device *dev,
 }
 
 static s32
-wl_cfg80211_add_key(struct wiphy *wiphy, struct net_device *dev,
+brcmf_cfg80211_add_key(struct wiphy *wiphy, struct net_device *dev,
                    u8 key_idx, bool pairwise, const u8 *mac_addr,
                    struct key_params *params)
 {
-       struct wl_wsec_key key;
+       struct brcmf_wsec_key key;
        s32 val;
        s32 wsec;
        s32 err = 0;
@@ -1690,7 +1680,7 @@ wl_cfg80211_add_key(struct wiphy *wiphy, struct net_device *dev,
 
        if (mac_addr) {
                WL_TRACE("Exit");
-               return wl_add_keyext(wiphy, dev, key_idx, mac_addr, params);
+               return brcmf_add_keyext(wiphy, dev, key_idx, mac_addr, params);
        }
        memset(&key, 0, sizeof(key));
 
@@ -1704,7 +1694,7 @@ wl_cfg80211_add_key(struct wiphy *wiphy, struct net_device *dev,
        }
        memcpy(key.data, params->key, key.len);
 
-       key.flags = WL_PRIMARY_KEY;
+       key.flags = BRCMF_PRIMARY_KEY;
        switch (params->cipher) {
        case WLAN_CIPHER_SUITE_WEP40:
                key.algo = CRYPTO_ALGO_WEP1;
@@ -1737,21 +1727,21 @@ 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 = brcmf_dev_ioctl(dev, BRCMF_C_SET_KEY, &key, sizeof(key));
        if (unlikely(err)) {
                WL_ERR("WLC_SET_KEY error (%d)\n", err);
                goto done;
        }
 
        val = WEP_ENABLED;
-       err = wl_dev_intvar_get(dev, "wsec", &wsec);
+       err = brcmf_dev_intvar_get(dev, "wsec", &wsec);
        if (unlikely(err)) {
                WL_ERR("get wsec error (%d)\n", err);
                goto done;
        }
        wsec &= ~(WEP_ENABLED);
        wsec |= val;
-       err = wl_dev_intvar_set(dev, "wsec", wsec);
+       err = brcmf_dev_intvar_set(dev, "wsec", wsec);
        if (unlikely(err)) {
                WL_ERR("set wsec error (%d)\n", err);
                goto done;
@@ -1759,7 +1749,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 = brcmf_dev_ioctl(dev, BRCMF_C_SET_AUTH, &val, sizeof(val));
        if (unlikely(err))
                WL_ERR("WLC_SET_AUTH error (%d)\n", err);
 done:
@@ -1768,10 +1758,10 @@ done:
 }
 
 static s32
-wl_cfg80211_del_key(struct wiphy *wiphy, struct net_device *dev,
+brcmf_cfg80211_del_key(struct wiphy *wiphy, struct net_device *dev,
                    u8 key_idx, bool pairwise, const u8 *mac_addr)
 {
-       struct wl_wsec_key key;
+       struct brcmf_wsec_key key;
        s32 err = 0;
        s32 val;
        s32 wsec;
@@ -1781,13 +1771,13 @@ wl_cfg80211_del_key(struct wiphy *wiphy, struct net_device *dev,
        memset(&key, 0, sizeof(key));
 
        key.index = (u32) key_idx;
-       key.flags = WL_PRIMARY_KEY;
+       key.flags = BRCMF_PRIMARY_KEY;
        key.algo = CRYPTO_ALGO_OFF;
 
        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 = brcmf_dev_ioctl(dev, BRCMF_C_SET_KEY, &key, sizeof(key));
        if (unlikely(err)) {
                if (err == -EINVAL) {
                        if (key.index >= DOT11_MAX_DEFAULT_KEYS)
@@ -1802,7 +1792,7 @@ wl_cfg80211_del_key(struct wiphy *wiphy, struct net_device *dev,
        }
 
        val = 0;
-       err = wl_dev_intvar_get(dev, "wsec", &wsec);
+       err = brcmf_dev_intvar_get(dev, "wsec", &wsec);
        if (unlikely(err)) {
                WL_ERR("get wsec error (%d)\n", err);
                /* Ignore this error, may happen during DISASSOC */
@@ -1811,7 +1801,7 @@ wl_cfg80211_del_key(struct wiphy *wiphy, struct net_device *dev,
        }
        wsec &= ~(WEP_ENABLED);
        wsec |= val;
-       err = wl_dev_intvar_set(dev, "wsec", wsec);
+       err = brcmf_dev_intvar_set(dev, "wsec", wsec);
        if (unlikely(err)) {
                WL_ERR("set wsec error (%d)\n", err);
                /* Ignore this error, may happen during DISASSOC */
@@ -1821,7 +1811,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 = brcmf_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 */
@@ -1833,12 +1823,12 @@ done:
 }
 
 static s32
-wl_cfg80211_get_key(struct wiphy *wiphy, struct net_device *dev,
+brcmf_cfg80211_get_key(struct wiphy *wiphy, struct net_device *dev,
                    u8 key_idx, bool pairwise, const u8 *mac_addr, void *cookie,
                    void (*callback) (void *cookie, struct key_params * params))
 {
        struct key_params params;
-       struct wl_wsec_key key;
+       struct brcmf_wsec_key key;
        struct wl_priv *wl = wiphy_to_wl(wiphy);
        struct wl_security *sec;
        s32 wsec;
@@ -1855,7 +1845,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 = brcmf_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 */
@@ -1865,7 +1855,7 @@ wl_cfg80211_get_key(struct wiphy *wiphy, struct net_device *dev,
        wsec = le32_to_cpu(wsec);
        switch (wsec) {
        case WEP_ENABLED:
-               sec = wl_read_prof(wl, WL_PROF_SEC);
+               sec = brcmf_read_prof(wl, WL_PROF_SEC);
                if (sec->cipher_pairwise & WLAN_CIPHER_SUITE_WEP40) {
                        params.cipher = WLAN_CIPHER_SUITE_WEP40;
                        WL_CONN("WLAN_CIPHER_SUITE_WEP40\n");
@@ -1895,7 +1885,7 @@ done:
 }
 
 static s32
-wl_cfg80211_config_default_mgmt_key(struct wiphy *wiphy,
+brcmf_cfg80211_config_default_mgmt_key(struct wiphy *wiphy,
                                    struct net_device *dev, u8 key_idx)
 {
        WL_INFO("Not supported\n");
@@ -1905,15 +1895,15 @@ wl_cfg80211_config_default_mgmt_key(struct wiphy *wiphy,
 }
 
 static s32
-wl_cfg80211_get_station(struct wiphy *wiphy, struct net_device *dev,
+brcmf_cfg80211_get_station(struct wiphy *wiphy, struct net_device *dev,
                        u8 *mac, struct station_info *sinfo)
 {
        struct wl_priv *wl = wiphy_to_wl(wiphy);
-       scb_val_t scb_val;
+       struct brcmf_scb_val scb_val;
        int rssi;
        s32 rate;
        s32 err = 0;
-       u8 *bssid = wl_read_prof(wl, WL_PROF_BSSID);
+       u8 *bssid = brcmf_read_prof(wl, WL_PROF_BSSID);
 
        WL_TRACE("Enter\n");
        CHECK_SYS_UP();
@@ -1930,7 +1920,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 = brcmf_dev_ioctl(dev, BRCMF_C_GET_RATE, &rate, sizeof(rate));
        if (err) {
                WL_ERR("Could not get rate (%d)\n", err);
        } else {
@@ -1942,8 +1932,8 @@ 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,
-                               sizeof(scb_val_t));
+               err = brcmf_dev_ioctl(dev, BRCMF_C_GET_RSSI, &scb_val,
+                               sizeof(struct brcmf_scb_val));
                if (unlikely(err)) {
                        WL_ERR("Could not get rssi (%d)\n", err);
                }
@@ -1959,7 +1949,7 @@ done:
 }
 
 static s32
-wl_cfg80211_set_power_mgmt(struct wiphy *wiphy, struct net_device *dev,
+brcmf_cfg80211_set_power_mgmt(struct wiphy *wiphy, struct net_device *dev,
                           bool enabled, s32 timeout)
 {
        s32 pm;
@@ -1972,7 +1962,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 = brcmf_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");
@@ -1983,7 +1973,7 @@ wl_cfg80211_set_power_mgmt(struct wiphy *wiphy, struct net_device *dev,
        return err;
 }
 
-static __used u32 wl_find_msb(u16 bit16)
+static __used u32 brcmf_find_msb(u16 bit16)
 {
        u32 ret = 0;
 
@@ -2011,7 +2001,7 @@ static __used u32 wl_find_msb(u16 bit16)
 }
 
 static s32
-wl_cfg80211_set_bitrate_mask(struct wiphy *wiphy, struct net_device *dev,
+brcmf_cfg80211_set_bitrate_mask(struct wiphy *wiphy, struct net_device *dev,
                             const u8 *addr,
                             const struct cfg80211_bitrate_mask *mask)
 {
@@ -2028,7 +2018,7 @@ wl_cfg80211_set_bitrate_mask(struct wiphy *wiphy, struct net_device *dev,
 
        /* addr param is always NULL. ignore it */
        /* Get current rateset */
-       err = wl_dev_ioctl(dev, WLC_GET_CURR_RATESET, &rateset,
+       err = brcmf_dev_ioctl(dev, WLC_GET_CURR_RATESET, &rateset,
                        sizeof(rateset));
        if (unlikely(err)) {
                WL_ERR("could not get current rateset (%d)\n", err);
@@ -2037,9 +2027,9 @@ wl_cfg80211_set_bitrate_mask(struct wiphy *wiphy, struct net_device *dev,
 
        rateset.count = le32_to_cpu(rateset.count);
 
-       legacy = wl_find_msb(mask->control[IEEE80211_BAND_2GHZ].legacy);
+       legacy = brcmf_find_msb(mask->control[IEEE80211_BAND_2GHZ].legacy);
        if (!legacy)
-               legacy = wl_find_msb(mask->control[IEEE80211_BAND_5GHZ].legacy);
+               legacy = brcmf_find_msb(mask->control[IEEE80211_BAND_5GHZ].legacy);
 
        val = wl_g_rates[legacy - 1].bitrate * 100000;
 
@@ -2057,8 +2047,8 @@ wl_cfg80211_set_bitrate_mask(struct wiphy *wiphy, struct net_device *dev,
         *      Set rate override,
         *      Since the is a/b/g-blind, both a/bg_rate are enforced.
         */
-       err_bg = wl_dev_intvar_set(dev, "bg_rate", rate);
-       err_a = wl_dev_intvar_set(dev, "a_rate", rate);
+       err_bg = brcmf_dev_intvar_set(dev, "bg_rate", rate);
+       err_a = brcmf_dev_intvar_set(dev, "a_rate", rate);
        if (unlikely(err_bg && err_a)) {
                WL_ERR("could not set fixed rate (%d) (%d)\n", err_bg, err_a);
                err = err_bg | err_a;
@@ -2069,10 +2059,9 @@ done:
        return err;
 }
 
-static s32 wl_cfg80211_resume(struct wiphy *wiphy)
+static s32 brcmf_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 +2071,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);
-               wl_invoke_iscan(wiphy_to_wl(wiphy));
-       }
+       if (test_bit(WL_STATUS_READY, &wl->status))
+               brcmf_invoke_iscan(wiphy_to_wl(wiphy));
 
        WL_TRACE("Exit\n");
        return 0;
 }
 
-static s32 wl_cfg80211_suspend(struct wiphy *wiphy)
+static s32 brcmf_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,11 +2098,12 @@ 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);
+               brcmf_link_down(wl);
 
                /*
                 * Make sure WPA_Supplicant receives all the event
@@ -2124,13 +2111,13 @@ static s32 wl_cfg80211_suspend(struct wiphy *wiphy)
                 * the state fw and WPA_Supplicant state consistent
                 */
                rtnl_unlock();
-               wl_delay(500);
+               brcmf_delay(500);
                rtnl_lock();
        }
 
        set_bit(WL_STATUS_SCAN_ABORTING, &wl->status);
        if (test_bit(WL_STATUS_READY, &wl->status))
-               wl_term_iscan(wl);
+               brcmf_term_iscan(wl);
 
        if (wl->scan_request) {
                /* Indidate scan abort to cfg80211 layer */
@@ -2140,21 +2127,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_set_mpc(ndev, 1);
-               wl_os_wd_timer(ndev, 0);
+               WL_INFO("Enable MPC\n");
+               brcmf_set_mpc(ndev, 1);
        }
 
 #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");
@@ -2163,7 +2144,7 @@ static s32 wl_cfg80211_suspend(struct wiphy *wiphy)
 }
 
 static __used s32
-wl_update_pmklist(struct net_device *dev, struct wl_pmk_list *pmk_list,
+brcmf_update_pmklist(struct net_device *dev, struct wl_pmk_list *pmk_list,
                  s32 err)
 {
        int i, j;
@@ -2177,14 +2158,14 @@ wl_update_pmklist(struct net_device *dev, struct wl_pmk_list *pmk_list,
        }
 
        if (likely(!err))
-               wl_dev_bufvar_set(dev, "pmkid_info", (char *)pmk_list,
+               brcmf_dev_bufvar_set(dev, "pmkid_info", (char *)pmk_list,
                                        sizeof(*pmk_list));
 
        return err;
 }
 
 static s32
-wl_cfg80211_set_pmksa(struct wiphy *wiphy, struct net_device *dev,
+brcmf_cfg80211_set_pmksa(struct wiphy *wiphy, struct net_device *dev,
                      struct cfg80211_pmksa *pmksa)
 {
        struct wl_priv *wl = wiphy_to_wl(wiphy);
@@ -2215,14 +2196,14 @@ wl_cfg80211_set_pmksa(struct wiphy *wiphy, struct net_device *dev,
                       wl->pmk_list->pmkids.pmkid[wl->pmk_list->pmkids.npmkid].
                       PMKID[i]);
 
-       err = wl_update_pmklist(dev, wl->pmk_list, err);
+       err = brcmf_update_pmklist(dev, wl->pmk_list, err);
 
        WL_TRACE("Exit\n");
        return err;
 }
 
 static s32
-wl_cfg80211_del_pmksa(struct wiphy *wiphy, struct net_device *dev,
+brcmf_cfg80211_del_pmksa(struct wiphy *wiphy, struct net_device *dev,
                      struct cfg80211_pmksa *pmksa)
 {
        struct wl_priv *wl = wiphy_to_wl(wiphy);
@@ -2261,7 +2242,7 @@ wl_cfg80211_del_pmksa(struct wiphy *wiphy, struct net_device *dev,
        } else
                err = -EINVAL;
 
-       err = wl_update_pmklist(dev, wl->pmk_list, err);
+       err = brcmf_update_pmklist(dev, wl->pmk_list, err);
 
        WL_TRACE("Exit\n");
        return err;
@@ -2269,7 +2250,7 @@ wl_cfg80211_del_pmksa(struct wiphy *wiphy, struct net_device *dev,
 }
 
 static s32
-wl_cfg80211_flush_pmksa(struct wiphy *wiphy, struct net_device *dev)
+brcmf_cfg80211_flush_pmksa(struct wiphy *wiphy, struct net_device *dev)
 {
        struct wl_priv *wl = wiphy_to_wl(wiphy);
        s32 err = 0;
@@ -2278,7 +2259,7 @@ wl_cfg80211_flush_pmksa(struct wiphy *wiphy, struct net_device *dev)
        CHECK_SYS_UP();
 
        memset(wl->pmk_list, 0, sizeof(*wl->pmk_list));
-       err = wl_update_pmklist(dev, wl->pmk_list, err);
+       err = brcmf_update_pmklist(dev, wl->pmk_list, err);
 
        WL_TRACE("Exit\n");
        return err;
@@ -2286,31 +2267,31 @@ wl_cfg80211_flush_pmksa(struct wiphy *wiphy, struct net_device *dev)
 }
 
 static struct cfg80211_ops wl_cfg80211_ops = {
-       .change_virtual_intf = wl_cfg80211_change_iface,
-       .scan = wl_cfg80211_scan,
-       .set_wiphy_params = wl_cfg80211_set_wiphy_params,
-       .join_ibss = wl_cfg80211_join_ibss,
-       .leave_ibss = wl_cfg80211_leave_ibss,
-       .get_station = wl_cfg80211_get_station,
-       .set_tx_power = wl_cfg80211_set_tx_power,
-       .get_tx_power = wl_cfg80211_get_tx_power,
-       .add_key = wl_cfg80211_add_key,
-       .del_key = wl_cfg80211_del_key,
-       .get_key = wl_cfg80211_get_key,
-       .set_default_key = wl_cfg80211_config_default_key,
-       .set_default_mgmt_key = wl_cfg80211_config_default_mgmt_key,
-       .set_power_mgmt = wl_cfg80211_set_power_mgmt,
-       .set_bitrate_mask = wl_cfg80211_set_bitrate_mask,
-       .connect = wl_cfg80211_connect,
-       .disconnect = wl_cfg80211_disconnect,
-       .suspend = wl_cfg80211_suspend,
-       .resume = wl_cfg80211_resume,
-       .set_pmksa = wl_cfg80211_set_pmksa,
-       .del_pmksa = wl_cfg80211_del_pmksa,
-       .flush_pmksa = wl_cfg80211_flush_pmksa
+       .change_virtual_intf = brcmf_cfg80211_change_iface,
+       .scan = brcmf_cfg80211_scan,
+       .set_wiphy_params = brcmf_cfg80211_set_wiphy_params,
+       .join_ibss = brcmf_cfg80211_join_ibss,
+       .leave_ibss = brcmf_cfg80211_leave_ibss,
+       .get_station = brcmf_cfg80211_get_station,
+       .set_tx_power = brcmf_cfg80211_set_tx_power,
+       .get_tx_power = brcmf_cfg80211_get_tx_power,
+       .add_key = brcmf_cfg80211_add_key,
+       .del_key = brcmf_cfg80211_del_key,
+       .get_key = brcmf_cfg80211_get_key,
+       .set_default_key = brcmf_cfg80211_config_default_key,
+       .set_default_mgmt_key = brcmf_cfg80211_config_default_mgmt_key,
+       .set_power_mgmt = brcmf_cfg80211_set_power_mgmt,
+       .set_bitrate_mask = brcmf_cfg80211_set_bitrate_mask,
+       .connect = brcmf_cfg80211_connect,
+       .disconnect = brcmf_cfg80211_disconnect,
+       .suspend = brcmf_cfg80211_suspend,
+       .resume = brcmf_cfg80211_resume,
+       .set_pmksa = brcmf_cfg80211_set_pmksa,
+       .del_pmksa = brcmf_cfg80211_del_pmksa,
+       .flush_pmksa = brcmf_cfg80211_flush_pmksa
 };
 
-static s32 wl_mode_to_nl80211_iftype(s32 mode)
+static s32 brcmf_mode_to_nl80211_iftype(s32 mode)
 {
        s32 err = 0;
 
@@ -2326,7 +2307,7 @@ static s32 wl_mode_to_nl80211_iftype(s32 mode)
        return err;
 }
 
-static struct wireless_dev *wl_alloc_wdev(s32 sizeof_iface,
+static struct wireless_dev *brcmf_alloc_wdev(s32 sizeof_iface,
                                          struct device *dev)
 {
        struct wireless_dev *wdev;
@@ -2384,7 +2365,7 @@ wiphy_new_out:
        return ERR_PTR(err);
 }
 
-static void wl_free_wdev(struct wl_priv *wl)
+static void brcmf_free_wdev(struct wl_priv *wl)
 {
        struct wireless_dev *wdev = wl_to_wdev(wl);
 
@@ -2398,15 +2379,15 @@ static void wl_free_wdev(struct wl_priv *wl)
        wl_to_wdev(wl) = NULL;
 }
 
-static s32 wl_inform_bss(struct wl_priv *wl)
+static s32 brcmf_inform_bss(struct wl_priv *wl)
 {
-       struct wl_scan_results *bss_list;
-       struct wl_bss_info *bi = NULL;  /* must be initialized */
+       struct brcmf_scan_results *bss_list;
+       struct brcmf_bss_info *bi = NULL;       /* must be initialized */
        s32 err = 0;
        int i;
 
        bss_list = wl->bss_list;
-       if (unlikely(bss_list->version != WL_BSS_INFO_VERSION)) {
+       if (unlikely(bss_list->version != BRCMF_BSS_INFO_VERSION)) {
                WL_ERR("Version %d != WL_BSS_INFO_VERSION\n",
                       bss_list->version);
                return -EOPNOTSUPP;
@@ -2414,7 +2395,7 @@ static s32 wl_inform_bss(struct wl_priv *wl)
        WL_SCAN("scanned AP count (%d)\n", bss_list->count);
        bi = next_bss(bss_list, bi);
        for_each_bss(bss_list, bi, i) {
-               err = wl_inform_single_bss(wl, bi);
+               err = brcmf_inform_single_bss(wl, bi);
                if (unlikely(err))
                        break;
        }
@@ -2422,7 +2403,7 @@ static s32 wl_inform_bss(struct wl_priv *wl)
 }
 
 
-static s32 wl_inform_single_bss(struct wl_priv *wl, struct wl_bss_info *bi)
+static s32 brcmf_inform_single_bss(struct wl_priv *wl, struct brcmf_bss_info *bi)
 {
        struct wiphy *wiphy = wl_to_wiphy(wl);
        struct ieee80211_channel *notify_channel;
@@ -2487,7 +2468,7 @@ wl_inform_ibss(struct wl_priv *wl, struct net_device *dev, const u8 *bssid)
 {
        struct wiphy *wiphy = wl_to_wiphy(wl);
        struct ieee80211_channel *notify_channel;
-       struct wl_bss_info *bi = NULL;
+       struct brcmf_bss_info *bi = NULL;
        struct ieee80211_supported_band *band;
        u8 *buf = NULL;
        s32 err = 0;
@@ -2511,13 +2492,13 @@ 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 = brcmf_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;
        }
 
-       bi = (wl_bss_info_t *)(buf + 4);
+       bi = (struct brcmf_bss_info *)(buf + 4);
 
        channel = bi->ctl_ch ? bi->ctl_ch :
                                CHSPEC_CHANNEL(le16_to_cpu(bi->chanspec));
@@ -2556,12 +2537,12 @@ CleanUp:
        return err;
 }
 
-static bool wl_is_linkup(struct wl_priv *wl, const wl_event_msg_t *e)
+static bool brcmf_is_linkup(struct wl_priv *wl, const struct brcmf_event_msg *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 +2551,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 brcmf_is_linkdown(struct wl_priv *wl, const struct brcmf_event_msg *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 brcmf_is_nonetwork(struct wl_priv *wl, const struct brcmf_event_msg *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;
        }
@@ -2603,88 +2584,90 @@ 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)
+brcmf_notify_connect_status(struct wl_priv *wl, struct net_device *ndev,
+                           const struct brcmf_event_msg *e, void *data)
 {
        s32 err = 0;
 
-       if (wl_is_linkup(wl, e)) {
+       if (brcmf_is_linkup(wl, e)) {
                WL_CONN("Linkup\n");
-               if (wl_is_ibssmode(wl)) {
-                       wl_update_prof(wl, NULL, (void *)e->addr,
+               if (brcmf_is_ibssmode(wl)) {
+                       brcmf_update_prof(wl, NULL, (void *)e->addr,
                                WL_PROF_BSSID);
                        wl_inform_ibss(wl, ndev, e->addr);
                        cfg80211_ibss_joined(ndev, e->addr, GFP_KERNEL);
                        clear_bit(WL_STATUS_CONNECTING, &wl->status);
                        set_bit(WL_STATUS_CONNECTED, &wl->status);
                } else
-                       wl_bss_connect_done(wl, ndev, e, data, true);
-       } else if (wl_is_linkdown(wl, e)) {
+                       brcmf_bss_connect_done(wl, ndev, e, data, true);
+       } else if (brcmf_is_linkdown(wl, e)) {
                WL_CONN("Linkdown\n");
-               if (wl_is_ibssmode(wl)) {
+               if (brcmf_is_ibssmode(wl)) {
+                       clear_bit(WL_STATUS_CONNECTING, &wl->status);
                        if (test_and_clear_bit(WL_STATUS_CONNECTED,
                                &wl->status))
-                               wl_link_down(wl);
+                               brcmf_link_down(wl);
                } else {
+                       brcmf_bss_connect_done(wl, ndev, e, data, false);
                        if (test_and_clear_bit(WL_STATUS_CONNECTED,
                                &wl->status)) {
                                cfg80211_disconnected(ndev, 0, NULL, 0,
                                        GFP_KERNEL);
-                               wl_link_down(wl);
+                               brcmf_link_down(wl);
                        }
                }
-               wl_init_prof(wl->profile);
-       } else if (wl_is_nonetwork(wl, e)) {
-               if (wl_is_ibssmode(wl))
+               brcmf_init_prof(wl->profile);
+       } else if (brcmf_is_nonetwork(wl, e)) {
+               if (brcmf_is_ibssmode(wl))
                        clear_bit(WL_STATUS_CONNECTING, &wl->status);
                else
-                       wl_bss_connect_done(wl, ndev, e, data, false);
+                       brcmf_bss_connect_done(wl, ndev, e, data, false);
        }
 
        return err;
 }
 
 static s32
-wl_notify_roaming_status(struct wl_priv *wl, struct net_device *ndev,
-                        const wl_event_msg_t *e, void *data)
+brcmf_notify_roaming_status(struct wl_priv *wl, struct net_device *ndev,
+                           const struct brcmf_event_msg *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);
+                       brcmf_bss_roaming_done(wl, ndev, e, data);
                else
-                       wl_bss_connect_done(wl, ndev, e, data, true);
+                       brcmf_bss_connect_done(wl, ndev, e, data, true);
        }
 
        return err;
 }
 
 static __used s32
-wl_dev_bufvar_set(struct net_device *dev, s8 *name, s8 *buf, s32 len)
+brcmf_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 brcmf_dev_ioctl(dev, BRCMF_C_SET_VAR, wl->ioctl_buf, buflen);
 }
 
 static s32
-wl_dev_bufvar_get(struct net_device *dev, s8 *name, s8 *buf,
+brcmf_dev_bufvar_get(struct net_device *dev, s8 *name, s8 *buf,
                  s32 buf_len)
 {
        struct wl_priv *wl = ndev_to_wl(dev);
        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 = brcmf_dev_ioctl(dev, BRCMF_C_GET_VAR, (void *)wl->ioctl_buf,
                        WL_IOCTL_LEN_MAX);
        if (unlikely(err)) {
                WL_ERR("error (%d)\n", err);
@@ -2695,7 +2678,7 @@ wl_dev_bufvar_get(struct net_device *dev, s8 *name, s8 *buf,
        return err;
 }
 
-static s32 wl_get_assoc_ies(struct wl_priv *wl)
+static s32 brcmf_get_assoc_ies(struct wl_priv *wl)
 {
        struct net_device *ndev = wl_to_ndev(wl);
        struct wl_assoc_ielen *assoc_info;
@@ -2704,9 +2687,9 @@ static s32 wl_get_assoc_ies(struct wl_priv *wl)
        u32 resp_len;
        s32 err = 0;
 
-       wl_clear_assoc_ies(wl);
+       brcmf_clear_assoc_ies(wl);
 
-       err = wl_dev_bufvar_get(ndev, "assoc_info", wl->extra_buf,
+       err = brcmf_dev_bufvar_get(ndev, "assoc_info", wl->extra_buf,
                                WL_ASSOC_INFO_MAX);
        if (unlikely(err)) {
                WL_ERR("could not get assoc info (%d)\n", err);
@@ -2716,7 +2699,7 @@ static s32 wl_get_assoc_ies(struct wl_priv *wl)
        req_len = assoc_info->req_len;
        resp_len = assoc_info->resp_len;
        if (req_len) {
-               err = wl_dev_bufvar_get(ndev, "assoc_req_ies", wl->extra_buf,
+               err = brcmf_dev_bufvar_get(ndev, "assoc_req_ies", wl->extra_buf,
                                        WL_ASSOC_INFO_MAX);
                if (unlikely(err)) {
                        WL_ERR("could not get assoc req (%d)\n", err);
@@ -2730,7 +2713,7 @@ static s32 wl_get_assoc_ies(struct wl_priv *wl)
                conn_info->req_ie = NULL;
        }
        if (resp_len) {
-               err = wl_dev_bufvar_get(ndev, "assoc_resp_ies", wl->extra_buf,
+               err = brcmf_dev_bufvar_get(ndev, "assoc_resp_ies", wl->extra_buf,
                                        WL_ASSOC_INFO_MAX);
                if (unlikely(err)) {
                        WL_ERR("could not get assoc resp (%d)\n", err);
@@ -2749,7 +2732,7 @@ static s32 wl_get_assoc_ies(struct wl_priv *wl)
        return err;
 }
 
-static void wl_clear_assoc_ies(struct wl_priv *wl)
+static void brcmf_clear_assoc_ies(struct wl_priv *wl)
 {
        struct wl_connect_info *conn_info = wl_to_conn(wl);
 
@@ -2762,7 +2745,7 @@ static void wl_clear_assoc_ies(struct wl_priv *wl)
 }
 
 
-static void wl_ch_to_chanspec(int ch, struct wl_join_params *join_params,
+static void brcmf_ch_to_chanspec(int ch, struct brcmf_join_params *join_params,
        size_t *join_params_size)
 {
        chanspec_t chanspec = 0;
@@ -2779,7 +2762,7 @@ static void wl_ch_to_chanspec(int ch, struct wl_join_params *join_params,
                chanspec |= WL_CHANSPEC_BW_20;
                chanspec |= WL_CHANSPEC_CTL_SB_NONE;
 
-               *join_params_size += WL_ASSOC_PARAMS_FIXED_SIZE +
+               *join_params_size += BRCMF_ASSOC_PARAMS_FIXED_SIZE +
                        join_params->params.chanspec_num * sizeof(chanspec_t);
 
                join_params->params.chanspec_list[0] &= WL_CHANSPEC_CHAN_MASK;
@@ -2796,11 +2779,11 @@ static void wl_ch_to_chanspec(int ch, struct wl_join_params *join_params,
        }
 }
 
-static s32 wl_update_bss_info(struct wl_priv *wl)
+static s32 brcmf_update_bss_info(struct wl_priv *wl)
 {
-       struct wl_bss_info *bi;
-       struct wlc_ssid *ssid;
-       struct bcm_tlv *tim;
+       struct brcmf_bss_info *bi;
+       struct brcmf_ssid *ssid;
+       struct brcmu_tlv *tim;
        u16 beacon_interval;
        u8 dtim_period;
        size_t ie_len;
@@ -2808,21 +2791,21 @@ static s32 wl_update_bss_info(struct wl_priv *wl)
        s32 err = 0;
 
        WL_TRACE("Enter\n");
-       if (wl_is_ibssmode(wl))
+       if (brcmf_is_ibssmode(wl))
                return err;
 
-       ssid = (struct wlc_ssid *)wl_read_prof(wl, WL_PROF_SSID);
+       ssid = (struct brcmf_ssid *)brcmf_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 = brcmf_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);
                goto update_bss_info_out;
        }
 
-       bi = (struct wl_bss_info *)(wl->extra_buf + 4);
-       err = wl_inform_single_bss(wl, bi);
+       bi = (struct brcmf_bss_info *)(wl->extra_buf + 4);
+       err = brcmf_inform_single_bss(wl, bi);
        if (unlikely(err))
                goto update_bss_info_out;
 
@@ -2830,7 +2813,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 {
@@ -2840,7 +2823,7 @@ static s32 wl_update_bss_info(struct wl_priv *wl)
                * so we speficially query dtim information to dongle.
                */
                u32 var;
-               err = wl_dev_intvar_get(wl_to_ndev(wl), "dtim_assoc", &var);
+               err = brcmf_dev_intvar_get(wl_to_ndev(wl), "dtim_assoc", &var);
                if (unlikely(err)) {
                        WL_ERR("wl dtim_assoc failed (%d)\n", err);
                        goto update_bss_info_out;
@@ -2848,8 +2831,8 @@ static s32 wl_update_bss_info(struct wl_priv *wl)
                dtim_period = (u8)var;
        }
 
-       wl_update_prof(wl, NULL, &beacon_interval, WL_PROF_BEACONINT);
-       wl_update_prof(wl, NULL, &dtim_period, WL_PROF_DTIMPERIOD);
+       brcmf_update_prof(wl, NULL, &beacon_interval, WL_PROF_BEACONINT);
+       brcmf_update_prof(wl, NULL, &dtim_period, WL_PROF_DTIMPERIOD);
 
 update_bss_info_out:
        WL_TRACE("Exit");
@@ -2857,20 +2840,20 @@ 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)
+brcmf_bss_roaming_done(struct wl_priv *wl, struct net_device *ndev,
+                      const struct brcmf_event_msg *e, void *data)
 {
        struct wl_connect_info *conn_info = wl_to_conn(wl);
        s32 err = 0;
 
        WL_TRACE("Enter\n");
 
-       wl_get_assoc_ies(wl);
-       wl_update_prof(wl, NULL, &e->addr, WL_PROF_BSSID);
-       wl_update_bss_info(wl);
+       brcmf_get_assoc_ies(wl);
+       brcmf_update_prof(wl, NULL, &e->addr, WL_PROF_BSSID);
+       brcmf_update_bss_info(wl);
 
        cfg80211_roamed(ndev, NULL,
-                       (u8 *)wl_read_prof(wl, WL_PROF_BSSID),
+                       (u8 *)brcmf_read_prof(wl, WL_PROF_BSSID),
                        conn_info->req_ie, conn_info->req_ie_len,
                        conn_info->resp_ie, conn_info->resp_ie_len, GFP_KERNEL);
        WL_CONN("Report roaming result\n");
@@ -2881,8 +2864,8 @@ 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)
+brcmf_bss_connect_done(struct wl_priv *wl, struct net_device *ndev,
+                      const struct brcmf_event_msg *e, void *data, bool completed)
 {
        struct wl_connect_info *conn_info = wl_to_conn(wl);
        s32 err = 0;
@@ -2891,12 +2874,12 @@ wl_bss_connect_done(struct wl_priv *wl, struct net_device *ndev,
 
        if (test_and_clear_bit(WL_STATUS_CONNECTING, &wl->status)) {
                if (completed) {
-                       wl_get_assoc_ies(wl);
-                       wl_update_prof(wl, NULL, &e->addr, WL_PROF_BSSID);
-                       wl_update_bss_info(wl);
+                       brcmf_get_assoc_ies(wl);
+                       brcmf_update_prof(wl, NULL, &e->addr, WL_PROF_BSSID);
+                       brcmf_update_bss_info(wl);
                }
                cfg80211_connect_result(ndev,
-                                       (u8 *)wl_read_prof(wl, WL_PROF_BSSID),
+                                       (u8 *)brcmf_read_prof(wl, WL_PROF_BSSID),
                                        conn_info->req_ie,
                                        conn_info->req_ie_len,
                                        conn_info->resp_ie,
@@ -2913,14 +2896,14 @@ 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)
+brcmf_notify_mic_status(struct wl_priv *wl, struct net_device *ndev,
+                       const struct brcmf_event_msg *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;
@@ -2933,11 +2916,11 @@ 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)
+brcmf_notify_scan_status(struct wl_priv *wl, struct net_device *ndev,
+                        const struct brcmf_event_msg *e, void *data)
 {
-       struct channel_info channel_inform;
-       struct wl_scan_results *bss_list;
+       struct brcmf_channel_info channel_inform;
+       struct brcmf_scan_results *bss_list;
        u32 len = WL_SCAN_BUF_MAX;
        s32 err = 0;
        bool scan_abort = false;
@@ -2946,7 +2929,7 @@ wl_notify_scan_status(struct wl_priv *wl, struct net_device *ndev,
 
        if (wl->iscan_on && wl->iscan_kickstart) {
                WL_TRACE("Exit\n");
-               return wl_wakeup_iscan(wl_to_iscan(wl));
+               return brcmf_wakeup_iscan(wl_to_iscan(wl));
        }
 
        if (unlikely(!test_and_clear_bit(WL_STATUS_SCANNING, &wl->status))) {
@@ -2956,7 +2939,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 = brcmf_dev_ioctl(ndev, BRCMF_C_GET_CHANNEL, &channel_inform,
                        sizeof(channel_inform));
        if (unlikely(err)) {
                WL_ERR("scan busy (%d)\n", err);
@@ -2974,7 +2957,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 = brcmf_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;
@@ -2985,7 +2968,7 @@ wl_notify_scan_status(struct wl_priv *wl, struct net_device *ndev,
        bss_list->version = le32_to_cpu(bss_list->version);
        bss_list->count = le32_to_cpu(bss_list->count);
 
-       err = wl_inform_bss(wl);
+       err = brcmf_inform_bss(wl);
        if (err) {
                scan_abort = true;
                goto scan_done_out;
@@ -2995,7 +2978,7 @@ scan_done_out:
        if (wl->scan_request) {
                WL_SCAN("calling cfg80211_scan_done\n");
                cfg80211_scan_done(wl->scan_request, scan_abort);
-               wl_set_mpc(ndev, 1);
+               brcmf_set_mpc(ndev, 1);
                wl->scan_request = NULL;
        }
 
@@ -3004,7 +2987,7 @@ scan_done_out:
        return err;
 }
 
-static void wl_init_conf(struct wl_conf *conf)
+static void brcmf_init_conf(struct wl_conf *conf)
 {
        conf->mode = (u32)-1;
        conf->frag_threshold = (u32)-1;
@@ -3014,22 +2997,22 @@ static void wl_init_conf(struct wl_conf *conf)
        conf->tx_power = -1;
 }
 
-static void wl_init_prof(struct wl_profile *prof)
+static void brcmf_init_prof(struct wl_profile *prof)
 {
        memset(prof, 0, sizeof(*prof));
 }
 
-static void wl_init_eloop_handler(struct wl_event_loop *el)
+static void brcmf_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] = brcmf_notify_scan_status;
+       el->handler[BRCMF_E_LINK] = brcmf_notify_connect_status;
+       el->handler[BRCMF_E_ROAM] = brcmf_notify_roaming_status;
+       el->handler[BRCMF_E_MIC_ERROR] = brcmf_notify_mic_status;
+       el->handler[BRCMF_E_SET_SSID] = brcmf_notify_connect_status;
 }
 
-static s32 wl_init_priv_mem(struct wl_priv *wl)
+static s32 brcmf_init_priv_mem(struct wl_priv *wl)
 {
        wl->scan_results = kzalloc(WL_SCAN_BUF_MAX, GFP_KERNEL);
        if (unlikely(!wl->scan_results)) {
@@ -3071,11 +3054,6 @@ static s32 wl_init_priv_mem(struct wl_priv *wl)
                WL_ERR("Iscan buf alloc failed\n");
                goto init_priv_mem_out;
        }
-       wl->fw = kzalloc(sizeof(*wl->fw), GFP_KERNEL);
-       if (unlikely(!wl->fw)) {
-               WL_ERR("fw object alloc failed\n");
-               goto init_priv_mem_out;
-       }
        wl->pmk_list = kzalloc(sizeof(*wl->pmk_list), GFP_KERNEL);
        if (unlikely(!wl->pmk_list)) {
                WL_ERR("pmk list alloc failed\n");
@@ -3085,12 +3063,12 @@ static s32 wl_init_priv_mem(struct wl_priv *wl)
        return 0;
 
 init_priv_mem_out:
-       wl_deinit_priv_mem(wl);
+       brcmf_deinit_priv_mem(wl);
 
        return -ENOMEM;
 }
 
-static void wl_deinit_priv_mem(struct wl_priv *wl)
+static void brcmf_deinit_priv_mem(struct wl_priv *wl)
 {
        kfree(wl->scan_results);
        wl->scan_results = NULL;
@@ -3108,16 +3086,14 @@ static void wl_deinit_priv_mem(struct wl_priv *wl)
        wl->extra_buf = NULL;
        kfree(wl->iscan);
        wl->iscan = NULL;
-       kfree(wl->fw);
-       wl->fw = NULL;
        kfree(wl->pmk_list);
        wl->pmk_list = NULL;
 }
 
-static s32 wl_create_event_handler(struct wl_priv *wl)
+static s32 brcmf_create_event_handler(struct wl_priv *wl)
 {
        sema_init(&wl->event_sync, 0);
-       wl->event_tsk = kthread_run(wl_event_handler, wl, "wl_event_handler");
+       wl->event_tsk = kthread_run(brcmf_event_handler, wl, "wl_event_handler");
        if (IS_ERR(wl->event_tsk)) {
                wl->event_tsk = NULL;
                WL_ERR("failed to create event thread\n");
@@ -3126,7 +3102,7 @@ static s32 wl_create_event_handler(struct wl_priv *wl)
        return 0;
 }
 
-static void wl_destroy_event_handler(struct wl_priv *wl)
+static void brcmf_destroy_event_handler(struct wl_priv *wl)
 {
        if (wl->event_tsk) {
                send_sig(SIGTERM, wl->event_tsk, 1);
@@ -3135,7 +3111,7 @@ static void wl_destroy_event_handler(struct wl_priv *wl)
        }
 }
 
-static void wl_term_iscan(struct wl_priv *wl)
+static void brcmf_term_iscan(struct wl_priv *wl)
 {
        struct wl_iscan_ctrl *iscan = wl_to_iscan(wl);
 
@@ -3147,7 +3123,7 @@ static void wl_term_iscan(struct wl_priv *wl)
        }
 }
 
-static void wl_notify_iscan_complete(struct wl_iscan_ctrl *iscan, bool aborted)
+static void brcmf_notify_iscan_complete(struct wl_iscan_ctrl *iscan, bool aborted)
 {
        struct wl_priv *wl = iscan_to_wl(iscan);
        struct net_device *ndev = wl_to_ndev(wl);
@@ -3160,13 +3136,13 @@ static void wl_notify_iscan_complete(struct wl_iscan_ctrl *iscan, bool aborted)
                WL_SCAN("ISCAN Completed scan: %s\n",
                                aborted ? "Aborted" : "Done");
                cfg80211_scan_done(wl->scan_request, aborted);
-               wl_set_mpc(ndev, 1);
+               brcmf_set_mpc(ndev, 1);
                wl->scan_request = NULL;
        }
        wl->iscan_kickstart = false;
 }
 
-static s32 wl_wakeup_iscan(struct wl_iscan_ctrl *iscan)
+static s32 brcmf_wakeup_iscan(struct wl_iscan_ctrl *iscan)
 {
        if (likely(iscan->state != WL_ISCAN_STATE_IDLE)) {
                WL_SCAN("wake up iscan\n");
@@ -3178,25 +3154,25 @@ static s32 wl_wakeup_iscan(struct wl_iscan_ctrl *iscan)
 }
 
 static s32
-wl_get_iscan_results(struct wl_iscan_ctrl *iscan, u32 *status,
-                    struct wl_scan_results **bss_list)
+brcmf_get_iscan_results(struct wl_iscan_ctrl *iscan, u32 *status,
+                    struct brcmf_scan_results **bss_list)
 {
-       struct wl_iscan_results list;
-       struct wl_scan_results *results;
-       struct wl_iscan_results *list_buf;
+       struct brcmf_iscan_results list;
+       struct brcmf_scan_results *results;
+       struct brcmf_iscan_results *list_buf;
        s32 err = 0;
 
        memset(iscan->scan_buf, 0, WL_ISCAN_BUF_MAX);
-       list_buf = (struct wl_iscan_results *)iscan->scan_buf;
+       list_buf = (struct brcmf_iscan_results *)iscan->scan_buf;
        results = &list_buf->results;
-       results->buflen = WL_ISCAN_RESULTS_FIXED_SIZE;
+       results->buflen = BRCMF_ISCAN_RESULTS_FIXED_SIZE;
        results->version = 0;
        results->count = 0;
 
        memset(&list, 0, sizeof(list));
        list.results.buflen = cpu_to_le32(WL_ISCAN_BUF_MAX);
-       err = wl_dev_iovar_getbuf(iscan->dev, "iscanresults", &list,
-                               WL_ISCAN_RESULTS_FIXED_SIZE, iscan->scan_buf,
+       err = brcmf_dev_iovar_getbuf(iscan->dev, "iscanresults", &list,
+                               BRCMF_ISCAN_RESULTS_FIXED_SIZE, iscan->scan_buf,
                                WL_ISCAN_BUF_MAX);
        if (unlikely(err)) {
                WL_ERR("error (%d)\n", err);
@@ -3213,21 +3189,21 @@ wl_get_iscan_results(struct wl_iscan_ctrl *iscan, u32 *status,
        return err;
 }
 
-static s32 wl_iscan_done(struct wl_priv *wl)
+static s32 brcmf_iscan_done(struct wl_priv *wl)
 {
        struct wl_iscan_ctrl *iscan = wl->iscan;
        s32 err = 0;
 
        iscan->state = WL_ISCAN_STATE_IDLE;
        rtnl_lock();
-       wl_inform_bss(wl);
-       wl_notify_iscan_complete(iscan, false);
+       brcmf_inform_bss(wl);
+       brcmf_notify_iscan_complete(iscan, false);
        rtnl_unlock();
 
        return err;
 }
 
-static s32 wl_iscan_pending(struct wl_priv *wl)
+static s32 brcmf_iscan_pending(struct wl_priv *wl)
 {
        struct wl_iscan_ctrl *iscan = wl->iscan;
        s32 err = 0;
@@ -3239,14 +3215,14 @@ static s32 wl_iscan_pending(struct wl_priv *wl)
        return err;
 }
 
-static s32 wl_iscan_inprogress(struct wl_priv *wl)
+static s32 brcmf_iscan_inprogress(struct wl_priv *wl)
 {
        struct wl_iscan_ctrl *iscan = wl->iscan;
        s32 err = 0;
 
        rtnl_lock();
-       wl_inform_bss(wl);
-       wl_run_iscan(iscan, NULL, WL_SCAN_ACTION_CONTINUE);
+       brcmf_inform_bss(wl);
+       brcmf_run_iscan(iscan, NULL, BRCMF_SCAN_ACTION_CONTINUE);
        rtnl_unlock();
        /* Reschedule the timer */
        mod_timer(&iscan->timer, jiffies + iscan->timer_ms * HZ / 1000);
@@ -3255,20 +3231,20 @@ static s32 wl_iscan_inprogress(struct wl_priv *wl)
        return err;
 }
 
-static s32 wl_iscan_aborted(struct wl_priv *wl)
+static s32 brcmf_iscan_aborted(struct wl_priv *wl)
 {
        struct wl_iscan_ctrl *iscan = wl->iscan;
        s32 err = 0;
 
        iscan->state = WL_ISCAN_STATE_IDLE;
        rtnl_lock();
-       wl_notify_iscan_complete(iscan, true);
+       brcmf_notify_iscan_complete(iscan, true);
        rtnl_unlock();
 
        return err;
 }
 
-static s32 wl_iscan_thread(void *data)
+static s32 brcmf_iscan_thread(void *data)
 {
        struct sched_param param = {.sched_priority = MAX_RT_PRIO - 1 };
        struct wl_iscan_ctrl *iscan = (struct wl_iscan_ctrl *)data;
@@ -3279,7 +3255,7 @@ static s32 wl_iscan_thread(void *data)
 
        sched_setscheduler(current, SCHED_FIFO, &param);
        allow_signal(SIGTERM);
-       status = WL_SCAN_RESULTS_PARTIAL;
+       status = BRCMF_SCAN_RESULTS_PARTIAL;
        while (likely(!down_interruptible(&iscan->sync))) {
                if (kthread_should_stop())
                        break;
@@ -3288,9 +3264,9 @@ static s32 wl_iscan_thread(void *data)
                        iscan->timer_on = 0;
                }
                rtnl_lock();
-               err = wl_get_iscan_results(iscan, &status, &wl->bss_list);
+               err = brcmf_get_iscan_results(iscan, &status, &wl->bss_list);
                if (unlikely(err)) {
-                       status = WL_SCAN_RESULTS_ABORTED;
+                       status = BRCMF_SCAN_RESULTS_ABORTED;
                        WL_ERR("Abort iscan\n");
                }
                rtnl_unlock();
@@ -3305,18 +3281,18 @@ static s32 wl_iscan_thread(void *data)
        return 0;
 }
 
-static void wl_iscan_timer(unsigned long data)
+static void brcmf_iscan_timer(unsigned long data)
 {
        struct wl_iscan_ctrl *iscan = (struct wl_iscan_ctrl *)data;
 
        if (iscan) {
                iscan->timer_on = 0;
                WL_SCAN("timer expired\n");
-               wl_wakeup_iscan(iscan);
+               brcmf_wakeup_iscan(iscan);
        }
 }
 
-static s32 wl_invoke_iscan(struct wl_priv *wl)
+static s32 brcmf_invoke_iscan(struct wl_priv *wl)
 {
        struct wl_iscan_ctrl *iscan = wl_to_iscan(wl);
        int err = 0;
@@ -3324,7 +3300,7 @@ static s32 wl_invoke_iscan(struct wl_priv *wl)
        if (wl->iscan_on && !iscan->tsk) {
                iscan->state = WL_ISCAN_STATE_IDLE;
                sema_init(&iscan->sync, 0);
-               iscan->tsk = kthread_run(wl_iscan_thread, iscan, "wl_iscan");
+               iscan->tsk = kthread_run(brcmf_iscan_thread, iscan, "wl_iscan");
                if (IS_ERR(iscan->tsk)) {
                        WL_ERR("Could not create iscan thread\n");
                        iscan->tsk = NULL;
@@ -3335,17 +3311,17 @@ static s32 wl_invoke_iscan(struct wl_priv *wl)
        return err;
 }
 
-static void wl_init_iscan_eloop(struct wl_iscan_eloop *el)
+static void brcmf_init_iscan_eloop(struct wl_iscan_eloop *el)
 {
        memset(el, 0, sizeof(*el));
-       el->handler[WL_SCAN_RESULTS_SUCCESS] = wl_iscan_done;
-       el->handler[WL_SCAN_RESULTS_PARTIAL] = wl_iscan_inprogress;
-       el->handler[WL_SCAN_RESULTS_PENDING] = wl_iscan_pending;
-       el->handler[WL_SCAN_RESULTS_ABORTED] = wl_iscan_aborted;
-       el->handler[WL_SCAN_RESULTS_NO_MEM] = wl_iscan_aborted;
+       el->handler[BRCMF_SCAN_RESULTS_SUCCESS] = brcmf_iscan_done;
+       el->handler[BRCMF_SCAN_RESULTS_PARTIAL] = brcmf_iscan_inprogress;
+       el->handler[BRCMF_SCAN_RESULTS_PENDING] = brcmf_iscan_pending;
+       el->handler[BRCMF_SCAN_RESULTS_ABORTED] = brcmf_iscan_aborted;
+       el->handler[BRCMF_SCAN_RESULTS_NO_MEM] = brcmf_iscan_aborted;
 }
 
-static s32 wl_init_iscan(struct wl_priv *wl)
+static s32 brcmf_init_iscan(struct wl_priv *wl)
 {
        struct wl_iscan_ctrl *iscan = wl_to_iscan(wl);
        int err = 0;
@@ -3353,13 +3329,13 @@ static s32 wl_init_iscan(struct wl_priv *wl)
        if (wl->iscan_on) {
                iscan->dev = wl_to_ndev(wl);
                iscan->state = WL_ISCAN_STATE_IDLE;
-               wl_init_iscan_eloop(&iscan->el);
+               brcmf_init_iscan_eloop(&iscan->el);
                iscan->timer_ms = WL_ISCAN_TIMER_INTERVAL_MS;
                init_timer(&iscan->timer);
                iscan->timer.data = (unsigned long) iscan;
-               iscan->timer.function = wl_iscan_timer;
+               iscan->timer.function = brcmf_iscan_timer;
                sema_init(&iscan->sync, 0);
-               iscan->tsk = kthread_run(wl_iscan_thread, iscan, "wl_iscan");
+               iscan->tsk = kthread_run(brcmf_iscan_thread, iscan, "wl_iscan");
                if (IS_ERR(iscan->tsk)) {
                        WL_ERR("Could not create iscan thread\n");
                        iscan->tsk = NULL;
@@ -3371,12 +3347,6 @@ static s32 wl_init_iscan(struct wl_priv *wl)
        return err;
 }
 
-static void wl_init_fw(struct wl_fw_ctrl *fw)
-{
-       fw->status = 0;         /* init fw loading status.
-                                0 means nothing was loaded yet */
-}
-
 static s32 wl_init_priv(struct wl_priv *wl)
 {
        struct wiphy *wiphy = wl_to_wiphy(wl);
@@ -3393,33 +3363,32 @@ static s32 wl_init_priv(struct wl_priv *wl)
        wl->active_scan = true; /* we do active scan for
                                 specific scan per default */
        wl->dongle_up = false;  /* dongle is not up yet */
-       wl_init_eq(wl);
-       err = wl_init_priv_mem(wl);
+       brcmf_init_eq(wl);
+       err = brcmf_init_priv_mem(wl);
        if (unlikely(err))
                return err;
-       if (unlikely(wl_create_event_handler(wl)))
+       if (unlikely(brcmf_create_event_handler(wl)))
                return -ENOMEM;
-       wl_init_eloop_handler(&wl->el);
+       brcmf_init_eloop_handler(&wl->el);
        mutex_init(&wl->usr_sync);
-       err = wl_init_iscan(wl);
+       err = brcmf_init_iscan(wl);
        if (unlikely(err))
                return err;
-       wl_init_fw(wl->fw);
-       wl_init_conf(wl->conf);
-       wl_init_prof(wl->profile);
-       wl_link_down(wl);
+       brcmf_init_conf(wl->conf);
+       brcmf_init_prof(wl->profile);
+       brcmf_link_down(wl);
 
        return err;
 }
 
 static void wl_deinit_priv(struct wl_priv *wl)
 {
-       wl_destroy_event_handler(wl);
+       brcmf_destroy_event_handler(wl);
        wl->dongle_up = false;  /* dongle down */
-       wl_flush_eq(wl);
-       wl_link_down(wl);
-       wl_term_iscan(wl);
-       wl_deinit_priv_mem(wl);
+       brcmf_flush_eq(wl);
+       brcmf_link_down(wl);
+       brcmf_term_iscan(wl);
+       brcmf_deinit_priv_mem(wl);
 }
 
 s32 wl_cfg80211_attach(struct net_device *ndev, void *data)
@@ -3439,11 +3408,11 @@ s32 wl_cfg80211_attach(struct net_device *ndev, void *data)
                return -ENOMEM;
        }
        WL_INFO("func %p\n", wl_cfg80211_get_sdio_func());
-       wdev = wl_alloc_wdev(sizeof(struct wl_iface), &wl_cfg80211_get_sdio_func()->dev);
+       wdev = brcmf_alloc_wdev(sizeof(struct wl_iface), &wl_cfg80211_get_sdio_func()->dev);
        if (IS_ERR(wdev))
                return -ENOMEM;
 
-       wdev->iftype = wl_mode_to_nl80211_iftype(WL_MODE_BSS);
+       wdev->iftype = brcmf_mode_to_nl80211_iftype(WL_MODE_BSS);
        wl = wdev_to_wl(wdev);
        wl->wdev = wdev;
        wl->pub = data;
@@ -3457,12 +3426,12 @@ s32 wl_cfg80211_attach(struct net_device *ndev, void *data)
                WL_ERR("Failed to init iwm_priv (%d)\n", err);
                goto cfg80211_attach_out;
        }
-       wl_set_drvdata(wl_cfg80211_dev, ci);
+       brcmf_set_drvdata(wl_cfg80211_dev, ci);
 
        return err;
 
 cfg80211_attach_out:
-       wl_free_wdev(wl);
+       brcmf_free_wdev(wl);
        return err;
 }
 
@@ -3473,19 +3442,19 @@ void wl_cfg80211_detach(void)
        wl = WL_PRIV_GET();
 
        wl_deinit_priv(wl);
-       wl_free_wdev(wl);
-       wl_set_drvdata(wl_cfg80211_dev, NULL);
+       brcmf_free_wdev(wl);
+       brcmf_set_drvdata(wl_cfg80211_dev, NULL);
        kfree(wl_cfg80211_dev);
        wl_cfg80211_dev = NULL;
-       wl_clear_sdio_func();
+       brcmf_clear_sdio_func();
 }
 
-static void wl_wakeup_event(struct wl_priv *wl)
+static void brcmf_wakeup_event(struct wl_priv *wl)
 {
        up(&wl->event_sync);
 }
 
-static s32 wl_event_handler(void *data)
+static s32 brcmf_event_handler(void *data)
 {
        struct wl_priv *wl = (struct wl_priv *)data;
        struct sched_param param = {.sched_priority = MAX_RT_PRIO - 1 };
@@ -3496,7 +3465,7 @@ static s32 wl_event_handler(void *data)
        while (likely(!down_interruptible(&wl->event_sync))) {
                if (kthread_should_stop())
                        break;
-               e = wl_deq_event(wl);
+               e = brcmf_deq_event(wl);
                if (unlikely(!e)) {
                        WL_ERR("event queue empty...\n");
                        BUG();
@@ -3508,55 +3477,56 @@ static s32 wl_event_handler(void *data)
                } else {
                        WL_INFO("Unknown Event (%d): ignoring\n", e->etype);
                }
-               wl_put_event(e);
+               brcmf_put_event(e);
        }
        WL_INFO("was terminated\n");
        return 0;
 }
 
 void
-wl_cfg80211_event(struct net_device *ndev, const wl_event_msg_t * e, void *data)
+wl_cfg80211_event(struct net_device *ndev,
+                 const struct brcmf_event_msg *e, void *data)
 {
        u32 event_type = be32_to_cpu(e->event_type);
        struct wl_priv *wl = ndev_to_wl(ndev);
 
-       if (likely(!wl_enq_event(wl, event_type, e, data)))
-               wl_wakeup_event(wl);
+       if (likely(!brcmf_enq_event(wl, event_type, e, data)))
+               brcmf_wakeup_event(wl);
 }
 
-static void wl_init_eq(struct wl_priv *wl)
+static void brcmf_init_eq(struct wl_priv *wl)
 {
-       wl_init_eq_lock(wl);
+       brcmf_init_eq_lock(wl);
        INIT_LIST_HEAD(&wl->eq_list);
 }
 
-static void wl_flush_eq(struct wl_priv *wl)
+static void brcmf_flush_eq(struct wl_priv *wl)
 {
        struct wl_event_q *e;
 
-       wl_lock_eq(wl);
+       brcmf_lock_eq(wl);
        while (!list_empty(&wl->eq_list)) {
                e = list_first_entry(&wl->eq_list, struct wl_event_q, eq_list);
                list_del(&e->eq_list);
                kfree(e);
        }
-       wl_unlock_eq(wl);
+       brcmf_unlock_eq(wl);
 }
 
 /*
 * retrieve first queued event from head
 */
 
-static struct wl_event_q *wl_deq_event(struct wl_priv *wl)
+static struct wl_event_q *brcmf_deq_event(struct wl_priv *wl)
 {
        struct wl_event_q *e = NULL;
 
-       wl_lock_eq(wl);
+       brcmf_lock_eq(wl);
        if (likely(!list_empty(&wl->eq_list))) {
                e = list_first_entry(&wl->eq_list, struct wl_event_q, eq_list);
                list_del(&e->eq_list);
        }
-       wl_unlock_eq(wl);
+       brcmf_unlock_eq(wl);
 
        return e;
 }
@@ -3566,8 +3536,8 @@ 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,
-            void *data)
+brcmf_enq_event(struct wl_priv *wl, u32 event, const struct brcmf_event_msg *msg,
+               void *data)
 {
        struct wl_event_q *e;
        s32 err = 0;
@@ -3579,17 +3549,17 @@ 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(struct brcmf_event_msg));
        if (data) {
        }
-       wl_lock_eq(wl);
+       brcmf_lock_eq(wl);
        list_add_tail(&e->eq_list, &wl->eq_list);
-       wl_unlock_eq(wl);
+       brcmf_unlock_eq(wl);
 
        return err;
 }
 
-static void wl_put_event(struct wl_event_q *e)
+static void brcmf_put_event(struct wl_event_q *e)
 {
        kfree(e);
 }
@@ -3599,7 +3569,7 @@ void wl_cfg80211_sdio_func(void *func)
        cfg80211_sdio_func = (struct sdio_func *)func;
 }
 
-static void wl_clear_sdio_func(void)
+static void brcmf_clear_sdio_func(void)
 {
        cfg80211_sdio_func = NULL;
 }
@@ -3609,7 +3579,7 @@ struct sdio_func *wl_cfg80211_get_sdio_func(void)
        return cfg80211_sdio_func;
 }
 
-static s32 wl_dongle_mode(struct net_device *ndev, s32 iftype)
+static s32 brcmf_dongle_mode(struct net_device *ndev, s32 iftype)
 {
        s32 infra = 0;
        s32 err = 0;
@@ -3633,7 +3603,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 = brcmf_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,253 +3612,48 @@ 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)
+static s32 brcmf_dongle_eventmsg(struct net_device *ndev)
 {
-       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" +
-                                                '\0' + bitvec  */
-       s8 eventmask[WL_EVENTING_MASK_LEN];
+       /* Room for "event_msgs" + '\0' + bitvec */
+       s8 iovbuf[BRCMF_EVENTING_MASK_LEN + 12];
+       s8 eventmask[BRCMF_EVENTING_MASK_LEN];
        s32 err = 0;
 
        WL_TRACE("Enter\n");
 
        /* Setup event_msgs */
-       bcm_mkiovar("event_msgs", eventmask, WL_EVENTING_MASK_LEN, iovbuf,
+       brcmu_mkiovar("event_msgs", eventmask, BRCMF_EVENTING_MASK_LEN, iovbuf,
                    sizeof(iovbuf));
-       err = wl_dev_ioctl(ndev, WLC_GET_VAR, iovbuf, sizeof(iovbuf));
+       err = brcmf_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,
+       memcpy(eventmask, iovbuf, BRCMF_EVENTING_MASK_LEN);
+
+       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, BRCMF_EVENTING_MASK_LEN, iovbuf,
                    sizeof(iovbuf));
-       err = wl_dev_ioctl(ndev, WLC_SET_VAR, iovbuf, sizeof(iovbuf));
+       err = brcmf_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;
@@ -3900,7 +3665,7 @@ dongle_eventmsg_out:
 }
 
 static s32
-wl_dongle_roam(struct net_device *ndev, u32 roamvar, u32 bcn_timeout)
+brcmf_dongle_roam(struct net_device *ndev, u32 roamvar, u32 bcn_timeout)
 {
        s8 iovbuf[32];
        s32 roamtrigger[2];
@@ -3912,9 +3677,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 = brcmf_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 +3692,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 = brcmf_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 +3702,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 = brcmf_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 +3711,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 = brcmf_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);
@@ -3957,13 +3723,13 @@ dongle_rom_out:
 }
 
 static s32
-wl_dongle_scantime(struct net_device *ndev, s32 scan_assoc_time,
+brcmf_dongle_scantime(struct net_device *ndev, s32 scan_assoc_time,
                s32 scan_unassoc_time, s32 scan_passive_time)
 {
        s32 err = 0;
 
-       err = wl_dev_ioctl(ndev, WLC_SET_SCAN_CHANNEL_TIME, &scan_assoc_time,
-                       sizeof(scan_assoc_time));
+       err = brcmf_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 +3737,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 = brcmf_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 +3747,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 = brcmf_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");
@@ -3995,11 +3761,8 @@ dongle_scantime_out:
        return err;
 }
 
-s32 wl_config_dongle(struct wl_priv *wl, bool need_lock)
+s32 brcmf_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,37 +3775,19 @@ 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,
+       brcmf_dongle_scantime(ndev, WL_SCAN_CHANNEL_TIME,
                        WL_SCAN_UNASSOC_TIME, WL_SCAN_PASSIVE_TIME);
 
-       err = wl_dongle_eventmsg(ndev);
+       err = brcmf_dongle_eventmsg(ndev);
        if (unlikely(err))
                goto default_conf_out;
-       err = wl_dongle_roam(ndev, (wl->roam_on ? 0 : 1), WL_BEACON_TIMEOUT);
+       err = brcmf_dongle_roam(ndev, (wl->roam_on ? 0 : 1), WL_BEACON_TIMEOUT);
        if (unlikely(err))
                goto default_conf_out;
-       err = wl_dongle_mode(ndev, wdev->iftype);
+       err = brcmf_dongle_mode(ndev, wdev->iftype);
        if (unlikely(err && err != -EINPROGRESS))
                goto default_conf_out;
-       err = wl_dongle_probecap(wl);
+       err = brcmf_dongle_probecap(wl);
        if (unlikely(err))
                goto default_conf_out;
 
@@ -4065,7 +3810,7 @@ static s32 wl_update_wiphybands(struct wl_priv *wl)
        s8 phy;
        s32 err = 0;
 
-       err = wl_dev_ioctl(wl_to_ndev(wl), WLC_GET_PHYLIST, &phy_list,
+       err = brcmf_dev_ioctl(wl_to_ndev(wl), WLC_GET_PHYLIST, &phy_list,
                        sizeof(phy_list));
        if (unlikely(err)) {
                WL_ERR("error (%d)\n", err);
@@ -4082,27 +3827,46 @@ static s32 wl_update_wiphybands(struct wl_priv *wl)
        return err;
 }
 
-static s32 __wl_cfg80211_up(struct wl_priv *wl)
+static s32 __brcmf_cfg80211_up(struct wl_priv *wl)
 {
        s32 err = 0;
 
        set_bit(WL_STATUS_READY, &wl->status);
 
-       wl_debugfs_add_netdev_params(wl);
+       brcmf_debugfs_add_netdev_params(wl);
 
-       err = wl_config_dongle(wl, false);
+       err = brcmf_config_dongle(wl, false);
        if (unlikely(err))
                return err;
 
-       wl_invoke_iscan(wl);
+       brcmf_invoke_iscan(wl);
 
        return err;
 }
 
-static s32 __wl_cfg80211_down(struct wl_priv *wl)
+static s32 __brcmf_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");
+               brcmf_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();
+               brcmf_delay(500);
+               rtnl_lock();
+       }
+
        set_bit(WL_STATUS_SCAN_ABORTING, &wl->status);
-       wl_term_iscan(wl);
+       brcmf_term_iscan(wl);
        if (wl->scan_request) {
                cfg80211_scan_done(wl->scan_request, true);
                /* May need to perform this to cover rmmod */
@@ -4112,10 +3876,8 @@ 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);
+       brcmf_debugfs_remove_netdev(wl);
 
        return 0;
 }
@@ -4127,7 +3889,7 @@ s32 wl_cfg80211_up(void)
 
        wl = WL_PRIV_GET();
        mutex_lock(&wl->usr_sync);
-       err = __wl_cfg80211_up(wl);
+       err = __brcmf_cfg80211_up(wl);
        mutex_unlock(&wl->usr_sync);
 
        return err;
@@ -4140,24 +3902,18 @@ s32 wl_cfg80211_down(void)
 
        wl = WL_PRIV_GET();
        mutex_lock(&wl->usr_sync);
-       err = __wl_cfg80211_down(wl);
+       err = __brcmf_cfg80211_down(wl);
        mutex_unlock(&wl->usr_sync);
 
        return err;
 }
 
-static s32 wl_dongle_probecap(struct wl_priv *wl)
+static s32 brcmf_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)
+static void *brcmf_read_prof(struct wl_priv *wl, s32 item)
 {
        switch (item) {
        case WL_PROF_SEC:
@@ -4172,15 +3928,15 @@ 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,
-              s32 item)
+brcmf_update_prof(struct wl_priv *wl, const struct brcmf_event_msg *e, void *data,
+                 s32 item)
 {
        s32 err = 0;
-       struct wlc_ssid *ssid;
+       struct brcmf_ssid *ssid;
 
        switch (item) {
        case WL_PROF_SSID:
-               ssid = (wlc_ssid_t *) data;
+               ssid = (struct brcmf_ssid *) data;
                memset(wl->profile->ssid.SSID, 0,
                       sizeof(wl->profile->ssid.SSID));
                memcpy(wl->profile->ssid.SSID, ssid->SSID, ssid->SSID_len);
@@ -4210,12 +3966,12 @@ wl_update_prof(struct wl_priv *wl, const wl_event_msg_t *e, void *data,
        return err;
 }
 
-static bool wl_is_ibssmode(struct wl_priv *wl)
+static bool brcmf_is_ibssmode(struct wl_priv *wl)
 {
        return wl->conf->mode == WL_MODE_IBSS;
 }
 
-static __used s32 wl_add_ie(struct wl_priv *wl, u8 t, u8 l, u8 *v)
+static __used s32 brcmf_add_ie(struct wl_priv *wl, u8 t, u8 l, u8 *v)
 {
        struct wl_ie *ie = wl_to_ie(wl);
        s32 err = 0;
@@ -4232,19 +3988,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)
+static void brcmf_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 = brcmf_dev_ioctl(dev, BRCMF_C_DISASSOC, NULL, 0);
                if (unlikely(err))
                        WL_ERR("WLC_DISASSOC failed (%d)\n", err);
                wl->link_up = false;
@@ -4252,22 +4006,22 @@ static void wl_link_down(struct wl_priv *wl)
        WL_TRACE("Exit\n");
 }
 
-static void wl_lock_eq(struct wl_priv *wl)
+static void brcmf_lock_eq(struct wl_priv *wl)
 {
        spin_lock_irq(&wl->eq_lock);
 }
 
-static void wl_unlock_eq(struct wl_priv *wl)
+static void brcmf_unlock_eq(struct wl_priv *wl)
 {
        spin_unlock_irq(&wl->eq_lock);
 }
 
-static void wl_init_eq_lock(struct wl_priv *wl)
+static void brcmf_init_eq_lock(struct wl_priv *wl)
 {
        spin_lock_init(&wl->eq_lock);
 }
 
-static void wl_delay(u32 ms)
+static void brcmf_delay(u32 ms)
 {
        if (ms < 1000 / HZ) {
                cond_resched();
@@ -4277,115 +4031,27 @@ static void wl_delay(u32 ms)
        }
 }
 
-static void wl_set_drvdata(struct wl_dev *dev, void *data)
+static void brcmf_set_drvdata(struct wl_dev *dev, void *data)
 {
        dev->driver_data = data;
 }
 
-static void *wl_get_drvdata(struct wl_dev *dev)
-{
-       return dev->driver_data;
-}
-
-s32 wl_cfg80211_read_fw(s8 *buf, u32 size)
-{
-       const struct firmware *fw_entry;
-       struct wl_priv *wl;
-
-       wl = WL_PRIV_GET();
-
-       fw_entry = wl->fw->fw_entry;
-
-       if (fw_entry->size < wl->fw->ptr + size)
-               size = fw_entry->size - wl->fw->ptr;
-
-       memcpy(buf, &fw_entry->data[wl->fw->ptr], size);
-       wl->fw->ptr += size;
-       return size;
-}
-
-void wl_cfg80211_release_fw(void)
-{
-       struct wl_priv *wl;
-
-       wl = WL_PRIV_GET();
-       release_firmware(wl->fw->fw_entry);
-       wl->fw->ptr = 0;
-}
-
-void *wl_cfg80211_request_fw(s8 *file_name)
-{
-       struct wl_priv *wl;
-       const struct firmware *fw_entry = NULL;
-       s32 err = 0;
-
-       WL_INFO("file name : \"%s\"\n", file_name);
-       wl = WL_PRIV_GET();
-
-       if (!test_bit(WL_FW_LOADING_DONE, &wl->fw->status)) {
-               err = request_firmware(&wl->fw->fw_entry, file_name,
-                               &wl_cfg80211_get_sdio_func()->dev);
-               if (unlikely(err)) {
-                       WL_ERR("Could not download fw (%d)\n", err);
-                       goto req_fw_out;
-               }
-               set_bit(WL_FW_LOADING_DONE, &wl->fw->status);
-               fw_entry = wl->fw->fw_entry;
-               if (fw_entry) {
-                       WL_INFO("fw size (%zd), data (%p)\n",
-                              fw_entry->size, fw_entry->data);
-               }
-       } else if (!test_bit(WL_NVRAM_LOADING_DONE, &wl->fw->status)) {
-               err = request_firmware(&wl->fw->fw_entry, file_name,
-                               &wl_cfg80211_get_sdio_func()->dev);
-               if (unlikely(err)) {
-                       WL_ERR("Could not download nvram (%d)\n", err);
-                       goto req_fw_out;
-               }
-               set_bit(WL_NVRAM_LOADING_DONE, &wl->fw->status);
-               fw_entry = wl->fw->fw_entry;
-               if (fw_entry) {
-                       WL_INFO("nvram size (%zd), data (%p)\n",
-                              fw_entry->size, fw_entry->data);
-               }
-       } else {
-               WL_INFO("Downloading already done. Nothing to do more\n");
-               err = -EPERM;
-       }
-
-req_fw_out:
-       if (unlikely(err)) {
-               return NULL;
-       }
-       wl->fw->ptr = 0;
-       return (void *)fw_entry->data;
-}
-
-s8 *wl_cfg80211_get_fwname(void)
-{
-       struct wl_priv *wl;
-
-       wl = WL_PRIV_GET();
-       strcpy(wl->fw->fw_name, WL_4329_FW_FILE);
-       return wl->fw->fw_name;
-}
-
-s8 *wl_cfg80211_get_nvramname(void)
+static void *brcmf_get_drvdata(struct wl_dev *dev)
 {
-       struct wl_priv *wl;
+       void *data = NULL;
 
-       wl = WL_PRIV_GET();
-       strcpy(wl->fw->nvram_name, WL_4329_NVRAM_FILE);
-       return wl->fw->nvram_name;
+       if (dev)
+               data = dev->driver_data;
+       return data;
 }
 
-static void wl_set_mpc(struct net_device *ndev, int mpc)
+static void brcmf_set_mpc(struct net_device *ndev, int mpc)
 {
        s32 err = 0;
        struct wl_priv *wl = ndev_to_wl(ndev);
 
        if (test_bit(WL_STATUS_READY, &wl->status)) {
-               err = wl_dev_intvar_set(ndev, "mpc", mpc);
+               err = brcmf_dev_intvar_set(ndev, "mpc", mpc);
                if (unlikely(err)) {
                        WL_ERR("fail to set mpc\n");
                        return;
@@ -4394,7 +4060,7 @@ static void wl_set_mpc(struct net_device *ndev, int mpc)
        }
 }
 
-static int wl_debugfs_add_netdev_params(struct wl_priv *wl)
+static int brcmf_debugfs_add_netdev_params(struct wl_priv *wl)
 {
        char buf[10+IFNAMSIZ];
        struct dentry *fd;
@@ -4421,7 +4087,7 @@ err_out:
        return err;
 }
 
-static void wl_debugfs_remove_netdev(struct wl_priv *wl)
+static void brcmf_debugfs_remove_netdev(struct wl_priv *wl)
 {
        debugfs_remove_recursive(wl->debugfsdir);
        wl->debugfsdir = NULL;
This page took 0.128049 seconds and 5 git commands to generate.