]> git.proxmox.com Git - mirror_ubuntu-hirsute-kernel.git/commitdiff
staging: Remove rtl8723au driver
authorJes Sorensen <Jes.Sorensen@redhat.com>
Sat, 10 Sep 2016 12:21:57 +0000 (08:21 -0400)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Sat, 10 Sep 2016 13:21:43 +0000 (15:21 +0200)
This driver is superseded by rtl8xxxu and has been marked as scheduled
for deletion since 4.6

Signed-off-by: Jes Sorensen <Jes.Sorensen@redhat.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
114 files changed:
MAINTAINERS
drivers/staging/Kconfig
drivers/staging/Makefile
drivers/staging/rtl8723au/Kconfig [deleted file]
drivers/staging/rtl8723au/Makefile [deleted file]
drivers/staging/rtl8723au/TODO [deleted file]
drivers/staging/rtl8723au/core/rtw_ap.c [deleted file]
drivers/staging/rtl8723au/core/rtw_cmd.c [deleted file]
drivers/staging/rtl8723au/core/rtw_efuse.c [deleted file]
drivers/staging/rtl8723au/core/rtw_ieee80211.c [deleted file]
drivers/staging/rtl8723au/core/rtw_mlme.c [deleted file]
drivers/staging/rtl8723au/core/rtw_mlme_ext.c [deleted file]
drivers/staging/rtl8723au/core/rtw_pwrctrl.c [deleted file]
drivers/staging/rtl8723au/core/rtw_recv.c [deleted file]
drivers/staging/rtl8723au/core/rtw_security.c [deleted file]
drivers/staging/rtl8723au/core/rtw_sreset.c [deleted file]
drivers/staging/rtl8723au/core/rtw_sta_mgt.c [deleted file]
drivers/staging/rtl8723au/core/rtw_wlan_util.c [deleted file]
drivers/staging/rtl8723au/core/rtw_xmit.c [deleted file]
drivers/staging/rtl8723au/hal/Hal8723PwrSeq.c [deleted file]
drivers/staging/rtl8723au/hal/Hal8723UHWImg_CE.c [deleted file]
drivers/staging/rtl8723au/hal/HalDMOutSrc8723A_CE.c [deleted file]
drivers/staging/rtl8723au/hal/HalHWImg8723A_BB.c [deleted file]
drivers/staging/rtl8723au/hal/HalHWImg8723A_MAC.c [deleted file]
drivers/staging/rtl8723au/hal/HalHWImg8723A_RF.c [deleted file]
drivers/staging/rtl8723au/hal/HalPwrSeqCmd.c [deleted file]
drivers/staging/rtl8723au/hal/hal_com.c [deleted file]
drivers/staging/rtl8723au/hal/hal_intf.c [deleted file]
drivers/staging/rtl8723au/hal/odm.c [deleted file]
drivers/staging/rtl8723au/hal/odm_HWConfig.c [deleted file]
drivers/staging/rtl8723au/hal/odm_RegConfig8723A.c [deleted file]
drivers/staging/rtl8723au/hal/odm_debug.c [deleted file]
drivers/staging/rtl8723au/hal/odm_interface.c [deleted file]
drivers/staging/rtl8723au/hal/rtl8723a_bt-coexist.c [deleted file]
drivers/staging/rtl8723au/hal/rtl8723a_cmd.c [deleted file]
drivers/staging/rtl8723au/hal/rtl8723a_dm.c [deleted file]
drivers/staging/rtl8723au/hal/rtl8723a_hal_init.c [deleted file]
drivers/staging/rtl8723au/hal/rtl8723a_phycfg.c [deleted file]
drivers/staging/rtl8723au/hal/rtl8723a_rf6052.c [deleted file]
drivers/staging/rtl8723au/hal/rtl8723a_rxdesc.c [deleted file]
drivers/staging/rtl8723au/hal/rtl8723a_sreset.c [deleted file]
drivers/staging/rtl8723au/hal/rtl8723au_recv.c [deleted file]
drivers/staging/rtl8723au/hal/rtl8723au_xmit.c [deleted file]
drivers/staging/rtl8723au/hal/usb_halinit.c [deleted file]
drivers/staging/rtl8723au/hal/usb_ops_linux.c [deleted file]
drivers/staging/rtl8723au/include/Hal8723APhyCfg.h [deleted file]
drivers/staging/rtl8723au/include/Hal8723APhyReg.h [deleted file]
drivers/staging/rtl8723au/include/Hal8723PwrSeq.h [deleted file]
drivers/staging/rtl8723au/include/Hal8723UHWImg_CE.h [deleted file]
drivers/staging/rtl8723au/include/HalDMOutSrc8723A.h [deleted file]
drivers/staging/rtl8723au/include/HalHWImg8723A_BB.h [deleted file]
drivers/staging/rtl8723au/include/HalHWImg8723A_FW.h [deleted file]
drivers/staging/rtl8723au/include/HalHWImg8723A_MAC.h [deleted file]
drivers/staging/rtl8723au/include/HalHWImg8723A_RF.h [deleted file]
drivers/staging/rtl8723au/include/HalPwrSeqCmd.h [deleted file]
drivers/staging/rtl8723au/include/HalVerDef.h [deleted file]
drivers/staging/rtl8723au/include/drv_types.h [deleted file]
drivers/staging/rtl8723au/include/hal_com.h [deleted file]
drivers/staging/rtl8723au/include/hal_intf.h [deleted file]
drivers/staging/rtl8723au/include/ieee80211.h [deleted file]
drivers/staging/rtl8723au/include/ioctl_cfg80211.h [deleted file]
drivers/staging/rtl8723au/include/mlme_osdep.h [deleted file]
drivers/staging/rtl8723au/include/odm.h [deleted file]
drivers/staging/rtl8723au/include/odm_HWConfig.h [deleted file]
drivers/staging/rtl8723au/include/odm_RegConfig8723A.h [deleted file]
drivers/staging/rtl8723au/include/odm_RegDefine11N.h [deleted file]
drivers/staging/rtl8723au/include/odm_debug.h [deleted file]
drivers/staging/rtl8723au/include/odm_interface.h [deleted file]
drivers/staging/rtl8723au/include/odm_precomp.h [deleted file]
drivers/staging/rtl8723au/include/odm_reg.h [deleted file]
drivers/staging/rtl8723au/include/osdep_intf.h [deleted file]
drivers/staging/rtl8723au/include/osdep_service.h [deleted file]
drivers/staging/rtl8723au/include/recv_osdep.h [deleted file]
drivers/staging/rtl8723au/include/rtl8723a_bt-coexist.h [deleted file]
drivers/staging/rtl8723au/include/rtl8723a_bt_intf.h [deleted file]
drivers/staging/rtl8723au/include/rtl8723a_cmd.h [deleted file]
drivers/staging/rtl8723au/include/rtl8723a_dm.h [deleted file]
drivers/staging/rtl8723au/include/rtl8723a_hal.h [deleted file]
drivers/staging/rtl8723au/include/rtl8723a_pg.h [deleted file]
drivers/staging/rtl8723au/include/rtl8723a_recv.h [deleted file]
drivers/staging/rtl8723au/include/rtl8723a_rf.h [deleted file]
drivers/staging/rtl8723au/include/rtl8723a_spec.h [deleted file]
drivers/staging/rtl8723au/include/rtl8723a_sreset.h [deleted file]
drivers/staging/rtl8723au/include/rtl8723a_xmit.h [deleted file]
drivers/staging/rtl8723au/include/rtw_ap.h [deleted file]
drivers/staging/rtl8723au/include/rtw_cmd.h [deleted file]
drivers/staging/rtl8723au/include/rtw_debug.h [deleted file]
drivers/staging/rtl8723au/include/rtw_eeprom.h [deleted file]
drivers/staging/rtl8723au/include/rtw_efuse.h [deleted file]
drivers/staging/rtl8723au/include/rtw_event.h [deleted file]
drivers/staging/rtl8723au/include/rtw_ht.h [deleted file]
drivers/staging/rtl8723au/include/rtw_io.h [deleted file]
drivers/staging/rtl8723au/include/rtw_mlme.h [deleted file]
drivers/staging/rtl8723au/include/rtw_mlme_ext.h [deleted file]
drivers/staging/rtl8723au/include/rtw_pwrctrl.h [deleted file]
drivers/staging/rtl8723au/include/rtw_recv.h [deleted file]
drivers/staging/rtl8723au/include/rtw_rf.h [deleted file]
drivers/staging/rtl8723au/include/rtw_security.h [deleted file]
drivers/staging/rtl8723au/include/rtw_sreset.h [deleted file]
drivers/staging/rtl8723au/include/rtw_version.h [deleted file]
drivers/staging/rtl8723au/include/rtw_xmit.h [deleted file]
drivers/staging/rtl8723au/include/sta_info.h [deleted file]
drivers/staging/rtl8723au/include/usb_ops.h [deleted file]
drivers/staging/rtl8723au/include/usb_ops_linux.h [deleted file]
drivers/staging/rtl8723au/include/wifi.h [deleted file]
drivers/staging/rtl8723au/include/wlan_bssdef.h [deleted file]
drivers/staging/rtl8723au/include/xmit_osdep.h [deleted file]
drivers/staging/rtl8723au/os_dep/ioctl_cfg80211.c [deleted file]
drivers/staging/rtl8723au/os_dep/mlme_linux.c [deleted file]
drivers/staging/rtl8723au/os_dep/os_intfs.c [deleted file]
drivers/staging/rtl8723au/os_dep/recv_linux.c [deleted file]
drivers/staging/rtl8723au/os_dep/usb_intf.c [deleted file]
drivers/staging/rtl8723au/os_dep/usb_ops_linux.c [deleted file]
drivers/staging/rtl8723au/os_dep/xmit_linux.c [deleted file]

index b53c82825144c8533ebe028dce3d3f41e8f01663..0c554b5a0405b61b13ca5a65210024df3683e84a 100644 (file)
@@ -11210,13 +11210,6 @@ M:     Florian Schilhabel <florian.c.schilhabel@googlemail.com>.
 S:     Odd Fixes
 F:     drivers/staging/rtl8712/
 
-STAGING - REALTEK RTL8723U WIRELESS DRIVER
-M:     Larry Finger <Larry.Finger@lwfinger.net>
-M:     Jes Sorensen <Jes.Sorensen@redhat.com>
-L:     linux-wireless@vger.kernel.org
-S:     Maintained
-F:     drivers/staging/rtl8723au/
-
 STAGING - SILICON MOTION SM750 FRAME BUFFER DRIVER
 M:     Sudip Mukherjee <sudipm.mukherjee@gmail.com>
 M:     Teddy Wang <teddy.wang@siliconmotion.com>
index af9476460023a248b3349765c50e2f51772d65ab..5ebaf0028a10473da153af86a6b741072757fb9f 100644 (file)
@@ -40,8 +40,6 @@ source "drivers/staging/rtl8712/Kconfig"
 
 source "drivers/staging/rtl8188eu/Kconfig"
 
-source "drivers/staging/rtl8723au/Kconfig"
-
 source "drivers/staging/rts5208/Kconfig"
 
 source "drivers/staging/octeon/Kconfig"
index 9f6009dcafa85b45e066c29b42c9ca2ae1ff57d0..29a1672820e61bb8a8b57ec4bcbf7929f62bd6f8 100644 (file)
@@ -9,7 +9,6 @@ obj-$(CONFIG_RTL8192U)          += rtl8192u/
 obj-$(CONFIG_RTL8192E)         += rtl8192e/
 obj-$(CONFIG_R8712U)           += rtl8712/
 obj-$(CONFIG_R8188EU)          += rtl8188eu/
-obj-$(CONFIG_R8723AU)          += rtl8723au/
 obj-$(CONFIG_RTS5208)          += rts5208/
 obj-$(CONFIG_NETLOGIC_XLR_NET) += netlogic/
 obj-$(CONFIG_OCTEON_ETHERNET)  += octeon/
diff --git a/drivers/staging/rtl8723au/Kconfig b/drivers/staging/rtl8723au/Kconfig
deleted file mode 100644 (file)
index 277c1ab..0000000
+++ /dev/null
@@ -1,33 +0,0 @@
-config R8723AU
-       tristate "Realtek RTL8723AU Wireless LAN NIC driver (deprecated)"
-       depends on USB && WLAN && RFKILL
-       select WIRELESS_EXT
-       select WEXT_PRIV
-       select CFG80211
-       default n
-       ---help---
-       This option adds the Realtek RTL8723AU USB device such as found in
-       the Lenovo Yoga 13 tablet. If built as a module, it will be called r8723au.
-
-       Note: This driver is deprecated and scheduled to be removed in a
-       future kernel release. Please use rtl8xxxu instead.
-
-if R8723AU
-
-config 8723AU_AP_MODE
-       bool "Realtek RTL8723AU AP mode"
-       default y
-       ---help---
-       This option enables Access Point mode. Unless you know that your system
-       will never be used as an AP, or the target system has limited memory,
-       "Y" should be selected.
-
-config 8723AU_BT_COEXIST
-       bool "Realtek RTL8723AU BlueTooth Coexistence"
-       default y
-       ---help---
-       This option enables icoexistence with BlueTooth communications for the r8723au driver.
-       Unless you know that this driver will never by used with BT, or the target system has
-       limited memory, "Y" should be selected.
-
-endif
diff --git a/drivers/staging/rtl8723au/Makefile b/drivers/staging/rtl8723au/Makefile
deleted file mode 100644 (file)
index 3e89890..0000000
+++ /dev/null
@@ -1,53 +0,0 @@
-r8723au-y :=                           \
-               core/rtw_cmd.o          \
-               core/rtw_efuse.o        \
-               core/rtw_ieee80211.o    \
-               core/rtw_mlme.o         \
-               core/rtw_mlme_ext.o     \
-               core/rtw_pwrctrl.o      \
-               core/rtw_recv.o         \
-               core/rtw_security.o     \
-               core/rtw_sreset.o       \
-               core/rtw_sta_mgt.o      \
-               core/rtw_xmit.o         \
-               core/rtw_wlan_util.o    \
-               hal/hal_com.o           \
-               hal/hal_intf.o          \
-               hal/Hal8723PwrSeq.o     \
-               hal/Hal8723UHWImg_CE.o  \
-               hal/HalDMOutSrc8723A_CE.o \
-               hal/HalHWImg8723A_BB.o  \
-               hal/HalHWImg8723A_MAC.o \
-               hal/HalHWImg8723A_RF.o  \
-               hal/HalPwrSeqCmd.o      \
-               hal/odm_RegConfig8723A.o \
-               hal/odm_debug.o         \
-               hal/odm_interface.o     \
-               hal/odm_HWConfig.o      \
-               hal/odm.o               \
-               hal/rtl8723a_cmd.o      \
-               hal/rtl8723a_dm.o       \
-               hal/rtl8723a_hal_init.o \
-               hal/rtl8723a_phycfg.o   \
-               hal/rtl8723a_rf6052.o   \
-               hal/rtl8723a_rxdesc.o   \
-               hal/rtl8723a_sreset.o   \
-               hal/rtl8723au_recv.o    \
-               hal/rtl8723au_xmit.o    \
-               hal/usb_halinit.o       \
-               hal/usb_ops_linux.o     \
-               os_dep/ioctl_cfg80211.o \
-               os_dep/mlme_linux.o     \
-               os_dep/os_intfs.o       \
-               os_dep/recv_linux.o     \
-               os_dep/usb_intf.o       \
-               os_dep/usb_ops_linux.o  \
-               os_dep/xmit_linux.o
-
-r8723au-$(CONFIG_8723AU_BT_COEXIST) += hal/rtl8723a_bt-coexist.o
-r8723au-$(CONFIG_8723AU_AP_MODE) += core/rtw_ap.o
-
-obj-$(CONFIG_R8723AU)  := r8723au.o
-
-ccflags-y += $(call cc-option,-Wtype-limits,)
-ccflags-y += -D__CHECK_ENDIAN__ -I$(src)/include
diff --git a/drivers/staging/rtl8723au/TODO b/drivers/staging/rtl8723au/TODO
deleted file mode 100644 (file)
index 42b86e4..0000000
+++ /dev/null
@@ -1,16 +0,0 @@
-TODO:
-- find and remove code valid only for 5 HGz. Many of the obvious
-  ones have been removed, but things like channel > 14 still exist.
-- find and remove any code for other chips that is left over
-- convert any remaining unusual variable types
-- find codes that can use %pM and %Nph formatting
-- checkpatch.pl fixes - most of the remaining ones are lines too long. Many
-  of them will require refactoring
-- merge Realtek's bugfixes and new features into the driver
-- switch to use MAC80211
-
-A mac80211 driver for this hardware already was integrated at
-drivers/net/wireless/realtek/rtl8xxxu/
-
-Please send any patches to Greg Kroah-Hartman <gregkh@linuxfoundation.org>,
-Jes Sorensen <Jes.Sorensen@redhat.com>, and Larry Finger <Larry.Finger@lwfinger.net>.
diff --git a/drivers/staging/rtl8723au/core/rtw_ap.c b/drivers/staging/rtl8723au/core/rtw_ap.c
deleted file mode 100644 (file)
index aad686d..0000000
+++ /dev/null
@@ -1,1738 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#define _RTW_AP_C_
-
-#include <osdep_service.h>
-#include <drv_types.h>
-#include <linux/ieee80211.h>
-#include <wifi.h>
-#include <rtl8723a_cmd.h>
-#include <rtl8723a_hal.h>
-#include <asm/unaligned.h>
-#include <rtw_mlme_ext.h>
-
-void init_mlme_ap_info23a(struct rtw_adapter *padapter)
-{
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct sta_priv *pstapriv = &padapter->stapriv;
-       struct wlan_acl_pool *pacl_list = &pstapriv->acl_list;
-
-       spin_lock_init(&pmlmepriv->bcn_update_lock);
-
-       /* for ACL */
-       _rtw_init_queue23a(&pacl_list->acl_node_q);
-
-       start_ap_mode23a(padapter);
-}
-
-void free_mlme_ap_info23a(struct rtw_adapter *padapter)
-{
-       struct sta_info *psta = NULL;
-       struct sta_priv *pstapriv = &padapter->stapriv;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-
-       pmlmepriv->update_bcn = false;
-       pmlmeext->bstart_bss = false;
-
-       rtw_sta_flush23a(padapter);
-
-       pmlmeinfo->state = MSR_NOLINK;
-
-       /* free_assoc_sta_resources */
-       rtw_free_all_stainfo23a(padapter);
-
-       /* free bc/mc sta_info */
-       psta = rtw_get_bcmc_stainfo23a(padapter);
-       spin_lock_bh(&pstapriv->sta_hash_lock);
-       rtw_free_stainfo23a(padapter, psta);
-       spin_unlock_bh(&pstapriv->sta_hash_lock);
-}
-
-static void update_BCNTIM(struct rtw_adapter *padapter)
-{
-       struct sta_priv *pstapriv = &padapter->stapriv;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       struct wlan_bssid_ex *pnetwork_mlmeext = &pmlmeinfo->network;
-       unsigned char *pie = pnetwork_mlmeext->IEs;
-       u8 *p, *dst_ie, *premainder_ie = NULL, *pbackup_remainder_ie = NULL;
-       uint offset, tmp_len, tim_ielen, tim_ie_offset, remainder_ielen;
-
-       p = rtw_get_ie23a(pie, WLAN_EID_TIM, &tim_ielen,
-                         pnetwork_mlmeext->IELength);
-       if (p != NULL && tim_ielen > 0) {
-               tim_ielen += 2;
-
-               premainder_ie = p+tim_ielen;
-
-               tim_ie_offset = (int)(p - pie);
-
-               remainder_ielen = pnetwork_mlmeext->IELength - tim_ie_offset - tim_ielen;
-
-               /* append TIM IE from dst_ie offset */
-               dst_ie = p;
-       } else {
-               tim_ielen = 0;
-
-               /* calculate head_len */
-               offset = 0;
-
-               /* get ssid_ie len */
-               p = rtw_get_ie23a(pie, WLAN_EID_SSID,
-                                 &tmp_len, pnetwork_mlmeext->IELength);
-               if (p != NULL)
-                       offset += tmp_len+2;
-
-               /*  get supported rates len */
-               p = rtw_get_ie23a(pie, WLAN_EID_SUPP_RATES,
-                                 &tmp_len, pnetwork_mlmeext->IELength);
-               if (p !=  NULL)
-                       offset += tmp_len+2;
-
-               /* DS Parameter Set IE, len = 3 */
-               offset += 3;
-
-               premainder_ie = pie + offset;
-
-               remainder_ielen = pnetwork_mlmeext->IELength - offset - tim_ielen;
-
-               /* append TIM IE from offset */
-               dst_ie = pie + offset;
-       }
-
-       if (remainder_ielen > 0) {
-               pbackup_remainder_ie = kmalloc(remainder_ielen, GFP_ATOMIC);
-               if (pbackup_remainder_ie && premainder_ie)
-                       memcpy(pbackup_remainder_ie, premainder_ie, remainder_ielen);
-       }
-
-       *dst_ie++ = WLAN_EID_TIM;
-
-       if ((pstapriv->tim_bitmap&0xff00) && (pstapriv->tim_bitmap&0x00fc))
-               tim_ielen = 5;
-       else
-               tim_ielen = 4;
-
-       *dst_ie++ = tim_ielen;
-
-       *dst_ie++ = 0; /* DTIM count */
-       *dst_ie++ = 1; /* DTIM period */
-
-       if (pstapriv->tim_bitmap & BIT(0)) /* for bc/mc frames */
-               *dst_ie++ = BIT(0);        /* bitmap ctrl */
-       else
-               *dst_ie++ = 0;
-
-       if (tim_ielen == 4) {
-               *dst_ie++ = pstapriv->tim_bitmap & 0xff;
-       } else if (tim_ielen == 5) {
-               put_unaligned_le16(pstapriv->tim_bitmap, dst_ie);
-               dst_ie += 2;
-       }
-
-       /* copy remainder IE */
-       if (pbackup_remainder_ie) {
-               memcpy(dst_ie, pbackup_remainder_ie, remainder_ielen);
-
-               kfree(pbackup_remainder_ie);
-       }
-
-       offset =  (uint)(dst_ie - pie);
-       pnetwork_mlmeext->IELength = offset + remainder_ielen;
-
-       set_tx_beacon_cmd23a(padapter);
-}
-
-static u8 chk_sta_is_alive(struct sta_info *psta)
-{
-       u8 ret = false;
-
-       if ((psta->sta_stats.last_rx_data_pkts +
-           psta->sta_stats.last_rx_ctrl_pkts) !=
-           (psta->sta_stats.rx_data_pkts + psta->sta_stats.rx_ctrl_pkts))
-               ret = true;
-
-       sta_update_last_rx_pkts(psta);
-
-       return ret;
-}
-
-void expire_timeout_chk23a(struct rtw_adapter *padapter)
-{
-       struct list_head *phead;
-       u8 updated = 0;
-       struct sta_info *psta, *ptmp;
-       struct sta_priv *pstapriv = &padapter->stapriv;
-       u8 chk_alive_num = 0;
-       struct sta_info *chk_alive_list[NUM_STA];
-       int i;
-
-       spin_lock_bh(&pstapriv->auth_list_lock);
-       phead = &pstapriv->auth_list;
-       /* check auth_queue */
-       list_for_each_entry_safe(psta, ptmp, phead, auth_list) {
-               if (psta->expire_to > 0) {
-                       psta->expire_to--;
-                       if (psta->expire_to == 0) {
-                               list_del_init(&psta->auth_list);
-                               pstapriv->auth_list_cnt--;
-
-                               DBG_8723A("auth expire %pM\n", psta->hwaddr);
-
-                               spin_unlock_bh(&pstapriv->auth_list_lock);
-
-                               spin_lock_bh(&pstapriv->sta_hash_lock);
-                               rtw_free_stainfo23a(padapter, psta);
-                               spin_unlock_bh(&pstapriv->sta_hash_lock);
-
-                               spin_lock_bh(&pstapriv->auth_list_lock);
-                       }
-               }
-       }
-       spin_unlock_bh(&pstapriv->auth_list_lock);
-
-       spin_lock_bh(&pstapriv->asoc_list_lock);
-       phead = &pstapriv->asoc_list;
-       /* check asoc_queue */
-       list_for_each_entry_safe(psta, ptmp, phead, asoc_list) {
-               if (chk_sta_is_alive(psta) || !psta->expire_to) {
-                       psta->expire_to = pstapriv->expire_to;
-                       psta->keep_alive_trycnt = 0;
-               } else {
-                       psta->expire_to--;
-               }
-
-               if (psta->expire_to <= 0) {
-                       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-
-                       if (padapter->registrypriv.wifi_spec == 1) {
-                               psta->expire_to = pstapriv->expire_to;
-                               continue;
-                       }
-
-                       if (psta->state & WIFI_SLEEP_STATE) {
-                               if (!(psta->state & WIFI_STA_ALIVE_CHK_STATE)) {
-                                       /*
-                                        * check if alive by another method
-                                        * if station is at ps mode.
-                                        */
-                                       psta->expire_to = pstapriv->expire_to;
-                                       psta->state |= WIFI_STA_ALIVE_CHK_STATE;
-                                       /*
-                                        * update bcn with tim_bitmap
-                                        * for this station
-                                        */
-                                       pstapriv->tim_bitmap |= CHKBIT(psta->aid);
-                                       update_beacon23a(padapter, WLAN_EID_TIM, NULL, false);
-
-                                       if (!pmlmeext->active_keep_alive_check)
-                                               continue;
-                               }
-                       }
-
-                       if (pmlmeext->active_keep_alive_check) {
-                               chk_alive_list[chk_alive_num++] = psta;
-                               continue;
-                       }
-
-                       list_del_init(&psta->asoc_list);
-                       pstapriv->asoc_list_cnt--;
-
-                       DBG_8723A("asoc expire %pM, state = 0x%x\n",
-                                 psta->hwaddr, psta->state);
-                       updated = ap_free_sta23a(padapter, psta, false, WLAN_REASON_DEAUTH_LEAVING);
-               } else {
-                       /*
-                        * TODO: Aging mechanism to digest frames in
-                        * sleep_q to avoid running out of xmitframe
-                        */
-                       if (psta->sleepq_len > (NR_XMITFRAME/pstapriv->asoc_list_cnt)
-                               && padapter->xmitpriv.free_xmitframe_cnt < ((NR_XMITFRAME/pstapriv->asoc_list_cnt)/2)
-                       ) {
-                               DBG_8723A("%s sta:%pM, sleepq_len:%u, free_xmitframe_cnt:%u, asoc_list_cnt:%u, clear sleep_q\n",
-                                         __func__,
-                                         psta->hwaddr,
-                                         psta->sleepq_len,
-                                         padapter->xmitpriv.free_xmitframe_cnt,
-                                         pstapriv->asoc_list_cnt);
-                               wakeup_sta_to_xmit23a(padapter, psta);
-                       }
-               }
-       }
-       spin_unlock_bh(&pstapriv->asoc_list_lock);
-
-       if (chk_alive_num) {
-
-               u8 backup_oper_channel = 0;
-               struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-               /*
-                * switch to correct channel of current
-                * network before issue keep-alive frames
-                */
-               if (rtw_get_oper_ch23a(padapter) != pmlmeext->cur_channel) {
-                       backup_oper_channel = rtw_get_oper_ch23a(padapter);
-                       SelectChannel23a(padapter, pmlmeext->cur_channel);
-               }
-
-       /* issue null data to check sta alive */
-       for (i = 0; i < chk_alive_num; i++) {
-
-               int ret = _FAIL;
-
-               psta = chk_alive_list[i];
-               if (!(psta->state & _FW_LINKED))
-                       continue;
-
-               if (psta->state & WIFI_SLEEP_STATE)
-                       ret = issue_nulldata23a(padapter, psta->hwaddr, 0, 1, 50);
-               else
-                       ret = issue_nulldata23a(padapter, psta->hwaddr, 0, 3, 50);
-
-               psta->keep_alive_trycnt++;
-               if (ret == _SUCCESS) {
-                       DBG_8723A("asoc check, sta(%pM) is alive\n",
-                                 psta->hwaddr);
-                       psta->expire_to = pstapriv->expire_to;
-                       psta->keep_alive_trycnt = 0;
-                       continue;
-               } else if (psta->keep_alive_trycnt <= 3) {
-                       DBG_8723A("ack check for asoc expire, keep_alive_trycnt =%d\n", psta->keep_alive_trycnt);
-                       psta->expire_to = 1;
-                       continue;
-               }
-
-               psta->keep_alive_trycnt = 0;
-
-               DBG_8723A("asoc expire %pM, state = 0x%x\n",
-                         psta->hwaddr, psta->state);
-               spin_lock_bh(&pstapriv->asoc_list_lock);
-               if (!list_empty(&psta->asoc_list)) {
-                       list_del_init(&psta->asoc_list);
-                       pstapriv->asoc_list_cnt--;
-                       updated = ap_free_sta23a(padapter, psta, false, WLAN_REASON_DEAUTH_LEAVING);
-               }
-               spin_unlock_bh(&pstapriv->asoc_list_lock);
-
-       }
-
-       if (backup_oper_channel > 0) /* back to original operation channel */
-               SelectChannel23a(padapter, backup_oper_channel);
-}
-
-       associated_clients_update23a(padapter, updated);
-}
-
-void add_RATid23a(struct rtw_adapter *padapter, struct sta_info *psta, u8 rssi_level)
-{
-       int i;
-       u8 rf_type;
-       u32 init_rate = 0;
-       unsigned char sta_band = 0, raid, shortGIrate = false;
-       unsigned char limit;
-       unsigned int tx_ra_bitmap = 0;
-       struct ht_priv *psta_ht = NULL;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct wlan_bssid_ex *pcur_network = &pmlmepriv->cur_network.network;
-
-       if (psta)
-               psta_ht = &psta->htpriv;
-       else
-               return;
-
-       if (!(psta->state & _FW_LINKED))
-               return;
-
-       /* b/g mode ra_bitmap */
-       for (i = 0; i < sizeof(psta->bssrateset); i++) {
-               if (psta->bssrateset[i])
-                       tx_ra_bitmap |= rtw_get_bit_value_from_ieee_value23a(psta->bssrateset[i]&0x7f);
-       }
-       /* n mode ra_bitmap */
-       if (psta_ht->ht_option) {
-               rf_type = rtl8723a_get_rf_type(padapter);
-
-               if (rf_type == RF_2T2R)
-                       limit = 16; /* 2R */
-               else
-                       limit = 8;  /* 1R */
-
-               for (i = 0; i < limit; i++) {
-                       if (psta_ht->ht_cap.mcs.rx_mask[i / 8] & BIT(i % 8))
-                               tx_ra_bitmap |= BIT(i + 12);
-               }
-
-               /* max short GI rate */
-               shortGIrate = psta_ht->sgi;
-       }
-
-       if (pcur_network->DSConfig > 14) {
-               /*  5G band */
-               if (tx_ra_bitmap & 0xffff000)
-                       sta_band |= WIRELESS_11_5N | WIRELESS_11A;
-               else
-                       sta_band |= WIRELESS_11A;
-       } else {
-               if (tx_ra_bitmap & 0xffff000)
-                       sta_band |= WIRELESS_11_24N | WIRELESS_11G | WIRELESS_11B;
-               else if (tx_ra_bitmap & 0xff0)
-                       sta_band |= WIRELESS_11G | WIRELESS_11B;
-               else
-                       sta_band |= WIRELESS_11B;
-       }
-
-       psta->wireless_mode = sta_band;
-
-       raid = networktype_to_raid23a(sta_band);
-       init_rate = get_highest_rate_idx23a(tx_ra_bitmap&0x0fffffff)&0x3f;
-
-       if (psta->aid < NUM_STA) {
-               u8 arg;
-
-               arg = psta->mac_id&0x1f;
-
-               arg |= BIT(7); /* support entry 2~31 */
-
-               if (shortGIrate == true)
-                       arg |= BIT(5);
-
-               tx_ra_bitmap |= ((raid<<28)&0xf0000000);
-
-               DBG_8723A("%s => mac_id:%d , raid:%d , bitmap = 0x%x, arg = "
-                         "0x%x\n",
-                         __func__, psta->mac_id, raid, tx_ra_bitmap, arg);
-
-               /* bitmap[0:27] = tx_rate_bitmap */
-               /* bitmap[28:31]= Rate Adaptive id */
-               /* arg[0:4] = macid */
-               /* arg[5] = Short GI */
-               rtl8723a_add_rateatid(padapter, tx_ra_bitmap, arg, rssi_level);
-
-               if (shortGIrate == true)
-                       init_rate |= BIT(6);
-
-               /* set ra_id, init_rate */
-               psta->raid = raid;
-               psta->init_rate = init_rate;
-
-       } else
-               DBG_8723A("station aid %d exceed the max number\n", psta->aid);
-}
-
-static void update_bmc_sta(struct rtw_adapter *padapter)
-{
-       u32 init_rate = 0;
-       unsigned char network_type, raid;
-       int i, supportRateNum = 0;
-       unsigned int tx_ra_bitmap = 0;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct wlan_bssid_ex *pcur_network = &pmlmepriv->cur_network.network;
-       struct sta_info *psta = rtw_get_bcmc_stainfo23a(padapter);
-
-       if (psta) {
-               psta->aid = 0; /* default set to 0 */
-               psta->mac_id = psta->aid + 1;
-
-               psta->qos_option = 0;
-               psta->htpriv.ht_option = false;
-
-               psta->ieee8021x_blocked = 0;
-
-               memset((void *)&psta->sta_stats, 0,
-                      sizeof(struct stainfo_stats));
-
-               /* prepare for add_RATid23a */
-               supportRateNum = rtw_get_rateset_len23a((u8 *)&pcur_network->SupportedRates);
-               network_type = rtw_check_network_type23a((u8 *)&pcur_network->SupportedRates, supportRateNum, 1);
-
-               memcpy(psta->bssrateset, &pcur_network->SupportedRates, supportRateNum);
-               psta->bssratelen = supportRateNum;
-
-               /* b/g mode ra_bitmap */
-               for (i = 0; i < supportRateNum; i++) {
-                       if (psta->bssrateset[i])
-                               tx_ra_bitmap |= rtw_get_bit_value_from_ieee_value23a(psta->bssrateset[i]&0x7f);
-               }
-
-               if (pcur_network->DSConfig > 14) {
-                       /* force to A mode. 5G doesn't support CCK rates */
-                       network_type = WIRELESS_11A;
-                       tx_ra_bitmap = 0x150; /* 6, 12, 24 Mbps */
-               } else {
-                       /* force to b mode */
-                       network_type = WIRELESS_11B;
-                       tx_ra_bitmap = 0xf;
-               }
-
-               raid = networktype_to_raid23a(network_type);
-               init_rate = get_highest_rate_idx23a(tx_ra_bitmap&0x0fffffff)&0x3f;
-
-               /* ap mode */
-               rtl8723a_SetHalODMVar(padapter, HAL_ODM_STA_INFO, psta, true);
-
-               {
-                       u8 arg;
-
-                       arg = psta->mac_id&0x1f;
-
-                       arg |= BIT(7);
-
-                       tx_ra_bitmap |= ((raid<<28)&0xf0000000);
-
-                       DBG_8723A("update_bmc_sta, mask = 0x%x, arg = 0x%x\n", tx_ra_bitmap, arg);
-
-                       /* bitmap[0:27] = tx_rate_bitmap */
-                       /* bitmap[28:31]= Rate Adaptive id */
-                       /* arg[0:4] = macid */
-                       /* arg[5] = Short GI */
-                       rtl8723a_add_rateatid(padapter, tx_ra_bitmap, arg, 0);
-               }
-
-               /* set ra_id, init_rate */
-               psta->raid = raid;
-               psta->init_rate = init_rate;
-
-               spin_lock_bh(&psta->lock);
-               psta->state = _FW_LINKED;
-               spin_unlock_bh(&psta->lock);
-
-       } else
-               DBG_8723A("add_RATid23a_bmc_sta error!\n");
-}
-
-/*
- * AID: 1~MAX for sta and 0 for bc/mc in ap/adhoc mode
- * MAC_ID = AID+1 for sta in ap/adhoc mode
- * MAC_ID = 1 for bc/mc for sta/ap/adhoc
- * MAC_ID = 0 for bssid for sta/ap/adhoc
- * CAM_ID = 0~3 for default key, cmd_id = macid + 3, macid = aid + 1;
- */
-void update_sta_info23a_apmode23a(struct rtw_adapter *padapter, struct sta_info *psta)
-{
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct security_priv *psecuritypriv = &padapter->securitypriv;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct ht_priv *phtpriv_ap = &pmlmepriv->htpriv;
-       struct ht_priv *phtpriv_sta = &psta->htpriv;
-       /* set intf_tag to if1 */
-
-       psta->mac_id = psta->aid+1;
-       DBG_8723A("%s\n", __func__);
-
-       /* ap mode */
-       rtl8723a_SetHalODMVar(padapter, HAL_ODM_STA_INFO, psta, true);
-
-       if (psecuritypriv->dot11AuthAlgrthm == dot11AuthAlgrthm_8021X)
-               psta->ieee8021x_blocked = true;
-       else
-               psta->ieee8021x_blocked = false;
-
-       /* update sta's cap */
-
-       /* ERP */
-       VCS_update23a(padapter, psta);
-       /* HT related cap */
-       if (phtpriv_sta->ht_option) {
-               /* check if sta supports rx ampdu */
-               phtpriv_sta->ampdu_enable = phtpriv_ap->ampdu_enable;
-
-               /* check if sta support s Short GI */
-               if ((phtpriv_sta->ht_cap.cap_info & phtpriv_ap->ht_cap.cap_info) & cpu_to_le16(IEEE80211_HT_CAP_SGI_20|IEEE80211_HT_CAP_SGI_40))
-                       phtpriv_sta->sgi = true;
-
-               /* bwmode */
-               if ((phtpriv_sta->ht_cap.cap_info & phtpriv_ap->ht_cap.cap_info) & cpu_to_le16(IEEE80211_HT_CAP_SUP_WIDTH_20_40)) {
-                       /* phtpriv_sta->bwmode = HT_CHANNEL_WIDTH_40; */
-                       phtpriv_sta->bwmode = pmlmeext->cur_bwmode;
-                       phtpriv_sta->ch_offset = pmlmeext->cur_ch_offset;
-
-               }
-
-               psta->qos_option = true;
-
-       } else {
-               phtpriv_sta->ampdu_enable = false;
-
-               phtpriv_sta->sgi = false;
-               phtpriv_sta->bwmode = HT_CHANNEL_WIDTH_20;
-               phtpriv_sta->ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
-       }
-
-       /* Rx AMPDU */
-       send_delba23a(padapter, 0, psta->hwaddr); /* recipient */
-
-       /* TX AMPDU */
-       send_delba23a(padapter, 1, psta->hwaddr); /* originator */
-       phtpriv_sta->agg_enable_bitmap = 0x0;/* reset */
-       phtpriv_sta->candidate_tid_bitmap = 0x0;/* reset */
-
-       /* todo: init other variables */
-
-       memset((void *)&psta->sta_stats, 0, sizeof(struct stainfo_stats));
-
-       spin_lock_bh(&psta->lock);
-       psta->state |= _FW_LINKED;
-       spin_unlock_bh(&psta->lock);
-}
-
-static void update_hw_ht_param(struct rtw_adapter *padapter)
-{
-       unsigned char max_AMPDU_len;
-       unsigned char min_MPDU_spacing;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-
-       DBG_8723A("%s\n", __func__);
-       /*
-        * handle A-MPDU parameter field
-        * AMPDU_para [1:0]:Max AMPDU Len => 0:8k, 1:16k, 2:32k, 3:64k
-        * AMPDU_para [4:2]:Min MPDU Start Spacing
-       */
-       max_AMPDU_len = pmlmeinfo->ht_cap.ampdu_params_info &
-               IEEE80211_HT_AMPDU_PARM_FACTOR;
-
-       min_MPDU_spacing = (pmlmeinfo->ht_cap.ampdu_params_info &
-                           IEEE80211_HT_AMPDU_PARM_DENSITY) >> 2;
-
-       rtl8723a_set_ampdu_min_space(padapter, min_MPDU_spacing);
-       rtl8723a_set_ampdu_factor(padapter, max_AMPDU_len);
-
-       /* Config SM Power Save setting */
-       pmlmeinfo->SM_PS = (le16_to_cpu(pmlmeinfo->ht_cap.cap_info) &
-                           IEEE80211_HT_CAP_SM_PS) >> 2;
-       if (pmlmeinfo->SM_PS == WLAN_HT_CAP_SM_PS_STATIC)
-               DBG_8723A("%s(): WLAN_HT_CAP_SM_PS_STATIC\n", __func__);
-}
-
-static void start_bss_network(struct rtw_adapter *padapter, u8 *pbuf)
-{
-       const u8 *p;
-       u8 val8, cur_channel, cur_bwmode, cur_ch_offset;
-       u16 bcn_interval;
-       u32 acparm;
-       struct registry_priv *pregpriv = &padapter->registrypriv;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct security_priv *psecuritypriv = &padapter->securitypriv;
-       struct wlan_bssid_ex *pnetwork = &pmlmepriv->cur_network.network;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       struct wlan_bssid_ex *pnetwork_mlmeext = &pmlmeinfo->network;
-       struct ieee80211_ht_operation *pht_info = NULL;
-
-       bcn_interval = (u16)pnetwork->beacon_interval;
-       cur_channel = pnetwork->DSConfig;
-       cur_bwmode = HT_CHANNEL_WIDTH_20;
-       cur_ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
-
-       /*
-        * check if there is wps ie
-        * if there is wpsie in beacon the hostapd will
-        * update beacon twice when stating hostapd
-        * and at first time the security
-        * ie (RSN/WPA IE) will not include in beacon
-        */
-       if (!cfg80211_find_vendor_ie(WLAN_OUI_MICROSOFT,
-                                    WLAN_OUI_TYPE_MICROSOFT_WPS,
-                                    pnetwork->IEs,
-                                    pnetwork->IELength))
-               pmlmeext->bstart_bss = true;
-
-       /* todo: update wmm, ht cap */
-       /* pmlmeinfo->WMM_enable; */
-       /* pmlmeinfo->HT_enable; */
-       if (pmlmepriv->qos_option)
-               pmlmeinfo->WMM_enable = true;
-       if (pmlmepriv->htpriv.ht_option) {
-               pmlmeinfo->WMM_enable = true;
-               pmlmeinfo->HT_enable = true;
-
-               update_hw_ht_param(padapter);
-       }
-
-       if (pmlmepriv->cur_network.join_res != true) {
-               /*
-                * setting only at first time
-                * WEP Key will be set before this
-                * function, do not clear CAM.
-                */
-               if (psecuritypriv->dot11PrivacyAlgrthm !=
-                   WLAN_CIPHER_SUITE_WEP40 &&
-                   psecuritypriv->dot11PrivacyAlgrthm !=
-                   WLAN_CIPHER_SUITE_WEP104)
-                       flush_all_cam_entry23a(padapter);       /* clear CAM */
-       }
-
-       /* set MSR to AP_Mode */
-       rtl8723a_set_media_status(padapter, MSR_AP);
-
-       /* Set BSSID REG */
-       hw_var_set_bssid(padapter, pnetwork->MacAddress);
-
-       /* Set EDCA param reg */
-       acparm = 0x002F3217; /* VO */
-       rtl8723a_set_ac_param_vo(padapter, acparm);
-       acparm = 0x005E4317; /* VI */
-       rtl8723a_set_ac_param_vi(padapter, acparm);
-       acparm = 0x005ea42b;
-       rtl8723a_set_ac_param_be(padapter, acparm);
-       acparm = 0x0000A444; /* BK */
-       rtl8723a_set_ac_param_bk(padapter, acparm);
-
-       /* Set Security */
-       val8 = (psecuritypriv->dot11AuthAlgrthm == dot11AuthAlgrthm_8021X) ?
-               0xcc : 0xcf;
-       rtl8723a_set_sec_cfg(padapter, val8);
-
-       /* Beacon Control related register */
-       rtl8723a_set_beacon_interval(padapter, bcn_interval);
-
-       UpdateBrateTbl23a(padapter, pnetwork->SupportedRates);
-       HalSetBrateCfg23a(padapter, pnetwork->SupportedRates);
-
-       if (!pmlmepriv->cur_network.join_res) {
-               /* setting only at  first time */
-
-               /* disable dynamic functions, such as high power, DIG */
-
-               /* turn on all dynamic functions */
-               rtl8723a_odm_support_ability_set(padapter,
-                                                DYNAMIC_ALL_FUNC_ENABLE);
-       }
-       /* set channel, bwmode */
-
-       p = cfg80211_find_ie(WLAN_EID_HT_OPERATION, pnetwork->IEs,
-                            pnetwork->IELength);
-       if (p && p[1]) {
-               pht_info = (struct ieee80211_ht_operation *)(p + 2);
-
-               if (pregpriv->cbw40_enable && pht_info->ht_param &
-                   IEEE80211_HT_PARAM_CHAN_WIDTH_ANY) {
-                       /* switch to the 40M Hz mode */
-                       cur_bwmode = HT_CHANNEL_WIDTH_40;
-                       switch (pht_info->ht_param &
-                               IEEE80211_HT_PARAM_CHA_SEC_OFFSET) {
-                       case IEEE80211_HT_PARAM_CHA_SEC_ABOVE:
-                               /*
-                                * pmlmeext->cur_ch_offset =
-                                * HAL_PRIME_CHNL_OFFSET_LOWER;
-                                */
-                               cur_ch_offset = HAL_PRIME_CHNL_OFFSET_LOWER;
-                               break;
-                       case IEEE80211_HT_PARAM_CHA_SEC_BELOW:
-                               cur_ch_offset = HAL_PRIME_CHNL_OFFSET_UPPER;
-                               break;
-                       default:
-                               cur_ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
-                               break;
-                       }
-               }
-       }
-       /*
-        * TODO: need to judge the phy parameters
-        * on concurrent mode for single phy
-        */
-       set_channel_bwmode23a(padapter, cur_channel, cur_ch_offset, cur_bwmode);
-
-       DBG_8723A("CH =%d, BW =%d, offset =%d\n", cur_channel, cur_bwmode,
-                 cur_ch_offset);
-
-       pmlmeext->cur_channel = cur_channel;
-       pmlmeext->cur_bwmode = cur_bwmode;
-       pmlmeext->cur_ch_offset = cur_ch_offset;
-       pmlmeext->cur_wireless_mode = pmlmepriv->cur_network.network_type;
-
-       /* update cur_wireless_mode */
-       update_wireless_mode23a(padapter);
-
-       /* update capability after cur_wireless_mode updated */
-       update_capinfo23a(padapter, pnetwork->capability);
-
-       /* let pnetwork_mlmeext == pnetwork_mlme. */
-       memcpy(pnetwork_mlmeext, pnetwork, pnetwork->Length);
-
-       if (pmlmeext->bstart_bss) {
-               update_beacon23a(padapter, WLAN_EID_TIM, NULL, false);
-
-               /* issue beacon frame */
-               if (send_beacon23a(padapter) == _FAIL)
-                       DBG_8723A("issue_beacon23a, fail!\n");
-       }
-
-       /* update bc/mc sta_info */
-       update_bmc_sta(padapter);
-}
-
-int rtw_check_beacon_data23a(struct rtw_adapter *padapter,
-                            struct ieee80211_mgmt *mgmt, unsigned int len)
-{
-       int ret = _SUCCESS;
-       u8 *p;
-       u8 *pHT_caps_ie = NULL;
-       u8 *pHT_info_ie = NULL;
-       struct sta_info *psta = NULL;
-       u16 ht_cap = false;
-       uint ie_len = 0;
-       int group_cipher, pairwise_cipher;
-       u8 channel, network_type, supportRate[NDIS_802_11_LENGTH_RATES_EX];
-       int supportRateNum = 0;
-       u8 WMM_PARA_IE[] = {0x00, 0x50, 0xf2, 0x02, 0x01, 0x01};
-       struct registry_priv *pregistrypriv = &padapter->registrypriv;
-       struct security_priv *psecuritypriv = &padapter->securitypriv;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct wlan_bssid_ex *pbss_network = &pmlmepriv->cur_network.network;
-       u8 *ie = pbss_network->IEs;
-       u8 *pbuf = mgmt->u.beacon.variable;
-
-       len -= offsetof(struct ieee80211_mgmt, u.beacon.variable);
-       /* SSID */
-       /* Supported rates */
-       /* DS Params */
-       /* WLAN_EID_COUNTRY */
-       /* ERP Information element */
-       /* Extended supported rates */
-       /* WPA/WPA2 */
-       /* Wi-Fi Wireless Multimedia Extensions */
-       /* ht_capab, ht_oper */
-       /* WPS IE */
-
-       DBG_8723A("%s, len =%d\n", __func__, len);
-
-       if (!check_fwstate(pmlmepriv, WIFI_AP_STATE))
-               return _FAIL;
-
-       if (len > MAX_IE_SZ)
-               return _FAIL;
-
-       pbss_network->IELength = len;
-
-       memset(ie, 0, MAX_IE_SZ);
-
-       memcpy(ie, pbuf, pbss_network->IELength);
-
-       if (pbss_network->ifmode != NL80211_IFTYPE_AP &&
-           pbss_network->ifmode != NL80211_IFTYPE_P2P_GO)
-               return _FAIL;
-
-       pbss_network->Rssi = 0;
-
-       memcpy(pbss_network->MacAddress, myid(&padapter->eeprompriv), ETH_ALEN);
-
-       /* SSID */
-       p = rtw_get_ie23a(ie, WLAN_EID_SSID, &ie_len, pbss_network->IELength);
-       if (p && ie_len > 0) {
-               memset(&pbss_network->Ssid, 0, sizeof(struct cfg80211_ssid));
-               memcpy(pbss_network->Ssid.ssid, (p + 2), ie_len);
-               pbss_network->Ssid.ssid_len = ie_len;
-       }
-
-       /* channel */
-       channel = 0;
-       p = rtw_get_ie23a(ie, WLAN_EID_DS_PARAMS, &ie_len,
-                         pbss_network->IELength);
-       if (p && ie_len > 0)
-               channel = *(p + 2);
-
-       pbss_network->DSConfig = channel;
-
-       memset(supportRate, 0, NDIS_802_11_LENGTH_RATES_EX);
-       /*  get supported rates */
-       p = rtw_get_ie23a(ie, WLAN_EID_SUPP_RATES, &ie_len,
-                         pbss_network->IELength);
-       if (p) {
-               memcpy(supportRate, p+2, ie_len);
-               supportRateNum = ie_len;
-       }
-
-       /* get ext_supported rates */
-       p = rtw_get_ie23a(ie, WLAN_EID_EXT_SUPP_RATES,
-                         &ie_len, pbss_network->IELength);
-       if (p) {
-               memcpy(supportRate+supportRateNum, p+2, ie_len);
-               supportRateNum += ie_len;
-       }
-
-       network_type = rtw_check_network_type23a(supportRate,
-                                                supportRateNum, channel);
-
-       rtw_set_supported_rate23a(pbss_network->SupportedRates, network_type);
-
-       /* parsing ERP_IE */
-       p = rtw_get_ie23a(ie, WLAN_EID_ERP_INFO, &ie_len,
-                         pbss_network->IELength);
-       if (p && ie_len > 0)
-               ERP_IE_handler23a(padapter, p);
-
-       /* update privacy/security */
-       if (pbss_network->capability & BIT(4))
-               pbss_network->Privacy = 1;
-       else
-               pbss_network->Privacy = 0;
-
-       psecuritypriv->wpa_psk = 0;
-
-       /* wpa2 */
-       group_cipher = 0; pairwise_cipher = 0;
-       psecuritypriv->wpa2_group_cipher = 0;
-       psecuritypriv->wpa2_pairwise_cipher = 0;
-       p = rtw_get_ie23a(ie, WLAN_EID_RSN, &ie_len,
-                         pbss_network->IELength);
-       if (p && ie_len > 0) {
-               if (rtw_parse_wpa2_ie23a(p, ie_len+2, &group_cipher,
-                                        &pairwise_cipher, NULL) == _SUCCESS) {
-                       psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_8021X;
-
-                       psecuritypriv->dot8021xalg = 1; /* psk, todo:802.1x */
-                       psecuritypriv->wpa_psk |= BIT(1);
-
-                       psecuritypriv->wpa2_group_cipher = group_cipher;
-                       psecuritypriv->wpa2_pairwise_cipher = pairwise_cipher;
-               }
-       }
-
-       /* wpa */
-       ie_len = 0;
-       group_cipher = 0;
-       pairwise_cipher = 0;
-       psecuritypriv->wpa_group_cipher = 0;
-       psecuritypriv->wpa_pairwise_cipher = 0;
-       for (p = ie; ; p += (ie_len + 2)) {
-               p = rtw_get_ie23a(p, WLAN_EID_VENDOR_SPECIFIC, &ie_len,
-                                 pbss_network->IELength - (ie_len + 2));
-               if ((p) && (!memcmp(p+2, RTW_WPA_OUI23A_TYPE, 4))) {
-                       if (rtw_parse_wpa_ie23a(p, ie_len+2, &group_cipher,
-                                               &pairwise_cipher, NULL) == _SUCCESS) {
-                               psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_8021X;
-
-                               /* psk,  todo:802.1x */
-                               psecuritypriv->dot8021xalg = 1;
-
-                               psecuritypriv->wpa_psk |= BIT(0);
-
-                               psecuritypriv->wpa_group_cipher = group_cipher;
-                               psecuritypriv->wpa_pairwise_cipher = pairwise_cipher;
-                       }
-                       break;
-               }
-
-               if (!p || !ie_len)
-                       break;
-       }
-
-       /* wmm */
-       ie_len = 0;
-       pmlmepriv->qos_option = 0;
-       if (pregistrypriv->wmm_enable) {
-               for (p = ie; ; p += (ie_len + 2)) {
-                       p = rtw_get_ie23a(p, WLAN_EID_VENDOR_SPECIFIC, &ie_len,
-                                         (pbss_network->IELength -
-                                          (ie_len + 2)));
-                       if ((p) && !memcmp(p+2, WMM_PARA_IE, 6)) {
-                               pmlmepriv->qos_option = 1;
-
-                               *(p + 8) |= BIT(7);/* QoS Info:support U-APSD */
-
-                               /* disable all ACM bits since the WMM admission
-                                * control is not supported
-                                */
-                               *(p + 10) &= ~BIT(4); /* BE */
-                               *(p + 14) &= ~BIT(4); /* BK */
-                               *(p + 18) &= ~BIT(4); /* VI */
-                               *(p + 22) &= ~BIT(4); /* VO */
-                               break;
-                       }
-                       if ((p == NULL) || (ie_len == 0))
-                               break;
-               }
-       }
-       /* parsing HT_CAP_IE */
-       p = rtw_get_ie23a(ie, WLAN_EID_HT_CAPABILITY, &ie_len,
-                         pbss_network->IELength);
-       if (p && ie_len > 0) {
-               u8 rf_type;
-
-               struct ieee80211_ht_cap *pht_cap = (struct ieee80211_ht_cap *)(p+2);
-
-               pHT_caps_ie = p;
-
-               ht_cap = true;
-               network_type |= WIRELESS_11_24N;
-
-               rf_type = rtl8723a_get_rf_type(padapter);
-
-               if ((psecuritypriv->wpa_pairwise_cipher & WPA_CIPHER_CCMP) ||
-                   (psecuritypriv->wpa2_pairwise_cipher & WPA_CIPHER_CCMP))
-                       pht_cap->ampdu_params_info |= (IEEE80211_HT_AMPDU_PARM_DENSITY & (0x07<<2));
-               else
-                       pht_cap->ampdu_params_info |= (IEEE80211_HT_AMPDU_PARM_DENSITY&0x00);
-
-               /* set  Max Rx AMPDU size  to 64K */
-               pht_cap->ampdu_params_info |= (IEEE80211_HT_AMPDU_PARM_FACTOR & 0x03);
-
-               if (rf_type == RF_1T1R) {
-                       pht_cap->mcs.rx_mask[0] = 0xff;
-                       pht_cap->mcs.rx_mask[1] = 0x0;
-               }
-
-               memcpy(&pmlmepriv->htpriv.ht_cap, p+2, ie_len);
-       }
-
-       /* parsing HT_INFO_IE */
-       p = rtw_get_ie23a(ie, WLAN_EID_HT_OPERATION, &ie_len,
-                         pbss_network->IELength);
-       if (p && ie_len > 0)
-               pHT_info_ie = p;
-
-       pmlmepriv->cur_network.network_type = network_type;
-
-       pmlmepriv->htpriv.ht_option = false;
-
-       /* ht_cap */
-       if (pregistrypriv->ht_enable && ht_cap) {
-               pmlmepriv->htpriv.ht_option = true;
-               pmlmepriv->qos_option = 1;
-
-               if (pregistrypriv->ampdu_enable == 1)
-                       pmlmepriv->htpriv.ampdu_enable = true;
-
-               HT_caps_handler23a(padapter, pHT_caps_ie);
-
-               HT_info_handler23a(padapter, pHT_info_ie);
-       }
-
-       pbss_network->Length = get_wlan_bssid_ex_sz(pbss_network);
-
-       /* issue beacon to start bss network */
-       start_bss_network(padapter, (u8 *)pbss_network);
-
-       /* alloc sta_info for ap itself */
-       psta = rtw_get_stainfo23a(&padapter->stapriv, pbss_network->MacAddress);
-       if (!psta) {
-               psta = rtw_alloc_stainfo23a(&padapter->stapriv,
-                                           pbss_network->MacAddress,
-                                           GFP_KERNEL);
-               if (!psta)
-                       return _FAIL;
-       }
-       /* fix bug of flush_cam_entry at STOP AP mode */
-       psta->state |= WIFI_AP_STATE;
-       rtw_indicate_connect23a(padapter);
-
-       /* for check if already set beacon */
-       pmlmepriv->cur_network.join_res = true;
-
-       return ret;
-}
-
-void rtw_set_macaddr_acl23a(struct rtw_adapter *padapter, int mode)
-{
-       struct sta_priv *pstapriv = &padapter->stapriv;
-       struct wlan_acl_pool *pacl_list = &pstapriv->acl_list;
-
-       DBG_8723A("%s, mode =%d\n", __func__, mode);
-
-       pacl_list->mode = mode;
-}
-
-static void update_bcn_erpinfo_ie(struct rtw_adapter *padapter)
-{
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       struct wlan_bssid_ex *pnetwork = &pmlmeinfo->network;
-       unsigned char *p, *ie = pnetwork->IEs;
-       u32 len = 0;
-
-       DBG_8723A("%s, ERP_enable =%d\n", __func__, pmlmeinfo->ERP_enable);
-
-       if (!pmlmeinfo->ERP_enable)
-               return;
-
-       /* parsing ERP_IE */
-       p = rtw_get_ie23a(ie, WLAN_EID_ERP_INFO, &len, pnetwork->IELength);
-       if (p && len > 0) {
-               if (pmlmepriv->num_sta_non_erp == 1)
-                       p[2] |= WLAN_ERP_NON_ERP_PRESENT |
-                               WLAN_ERP_USE_PROTECTION;
-               else
-                       p[2] &= ~(WLAN_ERP_NON_ERP_PRESENT |
-                                 WLAN_ERP_USE_PROTECTION);
-
-               if (pmlmepriv->num_sta_no_short_preamble > 0)
-                       p[2] |= WLAN_ERP_BARKER_PREAMBLE;
-               else
-                       p[2] &= ~(WLAN_ERP_BARKER_PREAMBLE);
-
-               ERP_IE_handler23a(padapter, p);
-       }
-}
-
-static void update_bcn_wpa_ie(struct rtw_adapter *padapter)
-{
-       DBG_8723A("%s\n", __func__);
-}
-
-static void update_bcn_wmm_ie(struct rtw_adapter *padapter)
-{
-       DBG_8723A("%s\n", __func__);
-}
-
-static void update_bcn_wps_ie(struct rtw_adapter *padapter)
-{
-       DBG_8723A("%s\n", __func__);
-}
-
-static void update_bcn_p2p_ie(struct rtw_adapter *padapter)
-{
-}
-
-static void update_bcn_vendor_spec_ie(struct rtw_adapter *padapter, u8 *oui)
-{
-       DBG_8723A("%s\n", __func__);
-
-       if (!memcmp(RTW_WPA_OUI23A_TYPE, oui, 4))
-               update_bcn_wpa_ie(padapter);
-       else if (!memcmp(WMM_OUI23A, oui, 4))
-               update_bcn_wmm_ie(padapter);
-       else if (!memcmp(WPS_OUI23A, oui, 4))
-               update_bcn_wps_ie(padapter);
-       else if (!memcmp(P2P_OUI23A, oui, 4))
-               update_bcn_p2p_ie(padapter);
-       else
-               DBG_8723A("unknown OUI type!\n");
-}
-
-void update_beacon23a(struct rtw_adapter *padapter, u8 ie_id, u8 *oui, u8 tx)
-{
-       struct mlme_priv *pmlmepriv;
-       struct mlme_ext_priv *pmlmeext;
-       /* struct mlme_ext_info *pmlmeinfo; */
-
-       /* DBG_8723A("%s\n", __func__); */
-
-       if (!padapter)
-               return;
-
-       pmlmepriv = &padapter->mlmepriv;
-       pmlmeext = &padapter->mlmeextpriv;
-       /* pmlmeinfo = &pmlmeext->mlmext_info; */
-
-       if (false == pmlmeext->bstart_bss)
-               return;
-
-       spin_lock_bh(&pmlmepriv->bcn_update_lock);
-
-       switch (ie_id) {
-       case WLAN_EID_TIM:
-               update_BCNTIM(padapter);
-               break;
-
-       case WLAN_EID_ERP_INFO:
-               update_bcn_erpinfo_ie(padapter);
-               break;
-
-       case WLAN_EID_VENDOR_SPECIFIC:
-               update_bcn_vendor_spec_ie(padapter, oui);
-               break;
-
-       default:
-               break;
-       }
-
-       pmlmepriv->update_bcn = true;
-
-       spin_unlock_bh(&pmlmepriv->bcn_update_lock);
-
-       if (tx)
-               set_tx_beacon_cmd23a(padapter);
-}
-
-/*
- * op_mode
- * Set to 0 (HT pure) under the following conditions
- *     - all STAs in the BSS are 20/40 MHz HT in 20/40 MHz BSS or
- *     - all STAs in the BSS are 20 MHz HT in 20 MHz BSS
- * Set to 1 (HT non-member protection) if there may be non-HT STAs
- *     in both the primary and the secondary channel
- * Set to 2 if only HT STAs are associated in BSS,
- *     however and at least one 20 MHz HT STA is associated
- * Set to 3 (HT mixed mode) when one or more non-HT STAs are associated
- *     (currently non-GF HT station is considered as non-HT STA also)
-*/
-static int rtw_ht_operation_update(struct rtw_adapter *padapter)
-{
-       u16 cur_op_mode, new_op_mode;
-       int op_mode_changes = 0;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct ht_priv *phtpriv_ap = &pmlmepriv->htpriv;
-
-       if (pmlmepriv->htpriv.ht_option)
-               return 0;
-
-       /* if (!iface->conf->ieee80211n || iface->conf->ht_op_mode_fixed) */
-       /*      return 0; */
-
-       DBG_8723A("%s current operation mode = 0x%X\n",
-                  __func__, pmlmepriv->ht_op_mode);
-
-       if (!(pmlmepriv->ht_op_mode & IEEE80211_HT_OP_MODE_NON_GF_STA_PRSNT)
-           && pmlmepriv->num_sta_ht_no_gf) {
-               pmlmepriv->ht_op_mode |=
-                       IEEE80211_HT_OP_MODE_NON_GF_STA_PRSNT;
-               op_mode_changes++;
-       } else if ((pmlmepriv->ht_op_mode &
-                   IEEE80211_HT_OP_MODE_NON_GF_STA_PRSNT) &&
-                  pmlmepriv->num_sta_ht_no_gf == 0) {
-               pmlmepriv->ht_op_mode &=
-                       ~IEEE80211_HT_OP_MODE_NON_GF_STA_PRSNT;
-               op_mode_changes++;
-       }
-
-       if (!(pmlmepriv->ht_op_mode & IEEE80211_HT_OP_MODE_NON_HT_STA_PRSNT) &&
-           (pmlmepriv->num_sta_no_ht || pmlmepriv->olbc_ht)) {
-               pmlmepriv->ht_op_mode |= IEEE80211_HT_OP_MODE_NON_HT_STA_PRSNT;
-               op_mode_changes++;
-       } else if ((pmlmepriv->ht_op_mode &
-                   IEEE80211_HT_OP_MODE_NON_HT_STA_PRSNT) &&
-                  (pmlmepriv->num_sta_no_ht == 0 && !pmlmepriv->olbc_ht)) {
-               pmlmepriv->ht_op_mode &=
-                       ~IEEE80211_HT_OP_MODE_NON_HT_STA_PRSNT;
-               op_mode_changes++;
-       }
-
-       /*
-        * Note: currently we switch to the MIXED op mode if HT non-greenfield
-        * station is associated. Probably it's a theoretical case, since
-        * it looks like all known HT STAs support greenfield.
-        */
-       if (pmlmepriv->num_sta_no_ht ||
-           (pmlmepriv->ht_op_mode & IEEE80211_HT_OP_MODE_NON_GF_STA_PRSNT))
-               new_op_mode = IEEE80211_HT_OP_MODE_PROTECTION_NONHT_MIXED;
-       else if ((le16_to_cpu(phtpriv_ap->ht_cap.cap_info) &
-                 IEEE80211_HT_CAP_SUP_WIDTH_20_40) &&
-                pmlmepriv->num_sta_ht_20mhz)
-               new_op_mode = IEEE80211_HT_OP_MODE_PROTECTION_20MHZ;
-       else if (pmlmepriv->olbc_ht)
-               new_op_mode = IEEE80211_HT_OP_MODE_PROTECTION_NONMEMBER;
-       else
-               new_op_mode = IEEE80211_HT_OP_MODE_PROTECTION_NONE;
-
-       cur_op_mode = pmlmepriv->ht_op_mode & IEEE80211_HT_OP_MODE_PROTECTION;
-       if (cur_op_mode != new_op_mode) {
-               pmlmepriv->ht_op_mode &= ~IEEE80211_HT_OP_MODE_PROTECTION;
-               pmlmepriv->ht_op_mode |= new_op_mode;
-               op_mode_changes++;
-       }
-
-       DBG_8723A("%s new operation mode = 0x%X changes =%d\n",
-                  __func__, pmlmepriv->ht_op_mode, op_mode_changes);
-
-       return op_mode_changes;
-}
-
-void associated_clients_update23a(struct rtw_adapter *padapter, u8 updated)
-{
-       /* update associated stations cap. */
-       if (updated == true) {
-               struct list_head *phead;
-               struct sta_info *psta, *ptmp;
-               struct sta_priv *pstapriv = &padapter->stapriv;
-
-               spin_lock_bh(&pstapriv->asoc_list_lock);
-               phead = &pstapriv->asoc_list;
-               list_for_each_entry_safe(psta, ptmp, phead, asoc_list)
-                       VCS_update23a(padapter, psta);
-               spin_unlock_bh(&pstapriv->asoc_list_lock);
-       }
-}
-
-/* called > TSR LEVEL for USB or SDIO Interface */
-void bss_cap_update_on_sta_join23a(struct rtw_adapter *padapter, struct sta_info *psta)
-{
-       u8 beacon_updated = false;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-
-       if (!(psta->flags & WLAN_STA_SHORT_PREAMBLE)) {
-               if (!psta->no_short_preamble_set) {
-                       psta->no_short_preamble_set = 1;
-
-                       pmlmepriv->num_sta_no_short_preamble++;
-
-                       if ((pmlmeext->cur_wireless_mode > WIRELESS_11B) &&
-                               (pmlmepriv->num_sta_no_short_preamble == 1)) {
-                               beacon_updated = true;
-                               update_beacon23a(padapter, 0xFF, NULL, true);
-                       }
-
-               }
-       } else {
-               if (psta->no_short_preamble_set) {
-                       psta->no_short_preamble_set = 0;
-
-                       pmlmepriv->num_sta_no_short_preamble--;
-
-                       if ((pmlmeext->cur_wireless_mode > WIRELESS_11B) &&
-                               (pmlmepriv->num_sta_no_short_preamble == 0)) {
-                               beacon_updated = true;
-                               update_beacon23a(padapter, 0xFF, NULL, true);
-                       }
-
-               }
-       }
-
-       if (psta->flags & WLAN_STA_NONERP) {
-               if (!psta->nonerp_set) {
-                       psta->nonerp_set = 1;
-
-                       pmlmepriv->num_sta_non_erp++;
-
-                       if (pmlmepriv->num_sta_non_erp == 1) {
-                               beacon_updated = true;
-                               update_beacon23a(padapter, WLAN_EID_ERP_INFO, NULL, true);
-                       }
-               }
-
-       } else {
-               if (psta->nonerp_set) {
-                       psta->nonerp_set = 0;
-
-                       pmlmepriv->num_sta_non_erp--;
-
-                       if (pmlmepriv->num_sta_non_erp == 0) {
-                               beacon_updated = true;
-                               update_beacon23a(padapter, WLAN_EID_ERP_INFO, NULL, true);
-                       }
-               }
-
-       }
-
-       if (!(psta->capability & WLAN_CAPABILITY_SHORT_SLOT_TIME)) {
-               if (!psta->no_short_slot_time_set) {
-                       psta->no_short_slot_time_set = 1;
-
-                       pmlmepriv->num_sta_no_short_slot_time++;
-
-                       if ((pmlmeext->cur_wireless_mode > WIRELESS_11B) &&
-                                (pmlmepriv->num_sta_no_short_slot_time == 1)) {
-                               beacon_updated = true;
-                               update_beacon23a(padapter, 0xFF, NULL, true);
-                       }
-
-               }
-       } else {
-               if (psta->no_short_slot_time_set) {
-                       psta->no_short_slot_time_set = 0;
-
-                       pmlmepriv->num_sta_no_short_slot_time--;
-
-                       if ((pmlmeext->cur_wireless_mode > WIRELESS_11B) &&
-                                (pmlmepriv->num_sta_no_short_slot_time == 0)) {
-                               beacon_updated = true;
-                               update_beacon23a(padapter, 0xFF, NULL, true);
-                       }
-               }
-       }
-
-       if (psta->flags & WLAN_STA_HT) {
-               u16 ht_capab = le16_to_cpu(psta->htpriv.ht_cap.cap_info);
-
-               DBG_8723A("HT: STA %pM HT Capabilities Info: 0x%04x\n",
-                         psta->hwaddr, ht_capab);
-
-               if (psta->no_ht_set) {
-                       psta->no_ht_set = 0;
-                       pmlmepriv->num_sta_no_ht--;
-               }
-
-               if ((ht_capab & IEEE80211_HT_CAP_GRN_FLD) == 0) {
-                       if (!psta->no_ht_gf_set) {
-                               psta->no_ht_gf_set = 1;
-                               pmlmepriv->num_sta_ht_no_gf++;
-                       }
-                       DBG_8723A("%s STA %pM - no greenfield, num of non-gf stations %d\n",
-                                 __func__, psta->hwaddr,
-                                 pmlmepriv->num_sta_ht_no_gf);
-               }
-
-               if ((ht_capab & IEEE80211_HT_CAP_SUP_WIDTH_20_40) == 0) {
-                       if (!psta->ht_20mhz_set) {
-                               psta->ht_20mhz_set = 1;
-                               pmlmepriv->num_sta_ht_20mhz++;
-                       }
-                       DBG_8723A("%s STA %pM - 20 MHz HT, num of 20MHz HT STAs %d\n",
-                                 __func__, psta->hwaddr,
-                                 pmlmepriv->num_sta_ht_20mhz);
-               }
-
-       } else {
-               if (!psta->no_ht_set) {
-                       psta->no_ht_set = 1;
-                       pmlmepriv->num_sta_no_ht++;
-               }
-               if (pmlmepriv->htpriv.ht_option) {
-                       DBG_8723A("%s STA %pM - no HT, num of non-HT stations %d\n",
-                                 __func__, psta->hwaddr,
-                                 pmlmepriv->num_sta_no_ht);
-               }
-       }
-
-       if (rtw_ht_operation_update(padapter) > 0) {
-               update_beacon23a(padapter, WLAN_EID_HT_CAPABILITY, NULL, false);
-               update_beacon23a(padapter, WLAN_EID_HT_OPERATION, NULL, true);
-       }
-
-       /* update associated stations cap. */
-       associated_clients_update23a(padapter,  beacon_updated);
-
-       DBG_8723A("%s, updated =%d\n", __func__, beacon_updated);
-}
-
-u8 bss_cap_update_on_sta_leave23a(struct rtw_adapter *padapter, struct sta_info *psta)
-{
-       u8 beacon_updated = false;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-
-       if (!psta)
-               return beacon_updated;
-
-       if (psta->no_short_preamble_set) {
-               psta->no_short_preamble_set = 0;
-               pmlmepriv->num_sta_no_short_preamble--;
-               if (pmlmeext->cur_wireless_mode > WIRELESS_11B
-                   && pmlmepriv->num_sta_no_short_preamble == 0) {
-                       beacon_updated = true;
-                       update_beacon23a(padapter, 0xFF, NULL, true);
-               }
-       }
-
-       if (psta->nonerp_set) {
-               psta->nonerp_set = 0;
-               pmlmepriv->num_sta_non_erp--;
-               if (pmlmepriv->num_sta_non_erp == 0) {
-                       beacon_updated = true;
-                       update_beacon23a(padapter, WLAN_EID_ERP_INFO,
-                                        NULL, true);
-               }
-       }
-
-       if (psta->no_short_slot_time_set) {
-               psta->no_short_slot_time_set = 0;
-               pmlmepriv->num_sta_no_short_slot_time--;
-               if (pmlmeext->cur_wireless_mode > WIRELESS_11B
-                   && pmlmepriv->num_sta_no_short_slot_time == 0) {
-                       beacon_updated = true;
-                       update_beacon23a(padapter, 0xFF, NULL, true);
-               }
-       }
-
-       if (psta->no_ht_gf_set) {
-               psta->no_ht_gf_set = 0;
-               pmlmepriv->num_sta_ht_no_gf--;
-       }
-
-       if (psta->no_ht_set) {
-               psta->no_ht_set = 0;
-               pmlmepriv->num_sta_no_ht--;
-       }
-
-       if (psta->ht_20mhz_set) {
-               psta->ht_20mhz_set = 0;
-               pmlmepriv->num_sta_ht_20mhz--;
-       }
-
-       if (rtw_ht_operation_update(padapter) > 0) {
-               update_beacon23a(padapter, WLAN_EID_HT_CAPABILITY, NULL, false);
-               update_beacon23a(padapter, WLAN_EID_HT_OPERATION, NULL, true);
-       }
-
-       /* update associated stations cap. */
-
-       DBG_8723A("%s, updated =%d\n", __func__, beacon_updated);
-
-       return beacon_updated;
-}
-
-u8 ap_free_sta23a(struct rtw_adapter *padapter, struct sta_info *psta, bool active, u16 reason)
-{
-       struct sta_priv *pstapriv = &padapter->stapriv;
-       u8 beacon_updated = false;
-
-       if (!psta)
-               return beacon_updated;
-
-       if (active) {
-               /* tear down Rx AMPDU */
-               send_delba23a(padapter, 0, psta->hwaddr); /* recipient */
-
-               /* tear down TX AMPDU */
-               send_delba23a(padapter, 1, psta->hwaddr); /* originator */
-
-               issue_deauth23a(padapter, psta->hwaddr, reason);
-       }
-
-       psta->htpriv.agg_enable_bitmap = 0x0;    /* reset */
-       psta->htpriv.candidate_tid_bitmap = 0x0; /* reset */
-
-       /* report_del_sta_event23a(padapter, psta->hwaddr, reason); */
-
-       /* clear cam entry / key */
-       /* clear_cam_entry23a(padapter, (psta->mac_id + 3)); */
-       rtw_clearstakey_cmd23a(padapter, (u8 *)psta, (u8)(psta->mac_id + 3),
-                              true);
-
-       spin_lock_bh(&psta->lock);
-       psta->state &= ~_FW_LINKED;
-       spin_unlock_bh(&psta->lock);
-
-       rtw_cfg80211_indicate_sta_disassoc(padapter, psta->hwaddr, reason);
-
-       report_del_sta_event23a(padapter, psta->hwaddr, reason);
-
-       beacon_updated = bss_cap_update_on_sta_leave23a(padapter, psta);
-
-       spin_lock_bh(&pstapriv->sta_hash_lock);
-       rtw_free_stainfo23a(padapter, psta);
-       spin_unlock_bh(&pstapriv->sta_hash_lock);
-
-       return beacon_updated;
-}
-
-int rtw_sta_flush23a(struct rtw_adapter *padapter)
-{
-       struct list_head *phead;
-       struct sta_info *psta, *ptmp;
-       struct sta_priv *pstapriv = &padapter->stapriv;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       u8 bc_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
-       u8 chk_alive_num = 0;
-       struct sta_info *chk_alive_list[NUM_STA];
-       int i;
-
-       DBG_8723A("%s(%s)\n", __func__, padapter->pnetdev->name);
-
-       if ((pmlmeinfo->state&0x03) != MSR_AP)
-               return 0;
-
-       spin_lock_bh(&pstapriv->asoc_list_lock);
-       phead = &pstapriv->asoc_list;
-       list_for_each_entry_safe(psta, ptmp, phead, asoc_list) {
-               /* Remove sta from asoc_list */
-               list_del_init(&psta->asoc_list);
-               pstapriv->asoc_list_cnt--;
-
-               /* Keep sta for ap_free_sta23a() beyond this asoc_list loop */
-               chk_alive_list[chk_alive_num++] = psta;
-       }
-       spin_unlock_bh(&pstapriv->asoc_list_lock);
-
-       /* For each sta in chk_alive_list, call ap_free_sta23a */
-       for (i = 0; i < chk_alive_num; i++)
-               ap_free_sta23a(padapter, chk_alive_list[i], true,
-                              WLAN_REASON_DEAUTH_LEAVING);
-
-       issue_deauth23a(padapter, bc_addr, WLAN_REASON_DEAUTH_LEAVING);
-
-       associated_clients_update23a(padapter, true);
-
-       return 0;
-}
-
-/* called > TSR LEVEL for USB or SDIO Interface */
-void sta_info_update23a(struct rtw_adapter *padapter, struct sta_info *psta)
-{
-       int flags = psta->flags;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-
-       /* update wmm cap. */
-       if (WLAN_STA_WME&flags)
-               psta->qos_option = 1;
-       else
-               psta->qos_option = 0;
-
-       if (pmlmepriv->qos_option == 0)
-               psta->qos_option = 0;
-
-       /* update 802.11n ht cap. */
-       if (WLAN_STA_HT&flags) {
-               psta->htpriv.ht_option = true;
-               psta->qos_option = 1;
-       } else {
-               psta->htpriv.ht_option = false;
-       }
-
-       if (!pmlmepriv->htpriv.ht_option)
-               psta->htpriv.ht_option = false;
-
-       update_sta_info23a_apmode23a(padapter, psta);
-}
-
-/* called >= TSR LEVEL for USB or SDIO Interface */
-void ap_sta_info_defer_update23a(struct rtw_adapter *padapter, struct sta_info *psta)
-{
-       if (psta->state & _FW_LINKED) {
-               /* add ratid */
-               add_RATid23a(padapter, psta, 0);/* DM_RATR_STA_INIT */
-       }
-}
-
-/* restore hw setting from sw data structures */
-void rtw_ap_restore_network(struct rtw_adapter *padapter)
-{
-       struct mlme_priv *mlmepriv = &padapter->mlmepriv;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct sta_priv *pstapriv = &padapter->stapriv;
-       struct sta_info *psta, *ptmp;
-       struct security_priv *psecuritypriv = &padapter->securitypriv;
-       struct list_head *phead;
-       u8 chk_alive_num = 0;
-       struct sta_info *chk_alive_list[NUM_STA];
-       int i;
-
-       rtw_setopmode_cmd23a(padapter, NL80211_IFTYPE_AP);
-
-       set_channel_bwmode23a(padapter, pmlmeext->cur_channel, pmlmeext->cur_ch_offset, pmlmeext->cur_bwmode);
-
-       start_bss_network(padapter, (u8 *)&mlmepriv->cur_network.network);
-
-       if (padapter->securitypriv.dot11PrivacyAlgrthm ==
-           WLAN_CIPHER_SUITE_TKIP ||
-           padapter->securitypriv.dot11PrivacyAlgrthm ==
-           WLAN_CIPHER_SUITE_CCMP) {
-               /* restore group key, WEP keys is restored in ips_leave23a() */
-               rtw_set_key23a(padapter, psecuritypriv,
-                              psecuritypriv->dot118021XGrpKeyid, 0);
-       }
-
-       /* per sta pairwise key and settings */
-       if (padapter->securitypriv.dot11PrivacyAlgrthm !=
-           WLAN_CIPHER_SUITE_TKIP &&
-           padapter->securitypriv.dot11PrivacyAlgrthm !=
-           WLAN_CIPHER_SUITE_CCMP) {
-               return;
-       }
-
-       spin_lock_bh(&pstapriv->asoc_list_lock);
-       phead = &pstapriv->asoc_list;
-       list_for_each_entry_safe(psta, ptmp, phead, asoc_list)
-               chk_alive_list[chk_alive_num++] = psta;
-       spin_unlock_bh(&pstapriv->asoc_list_lock);
-
-       for (i = 0; i < chk_alive_num; i++) {
-               psta = chk_alive_list[i];
-
-               if (psta->state & _FW_LINKED) {
-                       Update_RA_Entry23a(padapter, psta);
-                       /* pairwise key */
-                       rtw_setstakey_cmd23a(padapter, (unsigned char *)psta, true);
-               }
-       }
-}
-
-void start_ap_mode23a(struct rtw_adapter *padapter)
-{
-       int i;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct sta_priv *pstapriv = &padapter->stapriv;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct wlan_acl_pool *pacl_list = &pstapriv->acl_list;
-
-       pmlmepriv->update_bcn = false;
-
-       /* init_mlme_ap_info23a(padapter); */
-       pmlmeext->bstart_bss = false;
-
-       pmlmepriv->num_sta_non_erp = 0;
-
-       pmlmepriv->num_sta_no_short_slot_time = 0;
-
-       pmlmepriv->num_sta_no_short_preamble = 0;
-
-       pmlmepriv->num_sta_ht_no_gf = 0;
-       pmlmepriv->num_sta_no_ht = 0;
-       pmlmepriv->num_sta_ht_20mhz = 0;
-
-       pmlmepriv->olbc = false;
-
-       pmlmepriv->olbc_ht = false;
-
-       pmlmepriv->ht_op_mode = 0;
-
-       for (i = 0; i < NUM_STA; i++)
-               pstapriv->sta_aid[i] = NULL;
-
-       /* for ACL */
-       INIT_LIST_HEAD(&pacl_list->acl_node_q.queue);
-       pacl_list->num = 0;
-       pacl_list->mode = 0;
-       for (i = 0; i < NUM_ACL; i++) {
-               INIT_LIST_HEAD(&pacl_list->aclnode[i].list);
-               pacl_list->aclnode[i].valid = false;
-       }
-}
-
-void stop_ap_mode23a(struct rtw_adapter *padapter)
-{
-       struct list_head *phead;
-       struct rtw_wlan_acl_node *paclnode, *ptmp;
-       struct sta_info *psta = NULL;
-       struct sta_priv *pstapriv = &padapter->stapriv;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct wlan_acl_pool *pacl_list = &pstapriv->acl_list;
-       struct rtw_queue *pacl_node_q = &pacl_list->acl_node_q;
-
-       pmlmepriv->update_bcn = false;
-       pmlmeext->bstart_bss = false;
-
-       /*
-        * reset and init security priv , this can
-        * refine with rtw_reset_securitypriv23a
-        */
-       memset((unsigned char *)&padapter->securitypriv, 0, sizeof(struct security_priv));
-       padapter->securitypriv.ndisauthtype = Ndis802_11AuthModeOpen;
-       padapter->securitypriv.ndisencryptstatus = Ndis802_11WEPDisabled;
-
-       /* for ACL */
-       spin_lock_bh(&pacl_node_q->lock);
-       phead = get_list_head(pacl_node_q);
-       list_for_each_entry_safe(paclnode, ptmp, phead, list) {
-               if (paclnode->valid == true) {
-                       paclnode->valid = false;
-                       list_del_init(&paclnode->list);
-                       pacl_list->num--;
-               }
-       }
-       spin_unlock_bh(&pacl_node_q->lock);
-
-       DBG_8723A("%s, free acl_node_queue, num =%d\n",
-                 __func__, pacl_list->num);
-
-       rtw_sta_flush23a(padapter);
-
-       /* free_assoc_sta_resources */
-       rtw_free_all_stainfo23a(padapter);
-
-       psta = rtw_get_bcmc_stainfo23a(padapter);
-       spin_lock_bh(&pstapriv->sta_hash_lock);
-       rtw_free_stainfo23a(padapter, psta);
-       spin_unlock_bh(&pstapriv->sta_hash_lock);
-
-       rtw_init_bcmc_stainfo23a(padapter);
-
-       rtw23a_free_mlme_priv_ie_data(pmlmepriv);
-}
diff --git a/drivers/staging/rtl8723au/core/rtw_cmd.c b/drivers/staging/rtl8723au/core/rtw_cmd.c
deleted file mode 100644 (file)
index cd4e0f0..0000000
+++ /dev/null
@@ -1,1470 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#define _RTW_CMD_C_
-
-#include <osdep_service.h>
-#include <drv_types.h>
-#include <recv_osdep.h>
-#include <mlme_osdep.h>
-#include <rtl8723a_cmd.h>
-#include <rtw_sreset.h>
-
-static struct cmd_hdl wlancmds[] = {
-       GEN_DRV_CMD_HANDLER(0, NULL) /*0*/
-       GEN_DRV_CMD_HANDLER(0, NULL)
-       GEN_DRV_CMD_HANDLER(0, NULL)
-       GEN_DRV_CMD_HANDLER(0, NULL)
-       GEN_DRV_CMD_HANDLER(0, NULL)
-       GEN_DRV_CMD_HANDLER(0, NULL)
-       GEN_MLME_EXT_HANDLER(0, NULL)
-       GEN_MLME_EXT_HANDLER(0, NULL)
-       GEN_MLME_EXT_HANDLER(0, NULL)
-       GEN_MLME_EXT_HANDLER(0, NULL)
-       GEN_MLME_EXT_HANDLER(0, NULL) /*10*/
-       GEN_MLME_EXT_HANDLER(0, NULL)
-       GEN_MLME_EXT_HANDLER(0, NULL)
-       GEN_MLME_EXT_HANDLER(0, NULL)
-       GEN_MLME_EXT_HANDLER(sizeof(struct wlan_bssid_ex), join_cmd_hdl23a) /*14*/
-       GEN_MLME_EXT_HANDLER(sizeof(struct disconnect_parm), disconnect_hdl23a)
-       GEN_MLME_EXT_HANDLER(sizeof(struct wlan_bssid_ex), createbss_hdl23a)
-       GEN_MLME_EXT_HANDLER(sizeof(struct setopmode_parm), setopmode_hdl23a)
-       GEN_MLME_EXT_HANDLER(sizeof(struct sitesurvey_parm), sitesurvey_cmd_hdl23a) /*18*/
-       GEN_MLME_EXT_HANDLER(sizeof(struct setauth_parm), setauth_hdl23a)
-       GEN_MLME_EXT_HANDLER(sizeof(struct setkey_parm), setkey_hdl23a) /*20*/
-       GEN_MLME_EXT_HANDLER(sizeof(struct set_stakey_parm), set_stakey_hdl23a)
-       GEN_MLME_EXT_HANDLER(sizeof(struct set_assocsta_parm), NULL)
-       GEN_MLME_EXT_HANDLER(sizeof(struct del_assocsta_parm), NULL)
-       GEN_MLME_EXT_HANDLER(sizeof(struct setstapwrstate_parm), NULL)
-       GEN_MLME_EXT_HANDLER(sizeof(struct setbasicrate_parm), NULL)
-       GEN_MLME_EXT_HANDLER(sizeof(struct getbasicrate_parm), NULL)
-       GEN_MLME_EXT_HANDLER(sizeof(struct setdatarate_parm), NULL)
-       GEN_MLME_EXT_HANDLER(sizeof(struct getdatarate_parm), NULL)
-       GEN_MLME_EXT_HANDLER(sizeof(struct setphyinfo_parm), NULL)
-       GEN_MLME_EXT_HANDLER(sizeof(struct getphyinfo_parm), NULL)  /*30*/
-       GEN_MLME_EXT_HANDLER(sizeof(struct setphy_parm), NULL)
-       GEN_MLME_EXT_HANDLER(sizeof(struct getphy_parm), NULL)
-       GEN_MLME_EXT_HANDLER(0, NULL)
-       GEN_MLME_EXT_HANDLER(0, NULL)
-       GEN_MLME_EXT_HANDLER(0, NULL)
-       GEN_MLME_EXT_HANDLER(0, NULL)
-       GEN_MLME_EXT_HANDLER(0, NULL)
-       GEN_MLME_EXT_HANDLER(0, NULL)
-       GEN_MLME_EXT_HANDLER(0, NULL)
-       GEN_MLME_EXT_HANDLER(0, NULL)   /*40*/
-       GEN_MLME_EXT_HANDLER(0, NULL)
-       GEN_MLME_EXT_HANDLER(0, NULL)
-       GEN_MLME_EXT_HANDLER(0, NULL)
-       GEN_MLME_EXT_HANDLER(0, NULL)
-       GEN_MLME_EXT_HANDLER(sizeof(struct addBaReq_parm), add_ba_hdl23a)
-       GEN_MLME_EXT_HANDLER(sizeof(struct set_ch_parm), set_ch_hdl23a) /* 46 */
-       GEN_MLME_EXT_HANDLER(0, NULL)
-       GEN_MLME_EXT_HANDLER(0, NULL)
-       GEN_MLME_EXT_HANDLER(0, NULL)
-       GEN_MLME_EXT_HANDLER(0, NULL) /*50*/
-       GEN_MLME_EXT_HANDLER(0, NULL)
-       GEN_MLME_EXT_HANDLER(0, NULL)
-       GEN_MLME_EXT_HANDLER(0, NULL)
-       GEN_MLME_EXT_HANDLER(0, NULL)
-       GEN_MLME_EXT_HANDLER(sizeof(struct Tx_Beacon_param), tx_beacon_hdl23a) /*55*/
-
-       GEN_MLME_EXT_HANDLER(0, mlme_evt_hdl23a) /*56*/
-       GEN_MLME_EXT_HANDLER(0, rtw_drvextra_cmd_hdl23a) /*57*/
-
-       GEN_MLME_EXT_HANDLER(0, h2c_msg_hdl23a) /*58*/
-       GEN_MLME_EXT_HANDLER(sizeof(struct SetChannelPlan_param), set_chplan_hdl23a) /*59*/
-       GEN_MLME_EXT_HANDLER(sizeof(struct LedBlink_param), led_blink_hdl23a) /*60*/
-
-       GEN_MLME_EXT_HANDLER(sizeof(struct SetChannelSwitch_param), set_csa_hdl23a) /*61*/
-       GEN_MLME_EXT_HANDLER(sizeof(struct TDLSoption_param), tdls_hdl23a) /*62*/
-};
-
-struct _cmd_callback   rtw_cmd_callback[] = {
-       {GEN_CMD_CODE(_Read_MACREG), NULL}, /*0*/
-       {GEN_CMD_CODE(_Write_MACREG), NULL},
-       {GEN_CMD_CODE(_Read_BBREG), &rtw_getbbrfreg_cmdrsp_callback23a},
-       {GEN_CMD_CODE(_Write_BBREG), NULL},
-       {GEN_CMD_CODE(_Read_RFREG), &rtw_getbbrfreg_cmdrsp_callback23a},
-       {GEN_CMD_CODE(_Write_RFREG), NULL}, /*5*/
-       {GEN_CMD_CODE(_Read_EEPROM), NULL},
-       {GEN_CMD_CODE(_Write_EEPROM), NULL},
-       {GEN_CMD_CODE(_Read_EFUSE), NULL},
-       {GEN_CMD_CODE(_Write_EFUSE), NULL},
-
-       {GEN_CMD_CODE(_Read_CAM),       NULL},  /*10*/
-       {GEN_CMD_CODE(_Write_CAM),       NULL},
-       {GEN_CMD_CODE(_setBCNITV), NULL},
-       {GEN_CMD_CODE(_setMBIDCFG), NULL},
-       {GEN_CMD_CODE(_JoinBss), &rtw_joinbss_cmd23a_callback},  /*14*/
-       {GEN_CMD_CODE(_DisConnect), &rtw_disassoc_cmd23a_callback}, /*15*/
-       {GEN_CMD_CODE(_CreateBss), &rtw_createbss_cmd23a_callback},
-       {GEN_CMD_CODE(_SetOpMode), NULL},
-       {GEN_CMD_CODE(_SiteSurvey), &rtw_survey_cmd_callback23a}, /*18*/
-       {GEN_CMD_CODE(_SetAuth), NULL},
-
-       {GEN_CMD_CODE(_SetKey), NULL},  /*20*/
-       {GEN_CMD_CODE(_SetStaKey), &rtw_setstaKey_cmdrsp_callback23a},
-       {GEN_CMD_CODE(_SetAssocSta), &rtw_setassocsta_cmdrsp_callback23a},
-       {GEN_CMD_CODE(_DelAssocSta), NULL},
-       {GEN_CMD_CODE(_SetStaPwrState), NULL},
-       {GEN_CMD_CODE(_SetBasicRate), NULL}, /*25*/
-       {GEN_CMD_CODE(_GetBasicRate), NULL},
-       {GEN_CMD_CODE(_SetDataRate), NULL},
-       {GEN_CMD_CODE(_GetDataRate), NULL},
-       {GEN_CMD_CODE(_SetPhyInfo), NULL},
-
-       {GEN_CMD_CODE(_GetPhyInfo), NULL}, /*30*/
-       {GEN_CMD_CODE(_SetPhy), NULL},
-       {GEN_CMD_CODE(_GetPhy), NULL},
-       {GEN_CMD_CODE(_readRssi), NULL},
-       {GEN_CMD_CODE(_readGain), NULL},
-       {GEN_CMD_CODE(_SetAtim), NULL}, /*35*/
-       {GEN_CMD_CODE(_SetPwrMode), NULL},
-       {GEN_CMD_CODE(_JoinbssRpt), NULL},
-       {GEN_CMD_CODE(_SetRaTable), NULL},
-       {GEN_CMD_CODE(_GetRaTable), NULL},
-
-       {GEN_CMD_CODE(_GetCCXReport), NULL}, /*40*/
-       {GEN_CMD_CODE(_GetDTMReport),   NULL},
-       {GEN_CMD_CODE(_GetTXRateStatistics), NULL},
-       {GEN_CMD_CODE(_SetUsbSuspend), NULL},
-       {GEN_CMD_CODE(_SetH2cLbk), NULL},
-       {GEN_CMD_CODE(_AddBAReq), NULL}, /*45*/
-       {GEN_CMD_CODE(_SetChannel), NULL},              /*46*/
-       {GEN_CMD_CODE(_SetTxPower), NULL},
-       {GEN_CMD_CODE(_SwitchAntenna), NULL},
-       {GEN_CMD_CODE(_SetCrystalCap), NULL},
-       {GEN_CMD_CODE(_SetSingleCarrierTx), NULL},      /*50*/
-
-       {GEN_CMD_CODE(_SetSingleToneTx), NULL}, /*51*/
-       {GEN_CMD_CODE(_SetCarrierSuppressionTx), NULL},
-       {GEN_CMD_CODE(_SetContinuousTx), NULL},
-       {GEN_CMD_CODE(_SwitchBandwidth), NULL},         /*54*/
-       {GEN_CMD_CODE(_TX_Beacon), NULL},/*55*/
-
-       {GEN_CMD_CODE(_Set_MLME_EVT), NULL},/*56*/
-       {GEN_CMD_CODE(_Set_Drv_Extra), NULL},/*57*/
-       {GEN_CMD_CODE(_Set_H2C_MSG), NULL},/*58*/
-       {GEN_CMD_CODE(_SetChannelPlan), NULL},/*59*/
-       {GEN_CMD_CODE(_LedBlink), NULL},/*60*/
-
-       {GEN_CMD_CODE(_SetChannelSwitch), NULL},/*61*/
-       {GEN_CMD_CODE(_TDLS), NULL},/*62*/
-};
-
-/*
-Caller and the rtw_cmd_thread23a can protect cmd_q by spin_lock.
-No irqsave is necessary.
-*/
-
-int rtw_init_cmd_priv23a(struct cmd_priv *pcmdpriv)
-{
-       int res = _SUCCESS;
-
-       pcmdpriv->cmd_issued_cnt = 0;
-       pcmdpriv->cmd_done_cnt = 0;
-       pcmdpriv->rsp_cnt = 0;
-
-       pcmdpriv->wq = alloc_workqueue("rtl8723au_cmd", 0, 1);
-       if (!pcmdpriv->wq)
-               res = _FAIL;
-
-       return res;
-}
-
-/* forward definition */
-
-static void rtw_irq_work(struct work_struct *work);
-
-u32 rtw_init_evt_priv23a(struct evt_priv *pevtpriv)
-{
-       pevtpriv->wq = alloc_workqueue("rtl8723au_evt", 0, 1);
-
-       INIT_WORK(&pevtpriv->irq_wk, rtw_irq_work);
-
-       return _SUCCESS;
-}
-
-void rtw_free_evt_priv23a(struct evt_priv *pevtpriv)
-{
-       cancel_work_sync(&pevtpriv->irq_wk);
-}
-
-static int rtw_cmd_filter(struct cmd_priv *pcmdpriv, struct cmd_obj *cmd_obj)
-{
-       /* set to true to allow enqueuing cmd when hw_init_completed is false */
-       u8 bAllow = false;
-
-       if (cmd_obj->cmdcode == GEN_CMD_CODE(_SetChannelPlan))
-               bAllow = true;
-
-       if (pcmdpriv->padapter->hw_init_completed == false && bAllow == false)
-               return _FAIL;
-       return _SUCCESS;
-}
-
-static void rtw_cmd_work(struct work_struct *work);
-
-int rtw_enqueue_cmd23a(struct cmd_priv *pcmdpriv, struct cmd_obj *cmd_obj)
-{
-       int res = _FAIL;
-
-       if (!cmd_obj)
-               goto exit;
-
-       cmd_obj->padapter = pcmdpriv->padapter;
-
-       res = rtw_cmd_filter(pcmdpriv, cmd_obj);
-       if (res == _FAIL) {
-               rtw_free_cmd_obj23a(cmd_obj);
-               goto exit;
-       }
-
-       INIT_WORK(&cmd_obj->work, rtw_cmd_work);
-
-       res = queue_work(pcmdpriv->wq, &cmd_obj->work);
-
-       if (!res) {
-               netdev_err(pcmdpriv->padapter->pnetdev,
-                          "%s: Call to queue_work() failed\n", __func__);
-               res = _FAIL;
-       } else
-               res = _SUCCESS;
-exit:
-
-       return res;
-}
-
-void rtw_free_cmd_obj23a(struct cmd_obj *pcmd)
-{
-
-       if (pcmd->cmdcode != _JoinBss_CMD_ &&
-           pcmd->cmdcode != _CreateBss_CMD_) {
-               /* free parmbuf in cmd_obj */
-               kfree(pcmd->parmbuf);
-       }
-
-       if (pcmd->rsp) {
-               if (pcmd->rspsz != 0) {
-                       /* free rsp in cmd_obj */
-                       kfree(pcmd->rsp);
-               }
-       }
-
-       kfree(pcmd);
-}
-
-static void rtw_cmd_work(struct work_struct *work)
-{
-       int (*cmd_hdl)(struct rtw_adapter *padapter, const u8 *pbuf);
-       void (*pcmd_callback)(struct rtw_adapter *dev, struct cmd_obj *pcmd);
-       struct cmd_priv *pcmdpriv;
-       struct cmd_obj *pcmd = container_of(work, struct cmd_obj, work);
-
-       pcmdpriv = &pcmd->padapter->cmdpriv;
-
-       if (rtw_cmd_filter(pcmdpriv, pcmd) == _FAIL) {
-               pcmd->res = H2C_DROPPED;
-               goto post_process;
-       }
-
-       pcmdpriv->cmd_issued_cnt++;
-
-       pcmd->cmdsz = ALIGN(pcmd->cmdsz, 4);
-
-       if (pcmd->cmdcode < (sizeof(wlancmds)/sizeof(struct cmd_hdl))) {
-               cmd_hdl = wlancmds[pcmd->cmdcode].h2cfuns;
-
-               if (cmd_hdl)
-                       pcmd->res = cmd_hdl(pcmd->padapter, pcmd->parmbuf);
-               else
-                       pcmd->res = H2C_DROPPED;
-       } else
-               pcmd->res = H2C_PARAMETERS_ERROR;
-
-post_process:
-       /* call callback function for post-processed */
-       if (pcmd->cmdcode < ARRAY_SIZE(rtw_cmd_callback)) {
-               pcmd_callback = rtw_cmd_callback[pcmd->cmdcode].callback;
-               if (!pcmd_callback) {
-                       RT_TRACE(_module_rtl871x_cmd_c_, _drv_info_,
-                                "mlme_cmd_hdl(): pcmd_callback = 0x%p, cmdcode = 0x%x\n",
-                                pcmd_callback, pcmd->cmdcode);
-                       rtw_free_cmd_obj23a(pcmd);
-               } else {
-                       /* need consider that free cmd_obj in
-                          rtw_cmd_callback */
-                       pcmd_callback(pcmd->padapter, pcmd);
-               }
-       } else {
-               RT_TRACE(_module_rtl871x_cmd_c_, _drv_err_,
-                        "%s: cmdcode = 0x%x callback not defined!\n",
-                        __func__, pcmd->cmdcode);
-               rtw_free_cmd_obj23a(pcmd);
-       }
-}
-
-
-int rtw_sitesurvey_cmd23a(struct rtw_adapter *padapter,
-                         struct cfg80211_ssid *ssid, int ssid_num,
-                         struct rtw_ieee80211_channel *ch, int ch_num)
-{
-       int res = _FAIL;
-       struct cmd_obj *ph2c;
-       struct sitesurvey_parm *psurveyPara;
-       struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-
-       if (check_fwstate(pmlmepriv, _FW_LINKED))
-               rtw_lps_ctrl_wk_cmd23a(padapter, LPS_CTRL_SCAN, 1);
-
-       ph2c = kzalloc(sizeof(struct cmd_obj), GFP_ATOMIC);
-       if (!ph2c)
-               return _FAIL;
-
-       psurveyPara = kzalloc(sizeof(struct sitesurvey_parm), GFP_ATOMIC);
-       if (!psurveyPara) {
-               kfree(ph2c);
-               return _FAIL;
-       }
-
-       rtw_free_network_queue23a(padapter);
-
-       RT_TRACE(_module_rtl871x_cmd_c_, _drv_info_,
-                "%s: flush network queue\n", __func__);
-
-       init_h2fwcmd_w_parm_no_rsp(ph2c, psurveyPara,
-                                  GEN_CMD_CODE(_SiteSurvey));
-
-       /* psurveyPara->bsslimit = 48; */
-       psurveyPara->scan_mode = pmlmepriv->scan_mode;
-
-       /* prepare ssid list */
-       if (ssid) {
-               int i;
-
-               for (i = 0; i < ssid_num && i < RTW_SSID_SCAN_AMOUNT; i++) {
-                       if (ssid[i].ssid_len) {
-                               memcpy(&psurveyPara->ssid[i], &ssid[i],
-                                      sizeof(struct cfg80211_ssid));
-                               psurveyPara->ssid_num++;
-                       }
-               }
-       }
-
-       /* prepare channel list */
-       if (ch) {
-               int i;
-
-               for (i = 0; i < ch_num && i < RTW_CHANNEL_SCAN_AMOUNT; i++) {
-                       if (ch[i].hw_value &&
-                           !(ch[i].flags & IEEE80211_CHAN_DISABLED)) {
-                               memcpy(&psurveyPara->ch[i], &ch[i],
-                                      sizeof(struct rtw_ieee80211_channel));
-                               psurveyPara->ch_num++;
-                       }
-               }
-       }
-
-       set_fwstate(pmlmepriv, _FW_UNDER_SURVEY);
-
-       res = rtw_enqueue_cmd23a(pcmdpriv, ph2c);
-
-       if (res == _SUCCESS) {
-               mod_timer(&pmlmepriv->scan_to_timer, jiffies +
-                         msecs_to_jiffies(SCANNING_TIMEOUT));
-
-               pmlmepriv->scan_interval = SCAN_INTERVAL;/*  30*2 sec = 60sec */
-       } else
-               _clr_fwstate_(pmlmepriv, _FW_UNDER_SURVEY);
-
-       return res;
-}
-
-void rtw_getbbrfreg_cmdrsp_callback23a(struct rtw_adapter *padapter,
-                                      struct cmd_obj *pcmd)
-{
-       kfree(pcmd->parmbuf);
-       kfree(pcmd);
-}
-
-int rtw_createbss_cmd23a(struct rtw_adapter  *padapter)
-{
-       struct cmd_obj *pcmd;
-       struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct wlan_bssid_ex *pdev_network;
-       u8 res = _SUCCESS;
-
-       pdev_network = &padapter->registrypriv.dev_network;
-
-       if (pmlmepriv->assoc_ssid.ssid_len == 0) {
-               RT_TRACE(_module_rtl871x_cmd_c_, _drv_info_,
-                        "createbss for Any SSid:%s\n",
-                        pmlmepriv->assoc_ssid.ssid);
-       } else {
-               RT_TRACE(_module_rtl871x_cmd_c_, _drv_info_,
-                        "createbss for SSid:%s\n",
-                        pmlmepriv->assoc_ssid.ssid);
-       }
-
-       pcmd = kzalloc(sizeof(struct cmd_obj), GFP_ATOMIC);
-       if (!pcmd) {
-               res = _FAIL;
-               goto exit;
-       }
-
-       pcmd->cmdcode = _CreateBss_CMD_;
-       pcmd->parmbuf = (unsigned char *)pdev_network;
-       pcmd->cmdsz = get_wlan_bssid_ex_sz(pdev_network);
-       pcmd->rsp = NULL;
-       pcmd->rspsz = 0;
-
-       pdev_network->Length = pcmd->cmdsz;
-
-       res = rtw_enqueue_cmd23a(pcmdpriv, pcmd);
-
-exit:
-
-       return res;
-}
-
-int rtw_joinbss_cmd23a(struct rtw_adapter *padapter,
-                      struct wlan_network *pnetwork)
-{
-       int res = _SUCCESS;
-       struct wlan_bssid_ex *psecnetwork;
-       struct cmd_obj *pcmd;
-       struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct security_priv *psecuritypriv = &padapter->securitypriv;
-       struct registry_priv *pregistrypriv = &padapter->registrypriv;
-       struct ht_priv *phtpriv = &pmlmepriv->htpriv;
-       enum nl80211_iftype ifmode;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-
-       ifmode = pnetwork->network.ifmode;
-
-       if (pmlmepriv->assoc_ssid.ssid_len == 0) {
-               RT_TRACE(_module_rtl871x_cmd_c_, _drv_info_,
-                        "+Join cmd: Any SSid\n");
-       } else {
-               RT_TRACE(_module_rtl871x_cmd_c_, _drv_notice_,
-                        "+Join cmd: SSid =[%s]\n",
-                        pmlmepriv->assoc_ssid.ssid);
-       }
-
-       pcmd = kzalloc(sizeof(struct cmd_obj), GFP_ATOMIC);
-       if (!pcmd) {
-               res = _FAIL;
-               RT_TRACE(_module_rtl871x_cmd_c_, _drv_err_,
-                        "rtw_joinbss_cmd23a: memory allocate for cmd_obj fail!!!\n");
-               goto exit;
-       }
-
-       /* for hidden ap to set fw_state here */
-       if (!check_fwstate(pmlmepriv, WIFI_STATION_STATE|WIFI_ADHOC_STATE)) {
-               switch (ifmode) {
-               case NL80211_IFTYPE_ADHOC:
-                       set_fwstate(pmlmepriv, WIFI_ADHOC_STATE);
-                       break;
-               case NL80211_IFTYPE_P2P_CLIENT:
-               case NL80211_IFTYPE_STATION:
-                       set_fwstate(pmlmepriv, WIFI_STATION_STATE);
-                       break;
-               default:
-                       break;
-               }
-       }
-
-       psecnetwork = &psecuritypriv->sec_bss;
-       if (!psecnetwork) {
-               kfree(pcmd);
-               res = _FAIL;
-
-               RT_TRACE(_module_rtl871x_cmd_c_, _drv_err_,
-                        "rtw_joinbss_cmd23a :psecnetwork == NULL!!!\n");
-
-               goto exit;
-       }
-
-       memset(psecnetwork, 0, sizeof(struct wlan_bssid_ex));
-
-       memcpy(psecnetwork, &pnetwork->network,
-              get_wlan_bssid_ex_sz(&pnetwork->network));
-
-       psecnetwork->IELength = 0;
-       /*  Added by Albert 2009/02/18 */
-       /*  If the the driver wants to use the bssid to create the
-        *  connection. If not,  we have to copy the connecting AP's
-        *  MAC address to it so that the driver just has the bssid
-        *  information for PMKIDList searching. */
-
-       if (pmlmepriv->assoc_by_bssid == false)
-               ether_addr_copy(&pmlmepriv->assoc_bssid[0],
-                               &pnetwork->network.MacAddress[0]);
-
-       psecnetwork->IELength =
-               rtw_restruct_sec_ie23a(padapter, &pnetwork->network.IEs[0],
-                                      &psecnetwork->IEs[0],
-                                      pnetwork->network.IELength);
-
-       pmlmepriv->qos_option = 0;
-
-       if (pregistrypriv->wmm_enable) {
-               u32 tmp_len;
-
-               tmp_len = rtw_restruct_wmm_ie23a(padapter,
-                                                &pnetwork->network.IEs[0],
-                                                &psecnetwork->IEs[0],
-                                                pnetwork->network.IELength,
-                                                psecnetwork->IELength);
-
-               if (psecnetwork->IELength != tmp_len) {
-                       psecnetwork->IELength = tmp_len;
-                       /* There is WMM IE in this corresp. beacon */
-                       pmlmepriv->qos_option = 1;
-               } else {
-                       /* There is no WMM IE in this corresp. beacon */
-                       pmlmepriv->qos_option = 0;
-               }
-       }
-
-       phtpriv->ht_option = false;
-       if (pregistrypriv->ht_enable) {
-               u32 algo = padapter->securitypriv.dot11PrivacyAlgrthm;
-               /*      Added by Albert 2010/06/23 */
-               /*      For the WEP mode, we will use the bg mode to do
-                       the connection to avoid some IOT issue. */
-               /*      Especially for Realtek 8192u SoftAP. */
-               if (algo != WLAN_CIPHER_SUITE_WEP40 &&
-                   algo != WLAN_CIPHER_SUITE_WEP104 &&
-                   algo != WLAN_CIPHER_SUITE_TKIP) {
-                       /* rtw_restructure_ht_ie23a */
-                       rtw_restructure_ht_ie23a(padapter,
-                                                &pnetwork->network.IEs[0],
-                                                &psecnetwork->IEs[0],
-                                                pnetwork->network.IELength,
-                                                &psecnetwork->IELength);
-               }
-       }
-
-       pmlmeinfo->assoc_AP_vendor =
-               check_assoc_AP23a(pnetwork->network.IEs,
-                                 pnetwork->network.IELength);
-
-       if (pmlmeinfo->assoc_AP_vendor == HT_IOT_PEER_TENDA)
-               padapter->pwrctrlpriv.smart_ps = 0;
-       else
-               padapter->pwrctrlpriv.smart_ps =
-                       padapter->registrypriv.smart_ps;
-
-       DBG_8723A("%s: smart_ps =%d\n", __func__,
-                 padapter->pwrctrlpriv.smart_ps);
-
-       /* get cmdsz before endian conversion */
-       pcmd->cmdsz = get_wlan_bssid_ex_sz(psecnetwork);
-
-       pcmd->cmdcode = _JoinBss_CMD_;/* GEN_CMD_CODE(_JoinBss) */
-       pcmd->parmbuf = (unsigned char *)psecnetwork;
-       pcmd->rsp = NULL;
-       pcmd->rspsz = 0;
-
-       res = rtw_enqueue_cmd23a(pcmdpriv, pcmd);
-exit:
-
-       return res;
-}
-
-int rtw_disassoc_cmd23a(struct rtw_adapter *padapter, u32 deauth_timeout_ms,
-                       bool enqueue)
-{
-       struct cmd_obj *cmdobj = NULL;
-       struct disconnect_parm *param = NULL;
-       struct cmd_priv *cmdpriv = &padapter->cmdpriv;
-       int res = _SUCCESS;
-
-       RT_TRACE(_module_rtl871x_cmd_c_, _drv_notice_,
-                "+rtw_disassoc_cmd23a\n");
-
-       /* prepare cmd parameter */
-       param = kzalloc(sizeof(*param), GFP_ATOMIC);
-       if (param == NULL) {
-               res = _FAIL;
-               goto exit;
-       }
-       param->deauth_timeout_ms = deauth_timeout_ms;
-
-       if (enqueue) {
-               /* need enqueue, prepare cmd_obj and enqueue */
-               cmdobj = kzalloc(sizeof(struct cmd_obj), GFP_ATOMIC);
-               if (!cmdobj) {
-                       res = _FAIL;
-                       kfree(param);
-                       goto exit;
-               }
-               init_h2fwcmd_w_parm_no_rsp(cmdobj, param, _DisConnect_CMD_);
-               res = rtw_enqueue_cmd23a(cmdpriv, cmdobj);
-       } else {
-               /* no need to enqueue, do the cmd hdl directly and
-                  free cmd parameter */
-               if (disconnect_hdl23a(padapter, (u8 *)param) != H2C_SUCCESS)
-                       res = _FAIL;
-               kfree(param);
-       }
-
-exit:
-       return res;
-}
-
-int rtw_setopmode_cmd23a(struct rtw_adapter *padapter,
-                        enum nl80211_iftype ifmode)
-{
-       struct  cmd_obj *ph2c;
-       struct  setopmode_parm *psetop;
-       struct  cmd_priv   *pcmdpriv = &padapter->cmdpriv;
-       int res = _SUCCESS;
-
-       ph2c = kzalloc(sizeof(struct cmd_obj), GFP_KERNEL);
-       if (!ph2c) {
-               res = false;
-               goto exit;
-       }
-       psetop = kzalloc(sizeof(struct setopmode_parm), GFP_KERNEL);
-
-       if (!psetop) {
-               kfree(ph2c);
-               res = false;
-               goto exit;
-       }
-
-       init_h2fwcmd_w_parm_no_rsp(ph2c, psetop, _SetOpMode_CMD_);
-       psetop->mode = ifmode;
-
-       res = rtw_enqueue_cmd23a(pcmdpriv, ph2c);
-exit:
-       return res;
-}
-
-int rtw_setstakey_cmd23a(struct rtw_adapter *padapter, u8 *psta, u8 unicast_key)
-{
-       struct cmd_obj *ph2c;
-       struct set_stakey_parm *psetstakey_para;
-       struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
-       struct set_stakey_rsp *psetstakey_rsp = NULL;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct security_priv *psecuritypriv = &padapter->securitypriv;
-       struct sta_info *sta = (struct sta_info *)psta;
-       int res = _SUCCESS;
-
-       ph2c = kzalloc(sizeof(struct cmd_obj), GFP_KERNEL);
-       if (!ph2c) {
-               res = _FAIL;
-               goto exit;
-       }
-
-       psetstakey_para = kzalloc(sizeof(struct set_stakey_parm), GFP_KERNEL);
-       if (!psetstakey_para) {
-               kfree(ph2c);
-               res = _FAIL;
-               goto exit;
-       }
-
-       psetstakey_rsp = kzalloc(sizeof(struct set_stakey_rsp), GFP_KERNEL);
-       if (!psetstakey_rsp) {
-               kfree(ph2c);
-               kfree(psetstakey_para);
-               res = _FAIL;
-               goto exit;
-       }
-
-       init_h2fwcmd_w_parm_no_rsp(ph2c, psetstakey_para, _SetStaKey_CMD_);
-       ph2c->rsp = (u8 *) psetstakey_rsp;
-       ph2c->rspsz = sizeof(struct set_stakey_rsp);
-
-       ether_addr_copy(psetstakey_para->addr, sta->hwaddr);
-
-       if (check_fwstate(pmlmepriv, WIFI_STATION_STATE)) {
-               psetstakey_para->algorithm =
-                       (unsigned char)psecuritypriv->dot11PrivacyAlgrthm;
-       } else {
-               GET_ENCRY_ALGO(psecuritypriv, sta, psetstakey_para->algorithm,
-                              false);
-       }
-
-       if (unicast_key == true) {
-               memcpy(&psetstakey_para->key, &sta->dot118021x_UncstKey, 16);
-       } else {
-               int idx = psecuritypriv->dot118021XGrpKeyid;
-
-               memcpy(&psetstakey_para->key,
-                      &psecuritypriv->dot118021XGrpKey[idx].skey, 16);
-       }
-
-       /* jeff: set this because at least sw key is ready */
-       padapter->securitypriv.busetkipkey = 1;
-
-       res = rtw_enqueue_cmd23a(pcmdpriv, ph2c);
-
-exit:
-
-       return res;
-}
-
-int rtw_clearstakey_cmd23a(struct rtw_adapter *padapter, u8 *psta, u8 entry,
-                          u8 enqueue)
-{
-       struct cmd_obj *ph2c;
-       struct set_stakey_parm *psetstakey_para;
-       struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
-       struct set_stakey_rsp *psetstakey_rsp = NULL;
-       struct sta_info *sta = (struct sta_info *)psta;
-       int res = _SUCCESS;
-
-       if (!enqueue) {
-               clear_cam_entry23a(padapter, entry);
-       } else {
-               ph2c = kzalloc(sizeof(struct cmd_obj), GFP_KERNEL);
-               if (!ph2c) {
-                       res = _FAIL;
-                       goto exit;
-               }
-
-               psetstakey_para = kzalloc(sizeof(struct set_stakey_parm),
-                                         GFP_KERNEL);
-               if (!psetstakey_para) {
-                       kfree(ph2c);
-                       res = _FAIL;
-                       goto exit;
-               }
-
-               psetstakey_rsp = kzalloc(sizeof(struct set_stakey_rsp),
-                                        GFP_KERNEL);
-               if (!psetstakey_rsp) {
-                       kfree(ph2c);
-                       kfree(psetstakey_para);
-                       res = _FAIL;
-                       goto exit;
-               }
-
-               init_h2fwcmd_w_parm_no_rsp(ph2c, psetstakey_para,
-                                          _SetStaKey_CMD_);
-               ph2c->rsp = (u8 *) psetstakey_rsp;
-               ph2c->rspsz = sizeof(struct set_stakey_rsp);
-
-               ether_addr_copy(psetstakey_para->addr, sta->hwaddr);
-
-               psetstakey_para->algorithm = 0;
-
-               psetstakey_para->id = entry;
-
-               res = rtw_enqueue_cmd23a(pcmdpriv, ph2c);
-       }
-exit:
-       return res;
-}
-
-int rtw_addbareq_cmd23a(struct rtw_adapter *padapter, u8 tid, u8 *addr)
-{
-       struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
-       struct cmd_obj *ph2c;
-       struct addBaReq_parm *paddbareq_parm;
-       int res = _SUCCESS;
-
-       if (tid >= MAXTID) {
-               res = _FAIL;
-               goto exit;
-       }
-
-       ph2c = kzalloc(sizeof(struct cmd_obj), GFP_ATOMIC);
-       if (!ph2c) {
-               res = _FAIL;
-               goto exit;
-       }
-
-       paddbareq_parm = kzalloc(sizeof(struct addBaReq_parm), GFP_ATOMIC);
-       if (!paddbareq_parm) {
-               kfree(ph2c);
-               res = _FAIL;
-               goto exit;
-       }
-
-       paddbareq_parm->tid = tid;
-       ether_addr_copy(paddbareq_parm->addr, addr);
-
-       init_h2fwcmd_w_parm_no_rsp(ph2c, paddbareq_parm,
-                                  GEN_CMD_CODE(_AddBAReq));
-
-       res = rtw_enqueue_cmd23a(pcmdpriv, ph2c);
-exit:
-       return res;
-}
-
-int rtw_dynamic_chk_wk_cmd23a(struct rtw_adapter *padapter)
-{
-       struct cmd_obj *ph2c;
-       struct drvextra_cmd_parm *pdrvextra_cmd_parm;
-       struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
-       int res = _SUCCESS;
-
-       ph2c = kzalloc(sizeof(struct cmd_obj), GFP_ATOMIC);
-       if (!ph2c) {
-               res = _FAIL;
-               goto exit;
-       }
-
-       pdrvextra_cmd_parm = kzalloc(sizeof(*pdrvextra_cmd_parm), GFP_ATOMIC);
-       if (!pdrvextra_cmd_parm) {
-               kfree(ph2c);
-               res = _FAIL;
-               goto exit;
-       }
-
-       pdrvextra_cmd_parm->ec_id = DYNAMIC_CHK_WK_CID;
-       pdrvextra_cmd_parm->type_size = 0;
-       pdrvextra_cmd_parm->pbuf = (u8 *)padapter;
-
-       init_h2fwcmd_w_parm_no_rsp(ph2c, pdrvextra_cmd_parm,
-                                  GEN_CMD_CODE(_Set_Drv_Extra));
-
-       res = rtw_enqueue_cmd23a(pcmdpriv, ph2c);
-exit:
-
-       return res;
-}
-
-static void traffic_status_watchdog(struct rtw_adapter *padapter)
-{
-       u8 bEnterPS;
-       u8 bBusyTraffic = false, bTxBusyTraffic = false, bRxBusyTraffic = false;
-       u8 bHigherBusyTraffic = false, bHigherBusyRxTraffic = false;
-       u8 bHigherBusyTxTraffic = false;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       int BusyThreshold = 100;
-       struct rt_link_detect *ldi = &pmlmepriv->LinkDetectInfo;
-
-       /*  */
-       /*  Determine if our traffic is busy now */
-       /*  */
-       if (check_fwstate(pmlmepriv, _FW_LINKED)) {
-               if (rtl8723a_BT_coexist(padapter))
-                       BusyThreshold = 50;
-               else if (ldi->bBusyTraffic)
-                       BusyThreshold = 75;
-               /*  if we raise bBusyTraffic in last watchdog, using
-                   lower threshold. */
-               if (ldi->NumRxOkInPeriod > BusyThreshold ||
-                   ldi->NumTxOkInPeriod > BusyThreshold) {
-                       bBusyTraffic = true;
-
-                       if (ldi->NumRxOkInPeriod > ldi->NumTxOkInPeriod)
-                               bRxBusyTraffic = true;
-                       else
-                               bTxBusyTraffic = true;
-               }
-
-               /*  Higher Tx/Rx data. */
-               if (ldi->NumRxOkInPeriod > 4000 ||
-                   ldi->NumTxOkInPeriod > 4000) {
-                       bHigherBusyTraffic = true;
-
-                       if (ldi->NumRxOkInPeriod > ldi->NumTxOkInPeriod)
-                               bHigherBusyRxTraffic = true;
-                       else
-                               bHigherBusyTxTraffic = true;
-               }
-
-               if (!rtl8723a_BT_coexist(padapter) ||
-                   !rtl8723a_BT_using_antenna_1(padapter)) {
-               /*  check traffic for  powersaving. */
-                       if (((ldi->NumRxUnicastOkInPeriod +
-                             ldi->NumTxOkInPeriod) > 8) ||
-                           ldi->NumRxUnicastOkInPeriod > 2)
-                               bEnterPS = false;
-                       else
-                               bEnterPS = true;
-
-                       /*  LeisurePS only work in infra mode. */
-                       if (bEnterPS)
-                               LPS_Enter23a(padapter);
-                       else
-                               LPS_Leave23a(padapter);
-               }
-       } else
-               LPS_Leave23a(padapter);
-
-       ldi->NumRxOkInPeriod = 0;
-       ldi->NumTxOkInPeriod = 0;
-       ldi->NumRxUnicastOkInPeriod = 0;
-       ldi->bBusyTraffic = bBusyTraffic;
-       ldi->bTxBusyTraffic = bTxBusyTraffic;
-       ldi->bRxBusyTraffic = bRxBusyTraffic;
-       ldi->bHigherBusyTraffic = bHigherBusyTraffic;
-       ldi->bHigherBusyRxTraffic = bHigherBusyRxTraffic;
-       ldi->bHigherBusyTxTraffic = bHigherBusyTxTraffic;
-}
-
-static void dynamic_chk_wk_hdl(struct rtw_adapter *padapter, u8 *pbuf, int sz)
-{
-       struct mlme_priv *pmlmepriv;
-
-       padapter = (struct rtw_adapter *)pbuf;
-       pmlmepriv = &padapter->mlmepriv;
-
-#ifdef CONFIG_8723AU_AP_MODE
-       if (check_fwstate(pmlmepriv, WIFI_AP_STATE))
-               expire_timeout_chk23a(padapter);
-#endif
-
-       rtl8723a_sreset_xmit_status_check(padapter);
-
-       linked_status_chk23a(padapter);
-       traffic_status_watchdog(padapter);
-
-       rtl8723a_HalDmWatchDog(padapter);
-
-       /*  */
-       /*  BT-Coexist */
-       /*  */
-       rtl8723a_BT_do_coexist(padapter);
-}
-
-static void lps_ctrl_wk_hdl(struct rtw_adapter *padapter, u8 lps_ctrl_type)
-{
-       struct pwrctrl_priv *pwrpriv = &padapter->pwrctrlpriv;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       u8 mstatus;
-
-       if (check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) ||
-           check_fwstate(pmlmepriv, WIFI_ADHOC_STATE))
-               return;
-
-       switch (lps_ctrl_type) {
-       case LPS_CTRL_SCAN:
-               rtl8723a_BT_wifiscan_notify(padapter, true);
-               if (!rtl8723a_BT_using_antenna_1(padapter)) {
-                       if (check_fwstate(pmlmepriv, _FW_LINKED))
-                               LPS_Leave23a(padapter);
-                       }
-               break;
-       case LPS_CTRL_JOINBSS:
-               LPS_Leave23a(padapter);
-               break;
-       case LPS_CTRL_CONNECT:
-               mstatus = 1;/* connect */
-               /*  Reset LPS Setting */
-               padapter->pwrctrlpriv.LpsIdleCount = 0;
-               rtl8723a_set_FwJoinBssReport_cmd(padapter, 1);
-               rtl8723a_BT_mediastatus_notify(padapter, mstatus);
-               break;
-       case LPS_CTRL_DISCONNECT:
-               mstatus = 0;/* disconnect */
-               rtl8723a_BT_mediastatus_notify(padapter, mstatus);
-               if (!rtl8723a_BT_using_antenna_1(padapter))
-                       LPS_Leave23a(padapter);
-               rtl8723a_set_FwJoinBssReport_cmd(padapter, 0);
-               break;
-       case LPS_CTRL_SPECIAL_PACKET:
-               pwrpriv->DelayLPSLastTimeStamp = jiffies;
-               rtl8723a_BT_specialpacket_notify(padapter);
-               if (!rtl8723a_BT_using_antenna_1(padapter))
-                       LPS_Leave23a(padapter);
-               break;
-       case LPS_CTRL_LEAVE:
-               rtl8723a_BT_lps_leave(padapter);
-               if (!rtl8723a_BT_using_antenna_1(padapter))
-                       LPS_Leave23a(padapter);
-               break;
-
-       default:
-               break;
-       }
-}
-
-int rtw_lps_ctrl_wk_cmd23a(struct rtw_adapter *padapter,
-                          u8 lps_ctrl_type, u8 enqueue)
-{
-       struct cmd_obj *ph2c;
-       struct drvextra_cmd_parm *pdrvextra_cmd_parm;
-       struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
-       int res = _SUCCESS;
-
-       if (enqueue) {
-               ph2c = kzalloc(sizeof(struct cmd_obj), GFP_ATOMIC);
-               if (!ph2c) {
-                       res = _FAIL;
-                       goto exit;
-               }
-
-               pdrvextra_cmd_parm = kzalloc(sizeof(struct drvextra_cmd_parm),
-                                            GFP_ATOMIC);
-               if (!pdrvextra_cmd_parm) {
-                       kfree(ph2c);
-                       res = _FAIL;
-                       goto exit;
-               }
-
-               pdrvextra_cmd_parm->ec_id = LPS_CTRL_WK_CID;
-               pdrvextra_cmd_parm->type_size = lps_ctrl_type;
-               pdrvextra_cmd_parm->pbuf = NULL;
-
-               init_h2fwcmd_w_parm_no_rsp(ph2c, pdrvextra_cmd_parm,
-                                          GEN_CMD_CODE(_Set_Drv_Extra));
-
-               res = rtw_enqueue_cmd23a(pcmdpriv, ph2c);
-       } else
-               lps_ctrl_wk_hdl(padapter, lps_ctrl_type);
-exit:
-
-       return res;
-}
-
-int rtw_ps_cmd23a(struct rtw_adapter *padapter)
-{
-       struct cmd_obj *ppscmd;
-       struct drvextra_cmd_parm *pdrvextra_cmd_parm;
-       struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
-       int res = _SUCCESS;
-
-       ppscmd = kzalloc(sizeof(struct cmd_obj), GFP_ATOMIC);
-       if (!ppscmd) {
-               res = _FAIL;
-               goto exit;
-       }
-
-       pdrvextra_cmd_parm = kzalloc(sizeof(struct drvextra_cmd_parm),
-                                    GFP_ATOMIC);
-       if (!pdrvextra_cmd_parm) {
-               kfree(ppscmd);
-               res = _FAIL;
-               goto exit;
-       }
-
-       pdrvextra_cmd_parm->ec_id = POWER_SAVING_CTRL_WK_CID;
-       pdrvextra_cmd_parm->pbuf = NULL;
-       init_h2fwcmd_w_parm_no_rsp(ppscmd, pdrvextra_cmd_parm,
-                                  GEN_CMD_CODE(_Set_Drv_Extra));
-
-       res = rtw_enqueue_cmd23a(pcmdpriv, ppscmd);
-exit:
-
-       return res;
-}
-
-#ifdef CONFIG_8723AU_AP_MODE
-
-static void rtw_chk_hi_queue_hdl(struct rtw_adapter *padapter)
-{
-       int cnt = 0;
-       struct sta_info *psta_bmc;
-       struct sta_priv *pstapriv = &padapter->stapriv;
-
-       psta_bmc = rtw_get_bcmc_stainfo23a(padapter);
-       if (!psta_bmc)
-               return;
-
-       if (psta_bmc->sleepq_len == 0) {
-               bool val;
-
-               val = rtl8723a_chk_hi_queue_empty(padapter);
-
-               while (!val) {
-                       msleep(100);
-
-                       cnt++;
-
-                       if (cnt > 10)
-                               break;
-
-                       val = rtl8723a_chk_hi_queue_empty(padapter);
-               }
-
-               if (cnt <= 10) {
-                       pstapriv->tim_bitmap &= ~BIT(0);
-                       pstapriv->sta_dz_bitmap &= ~BIT(0);
-
-                       update_beacon23a(padapter, WLAN_EID_TIM, NULL, false);
-               } else /* re check again */
-                       rtw_chk_hi_queue_cmd23a(padapter);
-       }
-}
-
-int rtw_chk_hi_queue_cmd23a(struct rtw_adapter *padapter)
-{
-       struct cmd_obj *ph2c;
-       struct drvextra_cmd_parm *pdrvextra_cmd_parm;
-       struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
-       int res = _SUCCESS;
-
-       ph2c = kzalloc(sizeof(struct cmd_obj), GFP_ATOMIC);
-       if (!ph2c) {
-               res = _FAIL;
-               goto exit;
-       }
-
-       pdrvextra_cmd_parm = kzalloc(sizeof(struct drvextra_cmd_parm),
-                                    GFP_ATOMIC);
-       if (!pdrvextra_cmd_parm) {
-               kfree(ph2c);
-               res = _FAIL;
-               goto exit;
-       }
-
-       pdrvextra_cmd_parm->ec_id = CHECK_HIQ_WK_CID;
-       pdrvextra_cmd_parm->type_size = 0;
-       pdrvextra_cmd_parm->pbuf = NULL;
-
-       init_h2fwcmd_w_parm_no_rsp(ph2c, pdrvextra_cmd_parm,
-                                  GEN_CMD_CODE(_Set_Drv_Extra));
-
-       res = rtw_enqueue_cmd23a(pcmdpriv, ph2c);
-exit:
-
-       return res;
-}
-#endif
-
-int rtw_c2h_wk_cmd23a(struct rtw_adapter *padapter, u8 *c2h_evt)
-{
-       struct cmd_obj *ph2c;
-       struct drvextra_cmd_parm *pdrvextra_cmd_parm;
-       struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
-       int res = _SUCCESS;
-
-       ph2c = kzalloc(sizeof(struct cmd_obj), GFP_ATOMIC);
-       if (!ph2c) {
-               res = _FAIL;
-               goto exit;
-       }
-
-       pdrvextra_cmd_parm = kzalloc(sizeof(struct drvextra_cmd_parm),
-                                    GFP_ATOMIC);
-       if (!pdrvextra_cmd_parm) {
-               kfree(ph2c);
-               res = _FAIL;
-               goto exit;
-       }
-
-       pdrvextra_cmd_parm->ec_id = C2H_WK_CID;
-       pdrvextra_cmd_parm->type_size = c2h_evt?16:0;
-       pdrvextra_cmd_parm->pbuf = c2h_evt;
-
-       init_h2fwcmd_w_parm_no_rsp(ph2c, pdrvextra_cmd_parm,
-                                  GEN_CMD_CODE(_Set_Drv_Extra));
-
-       res = rtw_enqueue_cmd23a(pcmdpriv, ph2c);
-
-exit:
-
-       return res;
-}
-
-static int c2h_evt_hdl(struct rtw_adapter *adapter, struct c2h_evt_hdr *c2h_evt)
-{
-       int ret = _FAIL;
-       u8 buf[16];
-
-       if (!c2h_evt) {
-               /* No c2h event in cmd_obj, read c2h event before handling*/
-               if (c2h_evt_read23a(adapter, buf) == _SUCCESS) {
-                       c2h_evt = (struct c2h_evt_hdr *)buf;
-
-                       ret = c2h_handler_8723a(adapter, c2h_evt);
-               }
-       } else
-               ret = c2h_handler_8723a(adapter, c2h_evt);
-
-       return ret;
-}
-
-static void rtw_irq_work(struct work_struct *work)
-{
-       struct evt_priv *evtpriv;
-       struct rtw_adapter *adapter;
-
-       evtpriv = container_of(work, struct evt_priv, irq_wk);
-       adapter = container_of(evtpriv, struct rtw_adapter, evtpriv);
-
-       c2h_evt_clear23a(adapter);
-}
-
-void rtw_evt_work(struct work_struct *work)
-{
-       struct evt_work *ework;
-       struct rtw_adapter *adapter;
-
-       ework = container_of(work, struct evt_work, work);
-       adapter = ework->adapter;
-
-       c2h_evt_clear23a(adapter);
-
-       if (!c2h_evt_exist(&ework->u.c2h_evt)) {
-               kfree(ework);
-               return;
-       }
-
-       if (c2h_id_filter_ccx_8723a(ework->u.c2h_evt.id) == true) {
-               /* Handle CCX report here */
-               c2h_handler_8723a(adapter, &ework->u.c2h_evt);
-               kfree(ework);
-       } else {
-               /*
-                * Enqueue into cmd_thread for others.
-                * ework will be turned into a c2h_evt and freed once it
-                * has been consumed.
-                */
-               rtw_c2h_wk_cmd23a(adapter, (u8 *)&ework->u.c2h_evt);
-       }
-}
-
-int rtw_drvextra_cmd_hdl23a(struct rtw_adapter *padapter, const u8 *pbuf)
-{
-       const struct drvextra_cmd_parm *pdrvextra_cmd;
-
-       if (!pbuf)
-               return H2C_PARAMETERS_ERROR;
-
-       pdrvextra_cmd = (struct drvextra_cmd_parm *)pbuf;
-
-       switch (pdrvextra_cmd->ec_id) {
-       case DYNAMIC_CHK_WK_CID:
-               dynamic_chk_wk_hdl(padapter, pdrvextra_cmd->pbuf,
-                                  pdrvextra_cmd->type_size);
-               break;
-       case POWER_SAVING_CTRL_WK_CID:
-               rtw_ps_processor23a(padapter);
-               break;
-       case LPS_CTRL_WK_CID:
-               lps_ctrl_wk_hdl(padapter, (u8)pdrvextra_cmd->type_size);
-               break;
-#ifdef CONFIG_8723AU_AP_MODE
-       case CHECK_HIQ_WK_CID:
-               rtw_chk_hi_queue_hdl(padapter);
-               break;
-#endif /* CONFIG_8723AU_AP_MODE */
-       case C2H_WK_CID:
-               c2h_evt_hdl(padapter,
-                           (struct c2h_evt_hdr *)pdrvextra_cmd->pbuf);
-               break;
-
-       default:
-               break;
-       }
-
-       if (pdrvextra_cmd->pbuf && (pdrvextra_cmd->type_size > 0)) {
-               kfree(pdrvextra_cmd->pbuf);
-               /*
-                * No need to set pdrvextra_cmd->pbuf = NULL as we were
-                * operating on a copy of the original pcmd->parmbuf
-                * created in rtw_cmd_work().
-                */
-       }
-
-       return H2C_SUCCESS;
-}
-
-void rtw_survey_cmd_callback23a(struct rtw_adapter *padapter,
-                               struct cmd_obj *pcmd)
-{
-       struct  mlme_priv *pmlmepriv = &padapter->mlmepriv;
-
-       if (pcmd->res == H2C_DROPPED) {
-               /* TODO: cancel timer and do timeout handler directly... */
-               /* need to make timeout handlerOS independent */
-               mod_timer(&pmlmepriv->scan_to_timer,
-                         jiffies + msecs_to_jiffies(1));
-       } else if (pcmd->res != H2C_SUCCESS) {
-               mod_timer(&pmlmepriv->scan_to_timer,
-                         jiffies + msecs_to_jiffies(1));
-               RT_TRACE(_module_rtl871x_cmd_c_, _drv_err_,
-                        "********Error: MgntActrtw_set_802_11_bssid23a_LIST_SCAN Fail ************\n");
-       }
-
-       /*  free cmd */
-       rtw_free_cmd_obj23a(pcmd);
-}
-
-void rtw_disassoc_cmd23a_callback(struct rtw_adapter *padapter,
-                                 struct cmd_obj *pcmd)
-{
-       struct  mlme_priv *pmlmepriv = &padapter->mlmepriv;
-
-       if (pcmd->res != H2C_SUCCESS) {
-               spin_lock_bh(&pmlmepriv->lock);
-               set_fwstate(pmlmepriv, _FW_LINKED);
-               spin_unlock_bh(&pmlmepriv->lock);
-               RT_TRACE(_module_rtl871x_cmd_c_, _drv_err_,
-                        "***Error: disconnect_cmd_callback Fail ***\n");
-               return;
-       }
-
-       /*  free cmd */
-       rtw_free_cmd_obj23a(pcmd);
-}
-
-void rtw_joinbss_cmd23a_callback(struct rtw_adapter *padapter,
-                                struct cmd_obj *pcmd)
-{
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-
-       if (pcmd->res == H2C_DROPPED) {
-               /* TODO: cancel timer and do timeout handler directly... */
-               /* need to make timeout handlerOS independent */
-               mod_timer(&pmlmepriv->assoc_timer,
-                         jiffies + msecs_to_jiffies(1));
-       } else if (pcmd->res != H2C_SUCCESS) {
-               RT_TRACE(_module_rtl871x_cmd_c_, _drv_err_,
-                        "********Error:rtw_select_and_join_from_scanned_queue Wait Sema  Fail ************\n");
-               mod_timer(&pmlmepriv->assoc_timer,
-                         jiffies + msecs_to_jiffies(1));
-       }
-
-       rtw_free_cmd_obj23a(pcmd);
-}
-
-void rtw_createbss_cmd23a_callback(struct rtw_adapter *padapter,
-                                  struct cmd_obj *pcmd)
-{
-       struct sta_info *psta;
-       struct wlan_network *pwlan;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct wlan_bssid_ex *pnetwork = (struct wlan_bssid_ex *)pcmd->parmbuf;
-       struct wlan_network *tgt_network = &pmlmepriv->cur_network;
-       struct rtw_queue *scanned_queue = &pmlmepriv->scanned_queue;
-
-       if (pcmd->res != H2C_SUCCESS) {
-               RT_TRACE(_module_rtl871x_cmd_c_, _drv_err_,
-                        "********Error: rtw_createbss_cmd23a_callback  Fail ************\n");
-               mod_timer(&pmlmepriv->assoc_timer,
-                         jiffies + msecs_to_jiffies(1));
-       }
-
-       del_timer_sync(&pmlmepriv->assoc_timer);
-
-       if (check_fwstate(pmlmepriv, WIFI_AP_STATE)) {
-               psta = rtw_get_stainfo23a(&padapter->stapriv,
-                                         pnetwork->MacAddress);
-               if (!psta) {
-                       psta = rtw_alloc_stainfo23a(&padapter->stapriv,
-                                                   pnetwork->MacAddress,
-                                                   GFP_KERNEL);
-                       if (!psta) {
-                               RT_TRACE(_module_rtl871x_cmd_c_, _drv_err_,
-                                        "Can't alloc sta_info when createbss_cmd_callback\n");
-                               goto createbss_cmd_fail;
-                       }
-               }
-
-               spin_lock_bh(&pmlmepriv->lock);
-               rtw_indicate_connect23a(padapter);
-               spin_unlock_bh(&pmlmepriv->lock);
-       } else {
-               pwlan = rtw_alloc_network(pmlmepriv, GFP_KERNEL);
-               spin_lock_bh(&scanned_queue->lock);
-               if (!pwlan) {
-                       pwlan = rtw_get_oldest_wlan_network23a(scanned_queue);
-                       if (!pwlan) {
-                               RT_TRACE(_module_rtl871x_cmd_c_, _drv_err_,
-                                        "Error:  can't get pwlan in rtw23a_joinbss_event_cb\n");
-                               spin_unlock_bh(&scanned_queue->lock);
-                               goto createbss_cmd_fail;
-                       }
-                       pwlan->last_scanned = jiffies;
-               } else {
-                       list_add_tail(&pwlan->list,
-                                     &scanned_queue->queue);
-               }
-
-               pnetwork->Length = get_wlan_bssid_ex_sz(pnetwork);
-               memcpy(&pwlan->network, pnetwork, pnetwork->Length);
-               /* pwlan->fixed = true; */
-
-               /* list_add_tail(&pwlan->list,
-                  &pmlmepriv->scanned_queue.queue); */
-
-               /*  copy pdev_network information to
-                   pmlmepriv->cur_network */
-               memcpy(&tgt_network->network, pnetwork,
-                      get_wlan_bssid_ex_sz(pnetwork));
-
-               /*  reset DSConfig */
-
-               clr_fwstate(pmlmepriv, _FW_UNDER_LINKING);
-
-               /*  we will set _FW_LINKED when there is one more sat to
-                   join us (rtw_stassoc_event_callback23a) */
-               spin_unlock_bh(&scanned_queue->lock);
-       }
-
-createbss_cmd_fail:
-
-       rtw_free_cmd_obj23a(pcmd);
-}
-
-void rtw_setstaKey_cmdrsp_callback23a(struct rtw_adapter *padapter,
-                                     struct cmd_obj *pcmd)
-{
-       struct sta_priv *pstapriv;
-       struct set_stakey_rsp *psetstakey_rsp;
-       struct sta_info *psta;
-
-       pstapriv = &padapter->stapriv;
-       psetstakey_rsp = (struct set_stakey_rsp *) (pcmd->rsp);
-       psta = rtw_get_stainfo23a(pstapriv, psetstakey_rsp->addr);
-
-       if (!psta) {
-               RT_TRACE(_module_rtl871x_cmd_c_, _drv_err_,
-                        "ERROR: rtw_setstaKey_cmdrsp_callback23a => can't get sta_info\n");
-               goto exit;
-       }
-
-exit:
-
-       rtw_free_cmd_obj23a(pcmd);
-}
-
-void rtw_setassocsta_cmdrsp_callback23a(struct rtw_adapter *padapter,
-                                       struct cmd_obj *pcmd)
-{
-       struct sta_priv *pstapriv = &padapter->stapriv;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct set_assocsta_parm *passocsta_parm;
-       struct set_assocsta_rsp *passocsta_rsp;
-       struct sta_info *psta;
-
-       passocsta_parm = (struct set_assocsta_parm *)(pcmd->parmbuf);
-       passocsta_rsp = (struct set_assocsta_rsp *) (pcmd->rsp);
-       psta = rtw_get_stainfo23a(pstapriv, passocsta_parm->addr);
-
-       if (psta == NULL) {
-               RT_TRACE(_module_rtl871x_cmd_c_, _drv_err_,
-                        "ERROR: setassocsta_cmdrsp_callbac => can't get sta_info\n");
-               goto exit;
-       }
-
-       psta->aid = psta->mac_id = passocsta_rsp->cam_id;
-
-       spin_lock_bh(&pmlmepriv->lock);
-
-       if (check_fwstate(pmlmepriv, WIFI_MP_STATE) &&
-           check_fwstate(pmlmepriv, _FW_UNDER_LINKING))
-               _clr_fwstate_(pmlmepriv, _FW_UNDER_LINKING);
-
-       set_fwstate(pmlmepriv, _FW_LINKED);
-       spin_unlock_bh(&pmlmepriv->lock);
-
-exit:
-       rtw_free_cmd_obj23a(pcmd);
-}
diff --git a/drivers/staging/rtl8723au/core/rtw_efuse.c b/drivers/staging/rtl8723au/core/rtw_efuse.c
deleted file mode 100644 (file)
index 359ef41..0000000
+++ /dev/null
@@ -1,538 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#define _RTW_EFUSE_C_
-
-#include <osdep_service.h>
-#include <drv_types.h>
-
-#include <rtw_efuse.h>
-#include <rtl8723a_hal.h>
-#include <usb_ops_linux.h>
-
-#define REG_EFUSE_CTRL         0x0030
-#define EFUSE_CTRL             REG_EFUSE_CTRL  /* E-Fuse Control */
-
-#define VOLTAGE_V25            0x03
-#define LDOE25_SHIFT           28
-
-/*
- * When we want to enable write operation, we should change to
- * pwr on state. When we stop write, we should switch to 500k mode
- * and disable LDO 2.5V.
- */
-static void Efuse_PowerSwitch(struct rtw_adapter *padapter,
-                             u8 bWrite, u8 PwrState)
-{
-       u8 tempval;
-       u16 tmpV16;
-
-       if (PwrState == true) {
-               rtl8723au_write8(padapter, REG_EFUSE_ACCESS, EFUSE_ACCESS_ON);
-
-               /*
-                * 1.2V Power: From VDDON with Power
-                * Cut(0x0000h[15]), default valid
-                */
-               tmpV16 = rtl8723au_read16(padapter, REG_SYS_ISO_CTRL);
-               if (!(tmpV16 & PWC_EV12V)) {
-                       tmpV16 |= PWC_EV12V;
-                       rtl8723au_write16(padapter, REG_SYS_ISO_CTRL, tmpV16);
-               }
-               /* Reset: 0x0000h[28], default valid */
-               tmpV16 = rtl8723au_read16(padapter, REG_SYS_FUNC_EN);
-               if (!(tmpV16 & FEN_ELDR)) {
-                       tmpV16 |= FEN_ELDR;
-                       rtl8723au_write16(padapter, REG_SYS_FUNC_EN, tmpV16);
-               }
-
-               /*
-                * Clock: Gated(0x0008h[5]) 8M(0x0008h[1])
-                * clock from ANA, default valid
-                */
-               tmpV16 = rtl8723au_read16(padapter, REG_SYS_CLKR);
-               if ((!(tmpV16 & LOADER_CLK_EN)) || (!(tmpV16 & ANA8M))) {
-                       tmpV16 |= (LOADER_CLK_EN | ANA8M);
-                       rtl8723au_write16(padapter, REG_SYS_CLKR, tmpV16);
-               }
-
-               if (bWrite == true) {
-                       /*  Enable LDO 2.5V before read/write action */
-                       tempval = rtl8723au_read8(padapter, EFUSE_TEST + 3);
-                       tempval &= 0x0F;
-                       tempval |= (VOLTAGE_V25 << 4);
-                       rtl8723au_write8(padapter, EFUSE_TEST + 3,
-                                        tempval | 0x80);
-               }
-       } else {
-               rtl8723au_write8(padapter, REG_EFUSE_ACCESS, EFUSE_ACCESS_OFF);
-
-               if (bWrite == true) {
-                       /*  Disable LDO 2.5V after read/write action */
-                       tempval = rtl8723au_read8(padapter, EFUSE_TEST + 3);
-                       rtl8723au_write8(padapter, EFUSE_TEST + 3,
-                                        tempval & 0x7F);
-               }
-       }
-}
-
-u16 Efuse_GetCurrentSize23a(struct rtw_adapter *pAdapter, u8 efuseType)
-{
-       u16 ret = 0;
-
-       if (efuseType == EFUSE_WIFI)
-               ret = rtl8723a_EfuseGetCurrentSize_WiFi(pAdapter);
-       else
-               ret = rtl8723a_EfuseGetCurrentSize_BT(pAdapter);
-
-       return ret;
-}
-
-/* Get current efuse area enabled word */
-u8 Efuse_CalculateWordCnts23a(u8 word_en)
-{
-       return hweight8((~word_en) & 0xf);
-}
-
-/*
- * Description: Execute E-Fuse read byte operation.
- *
- * Assumptions: 1. Boot from E-Fuse and successfully auto-load.
- *              2. PASSIVE_LEVEL (USB interface)
- */
-void ReadEFuseByte23a(struct rtw_adapter *Adapter, u16 _offset, u8 *pbuf)
-{
-       u32     value32;
-       u8      readbyte;
-       u16     retry;
-
-       /* Write Address */
-       rtl8723au_write8(Adapter, EFUSE_CTRL+1, (_offset & 0xff));
-       readbyte = rtl8723au_read8(Adapter, EFUSE_CTRL+2);
-       rtl8723au_write8(Adapter, EFUSE_CTRL+2,
-                        ((_offset >> 8) & 0x03) | (readbyte & 0xfc));
-
-       /* Write bit 32 0 */
-       readbyte = rtl8723au_read8(Adapter, EFUSE_CTRL+3);
-       rtl8723au_write8(Adapter, EFUSE_CTRL+3, readbyte & 0x7f);
-
-       /* Check bit 32 read-ready */
-       retry = 0;
-       value32 = rtl8723au_read32(Adapter, EFUSE_CTRL);
-       while (!((value32 >> 24) & 0x80) && retry < 10000) {
-               value32 = rtl8723au_read32(Adapter, EFUSE_CTRL);
-               retry++;
-       }
-
-       /*
-        * Added suggested delay. This fixes the problem that
-        * Efuse read error in high temperature condition.
-        * Designer says that there shall be some delay after
-        * ready bit is set, or the result will always stay
-        * on last data we read.
-        */
-       udelay(50);
-       value32 = rtl8723au_read32(Adapter, EFUSE_CTRL);
-
-       *pbuf = (u8)(value32 & 0xff);
-}
-
-void EFUSE_GetEfuseDefinition23a(struct rtw_adapter *pAdapter, u8 efuseType,
-                                u8 type, void *pOut)
-{
-       u8 *pu1Tmp;
-       u16 *pu2Tmp;
-       u8 *pMax_section;
-
-       switch (type) {
-       case TYPE_EFUSE_MAX_SECTION:
-               pMax_section = pOut;
-
-               if (efuseType == EFUSE_WIFI)
-                       *pMax_section = EFUSE_MAX_SECTION_8723A;
-               else
-                       *pMax_section = EFUSE_BT_MAX_SECTION;
-               break;
-
-       case TYPE_EFUSE_REAL_CONTENT_LEN:
-               pu2Tmp = pOut;
-
-               if (efuseType == EFUSE_WIFI)
-                       *pu2Tmp = EFUSE_REAL_CONTENT_LEN_8723A;
-               else
-                       *pu2Tmp = EFUSE_BT_REAL_CONTENT_LEN;
-               break;
-
-       case TYPE_AVAILABLE_EFUSE_BYTES_BANK:
-               pu2Tmp = pOut;
-
-               if (efuseType == EFUSE_WIFI)
-                       *pu2Tmp = (EFUSE_REAL_CONTENT_LEN_8723A -
-                                  EFUSE_OOB_PROTECT_BYTES);
-               else
-                       *pu2Tmp = (EFUSE_BT_REAL_BANK_CONTENT_LEN -
-                                  EFUSE_PROTECT_BYTES_BANK);
-               break;
-
-       case TYPE_AVAILABLE_EFUSE_BYTES_TOTAL:
-               pu2Tmp = pOut;
-
-               if (efuseType == EFUSE_WIFI)
-                       *pu2Tmp = (EFUSE_REAL_CONTENT_LEN_8723A -
-                                  EFUSE_OOB_PROTECT_BYTES);
-               else
-                       *pu2Tmp = (EFUSE_BT_REAL_CONTENT_LEN -
-                                  (EFUSE_PROTECT_BYTES_BANK * 3));
-               break;
-
-       case TYPE_EFUSE_MAP_LEN:
-               pu2Tmp = pOut;
-
-               if (efuseType == EFUSE_WIFI)
-                       *pu2Tmp = EFUSE_MAP_LEN_8723A;
-               else
-                       *pu2Tmp = EFUSE_BT_MAP_LEN;
-               break;
-
-       case TYPE_EFUSE_PROTECT_BYTES_BANK:
-               pu1Tmp = pOut;
-
-               if (efuseType == EFUSE_WIFI)
-                       *pu1Tmp = EFUSE_OOB_PROTECT_BYTES;
-               else
-                       *pu1Tmp = EFUSE_PROTECT_BYTES_BANK;
-               break;
-
-       case TYPE_EFUSE_CONTENT_LEN_BANK:
-               pu2Tmp = pOut;
-
-               if (efuseType == EFUSE_WIFI)
-                       *pu2Tmp = EFUSE_REAL_CONTENT_LEN_8723A;
-               else
-                       *pu2Tmp = EFUSE_BT_REAL_BANK_CONTENT_LEN;
-               break;
-
-       default:
-               pu1Tmp = pOut;
-               *pu1Tmp = 0;
-               break;
-       }
-}
-
-/* Copy from WMAC for EFUSE read 1 byte. */
-u8 EFUSE_Read1Byte23a(struct rtw_adapter *Adapter, u16 Address)
-{
-       u8      data;
-       u8      Bytetemp = {0x00};
-       u8      temp = {0x00};
-       u32     k = 0;
-       u16     contentLen = 0;
-
-       EFUSE_GetEfuseDefinition23a(Adapter, EFUSE_WIFI,
-                                TYPE_EFUSE_REAL_CONTENT_LEN,
-                                (void *)&contentLen);
-
-       if (Address < contentLen) { /* E-fuse 512Byte */
-               /* Write E-fuse Register address bit0~7 */
-               temp = Address & 0xFF;
-               rtl8723au_write8(Adapter, EFUSE_CTRL+1, temp);
-               Bytetemp = rtl8723au_read8(Adapter, EFUSE_CTRL+2);
-               /* Write E-fuse Register address bit8~9 */
-               temp = ((Address >> 8) & 0x03) | (Bytetemp & 0xFC);
-               rtl8723au_write8(Adapter, EFUSE_CTRL+2, temp);
-
-               /* Write 0x30[31]= 0 */
-               Bytetemp = rtl8723au_read8(Adapter, EFUSE_CTRL+3);
-               temp = Bytetemp & 0x7F;
-               rtl8723au_write8(Adapter, EFUSE_CTRL+3, temp);
-
-               /* Wait Write-ready (0x30[31]= 1) */
-               Bytetemp = rtl8723au_read8(Adapter, EFUSE_CTRL+3);
-               while (!(Bytetemp & 0x80)) {
-                       Bytetemp = rtl8723au_read8(Adapter, EFUSE_CTRL+3);
-                       k++;
-                       if (k == 1000) {
-                               k = 0;
-                               break;
-                       }
-               }
-               data = rtl8723au_read8(Adapter, EFUSE_CTRL);
-               return data;
-       }
-       return 0xFF;
-}
-
-/* Read one byte from real Efuse. */
-int efuse_OneByteRead23a(struct rtw_adapter *pAdapter, u16 addr, u8 *data)
-{
-       u8      tmpidx = 0;
-       int     bResult;
-
-       /*  -----------------e-fuse reg ctrl ---------------------------- */
-       /* address */
-       rtl8723au_write8(pAdapter, EFUSE_CTRL + 1, (u8)(addr & 0xff));
-       rtl8723au_write8(pAdapter, EFUSE_CTRL + 2,
-                        ((u8)((addr >> 8) & 0x03)) |
-                        (rtl8723au_read8(pAdapter, EFUSE_CTRL + 2) & 0xFC));
-
-       rtl8723au_write8(pAdapter, EFUSE_CTRL + 3, 0x72); /* read cmd */
-
-       while (!(0x80 & rtl8723au_read8(pAdapter, EFUSE_CTRL + 3)) &&
-              (tmpidx < 100))
-               tmpidx++;
-       if (tmpidx < 100) {
-               *data = rtl8723au_read8(pAdapter, EFUSE_CTRL);
-               bResult = _SUCCESS;
-       } else {
-               *data = 0xff;
-               bResult = _FAIL;
-       }
-       return bResult;
-}
-
-/* Write one byte to reald Efuse. */
-int efuse_OneByteWrite23a(struct rtw_adapter *pAdapter, u16 addr, u8 data)
-{
-       u8      tmpidx = 0;
-       int     bResult;
-
-       /* return       0; */
-
-       /*  -----------------e-fuse reg ctrl ------------------------- */
-       /* address */
-       rtl8723au_write8(pAdapter, EFUSE_CTRL + 1, (u8)(addr & 0xff));
-       rtl8723au_write8(pAdapter, EFUSE_CTRL + 2,
-                        (rtl8723au_read8(pAdapter, EFUSE_CTRL + 2) & 0xFC) |
-                        (u8)((addr >> 8) & 0x03));
-       rtl8723au_write8(pAdapter, EFUSE_CTRL, data); /* data */
-
-       rtl8723au_write8(pAdapter, EFUSE_CTRL + 3, 0xF2); /* write cmd */
-
-       while ((0x80 & rtl8723au_read8(pAdapter, EFUSE_CTRL + 3)) &&
-              (tmpidx < 100)) {
-               tmpidx++;
-       }
-
-       if (tmpidx < 100)
-               bResult = _SUCCESS;
-       else
-               bResult = _FAIL;
-
-       return bResult;
-}
-
-/* Read allowed word in current efuse section data. */
-void efuse_WordEnableDataRead23a(u8 word_en, u8 *sourdata, u8 *targetdata)
-{
-       if (!(word_en&BIT(0))) {
-               targetdata[0] = sourdata[0];
-               targetdata[1] = sourdata[1];
-       }
-       if (!(word_en&BIT(1))) {
-               targetdata[2] = sourdata[2];
-               targetdata[3] = sourdata[3];
-       }
-       if (!(word_en&BIT(2))) {
-               targetdata[4] = sourdata[4];
-               targetdata[5] = sourdata[5];
-       }
-       if (!(word_en&BIT(3))) {
-               targetdata[6] = sourdata[6];
-               targetdata[7] = sourdata[7];
-       }
-}
-
-static int efuse_read8(struct rtw_adapter *padapter, u16 address, u8 *value)
-{
-       return efuse_OneByteRead23a(padapter, address, value);
-}
-
-static int efuse_write8(struct rtw_adapter *padapter, u16 address, u8 *value)
-{
-       return efuse_OneByteWrite23a(padapter, address, *value);
-}
-
-/* read/write raw efuse data */
-int rtw_efuse_access23a(struct rtw_adapter *padapter, u8 bWrite, u16 start_addr,
-                       u16 cnts, u8 *data)
-{
-       int i = 0;
-       u16 real_content_len = 0, max_available_size = 0;
-       int res = _FAIL;
-       int (*rw8)(struct rtw_adapter *, u16, u8*);
-
-       EFUSE_GetEfuseDefinition23a(padapter, EFUSE_WIFI,
-                                TYPE_EFUSE_REAL_CONTENT_LEN,
-                                (void *)&real_content_len);
-       EFUSE_GetEfuseDefinition23a(padapter, EFUSE_WIFI,
-                                TYPE_AVAILABLE_EFUSE_BYTES_TOTAL,
-                                (void *)&max_available_size);
-
-       if (start_addr > real_content_len)
-               return _FAIL;
-
-       if (true == bWrite) {
-               if ((start_addr + cnts) > max_available_size)
-                       return _FAIL;
-               rw8 = &efuse_write8;
-       } else
-               rw8 = &efuse_read8;
-
-       Efuse_PowerSwitch(padapter, bWrite, true);
-
-       /* e-fuse one byte read/write */
-       for (i = 0; i < cnts; i++) {
-               if (start_addr >= real_content_len) {
-                       res = _FAIL;
-                       break;
-               }
-
-               res = rw8(padapter, start_addr++, data++);
-               if (res == _FAIL)
-                       break;
-       }
-
-       Efuse_PowerSwitch(padapter, bWrite, false);
-
-       return res;
-}
-
-u16 efuse_GetMaxSize23a(struct rtw_adapter *padapter)
-{
-       u16 max_size;
-
-       EFUSE_GetEfuseDefinition23a(padapter, EFUSE_WIFI,
-                                TYPE_AVAILABLE_EFUSE_BYTES_TOTAL,
-                                (void *)&max_size);
-       return max_size;
-}
-
-int rtw_efuse_map_read23a(struct rtw_adapter *padapter,
-                         u16 addr, u16 cnts, u8 *data)
-{
-       u16 mapLen = 0;
-
-       EFUSE_GetEfuseDefinition23a(padapter, EFUSE_WIFI,
-                                TYPE_EFUSE_MAP_LEN, (void *)&mapLen);
-
-       if ((addr + cnts) > mapLen)
-               return _FAIL;
-
-       Efuse_PowerSwitch(padapter, false, true);
-
-       rtl8723a_readefuse(padapter, EFUSE_WIFI, addr, cnts, data);
-
-       Efuse_PowerSwitch(padapter, false, false);
-
-       return _SUCCESS;
-}
-
-int rtw_BT_efuse_map_read23a(struct rtw_adapter *padapter,
-                            u16 addr, u16 cnts, u8 *data)
-{
-       u16 mapLen = 0;
-
-       EFUSE_GetEfuseDefinition23a(padapter, EFUSE_BT,
-                                TYPE_EFUSE_MAP_LEN, (void *)&mapLen);
-
-       if ((addr + cnts) > mapLen)
-               return _FAIL;
-
-       Efuse_PowerSwitch(padapter, false, true);
-
-       rtl8723a_readefuse(padapter, EFUSE_BT, addr, cnts, data);
-
-       Efuse_PowerSwitch(padapter, false, false);
-
-       return _SUCCESS;
-}
-
-/* Read All Efuse content */
-static void Efuse_ReadAllMap(struct rtw_adapter *pAdapter, u8 efuseType,
-                            u8 *Efuse)
-{
-       u16     mapLen = 0;
-
-       Efuse_PowerSwitch(pAdapter, false, true);
-
-       EFUSE_GetEfuseDefinition23a(pAdapter, efuseType, TYPE_EFUSE_MAP_LEN,
-                                (void *)&mapLen);
-
-       rtl8723a_readefuse(pAdapter, efuseType, 0, mapLen, Efuse);
-
-       Efuse_PowerSwitch(pAdapter, false, false);
-}
-
-/*
- * Functions:  efuse_ShadowRead1Byte
- *             efuse_ShadowRead2Byte
- *             efuse_ShadowRead4Byte
- *
- * Read from efuse init map by one/two/four bytes
- */
-static void efuse_ShadowRead1Byte(struct rtw_adapter *pAdapter, u16 Offset,
-                                 u8 *Value)
-{
-       struct eeprom_priv *pEEPROM = GET_EEPROM_EFUSE_PRIV(pAdapter);
-
-       *Value = pEEPROM->efuse_eeprom_data[Offset];
-}
-
-static void efuse_ShadowRead2Byte(struct rtw_adapter *pAdapter, u16 Offset,
-                                 u16 *Value)
-{
-       struct eeprom_priv *pEEPROM = GET_EEPROM_EFUSE_PRIV(pAdapter);
-
-       *Value = pEEPROM->efuse_eeprom_data[Offset];
-       *Value |= pEEPROM->efuse_eeprom_data[Offset+1]<<8;
-}
-
-static void efuse_ShadowRead4Byte(struct rtw_adapter *pAdapter, u16 Offset,
-                                 u32 *Value)
-{
-       struct eeprom_priv *pEEPROM = GET_EEPROM_EFUSE_PRIV(pAdapter);
-
-       *Value = pEEPROM->efuse_eeprom_data[Offset];
-       *Value |= pEEPROM->efuse_eeprom_data[Offset+1]<<8;
-       *Value |= pEEPROM->efuse_eeprom_data[Offset+2]<<16;
-       *Value |= pEEPROM->efuse_eeprom_data[Offset+3]<<24;
-}
-
-/* Transfer current EFUSE content to shadow init and modify map. */
-void EFUSE_ShadowMapUpdate23a(struct rtw_adapter *pAdapter, u8 efuseType)
-{
-       struct eeprom_priv *pEEPROM = GET_EEPROM_EFUSE_PRIV(pAdapter);
-       u16     mapLen = 0;
-
-       EFUSE_GetEfuseDefinition23a(pAdapter, efuseType,
-                                TYPE_EFUSE_MAP_LEN, (void *)&mapLen);
-
-       if (pEEPROM->bautoload_fail_flag == true)
-               memset(pEEPROM->efuse_eeprom_data, 0xFF, mapLen);
-       else
-               Efuse_ReadAllMap(pAdapter, efuseType,
-                                pEEPROM->efuse_eeprom_data);
-}
-
-/* Read from efuse init map */
-void EFUSE_ShadowRead23a(struct rtw_adapter *pAdapter, u8 Type,
-                        u16 Offset, u32 *Value)
-{
-       if (Type == 1)
-               efuse_ShadowRead1Byte(pAdapter, Offset, (u8 *)Value);
-       else if (Type == 2)
-               efuse_ShadowRead2Byte(pAdapter, Offset, (u16 *)Value);
-       else if (Type == 4)
-               efuse_ShadowRead4Byte(pAdapter, Offset, (u32 *)Value);
-}
diff --git a/drivers/staging/rtl8723au/core/rtw_ieee80211.c b/drivers/staging/rtl8723au/core/rtw_ieee80211.c
deleted file mode 100644 (file)
index 9fa0ef1..0000000
+++ /dev/null
@@ -1,855 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#define _IEEE80211_C
-
-#include <drv_types.h>
-#include <linux/ieee80211.h>
-#include <ieee80211.h>
-#include <wifi.h>
-#include <osdep_service.h>
-#include <wlan_bssdef.h>
-
-u8 RTW_WPA_OUI23A_TYPE[] = { 0x00, 0x50, 0xf2, 1 };
-u16 RTW_WPA_VERSION23A = 1;
-u8 WPA_AUTH_KEY_MGMT_NONE23A[] = { 0x00, 0x50, 0xf2, 0 };
-u8 WPA_AUTH_KEY_MGMT_UNSPEC_802_1X23A[] = { 0x00, 0x50, 0xf2, 1 };
-u8 WPA_AUTH_KEY_MGMT_PSK_OVER_802_1X23A[] = { 0x00, 0x50, 0xf2, 2 };
-u8 WPA_CIPHER_SUITE_NONE23A[] = { 0x00, 0x50, 0xf2, 0 };
-u8 WPA_CIPHER_SUITE_WEP4023A[] = { 0x00, 0x50, 0xf2, 1 };
-u8 WPA_CIPHER_SUITE_TKIP23A[] = { 0x00, 0x50, 0xf2, 2 };
-u8 WPA_CIPHER_SUITE_WRAP23A[] = { 0x00, 0x50, 0xf2, 3 };
-u8 WPA_CIPHER_SUITE_CCMP23A[] = { 0x00, 0x50, 0xf2, 4 };
-u8 WPA_CIPHER_SUITE_WEP10423A[] = { 0x00, 0x50, 0xf2, 5 };
-
-u8 RSN_AUTH_KEY_MGMT_UNSPEC_802_1X23A[] = { 0x00, 0x0f, 0xac, 1 };
-u8 RSN_AUTH_KEY_MGMT_PSK_OVER_802_1X23A[] = { 0x00, 0x0f, 0xac, 2 };
-u8 RSN_CIPHER_SUITE_NONE23A[] = { 0x00, 0x0f, 0xac, 0 };
-u8 RSN_CIPHER_SUITE_WEP4023A[] = { 0x00, 0x0f, 0xac, 1 };
-u8 RSN_CIPHER_SUITE_TKIP23A[] = { 0x00, 0x0f, 0xac, 2 };
-u8 RSN_CIPHER_SUITE_WRAP23A[] = { 0x00, 0x0f, 0xac, 3 };
-u8 RSN_CIPHER_SUITE_CCMP23A[] = { 0x00, 0x0f, 0xac, 4 };
-u8 RSN_CIPHER_SUITE_WEP10423A[] = { 0x00, 0x0f, 0xac, 5 };
-/*  */
-/*  for adhoc-master to generate ie and provide supported-rate to fw */
-/*  */
-
-static u8 WIFI_CCKRATES[] = {
-       IEEE80211_CCK_RATE_1MB | IEEE80211_BASIC_RATE_MASK,
-       IEEE80211_CCK_RATE_2MB | IEEE80211_BASIC_RATE_MASK,
-       IEEE80211_CCK_RATE_5MB | IEEE80211_BASIC_RATE_MASK,
-       IEEE80211_CCK_RATE_11MB | IEEE80211_BASIC_RATE_MASK
-};
-
-static u8 WIFI_OFDMRATES[] = {
-       IEEE80211_OFDM_RATE_6MB,
-       IEEE80211_OFDM_RATE_9MB,
-       IEEE80211_OFDM_RATE_12MB,
-       IEEE80211_OFDM_RATE_18MB,
-       IEEE80211_OFDM_RATE_24MB,
-       IEEE80211_OFDM_RATE_36MB,
-       IEEE80211_OFDM_RATE_48MB,
-       IEEE80211_OFDM_RATE_54MB
-};
-
-int rtw_get_bit_value_from_ieee_value23a(u8 val)
-{
-       unsigned char dot11_rate_table[] =
-               {2, 4, 11, 22, 12, 18, 24, 36, 48, 72, 96, 108, 0};
-
-       int i = 0;
-
-       while (dot11_rate_table[i] != 0) {
-               if (dot11_rate_table[i] == val)
-                       return BIT(i);
-               i++;
-       }
-       return 0;
-}
-
-static bool rtw_is_cckrates_included(u8 *rate)
-{
-       u32 i = 0;
-
-       while (rate[i]) {
-               if ((rate[i] & 0x7f) == 2 || (rate[i] & 0x7f) == 4 ||
-                   (rate[i] & 0x7f) == 11 || (rate[i] & 0x7f) == 22)
-                       return true;
-               i++;
-       }
-
-       return false;
-}
-
-static bool rtw_is_cckratesonly_included(u8 *rate)
-{
-       u32 i = 0;
-
-       while (rate[i]) {
-               if ((rate[i] & 0x7f) != 2 && (rate[i] & 0x7f) != 4 &&
-                   (rate[i] & 0x7f) != 11 && (rate[i] & 0x7f) != 22)
-                       return false;
-
-               i++;
-       }
-
-       return true;
-}
-
-int rtw_check_network_type23a(unsigned char *rate, int ratelen, int channel)
-{
-       if (channel > 14) {
-               if (rtw_is_cckrates_included(rate))
-                       return WIRELESS_INVALID;
-               else
-                       return WIRELESS_11A;
-       } else {  /*  could be pure B, pure G, or B/G */
-               if (rtw_is_cckratesonly_included(rate))
-                       return WIRELESS_11B;
-               else if (rtw_is_cckrates_included(rate))
-                       return  WIRELESS_11BG;
-               else
-                       return WIRELESS_11G;
-       }
-}
-
-/*  rtw_set_ie23a will update frame length */
-u8 *rtw_set_ie23a(u8 *pbuf, int index, uint len, const u8 *source, uint *frlen)
-{
-
-       *pbuf = (u8)index;
-
-       *(pbuf + 1) = (u8)len;
-
-       if (len > 0)
-               memcpy((void *)(pbuf + 2), (void *)source, len);
-
-       *frlen = *frlen + (len + 2);
-
-       return pbuf + len + 2;
-}
-
-inline u8 *rtw_set_ie23a_ch_switch(u8 *buf, u32 *buf_len, u8 ch_switch_mode,
-                               u8 new_ch, u8 ch_switch_cnt)
-{
-       u8 ie_data[3];
-
-       ie_data[0] = ch_switch_mode;
-       ie_data[1] = new_ch;
-       ie_data[2] = ch_switch_cnt;
-       return rtw_set_ie23a(buf, WLAN_EID_CHANNEL_SWITCH,  3, ie_data, buf_len);
-}
-
-inline u8 hal_ch_offset_to_secondary_ch_offset23a(u8 ch_offset)
-{
-       if (ch_offset == HAL_PRIME_CHNL_OFFSET_LOWER)
-               return IEEE80211_HT_PARAM_CHA_SEC_BELOW;
-       else if (ch_offset == HAL_PRIME_CHNL_OFFSET_UPPER)
-               return IEEE80211_HT_PARAM_CHA_SEC_ABOVE;
-
-       return IEEE80211_HT_PARAM_CHA_SEC_NONE;
-}
-
-inline u8 *rtw_set_ie23a_secondary_ch_offset(u8 *buf, u32 *buf_len,
-                                         u8 secondary_ch_offset)
-{
-       return rtw_set_ie23a(buf, WLAN_EID_SECONDARY_CHANNEL_OFFSET,
-                         1, &secondary_ch_offset, buf_len);
-}
-
-/*----------------------------------------------------------------------------
-index: the information element id index, limit is the limit for search
------------------------------------------------------------------------------*/
-u8 *rtw_get_ie23a(u8 *pbuf, int index, int *len, int limit)
-{
-       int tmp, i;
-       u8 *p;
-
-       if (limit < 1) {
-
-               return NULL;
-       }
-
-       p = pbuf;
-       i = 0;
-       *len = 0;
-       while (1) {
-               if (*p == index) {
-                       *len = *(p + 1);
-                       return p;
-               } else {
-                       tmp = *(p + 1);
-                       p += (tmp + 2);
-                       i += (tmp + 2);
-               }
-               if (i >= limit)
-                       break;
-       }
-
-       return NULL;
-}
-
-/**
- * rtw_get_ie23a_ex - Search specific IE from a series of IEs
- * @in_ie: Address of IEs to search
- * @in_len: Length limit from in_ie
- * @eid: Element ID to match
- * @oui: OUI to match
- * @oui_len: OUI length
- * @ie: If not NULL and the specific IE is found, the IE will be copied
- *      to the buf starting from the specific IE
- * @ielen: If not NULL and the specific IE is found, will set to the length
- *         of the entire IE
- *
- * Returns: The address of the specific IE found, or NULL
- */
-u8 *rtw_get_ie23a_ex(u8 *in_ie, uint in_len, u8 eid, u8 *oui, u8 oui_len,
-                 u8 *ie, uint *ielen)
-{
-       uint cnt;
-       u8 *target_ie = NULL;
-
-       if (ielen)
-               *ielen = 0;
-
-       if (!in_ie || in_len <= 0)
-               return target_ie;
-
-       cnt = 0;
-
-       while (cnt < in_len) {
-               if (eid == in_ie[cnt] &&
-                   (!oui || !memcmp(&in_ie[cnt + 2], oui, oui_len))) {
-                       target_ie = &in_ie[cnt];
-
-                       if (ie)
-                               memcpy(ie, &in_ie[cnt], in_ie[cnt + 1] + 2);
-
-                       if (ielen)
-                               *ielen = in_ie[cnt + 1] + 2;
-                       break;
-               } else {
-                       cnt += in_ie[cnt + 1] + 2; /* goto next */
-               }
-       }
-
-       return target_ie;
-}
-
-/**
- * rtw_ies_remove_ie23a - Find matching IEs and remove
- * @ies: Address of IEs to search
- * @ies_len: Pointer of length of ies, will update to new length
- * @offset: The offset to start search
- * @eid: Element ID to match
- * @oui: OUI to match
- * @oui_len: OUI length
- *
- * Returns: _SUCCESS: ies is updated, _FAIL: not updated
- */
-int rtw_ies_remove_ie23a(u8 *ies, uint *ies_len, uint offset, u8 eid,
-                     u8 *oui, u8 oui_len)
-{
-       int ret = _FAIL;
-       u8 *target_ie;
-       u32 target_ielen;
-       u8 *start;
-       uint search_len;
-
-       if (!ies || !ies_len || *ies_len <= offset)
-               goto exit;
-
-       start = ies + offset;
-       search_len = *ies_len - offset;
-
-       while (1) {
-               target_ie = rtw_get_ie23a_ex(start, search_len, eid, oui, oui_len,
-                                         NULL, &target_ielen);
-               if (target_ie && target_ielen) {
-                       u8 buf[MAX_IE_SZ] = {0};
-                       u8 *remain_ies = target_ie + target_ielen;
-                       uint remain_len = search_len - (remain_ies - start);
-
-                       memcpy(buf, remain_ies, remain_len);
-                       memcpy(target_ie, buf, remain_len);
-                       *ies_len = *ies_len - target_ielen;
-                       ret = _SUCCESS;
-
-                       start = target_ie;
-                       search_len = remain_len;
-               } else {
-                       break;
-               }
-       }
-exit:
-       return ret;
-}
-
-void rtw_set_supported_rate23a(u8 *SupportedRates, uint mode)
-{
-
-
-       memset(SupportedRates, 0, NDIS_802_11_LENGTH_RATES_EX);
-
-       switch (mode) {
-       case WIRELESS_11B:
-               memcpy(SupportedRates, WIFI_CCKRATES, IEEE80211_CCK_RATE_LEN);
-               break;
-
-       case WIRELESS_11G:
-       case WIRELESS_11A:
-       case WIRELESS_11_5N:
-       case WIRELESS_11A_5N:/* Todo: no basic rate for ofdm ? */
-               memcpy(SupportedRates, WIFI_OFDMRATES,
-                      IEEE80211_NUM_OFDM_RATESLEN);
-               break;
-
-       case WIRELESS_11BG:
-       case WIRELESS_11G_24N:
-       case WIRELESS_11_24N:
-       case WIRELESS_11BG_24N:
-               memcpy(SupportedRates, WIFI_CCKRATES, IEEE80211_CCK_RATE_LEN);
-               memcpy(SupportedRates + IEEE80211_CCK_RATE_LEN, WIFI_OFDMRATES,
-                      IEEE80211_NUM_OFDM_RATESLEN);
-               break;
-       }
-
-}
-
-uint rtw_get_rateset_len23a(u8 *rateset)
-{
-       uint i = 0;
-
-       while (1) {
-               if (rateset[i] == 0)
-                       break;
-
-               if (i > 12)
-                       break;
-
-               i++;
-       }
-
-       return i;
-}
-
-int rtw_generate_ie23a(struct registry_priv *pregistrypriv)
-{
-       u8      wireless_mode;
-       int     sz = 0, rateLen;
-       struct wlan_bssid_ex *pdev_network = &pregistrypriv->dev_network;
-       u8      *ie = pdev_network->IEs;
-       u16     cap;
-
-       pdev_network->tsf = 0;
-
-       cap = WLAN_CAPABILITY_IBSS;
-
-       if (pregistrypriv->preamble == PREAMBLE_SHORT)
-               cap |= WLAN_CAPABILITY_SHORT_PREAMBLE;
-
-       if (pdev_network->Privacy)
-               cap |= WLAN_CAPABILITY_PRIVACY;
-
-       pdev_network->capability = cap;
-
-       /* SSID */
-       ie = rtw_set_ie23a(ie, WLAN_EID_SSID, pdev_network->Ssid.ssid_len,
-                       pdev_network->Ssid.ssid, &sz);
-
-       /* supported rates */
-       if (pregistrypriv->wireless_mode == WIRELESS_11ABGN) {
-               if (pdev_network->DSConfig > 14)
-                       wireless_mode = WIRELESS_11A_5N;
-               else
-                       wireless_mode = WIRELESS_11BG_24N;
-       } else {
-               wireless_mode = pregistrypriv->wireless_mode;
-       }
-
-       rtw_set_supported_rate23a(pdev_network->SupportedRates, wireless_mode);
-
-       rateLen = rtw_get_rateset_len23a(pdev_network->SupportedRates);
-
-       if (rateLen > 8) {
-               ie = rtw_set_ie23a(ie, WLAN_EID_SUPP_RATES, 8,
-                               pdev_network->SupportedRates, &sz);
-               /* ie = rtw_set_ie23a(ie, _EXT_SUPPORTEDRATES_IE_, (rateLen - 8), (pdev_network->SupportedRates + 8), &sz); */
-       } else {
-               ie = rtw_set_ie23a(ie, WLAN_EID_SUPP_RATES, rateLen,
-                               pdev_network->SupportedRates, &sz);
-       }
-
-       /* DS parameter set */
-       ie = rtw_set_ie23a(ie, WLAN_EID_DS_PARAMS, 1,
-                          (u8 *)&pdev_network->DSConfig, &sz);
-
-       /* IBSS Parameter Set */
-
-       ie = rtw_set_ie23a(ie, WLAN_EID_IBSS_PARAMS, 2,
-                          (u8 *)&pdev_network->ATIMWindow, &sz);
-
-       if (rateLen > 8) {
-               ie = rtw_set_ie23a(ie, WLAN_EID_EXT_SUPP_RATES, (rateLen - 8),
-                               (pdev_network->SupportedRates + 8), &sz);
-       }
-
-
-
-       /* return _SUCCESS; */
-
-       return sz;
-}
-
-static int rtw_get_wpa_cipher_suite(const u8 *s)
-{
-       if (!memcmp(s, WPA_CIPHER_SUITE_NONE23A, WPA_SELECTOR_LEN))
-               return WPA_CIPHER_NONE;
-       if (!memcmp(s, WPA_CIPHER_SUITE_WEP4023A, WPA_SELECTOR_LEN))
-               return WPA_CIPHER_WEP40;
-       if (!memcmp(s, WPA_CIPHER_SUITE_TKIP23A, WPA_SELECTOR_LEN))
-               return WPA_CIPHER_TKIP;
-       if (!memcmp(s, WPA_CIPHER_SUITE_CCMP23A, WPA_SELECTOR_LEN))
-               return WPA_CIPHER_CCMP;
-       if (!memcmp(s, WPA_CIPHER_SUITE_WEP10423A, WPA_SELECTOR_LEN))
-               return WPA_CIPHER_WEP104;
-
-       return 0;
-}
-
-static int rtw_get_wpa2_cipher_suite(const u8 *s)
-{
-       if (!memcmp(s, RSN_CIPHER_SUITE_NONE23A, RSN_SELECTOR_LEN))
-               return WPA_CIPHER_NONE;
-       if (!memcmp(s, RSN_CIPHER_SUITE_WEP4023A, RSN_SELECTOR_LEN))
-               return WPA_CIPHER_WEP40;
-       if (!memcmp(s, RSN_CIPHER_SUITE_TKIP23A, RSN_SELECTOR_LEN))
-               return WPA_CIPHER_TKIP;
-       if (!memcmp(s, RSN_CIPHER_SUITE_CCMP23A, RSN_SELECTOR_LEN))
-               return WPA_CIPHER_CCMP;
-       if (!memcmp(s, RSN_CIPHER_SUITE_WEP10423A, RSN_SELECTOR_LEN))
-               return WPA_CIPHER_WEP104;
-
-       return 0;
-}
-
-int rtw_parse_wpa_ie23a(const u8 *wpa_ie, int wpa_ie_len, int *group_cipher,
-                       int *pairwise_cipher, int *is_8021x)
-{
-       int i, ret = _SUCCESS;
-       int left, count;
-       const u8 *pos;
-
-       if (wpa_ie_len <= 0) {
-               /* No WPA IE - fail silently */
-               return _FAIL;
-       }
-
-       if (wpa_ie[1] != (u8)(wpa_ie_len - 2))
-               return _FAIL;
-
-       pos = wpa_ie;
-
-       pos += 8;
-       left = wpa_ie_len - 8;
-
-       /* group_cipher */
-       if (left >= WPA_SELECTOR_LEN) {
-
-               *group_cipher = rtw_get_wpa_cipher_suite(pos);
-
-               pos += WPA_SELECTOR_LEN;
-               left -= WPA_SELECTOR_LEN;
-       } else if (left > 0) {
-               RT_TRACE(_module_rtl871x_mlme_c_, _drv_err_,
-                        "%s: ie length mismatch, %u too much\n",
-                        __func__, left);
-
-               return _FAIL;
-       }
-
-       /* pairwise_cipher */
-       if (left >= 2) {
-                /* count = le16_to_cpu(*(u16*)pos); */
-               count = get_unaligned_le16(pos);
-               pos += 2;
-               left -= 2;
-
-               if (count == 0 || left < count * WPA_SELECTOR_LEN) {
-                       RT_TRACE(_module_rtl871x_mlme_c_, _drv_err_,
-                                "%s: ie count botch (pairwise), count %u left %u\n",
-                                __func__, count, left);
-                       return _FAIL;
-               }
-
-               for (i = 0; i < count; i++) {
-                       *pairwise_cipher |= rtw_get_wpa_cipher_suite(pos);
-
-                       pos += WPA_SELECTOR_LEN;
-                       left -= WPA_SELECTOR_LEN;
-               }
-       } else if (left == 1) {
-               RT_TRACE(_module_rtl871x_mlme_c_, _drv_err_,
-                        "%s: ie too short (for key mgmt)\n", __func__);
-               return _FAIL;
-       }
-
-       if (is_8021x) {
-               if (left >= 6) {
-                       pos += 2;
-                       if (!memcmp(pos, RTW_WPA_OUI23A_TYPE, 4)) {
-                               RT_TRACE(_module_rtl871x_mlme_c_, _drv_info_,
-                                        "%s : there has 802.1x auth\n",
-                                        __func__);
-                               *is_8021x = 1;
-                       }
-               }
-       }
-
-       return ret;
-}
-
-int rtw_parse_wpa2_ie23a(const u8 *rsn_ie, int rsn_ie_len, int *group_cipher,
-                     int *pairwise_cipher, int *is_8021x)
-{
-       int i, ret = _SUCCESS;
-       int left, count;
-       const u8 *pos;
-       u8 SUITE_1X[4] = {0x00, 0x0f, 0xac, 0x01};
-
-       if (rsn_ie_len <= 0) {
-               /* No RSN IE - fail silently */
-               return _FAIL;
-       }
-
-       if (*rsn_ie != WLAN_EID_RSN || *(rsn_ie + 1) != (u8)(rsn_ie_len - 2)) {
-               return _FAIL;
-       }
-
-       pos = rsn_ie;
-       pos += 4;
-       left = rsn_ie_len - 4;
-
-       /* group_cipher */
-       if (left >= RSN_SELECTOR_LEN) {
-               *group_cipher = rtw_get_wpa2_cipher_suite(pos);
-
-               pos += RSN_SELECTOR_LEN;
-               left -= RSN_SELECTOR_LEN;
-       } else if (left > 0) {
-               RT_TRACE(_module_rtl871x_mlme_c_, _drv_err_,
-                        "%s: ie length mismatch, %u too much\n",
-                        __func__, left);
-               return _FAIL;
-       }
-
-       /* pairwise_cipher */
-       if (left >= 2) {
-               /* count = le16_to_cpu(*(u16*)pos); */
-               count = get_unaligned_le16(pos);
-               pos += 2;
-               left -= 2;
-
-               if (count == 0 || left < count * RSN_SELECTOR_LEN) {
-                       RT_TRACE(_module_rtl871x_mlme_c_, _drv_err_,
-                                "%s: ie count botch (pairwise), count %u left %u\n",
-                                __func__, count, left);
-                       return _FAIL;
-               }
-
-               for (i = 0; i < count; i++) {
-                       *pairwise_cipher |= rtw_get_wpa2_cipher_suite(pos);
-
-                       pos += RSN_SELECTOR_LEN;
-                       left -= RSN_SELECTOR_LEN;
-               }
-       } else if (left == 1) {
-               RT_TRACE(_module_rtl871x_mlme_c_, _drv_err_,
-                        "%s: ie too short (for key mgmt)\n",  __func__);
-
-               return _FAIL;
-       }
-
-       if (is_8021x) {
-               if (left >= 6) {
-                       pos += 2;
-                       if (!memcmp(pos, SUITE_1X, 4)) {
-                               RT_TRACE(_module_rtl871x_mlme_c_, _drv_info_,
-                                        "%s (): there has 802.1x auth\n",
-                                        __func__);
-                               *is_8021x = 1;
-                       }
-               }
-       }
-
-       return ret;
-}
-
-/**
- * rtw_get_wps_attr23a - Search a specific WPS attribute from a given WPS IE
- * @wps_ie: Address of WPS IE to search
- * @wps_ielen: Length limit from wps_ie
- * @target_attr_id: The attribute ID of WPS attribute to search
- * @buf_attr: If not NULL and the WPS attribute is found, WPS attribute
- *            will be copied to the buf starting from buf_attr
- * @len_attr: If not NULL and the WPS attribute is found, will set to the
- *            length of the entire WPS attribute
- *
- * Returns: the address of the specific WPS attribute found, or NULL
- */
-const u8 *rtw_get_wps_attr23a(const u8 *wps_ie, uint wps_ielen,
-                             u16 target_attr_id, u8 *buf_attr, u32 *len_attr)
-{
-       const u8 *attr_ptr = NULL;
-       const u8 *target_attr_ptr = NULL;
-       u8 wps_oui[4] = {0x00, 0x50, 0xF2, 0x04};
-
-       if (len_attr)
-               *len_attr = 0;
-
-       if (wps_ie[0] != WLAN_EID_VENDOR_SPECIFIC ||
-           memcmp(wps_ie + 2, wps_oui, 4)) {
-               return attr_ptr;
-       }
-
-       /*  6 = 1(Element ID) + 1(Length) + 4(WPS OUI) */
-       attr_ptr = wps_ie + 6; /* goto first attr */
-
-       while (attr_ptr - wps_ie < wps_ielen) {
-               /*  4 = 2(Attribute ID) + 2(Length) */
-               u16 attr_id = get_unaligned_be16(attr_ptr);
-               u16 attr_data_len = get_unaligned_be16(attr_ptr + 2);
-               u16 attr_len = attr_data_len + 4;
-
-               /* DBG_8723A("%s attr_ptr:%p, id:%u, length:%u\n", __func__, attr_ptr, attr_id, attr_data_len); */
-               if (attr_id == target_attr_id) {
-                       target_attr_ptr = attr_ptr;
-
-                       if (buf_attr)
-                               memcpy(buf_attr, attr_ptr, attr_len);
-
-                       if (len_attr)
-                               *len_attr = attr_len;
-
-                       break;
-               } else {
-                       attr_ptr += attr_len; /* goto next */
-               }
-       }
-
-       return target_attr_ptr;
-}
-
-/**
- * rtw_get_wps_attr_content23a - Search a specific WPS attribute content
- * from a given WPS IE
- * @wps_ie: Address of WPS IE to search
- * @wps_ielen: Length limit from wps_ie
- * @target_attr_id: The attribute ID of WPS attribute to search
- * @buf_content: If not NULL and the WPS attribute is found, WPS attribute
- *               content will be copied to the buf starting from buf_content
- * @len_content: If not NULL and the WPS attribute is found, will set to the
- *               length of the WPS attribute content
- *
- * Returns: the address of the specific WPS attribute content found, or NULL
- */
-const u8 *rtw_get_wps_attr_content23a(const u8 *wps_ie, uint wps_ielen,
-                                     u16 target_attr_id, u8 *buf_content)
-{
-       const u8 *attr_ptr;
-       u32 attr_len;
-
-       attr_ptr = rtw_get_wps_attr23a(wps_ie, wps_ielen, target_attr_id,
-                                   NULL, &attr_len);
-
-       if (attr_ptr && attr_len) {
-               if (buf_content)
-                       memcpy(buf_content, attr_ptr + 4, attr_len - 4);
-
-               return attr_ptr + 4;
-       }
-
-       return NULL;
-}
-
-static int rtw_get_cipher_info(struct wlan_network *pnetwork)
-{
-       const u8 *pbuf;
-       int group_cipher = 0, pairwise_cipher = 0, is8021x = 0;
-       int ret = _FAIL;
-       int r, plen;
-       char *pie;
-
-       pie = pnetwork->network.IEs;
-       plen = pnetwork->network.IELength;
-
-       pbuf = cfg80211_find_vendor_ie(WLAN_OUI_MICROSOFT,
-                                      WLAN_OUI_TYPE_MICROSOFT_WPA, pie, plen);
-
-       if (pbuf && pbuf[1] > 0) {
-               RT_TRACE(_module_rtl871x_mlme_c_, _drv_info_,
-                        "rtw_get_cipher_info: wpa_ielen: %d\n", pbuf[1]);
-               r = rtw_parse_wpa_ie23a(pbuf, pbuf[1] + 2, &group_cipher,
-                                    &pairwise_cipher, &is8021x);
-               if (r == _SUCCESS) {
-                       pnetwork->BcnInfo.pairwise_cipher = pairwise_cipher;
-                       pnetwork->BcnInfo.group_cipher = group_cipher;
-                       pnetwork->BcnInfo.is_8021x = is8021x;
-                       RT_TRACE(_module_rtl871x_mlme_c_, _drv_info_,
-                                "%s: pnetwork->pairwise_cipher: %d, is_8021x is %d\n",
-                                __func__, pnetwork->BcnInfo.pairwise_cipher,
-                                pnetwork->BcnInfo.is_8021x);
-                       ret = _SUCCESS;
-               }
-       } else {
-               pbuf = cfg80211_find_ie(WLAN_EID_RSN, pie, plen);
-
-               if (pbuf && pbuf[1] > 0) {
-                       RT_TRACE(_module_rtl871x_mlme_c_, _drv_info_,
-                                "get RSN IE\n");
-                       r = rtw_parse_wpa2_ie23a(pbuf, pbuf[1] + 2,
-                                             &group_cipher, &pairwise_cipher,
-                                             &is8021x);
-                       if (r == _SUCCESS) {
-                               RT_TRACE(_module_rtl871x_mlme_c_, _drv_info_,
-                                        "get RSN IE  OK!!!\n");
-                               pnetwork->BcnInfo.pairwise_cipher =
-                                       pairwise_cipher;
-                               pnetwork->BcnInfo.group_cipher = group_cipher;
-                               pnetwork->BcnInfo.is_8021x = is8021x;
-                               RT_TRACE(_module_rtl871x_mlme_c_, _drv_info_,
-                                        "%s: pnetwork->pairwise_cipher: %d,pnetwork->group_cipher is %d, is_8021x is %d\n",
-                                        __func__,
-                                        pnetwork->BcnInfo.pairwise_cipher,
-                                        pnetwork->BcnInfo.group_cipher,
-                                        pnetwork->BcnInfo.is_8021x);
-                               ret = _SUCCESS;
-                       }
-               }
-       }
-
-       return ret;
-}
-
-void rtw_get_bcn_info23a(struct wlan_network *pnetwork)
-{
-       u8 bencrypt = 0;
-       int pie_len;
-       u8 *pie;
-       const u8 *p;
-
-       if (pnetwork->network.capability & WLAN_CAPABILITY_PRIVACY) {
-               bencrypt = 1;
-               pnetwork->network.Privacy = 1;
-       } else
-               pnetwork->BcnInfo.encryp_protocol = ENCRYP_PROTOCOL_OPENSYS;
-
-       RT_TRACE(_module_rtl871x_mlme_c_, _drv_info_,
-                "%s: ssid =%s\n", __func__, pnetwork->network.Ssid.ssid);
-
-       pie = pnetwork->network.IEs;
-       pie_len = pnetwork->network.IELength;
-
-       p = cfg80211_find_ie(WLAN_EID_RSN, pie, pie_len);
-       if (p && p[1]) {
-               pnetwork->BcnInfo.encryp_protocol = ENCRYP_PROTOCOL_WPA2;
-       } else if (cfg80211_find_vendor_ie(WLAN_OUI_MICROSOFT,
-                                          WLAN_OUI_TYPE_MICROSOFT_WPA,
-                                          pie, pie_len)) {
-               pnetwork->BcnInfo.encryp_protocol = ENCRYP_PROTOCOL_WPA;
-       } else {
-               if (bencrypt)
-                       pnetwork->BcnInfo.encryp_protocol = ENCRYP_PROTOCOL_WEP;
-       }
-       RT_TRACE(_module_rtl871x_mlme_c_, _drv_info_,
-                "%s: pnetwork->encryp_protocol is %x\n", __func__,
-                pnetwork->BcnInfo.encryp_protocol);
-       RT_TRACE(_module_rtl871x_mlme_c_, _drv_info_,
-                "%s: pnetwork->encryp_protocol is %x\n", __func__,
-                pnetwork->BcnInfo.encryp_protocol);
-       rtw_get_cipher_info(pnetwork);
-
-       /* get bwmode and ch_offset */
-}
-
-/* show MCS rate, unit: 100Kbps */
-u16 rtw_mcs_rate23a(u8 rf_type, u8 bw_40MHz, u8 short_GI_20, u8 short_GI_40,
-                   struct ieee80211_mcs_info *mcs)
-{
-       u16 max_rate = 0;
-
-       if (rf_type == RF_1T1R) {
-               if (mcs->rx_mask[0] & BIT(7))
-                       max_rate = (bw_40MHz) ? ((short_GI_40) ? 1500 : 1350) :
-                               ((short_GI_20) ? 722 : 650);
-               else if (mcs->rx_mask[0] & BIT(6))
-                       max_rate = (bw_40MHz) ? ((short_GI_40) ? 1350 : 1215) :
-                               ((short_GI_20) ? 650 : 585);
-               else if (mcs->rx_mask[0] & BIT(5))
-                       max_rate = (bw_40MHz) ? ((short_GI_40) ? 1200 : 1080) :
-                               ((short_GI_20) ? 578 : 520);
-               else if (mcs->rx_mask[0] & BIT(4))
-                       max_rate = (bw_40MHz) ? ((short_GI_40) ? 900 : 810) :
-                               ((short_GI_20) ? 433 : 390);
-               else if (mcs->rx_mask[0] & BIT(3))
-                       max_rate = (bw_40MHz) ? ((short_GI_40) ? 600 : 540) :
-                               ((short_GI_20) ? 289 : 260);
-               else if (mcs->rx_mask[0] & BIT(2))
-                       max_rate = (bw_40MHz) ? ((short_GI_40) ? 450 : 405) :
-                               ((short_GI_20) ? 217 : 195);
-               else if (mcs->rx_mask[0] & BIT(1))
-                       max_rate = (bw_40MHz) ? ((short_GI_40) ? 300 : 270) :
-                               ((short_GI_20) ? 144 : 130);
-               else if (mcs->rx_mask[0] & BIT(0))
-                       max_rate = (bw_40MHz) ? ((short_GI_40) ? 150 : 135) :
-                               ((short_GI_20) ? 72 : 65);
-       } else {
-               if (mcs->rx_mask[1]) {
-                       if (mcs->rx_mask[1] & BIT(7))
-                               max_rate = (bw_40MHz) ? ((short_GI_40) ? 3000 : 2700) : ((short_GI_20) ? 1444 : 1300);
-                       else if (mcs->rx_mask[1] & BIT(6))
-                               max_rate = (bw_40MHz) ? ((short_GI_40) ? 2700 : 2430) : ((short_GI_20) ? 1300 : 1170);
-                       else if (mcs->rx_mask[1] & BIT(5))
-                               max_rate = (bw_40MHz) ? ((short_GI_40) ? 2400 : 2160) : ((short_GI_20) ? 1156 : 1040);
-                       else if (mcs->rx_mask[1] & BIT(4))
-                               max_rate = (bw_40MHz) ? ((short_GI_40) ? 1800 : 1620) : ((short_GI_20) ? 867 : 780);
-                       else if (mcs->rx_mask[1] & BIT(3))
-                               max_rate = (bw_40MHz) ? ((short_GI_40) ? 1200 : 1080) : ((short_GI_20) ? 578 : 520);
-                       else if (mcs->rx_mask[1] & BIT(2))
-                               max_rate = (bw_40MHz) ? ((short_GI_40) ? 900 : 810) : ((short_GI_20) ? 433 : 390);
-                       else if (mcs->rx_mask[1] & BIT(1))
-                               max_rate = (bw_40MHz) ? ((short_GI_40) ? 600 : 540) : ((short_GI_20) ? 289 : 260);
-                       else if (mcs->rx_mask[1] & BIT(0))
-                               max_rate = (bw_40MHz) ? ((short_GI_40) ? 300 : 270) : ((short_GI_20) ? 144 : 130);
-               } else {
-                       if (mcs->rx_mask[0] & BIT(7))
-                               max_rate = (bw_40MHz) ? ((short_GI_40) ? 1500 : 1350) : ((short_GI_20) ? 722 : 650);
-                       else if (mcs->rx_mask[0] & BIT(6))
-                               max_rate = (bw_40MHz) ? ((short_GI_40) ? 1350 : 1215) : ((short_GI_20) ? 650 : 585);
-                       else if (mcs->rx_mask[0] & BIT(5))
-                               max_rate = (bw_40MHz) ? ((short_GI_40) ? 1200 : 1080) : ((short_GI_20) ? 578 : 520);
-                       else if (mcs->rx_mask[0] & BIT(4))
-                               max_rate = (bw_40MHz) ? ((short_GI_40) ? 900 : 810) : ((short_GI_20) ? 433 : 390);
-                       else if (mcs->rx_mask[0] & BIT(3))
-                               max_rate = (bw_40MHz) ? ((short_GI_40) ? 600 : 540) : ((short_GI_20) ? 289 : 260);
-                       else if (mcs->rx_mask[0] & BIT(2))
-                               max_rate = (bw_40MHz) ? ((short_GI_40) ? 450 : 405) : ((short_GI_20) ? 217 : 195);
-                       else if (mcs->rx_mask[0] & BIT(1))
-                               max_rate = (bw_40MHz) ? ((short_GI_40) ? 300 : 270) : ((short_GI_20) ? 144 : 130);
-                       else if (mcs->rx_mask[0] & BIT(0))
-                               max_rate = (bw_40MHz) ? ((short_GI_40) ? 150 : 135) : ((short_GI_20) ? 72 : 65);
-               }
-       }
-       return max_rate;
-}
diff --git a/drivers/staging/rtl8723au/core/rtw_mlme.c b/drivers/staging/rtl8723au/core/rtw_mlme.c
deleted file mode 100644 (file)
index a786fc4..0000000
+++ /dev/null
@@ -1,2314 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#define _RTW_MLME_C_
-
-#include <osdep_service.h>
-#include <drv_types.h>
-#include <recv_osdep.h>
-#include <xmit_osdep.h>
-#include <hal_intf.h>
-#include <mlme_osdep.h>
-#include <sta_info.h>
-#include <linux/ieee80211.h>
-#include <wifi.h>
-#include <wlan_bssdef.h>
-#include <rtw_sreset.h>
-
-static struct wlan_network *
-rtw_select_candidate_from_queue(struct mlme_priv *pmlmepriv);
-static int rtw_do_join(struct rtw_adapter *padapter);
-
-static void rtw_init_mlme_timer(struct rtw_adapter *padapter)
-{
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-
-       setup_timer(&pmlmepriv->assoc_timer, rtw23a_join_to_handler,
-                   (unsigned long)padapter);
-
-       setup_timer(&pmlmepriv->scan_to_timer, rtw_scan_timeout_handler23a,
-                   (unsigned long)padapter);
-
-       setup_timer(&pmlmepriv->dynamic_chk_timer,
-                   rtw_dynamic_check_timer_handler, (unsigned long)padapter);
-
-       setup_timer(&pmlmepriv->set_scan_deny_timer,
-                   rtw_set_scan_deny_timer_hdl, (unsigned long)padapter);
-}
-
-int rtw_init_mlme_priv23a(struct rtw_adapter *padapter)
-{
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-
-       pmlmepriv->nic_hdl = padapter;
-
-       pmlmepriv->fw_state = 0;
-       pmlmepriv->cur_network.network.ifmode = NL80211_IFTYPE_UNSPECIFIED;
-       /*  1: active, 0: pasive. Maybe someday we should rename this
-           varable to "active_mode" (Jeff) */
-       pmlmepriv->scan_mode = SCAN_ACTIVE;
-
-       spin_lock_init(&pmlmepriv->lock);
-       _rtw_init_queue23a(&pmlmepriv->scanned_queue);
-
-       memset(&pmlmepriv->assoc_ssid, 0, sizeof(struct cfg80211_ssid));
-
-       rtw_clear_scan_deny(padapter);
-
-       rtw_init_mlme_timer(padapter);
-       return _SUCCESS;
-}
-
-#ifdef CONFIG_8723AU_AP_MODE
-static void rtw_free_mlme_ie_data(u8 **ppie, u32 *plen)
-{
-       if (*ppie) {
-               kfree(*ppie);
-               *plen = 0;
-               *ppie = NULL;
-       }
-}
-#endif
-
-void rtw23a_free_mlme_priv_ie_data(struct mlme_priv *pmlmepriv)
-{
-#ifdef CONFIG_8723AU_AP_MODE
-       kfree(pmlmepriv->assoc_req);
-       kfree(pmlmepriv->assoc_rsp);
-       rtw_free_mlme_ie_data(&pmlmepriv->wps_probe_req_ie,
-                             &pmlmepriv->wps_probe_req_ie_len);
-#endif
-}
-
-void rtw_free_mlme_priv23a(struct mlme_priv *pmlmepriv)
-{
-       RT_TRACE(_module_rtl871x_mlme_c_, _drv_err_,
-                "rtw_free_mlme_priv23a\n");
-
-       rtw23a_free_mlme_priv_ie_data(pmlmepriv);
-}
-
-struct wlan_network *rtw_alloc_network(struct mlme_priv *pmlmepriv, gfp_t gfp)
-{
-       struct wlan_network *pnetwork;
-
-       pnetwork = kzalloc(sizeof(struct wlan_network), gfp);
-       if (pnetwork) {
-               INIT_LIST_HEAD(&pnetwork->list);
-               pnetwork->network_type = 0;
-               pnetwork->fixed = false;
-               pnetwork->last_scanned = jiffies;
-               pnetwork->join_res = 0;
-       }
-
-       return pnetwork;
-}
-
-static void _rtw_free_network23a(struct mlme_priv *pmlmepriv,
-                                struct wlan_network *pnetwork)
-{
-       if (!pnetwork)
-               return;
-
-       if (pnetwork->fixed == true)
-               return;
-
-       list_del_init(&pnetwork->list);
-
-       kfree(pnetwork);
-}
-
-/*
- return the wlan_network with the matching addr
-
- Shall be called under atomic context... to avoid possible racing condition...
-*/
-struct wlan_network *
-rtw_find_network23a(struct rtw_queue *scanned_queue, u8 *addr)
-{
-       struct list_head *phead, *plist;
-       struct wlan_network *pnetwork = NULL;
-
-       if (is_zero_ether_addr(addr)) {
-               pnetwork = NULL;
-               goto exit;
-       }
-
-       /* spin_lock_bh(&scanned_queue->lock); */
-
-       phead = get_list_head(scanned_queue);
-       plist = phead->next;
-
-       while (plist != phead) {
-               pnetwork = container_of(plist, struct wlan_network, list);
-
-               if (ether_addr_equal(addr, pnetwork->network.MacAddress))
-                       break;
-
-               plist = plist->next;
-       }
-
-       if (plist == phead)
-               pnetwork = NULL;
-
-       /* spin_unlock_bh(&scanned_queue->lock); */
-
-exit:
-
-       return pnetwork;
-}
-
-void rtw_free_network_queue23a(struct rtw_adapter *padapter)
-{
-       struct list_head *phead;
-       struct wlan_network *pnetwork, *ptmp;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct rtw_queue *scanned_queue = &pmlmepriv->scanned_queue;
-
-       spin_lock_bh(&scanned_queue->lock);
-       phead = get_list_head(scanned_queue);
-       list_for_each_entry_safe(pnetwork, ptmp, phead, list)
-               _rtw_free_network23a(pmlmepriv, pnetwork);
-       spin_unlock_bh(&scanned_queue->lock);
-}
-
-int rtw_if_up23a(struct rtw_adapter *padapter)
-{
-       int res;
-
-       if (padapter->bDriverStopped || padapter->bSurpriseRemoved ||
-           !check_fwstate(&padapter->mlmepriv, _FW_LINKED)) {
-               RT_TRACE(_module_rtl871x_mlme_c_, _drv_info_,
-                        "rtw_if_up23a:bDriverStopped(%d) OR bSurpriseRemoved(%d)\n",
-                        padapter->bDriverStopped, padapter->bSurpriseRemoved);
-               res = false;
-       } else
-               res =  true;
-
-       return res;
-}
-
-void rtw_generate_random_ibss23a(u8 *pibss)
-{
-       unsigned long curtime = jiffies;
-
-       pibss[0] = 0x02;  /* in ad-hoc mode bit1 must set to 1 */
-       pibss[1] = 0x11;
-       pibss[2] = 0x87;
-       pibss[3] = curtime & 0xff;/* p[0]; */
-       pibss[4] = (curtime >> 8) & 0xff;/* p[1]; */
-       pibss[5] = (curtime >> 16) & 0xff;/* p[2]; */
-}
-
-void rtw_set_roaming(struct rtw_adapter *adapter, u8 to_roaming)
-{
-       if (to_roaming == 0)
-               adapter->mlmepriv.to_join = false;
-       adapter->mlmepriv.to_roaming = to_roaming;
-}
-
-static void _rtw_roaming(struct rtw_adapter *padapter,
-                        struct wlan_network *tgt_network)
-{
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct wlan_network *pnetwork;
-       int do_join_r;
-
-       if (tgt_network)
-               pnetwork = tgt_network;
-       else
-               pnetwork = &pmlmepriv->cur_network;
-
-       if (padapter->mlmepriv.to_roaming > 0) {
-               DBG_8723A("roaming from %s(%pM), length:%d\n",
-                         pnetwork->network.Ssid.ssid,
-                         pnetwork->network.MacAddress,
-                         pnetwork->network.Ssid.ssid_len);
-               memcpy(&pmlmepriv->assoc_ssid, &pnetwork->network.Ssid,
-                      sizeof(struct cfg80211_ssid));
-
-               pmlmepriv->assoc_by_bssid = false;
-
-               while (1) {
-                       do_join_r = rtw_do_join(padapter);
-                       if (do_join_r == _SUCCESS)
-                               break;
-                       else {
-                               DBG_8723A("roaming do_join return %d\n",
-                                         do_join_r);
-                               pmlmepriv->to_roaming--;
-
-                               if (padapter->mlmepriv.to_roaming > 0)
-                                       continue;
-                               else {
-                                       DBG_8723A("%s(%d) -to roaming fail, "
-                                                 "indicate_disconnect\n",
-                                                 __func__, __LINE__);
-                                       rtw_indicate_disconnect23a(padapter);
-                                       break;
-                               }
-                       }
-               }
-       }
-}
-
-void rtw23a_roaming(struct rtw_adapter *padapter,
-                   struct wlan_network *tgt_network)
-{
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-
-       spin_lock_bh(&pmlmepriv->lock);
-       _rtw_roaming(padapter, tgt_network);
-       spin_unlock_bh(&pmlmepriv->lock);
-}
-
-static void rtw_free_network_nolock(struct mlme_priv *pmlmepriv,
-                                   struct wlan_network *pnetwork)
-{
-       _rtw_free_network23a(pmlmepriv, pnetwork);
-}
-
-bool rtw_is_same_ibss23a(struct rtw_adapter *adapter,
-                        struct wlan_network *pnetwork)
-{
-       int ret;
-       struct security_priv *psecuritypriv = &adapter->securitypriv;
-
-       if (psecuritypriv->dot11PrivacyAlgrthm != 0 &&
-           pnetwork->network.Privacy == 0)
-               ret = false;
-       else if (psecuritypriv->dot11PrivacyAlgrthm == 0 &&
-                pnetwork->network.Privacy == 1)
-               ret = false;
-       else
-               ret = true;
-
-       return ret;
-}
-
-inline int is_same_ess(struct wlan_bssid_ex *a, struct wlan_bssid_ex *b);
-inline int is_same_ess(struct wlan_bssid_ex *a, struct wlan_bssid_ex *b)
-{
-       return (a->Ssid.ssid_len == b->Ssid.ssid_len) &&
-               !memcmp(a->Ssid.ssid, b->Ssid.ssid, a->Ssid.ssid_len);
-}
-
-int is_same_network23a(struct wlan_bssid_ex *src, struct wlan_bssid_ex *dst)
-{
-       u16 s_cap, d_cap;
-
-       s_cap = src->capability;
-       d_cap = dst->capability;
-
-       return ((src->Ssid.ssid_len == dst->Ssid.ssid_len) &&
-               /*      (src->DSConfig == dst->DSConfig) && */
-               ether_addr_equal(src->MacAddress, dst->MacAddress) &&
-               !memcmp(src->Ssid.ssid, dst->Ssid.ssid, src->Ssid.ssid_len) &&
-               (s_cap & WLAN_CAPABILITY_IBSS) ==
-               (d_cap & WLAN_CAPABILITY_IBSS) &&
-               (s_cap & WLAN_CAPABILITY_ESS) == (d_cap & WLAN_CAPABILITY_ESS));
-}
-
-struct wlan_network *
-rtw_get_oldest_wlan_network23a(struct rtw_queue *scanned_queue)
-{
-       struct list_head *phead;
-       struct wlan_network *pwlan;
-       struct wlan_network *oldest = NULL;
-
-       phead = get_list_head(scanned_queue);
-       list_for_each_entry(pwlan, phead, list) {
-               if (pwlan->fixed != true) {
-                       if (!oldest || time_after(oldest->last_scanned,
-                                                 pwlan->last_scanned))
-                               oldest = pwlan;
-               }
-       }
-
-       return oldest;
-}
-
-void update_network23a(struct wlan_bssid_ex *dst, struct wlan_bssid_ex *src,
-                      struct rtw_adapter *padapter, bool update_ie)
-{
-       u8 ss_ori = dst->SignalStrength;
-       u8 sq_ori = dst->SignalQuality;
-       long rssi_ori = dst->Rssi;
-
-       u8 ss_smp = src->SignalStrength;
-       u8 sq_smp = src->SignalQuality;
-       long rssi_smp = src->Rssi;
-
-       u8 ss_final;
-       u8 sq_final;
-       long rssi_final;
-
-       DBG_8723A("%s %s(%pM, ch%u) ss_ori:%3u, sq_ori:%3u, rssi_ori:%3ld, "
-                 "ss_smp:%3u, sq_smp:%3u, rssi_smp:%3ld\n",
-                 __func__, src->Ssid.ssid, src->MacAddress,
-                 src->DSConfig, ss_ori, sq_ori, rssi_ori,
-                 ss_smp, sq_smp, rssi_smp
-       );
-
-       /* The rule below is 1/5 for sample value, 4/5 for history value */
-       if (check_fwstate(&padapter->mlmepriv, _FW_LINKED) &&
-           is_same_network23a(&padapter->mlmepriv.cur_network.network, src)) {
-               /* Take the recvpriv's value for the connected AP*/
-               ss_final = padapter->recvpriv.signal_strength;
-               sq_final = padapter->recvpriv.signal_qual;
-               /* the rssi value here is undecorated, and will be
-                  used for antenna diversity */
-               if (sq_smp != 101) /* from the right channel */
-                       rssi_final = (src->Rssi+dst->Rssi*4)/5;
-               else
-                       rssi_final = rssi_ori;
-       } else {
-               if (sq_smp != 101) { /* from the right channel */
-                       ss_final = ((u32)src->SignalStrength +
-                                   (u32)dst->SignalStrength * 4) / 5;
-                       sq_final = ((u32)src->SignalQuality +
-                                   (u32)dst->SignalQuality * 4) / 5;
-                       rssi_final = src->Rssi+dst->Rssi * 4 / 5;
-               } else {
-                       /* bss info not receiving from the right channel, use
-                          the original RX signal infos */
-                       ss_final = dst->SignalStrength;
-                       sq_final = dst->SignalQuality;
-                       rssi_final = dst->Rssi;
-               }
-
-       }
-
-       if (update_ie)
-               memcpy(dst, src, get_wlan_bssid_ex_sz(src));
-
-       dst->SignalStrength = ss_final;
-       dst->SignalQuality = sq_final;
-       dst->Rssi = rssi_final;
-
-       DBG_8723A("%s %s(%pM), SignalStrength:%u, SignalQuality:%u, "
-                 "RawRSSI:%ld\n",  __func__, dst->Ssid.ssid, dst->MacAddress,
-                 dst->SignalStrength, dst->SignalQuality, dst->Rssi);
-}
-
-static void update_current_network(struct rtw_adapter *adapter,
-                                  struct wlan_bssid_ex *pnetwork)
-{
-       struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
-
-       if (check_fwstate(pmlmepriv, _FW_LINKED) &&
-           is_same_network23a(&pmlmepriv->cur_network.network, pnetwork)) {
-               update_network23a(&pmlmepriv->cur_network.network,
-                                 pnetwork, adapter, true);
-
-               rtw_update_protection23a(adapter,
-                                        pmlmepriv->cur_network.network.IEs,
-                                        pmlmepriv->cur_network.network.IELength);
-       }
-}
-
-/*
-
-Caller must hold pmlmepriv->lock first.
-
-*/
-static void rtw_update_scanned_network(struct rtw_adapter *adapter,
-                                      struct wlan_bssid_ex *target)
-{
-       struct list_head *plist, *phead;
-       struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
-       struct wlan_network *pnetwork = NULL;
-       struct wlan_network *oldest = NULL;
-       struct rtw_queue *queue = &pmlmepriv->scanned_queue;
-       u32 bssid_ex_sz;
-       int found = 0;
-
-       spin_lock_bh(&queue->lock);
-       phead = get_list_head(queue);
-       list_for_each(plist, phead) {
-               pnetwork = container_of(plist, struct wlan_network, list);
-
-               if (is_same_network23a(&pnetwork->network, target)) {
-                       found = 1;
-                       break;
-               }
-               if (!oldest || time_after(oldest->last_scanned,
-                                         pnetwork->last_scanned))
-                       oldest = pnetwork;
-       }
-
-       /* If we didn't find a match, then get a new network slot to initialize
-        * with this beacon's information */
-       if (!found) {
-               pnetwork = rtw_alloc_network(pmlmepriv, GFP_ATOMIC);
-               if (!pnetwork) {
-                       if (!oldest) {
-                               RT_TRACE(_module_rtl871x_mlme_c_, _drv_err_,
-                                        "something wrong here\n");
-                               goto exit;
-                       }
-                       pnetwork = oldest;
-               } else
-                       list_add_tail(&pnetwork->list, &queue->queue);
-
-               bssid_ex_sz = get_wlan_bssid_ex_sz(target);
-               target->Length = bssid_ex_sz;
-               memcpy(&pnetwork->network, target, bssid_ex_sz);
-
-               /*  variable initialize */
-               pnetwork->fixed = false;
-               pnetwork->last_scanned = jiffies;
-
-               pnetwork->network_type = 0;
-               pnetwork->join_res = 0;
-
-               /* bss info not receiving from the right channel */
-               if (pnetwork->network.SignalQuality == 101)
-                       pnetwork->network.SignalQuality = 0;
-       } else {
-               /*
-                * we have an entry and we are going to update it. But
-                * this entry may be already expired. In this case we
-                * do the same as we found a new net and call the
-                * new_net handler
-                */
-               bool update_ie = true;
-
-               pnetwork->last_scanned = jiffies;
-
-               /* target.reserved == 1, means that scanned network is
-                * a bcn frame. */
-               if (pnetwork->network.IELength > target->IELength &&
-                   target->reserved == 1)
-                       update_ie = false;
-
-               update_network23a(&pnetwork->network, target, adapter,
-                                 update_ie);
-       }
-
-exit:
-       spin_unlock_bh(&queue->lock);
-}
-
-static void rtw_add_network(struct rtw_adapter *adapter,
-                           struct wlan_bssid_ex *pnetwork)
-{
-       update_current_network(adapter, pnetwork);
-       rtw_update_scanned_network(adapter, pnetwork);
-}
-
-/* select the desired network based on the capability of the (i)bss. */
-/*  check items: (1) security */
-/*                        (2) network_type */
-/*                        (3) WMM */
-/*                        (4) HT */
-/*                      (5) others */
-static int rtw_is_desired_network(struct rtw_adapter *adapter,
-                                 struct wlan_network *pnetwork)
-{
-       struct security_priv *psecuritypriv = &adapter->securitypriv;
-       struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
-       u32 desired_encmode;
-       u32 privacy;
-       int bselected = true;
-
-       desired_encmode = psecuritypriv->ndisencryptstatus;
-       privacy = pnetwork->network.Privacy;
-
-       if (check_fwstate(pmlmepriv, WIFI_UNDER_WPS)) {
-               if (cfg80211_find_vendor_ie(WLAN_OUI_MICROSOFT,
-                                           WLAN_OUI_TYPE_MICROSOFT_WPA,
-                                           pnetwork->network.IEs,
-                                           pnetwork->network.IELength))
-                       return true;
-               else
-                       return false;
-       }
-       if (adapter->registrypriv.wifi_spec == 1) {
-               /* for  correct flow of 8021X  to do.... */
-               if (desired_encmode == Ndis802_11EncryptionDisabled &&
-                   privacy != 0)
-                       bselected = false;
-       }
-
-       if (desired_encmode != Ndis802_11EncryptionDisabled && privacy == 0) {
-               DBG_8723A("desired_encmode: %d, privacy: %d\n",
-                         desired_encmode, privacy);
-               bselected = false;
-       }
-
-       if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE)) {
-               if (pnetwork->network.ifmode !=
-                   pmlmepriv->cur_network.network.ifmode)
-                       bselected = false;
-       }
-
-       return bselected;
-}
-
-void rtw_survey_event_cb23a(struct rtw_adapter *adapter, const u8 *pbuf)
-{
-       u32 len;
-       struct wlan_bssid_ex *pnetwork;
-       struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
-       struct survey_event *survey = (struct survey_event *)pbuf;
-
-       pnetwork = survey->bss;
-
-       RT_TRACE(_module_rtl871x_mlme_c_, _drv_info_,
-                "rtw_survey_event_cb23a, ssid=%s\n", pnetwork->Ssid.ssid);
-
-       len = get_wlan_bssid_ex_sz(pnetwork);
-       if (len > (sizeof(struct wlan_bssid_ex))) {
-               RT_TRACE(_module_rtl871x_mlme_c_, _drv_err_,
-                        "****rtw_survey_event_cb23a: return a wrong bss ***\n");
-               return;
-       }
-
-       spin_lock_bh(&pmlmepriv->lock);
-
-       /*  update IBSS_network 's timestamp */
-       if (check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE)) {
-               if (ether_addr_equal(pmlmepriv->cur_network.network.MacAddress,
-                                    pnetwork->MacAddress)) {
-                       struct wlan_network *ibss_wlan;
-
-                       pmlmepriv->cur_network.network.beacon_interval =
-                               pnetwork->beacon_interval;
-                       pmlmepriv->cur_network.network.capability =
-                               pnetwork->capability;
-                       pmlmepriv->cur_network.network.tsf = pnetwork->tsf;
-                       spin_lock_bh(&pmlmepriv->scanned_queue.lock);
-                       ibss_wlan = rtw_find_network23a(
-                               &pmlmepriv->scanned_queue,
-                               pnetwork->MacAddress);
-                       if (ibss_wlan) {
-                               pmlmepriv->cur_network.network.beacon_interval =
-                                       ibss_wlan->network.beacon_interval;
-                               pmlmepriv->cur_network.network.capability =
-                                       ibss_wlan->network.capability;
-                               pmlmepriv->cur_network.network.tsf =
-                                       ibss_wlan->network.tsf;
-                               spin_unlock_bh(&pmlmepriv->scanned_queue.lock);
-                               goto exit;
-                       }
-                       spin_unlock_bh(&pmlmepriv->scanned_queue.lock);
-               }
-       }
-
-       /*  lock pmlmepriv->lock when you accessing network_q */
-       if (!check_fwstate(pmlmepriv, _FW_UNDER_LINKING)) {
-               if (pnetwork->Ssid.ssid[0] == 0)
-                       pnetwork->Ssid.ssid_len = 0;
-
-               rtw_add_network(adapter, pnetwork);
-       }
-
-exit:
-
-       spin_unlock_bh(&pmlmepriv->lock);
-
-       kfree(survey->bss);
-       survey->bss = NULL;
-}
-
-void
-rtw_surveydone_event_callback23a(struct rtw_adapter *adapter, const u8 *pbuf)
-{
-       struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
-       struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
-       int ret;
-
-       spin_lock_bh(&pmlmepriv->lock);
-
-       if (pmlmepriv->wps_probe_req_ie) {
-               pmlmepriv->wps_probe_req_ie_len = 0;
-               kfree(pmlmepriv->wps_probe_req_ie);
-               pmlmepriv->wps_probe_req_ie = NULL;
-       }
-
-       RT_TRACE(_module_rtl871x_mlme_c_, _drv_info_,
-                "rtw_surveydone_event_callback23a: fw_state:%x\n",
-                get_fwstate(pmlmepriv));
-
-       if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY)) {
-               del_timer_sync(&pmlmepriv->scan_to_timer);
-
-               _clr_fwstate_(pmlmepriv, _FW_UNDER_SURVEY);
-       } else {
-               RT_TRACE(_module_rtl871x_mlme_c_, _drv_err_,
-                        "nic status =%x, survey done event comes too late!\n",
-                        get_fwstate(pmlmepriv));
-       }
-
-       rtw_set_signal_stat_timer(&adapter->recvpriv);
-
-       if (pmlmepriv->to_join == true) {
-               set_fwstate(pmlmepriv, _FW_UNDER_LINKING);
-               if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE)) {
-                       ret = rtw_select_and_join_from_scanned_queue23a(
-                               pmlmepriv);
-                       if (ret != _SUCCESS)
-                               rtw_do_join_adhoc(adapter);
-               } else {
-                       pmlmepriv->to_join = false;
-                       ret = rtw_select_and_join_from_scanned_queue23a(
-                               pmlmepriv);
-                       if (ret != _SUCCESS) {
-                               DBG_8723A("try_to_join, but select scanning "
-                                         "queue fail, to_roaming:%d\n",
-                                         adapter->mlmepriv.to_roaming);
-                               if (adapter->mlmepriv.to_roaming) {
-                                       if (--pmlmepriv->to_roaming == 0 ||
-                                           rtw_sitesurvey_cmd23a(
-                                                   adapter,
-                                                   &pmlmepriv->assoc_ssid, 1,
-                                                   NULL, 0) != _SUCCESS) {
-                                               rtw_set_roaming(adapter, 0);
-                                               rtw_free_assoc_resources23a(
-                                                       adapter, 1);
-                                               rtw_indicate_disconnect23a(
-                                                       adapter);
-                                       } else
-                                               pmlmepriv->to_join = true;
-                               }
-                               _clr_fwstate_(pmlmepriv, _FW_UNDER_LINKING);
-                       }
-               }
-       }
-
-       spin_unlock_bh(&pmlmepriv->lock);
-
-       rtw_os_xmit_schedule23a(adapter);
-
-       if (pmlmeext->sitesurvey_res.bss_cnt == 0)
-               rtw_sreset_reset(adapter);
-
-       rtw_cfg80211_surveydone_event_callback(adapter);
-}
-
-static void free_scanqueue(struct mlme_priv *pmlmepriv)
-{
-       struct wlan_network *pnetwork, *ptemp;
-       struct rtw_queue *scan_queue = &pmlmepriv->scanned_queue;
-       struct list_head *phead;
-
-       RT_TRACE(_module_rtl871x_mlme_c_, _drv_notice_, "+free_scanqueue\n");
-       spin_lock_bh(&scan_queue->lock);
-       phead = get_list_head(scan_queue);
-       list_for_each_entry_safe(pnetwork, ptemp, phead, list) {
-               pnetwork->fixed = false;
-               _rtw_free_network23a(pmlmepriv, pnetwork);
-       }
-       spin_unlock_bh(&scan_queue->lock);
-}
-
-/*
- *rtw_free_assoc_resources23a: the caller has to lock pmlmepriv->lock
- */
-void rtw_free_assoc_resources23a(struct rtw_adapter *adapter,
-                                int lock_scanned_queue)
-{
-       struct wlan_network *pwlan;
-       struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
-       struct sta_priv *pstapriv = &adapter->stapriv;
-       struct wlan_network *tgt_network = &pmlmepriv->cur_network;
-       struct sta_info *psta;
-
-       RT_TRACE(_module_rtl871x_mlme_c_, _drv_notice_,
-                "+rtw_free_assoc_resources23a\n");
-       RT_TRACE(_module_rtl871x_mlme_c_, _drv_info_,
-                "tgt_network->network.MacAddress=%pM ssid=%s\n",
-                tgt_network->network.MacAddress,
-                tgt_network->network.Ssid.ssid);
-
-       if (check_fwstate(pmlmepriv, WIFI_STATION_STATE|WIFI_AP_STATE)) {
-               psta = rtw_get_stainfo23a(&adapter->stapriv,
-                                         tgt_network->network.MacAddress);
-
-               spin_lock_bh(&pstapriv->sta_hash_lock);
-               rtw_free_stainfo23a(adapter,  psta);
-               spin_unlock_bh(&pstapriv->sta_hash_lock);
-       }
-
-       if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE |
-                         WIFI_ADHOC_MASTER_STATE|WIFI_AP_STATE)) {
-               rtw_free_all_stainfo23a(adapter);
-
-               psta = rtw_get_bcmc_stainfo23a(adapter);
-               spin_lock_bh(&pstapriv->sta_hash_lock);
-               rtw_free_stainfo23a(adapter, psta);
-               spin_unlock_bh(&pstapriv->sta_hash_lock);
-
-               rtw_init_bcmc_stainfo23a(adapter);
-       }
-
-       if (lock_scanned_queue)
-               spin_lock_bh(&pmlmepriv->scanned_queue.lock);
-
-       pwlan = rtw_find_network23a(&pmlmepriv->scanned_queue,
-                                   tgt_network->network.MacAddress);
-       if (pwlan)
-               pwlan->fixed = false;
-       else
-               RT_TRACE(_module_rtl871x_mlme_c_, _drv_err_,
-                        "rtw_free_assoc_resources23a : pwlan== NULL\n");
-
-       if (check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) &&
-           adapter->stapriv.asoc_sta_count == 1)
-               rtw_free_network_nolock(pmlmepriv, pwlan);
-
-       if (lock_scanned_queue)
-               spin_unlock_bh(&pmlmepriv->scanned_queue.lock);
-
-       pmlmepriv->key_mask = 0;
-}
-
-/*
-*rtw_indicate_connect23a: the caller has to lock pmlmepriv->lock
-*/
-void rtw_indicate_connect23a(struct rtw_adapter *padapter)
-{
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-
-       RT_TRACE(_module_rtl871x_mlme_c_, _drv_err_,
-                "+rtw_indicate_connect23a\n");
-
-       pmlmepriv->to_join = false;
-
-       if (!check_fwstate(&padapter->mlmepriv, _FW_LINKED)) {
-               set_fwstate(pmlmepriv, _FW_LINKED);
-
-               rtw_cfg80211_indicate_connect(padapter);
-
-               netif_carrier_on(padapter->pnetdev);
-
-               if (padapter->pid[2] != 0)
-                       kill_pid(find_vpid(padapter->pid[2]), SIGALRM, 1);
-       }
-
-       rtw_set_roaming(padapter, 0);
-
-       rtw_set_scan_deny(padapter, 3000);
-
-       RT_TRACE(_module_rtl871x_mlme_c_, _drv_err_,
-                "-rtw_indicate_connect23a: fw_state=0x%08x\n",
-                get_fwstate(pmlmepriv));
-}
-
-/*
- *rtw_indicate_disconnect23a: the caller has to lock pmlmepriv->lock
- */
-void rtw_indicate_disconnect23a(struct rtw_adapter *padapter)
-{
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-
-       RT_TRACE(_module_rtl871x_mlme_c_, _drv_err_,
-                "+rtw_indicate_disconnect23a\n");
-
-       _clr_fwstate_(pmlmepriv, _FW_UNDER_LINKING|WIFI_UNDER_WPS);
-
-       /* DBG_8723A("clear wps when %s\n", __func__); */
-
-       if (padapter->mlmepriv.to_roaming > 0)
-               _clr_fwstate_(pmlmepriv, _FW_LINKED);
-
-       if (check_fwstate(&padapter->mlmepriv, _FW_LINKED) ||
-           padapter->mlmepriv.to_roaming <= 0) {
-               rtw_os_indicate_disconnect23a(padapter);
-
-               /* set ips_deny_time to avoid enter IPS before LPS leave */
-               padapter->pwrctrlpriv.ips_deny_time =
-                       jiffies + msecs_to_jiffies(3000);
-
-               _clr_fwstate_(pmlmepriv, _FW_LINKED);
-
-               rtw_clear_scan_deny(padapter);
-       }
-
-       rtw_lps_ctrl_wk_cmd23a(padapter, LPS_CTRL_DISCONNECT, 1);
-}
-
-void rtw_scan_abort23a(struct rtw_adapter *adapter)
-{
-       unsigned long start;
-       struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
-       struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
-
-       start = jiffies;
-       pmlmeext->scan_abort = true;
-       while (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) &&
-              jiffies_to_msecs(jiffies - start) <= 200) {
-               if (adapter->bDriverStopped || adapter->bSurpriseRemoved)
-                       break;
-
-               DBG_8723A("%s(%s): fw_state = _FW_UNDER_SURVEY!\n",
-                         __func__, adapter->pnetdev->name);
-               msleep(20);
-       }
-
-       if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY)) {
-               if (!adapter->bDriverStopped && !adapter->bSurpriseRemoved)
-                       DBG_8723A("%s(%s): waiting for scan_abort time out!\n",
-                                 __func__, adapter->pnetdev->name);
-               rtw_cfg80211_indicate_scan_done(wdev_to_priv(adapter->rtw_wdev),
-                                               true);
-       }
-       pmlmeext->scan_abort = false;
-}
-
-static struct sta_info *
-rtw_joinbss_update_stainfo(struct rtw_adapter *padapter,
-                          struct wlan_network *pnetwork)
-{
-       int i;
-       struct sta_info *bmc_sta, *psta;
-       struct recv_reorder_ctrl *preorder_ctrl;
-       struct sta_priv *pstapriv = &padapter->stapriv;
-
-       psta = rtw_get_stainfo23a(pstapriv, pnetwork->network.MacAddress);
-       if (!psta)
-               psta = rtw_alloc_stainfo23a(pstapriv,
-                                           pnetwork->network.MacAddress,
-                                           GFP_ATOMIC);
-
-       if (psta) { /* update ptarget_sta */
-               DBG_8723A("%s\n", __func__);
-
-               psta->aid  = pnetwork->join_res;
-               psta->mac_id = 0;
-
-               /* sta mode */
-               rtl8723a_SetHalODMVar(padapter, HAL_ODM_STA_INFO, psta, true);
-
-               /* security related */
-               if (padapter->securitypriv.dot11AuthAlgrthm ==
-                   dot11AuthAlgrthm_8021X) {
-                       padapter->securitypriv.binstallGrpkey = 0;
-                       padapter->securitypriv.busetkipkey = 0;
-
-                       psta->ieee8021x_blocked = true;
-                       psta->dot118021XPrivacy =
-                               padapter->securitypriv.dot11PrivacyAlgrthm;
-
-                       memset(&psta->dot118021x_UncstKey, 0,
-                              sizeof (union Keytype));
-
-                       memset(&psta->dot11tkiprxmickey, 0,
-                              sizeof (union Keytype));
-                       memset(&psta->dot11tkiptxmickey, 0,
-                              sizeof (union Keytype));
-
-                       memset(&psta->dot11txpn, 0, sizeof (union pn48));
-                       memset(&psta->dot11rxpn, 0, sizeof (union pn48));
-               }
-
-               /*      Commented by Albert 2012/07/21 */
-               /*      When doing the WPS, the wps_ie_len won't equal to 0 */
-               /*      And the Wi-Fi driver shouldn't allow the data packet
-                       to be transmitted. */
-               if (padapter->securitypriv.wps_ie_len != 0) {
-                       psta->ieee8021x_blocked = true;
-                       padapter->securitypriv.wps_ie_len = 0;
-               }
-
-               /* for A-MPDU Rx reordering buffer control for bmc_sta &
-                * sta_info */
-               /* if A-MPDU Rx is enabled, resetting
-                  rx_ordering_ctrl wstart_b(indicate_seq) to default
-                  value = 0xffff */
-               /* todo: check if AP can send A-MPDU packets */
-               for (i = 0; i < 16 ; i++) {
-                       /* preorder_ctrl = &precvpriv->recvreorder_ctrl[i]; */
-                       preorder_ctrl = &psta->recvreorder_ctrl[i];
-                       preorder_ctrl->enable = false;
-                       preorder_ctrl->indicate_seq = 0xffff;
-                       preorder_ctrl->wend_b = 0xffff;
-                       /* max_ampdu_sz; ex. 32(kbytes) -> wsize_b = 32 */
-                       preorder_ctrl->wsize_b = 64;
-               }
-
-               bmc_sta = rtw_get_bcmc_stainfo23a(padapter);
-               if (bmc_sta) {
-                       for (i = 0; i < 16 ; i++) {
-                               preorder_ctrl = &bmc_sta->recvreorder_ctrl[i];
-                               preorder_ctrl->enable = false;
-                               preorder_ctrl->indicate_seq = 0xffff;
-                               preorder_ctrl->wend_b = 0xffff;
-                               /* max_ampdu_sz; ex. 32(kbytes) ->
-                                  wsize_b = 32 */
-                               preorder_ctrl->wsize_b = 64;
-                       }
-               }
-
-               /* misc. */
-               update_sta_info23a(padapter, psta);
-
-       }
-
-       return psta;
-}
-
-/* pnetwork : returns from rtw23a_joinbss_event_cb */
-/* ptarget_wlan: found from scanned_queue */
-static void
-rtw_joinbss_update_network23a(struct rtw_adapter *padapter,
-                             struct wlan_network *ptarget_wlan,
-                             struct wlan_network  *pnetwork)
-{
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct wlan_network *cur_network = &pmlmepriv->cur_network;
-
-       DBG_8723A("%s\n", __func__);
-
-       RT_TRACE(_module_rtl871x_mlme_c_, _drv_info_,
-                "fw_state:%x, BSSID:%pM\n",
-                get_fwstate(pmlmepriv),
-                pnetwork->network.MacAddress);
-
-       /*  why not use ptarget_wlan?? */
-       memcpy(&cur_network->network, &pnetwork->network,
-              pnetwork->network.Length);
-       /*  some IEs in pnetwork is wrong, so we should use ptarget_wlan IEs */
-       cur_network->network.IELength = ptarget_wlan->network.IELength;
-       memcpy(&cur_network->network.IEs[0], &ptarget_wlan->network.IEs[0],
-              MAX_IE_SZ);
-
-       cur_network->network.capability = ptarget_wlan->network.capability;
-       cur_network->network.beacon_interval =
-               ptarget_wlan->network.beacon_interval;
-       cur_network->network.tsf = ptarget_wlan->network.tsf;
-
-       rtw_set_signal_stat_timer(&padapter->recvpriv);
-       padapter->recvpriv.signal_strength =
-               ptarget_wlan->network.SignalStrength;
-       padapter->recvpriv.signal_qual = ptarget_wlan->network.SignalQuality;
-       /*
-        * the ptarget_wlan->network.Rssi is raw data, we use
-        * ptarget_wlan->network.SignalStrength instead (has scaled)
-        */
-       DBG_8723A("%s signal_strength:%3u, signal_qual:%3u\n",
-                 __func__, padapter->recvpriv.signal_strength,
-                 padapter->recvpriv.signal_qual);
-       rtw_set_signal_stat_timer(&padapter->recvpriv);
-
-       /* update fw_state will clr _FW_UNDER_LINKING here indirectly */
-       switch (pnetwork->network.ifmode) {
-       case NL80211_IFTYPE_P2P_CLIENT:
-       case NL80211_IFTYPE_STATION:
-               if (pmlmepriv->fw_state & WIFI_UNDER_WPS)
-                       pmlmepriv->fw_state = WIFI_STATION_STATE|WIFI_UNDER_WPS;
-               else
-                       pmlmepriv->fw_state = WIFI_STATION_STATE;
-               break;
-       case NL80211_IFTYPE_ADHOC:
-               pmlmepriv->fw_state = WIFI_ADHOC_STATE;
-               break;
-       default:
-               pmlmepriv->fw_state = WIFI_NULL_STATE;
-               RT_TRACE(_module_rtl871x_mlme_c_, _drv_err_,
-                        "Invalid network_mode\n");
-               break;
-       }
-
-       rtw_update_protection23a(padapter, cur_network->network.IEs,
-                                cur_network->network.IELength);
-
-       rtw_update_ht_cap23a(padapter, cur_network->network.IEs,
-                            cur_network->network.IELength);
-}
-
-/*
- * Notes:
- * the function could be > passive_level (the same context as Rx tasklet)
- * pnetwork : returns from rtw23a_joinbss_event_cb
- * ptarget_wlan: found from scanned_queue
- * if join_res > 0, for (fw_state==WIFI_STATION_STATE),
- * we check if  "ptarget_sta" & "ptarget_wlan" exist.
- * if join_res > 0, for (fw_state==WIFI_ADHOC_STATE),
- * we only check if "ptarget_wlan" exist.
- * if join_res > 0, update "cur_network->network" from "pnetwork->network"
- * if (ptarget_wlan !=NULL).
- */
-
-void rtw_joinbss_event_prehandle23a(struct rtw_adapter *adapter, u8 *pbuf)
-{
-       struct sta_info *ptarget_sta, *pcur_sta;
-       struct sta_priv *pstapriv = &adapter->stapriv;
-       struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
-       struct wlan_network *pnetwork = (struct wlan_network *)pbuf;
-       struct wlan_network *cur_network = &pmlmepriv->cur_network;
-       struct wlan_network *pcur_wlan, *ptarget_wlan = NULL;
-       bool the_same_macaddr;
-
-       RT_TRACE(_module_rtl871x_mlme_c_, _drv_info_,
-                "joinbss event call back received with res=%d\n",
-                pnetwork->join_res);
-
-       if (pmlmepriv->assoc_ssid.ssid_len == 0) {
-               RT_TRACE(_module_rtl871x_mlme_c_, _drv_err_,
-                        "@@@@@   joinbss event call back  for Any SSid\n");
-       } else {
-               RT_TRACE(_module_rtl871x_mlme_c_, _drv_err_,
-                        "@@@@@   rtw23a_joinbss_event_cb for SSid:%s\n",
-                        pmlmepriv->assoc_ssid.ssid);
-       }
-
-       if (ether_addr_equal(pnetwork->network.MacAddress,
-                            cur_network->network.MacAddress))
-               the_same_macaddr = true;
-       else
-               the_same_macaddr = false;
-
-       pnetwork->network.Length = get_wlan_bssid_ex_sz(&pnetwork->network);
-       if (pnetwork->network.Length > sizeof(struct wlan_bssid_ex)) {
-               RT_TRACE(_module_rtl871x_mlme_c_, _drv_err_,
-                        "***joinbss_evt_callback return a wrong bss ***\n");
-               return;
-       }
-
-       spin_lock_bh(&pmlmepriv->lock);
-
-       RT_TRACE(_module_rtl871x_mlme_c_, _drv_info_,
-                "rtw23a_joinbss_event_cb !! _enter_critical\n");
-
-       if (pnetwork->join_res > 0) {
-               spin_lock_bh(&pmlmepriv->scanned_queue.lock);
-               if (check_fwstate(pmlmepriv, _FW_UNDER_LINKING)) {
-                       /* s1. find ptarget_wlan */
-                       if (check_fwstate(pmlmepriv, _FW_LINKED)) {
-                               if (the_same_macaddr) {
-                                       ptarget_wlan = rtw_find_network23a(&pmlmepriv->scanned_queue, cur_network->network.MacAddress);
-                               } else {
-                                       pcur_wlan = rtw_find_network23a(&pmlmepriv->scanned_queue, cur_network->network.MacAddress);
-                                       if (pcur_wlan)
-                                               pcur_wlan->fixed = false;
-
-                                       pcur_sta = rtw_get_stainfo23a(pstapriv, cur_network->network.MacAddress);
-                                       if (pcur_sta) {
-                                               spin_lock_bh(&pstapriv->sta_hash_lock);
-                                               rtw_free_stainfo23a(adapter,
-                                                                   pcur_sta);
-                                               spin_unlock_bh(&pstapriv->sta_hash_lock);
-                                       }
-
-                                       ptarget_wlan = rtw_find_network23a(&pmlmepriv->scanned_queue, pnetwork->network.MacAddress);
-                                       if (check_fwstate(pmlmepriv,
-                                                         WIFI_STATION_STATE)) {
-                                               if (ptarget_wlan)
-                                                       ptarget_wlan->fixed =
-                                                               true;
-                                       }
-                               }
-
-                       } else {
-                               ptarget_wlan = rtw_find_network23a(
-                                       &pmlmepriv->scanned_queue,
-                                       pnetwork->network.MacAddress);
-                               if (check_fwstate(pmlmepriv,
-                                                 WIFI_STATION_STATE)) {
-                                       if (ptarget_wlan)
-                                               ptarget_wlan->fixed = true;
-                               }
-                       }
-
-                       /* s2. update cur_network */
-                       if (ptarget_wlan)
-                               rtw_joinbss_update_network23a(adapter,
-                                                             ptarget_wlan,
-                                                             pnetwork);
-                       else {
-                               RT_TRACE(_module_rtl871x_mlme_c_, _drv_err_,
-                                        "Can't find ptarget_wlan when joinbss_event callback\n");
-                               spin_unlock_bh(&pmlmepriv->scanned_queue.lock);
-                               goto ignore_joinbss_callback;
-                       }
-
-                       /* s3. find ptarget_sta & update ptarget_sta after
-                          update cur_network only for station mode */
-                       if (check_fwstate(pmlmepriv, WIFI_STATION_STATE)) {
-                               ptarget_sta = rtw_joinbss_update_stainfo(
-                                       adapter, pnetwork);
-                               if (!ptarget_sta) {
-                                       RT_TRACE(_module_rtl871x_mlme_c_,
-                                                _drv_err_,
-                                                "Can't update stainfo when joinbss_event callback\n");
-                                       spin_unlock_bh(&pmlmepriv->scanned_queue.lock);
-                                       goto ignore_joinbss_callback;
-                               }
-                       }
-
-                       /* s4. indicate connect */
-                       if (check_fwstate(pmlmepriv, WIFI_STATION_STATE))
-                               rtw_indicate_connect23a(adapter);
-                       else {
-                               /* adhoc mode will rtw_indicate_connect23a
-                                  when rtw_stassoc_event_callback23a */
-                               RT_TRACE(_module_rtl871x_mlme_c_, _drv_info_,
-                                        "adhoc mode, fw_state:%x\n",
-                                        get_fwstate(pmlmepriv));
-                       }
-
-                       /* s5. Cancle assoc_timer */
-                       del_timer_sync(&pmlmepriv->assoc_timer);
-
-                       RT_TRACE(_module_rtl871x_mlme_c_, _drv_info_,
-                                "Cancle assoc_timer\n");
-               } else {
-                       RT_TRACE(_module_rtl871x_mlme_c_, _drv_err_,
-                                "rtw23a_joinbss_event_cb err: fw_state:%x\n",
-                                get_fwstate(pmlmepriv));
-                       spin_unlock_bh(&pmlmepriv->scanned_queue.lock);
-                       goto ignore_joinbss_callback;
-               }
-               spin_unlock_bh(&pmlmepriv->scanned_queue.lock);
-       } else if (pnetwork->join_res == -4) {
-               rtw_reset_securitypriv23a(adapter);
-               mod_timer(&pmlmepriv->assoc_timer,
-                         jiffies + msecs_to_jiffies(1));
-
-               /* rtw_free_assoc_resources23a(adapter, 1); */
-
-               if (check_fwstate(pmlmepriv, _FW_UNDER_LINKING)) {
-                       RT_TRACE(_module_rtl871x_mlme_c_, _drv_err_,
-                                "fail! clear _FW_UNDER_LINKING ^^^fw_state=%x\n",
-                                get_fwstate(pmlmepriv));
-                       _clr_fwstate_(pmlmepriv, _FW_UNDER_LINKING);
-               }
-       } else {
-               /* if join_res < 0 (join fails), then try again */
-               mod_timer(&pmlmepriv->assoc_timer,
-                         jiffies + msecs_to_jiffies(1));
-               _clr_fwstate_(pmlmepriv, _FW_UNDER_LINKING);
-       }
-
-ignore_joinbss_callback:
-
-       spin_unlock_bh(&pmlmepriv->lock);
-}
-
-void rtw23a_joinbss_event_cb(struct rtw_adapter *adapter, const u8 *pbuf)
-{
-       struct wlan_network *pnetwork = (struct wlan_network *)pbuf;
-
-       mlmeext_joinbss_event_callback23a(adapter, pnetwork->join_res);
-
-       rtw_os_xmit_schedule23a(adapter);
-}
-
-void rtw_stassoc_event_callback23a(struct rtw_adapter *adapter, const u8 *pbuf)
-{
-       struct sta_info *psta;
-       struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
-       struct stassoc_event *pstassoc = (struct stassoc_event *)pbuf;
-       struct wlan_network *cur_network = &pmlmepriv->cur_network;
-       struct wlan_network *ptarget_wlan;
-
-       if (rtw_access_ctrl23a(adapter, pstassoc->macaddr) == false)
-               return;
-
-#ifdef CONFIG_8723AU_AP_MODE
-       if (check_fwstate(pmlmepriv, WIFI_AP_STATE)) {
-               psta = rtw_get_stainfo23a(&adapter->stapriv, pstassoc->macaddr);
-               if (psta) {
-                       /* bss_cap_update_on_sta_join23a(adapter, psta); */
-                       /* sta_info_update23a(adapter, psta); */
-                       ap_sta_info_defer_update23a(adapter, psta);
-               }
-               return;
-       }
-#endif
-       /* for AD-HOC mode */
-       psta = rtw_get_stainfo23a(&adapter->stapriv, pstassoc->macaddr);
-       if (psta != NULL) {
-               /* the sta have been in sta_info_queue => do nothing */
-               RT_TRACE(_module_rtl871x_mlme_c_, _drv_err_,
-                        "Error: rtw_stassoc_event_callback23a: sta has been in sta_hash_queue\n");
-               /* between drv has received this event before and
-                  fw have not yet to set key to CAM_ENTRY) */
-               return;
-       }
-
-       psta = rtw_alloc_stainfo23a(&adapter->stapriv, pstassoc->macaddr,
-               GFP_KERNEL);
-       if (!psta) {
-               RT_TRACE(_module_rtl871x_mlme_c_, _drv_err_,
-                        "Can't alloc sta_info when rtw_stassoc_event_callback23a\n");
-               return;
-       }
-
-       /* to do : init sta_info variable */
-       psta->qos_option = 0;
-       psta->mac_id = (uint)pstassoc->cam_id;
-       /* psta->aid = (uint)pstassoc->cam_id; */
-       DBG_8723A("%s\n", __func__);
-       /* for ad-hoc mode */
-       rtl8723a_SetHalODMVar(adapter, HAL_ODM_STA_INFO, psta, true);
-
-       if (adapter->securitypriv.dot11AuthAlgrthm == dot11AuthAlgrthm_8021X)
-               psta->dot118021XPrivacy =
-                       adapter->securitypriv.dot11PrivacyAlgrthm;
-
-       psta->ieee8021x_blocked = false;
-
-       spin_lock_bh(&pmlmepriv->lock);
-
-       if (check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) ||
-           check_fwstate(pmlmepriv, WIFI_ADHOC_STATE)) {
-               if (adapter->stapriv.asoc_sta_count == 2) {
-                       spin_lock_bh(&pmlmepriv->scanned_queue.lock);
-                       ptarget_wlan =
-                               rtw_find_network23a(&pmlmepriv->scanned_queue,
-                                                   cur_network->network.MacAddress);
-                       if (ptarget_wlan)
-                               ptarget_wlan->fixed = true;
-                       spin_unlock_bh(&pmlmepriv->scanned_queue.lock);
-                       /*  a sta + bc/mc_stainfo (not Ibss_stainfo) */
-                       rtw_indicate_connect23a(adapter);
-               }
-       }
-
-       spin_unlock_bh(&pmlmepriv->lock);
-
-       mlmeext_sta_add_event_callback23a(adapter, psta);
-}
-
-void rtw_stadel_event_callback23a(struct rtw_adapter *adapter, const u8 *pbuf)
-{
-       int mac_id;
-       struct sta_info *psta;
-       struct wlan_network *pwlan;
-       struct wlan_bssid_ex *pdev_network;
-       struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
-       struct stadel_event *pstadel = (struct stadel_event *)pbuf;
-       struct sta_priv *pstapriv = &adapter->stapriv;
-       struct wlan_network *tgt_network = &pmlmepriv->cur_network;
-
-       psta = rtw_get_stainfo23a(&adapter->stapriv, pstadel->macaddr);
-       if (psta)
-               mac_id = psta->mac_id;
-       else
-               mac_id = pstadel->mac_id;
-
-       DBG_8723A("%s(mac_id=%d)=%pM\n", __func__, mac_id, pstadel->macaddr);
-
-       if (check_fwstate(pmlmepriv, WIFI_AP_STATE))
-               return;
-
-       mlmeext_sta_del_event_callback23a(adapter);
-
-       spin_lock_bh(&pmlmepriv->lock);
-
-       if (check_fwstate(pmlmepriv, WIFI_STATION_STATE)) {
-               if (adapter->mlmepriv.to_roaming > 0) {
-                       /* this stadel_event is caused by roaming,
-                          decrease to_roaming */
-                       pmlmepriv->to_roaming--;
-               } else if (adapter->mlmepriv.to_roaming == 0)
-                       rtw_set_roaming(adapter, adapter->registrypriv.max_roaming_times);
-               if (*((u16 *)pstadel->rsvd) != WLAN_REASON_EXPIRATION_CHK)
-                       rtw_set_roaming(adapter, 0); /* don't roam */
-
-               rtw_free_uc_swdec_pending_queue23a(adapter);
-
-               rtw_free_assoc_resources23a(adapter, 1);
-               rtw_indicate_disconnect23a(adapter);
-               spin_lock_bh(&pmlmepriv->scanned_queue.lock);
-               /*  remove the network entry in scanned_queue */
-               pwlan = rtw_find_network23a(&pmlmepriv->scanned_queue,
-                                           tgt_network->network.MacAddress);
-               if (pwlan) {
-                       pwlan->fixed = false;
-                       rtw_free_network_nolock(pmlmepriv, pwlan);
-               }
-               spin_unlock_bh(&pmlmepriv->scanned_queue.lock);
-
-               _rtw_roaming(adapter, tgt_network);
-       }
-
-       if (check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) ||
-           check_fwstate(pmlmepriv, WIFI_ADHOC_STATE)) {
-
-               spin_lock_bh(&pstapriv->sta_hash_lock);
-               rtw_free_stainfo23a(adapter,  psta);
-               spin_unlock_bh(&pstapriv->sta_hash_lock);
-
-               /* a sta + bc/mc_stainfo (not Ibss_stainfo) */
-               if (adapter->stapriv.asoc_sta_count == 1) {
-                       spin_lock_bh(&pmlmepriv->scanned_queue.lock);
-                       /* free old ibss network */
-                       /* pwlan = rtw_find_network23a(
-                          &pmlmepriv->scanned_queue, pstadel->macaddr); */
-                       pwlan = rtw_find_network23a(&pmlmepriv->scanned_queue,
-                                                   tgt_network->network.MacAddress);
-                       if (pwlan) {
-                               pwlan->fixed = false;
-                               rtw_free_network_nolock(pmlmepriv, pwlan);
-                       }
-                       spin_unlock_bh(&pmlmepriv->scanned_queue.lock);
-                       /* re-create ibss */
-                       pdev_network = &adapter->registrypriv.dev_network;
-
-                       memcpy(pdev_network, &tgt_network->network,
-                              get_wlan_bssid_ex_sz(&tgt_network->network));
-
-                       rtw_do_join_adhoc(adapter);
-               }
-       }
-
-       spin_unlock_bh(&pmlmepriv->lock);
-}
-
-/*
-* rtw23a_join_to_handler - Timeout/failure handler for CMD JoinBss
-* @adapter: pointer to _adapter structure
-*/
-void rtw23a_join_to_handler (unsigned long data)
-{
-       struct rtw_adapter *adapter = (struct rtw_adapter *)data;
-       struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
-       int do_join_r;
-
-       DBG_8723A("%s, fw_state=%x\n", __func__, get_fwstate(pmlmepriv));
-
-       if (adapter->bDriverStopped || adapter->bSurpriseRemoved)
-               return;
-
-       spin_lock_bh(&pmlmepriv->lock);
-
-       if (adapter->mlmepriv.to_roaming > 0) {
-               /* join timeout caused by roaming */
-               while (1) {
-                       pmlmepriv->to_roaming--;
-                       if (adapter->mlmepriv.to_roaming != 0) {
-                               /* try another */
-                               DBG_8723A("%s try another roaming\n", __func__);
-                               do_join_r = rtw_do_join(adapter);
-                               if (do_join_r != _SUCCESS) {
-                                       DBG_8723A("%s roaming do_join return "
-                                                 "%d\n", __func__ , do_join_r);
-                                       continue;
-                               }
-                               break;
-                       } else {
-                               DBG_8723A("%s We've try roaming but fail\n",
-                                         __func__);
-                               rtw_indicate_disconnect23a(adapter);
-                               break;
-                       }
-               }
-       } else {
-               rtw_indicate_disconnect23a(adapter);
-               free_scanqueue(pmlmepriv);/*  */
-
-               /* indicate disconnect for the case that join_timeout and
-                  check_fwstate != FW_LINKED */
-               rtw_cfg80211_indicate_disconnect(adapter);
-       }
-
-       spin_unlock_bh(&pmlmepriv->lock);
-
-}
-
-/*
-* rtw_scan_timeout_handler23a - Timeout/Failure handler for CMD SiteSurvey
-* @data: pointer to _adapter structure
-*/
-void rtw_scan_timeout_handler23a(unsigned long data)
-{
-       struct rtw_adapter *adapter = (struct rtw_adapter *)data;
-       struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
-
-       DBG_8723A("%s(%s): fw_state =%x\n", __func__, adapter->pnetdev->name,
-                 get_fwstate(pmlmepriv));
-
-       spin_lock_bh(&pmlmepriv->lock);
-
-       _clr_fwstate_(pmlmepriv, _FW_UNDER_SURVEY);
-
-       spin_unlock_bh(&pmlmepriv->lock);
-
-       rtw_cfg80211_indicate_scan_done(wdev_to_priv(adapter->rtw_wdev), true);
-}
-
-void rtw_dynamic_check_timer_handler(unsigned long data)
-{
-       struct rtw_adapter *adapter = (struct rtw_adapter *)data;
-
-       if (adapter->hw_init_completed == false)
-               goto out;
-
-       if (adapter->bDriverStopped == true ||
-           adapter->bSurpriseRemoved == true)
-               goto out;
-
-       if (adapter->net_closed == true)
-               goto out;
-
-       rtw_dynamic_chk_wk_cmd23a(adapter);
-
-out:
-       mod_timer(&adapter->mlmepriv.dynamic_chk_timer,
-                 jiffies + msecs_to_jiffies(2000));
-}
-
-inline bool rtw_is_scan_deny(struct rtw_adapter *adapter)
-{
-       struct mlme_priv *mlmepriv = &adapter->mlmepriv;
-
-       return (atomic_read(&mlmepriv->set_scan_deny) != 0) ? true : false;
-}
-
-void rtw_clear_scan_deny(struct rtw_adapter *adapter)
-{
-       struct mlme_priv *mlmepriv = &adapter->mlmepriv;
-
-       atomic_set(&mlmepriv->set_scan_deny, 0);
-}
-
-void rtw_set_scan_deny_timer_hdl(unsigned long data)
-{
-       struct rtw_adapter *adapter = (struct rtw_adapter *)data;
-
-       rtw_clear_scan_deny(adapter);
-}
-
-void rtw_set_scan_deny(struct rtw_adapter *adapter, u32 ms)
-{
-       struct mlme_priv *mlmepriv = &adapter->mlmepriv;
-
-       atomic_set(&mlmepriv->set_scan_deny, 1);
-       mod_timer(&mlmepriv->set_scan_deny_timer,
-                 jiffies + msecs_to_jiffies(ms));
-}
-
-#if defined(IEEE80211_SCAN_RESULT_EXPIRE)
-#define RTW_SCAN_RESULT_EXPIRE  \
-       ((IEEE80211_SCAN_RESULT_EXPIRE / (HZ*1000)) - 1000) /* 3000 -1000 */
-#else
-#define RTW_SCAN_RESULT_EXPIRE 2000
-#endif
-
-/*
-* Select a new join candidate from the original @param candidate and
-*     @param competitor
-* @return true: candidate is updated
-* @return false: candidate is not updated
-*/
-static int rtw_check_join_candidate(struct mlme_priv *pmlmepriv,
-                                   struct wlan_network **candidate,
-                                   struct wlan_network *competitor)
-{
-       int updated = false;
-       struct rtw_adapter *adapter;
-
-       adapter = container_of(pmlmepriv, struct rtw_adapter, mlmepriv);
-
-       /* check bssid, if needed */
-       if (pmlmepriv->assoc_by_bssid == true) {
-               if (!ether_addr_equal(competitor->network.MacAddress,
-                                     pmlmepriv->assoc_bssid))
-                       goto exit;
-       }
-
-       /* check ssid, if needed */
-       if (pmlmepriv->assoc_ssid.ssid_len) {
-               if (competitor->network.Ssid.ssid_len !=
-                   pmlmepriv->assoc_ssid.ssid_len ||
-                   memcmp(competitor->network.Ssid.ssid,
-                          pmlmepriv->assoc_ssid.ssid,
-                          pmlmepriv->assoc_ssid.ssid_len))
-                       goto exit;
-       }
-
-       if (rtw_is_desired_network(adapter, competitor) == false)
-               goto exit;
-
-       if (adapter->mlmepriv.to_roaming > 0) {
-               unsigned int passed;
-
-               passed = jiffies_to_msecs(jiffies - competitor->last_scanned);
-               if (passed >= RTW_SCAN_RESULT_EXPIRE ||
-                   is_same_ess(&competitor->network,
-                               &pmlmepriv->cur_network.network) == false)
-                       goto exit;
-       }
-
-       if (!*candidate ||
-           (*candidate)->network.Rssi<competitor->network.Rssi) {
-               *candidate = competitor;
-               updated = true;
-       }
-
-       if (updated) {
-               DBG_8723A("[by_bssid:%u][assoc_ssid:%s][to_roaming:%u] new candidate: %s(%pM) rssi:%d\n",
-                         pmlmepriv->assoc_by_bssid,
-                         pmlmepriv->assoc_ssid.ssid,
-                         adapter->mlmepriv.to_roaming,
-                         (*candidate)->network.Ssid.ssid,
-                         (*candidate)->network.MacAddress,
-                         (int)(*candidate)->network.Rssi);
-       }
-
-exit:
-       return updated;
-}
-
-/*
-Calling context:
-The caller of the sub-routine will be in critical section...
-
-The caller must hold the following spinlock
-
-pmlmepriv->lock
-
-*/
-
-static int rtw_do_join(struct rtw_adapter *padapter)
-{
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       int ret;
-
-       pmlmepriv->cur_network.join_res = -2;
-
-       set_fwstate(pmlmepriv, _FW_UNDER_LINKING);
-
-       pmlmepriv->to_join = true;
-
-       ret = rtw_select_and_join_from_scanned_queue23a(pmlmepriv);
-       if (ret == _SUCCESS) {
-               pmlmepriv->to_join = false;
-       } else {
-               if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE)) {
-                       /* switch to ADHOC_MASTER */
-                       ret = rtw_do_join_adhoc(padapter);
-                       if (ret != _SUCCESS)
-                               goto exit;
-               } else {
-                       /*  can't associate ; reset under-linking */
-                       _clr_fwstate_(pmlmepriv, _FW_UNDER_LINKING);
-
-                       ret = _FAIL;
-                       pmlmepriv->to_join = false;
-               }
-       }
-
-exit:
-       return ret;
-}
-
-static struct wlan_network *
-rtw_select_candidate_from_queue(struct mlme_priv *pmlmepriv)
-{
-       struct wlan_network *pnetwork, *ptmp, *candidate = NULL;
-       struct rtw_queue *queue = &pmlmepriv->scanned_queue;
-       struct list_head *phead;
-
-       spin_lock_bh(&pmlmepriv->scanned_queue.lock);
-       phead = get_list_head(queue);
-       list_for_each_entry_safe(pnetwork, ptmp, phead, list)
-               rtw_check_join_candidate(pmlmepriv, &candidate, pnetwork);
-       spin_unlock_bh(&pmlmepriv->scanned_queue.lock);
-
-       return candidate;
-}
-
-
-int rtw_do_join_adhoc(struct rtw_adapter *adapter)
-{
-       struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
-       struct wlan_bssid_ex *pdev_network;
-       u8 *ibss;
-       int ret;
-
-       pdev_network = &adapter->registrypriv.dev_network;
-       ibss = adapter->registrypriv.dev_network.MacAddress;
-
-       _clr_fwstate_(pmlmepriv, _FW_UNDER_SURVEY);
-
-       RT_TRACE(_module_rtl871x_mlme_c_, _drv_err_,
-                "switching to adhoc master\n");
-
-       memcpy(&pdev_network->Ssid, &pmlmepriv->assoc_ssid,
-              sizeof(struct cfg80211_ssid));
-
-       rtw_update_registrypriv_dev_network23a(adapter);
-       rtw_generate_random_ibss23a(ibss);
-
-       pmlmepriv->fw_state = WIFI_ADHOC_MASTER_STATE;
-
-       ret = rtw_createbss_cmd23a(adapter);
-       if (ret != _SUCCESS) {
-               RT_TRACE(_module_rtl871x_mlme_c_, _drv_err_,
-                        "Error =>rtw_createbss_cmd23a status FAIL\n");
-       } else  {
-               pmlmepriv->to_join = false;
-       }
-
-       return ret;
-}
-
-int rtw_do_join_network(struct rtw_adapter *adapter,
-                       struct wlan_network *candidate)
-{
-       int ret;
-
-       /*  check for situation of  _FW_LINKED */
-       if (check_fwstate(&adapter->mlmepriv, _FW_LINKED)) {
-               DBG_8723A("%s: _FW_LINKED while ask_for_joinbss!\n", __func__);
-
-               rtw_disassoc_cmd23a(adapter, 0, true);
-               rtw_indicate_disconnect23a(adapter);
-               rtw_free_assoc_resources23a(adapter, 0);
-       }
-       set_fwstate(&adapter->mlmepriv, _FW_UNDER_LINKING);
-
-       ret = rtw_joinbss_cmd23a(adapter, candidate);
-
-       if (ret == _SUCCESS)
-               mod_timer(&adapter->mlmepriv.assoc_timer,
-                         jiffies + msecs_to_jiffies(MAX_JOIN_TIMEOUT));
-
-       return ret;
-}
-
-int rtw_select_and_join_from_scanned_queue23a(struct mlme_priv *pmlmepriv)
-{
-       struct rtw_adapter *adapter;
-       struct wlan_network *candidate = NULL;
-       int ret;
-
-       adapter = pmlmepriv->nic_hdl;
-
-       candidate = rtw_select_candidate_from_queue(pmlmepriv);
-       if (!candidate) {
-               DBG_8723A("%s: return _FAIL(candidate == NULL)\n", __func__);
-               ret = _FAIL;
-               goto exit;
-       } else {
-               DBG_8723A("%s: candidate: %s(%pM, ch:%u)\n",
-                         __func__,
-                         candidate->network.Ssid.ssid,
-                         candidate->network.MacAddress,
-                         candidate->network.DSConfig);
-       }
-
-       ret = rtw_do_join_network(adapter, candidate);
-
-exit:
-       return ret;
-}
-
-int rtw_set_auth23a(struct rtw_adapter *adapter,
-                   struct security_priv *psecuritypriv)
-{
-       struct cmd_obj *pcmd;
-       struct setauth_parm *psetauthparm;
-       struct cmd_priv *pcmdpriv = &adapter->cmdpriv;
-       int res = _SUCCESS;
-
-       pcmd = kzalloc(sizeof(struct cmd_obj), GFP_KERNEL);
-       if (!pcmd) {
-               res = _FAIL;  /* try again */
-               goto exit;
-       }
-
-       psetauthparm = kzalloc(sizeof(struct setauth_parm), GFP_KERNEL);
-       if (!psetauthparm) {
-               kfree(pcmd);
-               res = _FAIL;
-               goto exit;
-       }
-
-       psetauthparm->mode = (unsigned char)psecuritypriv->dot11AuthAlgrthm;
-
-       pcmd->cmdcode = _SetAuth_CMD_;
-       pcmd->parmbuf = (unsigned char *)psetauthparm;
-       pcmd->cmdsz =  (sizeof(struct setauth_parm));
-       pcmd->rsp = NULL;
-       pcmd->rspsz = 0;
-
-       RT_TRACE(_module_rtl871x_mlme_c_, _drv_err_,
-                "after enqueue set_auth_cmd, auth_mode=%x\n",
-                psecuritypriv->dot11AuthAlgrthm);
-
-       res = rtw_enqueue_cmd23a(pcmdpriv, pcmd);
-
-exit:
-
-       return res;
-}
-
-int rtw_set_key23a(struct rtw_adapter *adapter,
-                  struct security_priv *psecuritypriv, int keyid, u8 set_tx)
-{
-       u8 keylen;
-       struct cmd_obj *pcmd;
-       struct setkey_parm *psetkeyparm;
-       struct cmd_priv *pcmdpriv = &adapter->cmdpriv;
-       struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
-       int res = _SUCCESS;
-
-       if (keyid >= 4) {
-               res = _FAIL;
-               goto exit;
-       }
-
-       pcmd = kzalloc(sizeof(struct cmd_obj), GFP_KERNEL);
-       if (!pcmd) {
-               res = _FAIL;  /* try again */
-               goto exit;
-       }
-       psetkeyparm = kzalloc(sizeof(struct setkey_parm), GFP_KERNEL);
-       if (!psetkeyparm) {
-               kfree(pcmd);
-               res = _FAIL;
-               goto exit;
-       }
-
-       if (psecuritypriv->dot11AuthAlgrthm == dot11AuthAlgrthm_8021X) {
-               psetkeyparm->algorithm = (unsigned char)
-                       psecuritypriv->dot118021XGrpPrivacy;
-               RT_TRACE(_module_rtl871x_mlme_c_, _drv_err_,
-                        "rtw_set_key23a: psetkeyparm->algorithm = (unsigned char)psecuritypriv->dot118021XGrpPrivacy =%d\n",
-                        psetkeyparm->algorithm);
-       } else {
-               psetkeyparm->algorithm = (u8)psecuritypriv->dot11PrivacyAlgrthm;
-               RT_TRACE(_module_rtl871x_mlme_c_, _drv_err_,
-                        "rtw_set_key23a: psetkeyparm->algorithm = (u8)psecuritypriv->dot11PrivacyAlgrthm =%d\n",
-                        psetkeyparm->algorithm);
-       }
-       psetkeyparm->keyid = keyid;/* 0~3 */
-       psetkeyparm->set_tx = set_tx;
-       if (is_wep_enc(psetkeyparm->algorithm))
-               pmlmepriv->key_mask |= BIT(psetkeyparm->keyid);
-
-       DBG_8723A("==> rtw_set_key23a algorithm(%x), keyid(%x), key_mask(%x)\n",
-                 psetkeyparm->algorithm, psetkeyparm->keyid,
-                 pmlmepriv->key_mask);
-       RT_TRACE(_module_rtl871x_mlme_c_, _drv_err_,
-                "rtw_set_key23a: psetkeyparm->algorithm =%d psetkeyparm->keyid = (u8)keyid =%d\n",
-                psetkeyparm->algorithm, keyid);
-
-       switch (psetkeyparm->algorithm) {
-       case WLAN_CIPHER_SUITE_WEP40:
-               keylen = 5;
-               memcpy(&psetkeyparm->key[0],
-                      &psecuritypriv->wep_key[keyid].key, keylen);
-               break;
-       case WLAN_CIPHER_SUITE_WEP104:
-               keylen = 13;
-               memcpy(&psetkeyparm->key[0],
-                      &psecuritypriv->wep_key[keyid].key, keylen);
-               break;
-       case WLAN_CIPHER_SUITE_TKIP:
-               keylen = 16;
-               memcpy(&psetkeyparm->key,
-                      &psecuritypriv->dot118021XGrpKey[keyid], keylen);
-               psetkeyparm->grpkey = 1;
-               break;
-       case WLAN_CIPHER_SUITE_CCMP:
-               keylen = 16;
-               memcpy(&psetkeyparm->key,
-                      &psecuritypriv->dot118021XGrpKey[keyid], keylen);
-               psetkeyparm->grpkey = 1;
-               break;
-       default:
-               RT_TRACE(_module_rtl871x_mlme_c_, _drv_err_,
-                        "rtw_set_key23a:psecuritypriv->dot11PrivacyAlgrthm = %x (must be 1 or 2 or 4 or 5)\n",
-                        psecuritypriv->dot11PrivacyAlgrthm);
-               res = _FAIL;
-               kfree(pcmd);
-               kfree(psetkeyparm);
-               goto exit;
-       }
-
-       pcmd->cmdcode = _SetKey_CMD_;
-       pcmd->parmbuf = (u8 *)psetkeyparm;
-       pcmd->cmdsz =  (sizeof(struct setkey_parm));
-       pcmd->rsp = NULL;
-       pcmd->rspsz = 0;
-
-       /* sema_init(&pcmd->cmd_sem, 0); */
-
-       res = rtw_enqueue_cmd23a(pcmdpriv, pcmd);
-
-exit:
-
-       return res;
-}
-
-/* adjust IEs for rtw_joinbss_cmd23a in WMM */
-int rtw_restruct_wmm_ie23a(struct rtw_adapter *adapter, u8 *in_ie,
-                          u8 *out_ie, uint in_len, uint initial_out_len)
-{
-       int ielength;
-       const u8 *p;
-
-       ielength = initial_out_len;
-
-       p = cfg80211_find_vendor_ie(WLAN_OUI_MICROSOFT,
-                                   WLAN_OUI_TYPE_MICROSOFT_WMM,
-                                   in_ie, in_len);
-
-       if (p && p[1]) {
-               memcpy(out_ie + initial_out_len, p, 9);
-
-               out_ie[initial_out_len + 1] = 7;
-               out_ie[initial_out_len + 6] = 0;
-               out_ie[initial_out_len + 8] = 0;
-
-               ielength += 9;
-       }
-
-       return ielength;
-}
-
-/*  */
-/*  Ported from 8185: IsInPreAuthKeyList().
-    (Renamed from SecIsInPreAuthKeyList(), 2006-10-13.) */
-/*  Added by Annie, 2006-05-07. */
-/*  */
-/*  Search by BSSID, */
-/*  Return Value: */
-/*             -1      :if there is no pre-auth key in the  table */
-/*             >= 0    :if there is pre-auth key, and   return the entry id */
-/*  */
-/*  */
-
-static int SecIsInPMKIDList(struct rtw_adapter *Adapter, u8 *bssid)
-{
-       struct security_priv *psecuritypriv = &Adapter->securitypriv;
-       int i = 0;
-
-       do {
-               if (psecuritypriv->PMKIDList[i].bUsed &&
-                    ether_addr_equal(psecuritypriv->PMKIDList[i].Bssid, bssid)) {
-                       break;
-               } else {
-                       i++;
-                       /* continue; */
-               }
-       } while (i < NUM_PMKID_CACHE);
-
-       if (i == NUM_PMKID_CACHE)
-               i = -1;/*  Could not find. */
-       else {
-               /*  There is one Pre-Authentication Key for
-                   the specific BSSID. */
-       }
-
-       return i;
-}
-
-/*  */
-/*  Check the RSN IE length */
-/*  If the RSN IE length <= 20, the RSN IE didn't include
-    the PMKID information */
-/*  0-11th element in the array are the fixed IE */
-/*  12th element in the array is the IE */
-/*  13th element in the array is the IE length */
-/*  */
-
-static int rtw_append_pmkid(struct rtw_adapter *Adapter, int iEntry,
-                           u8 *ie, uint ie_len)
-{
-       struct security_priv *psecuritypriv = &Adapter->securitypriv;
-
-       if (ie[1] <= 20) {
-               /*  The RSN IE didn't include the PMK ID,
-                   append the PMK information */
-                       ie[ie_len] = 1;
-                       ie_len++;
-                       ie[ie_len] = 0; /* PMKID count = 0x0100 */
-                       ie_len++;
-                       memcpy(&ie[ie_len],
-                              &psecuritypriv->PMKIDList[iEntry].PMKID, 16);
-
-                       ie_len += 16;
-                       ie[1] += 18;/* PMKID length = 2+16 */
-       }
-       return ie_len;
-}
-
-int rtw_restruct_sec_ie23a(struct rtw_adapter *adapter, u8 *in_ie, u8 *out_ie,
-                          uint in_len)
-{
-       u8 authmode;
-       uint ielength;
-       int iEntry;
-       struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
-       struct security_priv *psecuritypriv = &adapter->securitypriv;
-       uint ndisauthmode = psecuritypriv->ndisauthtype;
-       uint ndissecuritytype = psecuritypriv->ndisencryptstatus;
-
-       RT_TRACE(_module_rtl871x_mlme_c_, _drv_notice_,
-                "+rtw_restruct_sec_ie23a: ndisauthmode=%d ndissecuritytype=%d\n",
-                ndisauthmode, ndissecuritytype);
-
-       ielength = 0;
-       if (ndisauthmode == Ndis802_11AuthModeWPA ||
-           ndisauthmode == Ndis802_11AuthModeWPAPSK)
-               authmode = WLAN_EID_VENDOR_SPECIFIC;
-       if (ndisauthmode == Ndis802_11AuthModeWPA2 ||
-           ndisauthmode == Ndis802_11AuthModeWPA2PSK)
-               authmode = WLAN_EID_RSN;
-
-       if (check_fwstate(pmlmepriv, WIFI_UNDER_WPS)) {
-               memcpy(out_ie + ielength, psecuritypriv->wps_ie,
-                      psecuritypriv->wps_ie_len);
-
-               ielength += psecuritypriv->wps_ie_len;
-       } else if (authmode == WLAN_EID_VENDOR_SPECIFIC ||
-                  authmode == WLAN_EID_RSN) {
-               /* copy RSN or SSN */
-               memcpy(&out_ie[ielength], &psecuritypriv->supplicant_ie[0],
-                      psecuritypriv->supplicant_ie[1] + 2);
-               ielength += psecuritypriv->supplicant_ie[1] + 2;
-       }
-
-       iEntry = SecIsInPMKIDList(adapter, pmlmepriv->assoc_bssid);
-       if (iEntry < 0)
-               return ielength;
-       else {
-               if (authmode == WLAN_EID_RSN)
-                       ielength = rtw_append_pmkid(adapter, iEntry,
-                                                   out_ie, ielength);
-       }
-
-       return ielength;
-}
-
-void rtw_init_registrypriv_dev_network23a(struct rtw_adapter *adapter)
-{
-       struct registry_priv *pregistrypriv = &adapter->registrypriv;
-       struct eeprom_priv *peepriv = &adapter->eeprompriv;
-       struct wlan_bssid_ex    *pdev_network = &pregistrypriv->dev_network;
-       u8 *myhwaddr = myid(peepriv);
-
-       ether_addr_copy(pdev_network->MacAddress, myhwaddr);
-
-       memcpy(&pdev_network->Ssid, &pregistrypriv->ssid,
-              sizeof(struct cfg80211_ssid));
-
-       pdev_network->beacon_interval = 100;
-}
-
-void rtw_update_registrypriv_dev_network23a(struct rtw_adapter *adapter)
-{
-       int sz = 0;
-       struct registry_priv *pregistrypriv = &adapter->registrypriv;
-       struct wlan_bssid_ex *pdev_network = &pregistrypriv->dev_network;
-       struct security_priv *psecuritypriv = &adapter->securitypriv;
-       struct wlan_network *cur_network = &adapter->mlmepriv.cur_network;
-       /* struct       xmit_priv       *pxmitpriv = &adapter->xmitpriv; */
-
-       pdev_network->Privacy =
-               (psecuritypriv->dot11PrivacyAlgrthm > 0 ? 1 : 0);
-
-       pdev_network->Rssi = 0;
-
-       pdev_network->DSConfig = pregistrypriv->channel;
-       RT_TRACE(_module_rtl871x_mlme_c_, _drv_info_,
-                "pregistrypriv->channel =%d, pdev_network->DSConfig = 0x%x\n",
-                pregistrypriv->channel, pdev_network->DSConfig);
-
-       if (cur_network->network.ifmode == NL80211_IFTYPE_ADHOC)
-               pdev_network->ATIMWindow = 0;
-
-       pdev_network->ifmode = cur_network->network.ifmode;
-
-       /*  1. Supported rates */
-       /*  2. IE */
-
-       sz = rtw_generate_ie23a(pregistrypriv);
-
-       pdev_network->IELength = sz;
-
-       pdev_network->Length =
-               get_wlan_bssid_ex_sz(pdev_network);
-
-       /* notes: translate IELength & Length after assign the
-          Length to cmdsz in createbss_cmd(); */
-       /* pdev_network->IELength = cpu_to_le32(sz); */
-}
-
-/* the function is at passive_level */
-void rtw_joinbss_reset23a(struct rtw_adapter *padapter)
-{
-       u8 threshold;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct ht_priv *phtpriv = &pmlmepriv->htpriv;
-
-       /* todo: if you want to do something io/reg/hw setting
-          before join_bss, please add code here */
-
-       pmlmepriv->num_FortyMHzIntolerant = 0;
-
-       pmlmepriv->num_sta_no_ht = 0;
-
-       phtpriv->ampdu_enable = false;/* reset to disabled */
-
-       /*  TH = 1 => means that invalidate usb rx aggregation */
-       /*  TH = 0 => means that validate usb rx aggregation, use init value. */
-       if (phtpriv->ht_option) {
-               if (padapter->registrypriv.wifi_spec == 1)
-                       threshold = 1;
-               else
-                       threshold = 0;
-       } else
-               threshold = 1;
-
-       rtl8723a_set_rxdma_agg_pg_th(padapter, threshold);
-}
-
-/* the function is >= passive_level */
-bool rtw_restructure_ht_ie23a(struct rtw_adapter *padapter, u8 *in_ie,
-                             u8 *out_ie, uint in_len, uint *pout_len)
-{
-       u32 out_len;
-       int max_rx_ampdu_factor;
-       unsigned char *pframe;
-       const u8 *p;
-       struct ieee80211_ht_cap ht_capie;
-       u8 WMM_IE[7] = {0x00, 0x50, 0xf2, 0x02, 0x00, 0x01, 0x00};
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct ht_priv *phtpriv = &pmlmepriv->htpriv;
-
-       phtpriv->ht_option = false;
-
-       p = cfg80211_find_ie(WLAN_EID_HT_CAPABILITY, in_ie, in_len);
-
-       if (p && p[1] > 0) {
-               u32 rx_packet_offset, max_recvbuf_sz;
-
-               if (pmlmepriv->qos_option == 0) {
-                       out_len = *pout_len;
-                       pframe = rtw_set_ie23a(out_ie + out_len,
-                                              WLAN_EID_VENDOR_SPECIFIC,
-                                              sizeof(WMM_IE), WMM_IE,
-                                              pout_len);
-
-                       pmlmepriv->qos_option = 1;
-               }
-
-               out_len = *pout_len;
-
-               memset(&ht_capie, 0, sizeof(struct ieee80211_ht_cap));
-
-               ht_capie.cap_info = cpu_to_le16(IEEE80211_HT_CAP_SUP_WIDTH_20_40 |
-                       IEEE80211_HT_CAP_SGI_20 | IEEE80211_HT_CAP_SGI_40 |
-                       IEEE80211_HT_CAP_TX_STBC | IEEE80211_HT_CAP_DSSSCCK40);
-
-               GetHalDefVar8192CUsb(padapter, HAL_DEF_RX_PACKET_OFFSET,
-                                    &rx_packet_offset);
-               GetHalDefVar8192CUsb(padapter, HAL_DEF_MAX_RECVBUF_SZ,
-                                    &max_recvbuf_sz);
-
-               GetHalDefVar8192CUsb(padapter, HW_VAR_MAX_RX_AMPDU_FACTOR,
-                                    &max_rx_ampdu_factor);
-               ht_capie.ampdu_params_info = max_rx_ampdu_factor & 0x03;
-
-               if (padapter->securitypriv.dot11PrivacyAlgrthm ==
-                   WLAN_CIPHER_SUITE_CCMP)
-                       ht_capie.ampdu_params_info |=
-                               (IEEE80211_HT_AMPDU_PARM_DENSITY& (0x07 << 2));
-               else
-                       ht_capie.ampdu_params_info |=
-                               (IEEE80211_HT_AMPDU_PARM_DENSITY & 0x00);
-
-               pframe = rtw_set_ie23a(out_ie + out_len, WLAN_EID_HT_CAPABILITY,
-                                   sizeof(struct ieee80211_ht_cap),
-                                   (unsigned char *)&ht_capie, pout_len);
-
-               phtpriv->ht_option = true;
-
-               p = cfg80211_find_ie(WLAN_EID_HT_OPERATION, in_ie, in_len);
-               if (p && (p[1] == sizeof(struct ieee80211_ht_operation))) {
-                       out_len = *pout_len;
-                       pframe = rtw_set_ie23a(out_ie + out_len,
-                                              WLAN_EID_HT_OPERATION,
-                                              p[1], p + 2 , pout_len);
-               }
-       }
-
-       return phtpriv->ht_option;
-}
-
-/* the function is > passive_level (in critical_section) */
-void rtw_update_ht_cap23a(struct rtw_adapter *padapter, u8 *pie, uint ie_len)
-{
-       u8 max_ampdu_sz;
-       const u8 *p;
-       struct ieee80211_ht_cap *pht_capie;
-       struct ieee80211_ht_operation *pht_addtinfo;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct ht_priv *phtpriv = &pmlmepriv->htpriv;
-       struct registry_priv *pregistrypriv = &padapter->registrypriv;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-
-       if (!phtpriv->ht_option)
-               return;
-
-       if ((!pmlmeinfo->HT_info_enable) || (!pmlmeinfo->HT_caps_enable))
-               return;
-
-       DBG_8723A("+rtw_update_ht_cap23a()\n");
-
-       /* maybe needs check if ap supports rx ampdu. */
-       if (!phtpriv->ampdu_enable && pregistrypriv->ampdu_enable == 1) {
-               if (pregistrypriv->wifi_spec == 1)
-                       phtpriv->ampdu_enable = false;
-               else
-                       phtpriv->ampdu_enable = true;
-       } else if (pregistrypriv->ampdu_enable == 2)
-               phtpriv->ampdu_enable = true;
-
-       /* check Max Rx A-MPDU Size */
-       p = cfg80211_find_ie(WLAN_EID_HT_CAPABILITY, pie, ie_len);
-
-       if (p && p[1] > 0) {
-               pht_capie = (struct ieee80211_ht_cap *)(p + 2);
-               max_ampdu_sz = pht_capie->ampdu_params_info &
-                       IEEE80211_HT_AMPDU_PARM_FACTOR;
-               /*  max_ampdu_sz (kbytes); */
-               max_ampdu_sz = 1 << (max_ampdu_sz + 3);
-
-               phtpriv->rx_ampdu_maxlen = max_ampdu_sz;
-       }
-
-       p = cfg80211_find_ie(WLAN_EID_HT_OPERATION, pie, ie_len);
-       if (p && p[1] > 0) {
-               pht_addtinfo = (struct ieee80211_ht_operation *)(p + 2);
-               /* todo: */
-       }
-
-       /* update cur_bwmode & cur_ch_offset */
-       if (pregistrypriv->cbw40_enable &&
-           pmlmeinfo->ht_cap.cap_info &
-           cpu_to_le16(IEEE80211_HT_CAP_SUP_WIDTH_20_40) &&
-           pmlmeinfo->HT_info.ht_param & IEEE80211_HT_PARAM_CHAN_WIDTH_ANY) {
-               int i;
-               u8 rf_type;
-
-               rf_type = rtl8723a_get_rf_type(padapter);
-
-               /* update the MCS rates */
-               for (i = 0; i < IEEE80211_HT_MCS_MASK_LEN; i++) {
-                       if (rf_type == RF_1T1R || rf_type == RF_1T2R)
-                               pmlmeinfo->ht_cap.mcs.rx_mask[i] &=
-                                       MCS_rate_1R23A[i];
-                       else
-                               pmlmeinfo->ht_cap.mcs.rx_mask[i] &=
-                                       MCS_rate_2R23A[i];
-               }
-               /* switch to the 40M Hz mode according to the AP */
-               pmlmeext->cur_bwmode = HT_CHANNEL_WIDTH_40;
-               switch (pmlmeinfo->HT_info.ht_param &
-                       IEEE80211_HT_PARAM_CHA_SEC_OFFSET) {
-               case IEEE80211_HT_PARAM_CHA_SEC_ABOVE:
-                       pmlmeext->cur_ch_offset = HAL_PRIME_CHNL_OFFSET_LOWER;
-                       break;
-
-               case IEEE80211_HT_PARAM_CHA_SEC_BELOW:
-                       pmlmeext->cur_ch_offset = HAL_PRIME_CHNL_OFFSET_UPPER;
-                       break;
-
-               default:
-                       pmlmeext->cur_ch_offset =
-                               HAL_PRIME_CHNL_OFFSET_DONT_CARE;
-                       break;
-               }
-       }
-
-       /*  */
-       /*  Config SM Power Save setting */
-       /*  */
-       pmlmeinfo->SM_PS =
-               (le16_to_cpu(pmlmeinfo->ht_cap.cap_info) &
-                IEEE80211_HT_CAP_SM_PS) >> IEEE80211_HT_CAP_SM_PS_SHIFT;
-       if (pmlmeinfo->SM_PS == WLAN_HT_CAP_SM_PS_STATIC)
-               DBG_8723A("%s(): WLAN_HT_CAP_SM_PS_STATIC\n", __func__);
-
-       /*  */
-       /*  Config current HT Protection mode. */
-       /*  */
-       pmlmeinfo->HT_protection =
-               le16_to_cpu(pmlmeinfo->HT_info.operation_mode) &
-               IEEE80211_HT_OP_MODE_PROTECTION;
-}
-
-void rtw_issue_addbareq_cmd23a(struct rtw_adapter *padapter,
-                              struct xmit_frame *pxmitframe)
-{
-       u8 issued;
-       int priority;
-       struct sta_info *psta;
-       struct ht_priv  *phtpriv;
-       struct pkt_attrib *pattrib = &pxmitframe->attrib;
-       s32 bmcst = is_multicast_ether_addr(pattrib->ra);
-
-       if (bmcst || padapter->mlmepriv.LinkDetectInfo.NumTxOkInPeriod < 100)
-               return;
-
-       priority = pattrib->priority;
-
-       if (pattrib->psta)
-               psta = pattrib->psta;
-       else {
-               DBG_8723A("%s, call rtw_get_stainfo23a()\n", __func__);
-               psta = rtw_get_stainfo23a(&padapter->stapriv, pattrib->ra);
-       }
-
-       if (!psta) {
-               DBG_8723A("%s, psta == NUL\n", __func__);
-               return;
-       }
-
-       if (!(psta->state &_FW_LINKED)) {
-               DBG_8723A("%s, psta->state(0x%x) != _FW_LINKED\n",
-                         __func__, psta->state);
-               return;
-       }
-
-       phtpriv = &psta->htpriv;
-
-       if (phtpriv->ht_option && phtpriv->ampdu_enable) {
-               issued = (phtpriv->agg_enable_bitmap>>priority)&0x1;
-               issued |= (phtpriv->candidate_tid_bitmap>>priority)&0x1;
-
-               if (issued == 0) {
-                       DBG_8723A("rtw_issue_addbareq_cmd23a, p =%d\n",
-                                 priority);
-                       psta->htpriv.candidate_tid_bitmap |= BIT(priority);
-                       rtw_addbareq_cmd23a(padapter, (u8) priority,
-                                           pattrib->ra);
-               }
-       }
-}
-
-int rtw_linked_check(struct rtw_adapter *padapter)
-{
-       if (check_fwstate(&padapter->mlmepriv, WIFI_AP_STATE) ||
-           check_fwstate(&padapter->mlmepriv,
-                         WIFI_ADHOC_STATE|WIFI_ADHOC_MASTER_STATE)) {
-               if (padapter->stapriv.asoc_sta_count > 2)
-                       return true;
-       } else {        /* Station mode */
-               if (check_fwstate(&padapter->mlmepriv, _FW_LINKED))
-                       return true;
-       }
-       return false;
-}
diff --git a/drivers/staging/rtl8723au/core/rtw_mlme_ext.c b/drivers/staging/rtl8723au/core/rtw_mlme_ext.c
deleted file mode 100644 (file)
index 7dd1540..0000000
+++ /dev/null
@@ -1,6187 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#define _RTW_MLME_EXT_C_
-
-#include <osdep_service.h>
-#include <drv_types.h>
-#include <wifi.h>
-#include <rtw_mlme_ext.h>
-#include <wlan_bssdef.h>
-#include <mlme_osdep.h>
-#include <recv_osdep.h>
-#include <linux/ieee80211.h>
-#include <rtl8723a_hal.h>
-
-static int OnAssocReq23a(struct rtw_adapter *padapter, struct recv_frame *precv_frame);
-static int OnAssocRsp23a(struct rtw_adapter *padapter, struct recv_frame *precv_frame);
-static int OnProbeReq23a(struct rtw_adapter *padapter, struct recv_frame *precv_frame);
-static int OnProbeRsp23a(struct rtw_adapter *padapter, struct recv_frame *precv_frame);
-static int DoReserved23a(struct rtw_adapter *padapter, struct recv_frame *precv_frame);
-static int OnBeacon23a(struct rtw_adapter *padapter, struct recv_frame *precv_frame);
-static int OnAtim23a(struct rtw_adapter *padapter, struct recv_frame *precv_frame);
-static int OnDisassoc23a(struct rtw_adapter *padapter, struct recv_frame *precv_frame);
-static int OnAuth23aClient23a(struct rtw_adapter *padapter, struct recv_frame *precv_frame);
-static int OnDeAuth23a(struct rtw_adapter *padapter, struct recv_frame *precv_frame);
-static int OnAction23a(struct rtw_adapter *padapter, struct recv_frame *precv_frame);
-
-static int on_action_spct23a(struct rtw_adapter *padapter, struct recv_frame *precv_frame);
-static int OnAction23a_qos(struct rtw_adapter *padapter, struct recv_frame *precv_frame);
-static int OnAction23a_dls(struct rtw_adapter *padapter, struct recv_frame *precv_frame);
-static int OnAction23a_back23a(struct rtw_adapter *padapter, struct recv_frame *precv_frame);
-static int on_action_public23a(struct rtw_adapter *padapter, struct recv_frame *precv_frame);
-static int OnAction23a_ht(struct rtw_adapter *padapter, struct recv_frame *precv_frame);
-static int OnAction23a_wmm(struct rtw_adapter *padapter, struct recv_frame *precv_frame);
-static int OnAction23a_p2p(struct rtw_adapter *padapter, struct recv_frame *precv_frame);
-
-static void issue_assocreq(struct rtw_adapter *padapter);
-static void issue_probereq(struct rtw_adapter *padapter,
-                          struct cfg80211_ssid *pssid, u8 *da);
-static int issue_probereq_ex(struct rtw_adapter *padapter,
-                            struct cfg80211_ssid *pssid,
-                            u8 *da, int try_cnt, int wait_ms);
-static void issue_probersp(struct rtw_adapter *padapter, unsigned char *da);
-static void issue_auth(struct rtw_adapter *padapter, struct sta_info *psta,
-                      unsigned short status);
-static int issue_deauth_ex(struct rtw_adapter *padapter, u8 *da,
-                          unsigned short reason, int try_cnt, int wait_ms);
-static void start_clnt_assoc(struct rtw_adapter *padapter);
-static void start_clnt_auth(struct rtw_adapter *padapter);
-static void start_clnt_join(struct rtw_adapter *padapter);
-static void start_create_ibss(struct rtw_adapter *padapter);
-static struct wlan_bssid_ex *collect_bss_info(struct rtw_adapter *padapter,
-                                             struct recv_frame *precv_frame);
-
-#ifdef CONFIG_8723AU_AP_MODE
-static int OnAuth23a(struct rtw_adapter *padapter, struct recv_frame *precv_frame);
-static void issue_assocrsp(struct rtw_adapter *padapter, unsigned short status,
-                          struct sta_info *pstat, u16 pkt_type);
-#endif
-
-static struct mlme_handler mlme_sta_tbl[]={
-       {"OnAssocReq23a",               &OnAssocReq23a},
-       {"OnAssocRsp23a",               &OnAssocRsp23a},
-       {"OnReAssocReq",        &OnAssocReq23a},
-       {"OnReAssocRsp",        &OnAssocRsp23a},
-       {"OnProbeReq23a",               &OnProbeReq23a},
-       {"OnProbeRsp23a",               &OnProbeRsp23a},
-
-       /*----------------------------------------------------------
-                                       below 2 are reserved
-       -----------------------------------------------------------*/
-       {"DoReserved23a",               &DoReserved23a},
-       {"DoReserved23a",               &DoReserved23a},
-       {"OnBeacon23a",         &OnBeacon23a},
-       {"OnATIM",              &OnAtim23a},
-       {"OnDisassoc23a",               &OnDisassoc23a},
-       {"OnAuth23a",           &OnAuth23aClient23a},
-       {"OnDeAuth23a",         &OnDeAuth23a},
-       {"OnAction23a",         &OnAction23a},
-};
-
-static struct action_handler OnAction23a_tbl[]={
-       {WLAN_CATEGORY_SPECTRUM_MGMT, "ACTION_SPECTRUM_MGMT", on_action_spct23a},
-       {WLAN_CATEGORY_QOS, "ACTION_QOS", &OnAction23a_qos},
-       {WLAN_CATEGORY_DLS, "ACTION_DLS", &OnAction23a_dls},
-       {WLAN_CATEGORY_BACK, "ACTION_BACK", &OnAction23a_back23a},
-       {WLAN_CATEGORY_PUBLIC, "ACTION_PUBLIC", on_action_public23a},
-       {WLAN_CATEGORY_HT, "ACTION_HT", &OnAction23a_ht},
-       {WLAN_CATEGORY_SA_QUERY, "ACTION_SA_QUERY", &DoReserved23a},
-       {WLAN_CATEGORY_WMM, "ACTION_WMM", &OnAction23a_wmm},
-       {WLAN_CATEGORY_VENDOR_SPECIFIC, "ACTION_P2P", &OnAction23a_p2p},
-};
-
-static u8      null_addr[ETH_ALEN]= {0, 0, 0, 0, 0, 0};
-
-/**************************************************
-OUI definitions for the vendor specific IE
-***************************************************/
-unsigned char WMM_OUI23A[] = {0x00, 0x50, 0xf2, 0x02};
-unsigned char WPS_OUI23A[] = {0x00, 0x50, 0xf2, 0x04};
-unsigned char P2P_OUI23A[] = {0x50, 0x6F, 0x9A, 0x09};
-unsigned char WFD_OUI23A[] = {0x50, 0x6F, 0x9A, 0x0A};
-
-unsigned char WMM_INFO_OUI23A[] = {0x00, 0x50, 0xf2, 0x02, 0x00, 0x01};
-unsigned char WMM_PARA_OUI23A[] = {0x00, 0x50, 0xf2, 0x02, 0x01, 0x01};
-
-static unsigned char REALTEK_96B_IE[] = {0x00, 0xe0, 0x4c, 0x02, 0x01, 0x20};
-
-/********************************************************
-MCS rate definitions
-*********************************************************/
-unsigned char MCS_rate_2R23A[16] = {
-       0xff, 0xff, 0x0, 0x0, 0x01, 0x0, 0x0, 0x0,
-       0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0};
-unsigned char MCS_rate_1R23A[16] = {
-       0xff, 0x00, 0x0, 0x0, 0x01, 0x0, 0x0, 0x0,
-       0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0};
-
-/********************************************************
-ChannelPlan definitions
-*********************************************************/
-
-static struct rt_channel_plan_2g RTW_ChannelPlan2G[RT_CHANNEL_DOMAIN_2G_MAX] = {
-       /*  0x00, RT_CHANNEL_DOMAIN_2G_WORLD , Passive scan CH 12, 13 */
-       {{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13}, 13},
-       /*  0x01, RT_CHANNEL_DOMAIN_2G_ETSI1 */
-       {{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13}, 13},
-       /*  0x02, RT_CHANNEL_DOMAIN_2G_FCC1 */
-       {{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11}, 11},
-       /*  0x03, RT_CHANNEL_DOMAIN_2G_MIKK1 */
-       {{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14}, 14},
-       /*  0x04, RT_CHANNEL_DOMAIN_2G_ETSI2 */
-       {{10, 11, 12, 13}, 4},
-       /*  0x05, RT_CHANNEL_DOMAIN_2G_NULL */
-       {{}, 0},
-};
-
-static struct rt_channel_plan_5g RTW_ChannelPlan5G[RT_CHANNEL_DOMAIN_5G_MAX] = {
-       /*  0x00, RT_CHANNEL_DOMAIN_5G_NULL */
-       {{}, 0},
-       /*  0x01, RT_CHANNEL_DOMAIN_5G_ETSI1 */
-       {{36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112,
-         116, 120, 124, 128, 132, 136, 140}, 19},
-       /*  0x02, RT_CHANNEL_DOMAIN_5G_ETSI2 */
-       {{36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112,
-         116, 120, 124, 128, 132, 136, 140, 149, 153, 157, 161, 165}, 24},
-       /*  0x03, RT_CHANNEL_DOMAIN_5G_ETSI3 */
-       {{36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112,
-         116, 120, 124, 128, 132, 149, 153, 157, 161, 165}, 22},
-       /*  0x04, RT_CHANNEL_DOMAIN_5G_FCC1 */
-       {{36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112,
-         116, 120, 124, 128, 132, 136, 140, 149, 153, 157, 161, 165}, 24},
-       /*  0x05, RT_CHANNEL_DOMAIN_5G_FCC2 */
-       {{36, 40, 44, 48, 149, 153, 157, 161, 165}, 9},
-       /*  0x06, RT_CHANNEL_DOMAIN_5G_FCC3 */
-       {{36, 40, 44, 48, 52, 56, 60, 64, 149, 153, 157, 161, 165}, 13},
-       /*  0x07, RT_CHANNEL_DOMAIN_5G_FCC4 */
-       {{36, 40, 44, 48, 52, 56, 60, 64, 149, 153, 157, 161}, 12},
-       /*  0x08, RT_CHANNEL_DOMAIN_5G_FCC5 */
-       {{149, 153, 157, 161, 165}, 5},
-       /*  0x09, RT_CHANNEL_DOMAIN_5G_FCC6 */
-       {{36, 40, 44, 48, 52, 56, 60, 64}, 8},
-       /*  0x0A, RT_CHANNEL_DOMAIN_5G_FCC7_IC1 */
-       {{36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112,
-         116, 136, 140, 149, 153, 157, 161, 165}, 20},
-       /*  0x0B, RT_CHANNEL_DOMAIN_5G_KCC1 */
-       {{36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112,
-         116, 120, 124, 149, 153, 157, 161, 165}, 20},
-       /*  0x0C, RT_CHANNEL_DOMAIN_5G_MKK1 */
-       {{36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112,
-         116, 120, 124, 128, 132, 136, 140}, 19},
-       /*  0x0D, RT_CHANNEL_DOMAIN_5G_MKK2 */
-       {{36, 40, 44, 48, 52, 56, 60, 64}, 8},
-       /*  0x0E, RT_CHANNEL_DOMAIN_5G_MKK3 */
-       {{100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140}, 11},
-       /*  0x0F, RT_CHANNEL_DOMAIN_5G_NCC1 */
-       {{56, 60, 64, 100, 104, 108, 112, 116, 136, 140, 149,
-         153, 157, 161, 165}, 15},
-       /*  0x10, RT_CHANNEL_DOMAIN_5G_NCC2 */
-       {{56, 60, 64, 149, 153, 157, 161, 165}, 8},
-
-       /*  Driver self defined for old channel plan Compatible,
-           Remember to modify if have new channel plan definition ===== */
-       /*  0x11, RT_CHANNEL_DOMAIN_5G_FCC */
-       {{36, 40, 44, 48, 52, 56, 60, 64, 100, 104, 108, 112,
-         116, 132, 136, 140, 149, 153, 157, 161, 165}, 21},
-       /*  0x12, RT_CHANNEL_DOMAIN_5G_JAPAN_NO_DFS */
-       {{36, 40, 44, 48}, 4},
-       /*  0x13, RT_CHANNEL_DOMAIN_5G_FCC4_NO_DFS */
-       {{36, 40, 44, 48, 149, 153, 157, 161}, 8},
-};
-
-static struct rt_channel_plan_map RTW_ChannelPlanMap[RT_CHANNEL_DOMAIN_MAX] = {
-       /*  0x00 ~ 0x1F , Old Define ===== */
-       {0x02, 0x11},   /* 0x00, RT_CHANNEL_DOMAIN_FCC */
-       {0x02, 0x0A},   /* 0x01, RT_CHANNEL_DOMAIN_IC */
-       {0x01, 0x01},   /* 0x02, RT_CHANNEL_DOMAIN_ETSI */
-       {0x01, 0x00},   /* 0x03, RT_CHANNEL_DOMAIN_SPAIN */
-       {0x01, 0x00},   /* 0x04, RT_CHANNEL_DOMAIN_FRANCE */
-       {0x03, 0x00},   /* 0x05, RT_CHANNEL_DOMAIN_MKK */
-       {0x03, 0x00},   /* 0x06, RT_CHANNEL_DOMAIN_MKK1 */
-       {0x01, 0x09},   /* 0x07, RT_CHANNEL_DOMAIN_ISRAEL */
-       {0x03, 0x09},   /* 0x08, RT_CHANNEL_DOMAIN_TELEC */
-       {0x03, 0x00},   /* 0x09, RT_CHANNEL_DOMAIN_GLOBAL_DOAMIN */
-       {0x00, 0x00},   /* 0x0A, RT_CHANNEL_DOMAIN_WORLD_WIDE_13 */
-       {0x02, 0x0F},   /* 0x0B, RT_CHANNEL_DOMAIN_TAIWAN */
-       {0x01, 0x08},   /* 0x0C, RT_CHANNEL_DOMAIN_CHINA */
-       {0x02, 0x06},   /* 0x0D, RT_CHANNEL_DOMAIN_SINGAPORE_INDIA_MEXICO */
-       {0x02, 0x0B},   /* 0x0E, RT_CHANNEL_DOMAIN_KOREA */
-       {0x02, 0x09},   /* 0x0F, RT_CHANNEL_DOMAIN_TURKEY */
-       {0x01, 0x01},   /* 0x10, RT_CHANNEL_DOMAIN_JAPAN */
-       {0x02, 0x05},   /* 0x11, RT_CHANNEL_DOMAIN_FCC_NO_DFS */
-       {0x01, 0x12},   /* 0x12, RT_CHANNEL_DOMAIN_JAPAN_NO_DFS */
-       {0x00, 0x04},   /* 0x13, RT_CHANNEL_DOMAIN_WORLD_WIDE_5G */
-       {0x02, 0x10},   /* 0x14, RT_CHANNEL_DOMAIN_TAIWAN_NO_DFS */
-       {0x00, 0x12},   /* 0x15, RT_CHANNEL_DOMAIN_ETSI_NO_DFS */
-       {0x00, 0x13},   /* 0x16, RT_CHANNEL_DOMAIN_KOREA_NO_DFS */
-       {0x03, 0x12},   /* 0x17, RT_CHANNEL_DOMAIN_JAPAN_NO_DFS */
-       {0x05, 0x08},   /* 0x18, RT_CHANNEL_DOMAIN_PAKISTAN_NO_DFS */
-       {0x02, 0x08},   /* 0x19, RT_CHANNEL_DOMAIN_TAIWAN2_NO_DFS */
-       {0x00, 0x00},   /* 0x1A, */
-       {0x00, 0x00},   /* 0x1B, */
-       {0x00, 0x00},   /* 0x1C, */
-       {0x00, 0x00},   /* 0x1D, */
-       {0x00, 0x00},   /* 0x1E, */
-       {0x05, 0x04},   /* 0x1F, RT_CHANNEL_DOMAIN_WORLD_WIDE_ONLY_5G */
-       /*  0x20 ~ 0x7F , New Define ===== */
-       {0x00, 0x00},   /* 0x20, RT_CHANNEL_DOMAIN_WORLD_NULL */
-       {0x01, 0x00},   /* 0x21, RT_CHANNEL_DOMAIN_ETSI1_NULL */
-       {0x02, 0x00},   /* 0x22, RT_CHANNEL_DOMAIN_FCC1_NULL */
-       {0x03, 0x00},   /* 0x23, RT_CHANNEL_DOMAIN_MKK1_NULL */
-       {0x04, 0x00},   /* 0x24, RT_CHANNEL_DOMAIN_ETSI2_NULL */
-       {0x02, 0x04},   /* 0x25, RT_CHANNEL_DOMAIN_FCC1_FCC1 */
-       {0x00, 0x01},   /* 0x26, RT_CHANNEL_DOMAIN_WORLD_ETSI1 */
-       {0x03, 0x0C},   /* 0x27, RT_CHANNEL_DOMAIN_MKK1_MKK1 */
-       {0x00, 0x0B},   /* 0x28, RT_CHANNEL_DOMAIN_WORLD_KCC1 */
-       {0x00, 0x05},   /* 0x29, RT_CHANNEL_DOMAIN_WORLD_FCC2 */
-       {0x00, 0x00},   /* 0x2A, */
-       {0x00, 0x00},   /* 0x2B, */
-       {0x00, 0x00},   /* 0x2C, */
-       {0x00, 0x00},   /* 0x2D, */
-       {0x00, 0x00},   /* 0x2E, */
-       {0x00, 0x00},   /* 0x2F, */
-       {0x00, 0x06},   /* 0x30, RT_CHANNEL_DOMAIN_WORLD_FCC3 */
-       {0x00, 0x07},   /* 0x31, RT_CHANNEL_DOMAIN_WORLD_FCC4 */
-       {0x00, 0x08},   /* 0x32, RT_CHANNEL_DOMAIN_WORLD_FCC5 */
-       {0x00, 0x09},   /* 0x33, RT_CHANNEL_DOMAIN_WORLD_FCC6 */
-       {0x02, 0x0A},   /* 0x34, RT_CHANNEL_DOMAIN_FCC1_FCC7 */
-       {0x00, 0x02},   /* 0x35, RT_CHANNEL_DOMAIN_WORLD_ETSI2 */
-       {0x00, 0x03},   /* 0x36, RT_CHANNEL_DOMAIN_WORLD_ETSI3 */
-       {0x03, 0x0D},   /* 0x37, RT_CHANNEL_DOMAIN_MKK1_MKK2 */
-       {0x03, 0x0E},   /* 0x38, RT_CHANNEL_DOMAIN_MKK1_MKK3 */
-       {0x02, 0x0F},   /* 0x39, RT_CHANNEL_DOMAIN_FCC1_NCC1 */
-       {0x00, 0x00},   /* 0x3A, */
-       {0x00, 0x00},   /* 0x3B, */
-       {0x00, 0x00},   /* 0x3C, */
-       {0x00, 0x00},   /* 0x3D, */
-       {0x00, 0x00},   /* 0x3E, */
-       {0x00, 0x00},   /* 0x3F, */
-       {0x02, 0x10},   /* 0x40, RT_CHANNEL_DOMAIN_FCC1_NCC2 */
-       {0x03, 0x00},   /* 0x41, RT_CHANNEL_DOMAIN_GLOBAL_DOAMIN_2G */
-};
-
-static struct rt_channel_plan_map RTW_CHANNEL_PLAN_MAP_REALTEK_DEFINE =
-{0x03, 0x02}; /* use the conbination for max channel numbers */
-
-static void dummy_event_callback(struct rtw_adapter *adapter, const u8 *pbuf)
-{
-}
-
-static struct fwevent wlanevents[] =
-{
-       {0, &dummy_event_callback},     /*0*/
-       {0, NULL},
-       {0, NULL},
-       {0, NULL},
-       {0, NULL},
-       {0, NULL},
-       {0, NULL},
-       {0, NULL},
-       {0, &rtw_survey_event_cb23a},           /*8*/
-       {sizeof (struct surveydone_event), &rtw_surveydone_event_callback23a},
-       {0, &rtw23a_joinbss_event_cb},          /*10*/
-       {sizeof(struct stassoc_event), &rtw_stassoc_event_callback23a},
-       {sizeof(struct stadel_event), &rtw_stadel_event_callback23a},
-       {0, &dummy_event_callback},
-       {0, &dummy_event_callback},
-       {0, NULL},      /*15*/
-       {0, NULL},
-       {0, NULL},
-       {0, NULL},
-       {0, &dummy_event_callback},
-       {0, NULL},       /*20*/
-       {0, NULL},
-       {0, NULL},
-       {0, &dummy_event_callback},
-       {0, NULL},
-};
-
-
-static void rtw_correct_TSF(struct rtw_adapter *padapter)
-{
-       hw_var_set_correct_tsf(padapter);
-}
-
-static void
-rtw_update_TSF(struct mlme_ext_priv *pmlmeext, struct ieee80211_mgmt *mgmt)
-{
-       pmlmeext->TSFValue = get_unaligned_le64(&mgmt->u.beacon.timestamp);
-}
-
-/*
- * Search the @param channel_num in given @param channel_set
- * @ch_set: the given channel set
- * @ch: the given channel number
- *
- * return the index of channel_num in channel_set, -1 if not found
- */
-int rtw_ch_set_search_ch23a(struct rt_channel_info *ch_set, const u32 ch)
-{
-       int i;
-
-       for (i = 0; ch_set[i]. ChannelNum != 0; i++) {
-               if (ch == ch_set[i].ChannelNum)
-                       break;
-       }
-
-       if (i >= ch_set[i].ChannelNum)
-               return -1;
-       return i;
-}
-
-/****************************************************************************
-
-Following are the initialization functions for WiFi MLME
-
-*****************************************************************************/
-
-int init_hw_mlme_ext23a(struct rtw_adapter *padapter)
-{
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-
-       set_channel_bwmode23a(padapter, pmlmeext->cur_channel,
-                             pmlmeext->cur_ch_offset, pmlmeext->cur_bwmode);
-       return _SUCCESS;
-}
-
-static void init_mlme_ext_priv23a_value(struct rtw_adapter *padapter)
-{
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       unsigned char   mixed_datarate[NumRates] = {
-               _1M_RATE_, _2M_RATE_, _5M_RATE_, _11M_RATE_, _6M_RATE_,
-               _9M_RATE_, _12M_RATE_, _18M_RATE_, _24M_RATE_, _36M_RATE_,
-               _48M_RATE_, _54M_RATE_, 0xff};
-       unsigned char   mixed_basicrate[NumRates] = {
-               _1M_RATE_, _2M_RATE_, _5M_RATE_, _11M_RATE_, _6M_RATE_,
-               _12M_RATE_, _24M_RATE_, 0xff,};
-
-       atomic_set(&pmlmeext->event_seq, 0);
-       /* reset to zero when disconnect at client mode */
-       pmlmeext->mgnt_seq = 0;
-
-       pmlmeext->cur_channel = padapter->registrypriv.channel;
-       pmlmeext->cur_bwmode = HT_CHANNEL_WIDTH_20;
-       pmlmeext->cur_ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
-
-       pmlmeext->retry = 0;
-
-       pmlmeext->cur_wireless_mode = padapter->registrypriv.wireless_mode;
-
-       memcpy(pmlmeext->datarate, mixed_datarate, NumRates);
-       memcpy(pmlmeext->basicrate, mixed_basicrate, NumRates);
-
-       if (pmlmeext->cur_channel > 14)
-               pmlmeext->tx_rate = IEEE80211_OFDM_RATE_6MB;
-       else
-               pmlmeext->tx_rate = IEEE80211_CCK_RATE_1MB;
-
-       pmlmeext->sitesurvey_res.state = SCAN_DISABLE;
-       pmlmeext->sitesurvey_res.channel_idx = 0;
-       pmlmeext->sitesurvey_res.bss_cnt = 0;
-       pmlmeext->scan_abort = false;
-
-       pmlmeinfo->state = MSR_NOLINK;
-       pmlmeinfo->reauth_count = 0;
-       pmlmeinfo->reassoc_count = 0;
-       pmlmeinfo->link_count = 0;
-       pmlmeinfo->auth_seq = 0;
-       pmlmeinfo->auth_algo = dot11AuthAlgrthm_Open;
-       pmlmeinfo->key_index = 0;
-       pmlmeinfo->iv = 0;
-
-       pmlmeinfo->enc_algo = 0;
-       pmlmeinfo->authModeToggle = 0;
-
-       memset(pmlmeinfo->chg_txt, 0, 128);
-
-       pmlmeinfo->slotTime = SHORT_SLOT_TIME;
-       pmlmeinfo->preamble_mode = PREAMBLE_AUTO;
-
-       pmlmeinfo->dialogToken = 0;
-
-       pmlmeext->action_public_rxseq = 0xffff;
-       pmlmeext->action_public_dialog_token = 0xff;
-}
-
-static int has_channel(struct rt_channel_info *channel_set,
-                      u8 chanset_size, u8 chan) {
-       int i;
-
-       for (i = 0; i < chanset_size; i++) {
-               if (channel_set[i].ChannelNum == chan)
-                       return 1;
-       }
-
-       return 0;
-}
-
-static void init_channel_list(struct rtw_adapter *padapter,
-                             struct rt_channel_info *channel_set,
-                             u8 chanset_size,
-                             struct p2p_channels *channel_list)
-{
-       struct p2p_oper_class_map op_class[] = {
-               { IEEE80211G,  81,   1,  13,  1, BW20 },
-               { IEEE80211G,  82,  14,  14,  1, BW20 },
-               { IEEE80211A, 115,  36,  48,  4, BW20 },
-               { IEEE80211A, 116,  36,  44,  8, BW40PLUS },
-               { IEEE80211A, 117,  40,  48,  8, BW40MINUS },
-               { IEEE80211A, 124, 149, 161,  4, BW20 },
-               { IEEE80211A, 125, 149, 169,  4, BW20 },
-               { IEEE80211A, 126, 149, 157,  8, BW40PLUS },
-               { IEEE80211A, 127, 153, 161,  8, BW40MINUS },
-               { -1, 0, 0, 0, 0, BW20 }
-       };
-
-       int cla, op;
-
-       cla = 0;
-
-       for (op = 0; op_class[op].op_class; op++) {
-               u8 ch;
-               struct p2p_oper_class_map *o = &op_class[op];
-               struct p2p_reg_class *reg = NULL;
-
-               for (ch = o->min_chan; ch <= o->max_chan; ch += o->inc) {
-                       if (!has_channel(channel_set, chanset_size, ch))
-                               continue;
-
-                       if ((0 == padapter->registrypriv.ht_enable) &&
-                           (o->inc == 8))
-                               continue;
-
-                       if ((0 == (padapter->registrypriv.cbw40_enable & BIT(1))) &&
-                               ((BW40MINUS == o->bw) || (BW40PLUS == o->bw)))
-                               continue;
-
-                       if (reg == NULL) {
-                               reg = &channel_list->reg_class[cla];
-                               cla++;
-                               reg->reg_class = o->op_class;
-                               reg->channels = 0;
-                       }
-                       reg->channel[reg->channels] = ch;
-                       reg->channels++;
-               }
-       }
-       channel_list->reg_classes = cla;
-}
-
-static u8 init_channel_set(struct rtw_adapter *padapter, u8 cplan,
-                          struct rt_channel_info *c_set)
-{
-       u8 i, ch_size = 0;
-       u8 b5GBand = false, b2_4GBand = false;
-       u8 Index2G = 0, Index5G = 0;
-
-       memset(c_set, 0, sizeof(struct rt_channel_info) * MAX_CHANNEL_NUM);
-
-       if (cplan >= RT_CHANNEL_DOMAIN_MAX &&
-           cplan != RT_CHANNEL_DOMAIN_REALTEK_DEFINE) {
-               DBG_8723A("ChannelPlan ID %x error !!!!!\n", cplan);
-               return ch_size;
-       }
-
-       if (padapter->registrypriv.wireless_mode & WIRELESS_11G) {
-               b2_4GBand = true;
-               if (RT_CHANNEL_DOMAIN_REALTEK_DEFINE == cplan)
-                       Index2G = RTW_CHANNEL_PLAN_MAP_REALTEK_DEFINE.Index2G;
-               else
-                       Index2G = RTW_ChannelPlanMap[cplan].Index2G;
-       }
-
-       if (padapter->registrypriv.wireless_mode & WIRELESS_11A) {
-               b5GBand = true;
-               if (RT_CHANNEL_DOMAIN_REALTEK_DEFINE == cplan)
-                       Index5G = RTW_CHANNEL_PLAN_MAP_REALTEK_DEFINE.Index5G;
-               else
-                       Index5G = RTW_ChannelPlanMap[cplan].Index5G;
-       }
-
-       if (b2_4GBand) {
-               for (i = 0; i < RTW_ChannelPlan2G[Index2G].Len; i++) {
-                       c_set[ch_size].ChannelNum =
-                               RTW_ChannelPlan2G[Index2G].Channel[i];
-
-                       if ((RT_CHANNEL_DOMAIN_GLOBAL_DOAMIN == cplan) ||
-                           /* Channel 1~11 is active, and 12~14 is passive */
-                           RT_CHANNEL_DOMAIN_GLOBAL_DOAMIN_2G == cplan) {
-                               if (c_set[ch_size].ChannelNum >= 1 &&
-                                   c_set[ch_size].ChannelNum <= 11)
-                                       c_set[ch_size].ScanType = SCAN_ACTIVE;
-                               else if (c_set[ch_size].ChannelNum >= 12 &&
-                                        c_set[ch_size].ChannelNum  <= 14)
-                                       c_set[ch_size].ScanType = SCAN_PASSIVE;
-                       } else if (RT_CHANNEL_DOMAIN_WORLD_WIDE_13 == cplan ||
-                                  RT_CHANNEL_DOMAIN_WORLD_WIDE_5G == cplan ||
-                                  RT_CHANNEL_DOMAIN_2G_WORLD == Index2G) {
-                               /*  channel 12~13, passive scan */
-                               if (c_set[ch_size].ChannelNum <= 11)
-                                       c_set[ch_size].ScanType = SCAN_ACTIVE;
-                               else
-                                       c_set[ch_size].ScanType = SCAN_PASSIVE;
-                       } else
-                               c_set[ch_size].ScanType = SCAN_ACTIVE;
-
-                       ch_size++;
-               }
-       }
-
-       if (b5GBand) {
-               for (i = 0; i < RTW_ChannelPlan5G[Index5G].Len; i++) {
-                       if (RTW_ChannelPlan5G[Index5G].Channel[i] <= 48 ||
-                           RTW_ChannelPlan5G[Index5G].Channel[i] >= 149) {
-                               c_set[ch_size].ChannelNum =
-                                       RTW_ChannelPlan5G[Index5G].Channel[i];
-                               if (RT_CHANNEL_DOMAIN_WORLD_WIDE_5G == cplan) {
-                                       /* passive scan for all 5G channels */
-                                       c_set[ch_size].ScanType =
-                                               SCAN_PASSIVE;
-                               } else
-                                       c_set[ch_size].ScanType =
-                                               SCAN_ACTIVE;
-                               DBG_8723A("%s(): channel_set[%d].ChannelNum = "
-                                         "%d\n", __func__, ch_size,
-                                         c_set[ch_size].ChannelNum);
-                               ch_size++;
-                       }
-               }
-       }
-
-       return ch_size;
-}
-
-int init_mlme_ext_priv23a(struct rtw_adapter *padapter)
-{
-       struct registry_priv *pregistrypriv = &padapter->registrypriv;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-
-       pmlmeext->padapter = padapter;
-
-       init_mlme_ext_priv23a_value(padapter);
-       pmlmeinfo->bAcceptAddbaReq = pregistrypriv->bAcceptAddbaReq;
-
-       init_mlme_ext_timer23a(padapter);
-
-#ifdef CONFIG_8723AU_AP_MODE
-       init_mlme_ap_info23a(padapter);
-#endif
-
-       pmlmeext->max_chan_nums = init_channel_set(padapter,
-                                                  pmlmepriv->ChannelPlan,
-                                                  pmlmeext->channel_set);
-       init_channel_list(padapter, pmlmeext->channel_set,
-                         pmlmeext->max_chan_nums, &pmlmeext->channel_list);
-
-       pmlmeext->chan_scan_time = SURVEY_TO;
-       pmlmeext->mlmeext_init = true;
-
-       pmlmeext->active_keep_alive_check = true;
-       return _SUCCESS;
-}
-
-void free_mlme_ext_priv23a (struct mlme_ext_priv *pmlmeext)
-{
-       struct rtw_adapter *padapter = pmlmeext->padapter;
-
-       if (!padapter)
-               return;
-
-       if (padapter->bDriverStopped == true) {
-               del_timer_sync(&pmlmeext->survey_timer);
-               del_timer_sync(&pmlmeext->link_timer);
-               /* del_timer_sync(&pmlmeext->ADDBA_timer); */
-       }
-}
-
-static void
-_mgt_dispatcher23a(struct rtw_adapter *padapter, struct mlme_handler *ptable,
-                  struct recv_frame *precv_frame)
-{
-       struct sk_buff *skb = precv_frame->pkt;
-       struct ieee80211_hdr *hdr = (struct ieee80211_hdr *) skb->data;
-
-       if (ptable->func) {
-               /* receive the frames that ra(a1) is my address
-                  or ra(a1) is bc address. */
-               if (!ether_addr_equal(hdr->addr1, myid(&padapter->eeprompriv))&&
-                   !is_broadcast_ether_addr(hdr->addr1))
-                       return;
-
-               ptable->func(padapter, precv_frame);
-       }
-}
-
-void mgt_dispatcher23a(struct rtw_adapter *padapter,
-                   struct recv_frame *precv_frame)
-{
-       struct mlme_handler *ptable;
-#ifdef CONFIG_8723AU_AP_MODE
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-#endif /* CONFIG_8723AU_AP_MODE */
-       struct sk_buff *skb = precv_frame->pkt;
-       struct ieee80211_mgmt *mgmt = (struct ieee80211_mgmt *) skb->data;
-       struct sta_info *psta;
-       u16 stype;
-       int index;
-
-       if (!ieee80211_is_mgmt(mgmt->frame_control))
-               return;
-
-       /* receive the frames that ra(a1) is my address or ra(a1) is
-          bc address. */
-       if (!ether_addr_equal(mgmt->da, myid(&padapter->eeprompriv)) &&
-           !is_broadcast_ether_addr(mgmt->da))
-               return;
-
-       ptable = mlme_sta_tbl;
-
-       stype = le16_to_cpu(mgmt->frame_control) & IEEE80211_FCTL_STYPE;
-       index = stype >> 4;
-
-       if (index > 13) {
-               RT_TRACE(_module_rtl871x_mlme_c_, _drv_err_,
-                        "Currently we do not support reserved sub-fr-type =%d\n",
-                        index);
-               return;
-       }
-       ptable += index;
-
-       psta = rtw_get_stainfo23a(&padapter->stapriv, mgmt->sa);
-
-       if (psta) {
-               if (ieee80211_has_retry(mgmt->frame_control)) {
-                       if (precv_frame->attrib.seq_num ==
-                           psta->RxMgmtFrameSeqNum) {
-                               /* drop the duplicate management frame */
-                               DBG_8723A("Drop duplicate management frame "
-                                         "with seq_num = %d.\n",
-                                         precv_frame->attrib.seq_num);
-                               return;
-                       }
-               }
-               psta->RxMgmtFrameSeqNum = precv_frame->attrib.seq_num;
-       }
-
-#ifdef CONFIG_8723AU_AP_MODE
-       switch (stype) {
-       case IEEE80211_STYPE_AUTH:
-               if (check_fwstate(pmlmepriv, WIFI_AP_STATE))
-                       ptable->func = &OnAuth23a;
-               else
-                       ptable->func = &OnAuth23aClient23a;
-               /* pass through */
-       case IEEE80211_STYPE_ASSOC_REQ:
-       case IEEE80211_STYPE_REASSOC_REQ:
-               _mgt_dispatcher23a(padapter, ptable, precv_frame);
-               break;
-       case IEEE80211_STYPE_PROBE_REQ:
-               if (check_fwstate(pmlmepriv, WIFI_AP_STATE))
-                       _mgt_dispatcher23a(padapter, ptable, precv_frame);
-               else
-                       _mgt_dispatcher23a(padapter, ptable, precv_frame);
-               break;
-       case IEEE80211_STYPE_BEACON:
-               _mgt_dispatcher23a(padapter, ptable, precv_frame);
-               break;
-       case IEEE80211_STYPE_ACTION:
-               /* if (check_fwstate(pmlmepriv, WIFI_AP_STATE)) */
-               _mgt_dispatcher23a(padapter, ptable, precv_frame);
-               break;
-       default:
-               _mgt_dispatcher23a(padapter, ptable, precv_frame);
-               break;
-       }
-#else
-       _mgt_dispatcher23a(padapter, ptable, precv_frame);
-#endif
-}
-
-/****************************************************************************
-
-Following are the callback functions for each subtype of the management frames
-
-*****************************************************************************/
-
-static int
-OnProbeReq23a(struct rtw_adapter *padapter, struct recv_frame *precv_frame)
-{
-       const u8 *ie;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       struct wlan_bssid_ex *cur = &pmlmeinfo->network;
-       struct sk_buff *skb = precv_frame->pkt;
-       struct ieee80211_mgmt *mgmt = (struct ieee80211_mgmt *) skb->data;
-       int len = skb->len;
-
-       if (check_fwstate(pmlmepriv, WIFI_STATION_STATE))
-               return _SUCCESS;
-
-       if (!check_fwstate(pmlmepriv, _FW_LINKED) &&
-           !check_fwstate(pmlmepriv,
-                          WIFI_ADHOC_MASTER_STATE | WIFI_AP_STATE))
-               return _SUCCESS;
-
-       if (unlikely(!ieee80211_is_probe_req(mgmt->frame_control))) {
-               printk(KERN_WARNING "%s: Received non probe request frame\n",
-                      __func__);
-               return _FAIL;
-       }
-
-       len -= offsetof(struct ieee80211_mgmt, u.probe_req.variable);
-
-       ie = cfg80211_find_ie(WLAN_EID_SSID, mgmt->u.probe_req.variable, len);
-
-       /* check (wildcard) SSID */
-       if (!ie)
-               goto out;
-
-       if ((ie[1] && memcmp(ie + 2, cur->Ssid.ssid, cur->Ssid.ssid_len)) ||
-           (ie[1] == 0 && pmlmeinfo->hidden_ssid_mode)) {
-               return _SUCCESS;
-       }
-
-       if (check_fwstate(pmlmepriv, _FW_LINKED) &&
-           pmlmepriv->cur_network.join_res)
-               issue_probersp(padapter, mgmt->sa);
-
-out:
-       return _SUCCESS;
-}
-
-static int
-OnProbeRsp23a(struct rtw_adapter *padapter, struct recv_frame *precv_frame)
-{
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-
-       if (pmlmeext->sitesurvey_res.state == SCAN_PROCESS) {
-               report_survey_event23a(padapter, precv_frame);
-               return _SUCCESS;
-       }
-
-       return _SUCCESS;
-}
-
-static int
-OnBeacon23a(struct rtw_adapter *padapter, struct recv_frame *precv_frame)
-{
-       int cam_idx;
-       struct sta_info *psta;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct sta_priv *pstapriv = &padapter->stapriv;
-       struct sk_buff *skb = precv_frame->pkt;
-       struct ieee80211_mgmt *mgmt = (struct ieee80211_mgmt *) skb->data;
-       int pkt_len = skb->len;
-       struct wlan_bssid_ex *pbss;
-       int ret = _SUCCESS;
-       u8 *p, *pie;
-       int pie_len;
-       u32 ielen = 0;
-
-       pie = mgmt->u.beacon.variable;
-       pie_len = pkt_len - offsetof(struct ieee80211_mgmt, u.beacon.variable);
-       p = rtw_get_ie23a(pie, WLAN_EID_EXT_SUPP_RATES, &ielen, pie_len);
-       if (p && ielen > 0) {
-               if (p[1 + ielen] == 0x2D && p[2 + ielen] != 0x2D) {
-                       /* Invalid value 0x2D is detected in Extended Supported
-                        * Rates (ESR) IE. Try to fix the IE length to avoid
-                        * failed Beacon parsing.
-                        */
-                       DBG_8723A("[WIFIDBG] Error in ESR IE is detected in "
-                                 "Beacon of BSSID: %pM. Fix the length of "
-                                 "ESR IE to avoid failed Beacon parsing.\n",
-                                 mgmt->bssid);
-                       p[1] = ielen - 1;
-               }
-       }
-
-       if (pmlmeext->sitesurvey_res.state == SCAN_PROCESS) {
-               report_survey_event23a(padapter, precv_frame);
-               return _SUCCESS;
-       }
-
-       if (!ether_addr_equal(mgmt->bssid,
-                             get_my_bssid23a(&pmlmeinfo->network)))
-               goto out;
-
-       if (pmlmeinfo->state & WIFI_FW_AUTH_NULL) {
-               /* we should update current network before auth,
-                  or some IE is wrong */
-               pbss = collect_bss_info(padapter, precv_frame);
-               if (pbss) {
-                       update_network23a(&pmlmepriv->cur_network.network, pbss,
-                                         padapter, true);
-                       rtw_get_bcn_info23a(&pmlmepriv->cur_network);
-                       kfree(pbss);
-               }
-
-               /* check the vendor of the assoc AP */
-               pmlmeinfo->assoc_AP_vendor =
-                       check_assoc_AP23a((u8 *)&mgmt->u.beacon, pkt_len -
-                                         offsetof(struct ieee80211_mgmt, u));
-
-               /* update TSF Value */
-               rtw_update_TSF(pmlmeext, mgmt);
-
-               /* start auth */
-               start_clnt_auth(padapter);
-
-               return _SUCCESS;
-       }
-
-       if (((pmlmeinfo->state & 0x03) == MSR_AP) &&
-           (pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS)) {
-               psta = rtw_get_stainfo23a(pstapriv, mgmt->sa);
-               if (psta) {
-                       ret = rtw_check_bcn_info23a(padapter, mgmt, pkt_len);
-                       if (ret != _SUCCESS) {
-                               DBG_8723A_LEVEL(_drv_always_, "ap has changed, "
-                                               "disconnect now\n");
-                               receive_disconnect23a(padapter, pmlmeinfo->network.MacAddress, 65535);
-                               return _SUCCESS;
-                       }
-                       /* update WMM, ERP in the beacon */
-                       /* todo: the timer is used instead of
-                          the number of the beacon received */
-                       if ((sta_rx_pkts(psta) & 0xf) == 0) {
-                               /* DBG_8723A("update_bcn_info\n"); */
-                               update_beacon23a_info(padapter, mgmt,
-                                                     pkt_len, psta);
-                       }
-               }
-       } else if ((pmlmeinfo->state&0x03) == MSR_ADHOC) {
-               psta = rtw_get_stainfo23a(pstapriv, mgmt->sa);
-               if (psta) {
-                       /* update WMM, ERP in the beacon */
-                       /* todo: the timer is used instead of the
-                          number of the beacon received */
-                       if ((sta_rx_pkts(psta) & 0xf) == 0) {
-                               /* DBG_8723A("update_bcn_info\n"); */
-                               update_beacon23a_info(padapter, mgmt,
-                                                     pkt_len, psta);
-                       }
-               } else {
-                       /* allocate a new CAM entry for IBSS station */
-                       cam_idx = allocate_fw_sta_entry23a(padapter);
-                       if (cam_idx == NUM_STA)
-                               goto out;
-
-                       /* get supported rate */
-                       if (update_sta_support_rate23a(padapter, pie, pie_len,
-                                                      cam_idx) == _FAIL) {
-                               pmlmeinfo->FW_sta_info[cam_idx].status = 0;
-                               goto out;
-                       }
-
-                       /* update TSF Value */
-                       rtw_update_TSF(pmlmeext, mgmt);
-
-                       /* report sta add event */
-                       report_add_sta_event23a(padapter, mgmt->sa,
-                                               cam_idx);
-               }
-       }
-
-out:
-
-       return _SUCCESS;
-}
-
-#ifdef CONFIG_8723AU_AP_MODE
-static int
-OnAuth23a(struct rtw_adapter *padapter, struct recv_frame *precv_frame)
-{
-       static struct sta_info stat;
-       struct sta_info *pstat = NULL;
-       struct sta_priv *pstapriv = &padapter->stapriv;
-       struct security_priv *psecuritypriv = &padapter->securitypriv;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       struct sk_buff *skb = precv_frame->pkt;
-       struct ieee80211_mgmt *mgmt = (struct ieee80211_mgmt *) skb->data;
-       u8 *pframe;
-       const u8 *p;
-       unsigned char *sa;
-       u16 auth_mode, seq, algorithm;
-       int status, len = skb->len;
-
-       if ((pmlmeinfo->state & 0x03) != MSR_AP)
-               return _FAIL;
-
-       DBG_8723A("+OnAuth23a\n");
-
-       sa = mgmt->sa;
-
-       auth_mode = psecuritypriv->dot11AuthAlgrthm;
-
-       pframe = mgmt->u.auth.variable;
-       len = skb->len - offsetof(struct ieee80211_mgmt, u.auth.variable);
-
-       seq = le16_to_cpu(mgmt->u.auth.auth_transaction);
-       algorithm = le16_to_cpu(mgmt->u.auth.auth_alg);
-
-       DBG_8723A("auth alg =%x, seq =%X\n", algorithm, seq);
-
-       if (auth_mode == 2 &&
-           psecuritypriv->dot11PrivacyAlgrthm != WLAN_CIPHER_SUITE_WEP40 &&
-           psecuritypriv->dot11PrivacyAlgrthm != WLAN_CIPHER_SUITE_WEP104)
-               auth_mode = 0;
-
-       /*  rx a shared-key auth but shared not enabled, or */
-       /*  rx a open-system auth but shared-key is enabled */
-       if ((algorithm != WLAN_AUTH_OPEN && auth_mode == 0) ||
-           (algorithm == WLAN_AUTH_OPEN && auth_mode == 1)) {
-               DBG_8723A("auth rejected due to bad alg [alg =%d, auth_mib "
-                         "=%d] %02X%02X%02X%02X%02X%02X\n",
-                         algorithm, auth_mode,
-                         sa[0], sa[1], sa[2], sa[3], sa[4], sa[5]);
-
-               status = WLAN_STATUS_NOT_SUPPORTED_AUTH_ALG;
-
-               goto auth_fail;
-       }
-
-       if (rtw_access_ctrl23a(padapter, sa) == false) {
-               status = WLAN_STATUS_AP_UNABLE_TO_HANDLE_NEW_STA;
-               goto auth_fail;
-       }
-
-       pstat = rtw_get_stainfo23a(pstapriv, sa);
-       if (!pstat) {
-               /*  allocate a new one */
-               DBG_8723A("going to alloc stainfo for sa =%pM\n", sa);
-               pstat = rtw_alloc_stainfo23a(pstapriv, sa, GFP_ATOMIC);
-               if (!pstat) {
-                       DBG_8723A(" Exceed the upper limit of supported "
-                                 "clients...\n");
-                       status = WLAN_STATUS_AP_UNABLE_TO_HANDLE_NEW_STA;
-                       goto auth_fail;
-               }
-
-               pstat->state = WIFI_FW_AUTH_NULL;
-               pstat->auth_seq = 0;
-
-               /* pstat->flags = 0; */
-               /* pstat->capability = 0; */
-       } else {
-               spin_lock_bh(&pstapriv->asoc_list_lock);
-               if (!list_empty(&pstat->asoc_list)) {
-                       list_del_init(&pstat->asoc_list);
-                       pstapriv->asoc_list_cnt--;
-                       if (pstat->expire_to > 0) {
-                               /* TODO: STA re_auth within expire_to */
-                       }
-               }
-               spin_unlock_bh(&pstapriv->asoc_list_lock);
-
-               if (seq == 1) {
-                       /* TODO: STA re_auth and auth timeout */
-               }
-       }
-
-       spin_lock_bh(&pstapriv->auth_list_lock);
-       if (list_empty(&pstat->auth_list)) {
-               list_add_tail(&pstat->auth_list, &pstapriv->auth_list);
-               pstapriv->auth_list_cnt++;
-       }
-       spin_unlock_bh(&pstapriv->auth_list_lock);
-
-       if (pstat->auth_seq == 0)
-               pstat->expire_to = pstapriv->auth_to;
-
-       if ((pstat->auth_seq + 1) != seq) {
-               DBG_8723A("(1)auth rejected because out of seq [rx_seq =%d, "
-                         "exp_seq =%d]!\n", seq, pstat->auth_seq+1);
-               status = WLAN_STATUS_UNKNOWN_AUTH_TRANSACTION;
-               goto auth_fail;
-       }
-
-       if (algorithm == WLAN_AUTH_OPEN && (auth_mode == 0 || auth_mode == 2)) {
-               if (seq == 1) {
-                       pstat->state &= ~WIFI_FW_AUTH_NULL;
-                       pstat->state |= WIFI_FW_AUTH_SUCCESS;
-                       pstat->expire_to = pstapriv->assoc_to;
-                       pstat->authalg = algorithm;
-               } else {
-                       DBG_8723A("(2)auth rejected because out of seq "
-                                 "[rx_seq =%d, exp_seq =%d]!\n",
-                                 seq, pstat->auth_seq+1);
-                       status = WLAN_STATUS_UNKNOWN_AUTH_TRANSACTION;
-                       goto auth_fail;
-               }
-       } else { /*  shared system or auto authentication */
-               if (seq == 1) {
-                       /* prepare for the challenging txt... */
-                       pstat->state &= ~WIFI_FW_AUTH_NULL;
-                       pstat->state |= WIFI_FW_AUTH_STATE;
-                       pstat->authalg = algorithm;
-                       pstat->auth_seq = 2;
-               } else if (seq == 3) {
-                       /* checking for challenging txt... */
-                       DBG_8723A("checking for challenging txt...\n");
-
-                       p = cfg80211_find_ie(WLAN_EID_CHALLENGE, pframe, len);
-                       if (!p || p[1] <= 0) {
-                               DBG_8723A("auth rejected because challenge "
-                                         "failure!(1)\n");
-                               status = WLAN_STATUS_CHALLENGE_FAIL;
-                               goto auth_fail;
-                       }
-
-                       if (!memcmp(p + 2, pstat->chg_txt, 128)) {
-                               pstat->state &= ~WIFI_FW_AUTH_STATE;
-                               pstat->state |= WIFI_FW_AUTH_SUCCESS;
-                               /*  challenging txt is correct... */
-                               pstat->expire_to =  pstapriv->assoc_to;
-                       } else {
-                               DBG_8723A("auth rejected because challenge "
-                                         "failure!\n");
-                               status = WLAN_STATUS_CHALLENGE_FAIL;
-                               goto auth_fail;
-                       }
-               } else {
-                       DBG_8723A("(3)auth rejected because out of seq "
-                                 "[rx_seq =%d, exp_seq =%d]!\n",
-                                 seq, pstat->auth_seq+1);
-                       status = WLAN_STATUS_UNKNOWN_AUTH_TRANSACTION;
-                       goto auth_fail;
-               }
-       }
-
-       /*  Now, we are going to issue_auth... */
-       pstat->auth_seq = seq + 1;
-
-       issue_auth(padapter, pstat, WLAN_STATUS_SUCCESS);
-
-       if (pstat->state & WIFI_FW_AUTH_SUCCESS)
-               pstat->auth_seq = 0;
-
-       return _SUCCESS;
-
-auth_fail:
-
-       if (pstat)
-               rtw_free_stainfo23a(padapter, pstat);
-
-       pstat = &stat;
-       memset((char *)pstat, '\0', sizeof(stat));
-       pstat->auth_seq = 2;
-       ether_addr_copy(pstat->hwaddr, sa);
-
-       issue_auth(padapter, pstat, (unsigned short)status);
-
-       return _FAIL;
-}
-#endif
-
-static int
-OnAuth23aClient23a(struct rtw_adapter *padapter, struct recv_frame *precv_frame)
-{
-       unsigned int seq, status, algthm;
-       unsigned int go2asoc = 0;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       struct sk_buff *skb = precv_frame->pkt;
-       struct ieee80211_mgmt *mgmt = (struct ieee80211_mgmt *) skb->data;
-       const u8 *p;
-       u8 *pie;
-       int plen = skb->len;
-
-       DBG_8723A("%s\n", __func__);
-
-       /* check A1 matches or not */
-       if (!ether_addr_equal(myid(&padapter->eeprompriv), mgmt->da))
-               return _SUCCESS;
-
-       if (!(pmlmeinfo->state & WIFI_FW_AUTH_STATE))
-               return _SUCCESS;
-
-       pie = mgmt->u.auth.variable;
-       plen -= offsetof(struct ieee80211_mgmt, u.auth.variable);
-
-       algthm = le16_to_cpu(mgmt->u.auth.auth_alg);
-       seq = le16_to_cpu(mgmt->u.auth.auth_transaction);
-       status = le16_to_cpu(mgmt->u.auth.status_code);
-
-       if (status) {
-               DBG_8723A("clnt auth fail, status: %d\n", status);
-               /*  pmlmeinfo->auth_algo == dot11AuthAlgrthm_Auto) */
-               if (status == WLAN_STATUS_NOT_SUPPORTED_AUTH_ALG) {
-                       if (pmlmeinfo->auth_algo == dot11AuthAlgrthm_Shared)
-                               pmlmeinfo->auth_algo = dot11AuthAlgrthm_Open;
-                       else
-                               pmlmeinfo->auth_algo = dot11AuthAlgrthm_Shared;
-                       /* pmlmeinfo->reauth_count = 0; */
-               }
-
-               set_link_timer(pmlmeext, 1);
-               goto authclnt_fail;
-       }
-
-       if (seq == 2) {
-               if (pmlmeinfo->auth_algo == dot11AuthAlgrthm_Shared) {
-                       /*  legendary shared system */
-                       p = cfg80211_find_ie(WLAN_EID_CHALLENGE, pie, plen);
-
-                       if (!p) {
-                               /* DBG_8723A("marc: no challenge text?\n"); */
-                               goto authclnt_fail;
-                       }
-
-                       memcpy((void *)(pmlmeinfo->chg_txt), p + 2, p[1]);
-                       pmlmeinfo->auth_seq = 3;
-                       issue_auth(padapter, NULL, 0);
-                       set_link_timer(pmlmeext, REAUTH_TO);
-
-                       return _SUCCESS;
-               } else {
-                       /*  open system */
-                       go2asoc = 1;
-               }
-       } else if (seq == 4) {
-               if (pmlmeinfo->auth_algo == dot11AuthAlgrthm_Shared)
-                       go2asoc = 1;
-               else
-                       goto authclnt_fail;
-       } else {
-               /*  this is also illegal */
-               /* DBG_8723A("marc: clnt auth failed due to illegal seq =%x\n",
-                  seq); */
-               goto authclnt_fail;
-       }
-
-       if (go2asoc) {
-               DBG_8723A_LEVEL(_drv_always_, "auth success, start assoc\n");
-               start_clnt_assoc(padapter);
-               return _SUCCESS;
-       }
-
-authclnt_fail:
-
-       /* pmlmeinfo->state &= ~(WIFI_FW_AUTH_STATE); */
-
-       return _FAIL;
-}
-
-#ifdef CONFIG_8723AU_AP_MODE
-static int rtw_validate_vendor_specific_ies(const u8 *pos, int elen)
-{
-       unsigned int oui;
-
-       /* first 3 bytes in vendor specific information element are the IEEE
-        * OUI of the vendor. The following byte is used a vendor specific
-        * sub-type. */
-       if (elen < 4) {
-               DBG_8723A("short vendor specific information element "
-                         "ignored (len =%i)\n", elen);
-               return -EINVAL;
-       }
-
-       oui = RTW_GET_BE24(pos);
-       switch (oui) {
-       case WLAN_OUI_MICROSOFT:
-               /* Microsoft/Wi-Fi information elements are further typed and
-                * subtyped */
-               switch (pos[3]) {
-               case WLAN_OUI_TYPE_MICROSOFT_WPA:
-                       /* Microsoft OUI (00:50:F2) with OUI Type 1:
-                        * real WPA information element */
-                       break;
-               case WLAN_OUI_TYPE_MICROSOFT_WMM:
-                       if (elen < 5) {
-                               DBG_8723A("short WME information element "
-                                         "ignored (len =%i)\n", elen);
-                               return -EINVAL;
-                       }
-                       switch (pos[4]) {
-                       case WME_OUI_SUBTYPE_INFORMATION_ELEMENT:
-                       case WME_OUI_SUBTYPE_PARAMETER_ELEMENT:
-                               break;
-                       case WME_OUI_SUBTYPE_TSPEC_ELEMENT:
-                               break;
-                       default:
-                               DBG_8723A("unknown WME information element "
-                                         "ignored (subtype =%d len =%i)\n",
-                                          pos[4], elen);
-                               return -EINVAL;
-                       }
-                       break;
-               case WLAN_OUI_TYPE_MICROSOFT_WPS:
-                       /* Wi-Fi Protected Setup (WPS) IE */
-                       break;
-               default:
-                       DBG_8723A("Unknown Microsoft information element "
-                                 "ignored (type =%d len =%i)\n",
-                                 pos[3], elen);
-                       return -EINVAL;
-               }
-               break;
-
-       case OUI_BROADCOM:
-               switch (pos[3]) {
-               case VENDOR_HT_CAPAB_OUI_TYPE:
-                       break;
-               default:
-                       DBG_8723A("Unknown Broadcom information element "
-                                 "ignored (type =%d len =%i)\n", pos[3], elen);
-                       return -EINVAL;
-               }
-               break;
-
-       default:
-               DBG_8723A("unknown vendor specific information element "
-                         "ignored (vendor OUI %02x:%02x:%02x len =%i)\n",
-                          pos[0], pos[1], pos[2], elen);
-               return -EINVAL;
-       }
-
-       return 0;
-}
-
-static int rtw_validate_frame_ies(const u8 *start, uint len)
-{
-       const u8 *pos = start;
-       int left = len;
-       int unknown = 0;
-
-       while (left >= 2) {
-               u8 id, elen;
-
-               id = *pos++;
-               elen = *pos++;
-               left -= 2;
-
-               if (elen > left) {
-                       DBG_8723A("%s: IEEE 802.11 failed (id =%d elen =%d "
-                                 "left =%i)\n", __func__, id, elen, left);
-                       return -EINVAL;
-               }
-
-               switch (id) {
-               case WLAN_EID_SSID:
-               case WLAN_EID_SUPP_RATES:
-               case WLAN_EID_FH_PARAMS:
-               case WLAN_EID_DS_PARAMS:
-               case WLAN_EID_CF_PARAMS:
-               case WLAN_EID_TIM:
-               case WLAN_EID_IBSS_PARAMS:
-               case WLAN_EID_CHALLENGE:
-               case WLAN_EID_ERP_INFO:
-               case WLAN_EID_EXT_SUPP_RATES:
-                       break;
-               case WLAN_EID_VENDOR_SPECIFIC:
-                       if (rtw_validate_vendor_specific_ies(pos, elen))
-                               unknown++;
-                       break;
-               case WLAN_EID_RSN:
-               case WLAN_EID_PWR_CAPABILITY:
-               case WLAN_EID_SUPPORTED_CHANNELS:
-               case WLAN_EID_MOBILITY_DOMAIN:
-               case WLAN_EID_FAST_BSS_TRANSITION:
-               case WLAN_EID_TIMEOUT_INTERVAL:
-               case WLAN_EID_HT_CAPABILITY:
-               case WLAN_EID_HT_OPERATION:
-               default:
-                       unknown++;
-                       DBG_8723A("%s IEEE 802.11 ignored unknown element "
-                                 "(id =%d elen =%d)\n", __func__, id, elen);
-                       break;
-               }
-
-               left -= elen;
-               pos += elen;
-       }
-
-       if (left)
-               return -EINVAL;
-
-       return 0;
-}
-#endif
-
-static int
-OnAssocReq23a(struct rtw_adapter *padapter, struct recv_frame *precv_frame)
-{
-#ifdef CONFIG_8723AU_AP_MODE
-       u16 capab_info, listen_interval;
-       struct sta_info *pstat;
-       unsigned char reassoc;
-       int i, wpa_ie_len, left;
-       unsigned char supportRate[16];
-       int supportRateNum;
-       unsigned short status = WLAN_STATUS_SUCCESS;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct security_priv *psecuritypriv = &padapter->securitypriv;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       struct wlan_bssid_ex *cur = &pmlmeinfo->network;
-       struct sta_priv *pstapriv = &padapter->stapriv;
-       struct sk_buff *skb = precv_frame->pkt;
-       struct ieee80211_mgmt *mgmt = (struct ieee80211_mgmt *) skb->data;
-       const u8 *pos, *p, *wpa_ie, *wps_ie;
-       u8 *pframe = skb->data;
-       uint pkt_len = skb->len;
-       int r;
-
-       if ((pmlmeinfo->state & 0x03) != MSR_AP)
-               return _FAIL;
-
-       left = pkt_len - sizeof(struct ieee80211_hdr_3addr);
-       if (ieee80211_is_assoc_req(mgmt->frame_control)) {
-               reassoc = 0;
-               pos = mgmt->u.assoc_req.variable;
-               left -= offsetof(struct ieee80211_mgmt, u.assoc_req.variable);
-       } else { /*  WIFI_REASSOCREQ */
-               reassoc = 1;
-               pos = mgmt->u.reassoc_req.variable;
-               left -= offsetof(struct ieee80211_mgmt, u.reassoc_req.variable);
-       }
-
-       if (left < 0) {
-               DBG_8723A("handle_assoc(reassoc =%d) - too short payload "
-                         "(len =%lu)\n", reassoc, (unsigned long)pkt_len);
-               return _FAIL;
-       }
-
-       pstat = rtw_get_stainfo23a(pstapriv, mgmt->sa);
-       if (!pstat) {
-               status = WLAN_REASON_CLASS2_FRAME_FROM_NONAUTH_STA;
-               goto asoc_class2_error;
-       }
-
-       /* These two are located at the same offsets whether it's an
-        * assoc_req or a reassoc_req */
-       capab_info = get_unaligned_le16(&mgmt->u.assoc_req.capab_info);
-       listen_interval =
-               get_unaligned_le16(&mgmt->u.assoc_req.listen_interval);
-
-       DBG_8723A("%s\n", __func__);
-
-       /*  check if this stat has been successfully authenticated/assocated */
-       if (!(pstat->state & WIFI_FW_AUTH_SUCCESS)) {
-               if (!(pstat->state & WIFI_FW_ASSOC_SUCCESS)) {
-                       status = WLAN_REASON_CLASS2_FRAME_FROM_NONAUTH_STA;
-                       goto asoc_class2_error;
-               } else {
-                       pstat->state &= (~WIFI_FW_ASSOC_SUCCESS);
-                       pstat->state |= WIFI_FW_ASSOC_STATE;
-               }
-       } else {
-               pstat->state &= (~WIFI_FW_AUTH_SUCCESS);
-               pstat->state |= WIFI_FW_ASSOC_STATE;
-       }
-
-       pstat->capability = capab_info;
-
-       /* now parse all ieee802_11 ie to point to elems */
-
-       if (rtw_validate_frame_ies(pos, left)) {
-               DBG_8723A("STA %pM sent invalid association request\n",
-                         pstat->hwaddr);
-               status = WLAN_STATUS_UNSPECIFIED_FAILURE;
-               goto OnAssocReq23aFail;
-       }
-
-       /*  now we should check all the fields... */
-       /*  checking SSID */
-       p = cfg80211_find_ie(WLAN_EID_SSID, pos, left);
-       if (!p || p[1] == 0) {
-               /*  broadcast ssid, however it is not allowed in assocreq */
-               DBG_8723A("STA %pM sent invalid association request lacking an SSID\n",
-                         pstat->hwaddr);
-               status = WLAN_STATUS_UNSPECIFIED_FAILURE;
-               goto OnAssocReq23aFail;
-       } else {
-               /*  check if ssid match */
-               if (memcmp(p + 2, cur->Ssid.ssid, cur->Ssid.ssid_len))
-                       status = WLAN_STATUS_UNSPECIFIED_FAILURE;
-
-               if (p[1] != cur->Ssid.ssid_len)
-                       status = WLAN_STATUS_UNSPECIFIED_FAILURE;
-       }
-
-       if (status != WLAN_STATUS_SUCCESS)
-               goto OnAssocReq23aFail;
-
-       /*  check if the supported rate is ok */
-       p = cfg80211_find_ie(WLAN_EID_SUPP_RATES, pos, left);
-       if (!p) {
-               DBG_8723A("Rx a sta assoc-req which supported rate is "
-                         "empty!\n");
-               /*  use our own rate set as statoin used */
-               /* memcpy(supportRate, AP_BSSRATE, AP_BSSRATE_LEN); */
-               /* supportRateNum = AP_BSSRATE_LEN; */
-
-               status = WLAN_STATUS_UNSPECIFIED_FAILURE;
-               goto OnAssocReq23aFail;
-       } else {
-               memcpy(supportRate, p + 2, p[1]);
-               supportRateNum = p[1];
-
-               p = cfg80211_find_ie(WLAN_EID_EXT_SUPP_RATES, pos, left);
-               if (p) {
-                       if (supportRateNum <= sizeof(supportRate)) {
-                               memcpy(supportRate+supportRateNum, p + 2, p[1]);
-                               supportRateNum += p[1];
-                       }
-               }
-       }
-
-       /* todo: mask supportRate between AP & STA -> move to update raid */
-       /* get_matched_rate(pmlmeext, supportRate, &supportRateNum, 0); */
-
-       /* update station supportRate */
-       pstat->bssratelen = supportRateNum;
-       memcpy(pstat->bssrateset, supportRate, supportRateNum);
-       Update23aTblForSoftAP(pstat->bssrateset, pstat->bssratelen);
-
-       /* check RSN/WPA/WPS */
-       pstat->dot8021xalg = 0;
-       pstat->wpa_psk = 0;
-       pstat->wpa_group_cipher = 0;
-       pstat->wpa2_group_cipher = 0;
-       pstat->wpa_pairwise_cipher = 0;
-       pstat->wpa2_pairwise_cipher = 0;
-       memset(pstat->wpa_ie, 0, sizeof(pstat->wpa_ie));
-
-       wpa_ie = cfg80211_find_ie(WLAN_EID_RSN, pos, left);
-       if (!wpa_ie)
-               wpa_ie = cfg80211_find_vendor_ie(WLAN_OUI_MICROSOFT,
-                                                WLAN_OUI_TYPE_MICROSOFT_WPA,
-                                                pos, left);
-       if (wpa_ie) {
-               int group_cipher = 0, pairwise_cipher = 0;
-
-               wpa_ie_len = wpa_ie[1];
-               if (psecuritypriv->wpa_psk & BIT(1)) {
-                       r = rtw_parse_wpa2_ie23a(wpa_ie, wpa_ie_len + 2,
-                                                &group_cipher,
-                                                &pairwise_cipher, NULL);
-                       if (r == _SUCCESS) {
-                               pstat->dot8021xalg = 1;/* psk,  todo:802.1x */
-                               pstat->wpa_psk |= BIT(1);
-
-                               pstat->wpa2_group_cipher = group_cipher &
-                                       psecuritypriv->wpa2_group_cipher;
-                               pstat->wpa2_pairwise_cipher = pairwise_cipher &
-                                       psecuritypriv->wpa2_pairwise_cipher;
-                       } else
-                               status = WLAN_STATUS_INVALID_IE;
-               } else if (psecuritypriv->wpa_psk & BIT(0)) {
-                       r = rtw_parse_wpa_ie23a(wpa_ie, wpa_ie_len + 2,
-                                               &group_cipher, &pairwise_cipher,
-                                               NULL);
-                       if (r == _SUCCESS) {
-                               pstat->dot8021xalg = 1;/* psk,  todo:802.1x */
-                               pstat->wpa_psk |= BIT(0);
-
-                               pstat->wpa_group_cipher = group_cipher &
-                                       psecuritypriv->wpa_group_cipher;
-                               pstat->wpa_pairwise_cipher = pairwise_cipher &
-                                       psecuritypriv->wpa_pairwise_cipher;
-                       } else
-                               status = WLAN_STATUS_INVALID_IE;
-               } else {
-                       wpa_ie = NULL;
-                       wpa_ie_len = 0;
-               }
-               if (wpa_ie && status == WLAN_STATUS_SUCCESS) {
-                       if (!pstat->wpa_group_cipher)
-                               status = WLAN_STATUS_INVALID_GROUP_CIPHER;
-
-                       if (!pstat->wpa_pairwise_cipher)
-                               status = WLAN_STATUS_INVALID_PAIRWISE_CIPHER;
-               }
-       }
-
-       if (status != WLAN_STATUS_SUCCESS)
-               goto OnAssocReq23aFail;
-
-       pstat->flags &= ~(WLAN_STA_WPS | WLAN_STA_MAYBE_WPS);
-
-       wps_ie = cfg80211_find_vendor_ie(WLAN_OUI_MICROSOFT,
-                                        WLAN_OUI_TYPE_MICROSOFT_WPS,
-                                        pos, left);
-
-       if (!wpa_ie) {
-               if (wps_ie) {
-                       DBG_8723A("STA included WPS IE in (Re)Association "
-                                 "Request - assume WPS is used\n");
-                       pstat->flags |= WLAN_STA_WPS;
-               } else {
-                       DBG_8723A("STA did not include WPA/RSN IE in (Re)"
-                                  "Association Request - possible WPS use\n");
-                       pstat->flags |= WLAN_STA_MAYBE_WPS;
-               }
-       } else {
-               int copy_len;
-
-               if (psecuritypriv->wpa_psk == 0) {
-                       DBG_8723A("STA %pM: WPA/RSN IE in association request, but AP don't support WPA/RSN\n",
-                                 pstat->hwaddr);
-
-                       status = WLAN_STATUS_INVALID_IE;
-
-                       goto OnAssocReq23aFail;
-               }
-
-               if (wps_ie) {
-                       DBG_8723A("STA included WPS IE in (Re)Association "
-                                 "Request - WPS is used\n");
-                       pstat->flags |= WLAN_STA_WPS;
-                       copy_len = 0;
-               } else {
-                       copy_len = ((wpa_ie_len + 2) > sizeof(pstat->wpa_ie)) ?
-                               sizeof(pstat->wpa_ie) : (wpa_ie_len + 2);
-               }
-
-               if (copy_len > 0)
-                       memcpy(pstat->wpa_ie, wpa_ie - 2, copy_len);
-       }
-
-       /*  check if there is WMM IE & support WWM-PS */
-       pstat->flags &= ~WLAN_STA_WME;
-       pstat->qos_option = 0;
-       pstat->qos_info = 0;
-       pstat->has_legacy_ac = true;
-       pstat->uapsd_vo = 0;
-       pstat->uapsd_vi = 0;
-       pstat->uapsd_be = 0;
-       pstat->uapsd_bk = 0;
-       if (pmlmepriv->qos_option) {
-               const u8 *end = pos + left;
-
-               p = pos;
-
-               for (;;) {
-                       left = end - p;
-                       p = cfg80211_find_vendor_ie(WLAN_OUI_MICROSOFT,
-                                                   WLAN_OUI_TYPE_MICROSOFT_WMM,
-                                                   p, left);
-                       if (p) {
-                               pstat->flags |= WLAN_STA_WME;
-
-                               pstat->qos_option = 1;
-                               pstat->qos_info = *(p + 8);
-
-                               pstat->max_sp_len =
-                                       (pstat->qos_info >> 5) & 0x3;
-
-                               if ((pstat->qos_info & 0xf) != 0xf)
-                                       pstat->has_legacy_ac = true;
-                               else
-                                       pstat->has_legacy_ac = false;
-
-                               if (pstat->qos_info & 0xf) {
-                                       if (pstat->qos_info & BIT(0))
-                                               pstat->uapsd_vo = BIT(0)|BIT(1);
-                                       else
-                                               pstat->uapsd_vo = 0;
-
-                                       if (pstat->qos_info & BIT(1))
-                                               pstat->uapsd_vi = BIT(0)|BIT(1);
-                                       else
-                                               pstat->uapsd_vi = 0;
-
-                                       if (pstat->qos_info & BIT(2))
-                                               pstat->uapsd_bk = BIT(0)|BIT(1);
-                                       else
-                                               pstat->uapsd_bk = 0;
-
-                                       if (pstat->qos_info & BIT(3))
-                                               pstat->uapsd_be = BIT(0)|BIT(1);
-                                       else
-                                               pstat->uapsd_be = 0;
-
-                                       break;
-                               }
-                       } else {
-                               break;
-                       }
-                       p = p + p[1] + 2;
-               }
-       }
-
-       /* save HT capabilities in the sta object */
-       memset(&pstat->htpriv.ht_cap, 0, sizeof(struct ieee80211_ht_cap));
-       p = cfg80211_find_ie(WLAN_EID_HT_CAPABILITY, pos, left);
-
-       if (p && p[1] >= sizeof(struct ieee80211_ht_cap)) {
-               pstat->flags |= WLAN_STA_HT;
-
-               pstat->flags |= WLAN_STA_WME;
-
-               memcpy(&pstat->htpriv.ht_cap, p + 2,
-                      sizeof(struct ieee80211_ht_cap));
-       } else
-               pstat->flags &= ~WLAN_STA_HT;
-
-       if (!pmlmepriv->htpriv.ht_option && pstat->flags & WLAN_STA_HT){
-               status = WLAN_STATUS_UNSPECIFIED_FAILURE;
-               goto OnAssocReq23aFail;
-       }
-
-       if (pstat->flags & WLAN_STA_HT &&
-           (pstat->wpa2_pairwise_cipher & WPA_CIPHER_TKIP ||
-            pstat->wpa_pairwise_cipher & WPA_CIPHER_TKIP)) {
-               DBG_8723A("HT: %pM tried to use TKIP with HT association\n",
-                         pstat->hwaddr);
-
-               /* status = WLAN_STATUS_CIPHER_REJECTED_PER_POLICY; */
-               /* goto OnAssocReq23aFail; */
-       }
-
-       pstat->flags |= WLAN_STA_NONERP;
-       for (i = 0; i < pstat->bssratelen; i++) {
-               if ((pstat->bssrateset[i] & 0x7f) > 22) {
-                       pstat->flags &= ~WLAN_STA_NONERP;
-                       break;
-               }
-       }
-
-       if (pstat->capability & WLAN_CAPABILITY_SHORT_PREAMBLE)
-               pstat->flags |= WLAN_STA_SHORT_PREAMBLE;
-       else
-               pstat->flags &= ~WLAN_STA_SHORT_PREAMBLE;
-
-       if (status != WLAN_STATUS_SUCCESS)
-               goto OnAssocReq23aFail;
-
-       /* TODO: identify_proprietary_vendor_ie(); */
-       /*  Realtek proprietary IE */
-       /*  identify if this is Broadcom sta */
-       /*  identify if this is ralink sta */
-       /*  Customer proprietary IE */
-
-       /* get a unique AID */
-       if (pstat->aid > 0) {
-               DBG_8723A("  old AID %d\n", pstat->aid);
-       } else {
-               for (pstat->aid = 1; pstat->aid <= NUM_STA; pstat->aid++)
-                       if (pstapriv->sta_aid[pstat->aid - 1] == NULL)
-                               break;
-
-               if (pstat->aid > NUM_STA)
-                       pstat->aid = NUM_STA;
-               if (pstat->aid > pstapriv->max_num_sta) {
-
-                       pstat->aid = 0;
-
-                       DBG_8723A("  no room for more AIDs\n");
-
-                       status = WLAN_STATUS_AP_UNABLE_TO_HANDLE_NEW_STA;
-
-                       goto OnAssocReq23aFail;
-               } else {
-                       pstapriv->sta_aid[pstat->aid - 1] = pstat;
-                       DBG_8723A("allocate new AID = (%d)\n", pstat->aid);
-               }
-       }
-
-       pstat->state &= ~WIFI_FW_ASSOC_STATE;
-       pstat->state |= WIFI_FW_ASSOC_SUCCESS;
-
-       spin_lock_bh(&pstapriv->auth_list_lock);
-       if (!list_empty(&pstat->auth_list)) {
-               list_del_init(&pstat->auth_list);
-               pstapriv->auth_list_cnt--;
-       }
-       spin_unlock_bh(&pstapriv->auth_list_lock);
-
-       spin_lock_bh(&pstapriv->asoc_list_lock);
-       if (list_empty(&pstat->asoc_list)) {
-               pstat->expire_to = pstapriv->expire_to;
-               list_add_tail(&pstat->asoc_list, &pstapriv->asoc_list);
-               pstapriv->asoc_list_cnt++;
-       }
-       spin_unlock_bh(&pstapriv->asoc_list_lock);
-
-       /*  now the station is qualified to join our BSS... */
-       if (pstat->state & WIFI_FW_ASSOC_SUCCESS &&
-           status == WLAN_STATUS_SUCCESS) {
-               /* 1 bss_cap_update & sta_info_update23a */
-               bss_cap_update_on_sta_join23a(padapter, pstat);
-               sta_info_update23a(padapter, pstat);
-
-               /* issue assoc rsp before notify station join event. */
-               if (ieee80211_is_assoc_req(mgmt->frame_control))
-                       issue_assocrsp(padapter, status, pstat,
-                                      IEEE80211_STYPE_ASSOC_RESP);
-               else
-                       issue_assocrsp(padapter, status, pstat,
-                                      IEEE80211_STYPE_REASSOC_RESP);
-
-               /* 2 - report to upper layer */
-               DBG_8723A("indicate_sta_join_event to upper layer - hostapd\n");
-               rtw_cfg80211_indicate_sta_assoc(padapter, pframe, pkt_len);
-
-               /* 3-(1) report sta add event */
-               report_add_sta_event23a(padapter, pstat->hwaddr, pstat->aid);
-       }
-
-       return _SUCCESS;
-
-asoc_class2_error:
-
-       issue_deauth23a(padapter, mgmt->sa, status);
-       return _FAIL;
-
-OnAssocReq23aFail:
-
-       pstat->aid = 0;
-       if (ieee80211_is_assoc_req(mgmt->frame_control))
-               issue_assocrsp(padapter, status, pstat,
-                              IEEE80211_STYPE_ASSOC_RESP);
-       else
-               issue_assocrsp(padapter, status, pstat,
-                              IEEE80211_STYPE_REASSOC_RESP);
-
-#endif /* CONFIG_8723AU_AP_MODE */
-
-       return _FAIL;
-}
-
-static int
-OnAssocRsp23a(struct rtw_adapter *padapter, struct recv_frame *precv_frame)
-{
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       struct sk_buff *skb = precv_frame->pkt;
-       struct ieee80211_mgmt *pmgmt = (struct ieee80211_mgmt *) skb->data;
-       int res;
-       unsigned short status;
-       const u8 *p, *pie;
-       u8 *pframe = skb->data;
-       int pkt_len = skb->len;
-       int pielen;
-
-       DBG_8723A("%s\n", __func__);
-
-       /* check A1 matches or not */
-       if (!ether_addr_equal(myid(&padapter->eeprompriv), pmgmt->da))
-               return _SUCCESS;
-
-       if (!(pmlmeinfo->state & (WIFI_FW_AUTH_SUCCESS | WIFI_FW_ASSOC_STATE)))
-               return _SUCCESS;
-
-       if (pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS)
-               return _SUCCESS;
-
-       del_timer_sync(&pmlmeext->link_timer);
-
-       /* status */
-       status = le16_to_cpu(pmgmt->u.assoc_resp.status_code);
-       if (status > 0) {
-               DBG_8723A("assoc reject, status code: %d\n", status);
-               pmlmeinfo->state = MSR_NOLINK;
-               res = -4;
-               goto report_assoc_result;
-       }
-
-       /* get capabilities */
-       pmlmeinfo->capability = le16_to_cpu(pmgmt->u.assoc_resp.capab_info);
-
-       /* set slot time */
-       pmlmeinfo->slotTime = (pmlmeinfo->capability & BIT(10))? 9: 20;
-
-       /* AID */
-       res = pmlmeinfo->aid = le16_to_cpu(pmgmt->u.assoc_resp.aid) & 0x3fff;
-
-       pie = pframe + offsetof(struct ieee80211_mgmt, u.assoc_resp.variable);
-       pielen = pkt_len -
-               offsetof(struct ieee80211_mgmt, u.assoc_resp.variable);
-
-       p = cfg80211_find_ie(WLAN_EID_HT_CAPABILITY,
-                            pmgmt->u.assoc_resp.variable, pielen);
-       if (p && p[1])
-               HT_caps_handler23a(padapter, p);
-
-       p = cfg80211_find_ie(WLAN_EID_HT_OPERATION,
-                            pmgmt->u.assoc_resp.variable, pielen);
-       if (p && p[1])
-               HT_info_handler23a(padapter, p);
-
-       p = cfg80211_find_ie(WLAN_EID_ERP_INFO,
-                            pmgmt->u.assoc_resp.variable, pielen);
-       if (p && p[1])
-               ERP_IE_handler23a(padapter, p);
-
-       pie = pframe + offsetof(struct ieee80211_mgmt, u.assoc_resp.variable);
-       while (true) {
-               p = cfg80211_find_vendor_ie(WLAN_OUI_MICROSOFT,
-                                           WLAN_OUI_TYPE_MICROSOFT_WMM,
-                                           pie, pframe + pkt_len - pie);
-               if (!p)
-                       break;
-
-               pie = p + p[1] + 2;
-               /* if this IE is too short, try the next */
-               if (p[1] <= 4)
-                       continue;
-               /* if this IE is WMM params, we found what we wanted */
-               if (p[6] == 1)
-                       break;
-       }
-
-       if (p && p[1])
-               WMM_param_handler23a(padapter, p);
-
-       pmlmeinfo->state &= ~WIFI_FW_ASSOC_STATE;
-       pmlmeinfo->state |= WIFI_FW_ASSOC_SUCCESS;
-
-       /* Update Basic Rate Table for spec, 2010-12-28 , by thomas */
-       UpdateBrateTbl23a(padapter, pmlmeinfo->network.SupportedRates);
-
-report_assoc_result:
-       pmlmepriv->assoc_rsp_len = 0;
-       if (res > 0) {
-               kfree(pmlmepriv->assoc_rsp);
-               pmlmepriv->assoc_rsp = kmalloc(pkt_len, GFP_ATOMIC);
-               if (pmlmepriv->assoc_rsp) {
-                       memcpy(pmlmepriv->assoc_rsp, pframe, pkt_len);
-                       pmlmepriv->assoc_rsp_len = pkt_len;
-               }
-       } else
-               kfree(pmlmepriv->assoc_rsp);
-
-       report_join_res23a(padapter, res);
-
-       return _SUCCESS;
-}
-
-static int
-OnDeAuth23a(struct rtw_adapter *padapter, struct recv_frame *precv_frame)
-{
-       unsigned short reason;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       struct sk_buff *skb = precv_frame->pkt;
-       struct ieee80211_mgmt *mgmt = (struct ieee80211_mgmt *) skb->data;
-
-       if (!ether_addr_equal(mgmt->bssid,
-                             get_my_bssid23a(&pmlmeinfo->network)))
-               return _SUCCESS;
-
-       reason = le16_to_cpu(mgmt->u.deauth.reason_code);
-
-       DBG_8723A("%s Reason code(%d)\n", __func__, reason);
-
-#ifdef CONFIG_8723AU_AP_MODE
-       if (check_fwstate(pmlmepriv, WIFI_AP_STATE)) {
-               struct sta_info *psta;
-               struct sta_priv *pstapriv = &padapter->stapriv;
-
-               DBG_8723A_LEVEL(_drv_always_, "ap recv deauth reason code(%d) "
-                               "sta:%pM\n", reason, mgmt->sa);
-
-               psta = rtw_get_stainfo23a(pstapriv, mgmt->sa);
-               if (psta) {
-                       u8 updated = 0;
-
-                       spin_lock_bh(&pstapriv->asoc_list_lock);
-                       if (!list_empty(&psta->asoc_list)) {
-                               list_del_init(&psta->asoc_list);
-                               pstapriv->asoc_list_cnt--;
-                               updated = ap_free_sta23a(padapter, psta,
-                                                     false, reason);
-                       }
-                       spin_unlock_bh(&pstapriv->asoc_list_lock);
-
-                       associated_clients_update23a(padapter, updated);
-               }
-
-               return _SUCCESS;
-       } else
-#endif
-       {
-               DBG_8723A_LEVEL(_drv_always_, "sta recv deauth reason code(%d) "
-                               "sta:%pM\n", reason, mgmt->bssid);
-
-               receive_disconnect23a(padapter, mgmt->bssid, reason);
-       }
-       pmlmepriv->LinkDetectInfo.bBusyTraffic = false;
-
-       return _SUCCESS;
-}
-
-static int
-OnDisassoc23a(struct rtw_adapter *padapter, struct recv_frame *precv_frame)
-{
-       unsigned short reason;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       struct sk_buff *skb = precv_frame->pkt;
-       struct ieee80211_mgmt *mgmt = (struct ieee80211_mgmt *) skb->data;
-
-       if (!ether_addr_equal(mgmt->bssid,
-                             get_my_bssid23a(&pmlmeinfo->network)))
-               return _SUCCESS;
-
-       reason = le16_to_cpu(mgmt->u.disassoc.reason_code);
-
-       DBG_8723A("%s Reason code(%d)\n", __func__, reason);
-
-#ifdef CONFIG_8723AU_AP_MODE
-       if (check_fwstate(pmlmepriv, WIFI_AP_STATE)) {
-               struct sta_info *psta;
-               struct sta_priv *pstapriv = &padapter->stapriv;
-
-               DBG_8723A_LEVEL(_drv_always_, "ap recv disassoc reason code(%d)"
-                               " sta:%pM\n", reason, mgmt->sa);
-
-               psta = rtw_get_stainfo23a(pstapriv, mgmt->sa);
-               if (psta) {
-                       u8 updated = 0;
-
-                       spin_lock_bh(&pstapriv->asoc_list_lock);
-                       if (!list_empty(&psta->asoc_list)) {
-                               list_del_init(&psta->asoc_list);
-                               pstapriv->asoc_list_cnt--;
-                               updated = ap_free_sta23a(padapter, psta,
-                                                        false, reason);
-                       }
-                       spin_unlock_bh(&pstapriv->asoc_list_lock);
-
-                       associated_clients_update23a(padapter, updated);
-               }
-
-               return _SUCCESS;
-       } else
-#endif
-       {
-               DBG_8723A_LEVEL(_drv_always_, "ap recv disassoc reason "
-                               "code(%d) sta:%pM\n", reason, mgmt->bssid);
-
-               receive_disconnect23a(padapter, mgmt->bssid, reason);
-       }
-       pmlmepriv->LinkDetectInfo.bBusyTraffic = false;
-       return _SUCCESS;
-}
-
-static int
-OnAtim23a(struct rtw_adapter *padapter, struct recv_frame *precv_frame)
-{
-       DBG_8723A("%s\n", __func__);
-       return _SUCCESS;
-}
-
-static int
-on_action_spct23a(struct rtw_adapter *padapter, struct recv_frame *precv_frame)
-{
-       return _FAIL;
-}
-
-static int
-OnAction23a_qos(struct rtw_adapter *padapter, struct recv_frame *precv_frame)
-{
-       return _SUCCESS;
-}
-
-static int
-OnAction23a_dls(struct rtw_adapter *padapter, struct recv_frame *precv_frame)
-{
-       return _SUCCESS;
-}
-
-static int OnAction23a_back23a(struct rtw_adapter *padapter,
-                              struct recv_frame *precv_frame)
-{
-       u8 *addr;
-       struct sta_info *psta = NULL;
-       struct recv_reorder_ctrl *preorder_ctrl;
-       unsigned char category, action;
-       unsigned short tid, status, capab, params, reason_code = 0;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       struct sk_buff *skb = precv_frame->pkt;
-       struct ieee80211_mgmt *mgmt = (struct ieee80211_mgmt *) skb->data;
-       struct sta_priv *pstapriv = &padapter->stapriv;
-
-       /* check RA matches or not */
-       if (!ether_addr_equal(myid(&padapter->eeprompriv), mgmt->da))
-               return _SUCCESS;
-
-       DBG_8723A("%s\n", __func__);
-
-       if ((pmlmeinfo->state&0x03) != MSR_AP)
-               if (!(pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS))
-                       return _SUCCESS;
-
-       addr = mgmt->sa;
-       psta = rtw_get_stainfo23a(pstapriv, addr);
-
-       if (!psta)
-               return _SUCCESS;
-
-       category = mgmt->u.action.category;
-       if (category == WLAN_CATEGORY_BACK) { /*  representing Block Ack */
-               if (!pmlmeinfo->HT_enable)
-                       return _SUCCESS;
-               /* action_code is located in the same place for all
-                  action events, so pick any */
-               action = mgmt->u.action.u.wme_action.action_code;
-               DBG_8723A("%s, action =%d\n", __func__, action);
-               switch (action) {
-               case WLAN_ACTION_ADDBA_REQ: /* ADDBA request */
-                       memcpy(&pmlmeinfo->ADDBA_req,
-                              &mgmt->u.action.u.addba_req.dialog_token,
-                              sizeof(struct ADDBA_request));
-                       process_addba_req23a(padapter,
-                                            (u8 *)&pmlmeinfo->ADDBA_req, addr);
-                       if (pmlmeinfo->bAcceptAddbaReq == true)
-                               issue_action_BA23a(padapter, addr,
-                                                  WLAN_ACTION_ADDBA_RESP, 0);
-                       else {
-                               /* reject ADDBA Req */
-                               issue_action_BA23a(padapter, addr,
-                                                  WLAN_ACTION_ADDBA_RESP, 37);
-                       }
-                       break;
-               case WLAN_ACTION_ADDBA_RESP: /* ADDBA response */
-                       status = get_unaligned_le16(
-                               &mgmt->u.action.u.addba_resp.status);
-                       capab = get_unaligned_le16(
-                               &mgmt->u.action.u.addba_resp.capab);
-                       tid = (capab & IEEE80211_ADDBA_PARAM_TID_MASK) >> 2;
-                       if (status == 0) {      /* successful */
-                               DBG_8723A("agg_enable for TID =%d\n", tid);
-                               psta->htpriv.agg_enable_bitmap |= BIT(tid);
-                               psta->htpriv.candidate_tid_bitmap &= ~BIT(tid);
-                       } else
-                               psta->htpriv.agg_enable_bitmap &= ~BIT(tid);
-                       break;
-
-               case WLAN_ACTION_DELBA: /* DELBA */
-                       params = get_unaligned_le16(
-                               &mgmt->u.action.u.delba.params);
-                       tid = params >> 12;
-
-                       if (params & IEEE80211_DELBA_PARAM_INITIATOR_MASK) {
-                               preorder_ctrl = &psta->recvreorder_ctrl[tid];
-                               preorder_ctrl->enable = false;
-                               preorder_ctrl->indicate_seq = 0xffff;
-                       } else {
-                               psta->htpriv.agg_enable_bitmap &= ~BIT(tid);
-                               psta->htpriv.candidate_tid_bitmap &= ~BIT(tid);
-                       }
-                       reason_code = get_unaligned_le16(
-                               &mgmt->u.action.u.delba.reason_code);
-                       /* todo: how to notify the host while receiving
-                          DELETE BA */
-                       break;
-               default:
-                       break;
-               }
-       }
-       return _SUCCESS;
-}
-
-static int on_action_public23a(struct rtw_adapter *padapter,
-                              struct recv_frame *precv_frame)
-{
-       struct sk_buff *skb = precv_frame->pkt;
-       struct ieee80211_hdr *hdr = (struct ieee80211_hdr *) skb->data;
-       u8 *pframe = skb->data;
-       int freq, channel;
-
-       /* check RA matches or not */
-       if (!ether_addr_equal(myid(&padapter->eeprompriv), hdr->addr1))
-               return _FAIL;
-
-       channel = rtw_get_oper_ch23a(padapter);
-
-       if (channel <= RTW_CH_MAX_2G_CHANNEL)
-               freq = ieee80211_channel_to_frequency(channel,
-                                                     NL80211_BAND_2GHZ);
-       else
-               freq = ieee80211_channel_to_frequency(channel,
-                                                     NL80211_BAND_5GHZ);
-
-       if (cfg80211_rx_mgmt(padapter->rtw_wdev, freq, 0, pframe,
-                            skb->len, 0))
-               return _SUCCESS;
-
-       return _FAIL;
-}
-
-static int
-OnAction23a_ht(struct rtw_adapter *padapter, struct recv_frame *precv_frame)
-{
-       return _SUCCESS;
-}
-
-static int
-OnAction23a_wmm(struct rtw_adapter *padapter, struct recv_frame *precv_frame)
-{
-       return _SUCCESS;
-}
-
-static int
-OnAction23a_p2p(struct rtw_adapter *padapter, struct recv_frame *precv_frame)
-{
-       return _SUCCESS;
-}
-
-static int
-OnAction23a(struct rtw_adapter *padapter, struct recv_frame *precv_frame)
-{
-       int i;
-       u8 category;
-       struct action_handler *ptable;
-       struct sk_buff *skb = precv_frame->pkt;
-       struct ieee80211_mgmt *mgmt = (struct ieee80211_mgmt *) skb->data;
-
-       category = mgmt->u.action.category;
-
-       for (i = 0; i < ARRAY_SIZE(OnAction23a_tbl); i++) {
-               ptable = &OnAction23a_tbl[i];
-
-               if (category == ptable->num)
-                       ptable->func(padapter, precv_frame);
-       }
-
-       return _SUCCESS;
-}
-
-static int DoReserved23a(struct rtw_adapter *padapter,
-                        struct recv_frame *precv_frame)
-{
-       return _SUCCESS;
-}
-
-struct xmit_frame *alloc_mgtxmitframe23a(struct xmit_priv *pxmitpriv)
-{
-       struct xmit_frame *pmgntframe;
-       struct xmit_buf *pxmitbuf;
-
-       pmgntframe = rtw_alloc_xmitframe23a_ext(pxmitpriv);
-
-       if (!pmgntframe) {
-               DBG_8723A("%s(%s): alloc xmitframe fail\n", __func__,
-                         pxmitpriv->adapter->pnetdev->name);
-               goto exit;
-       }
-
-       pxmitbuf = rtw_alloc_xmitbuf23a_ext(pxmitpriv);
-       if (!pxmitbuf) {
-               DBG_8723A("%s(%s): alloc xmitbuf fail\n", __func__,
-                         pxmitpriv->adapter->pnetdev->name);
-               rtw_free_xmitframe23a(pxmitpriv, pmgntframe);
-               pmgntframe = NULL;
-               goto exit;
-       }
-
-       pmgntframe->frame_tag = MGNT_FRAMETAG;
-       pmgntframe->pxmitbuf = pxmitbuf;
-       pmgntframe->buf_addr = pxmitbuf->pbuf;
-       pxmitbuf->priv_data = pmgntframe;
-
-exit:
-       return pmgntframe;
-}
-
-/****************************************************************************
-
-Following are some TX functions for WiFi MLME
-
-*****************************************************************************/
-
-void update_mgnt_tx_rate23a(struct rtw_adapter *padapter, u8 rate)
-{
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-
-       pmlmeext->tx_rate = rate;
-       DBG_8723A("%s(): rate = %x\n", __func__, rate);
-}
-
-void update_mgntframe_attrib23a(struct rtw_adapter *padapter,
-                               struct pkt_attrib *pattrib)
-{
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-
-       memset((u8 *)pattrib, 0, sizeof(struct pkt_attrib));
-
-       pattrib->hdrlen = 24;
-       pattrib->nr_frags = 1;
-       pattrib->priority = 7;
-       pattrib->mac_id = 0;
-       pattrib->qsel = 0x12;
-
-       pattrib->pktlen = 0;
-
-       if (pmlmeext->cur_wireless_mode & WIRELESS_11B)
-               pattrib->raid = 6;/* b mode */
-       else
-               pattrib->raid = 5;/* a/g mode */
-
-       pattrib->encrypt = 0;
-       pattrib->bswenc = false;
-
-       pattrib->qos_en = false;
-       pattrib->ht_en = false;
-       pattrib->bwmode = HT_CHANNEL_WIDTH_20;
-       pattrib->ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
-       pattrib->sgi = false;
-
-       pattrib->seqnum = pmlmeext->mgnt_seq;
-
-       pattrib->retry_ctrl = true;
-}
-
-void dump_mgntframe23a(struct rtw_adapter *padapter,
-                      struct xmit_frame *pmgntframe)
-{
-       if (padapter->bSurpriseRemoved == true ||
-           padapter->bDriverStopped == true)
-               return;
-
-       rtl8723au_mgnt_xmit(padapter, pmgntframe);
-}
-
-int dump_mgntframe23a_and_wait(struct rtw_adapter *padapter,
-                              struct xmit_frame *pmgntframe, int timeout_ms)
-{
-       int ret = _FAIL;
-       unsigned long irqL;
-       struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-       struct xmit_buf *pxmitbuf = pmgntframe->pxmitbuf;
-       struct submit_ctx sctx;
-
-       if (padapter->bSurpriseRemoved == true ||
-           padapter->bDriverStopped == true)
-               return ret;
-
-       rtw_sctx_init23a(&sctx, timeout_ms);
-       pxmitbuf->sctx = &sctx;
-
-       ret = rtl8723au_mgnt_xmit(padapter, pmgntframe);
-
-       if (ret == _SUCCESS)
-               ret = rtw_sctx_wait23a(&sctx);
-
-       spin_lock_irqsave(&pxmitpriv->lock_sctx, irqL);
-       pxmitbuf->sctx = NULL;
-       spin_unlock_irqrestore(&pxmitpriv->lock_sctx, irqL);
-
-       return ret;
-}
-
-int dump_mgntframe23a_and_wait_ack23a(struct rtw_adapter *padapter,
-                                     struct xmit_frame *pmgntframe)
-{
-       int ret = _FAIL;
-       u32 timeout_ms = 500;/*   500ms */
-       struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-
-       if (padapter->bSurpriseRemoved == true ||
-           padapter->bDriverStopped == true)
-               return _FAIL;
-
-       mutex_lock(&pxmitpriv->ack_tx_mutex);
-       pxmitpriv->ack_tx = true;
-
-       pmgntframe->ack_report = 1;
-       if (rtl8723au_mgnt_xmit(padapter, pmgntframe) == _SUCCESS)
-               ret = rtw_ack_tx_wait23a(pxmitpriv, timeout_ms);
-
-       pxmitpriv->ack_tx = false;
-       mutex_unlock(&pxmitpriv->ack_tx_mutex);
-
-       return ret;
-}
-
-static int update_hidden_ssid(u8 *ies, u32 ies_len, u8 hidden_ssid_mode)
-{
-       u8 *ssid_ie;
-       int ssid_len_ori;
-       int len_diff = 0;
-       u8 *next_ie;
-       u32 remain_len;
-
-       ssid_ie = rtw_get_ie23a(ies,  WLAN_EID_SSID, &ssid_len_ori, ies_len);
-
-       /* DBG_8723A("%s hidden_ssid_mode:%u, ssid_ie:%p, ssid_len_ori:%d\n",
-          __func__, hidden_ssid_mode, ssid_ie, ssid_len_ori); */
-
-       if (ssid_ie && ssid_len_ori > 0) {
-               switch (hidden_ssid_mode) {
-               case 1:
-                       next_ie = ssid_ie + 2 + ssid_len_ori;
-                       remain_len = ies_len -(next_ie-ies);
-
-                       ssid_ie[1] = 0;
-                       memcpy(ssid_ie+2, next_ie, remain_len);
-                       len_diff -= ssid_len_ori;
-
-                       break;
-               case 2:
-                       memset(&ssid_ie[2], 0, ssid_len_ori);
-                       break;
-               default:
-                       break;
-               }
-       }
-
-       return len_diff;
-}
-
-void issue_beacon23a(struct rtw_adapter *padapter, int timeout_ms)
-{
-       struct xmit_frame *pmgntframe;
-       struct pkt_attrib *pattrib;
-       unsigned char *pframe;
-       struct ieee80211_mgmt *mgmt;
-       unsigned int rate_len;
-       struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       struct wlan_bssid_ex *cur_network = &pmlmeinfo->network;
-       u8 bc_addr[] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
-       const u8 *wps_ie;
-       u8 sr = 0;
-       int len_diff;
-
-       /* DBG_8723A("%s\n", __func__); */
-
-       pmgntframe = alloc_mgtxmitframe23a(pxmitpriv);
-       if (!pmgntframe) {
-               DBG_8723A("%s, alloc mgnt frame fail\n", __func__);
-               return;
-       }
-#ifdef CONFIG_8723AU_AP_MODE
-       spin_lock_bh(&pmlmepriv->bcn_update_lock);
-#endif
-
-       /* update attribute */
-       pattrib = &pmgntframe->attrib;
-       update_mgntframe_attrib23a(padapter, pattrib);
-       pattrib->qsel = 0x10;
-
-       memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
-
-       pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
-       mgmt = (struct ieee80211_mgmt *)pframe;
-
-       mgmt->frame_control =
-               cpu_to_le16(IEEE80211_FTYPE_MGMT | IEEE80211_STYPE_BEACON);
-       mgmt->seq_ctrl = 0;
-
-       ether_addr_copy(mgmt->da, bc_addr);
-       ether_addr_copy(mgmt->sa, myid(&padapter->eeprompriv));
-       ether_addr_copy(mgmt->bssid, get_my_bssid23a(cur_network));
-
-       /* timestamp will be inserted by hardware */
-
-       put_unaligned_le16(cur_network->beacon_interval,
-                          &mgmt->u.beacon.beacon_int);
-
-       put_unaligned_le16(cur_network->capability,
-                          &mgmt->u.beacon.capab_info);
-
-       pframe = mgmt->u.beacon.variable;
-       pattrib->pktlen = offsetof(struct ieee80211_mgmt, u.beacon.variable);
-
-       if ((pmlmeinfo->state & 0x03) == MSR_AP) {
-               u8 *iebuf;
-               int buflen;
-               /* DBG_8723A("ie len =%d\n", cur_network->IELength); */
-               memcpy(pframe, cur_network->IEs, cur_network->IELength);
-               len_diff = update_hidden_ssid(pframe, cur_network->IELength,
-                                             pmlmeinfo->hidden_ssid_mode);
-               pframe += (cur_network->IELength+len_diff);
-               pattrib->pktlen += (cur_network->IELength+len_diff);
-
-               iebuf = mgmt->u.beacon.variable;
-               buflen = pattrib->pktlen -
-                       offsetof(struct ieee80211_mgmt, u.beacon.variable);
-               wps_ie = cfg80211_find_vendor_ie(WLAN_OUI_MICROSOFT,
-                                                WLAN_OUI_TYPE_MICROSOFT_WPS,
-                                                iebuf, buflen);
-
-               if (wps_ie && wps_ie[1] > 0) {
-                       rtw_get_wps_attr_content23a(wps_ie, wps_ie[1],
-                                                   WPS_ATTR_SELECTED_REGISTRAR,
-                                                   (u8 *)&sr);
-               }
-               if (sr != 0)
-                       set_fwstate(pmlmepriv, WIFI_UNDER_WPS);
-               else
-                       _clr_fwstate_(pmlmepriv, WIFI_UNDER_WPS);
-
-               goto _issue_bcn;
-       }
-
-       /*  SSID */
-       pframe = rtw_set_ie23a(pframe, WLAN_EID_SSID,
-                              cur_network->Ssid.ssid_len,
-                              cur_network->Ssid.ssid, &pattrib->pktlen);
-
-       /*  supported rates... */
-       rate_len = rtw_get_rateset_len23a(cur_network->SupportedRates);
-       pframe = rtw_set_ie23a(pframe, WLAN_EID_SUPP_RATES,
-                              ((rate_len > 8)? 8: rate_len),
-                              cur_network->SupportedRates, &pattrib->pktlen);
-
-       /*  DS parameter set */
-       pframe = rtw_set_ie23a(pframe, WLAN_EID_DS_PARAMS, 1, (unsigned char *)
-                              &cur_network->DSConfig, &pattrib->pktlen);
-
-       /* if ((pmlmeinfo->state&0x03) == MSR_ADHOC) */
-       {
-               u8 erpinfo = 0;
-               u32 ATIMWindow;
-               /*  IBSS Parameter Set... */
-               /* ATIMWindow = cur->ATIMWindow; */
-               ATIMWindow = 0;
-               pframe = rtw_set_ie23a(pframe, WLAN_EID_IBSS_PARAMS, 2,
-                                      (unsigned char *)&ATIMWindow,
-                                      &pattrib->pktlen);
-
-               /* ERP IE */
-               pframe = rtw_set_ie23a(pframe, WLAN_EID_ERP_INFO, 1,
-                                      &erpinfo, &pattrib->pktlen);
-       }
-
-       /*  EXTERNDED SUPPORTED RATE */
-       if (rate_len > 8)
-               pframe = rtw_set_ie23a(pframe, WLAN_EID_EXT_SUPP_RATES,
-                                      rate_len - 8,
-                                      cur_network->SupportedRates + 8,
-                                      &pattrib->pktlen);
-
-       /* todo:HT for adhoc */
-
-_issue_bcn:
-
-#ifdef CONFIG_8723AU_AP_MODE
-       pmlmepriv->update_bcn = false;
-
-       spin_unlock_bh(&pmlmepriv->bcn_update_lock);
-#endif
-
-       if ((pattrib->pktlen + TXDESC_SIZE) > 512) {
-               DBG_8723A("beacon frame too large\n");
-               return;
-       }
-
-       pattrib->last_txcmdsz = pattrib->pktlen;
-
-       /* DBG_8723A("issue bcn_sz =%d\n", pattrib->last_txcmdsz); */
-       if (timeout_ms > 0)
-               dump_mgntframe23a_and_wait(padapter, pmgntframe, timeout_ms);
-       else
-               dump_mgntframe23a(padapter, pmgntframe);
-}
-
-static void issue_probersp(struct rtw_adapter *padapter, unsigned char *da)
-{
-       struct xmit_frame *pmgntframe;
-       struct pkt_attrib *pattrib;
-       unsigned char *pframe;
-       struct ieee80211_mgmt *mgmt;
-       unsigned char *mac, *bssid;
-       struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-#ifdef CONFIG_8723AU_AP_MODE
-       const u8 *pwps_ie;
-       u8 *ssid_ie;
-       int ssid_ielen;
-       int ssid_ielen_diff;
-       u8 buf[MAX_IE_SZ];
-#endif
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       struct wlan_bssid_ex *cur_network = &pmlmeinfo->network;
-       unsigned int rate_len;
-
-       /* DBG_8723A("%s\n", __func__); */
-
-       if (cur_network->IELength > MAX_IE_SZ)
-               return;
-
-       pmgntframe = alloc_mgtxmitframe23a(pxmitpriv);
-       if (!pmgntframe) {
-               DBG_8723A("%s, alloc mgnt frame fail\n", __func__);
-               return;
-       }
-
-       /* update attribute */
-       pattrib = &pmgntframe->attrib;
-       update_mgntframe_attrib23a(padapter, pattrib);
-
-       memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
-
-       pframe = (u8 *)pmgntframe->buf_addr + TXDESC_OFFSET;
-       mgmt = (struct ieee80211_mgmt *)pframe;
-
-       mac = myid(&padapter->eeprompriv);
-       bssid = cur_network->MacAddress;
-
-       mgmt->frame_control =
-               cpu_to_le16(IEEE80211_FTYPE_MGMT | IEEE80211_STYPE_PROBE_RESP);
-
-       ether_addr_copy(mgmt->da, da);
-       ether_addr_copy(mgmt->sa, mac);
-       ether_addr_copy(mgmt->bssid, bssid);
-
-       mgmt->seq_ctrl = cpu_to_le16(IEEE80211_SN_TO_SEQ(pmlmeext->mgnt_seq));
-       pmlmeext->mgnt_seq++;
-
-       pattrib->hdrlen = sizeof(struct ieee80211_hdr_3addr);
-
-       /* timestamp will be inserted by hardware */
-       put_unaligned_le16(cur_network->beacon_interval,
-                          &mgmt->u.probe_resp.beacon_int);
-
-       put_unaligned_le16(cur_network->capability,
-                          &mgmt->u.probe_resp.capab_info);
-
-       pframe = mgmt->u.probe_resp.variable;
-       pattrib->pktlen =
-               offsetof(struct ieee80211_mgmt, u.probe_resp.variable);
-
-       /* below for ad-hoc mode */
-
-#ifdef CONFIG_8723AU_AP_MODE
-       if ((pmlmeinfo->state & 0x03) == MSR_AP) {
-               pwps_ie = cfg80211_find_vendor_ie(WLAN_OUI_MICROSOFT,
-                                                 WLAN_OUI_TYPE_MICROSOFT_WPS,
-                                                 cur_network->IEs,
-                                                 cur_network->IELength);
-
-               memcpy(pframe, cur_network->IEs, cur_network->IELength);
-               pframe += cur_network->IELength;
-               pattrib->pktlen += cur_network->IELength;
-
-               /* retrieve SSID IE from cur_network->Ssid */
-
-               ssid_ie = rtw_get_ie23a(mgmt->u.probe_resp.variable,
-                                       WLAN_EID_SSID, &ssid_ielen,
-                                       pframe - mgmt->u.probe_resp.variable);
-
-               ssid_ielen_diff = cur_network->Ssid.ssid_len - ssid_ielen;
-
-               if (ssid_ie && cur_network->Ssid.ssid_len) {
-                       uint remainder_ielen;
-                       u8 *remainder_ie;
-
-                       remainder_ie = ssid_ie + 2;
-
-                       remainder_ielen = pframe - remainder_ie;
-
-                       DBG_8723A_LEVEL(_drv_warning_, "%s(%s): "
-                                       "remainder_ielen > MAX_IE_SZ\n",
-                                       __func__, padapter->pnetdev->name);
-                       if (remainder_ielen > MAX_IE_SZ)
-                               remainder_ielen = MAX_IE_SZ;
-
-                       memcpy(buf, remainder_ie, remainder_ielen);
-                       memcpy(remainder_ie + ssid_ielen_diff, buf,
-                              remainder_ielen);
-                       *(ssid_ie + 1) = cur_network->Ssid.ssid_len;
-                       memcpy(ssid_ie + 2, cur_network->Ssid.ssid,
-                              cur_network->Ssid.ssid_len);
-
-                       pframe += ssid_ielen_diff;
-                       pattrib->pktlen += ssid_ielen_diff;
-               }
-       } else
-#endif
-       {
-               /*  SSID */
-               pframe = rtw_set_ie23a(pframe, WLAN_EID_SSID,
-                                      cur_network->Ssid.ssid_len,
-                                      cur_network->Ssid.ssid,
-                                      &pattrib->pktlen);
-
-               /*  supported rates... */
-               rate_len = rtw_get_rateset_len23a(cur_network->SupportedRates);
-               pframe = rtw_set_ie23a(pframe, WLAN_EID_SUPP_RATES,
-                                      ((rate_len > 8)? 8: rate_len),
-                                      cur_network->SupportedRates,
-                                      &pattrib->pktlen);
-
-               /*  DS parameter set */
-               pframe = rtw_set_ie23a(pframe, WLAN_EID_DS_PARAMS, 1,
-                                      (unsigned char *)&cur_network->DSConfig,
-                                      &pattrib->pktlen);
-
-               if ((pmlmeinfo->state & 0x03) == MSR_ADHOC) {
-                       u8 erpinfo = 0;
-                       u32 ATIMWindow;
-                       /*  IBSS Parameter Set... */
-                       /* ATIMWindow = cur->ATIMWindow; */
-                       ATIMWindow = 0;
-                       pframe = rtw_set_ie23a(pframe, WLAN_EID_IBSS_PARAMS, 2,
-                                              (unsigned char *)&ATIMWindow,
-                                              &pattrib->pktlen);
-
-                       /* ERP IE */
-                       pframe = rtw_set_ie23a(pframe, WLAN_EID_ERP_INFO, 1,
-                                              &erpinfo, &pattrib->pktlen);
-               }
-
-               /*  EXTERNDED SUPPORTED RATE */
-               if (rate_len > 8)
-                       pframe = rtw_set_ie23a(pframe, WLAN_EID_EXT_SUPP_RATES,
-                                              rate_len - 8,
-                                              cur_network->SupportedRates + 8,
-                                              &pattrib->pktlen);
-
-               /* todo:HT for adhoc */
-       }
-
-       pattrib->last_txcmdsz = pattrib->pktlen;
-
-       dump_mgntframe23a(padapter, pmgntframe);
-}
-
-static int _issue_probereq(struct rtw_adapter *padapter,
-                          struct cfg80211_ssid *pssid, u8 *da, int wait_ack)
-{
-       int ret = _FAIL;
-       struct xmit_frame *pmgntframe;
-       struct pkt_attrib *pattrib;
-       unsigned char *pframe;
-       struct ieee80211_hdr *pwlanhdr;
-       unsigned char *mac;
-       unsigned char bssrate[NumRates];
-       struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       int bssrate_len = 0;
-       u8 bc_addr[] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
-
-       RT_TRACE(_module_rtl871x_mlme_c_, _drv_notice_,
-                "+%s\n", __func__);
-
-       pmgntframe = alloc_mgtxmitframe23a(pxmitpriv);
-       if (!pmgntframe)
-               goto exit;
-
-       /* update attribute */
-       pattrib = &pmgntframe->attrib;
-       update_mgntframe_attrib23a(padapter, pattrib);
-
-       memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
-
-       pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
-       pwlanhdr = (struct ieee80211_hdr *)pframe;
-
-       mac = myid(&padapter->eeprompriv);
-
-       pwlanhdr->frame_control = cpu_to_le16(IEEE80211_FTYPE_MGMT |
-                                             IEEE80211_STYPE_PROBE_REQ);
-
-       if (da) {
-               /*      unicast probe request frame */
-               ether_addr_copy(pwlanhdr->addr1, da);
-               ether_addr_copy(pwlanhdr->addr3, da);
-       } else {
-               /*      broadcast probe request frame */
-               ether_addr_copy(pwlanhdr->addr1, bc_addr);
-               ether_addr_copy(pwlanhdr->addr3, bc_addr);
-       }
-
-       ether_addr_copy(pwlanhdr->addr2, mac);
-
-       pwlanhdr->seq_ctrl =
-               cpu_to_le16(IEEE80211_SN_TO_SEQ(pmlmeext->mgnt_seq));
-
-       pmlmeext->mgnt_seq++;
-
-       pframe += sizeof (struct ieee80211_hdr_3addr);
-       pattrib->pktlen = sizeof (struct ieee80211_hdr_3addr);
-
-       if (pssid)
-               pframe = rtw_set_ie23a(pframe, WLAN_EID_SSID, pssid->ssid_len,
-                                      pssid->ssid, &pattrib->pktlen);
-       else
-               pframe = rtw_set_ie23a(pframe, WLAN_EID_SSID, 0, NULL,
-                                      &pattrib->pktlen);
-
-       get_rate_set23a(padapter, bssrate, &bssrate_len);
-
-       if (bssrate_len > 8) {
-               pframe = rtw_set_ie23a(pframe, WLAN_EID_SUPP_RATES, 8,
-                                      bssrate, &pattrib->pktlen);
-               pframe = rtw_set_ie23a(pframe, WLAN_EID_EXT_SUPP_RATES,
-                                      (bssrate_len - 8), (bssrate + 8),
-                                      &pattrib->pktlen);
-       } else {
-               pframe = rtw_set_ie23a(pframe, WLAN_EID_SUPP_RATES,
-                                      bssrate_len, bssrate, &pattrib->pktlen);
-       }
-
-       /* add wps_ie for wps2.0 */
-       if (pmlmepriv->wps_probe_req_ie_len>0 && pmlmepriv->wps_probe_req_ie) {
-               memcpy(pframe, pmlmepriv->wps_probe_req_ie,
-                      pmlmepriv->wps_probe_req_ie_len);
-               pframe += pmlmepriv->wps_probe_req_ie_len;
-               pattrib->pktlen += pmlmepriv->wps_probe_req_ie_len;
-       }
-
-       pattrib->last_txcmdsz = pattrib->pktlen;
-
-       RT_TRACE(_module_rtl871x_mlme_c_, _drv_notice_,
-                "issuing probe_req, tx_len =%d\n", pattrib->last_txcmdsz);
-
-       if (wait_ack) {
-               ret = dump_mgntframe23a_and_wait_ack23a(padapter, pmgntframe);
-       } else {
-               dump_mgntframe23a(padapter, pmgntframe);
-               ret = _SUCCESS;
-       }
-
-exit:
-       return ret;
-}
-
-static inline void issue_probereq(struct rtw_adapter *padapter,
-                                 struct cfg80211_ssid *pssid, u8 *da)
-{
-       _issue_probereq(padapter, pssid, da, false);
-}
-
-static int issue_probereq_ex(struct rtw_adapter *padapter,
-                            struct cfg80211_ssid *pssid, u8 *da,
-                            int try_cnt, int wait_ms)
-{
-       int ret;
-       int i = 0;
-       unsigned long start = jiffies;
-
-       do {
-               ret = _issue_probereq(padapter, pssid, da,
-                                     wait_ms > 0 ? true : false);
-
-               i++;
-
-               if (padapter->bDriverStopped || padapter->bSurpriseRemoved)
-                       break;
-
-               if (i < try_cnt && wait_ms > 0 && ret == _FAIL)
-                       msleep(wait_ms);
-
-       } while((i < try_cnt) && ((ret == _FAIL) || (wait_ms == 0)));
-
-       if (ret != _FAIL) {
-               ret = _SUCCESS;
-               goto exit;
-       }
-
-       if (try_cnt && wait_ms) {
-               if (da)
-                       DBG_8723A("%s(%s): to %pM, ch:%u%s, %d/%d in %u ms\n",
-                                 __func__, padapter->pnetdev->name,
-                                 da, rtw_get_oper_ch23a(padapter),
-                                 ret == _SUCCESS ? ", acked" : "", i, try_cnt,
-                                 jiffies_to_msecs(jiffies - start));
-               else
-                       DBG_8723A("%s(%s):, ch:%u%s, %d/%d in %u ms\n",
-                                 __func__, padapter->pnetdev->name,
-                                 rtw_get_oper_ch23a(padapter),
-                                 ret == _SUCCESS ? ", acked" : "", i, try_cnt,
-                                 jiffies_to_msecs(jiffies - start));
-       }
-exit:
-       return ret;
-}
-
-/*  if psta == NULL, indiate we are station(client) now... */
-static void issue_auth(struct rtw_adapter *padapter, struct sta_info *psta,
-                      unsigned short status)
-{
-       struct xmit_frame *pmgntframe;
-       struct pkt_attrib *pattrib;
-       unsigned char *pframe;
-       struct ieee80211_mgmt *mgmt;
-       unsigned int val32;
-       u16 auth_algo;
-       int use_shared_key = 0;
-       struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-
-       pmgntframe = alloc_mgtxmitframe23a(pxmitpriv);
-       if (!pmgntframe)
-               return;
-
-       /* update attribute */
-       pattrib = &pmgntframe->attrib;
-       update_mgntframe_attrib23a(padapter, pattrib);
-
-       memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
-
-       pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
-       mgmt = (struct ieee80211_mgmt *)pframe;
-
-       mgmt->frame_control =
-               cpu_to_le16(IEEE80211_FTYPE_MGMT | IEEE80211_STYPE_AUTH);
-       mgmt->seq_ctrl = cpu_to_le16(IEEE80211_SN_TO_SEQ(pmlmeext->mgnt_seq));
-       pmlmeext->mgnt_seq++;
-
-       pattrib->pktlen = offsetof(struct ieee80211_mgmt, u.auth.variable);
-
-       if (psta) { /*  for AP mode */
-#ifdef CONFIG_8723AU_AP_MODE
-               unsigned short val16;
-
-               ether_addr_copy(mgmt->da, psta->hwaddr);
-               ether_addr_copy(mgmt->sa, myid(&padapter->eeprompriv));
-               ether_addr_copy(mgmt->bssid, myid(&padapter->eeprompriv));
-
-               /*  setting auth algo number */
-               val16 = (u16)psta->authalg;
-
-               if (status != WLAN_STATUS_SUCCESS)
-                       val16 = 0;
-
-               if (val16)
-                       use_shared_key = 1;
-
-               mgmt->u.auth.auth_alg = cpu_to_le16(val16);
-
-               /*  setting auth seq number */
-               mgmt->u.auth.auth_transaction =
-                       cpu_to_le16((u16)psta->auth_seq);
-
-               /*  setting status code... */
-               mgmt->u.auth.status_code = cpu_to_le16(status);
-
-               pframe = mgmt->u.auth.variable;
-               /*  added challenging text... */
-               if ((psta->auth_seq == 2) &&
-                   (psta->state & WIFI_FW_AUTH_STATE) && (use_shared_key == 1))
-                       pframe = rtw_set_ie23a(pframe, WLAN_EID_CHALLENGE, 128,
-                                              psta->chg_txt, &pattrib->pktlen);
-#endif
-       } else {
-               struct ieee80211_mgmt *iv_mgmt;
-
-               ether_addr_copy(mgmt->da, get_my_bssid23a(&pmlmeinfo->network));
-               ether_addr_copy(mgmt->sa, myid(&padapter->eeprompriv));
-               ether_addr_copy(mgmt->bssid,
-                               get_my_bssid23a(&pmlmeinfo->network));
-
-               /*  setting auth algo number */
-               /*  0:OPEN System, 1:Shared key */
-               if (pmlmeinfo->auth_algo == dot11AuthAlgrthm_Shared) {
-                       use_shared_key = 1;
-                       auth_algo = WLAN_AUTH_SHARED_KEY;
-               } else
-                       auth_algo = WLAN_AUTH_OPEN;
-
-               /* DBG_8723A("%s auth_algo = %s auth_seq =%d\n", __func__,
-                  (pmlmeinfo->auth_algo == 0)?"OPEN":"SHARED",
-                  pmlmeinfo->auth_seq); */
-
-               /* setting IV for auth seq #3 */
-               if ((pmlmeinfo->auth_seq == 3) &&
-                   (pmlmeinfo->state & WIFI_FW_AUTH_STATE) &&
-                   (use_shared_key == 1)) {
-                       u32 *piv = (u32 *)&mgmt->u.auth;
-
-                       iv_mgmt = (struct ieee80211_mgmt *)(pframe + 4);
-                       /* DBG_8723A("==> iv(%d), key_index(%d)\n",
-                          pmlmeinfo->iv, pmlmeinfo->key_index); */
-                       val32 = (pmlmeinfo->iv & 0x3fffffff) |
-                               (pmlmeinfo->key_index << 30);
-                       pmlmeinfo->iv++;
-                       put_unaligned_le32(val32, piv);
-
-                       pattrib->pktlen += 4;
-
-                       pattrib->iv_len = IEEE80211_WEP_IV_LEN;
-               } else
-                       iv_mgmt = mgmt;
-
-               iv_mgmt->u.auth.auth_alg = cpu_to_le16(auth_algo);
-
-               /*  setting auth seq number */
-               iv_mgmt->u.auth.auth_transaction =
-                       cpu_to_le16(pmlmeinfo->auth_seq);
-
-               /*  setting status code... */
-               iv_mgmt->u.auth.status_code = cpu_to_le16(status);
-
-               pframe = iv_mgmt->u.auth.variable;
-
-               /*  then checking to see if sending challenging text... */
-               if ((pmlmeinfo->auth_seq == 3) &&
-                   (pmlmeinfo->state & WIFI_FW_AUTH_STATE) &&
-                   (use_shared_key == 1)) {
-                       pframe = rtw_set_ie23a(pframe, WLAN_EID_CHALLENGE, 128,
-                                              pmlmeinfo->chg_txt,
-                                              &pattrib->pktlen);
-
-                       mgmt->frame_control |=
-                               cpu_to_le16(IEEE80211_FCTL_PROTECTED);
-
-                       pattrib->hdrlen = sizeof(struct ieee80211_hdr_3addr);
-
-                       pattrib->encrypt = WLAN_CIPHER_SUITE_WEP40;
-
-                       pattrib->icv_len = IEEE80211_WEP_ICV_LEN;
-
-                       pattrib->pktlen += pattrib->icv_len;
-               }
-       }
-
-       pattrib->last_txcmdsz = pattrib->pktlen;
-
-       rtw_wep_encrypt23a(padapter, pmgntframe);
-       DBG_8723A("%s\n", __func__);
-       dump_mgntframe23a(padapter, pmgntframe);
-}
-
-#ifdef CONFIG_8723AU_AP_MODE
-static void issue_assocrsp(struct rtw_adapter *padapter, unsigned short status,
-                          struct sta_info *pstat, u16 pkt_type)
-{
-       struct xmit_frame *pmgntframe;
-       struct ieee80211_mgmt *mgmt;
-       struct pkt_attrib *pattrib;
-       unsigned char *pframe;
-       struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       struct wlan_bssid_ex *pnetwork = &pmlmeinfo->network;
-       const u8 *p;
-       u8 *ie = pnetwork->IEs;
-
-       DBG_8723A("%s\n", __func__);
-
-       pmgntframe = alloc_mgtxmitframe23a(pxmitpriv);
-       if (!pmgntframe)
-               return;
-
-       /* update attribute */
-       pattrib = &pmgntframe->attrib;
-       update_mgntframe_attrib23a(padapter, pattrib);
-
-       memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
-
-       pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
-       mgmt = (struct ieee80211_mgmt *)pframe;
-
-       mgmt->frame_control = cpu_to_le16(IEEE80211_FTYPE_MGMT | pkt_type);
-
-       ether_addr_copy(mgmt->da, pstat->hwaddr);
-       ether_addr_copy(mgmt->sa, myid(&padapter->eeprompriv));
-       ether_addr_copy(mgmt->bssid, get_my_bssid23a(&pmlmeinfo->network));
-
-       mgmt->seq_ctrl = cpu_to_le16(IEEE80211_SN_TO_SEQ(pmlmeext->mgnt_seq));
-
-       pmlmeext->mgnt_seq++;
-
-       pattrib->hdrlen = sizeof(struct ieee80211_hdr_3addr);
-       pattrib->pktlen =
-               offsetof(struct ieee80211_mgmt, u.assoc_resp.variable);
-
-       mgmt->u.assoc_resp.capab_info = cpu_to_le16(pnetwork->capability);
-       mgmt->u.assoc_resp.status_code = cpu_to_le16(status);
-       mgmt->u.assoc_resp.aid = cpu_to_le16(pstat->aid | BIT(14) | BIT(15));
-
-       pframe = mgmt->u.assoc_resp.variable;
-
-       if (pstat->bssratelen <= 8) {
-               pframe = rtw_set_ie23a(pframe, WLAN_EID_SUPP_RATES,
-                                      pstat->bssratelen, pstat->bssrateset,
-                                      &pattrib->pktlen);
-       } else {
-               pframe = rtw_set_ie23a(pframe, WLAN_EID_SUPP_RATES, 8,
-                                      pstat->bssrateset, &pattrib->pktlen);
-               pframe = rtw_set_ie23a(pframe, WLAN_EID_EXT_SUPP_RATES,
-                                      pstat->bssratelen - 8,
-                                      pstat->bssrateset + 8, &pattrib->pktlen);
-       }
-
-       if (pstat->flags & WLAN_STA_HT && pmlmepriv->htpriv.ht_option) {
-               /* FILL HT CAP INFO IE */
-               /* p = hostapd_eid_ht_capabilities_info(hapd, p); */
-               p = cfg80211_find_ie(WLAN_EID_HT_CAPABILITY, ie,
-                                    pnetwork->IELength);
-               if (p && p[1]) {
-                       memcpy(pframe, p, p[1] + 2);
-                       pframe += (p[1] + 2);
-                       pattrib->pktlen += (p[1] + 2);
-               }
-
-               /* FILL HT ADD INFO IE */
-               /* p = hostapd_eid_ht_operation(hapd, p); */
-               p = cfg80211_find_ie(WLAN_EID_HT_OPERATION, ie,
-                                    pnetwork->IELength);
-               if (p && p[1] > 0) {
-                       memcpy(pframe, p, p[1] + 2);
-                       pframe += (p[1] + 2);
-                       pattrib->pktlen += (p[1] + 2);
-               }
-       }
-
-       /* FILL WMM IE */
-       if (pstat->flags & WLAN_STA_WME && pmlmepriv->qos_option) {
-               unsigned char WMM_PARA_IE[] = {0x00, 0x50, 0xf2, 0x02,
-                                              0x01, 0x01};
-               int ie_len = 0;
-
-               for (p = ie; ; p += (ie_len + 2)) {
-                       p = cfg80211_find_ie(WLAN_EID_VENDOR_SPECIFIC, p,
-                                            pnetwork->IELength - (ie_len + 2));
-                       if (p)
-                               ie_len = p[1];
-                       else
-                               ie_len = 0;
-                       if (p && !memcmp(p + 2, WMM_PARA_IE, 6)) {
-                               memcpy(pframe, p, ie_len + 2);
-                               pframe += (ie_len + 2);
-                               pattrib->pktlen += (ie_len + 2);
-
-                               break;
-                       }
-
-                       if (!p || ie_len == 0)
-                               break;
-               }
-       }
-
-       if (pmlmeinfo->assoc_AP_vendor == HT_IOT_PEER_REALTEK) {
-               pframe = rtw_set_ie23a(pframe, WLAN_EID_VENDOR_SPECIFIC, 6,
-                                      REALTEK_96B_IE, &pattrib->pktlen);
-       }
-
-       pattrib->last_txcmdsz = pattrib->pktlen;
-
-       dump_mgntframe23a(padapter, pmgntframe);
-}
-#endif
-
-static void issue_assocreq(struct rtw_adapter *padapter)
-{
-       int ret = _FAIL;
-       struct xmit_frame *pmgntframe;
-       struct pkt_attrib *pattrib;
-       unsigned char *pframe;
-       const u8 *p;
-       struct ieee80211_mgmt *mgmt;
-       unsigned int i, j, index = 0;
-       unsigned char rf_type, bssrate[NumRates], sta_bssrate[NumRates];
-       struct registry_priv *pregpriv = &padapter->registrypriv;
-       struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       int bssrate_len = 0, sta_bssrate_len = 0, pie_len;
-       u8 *pie;
-
-       pmgntframe = alloc_mgtxmitframe23a(pxmitpriv);
-       if (!pmgntframe)
-               goto exit;
-
-       /* update attribute */
-       pattrib = &pmgntframe->attrib;
-       update_mgntframe_attrib23a(padapter, pattrib);
-
-       memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
-
-       pframe = (u8 *)pmgntframe->buf_addr + TXDESC_OFFSET;
-       mgmt = (struct ieee80211_mgmt *)pframe;
-
-       mgmt->frame_control =
-               cpu_to_le16(IEEE80211_FTYPE_MGMT | IEEE80211_STYPE_ASSOC_REQ);
-
-       ether_addr_copy(mgmt->da, get_my_bssid23a(&pmlmeinfo->network));
-       ether_addr_copy(mgmt->sa, myid(&padapter->eeprompriv));
-       ether_addr_copy(mgmt->bssid, get_my_bssid23a(&pmlmeinfo->network));
-
-       mgmt->seq_ctrl = cpu_to_le16(IEEE80211_SN_TO_SEQ(pmlmeext->mgnt_seq));
-       pmlmeext->mgnt_seq++;
-
-       /* caps */
-       put_unaligned_le16(pmlmeinfo->network.capability,
-                          &mgmt->u.assoc_req.capab_info);
-       /* todo: listen interval for power saving */
-       put_unaligned_le16(3, &mgmt->u.assoc_req.listen_interval);
-
-       pframe = mgmt->u.assoc_req.variable;
-       pattrib->pktlen = offsetof(struct ieee80211_mgmt, u.assoc_req.variable);
-
-       /* SSID */
-       pframe = rtw_set_ie23a(pframe, WLAN_EID_SSID,
-                              pmlmeinfo->network.Ssid.ssid_len,
-                              pmlmeinfo->network.Ssid.ssid, &pattrib->pktlen);
-
-       /* supported rate & extended supported rate */
-
-       get_rate_set23a(padapter, sta_bssrate, &sta_bssrate_len);
-       /* DBG_8723A("sta_bssrate_len =%d\n", sta_bssrate_len); */
-
-       /*  for JAPAN, channel 14 can only uses B Mode(CCK) */
-       if (pmlmeext->cur_channel == 14)
-               sta_bssrate_len = 4;
-
-       /* for (i = 0; i < sta_bssrate_len; i++) { */
-       /*      DBG_8723A("sta_bssrate[%d]=%02X\n", i, sta_bssrate[i]); */
-       /*  */
-
-       for (i = 0; i < NDIS_802_11_LENGTH_RATES_EX; i++) {
-               if (pmlmeinfo->network.SupportedRates[i] == 0)
-                       break;
-               DBG_8723A("network.SupportedRates[%d]=%02X\n", i,
-                         pmlmeinfo->network.SupportedRates[i]);
-       }
-
-       for (i = 0; i < NDIS_802_11_LENGTH_RATES_EX; i++) {
-               if (pmlmeinfo->network.SupportedRates[i] == 0)
-                       break;
-
-               /*  Check if the AP's supported rates are also
-                   supported by STA. */
-               for (j = 0; j < sta_bssrate_len; j++) {
-                        /*  Avoid the proprietary data rate (22Mbps) of
-                            Handlink WSG-4000 AP */
-                       if ((pmlmeinfo->network.SupportedRates[i] |
-                            IEEE80211_BASIC_RATE_MASK) ==
-                           (sta_bssrate[j] | IEEE80211_BASIC_RATE_MASK)) {
-                               /* DBG_8723A("match i = %d, j =%d\n", i, j); */
-                               break;
-                       }
-               }
-
-               if (j == sta_bssrate_len) {
-                       /*  the rate is not supported by STA */
-                       DBG_8723A("%s(): the rate[%d]=%02X is not supported by "
-                                 "STA!\n", __func__, i,
-                                 pmlmeinfo->network.SupportedRates[i]);
-               } else {
-                       /*  the rate is supported by STA */
-                       bssrate[index++] = pmlmeinfo->network.SupportedRates[i];
-               }
-       }
-
-       bssrate_len = index;
-       DBG_8723A("bssrate_len = %d\n", bssrate_len);
-
-       if (bssrate_len == 0) {
-               rtw_free_xmitbuf23a(pxmitpriv, pmgntframe->pxmitbuf);
-               rtw_free_xmitframe23a(pxmitpriv, pmgntframe);
-               goto exit; /* don't connect to AP if no joint supported rate */
-       }
-
-       if (bssrate_len > 8) {
-               pframe = rtw_set_ie23a(pframe, WLAN_EID_SUPP_RATES, 8,
-                                      bssrate, &pattrib->pktlen);
-               pframe = rtw_set_ie23a(pframe, WLAN_EID_EXT_SUPP_RATES,
-                                      (bssrate_len - 8), (bssrate + 8),
-                                      &pattrib->pktlen);
-       } else
-               pframe = rtw_set_ie23a(pframe, WLAN_EID_SUPP_RATES,
-                                      bssrate_len, bssrate, &pattrib->pktlen);
-
-       /* RSN */
-
-       pie = pmlmeinfo->network.IEs;
-       pie_len = pmlmeinfo->network.IELength;
-
-       p = cfg80211_find_ie(WLAN_EID_RSN, pie, pie_len);
-       if (p)
-               pframe = rtw_set_ie23a(pframe, WLAN_EID_RSN, p[1], p + 2,
-                                      &pattrib->pktlen);
-
-       /* HT caps */
-       if (padapter->mlmepriv.htpriv.ht_option) {
-               p = cfg80211_find_ie(WLAN_EID_HT_CAPABILITY, pie, pie_len);
-
-               if (p && !is_ap_in_tkip23a(padapter)) {
-                       struct ieee80211_ht_cap *cap = &pmlmeinfo->ht_cap;
-
-                       memcpy(cap, p + 2, sizeof(struct ieee80211_ht_cap));
-
-                       /* to disable 40M Hz support while gd_bw_40MHz_en = 0 */
-                       if (pregpriv->cbw40_enable == 0) {
-                               cap->cap_info &= ~cpu_to_le16(
-                                       IEEE80211_HT_CAP_SGI_40 |
-                                       IEEE80211_HT_CAP_SUP_WIDTH_20_40);
-                       } else {
-                               cap->cap_info |= cpu_to_le16(
-                                       IEEE80211_HT_CAP_SUP_WIDTH_20_40);
-                       }
-
-                       /* todo: disable SM power save mode */
-                       cap->cap_info |= cpu_to_le16(IEEE80211_HT_CAP_SM_PS);
-
-                       rf_type = rtl8723a_get_rf_type(padapter);
-                       /* switch (pregpriv->rf_config) */
-                       switch (rf_type) {
-                       case RF_1T1R:
-                               /* RX STBC One spatial stream */
-                               if (pregpriv->rx_stbc)
-                                       cap->cap_info |= cpu_to_le16(1 << IEEE80211_HT_CAP_RX_STBC_SHIFT);
-
-                               memcpy(&cap->mcs, MCS_rate_1R23A, 16);
-                               break;
-
-                       case RF_2T2R:
-                       case RF_1T2R:
-                       default:
-                               /* enable for 2.4/5 GHz */
-                               if (pregpriv->rx_stbc == 0x3 ||
-                                   (pmlmeext->cur_wireless_mode &
-                                    WIRELESS_11_24N &&
-                                    /* enable for 2.4GHz */
-                                    pregpriv->rx_stbc == 0x1) ||
-                                   (pmlmeext->cur_wireless_mode &
-                                    WIRELESS_11_5N &&
-                                    pregpriv->rx_stbc == 0x2) ||
-                                   /* enable for 5GHz */
-                                   pregpriv->wifi_spec == 1) {
-                                       DBG_8723A("declare supporting RX "
-                                                 "STBC\n");
-                                       /* RX STBC two spatial stream */
-                                       cap->cap_info |= cpu_to_le16(2 << IEEE80211_HT_CAP_RX_STBC_SHIFT);
-                               }
-                               memcpy(&cap->mcs, MCS_rate_2R23A, 16);
-                               break;
-                       }
-
-                       if (rtl8723a_BT_coexist(padapter) &&
-                           rtl8723a_BT_using_antenna_1(padapter)) {
-                               /*  set to 8K */
-                               cap->ampdu_params_info &=
-                                       ~IEEE80211_HT_AMPDU_PARM_FACTOR;
-/*                             cap->ampdu_params_info |= MAX_AMPDU_FACTOR_8K */
-                       }
-
-                       pframe = rtw_set_ie23a(pframe, WLAN_EID_HT_CAPABILITY,
-                                              p[1], (u8 *)&pmlmeinfo->ht_cap,
-                                              &pattrib->pktlen);
-               }
-       }
-
-       /* vendor specific IE, such as WPA, WMM, WPS */
-       for (i = 0;  i < pmlmeinfo->network.IELength;) {
-               p = pmlmeinfo->network.IEs + i;
-
-               switch (p[0]) {
-               case WLAN_EID_VENDOR_SPECIFIC:
-                       if (!memcmp(p + 2, RTW_WPA_OUI23A_TYPE, 4) ||
-                           !memcmp(p + 2, WMM_OUI23A, 4) ||
-                           !memcmp(p + 2, WPS_OUI23A, 4)) {
-                               u8 plen = p[1];
-
-                               if (!padapter->registrypriv.wifi_spec) {
-                                       /* Commented by Kurt 20110629 */
-                                       /* In some older APs, WPS handshake */
-                                       /* would be fail if we append vender
-                                          extensions informations to AP */
-                                       if (!memcmp(p + 2, WPS_OUI23A, 4))
-                                               plen = 14;
-                               }
-                               pframe = rtw_set_ie23a(pframe,
-                                                      WLAN_EID_VENDOR_SPECIFIC,
-                                                      plen, p + 2,
-                                                      &pattrib->pktlen);
-                       }
-                       break;
-
-               default:
-                       break;
-               }
-
-               i += p[1] + 2;
-       }
-
-       if (pmlmeinfo->assoc_AP_vendor == HT_IOT_PEER_REALTEK)
-               pframe = rtw_set_ie23a(pframe, WLAN_EID_VENDOR_SPECIFIC, 6,
-                                      REALTEK_96B_IE, &pattrib->pktlen);
-
-       pattrib->last_txcmdsz = pattrib->pktlen;
-       dump_mgntframe23a(padapter, pmgntframe);
-
-       ret = _SUCCESS;
-
-exit:
-       pmlmepriv->assoc_req_len = 0;
-       if (ret == _SUCCESS) {
-               kfree(pmlmepriv->assoc_req);
-               pmlmepriv->assoc_req = kmalloc(pattrib->pktlen, GFP_ATOMIC);
-               if (pmlmepriv->assoc_req) {
-                       memcpy(pmlmepriv->assoc_req, mgmt, pattrib->pktlen);
-                       pmlmepriv->assoc_req_len = pattrib->pktlen;
-               }
-       } else
-               kfree(pmlmepriv->assoc_req);
-}
-
-/* when wait_ack is true, this function should be called at process context */
-static int _issue_nulldata23a(struct rtw_adapter *padapter, unsigned char *da,
-                             unsigned int power_mode, int wait_ack)
-{
-       int ret = _FAIL;
-       struct xmit_frame *pmgntframe;
-       struct pkt_attrib *pattrib;
-       unsigned char *pframe;
-       struct ieee80211_hdr *pwlanhdr;
-       struct xmit_priv *pxmitpriv;
-       struct mlme_ext_priv *pmlmeext;
-       struct mlme_ext_info *pmlmeinfo;
-
-       /* DBG_8723A("%s:%d\n", __func__, power_mode); */
-
-       if (!padapter)
-               goto exit;
-
-       pxmitpriv = &padapter->xmitpriv;
-       pmlmeext = &padapter->mlmeextpriv;
-       pmlmeinfo = &pmlmeext->mlmext_info;
-
-       pmgntframe = alloc_mgtxmitframe23a(pxmitpriv);
-       if (!pmgntframe)
-               goto exit;
-
-       /* update attribute */
-       pattrib = &pmgntframe->attrib;
-       update_mgntframe_attrib23a(padapter, pattrib);
-       pattrib->retry_ctrl = false;
-
-       memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
-
-       pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
-       pwlanhdr = (struct ieee80211_hdr *)pframe;
-
-       pwlanhdr->frame_control = cpu_to_le16(IEEE80211_FTYPE_DATA |
-                                             IEEE80211_STYPE_NULLFUNC);
-
-       if ((pmlmeinfo->state&0x03) == MSR_AP)
-               pwlanhdr->frame_control |= cpu_to_le16(IEEE80211_FCTL_FROMDS);
-       else if ((pmlmeinfo->state&0x03) == MSR_INFRA)
-               pwlanhdr->frame_control |= cpu_to_le16(IEEE80211_FCTL_TODS);
-
-       if (power_mode)
-               pwlanhdr->frame_control |= cpu_to_le16(IEEE80211_FCTL_PM);
-
-       ether_addr_copy(pwlanhdr->addr1, da);
-       ether_addr_copy(pwlanhdr->addr2, myid(&padapter->eeprompriv));
-       ether_addr_copy(pwlanhdr->addr3, get_my_bssid23a(&pmlmeinfo->network));
-
-       pwlanhdr->seq_ctrl =
-               cpu_to_le16(IEEE80211_SN_TO_SEQ(pmlmeext->mgnt_seq));
-       pmlmeext->mgnt_seq++;
-
-       pframe += sizeof(struct ieee80211_hdr_3addr);
-       pattrib->pktlen = sizeof(struct ieee80211_hdr_3addr);
-
-       pattrib->last_txcmdsz = pattrib->pktlen;
-
-       if (wait_ack)
-               ret = dump_mgntframe23a_and_wait_ack23a(padapter, pmgntframe);
-       else {
-               dump_mgntframe23a(padapter, pmgntframe);
-               ret = _SUCCESS;
-       }
-
-exit:
-       return ret;
-}
-
-/* when wait_ms >0 , this function should be called at process context */
-/* da == NULL for station mode */
-int issue_nulldata23a(struct rtw_adapter *padapter, unsigned char *da,
-                     unsigned int power_mode, int try_cnt, int wait_ms)
-{
-       int ret;
-       int i = 0;
-       unsigned long start = jiffies;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-
-       /* da == NULL, assume it's null data for sta to ap*/
-       if (da == NULL)
-               da = get_my_bssid23a(&pmlmeinfo->network);
-
-       do {
-               ret = _issue_nulldata23a(padapter, da, power_mode,
-                                        wait_ms > 0 ? true : false);
-
-               i++;
-
-               if (padapter->bDriverStopped || padapter->bSurpriseRemoved)
-                       break;
-
-               if (i < try_cnt && wait_ms > 0 && ret == _FAIL)
-                       msleep(wait_ms);
-
-       } while((i < try_cnt) && ((ret == _FAIL) || (wait_ms == 0)));
-
-       if (ret != _FAIL) {
-               ret = _SUCCESS;
-               goto exit;
-       }
-
-       if (try_cnt && wait_ms) {
-               if (da)
-                       DBG_8723A("%s(%s): to %pM, ch:%u%s, %d/%d in %u ms\n",
-                                 __func__, padapter->pnetdev->name,
-                                 da, rtw_get_oper_ch23a(padapter),
-                                 ret == _SUCCESS ? ", acked" : "", i, try_cnt,
-                                 jiffies_to_msecs(jiffies - start));
-               else
-                       DBG_8723A("%s(%s):, ch:%u%s, %d/%d in %u ms\n",
-                                 __func__, padapter->pnetdev->name,
-                                 rtw_get_oper_ch23a(padapter),
-                                 ret == _SUCCESS ? ", acked" : "", i, try_cnt,
-                                 jiffies_to_msecs(jiffies - start));
-       }
-exit:
-       return ret;
-}
-
-/* when wait_ack is true, this function should be called at process context */
-static int _issue_qos_nulldata23a(struct rtw_adapter *padapter,
-                                 unsigned char *da, u16 tid, int wait_ack)
-{
-       int ret = _FAIL;
-       struct xmit_frame *pmgntframe;
-       struct pkt_attrib *pattrib;
-       unsigned char *pframe;
-       struct ieee80211_qos_hdr *pwlanhdr;
-       struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-
-       DBG_8723A("%s\n", __func__);
-
-       pmgntframe = alloc_mgtxmitframe23a(pxmitpriv);
-       if (!pmgntframe)
-               goto exit;
-
-       /* update attribute */
-       pattrib = &pmgntframe->attrib;
-       update_mgntframe_attrib23a(padapter, pattrib);
-
-       pattrib->hdrlen += 2;
-       pattrib->qos_en = true;
-       pattrib->eosp = 1;
-       pattrib->ack_policy = 0;
-       pattrib->mdata = 0;
-
-       memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
-
-       pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
-       pwlanhdr = (struct ieee80211_qos_hdr *)pframe;
-
-       pwlanhdr->frame_control = cpu_to_le16(IEEE80211_FTYPE_DATA |
-                                             IEEE80211_STYPE_QOS_NULLFUNC);
-
-       if ((pmlmeinfo->state&0x03) == MSR_AP)
-               pwlanhdr->frame_control |= cpu_to_le16(IEEE80211_FCTL_FROMDS);
-       else if ((pmlmeinfo->state&0x03) == MSR_INFRA)
-               pwlanhdr->frame_control |= cpu_to_le16(IEEE80211_FCTL_TODS);
-
-       if (pattrib->mdata)
-               pwlanhdr->frame_control |= cpu_to_le16(IEEE80211_FCTL_MOREDATA);
-
-       pwlanhdr->qos_ctrl = cpu_to_le16(tid & IEEE80211_QOS_CTL_TID_MASK);
-       pwlanhdr->qos_ctrl |= cpu_to_le16((pattrib->ack_policy << 5) &
-                                         IEEE80211_QOS_CTL_ACK_POLICY_MASK);
-       if (pattrib->eosp)
-               pwlanhdr->qos_ctrl |= cpu_to_le16(IEEE80211_QOS_CTL_EOSP);
-
-       ether_addr_copy(pwlanhdr->addr1, da);
-       ether_addr_copy(pwlanhdr->addr2, myid(&padapter->eeprompriv));
-       ether_addr_copy(pwlanhdr->addr3, get_my_bssid23a(&pmlmeinfo->network));
-
-       pwlanhdr->seq_ctrl =
-               cpu_to_le16(IEEE80211_SN_TO_SEQ(pmlmeext->mgnt_seq));
-       pmlmeext->mgnt_seq++;
-
-       pframe += sizeof(struct ieee80211_qos_hdr);
-       pattrib->pktlen = sizeof(struct ieee80211_qos_hdr);
-
-       pattrib->last_txcmdsz = pattrib->pktlen;
-
-       if (wait_ack)
-               ret = dump_mgntframe23a_and_wait_ack23a(padapter, pmgntframe);
-       else {
-               dump_mgntframe23a(padapter, pmgntframe);
-               ret = _SUCCESS;
-       }
-
-exit:
-       return ret;
-}
-
-/* when wait_ms >0 , this function should be called at process context */
-/* da == NULL for station mode */
-int issue_qos_nulldata23a(struct rtw_adapter *padapter, unsigned char *da,
-                         u16 tid, int try_cnt, int wait_ms)
-{
-       int ret;
-       int i = 0;
-       unsigned long start = jiffies;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-
-       /* da == NULL, assume it's null data for sta to ap*/
-       if (da == NULL)
-               da = get_my_bssid23a(&pmlmeinfo->network);
-
-       do {
-               ret = _issue_qos_nulldata23a(padapter, da, tid,
-                                            wait_ms > 0 ? true : false);
-
-               i++;
-
-               if (padapter->bDriverStopped || padapter->bSurpriseRemoved)
-                       break;
-
-               if (i < try_cnt && wait_ms > 0 && ret == _FAIL)
-                       msleep(wait_ms);
-       } while((i < try_cnt) && ((ret == _FAIL)||(wait_ms == 0)));
-
-       if (ret != _FAIL) {
-               ret = _SUCCESS;
-               goto exit;
-       }
-
-       if (try_cnt && wait_ms) {
-               if (da)
-                       DBG_8723A("%s(%s): to %pM, ch:%u%s, %d/%d in %u ms\n",
-                                 __func__, padapter->pnetdev->name,
-                                 da, rtw_get_oper_ch23a(padapter),
-                                 ret == _SUCCESS ? ", acked" : "", i, try_cnt,
-                                 jiffies_to_msecs(jiffies - start));
-               else
-                       DBG_8723A("%s(%s):, ch:%u%s, %d/%d in %u ms\n",
-                                 __func__, padapter->pnetdev->name,
-                                 rtw_get_oper_ch23a(padapter),
-                                 ret == _SUCCESS ? ", acked" : "", i, try_cnt,
-                                 jiffies_to_msecs(jiffies - start));
-       }
-exit:
-       return ret;
-}
-
-static int _issue_deauth(struct rtw_adapter *padapter, unsigned char *da,
-                        unsigned short reason, u8 wait_ack)
-{
-       struct xmit_frame *pmgntframe;
-       struct pkt_attrib *pattrib;
-       struct ieee80211_mgmt *mgmt;
-       struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       int ret = _FAIL;
-
-       /* DBG_8723A("%s to %pM\n", __func__, da); */
-
-       pmgntframe = alloc_mgtxmitframe23a(pxmitpriv);
-       if (!pmgntframe)
-               goto exit;
-
-       /* update attribute */
-       pattrib = &pmgntframe->attrib;
-       update_mgntframe_attrib23a(padapter, pattrib);
-       pattrib->retry_ctrl = false;
-
-       memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
-
-       mgmt = (struct ieee80211_mgmt *)(pmgntframe->buf_addr + TXDESC_OFFSET);
-
-       mgmt->frame_control =
-               cpu_to_le16(IEEE80211_FTYPE_MGMT | IEEE80211_STYPE_DEAUTH);
-
-       ether_addr_copy(mgmt->da, da);
-       ether_addr_copy(mgmt->sa, myid(&padapter->eeprompriv));
-       ether_addr_copy(mgmt->bssid, get_my_bssid23a(&pmlmeinfo->network));
-
-       mgmt->seq_ctrl = cpu_to_le16(IEEE80211_SN_TO_SEQ(pmlmeext->mgnt_seq));
-       pmlmeext->mgnt_seq++;
-
-       pattrib->pktlen = sizeof(struct ieee80211_hdr_3addr) + 2;
-
-       mgmt->u.deauth.reason_code = cpu_to_le16(reason);
-
-       pattrib->last_txcmdsz = pattrib->pktlen;
-
-       if (wait_ack)
-               ret = dump_mgntframe23a_and_wait_ack23a(padapter, pmgntframe);
-       else {
-               dump_mgntframe23a(padapter, pmgntframe);
-               ret = _SUCCESS;
-       }
-
-exit:
-       return ret;
-}
-
-int issue_deauth23a(struct rtw_adapter *padapter, unsigned char *da,
-                   unsigned short reason)
-{
-       DBG_8723A("%s to %pM\n", __func__, da);
-       return _issue_deauth(padapter, da, reason, false);
-}
-
-static int issue_deauth_ex(struct rtw_adapter *padapter, u8 *da,
-                          unsigned short reason, int try_cnt, int wait_ms)
-{
-       int ret;
-       int i = 0;
-       unsigned long start = jiffies;
-
-       do {
-               ret = _issue_deauth(padapter, da, reason,
-                                   wait_ms >0 ? true : false);
-
-               i++;
-
-               if (padapter->bDriverStopped || padapter->bSurpriseRemoved)
-                       break;
-
-               if (i < try_cnt && wait_ms > 0 && ret == _FAIL)
-                       msleep(wait_ms);
-
-       } while((i < try_cnt) && ((ret == _FAIL)||(wait_ms == 0)));
-
-       if (ret != _FAIL) {
-               ret = _SUCCESS;
-               goto exit;
-       }
-
-       if (try_cnt && wait_ms) {
-               if (da)
-                       DBG_8723A("%s(%s): to %pM, ch:%u%s, %d/%d in %u ms\n",
-                                 __func__, padapter->pnetdev->name,
-                                 da, rtw_get_oper_ch23a(padapter),
-                                 ret == _SUCCESS ? ", acked" : "", i, try_cnt,
-                                 jiffies_to_msecs(jiffies - start));
-               else
-                       DBG_8723A("%s(%s):, ch:%u%s, %d/%d in %u ms\n",
-                                 __func__, padapter->pnetdev->name,
-                                 rtw_get_oper_ch23a(padapter),
-                                 ret == _SUCCESS ? ", acked" : "", i, try_cnt,
-                                 jiffies_to_msecs(jiffies - start));
-       }
-exit:
-       return ret;
-}
-
-void issue_action_spct_ch_switch23a(struct rtw_adapter *padapter,
-                                   u8 *ra, u8 new_ch, u8 ch_offset)
-{
-       struct xmit_frame *pmgntframe;
-       struct pkt_attrib *pattrib;
-       unsigned char *pframe;
-       struct ieee80211_mgmt *mgmt;
-       struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-
-       DBG_8723A("%s(%s): ra=%pM, ch:%u, offset:%u\n",
-                 __func__, padapter->pnetdev->name, ra, new_ch, ch_offset);
-
-       pmgntframe = alloc_mgtxmitframe23a(pxmitpriv);
-       if (!pmgntframe)
-               return;
-
-       /* update attribute */
-       pattrib = &pmgntframe->attrib;
-       update_mgntframe_attrib23a(padapter, pattrib);
-
-       memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
-
-       mgmt = (struct ieee80211_mgmt *)(pmgntframe->buf_addr + TXDESC_OFFSET);
-
-       mgmt->frame_control =
-               cpu_to_le16(IEEE80211_FTYPE_MGMT | IEEE80211_STYPE_ACTION);
-
-       ether_addr_copy(mgmt->da, ra); /* RA */
-       ether_addr_copy(mgmt->sa, myid(&padapter->eeprompriv)); /* TA */
-       ether_addr_copy(mgmt->bssid, ra); /* DA = RA */
-
-       mgmt->seq_ctrl = cpu_to_le16(IEEE80211_SN_TO_SEQ(pmlmeext->mgnt_seq));
-       pmlmeext->mgnt_seq++;
-
-       mgmt->u.action.category = WLAN_CATEGORY_SPECTRUM_MGMT;
-       mgmt->u.action.u.chan_switch.action_code = WLAN_ACTION_SPCT_CHL_SWITCH;
-
-       pframe = mgmt->u.action.u.chan_switch.variable;
-       pattrib->pktlen = offsetof(struct ieee80211_mgmt,
-                                  u.action.u.chan_switch.variable);
-
-       pframe = rtw_set_ie23a_ch_switch (pframe, &pattrib->pktlen, 0,
-                                         new_ch, 0);
-       pframe = rtw_set_ie23a_secondary_ch_offset(pframe, &pattrib->pktlen,
-               hal_ch_offset_to_secondary_ch_offset23a(ch_offset));
-
-       pattrib->last_txcmdsz = pattrib->pktlen;
-
-       dump_mgntframe23a(padapter, pmgntframe);
-}
-
-void issue_action_BA23a(struct rtw_adapter *padapter,
-                       const unsigned char *raddr,
-                       unsigned char action, unsigned short status)
-{
-       u16 start_seq;
-       u16 BA_para_set;
-       u16 BA_starting_seqctrl;
-       u16 BA_para;
-       int max_rx_ampdu_factor;
-       struct xmit_frame *pmgntframe;
-       struct pkt_attrib *pattrib;
-       struct ieee80211_mgmt *mgmt;
-       struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       struct sta_info *psta;
-       struct sta_priv *pstapriv = &padapter->stapriv;
-       struct registry_priv *pregpriv = &padapter->registrypriv;
-       u8 tendaAPMac[] = {0xC8, 0x3A, 0x35};
-
-       DBG_8723A("%s, action =%d, status =%d\n", __func__, action, status);
-
-       pmgntframe = alloc_mgtxmitframe23a(pxmitpriv);
-       if (!pmgntframe)
-               return;
-
-       /* update attribute */
-       pattrib = &pmgntframe->attrib;
-       update_mgntframe_attrib23a(padapter, pattrib);
-
-       memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
-
-       mgmt = (struct ieee80211_mgmt *)(pmgntframe->buf_addr + TXDESC_OFFSET);
-
-       mgmt->frame_control =
-               cpu_to_le16(IEEE80211_FTYPE_MGMT | IEEE80211_STYPE_ACTION);
-
-       ether_addr_copy(mgmt->da, raddr);
-       ether_addr_copy(mgmt->sa, myid(&padapter->eeprompriv));
-       ether_addr_copy(mgmt->bssid, get_my_bssid23a(&pmlmeinfo->network));
-
-       mgmt->seq_ctrl = cpu_to_le16(IEEE80211_SN_TO_SEQ(pmlmeext->mgnt_seq));
-       pmlmeext->mgnt_seq++;
-
-       mgmt->u.action.category = WLAN_CATEGORY_BACK;
-
-       pattrib->pktlen = sizeof(struct ieee80211_hdr_3addr) + 1;
-
-       switch (action) {
-       case WLAN_ACTION_ADDBA_REQ:
-               pattrib->pktlen += sizeof(mgmt->u.action.u.addba_req);
-
-               mgmt->u.action.u.addba_req.action_code = action;
-
-               do {
-                       pmlmeinfo->dialogToken++;
-               } while (pmlmeinfo->dialogToken == 0);
-
-               mgmt->u.action.u.addba_req.dialog_token =
-                       pmlmeinfo->dialogToken;
-
-               if (rtl8723a_BT_coexist(padapter) &&
-                   rtl8723a_BT_using_antenna_1(padapter) &&
-                   (pmlmeinfo->assoc_AP_vendor != broadcomAP ||
-                    memcmp(raddr, tendaAPMac, 3))) {
-                       /*  A-MSDU NOT Supported */
-                       BA_para_set = 0;
-                       /*  immediate Block Ack */
-                       BA_para_set |= (1 << 1) &
-                               IEEE80211_ADDBA_PARAM_POLICY_MASK;
-                       /*  TID */
-                       BA_para_set |= (status << 2) &
-                               IEEE80211_ADDBA_PARAM_TID_MASK;
-                       /*  max buffer size is 8 MSDU */
-                       BA_para_set |= (8 << 6) &
-                               IEEE80211_ADDBA_PARAM_BUF_SIZE_MASK;
-               } else {
-                       /* immediate ack & 64 buffer size */
-                       BA_para_set = 0x1002 | ((status & 0xf) << 2);
-               }
-
-               put_unaligned_le16(BA_para_set,
-                                  &mgmt->u.action.u.addba_req.capab);
-
-               /*  5ms */
-               put_unaligned_le16(5000, &mgmt->u.action.u.addba_req.timeout);
-
-               psta = rtw_get_stainfo23a(pstapriv, raddr);
-               if (psta) {
-                       int idx;
-
-                       idx = status & 0x07;
-                       start_seq =
-                               (psta->sta_xmitpriv.txseq_tid[idx] & 0xfff) + 1;
-
-                       DBG_8723A("BA_starting_seqctrl = %d for TID =%d\n",
-                                 start_seq, idx);
-
-                       psta->BA_starting_seqctrl[idx] = start_seq;
-
-                       BA_starting_seqctrl = start_seq << 4;
-               } else
-                       BA_starting_seqctrl = 0;
-
-               put_unaligned_le16(BA_starting_seqctrl,
-                                  &mgmt->u.action.u.addba_req.start_seq_num);
-
-               break;
-
-       case WLAN_ACTION_ADDBA_RESP:
-               pattrib->pktlen += sizeof(mgmt->u.action.u.addba_resp);
-
-               mgmt->u.action.u.addba_resp.action_code = action;
-               mgmt->u.action.u.addba_resp.dialog_token =
-                       pmlmeinfo->ADDBA_req.dialog_token;
-               put_unaligned_le16(status,
-                                  &mgmt->u.action.u.addba_resp.status);
-
-               GetHalDefVar8192CUsb(padapter, HW_VAR_MAX_RX_AMPDU_FACTOR,
-                                    &max_rx_ampdu_factor);
-
-               BA_para = le16_to_cpu(pmlmeinfo->ADDBA_req.BA_para_set) & 0x3f;
-               if (max_rx_ampdu_factor == IEEE80211_HT_MAX_AMPDU_64K)
-                       BA_para_set = BA_para | 0x1000; /* 64 buffer size */
-               else if (max_rx_ampdu_factor == IEEE80211_HT_MAX_AMPDU_32K)
-                       BA_para_set = BA_para | 0x0800; /* 32 buffer size */
-               else if (max_rx_ampdu_factor == IEEE80211_HT_MAX_AMPDU_16K)
-                       BA_para_set = BA_para | 0x0400; /* 16 buffer size */
-               else if (max_rx_ampdu_factor == IEEE80211_HT_MAX_AMPDU_8K)
-                       BA_para_set = BA_para | 0x0200; /* 8 buffer size */
-               else
-                       BA_para_set = BA_para | 0x1000; /* 64 buffer size */
-
-               if (rtl8723a_BT_coexist(padapter) &&
-                   rtl8723a_BT_using_antenna_1(padapter) &&
-                   (pmlmeinfo->assoc_AP_vendor != broadcomAP ||
-                    memcmp(raddr, tendaAPMac, 3))) {
-                       /*  max buffer size is 8 MSDU */
-                       BA_para_set &= ~IEEE80211_ADDBA_PARAM_BUF_SIZE_MASK;
-                       BA_para_set |= (8 << 6) &
-                               IEEE80211_ADDBA_PARAM_BUF_SIZE_MASK;
-               }
-
-               if (pregpriv->ampdu_amsdu == 0)/* disabled */
-                       BA_para_set &= ~BIT(0);
-               else if (pregpriv->ampdu_amsdu == 1)/* enabled */
-                       BA_para_set |= BIT(0);
-
-               put_unaligned_le16(BA_para_set,
-                                  &mgmt->u.action.u.addba_resp.capab);
-
-               mgmt->u.action.u.addba_resp.timeout
-                       = pmlmeinfo->ADDBA_req.BA_timeout_value;
-
-               pattrib->pktlen += 8;
-               break;
-       case WLAN_ACTION_DELBA:
-               pattrib->pktlen += sizeof(mgmt->u.action.u.delba);
-
-               mgmt->u.action.u.delba.action_code = action;
-               BA_para_set = (status & 0x1F) << 3;
-               mgmt->u.action.u.delba.params = cpu_to_le16(BA_para_set);
-               mgmt->u.action.u.delba.reason_code =
-                       cpu_to_le16(WLAN_REASON_QSTA_NOT_USE);
-
-               pattrib->pktlen += 5;
-               break;
-       default:
-               break;
-       }
-
-       pattrib->last_txcmdsz = pattrib->pktlen;
-
-       dump_mgntframe23a(padapter, pmgntframe);
-}
-
-int send_delba23a(struct rtw_adapter *padapter, u8 initiator, u8 *addr)
-{
-       struct sta_priv *pstapriv = &padapter->stapriv;
-       struct sta_info *psta = NULL;
-       /* struct recv_reorder_ctrl *preorder_ctrl; */
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       u16 tid;
-
-       if ((pmlmeinfo->state&0x03) != MSR_AP)
-               if (!(pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS))
-                       return _SUCCESS;
-
-       psta = rtw_get_stainfo23a(pstapriv, addr);
-       if (psta == NULL)
-               return _SUCCESS;
-
-       if (initiator == 0) {  /*  recipient */
-               for (tid = 0; tid < MAXTID; tid++) {
-                       if (psta->recvreorder_ctrl[tid].enable == true) {
-                               DBG_8723A("rx agg disable tid(%d)\n", tid);
-                               issue_action_BA23a(padapter, addr, WLAN_ACTION_DELBA, (((tid <<1) |initiator)&0x1F));
-                               psta->recvreorder_ctrl[tid].enable = false;
-                               psta->recvreorder_ctrl[tid].indicate_seq = 0xffff;
-                       }
-               }
-       } else if (initiator == 1) { /*  originator */
-               for (tid = 0; tid < MAXTID; tid++) {
-                       if (psta->htpriv.agg_enable_bitmap & BIT(tid)) {
-                               DBG_8723A("tx agg disable tid(%d)\n", tid);
-                               issue_action_BA23a(padapter, addr, WLAN_ACTION_DELBA, (((tid <<1) |initiator)&0x1F));
-                               psta->htpriv.agg_enable_bitmap &= ~BIT(tid);
-                               psta->htpriv.candidate_tid_bitmap &= ~BIT(tid);
-
-                       }
-               }
-       }
-       return _SUCCESS;
-}
-
-int send_beacon23a(struct rtw_adapter *padapter)
-{
-       bool bxmitok;
-       int issue = 0;
-       int poll = 0;
-       unsigned long start = jiffies;
-       unsigned int passing_time;
-
-       rtl8723a_bcn_valid(padapter);
-       do {
-               issue_beacon23a(padapter, 100);
-               issue++;
-               do {
-                       yield();
-                       bxmitok = rtl8723a_get_bcn_valid(padapter);
-                       poll++;
-               } while ((poll % 10) != 0 && !bxmitok &&
-                        !padapter->bSurpriseRemoved &&
-                        !padapter->bDriverStopped);
-
-       } while (!bxmitok && issue<100 && !padapter->bSurpriseRemoved &&
-                !padapter->bDriverStopped);
-
-       if (padapter->bSurpriseRemoved || padapter->bDriverStopped)
-               return _FAIL;
-
-       passing_time = jiffies_to_msecs(jiffies - start);
-
-       if (!bxmitok) {
-               DBG_8723A("%s fail! %u ms\n", __func__, passing_time);
-               return _FAIL;
-       } else {
-
-               if (passing_time > 100 || issue > 3)
-                       DBG_8723A("%s success, issue:%d, poll:%d, %u ms\n",
-                                 __func__, issue, poll, passing_time);
-               return _SUCCESS;
-       }
-}
-
-/****************************************************************************
-
-Following are some utitity functions for WiFi MLME
-
-*****************************************************************************/
-
-bool IsLegal5GChannel(struct rtw_adapter *Adapter, u8 channel)
-{
-
-       int i = 0;
-       u8 Channel_5G[45] = {36, 38, 40, 42, 44, 46, 48, 50, 52, 54, 56, 58,
-                            60, 62, 64, 100, 102, 104, 106, 108, 110, 112,
-                            114, 116, 118, 120, 122, 124, 126, 128, 130, 132,
-                            134, 136, 138, 140, 149, 151, 153, 155, 157, 159,
-                            161, 163, 165};
-       for (i = 0; i < sizeof(Channel_5G); i++)
-               if (channel == Channel_5G[i])
-                       return true;
-       return false;
-}
-
-static void rtw_site_survey(struct rtw_adapter *padapter)
-{
-       unsigned char survey_channel = 0;
-       enum rt_scan_type ScanType = SCAN_PASSIVE;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       struct rtw_ieee80211_channel *ch;
-
-       if (pmlmeext->sitesurvey_res.channel_idx <
-           pmlmeext->sitesurvey_res.ch_num) {
-               ch = &pmlmeext->sitesurvey_res.ch[pmlmeext->sitesurvey_res.channel_idx];
-               survey_channel = ch->hw_value;
-               ScanType = (ch->flags & IEEE80211_CHAN_NO_IR) ?
-                       SCAN_PASSIVE : SCAN_ACTIVE;
-       }
-
-       if (survey_channel != 0) {
-               /* PAUSE 4-AC Queue when site_survey */
-               if (pmlmeext->sitesurvey_res.channel_idx == 0)
-                       set_channel_bwmode23a(padapter, survey_channel,
-                                             HAL_PRIME_CHNL_OFFSET_DONT_CARE,
-                                             HT_CHANNEL_WIDTH_20);
-               else
-                       SelectChannel23a(padapter, survey_channel);
-
-               if (ScanType == SCAN_ACTIVE) /* obey the channel plan setting... */
-               {
-                       int i;
-
-                       for (i = 0;i<RTW_SSID_SCAN_AMOUNT;i++) {
-                               if (pmlmeext->sitesurvey_res.ssid[i].ssid_len) {
-                                       /* todo: to issue two probe req??? */
-                                       issue_probereq(padapter, &pmlmeext->sitesurvey_res.ssid[i], NULL);
-                                       /* msleep(SURVEY_TO>>1); */
-                                       issue_probereq(padapter, &pmlmeext->sitesurvey_res.ssid[i], NULL);
-                               }
-                       }
-
-                       if (pmlmeext->sitesurvey_res.scan_mode == SCAN_ACTIVE) {
-                               /* todo: to issue two probe req??? */
-                               issue_probereq(padapter, NULL, NULL);
-                               /* msleep(SURVEY_TO>>1); */
-                               issue_probereq(padapter, NULL, NULL);
-                       }
-               }
-
-               set_survey_timer(pmlmeext, pmlmeext->chan_scan_time);
-       } else {
-               /*      channel number is 0 or this channel is not valid. */
-               pmlmeext->sitesurvey_res.state = SCAN_COMPLETE;
-
-               /* switch back to the original channel */
-
-               set_channel_bwmode23a(padapter, pmlmeext->cur_channel,
-                                     pmlmeext->cur_ch_offset,
-                                     pmlmeext->cur_bwmode);
-
-               /* flush 4-AC Queue after rtw_site_survey */
-               /* val8 = 0; */
-
-               /* config MSR */
-               rtl8723a_set_media_status(padapter, pmlmeinfo->state & 0x3);
-
-               /* restore RX GAIN */
-               rtl8723a_set_initial_gain(padapter, 0xff);
-               /* turn on dynamic functions */
-               rtl8723a_odm_support_ability_restore(padapter);
-
-               if (is_client_associated_to_ap23a(padapter) == true)
-                       issue_nulldata23a(padapter, NULL, 0, 3, 500);
-
-               rtl8723a_mlme_sitesurvey(padapter, 0);
-
-               report_surveydone_event23a(padapter);
-
-               pmlmeext->chan_scan_time = SURVEY_TO;
-               pmlmeext->sitesurvey_res.state = SCAN_DISABLE;
-       }
-}
-
-/* collect bss info from Beacon and Probe request/response frames. */
-static struct wlan_bssid_ex *collect_bss_info(struct rtw_adapter *padapter,
-                                             struct recv_frame *precv_frame)
-{
-       struct sk_buff *skb = precv_frame->pkt;
-       struct ieee80211_mgmt *mgmt = (struct ieee80211_mgmt *) skb->data;
-       struct registry_priv *pregistrypriv = &padapter->registrypriv;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       struct wlan_bssid_ex *bssid;
-       const u8 *p;
-       u8 *pie;
-       unsigned int length;
-       int i;
-
-       length = skb->len;
-
-       bssid = kzalloc(sizeof(struct wlan_bssid_ex), GFP_ATOMIC);
-       if (!bssid)
-               return NULL;
-
-       if (ieee80211_is_beacon(mgmt->frame_control)) {
-               length -= offsetof(struct ieee80211_mgmt, u.beacon.variable);
-               pie = mgmt->u.beacon.variable;
-               bssid->reserved = 1;
-               bssid->capability =
-                       get_unaligned_le16(&mgmt->u.beacon.capab_info);
-               bssid->beacon_interval =
-                       get_unaligned_le16(&mgmt->u.beacon.beacon_int);
-               bssid->tsf = get_unaligned_le64(&mgmt->u.beacon.timestamp);
-       } else if (ieee80211_is_probe_req(mgmt->frame_control)) {
-               length -= offsetof(struct ieee80211_mgmt, u.probe_req.variable);
-               pie = mgmt->u.probe_req.variable;
-               bssid->reserved = 2;
-               bssid->capability = 0;
-               bssid->beacon_interval =
-                       padapter->registrypriv.dev_network.beacon_interval;
-               bssid->tsf = 0;
-       } else if (ieee80211_is_probe_resp(mgmt->frame_control)) {
-               length -=
-                       offsetof(struct ieee80211_mgmt, u.probe_resp.variable);
-               pie = mgmt->u.probe_resp.variable;
-               bssid->reserved = 3;
-               bssid->capability =
-                       get_unaligned_le16(&mgmt->u.probe_resp.capab_info);
-               bssid->beacon_interval =
-                       get_unaligned_le16(&mgmt->u.probe_resp.beacon_int);
-               bssid->tsf = get_unaligned_le64(&mgmt->u.probe_resp.timestamp);
-       } else {
-               length -= offsetof(struct ieee80211_mgmt, u.beacon.variable);
-               pie = mgmt->u.beacon.variable;
-               bssid->reserved = 0;
-               bssid->capability =
-                       get_unaligned_le16(&mgmt->u.beacon.capab_info);
-               bssid->beacon_interval =
-                       padapter->registrypriv.dev_network.beacon_interval;
-               bssid->tsf = 0;
-       }
-
-       if (length > MAX_IE_SZ) {
-               /* DBG_8723A("IE too long for survey event\n"); */
-               kfree(bssid);
-               return NULL;
-       }
-
-       bssid->Length = offsetof(struct wlan_bssid_ex, IEs) + length;
-
-       /* below is to copy the information element */
-       bssid->IELength = length;
-       memcpy(bssid->IEs, pie, bssid->IELength);
-
-       /* get the signal strength */
-       /*  in dBM.raw data */
-       bssid->Rssi = precv_frame->attrib.phy_info.RecvSignalPower;
-       bssid->SignalQuality =
-               precv_frame->attrib.phy_info.SignalQuality;/* in percentage */
-       bssid->SignalStrength =
-               precv_frame->attrib.phy_info.SignalStrength;/* in percentage */
-
-       /*  checking SSID */
-       p = cfg80211_find_ie(WLAN_EID_SSID, bssid->IEs, bssid->IELength);
-
-       if (!p) {
-               DBG_8723A("marc: cannot find SSID for survey event\n");
-               goto fail;
-       }
-
-       if (p[1] > IEEE80211_MAX_SSID_LEN) {
-               DBG_8723A("%s()-%d: IE too long (%d) for survey "
-                         "event\n", __func__, __LINE__, p[1]);
-               goto fail;
-       }
-       memcpy(bssid->Ssid.ssid, p + 2, p[1]);
-       bssid->Ssid.ssid_len = p[1];
-
-       /* checking rate info... */
-       i = 0;
-       p = cfg80211_find_ie(WLAN_EID_SUPP_RATES, bssid->IEs, bssid->IELength);
-       if (p) {
-               if (p[1] > NDIS_802_11_LENGTH_RATES_EX) {
-                       DBG_8723A("%s()-%d: IE too long (%d) for survey "
-                                 "event\n", __func__, __LINE__, p[1]);
-                       goto fail;
-               }
-               memcpy(bssid->SupportedRates, p + 2, p[1]);
-               i = p[1];
-       }
-
-       p = cfg80211_find_ie(WLAN_EID_EXT_SUPP_RATES, bssid->IEs,
-                            bssid->IELength);
-       if (p) {
-               if (p[1] > (NDIS_802_11_LENGTH_RATES_EX-i)) {
-                       DBG_8723A("%s()-%d: IE too long (%d) for survey "
-                                 "event\n", __func__, __LINE__, p[1]);
-                       goto fail;
-               }
-               memcpy(bssid->SupportedRates + i, p + 2, p[1]);
-       }
-
-       /*  Checking for DSConfig */
-       p = cfg80211_find_ie(WLAN_EID_DS_PARAMS, bssid->IEs, bssid->IELength);
-
-       bssid->DSConfig = 0;
-
-       if (p) {
-               bssid->DSConfig = p[2];
-       } else {/*  In 5G, some ap do not have DSSET IE */
-               /*  checking HT info for channel */
-               p = cfg80211_find_ie(WLAN_EID_HT_OPERATION, bssid->IEs,
-                                    bssid->IELength);
-               if (p) {
-                       struct ieee80211_ht_operation *HT_info =
-                               (struct ieee80211_ht_operation *)(p + 2);
-                       bssid->DSConfig = HT_info->primary_chan;
-               } else /*  use current channel */
-                       bssid->DSConfig = rtw_get_oper_ch23a(padapter);
-       }
-
-       if (ieee80211_is_probe_req(mgmt->frame_control)) {
-               /*  FIXME */
-               bssid->ifmode = NL80211_IFTYPE_STATION;
-               ether_addr_copy(bssid->MacAddress, mgmt->sa);
-               bssid->Privacy = 1;
-               return bssid;
-       }
-
-       if (bssid->capability & WLAN_CAPABILITY_ESS) {
-               bssid->ifmode = NL80211_IFTYPE_STATION;
-               ether_addr_copy(bssid->MacAddress, mgmt->sa);
-       } else {
-               bssid->ifmode = NL80211_IFTYPE_ADHOC;
-               ether_addr_copy(bssid->MacAddress, mgmt->bssid);
-       }
-
-       if (bssid->capability & WLAN_CAPABILITY_PRIVACY)
-               bssid->Privacy = 1;
-       else
-               bssid->Privacy = 0;
-
-       bssid->ATIMWindow = 0;
-
-       /* 20/40 BSS Coexistence check */
-       if (pregistrypriv->wifi_spec == 1 &&
-           pmlmeinfo->bwmode_updated == false) {
-               struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-
-               p = cfg80211_find_ie(WLAN_EID_HT_CAPABILITY, bssid->IEs,
-                                    bssid->IELength);
-               if (p && p[1] > 0) {
-                       struct ieee80211_ht_cap *pHT_caps;
-
-                       pHT_caps = (struct ieee80211_ht_cap *)(p + 2);
-
-                       if (pHT_caps->cap_info &
-                           cpu_to_le16(IEEE80211_HT_CAP_40MHZ_INTOLERANT))
-                               pmlmepriv->num_FortyMHzIntolerant++;
-               } else
-                       pmlmepriv->num_sta_no_ht++;
-       }
-
-
-       /*  mark bss info receiving from nearby channel as SignalQuality 101 */
-       if (bssid->DSConfig != rtw_get_oper_ch23a(padapter))
-               bssid->SignalQuality = 101;
-
-       return bssid;
-fail:
-       kfree (bssid);
-       return NULL;
-}
-
-static void start_create_ibss(struct rtw_adapter *padapter)
-{
-       unsigned short caps;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       struct wlan_bssid_ex *pnetwork = &pmlmeinfo->network;
-
-       pmlmeext->cur_channel = (u8)pnetwork->DSConfig;
-       pmlmeinfo->bcn_interval = pnetwork->beacon_interval;
-
-       /* update wireless mode */
-       update_wireless_mode23a(padapter);
-
-       /* update capability */
-       caps = pnetwork->capability;
-       update_capinfo23a(padapter, caps);
-       if (caps & WLAN_CAPABILITY_IBSS) {      /* adhoc master */
-               rtl8723a_set_sec_cfg(padapter, 0xcf);
-
-               /* switch channel */
-               /* SelectChannel23a(padapter, pmlmeext->cur_channel, HAL_PRIME_CHNL_OFFSET_DONT_CARE); */
-               set_channel_bwmode23a(padapter, pmlmeext->cur_channel, HAL_PRIME_CHNL_OFFSET_DONT_CARE, HT_CHANNEL_WIDTH_20);
-
-               rtl8723a_SetBeaconRelatedRegisters(padapter);
-
-               /* set msr to MSR_ADHOC */
-               pmlmeinfo->state = MSR_ADHOC;
-               rtl8723a_set_media_status(padapter, pmlmeinfo->state & 0x3);
-
-               /* issue beacon */
-               if (send_beacon23a(padapter) == _FAIL) {
-                       RT_TRACE(_module_rtl871x_mlme_c_, _drv_err_,
-                                "issuing beacon frame fail....\n");
-
-                       report_join_res23a(padapter, -1);
-                       pmlmeinfo->state = MSR_NOLINK;
-               } else {
-                       hw_var_set_bssid(padapter, padapter->registrypriv.dev_network.MacAddress);
-                       hw_var_set_mlme_join(padapter, 0);
-
-                       report_join_res23a(padapter, 1);
-                       pmlmeinfo->state |= WIFI_FW_ASSOC_SUCCESS;
-               }
-       } else {
-               DBG_8723A("%s: invalid cap:%x\n", __func__, caps);
-               return;
-       }
-}
-
-static void start_clnt_join(struct rtw_adapter *padapter)
-{
-       unsigned short caps;
-       u8 val8;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       struct wlan_bssid_ex *pnetwork = &pmlmeinfo->network;
-       int beacon_timeout;
-
-       pmlmeext->cur_channel = (u8)pnetwork->DSConfig;
-       pmlmeinfo->bcn_interval = pnetwork->beacon_interval;
-
-       /* update wireless mode */
-       update_wireless_mode23a(padapter);
-
-       /* update capability */
-       caps = pnetwork->capability;
-       update_capinfo23a(padapter, caps);
-       if (caps & WLAN_CAPABILITY_ESS) {
-               /* switch channel */
-               set_channel_bwmode23a(padapter, pmlmeext->cur_channel, pmlmeext->cur_ch_offset, pmlmeext->cur_bwmode);
-
-               rtl8723a_set_media_status(padapter, MSR_INFRA);
-
-               val8 = (pmlmeinfo->auth_algo == dot11AuthAlgrthm_8021X) ?
-                       0xcc: 0xcf;
-
-               rtl8723a_set_sec_cfg(padapter, val8);
-
-               /* switch channel */
-               /* set_channel_bwmode23a(padapter, pmlmeext->cur_channel, pmlmeext->cur_ch_offset, pmlmeext->cur_bwmode); */
-
-               /* here wait for receiving the beacon to start auth */
-               /* and enable a timer */
-               beacon_timeout = decide_wait_for_beacon_timeout23a(pmlmeinfo->bcn_interval);
-               set_link_timer(pmlmeext, beacon_timeout);
-               mod_timer(&padapter->mlmepriv.assoc_timer, jiffies +
-                         msecs_to_jiffies((REAUTH_TO * REAUTH_LIMIT) + (REASSOC_TO*REASSOC_LIMIT) + beacon_timeout));
-               pmlmeinfo->state = WIFI_FW_AUTH_NULL | MSR_INFRA;
-       } else if (caps & WLAN_CAPABILITY_IBSS) {       /* adhoc client */
-               rtl8723a_set_media_status(padapter, MSR_ADHOC);
-
-               rtl8723a_set_sec_cfg(padapter, 0xcf);
-
-               /* switch channel */
-               set_channel_bwmode23a(padapter, pmlmeext->cur_channel, pmlmeext->cur_ch_offset, pmlmeext->cur_bwmode);
-
-               rtl8723a_SetBeaconRelatedRegisters(padapter);
-
-               pmlmeinfo->state = MSR_ADHOC;
-
-               report_join_res23a(padapter, 1);
-       } else {
-               /* DBG_8723A("marc: invalid cap:%x\n", caps); */
-               return;
-       }
-}
-
-static void start_clnt_auth(struct rtw_adapter *padapter)
-{
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-
-       del_timer_sync(&pmlmeext->link_timer);
-
-       pmlmeinfo->state &= (~WIFI_FW_AUTH_NULL);
-       pmlmeinfo->state |= WIFI_FW_AUTH_STATE;
-
-       pmlmeinfo->auth_seq = 1;
-       pmlmeinfo->reauth_count = 0;
-       pmlmeinfo->reassoc_count = 0;
-       pmlmeinfo->link_count = 0;
-       pmlmeext->retry = 0;
-
-       /*  Because of AP's not receiving deauth before */
-       /*  AP may: 1)not response auth or 2)deauth us after link is complete */
-       /*  issue deauth before issuing auth to deal with the situation */
-       /*      Commented by Albert 2012/07/21 */
-       /*      For the Win8 P2P connection, it will be hard to have a
-               successful connection if this Wi-Fi doesn't connect to it. */
-       issue_deauth23a(padapter, (&pmlmeinfo->network)->MacAddress,
-                       WLAN_REASON_DEAUTH_LEAVING);
-
-       DBG_8723A_LEVEL(_drv_always_, "start auth\n");
-       issue_auth(padapter, NULL, 0);
-
-       set_link_timer(pmlmeext, REAUTH_TO);
-}
-
-static void start_clnt_assoc(struct rtw_adapter *padapter)
-{
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-
-       del_timer_sync(&pmlmeext->link_timer);
-
-       pmlmeinfo->state &= (~(WIFI_FW_AUTH_NULL | WIFI_FW_AUTH_STATE));
-       pmlmeinfo->state |= (WIFI_FW_AUTH_SUCCESS | WIFI_FW_ASSOC_STATE);
-
-       issue_assocreq(padapter);
-
-       set_link_timer(pmlmeext, REASSOC_TO);
-}
-
-int receive_disconnect23a(struct rtw_adapter *padapter,
-                         unsigned char *MacAddr, unsigned short reason)
-{
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-
-       /* check A3 */
-       if (!ether_addr_equal(MacAddr, get_my_bssid23a(&pmlmeinfo->network)))
-               return _SUCCESS;
-
-       DBG_8723A("%s\n", __func__);
-
-       if ((pmlmeinfo->state&0x03) == MSR_INFRA) {
-               if (pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS) {
-                       pmlmeinfo->state = MSR_NOLINK;
-                       report_del_sta_event23a(padapter, MacAddr, reason);
-
-               } else if (pmlmeinfo->state & WIFI_FW_LINKING_STATE) {
-                       pmlmeinfo->state = MSR_NOLINK;
-                       report_join_res23a(padapter, -2);
-               }
-       }
-
-       return _SUCCESS;
-}
-
-static void process_80211d(struct rtw_adapter *padapter,
-                          struct wlan_bssid_ex *bssid)
-{
-       struct registry_priv *pregistrypriv;
-       struct mlme_ext_priv *pmlmeext;
-       struct rt_channel_info *chplan_new;
-       u8 channel;
-       u8 i;
-
-       pregistrypriv = &padapter->registrypriv;
-       pmlmeext = &padapter->mlmeextpriv;
-
-       /*  Adjust channel plan by AP Country IE */
-       if (pregistrypriv->enable80211d &&
-           !pmlmeext->update_channel_plan_by_ap_done) {
-               const u8 *ie, *p;
-               struct rt_channel_plan chplan_ap;
-               struct rt_channel_info chplan_sta[MAX_CHANNEL_NUM];
-               u8 country[4];
-               u8 fcn; /*  first channel number */
-               u8 noc; /*  number of channel */
-               u8 j, k;
-
-               ie = cfg80211_find_ie(WLAN_EID_COUNTRY, bssid->IEs,
-                                     bssid->IELength);
-               if (!ie || ie[1] < IEEE80211_COUNTRY_IE_MIN_LEN)
-                       return;
-
-               p = ie + 2;
-               ie += ie[1];
-               ie += 2;
-
-               memcpy(country, p, 3);
-               country[3] = '\0';
-
-               p += 3;
-               RT_TRACE(_module_rtl871x_mlme_c_, _drv_notice_,
-                        "%s: 802.11d country =%s\n", __func__, country);
-
-               i = 0;
-               while ((ie - p) >= 3) {
-                       fcn = *(p++);
-                       noc = *(p++);
-                       p++;
-
-                       for (j = 0; j < noc; j++) {
-                               if (fcn <= 14)
-                                       channel = fcn + j; /*  2.4 GHz */
-                               else
-                                       channel = fcn + j * 4; /*  5 GHz */
-
-                               chplan_ap.Channel[i++] = channel;
-                       }
-               }
-               chplan_ap.Len = i;
-
-               memcpy(chplan_sta, pmlmeext->channel_set, sizeof(chplan_sta));
-               memset(pmlmeext->channel_set, 0, sizeof(pmlmeext->channel_set));
-               chplan_new = pmlmeext->channel_set;
-
-               i = j = k = 0;
-               if (pregistrypriv->wireless_mode & WIRELESS_11G) {
-                       do {
-                               if (i == MAX_CHANNEL_NUM ||
-                                   chplan_sta[i].ChannelNum == 0 ||
-                                   chplan_sta[i].ChannelNum > 14)
-                                       break;
-
-                               if (j == chplan_ap.Len ||
-                                   chplan_ap.Channel[j] > 14)
-                                       break;
-
-                               if (chplan_sta[i].ChannelNum ==
-                                   chplan_ap.Channel[j]) {
-                                       chplan_new[k].ChannelNum =
-                                               chplan_ap.Channel[j];
-                                       chplan_new[k].ScanType = SCAN_ACTIVE;
-                                       i++;
-                                       j++;
-                                       k++;
-                               } else if (chplan_sta[i].ChannelNum <
-                                          chplan_ap.Channel[j]) {
-                                       chplan_new[k].ChannelNum =
-                                               chplan_sta[i].ChannelNum;
-                                       chplan_new[k].ScanType =
-                                               SCAN_PASSIVE;
-                                       i++;
-                                       k++;
-                               } else if (chplan_sta[i].ChannelNum >
-                                          chplan_ap.Channel[j]) {
-                                       chplan_new[k].ChannelNum =
-                                               chplan_ap.Channel[j];
-                                       chplan_new[k].ScanType =
-                                               SCAN_ACTIVE;
-                                       j++;
-                                       k++;
-                               }
-                       } while (1);
-
-                       /*  change AP not support channel to Passive scan */
-                       while (i < MAX_CHANNEL_NUM &&
-                              chplan_sta[i].ChannelNum != 0 &&
-                              chplan_sta[i].ChannelNum <= 14) {
-                               chplan_new[k].ChannelNum =
-                                       chplan_sta[i].ChannelNum;
-                               chplan_new[k].ScanType = SCAN_PASSIVE;
-                               i++;
-                               k++;
-                       }
-
-                       /*  add channel AP supported */
-                       while (j < chplan_ap.Len && chplan_ap.Channel[j] <= 14){
-                               chplan_new[k].ChannelNum = chplan_ap.Channel[j];
-                               chplan_new[k].ScanType = SCAN_ACTIVE;
-                               j++;
-                               k++;
-                       }
-               } else {
-                       /*  keep original STA 2.4G channel plan */
-                       while (i < MAX_CHANNEL_NUM &&
-                              chplan_sta[i].ChannelNum != 0 &&
-                              chplan_sta[i].ChannelNum <= 14) {
-                               chplan_new[k].ChannelNum =
-                                       chplan_sta[i].ChannelNum;
-                               chplan_new[k].ScanType = chplan_sta[i].ScanType;
-                               i++;
-                               k++;
-                       }
-
-                       /*  skip AP 2.4G channel plan */
-                       while (j < chplan_ap.Len && chplan_ap.Channel[j] <= 14)
-                               j++;
-               }
-
-               if (pregistrypriv->wireless_mode & WIRELESS_11A) {
-                       do {
-                               if (i == MAX_CHANNEL_NUM ||
-                                   chplan_sta[i].ChannelNum == 0)
-                                       break;
-
-                               if (j == chplan_ap.Len ||
-                                   chplan_ap.Channel[j] == 0)
-                                       break;
-
-                               if (chplan_sta[i].ChannelNum ==
-                                   chplan_ap.Channel[j]) {
-                                       chplan_new[k].ChannelNum =
-                                               chplan_ap.Channel[j];
-                                       chplan_new[k].ScanType = SCAN_ACTIVE;
-                                       i++;
-                                       j++;
-                                       k++;
-                               } else if (chplan_sta[i].ChannelNum <
-                                          chplan_ap.Channel[j]) {
-                                       chplan_new[k].ChannelNum =
-                                               chplan_sta[i].ChannelNum;
-                                       chplan_new[k].ScanType = SCAN_PASSIVE;
-                                       i++;
-                                       k++;
-                               } else if (chplan_sta[i].ChannelNum >
-                                          chplan_ap.Channel[j]) {
-                                       chplan_new[k].ChannelNum =
-                                               chplan_ap.Channel[j];
-                                       chplan_new[k].ScanType = SCAN_ACTIVE;
-                                       j++;
-                                       k++;
-                               }
-                       } while (1);
-
-                       /*  change AP not support channel to Passive scan */
-                       while (i < MAX_CHANNEL_NUM &&
-                              chplan_sta[i].ChannelNum != 0) {
-                               chplan_new[k].ChannelNum =
-                                       chplan_sta[i].ChannelNum;
-                               chplan_new[k].ScanType = SCAN_PASSIVE;
-                               i++;
-                               k++;
-                       }
-
-                       /*  add channel AP supported */
-                       while (j < chplan_ap.Len && chplan_ap.Channel[j] != 0) {
-                               chplan_new[k].ChannelNum = chplan_ap.Channel[j];
-                               chplan_new[k].ScanType = SCAN_ACTIVE;
-                               j++;
-                               k++;
-                       }
-               } else {
-                       /*  keep original STA 5G channel plan */
-                       while (i < MAX_CHANNEL_NUM &&
-                              chplan_sta[i].ChannelNum != 0) {
-                               chplan_new[k].ChannelNum =
-                                       chplan_sta[i].ChannelNum;
-                               chplan_new[k].ScanType = chplan_sta[i].ScanType;
-                               i++;
-                               k++;
-                       }
-               }
-               pmlmeext->update_channel_plan_by_ap_done = 1;
-       }
-
-       /*  If channel is used by AP, set channel scan type to active */
-       channel = bssid->DSConfig;
-       chplan_new = pmlmeext->channel_set;
-       i = 0;
-       while (i < MAX_CHANNEL_NUM && chplan_new[i].ChannelNum != 0) {
-               if (chplan_new[i].ChannelNum == channel) {
-                       if (chplan_new[i].ScanType == SCAN_PASSIVE) {
-                               /* 5G Bnad 2, 3 (DFS) doesn't change
-                                  to active scan */
-                               if (channel >= 52 && channel <= 144)
-                                       break;
-
-                               chplan_new[i].ScanType = SCAN_ACTIVE;
-                               RT_TRACE(_module_rtl871x_mlme_c_, _drv_notice_,
-                                        "%s: change channel %d scan type from passive to active\n",
-                                        __func__, channel);
-                       }
-                       break;
-               }
-               i++;
-       }
-}
-
-/****************************************************************************
-
-Following are the functions to report events
-
-*****************************************************************************/
-
-void report_survey_event23a(struct rtw_adapter *padapter,
-                           struct recv_frame *precv_frame)
-{
-       struct cmd_obj *pcmd_obj;
-       u8 *pevtcmd;
-       u32 cmdsz;
-       struct survey_event *psurvey_evt;
-       struct C2HEvent_Header *pc2h_evt_hdr;
-       struct mlme_ext_priv *pmlmeext;
-       struct cmd_priv *pcmdpriv;
-
-       if (!padapter)
-               return;
-
-       pmlmeext = &padapter->mlmeextpriv;
-       pcmdpriv = &padapter->cmdpriv;
-
-       pcmd_obj = kzalloc(sizeof(struct cmd_obj), GFP_ATOMIC);
-       if (!pcmd_obj)
-               return;
-
-       cmdsz = sizeof(struct survey_event) + sizeof(struct C2HEvent_Header);
-       pevtcmd = kzalloc(cmdsz, GFP_ATOMIC);
-       if (!pevtcmd) {
-               kfree(pcmd_obj);
-               return;
-       }
-
-       pcmd_obj->cmdcode = GEN_CMD_CODE(_Set_MLME_EVT);
-       pcmd_obj->cmdsz = cmdsz;
-       pcmd_obj->parmbuf = pevtcmd;
-
-       pcmd_obj->rsp = NULL;
-       pcmd_obj->rspsz  = 0;
-
-       pc2h_evt_hdr = (struct C2HEvent_Header *)(pevtcmd);
-       pc2h_evt_hdr->len = sizeof(struct survey_event);
-       pc2h_evt_hdr->ID = GEN_EVT_CODE(_Survey);
-       pc2h_evt_hdr->seq = atomic_inc_return(&pmlmeext->event_seq);
-
-       psurvey_evt = (struct survey_event*)(pevtcmd + sizeof(struct C2HEvent_Header));
-
-       psurvey_evt->bss = collect_bss_info(padapter, precv_frame);
-       if (!psurvey_evt->bss) {
-               kfree(pcmd_obj);
-               kfree(pevtcmd);
-               return;
-       }
-
-       process_80211d(padapter, psurvey_evt->bss);
-
-       rtw_enqueue_cmd23a(pcmdpriv, pcmd_obj);
-
-       pmlmeext->sitesurvey_res.bss_cnt++;
-}
-
-void report_surveydone_event23a(struct rtw_adapter *padapter)
-{
-       struct cmd_obj *pcmd_obj;
-       u8 *pevtcmd;
-       u32 cmdsz;
-       struct surveydone_event *psurveydone_evt;
-       struct C2HEvent_Header *pc2h_evt_hdr;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
-
-       pcmd_obj = kzalloc(sizeof(struct cmd_obj), GFP_ATOMIC);
-       if (!pcmd_obj)
-               return;
-
-       cmdsz = sizeof(struct surveydone_event) + sizeof(struct C2HEvent_Header);
-       pevtcmd = kzalloc(cmdsz, GFP_ATOMIC);
-       if (!pevtcmd) {
-               kfree(pcmd_obj);
-               return;
-       }
-
-       pcmd_obj->cmdcode = GEN_CMD_CODE(_Set_MLME_EVT);
-       pcmd_obj->cmdsz = cmdsz;
-       pcmd_obj->parmbuf = pevtcmd;
-
-       pcmd_obj->rsp = NULL;
-       pcmd_obj->rspsz  = 0;
-
-       pc2h_evt_hdr = (struct C2HEvent_Header *)(pevtcmd);
-       pc2h_evt_hdr->len = sizeof(struct surveydone_event);
-       pc2h_evt_hdr->ID = GEN_EVT_CODE(_SurveyDone);
-       pc2h_evt_hdr->seq = atomic_inc_return(&pmlmeext->event_seq);
-
-       psurveydone_evt = (struct surveydone_event*)(pevtcmd + sizeof(struct C2HEvent_Header));
-       psurveydone_evt->bss_cnt = pmlmeext->sitesurvey_res.bss_cnt;
-
-       DBG_8723A("survey done event(%x)\n", psurveydone_evt->bss_cnt);
-
-       rtw_enqueue_cmd23a(pcmdpriv, pcmd_obj);
-}
-
-void report_join_res23a(struct rtw_adapter *padapter, int res)
-{
-       struct cmd_obj *pcmd_obj;
-       u8 *pevtcmd;
-       u32 cmdsz;
-       struct joinbss_event            *pjoinbss_evt;
-       struct C2HEvent_Header  *pc2h_evt_hdr;
-       struct mlme_ext_priv            *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
-
-       pcmd_obj = kzalloc(sizeof(struct cmd_obj), GFP_ATOMIC);
-       if (!pcmd_obj)
-               return;
-
-       cmdsz = sizeof(struct joinbss_event) + sizeof(struct C2HEvent_Header);
-       pevtcmd = kzalloc(cmdsz, GFP_ATOMIC);
-       if (!pevtcmd) {
-               kfree(pcmd_obj);
-               return;
-       }
-
-       pcmd_obj->cmdcode = GEN_CMD_CODE(_Set_MLME_EVT);
-       pcmd_obj->cmdsz = cmdsz;
-       pcmd_obj->parmbuf = pevtcmd;
-
-       pcmd_obj->rsp = NULL;
-       pcmd_obj->rspsz  = 0;
-
-       pc2h_evt_hdr = (struct C2HEvent_Header *)(pevtcmd);
-       pc2h_evt_hdr->len = sizeof(struct joinbss_event);
-       pc2h_evt_hdr->ID = GEN_EVT_CODE(_JoinBss);
-       pc2h_evt_hdr->seq = atomic_inc_return(&pmlmeext->event_seq);
-
-       pjoinbss_evt = (struct joinbss_event*)(pevtcmd + sizeof(struct C2HEvent_Header));
-       memcpy((unsigned char *)&pjoinbss_evt->network.network,
-              &pmlmeinfo->network, sizeof(struct wlan_bssid_ex));
-       pjoinbss_evt->network.join_res = res;
-
-       DBG_8723A("report_join_res23a(%d)\n", res);
-
-       rtw_joinbss_event_prehandle23a(padapter, (u8 *)&pjoinbss_evt->network);
-
-       rtw_enqueue_cmd23a(pcmdpriv, pcmd_obj);
-}
-
-void report_del_sta_event23a(struct rtw_adapter *padapter,
-                            unsigned char *MacAddr, unsigned short reason)
-{
-       struct cmd_obj *pcmd_obj;
-       u8 *pevtcmd;
-       u32 cmdsz;
-       struct sta_info *psta;
-       int mac_id;
-       struct stadel_event *pdel_sta_evt;
-       struct C2HEvent_Header *pc2h_evt_hdr;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
-
-       pcmd_obj = kzalloc(sizeof(struct cmd_obj), GFP_ATOMIC);
-       if (!pcmd_obj)
-               return;
-
-       cmdsz = sizeof(struct stadel_event) + sizeof(struct C2HEvent_Header);
-       pevtcmd = kzalloc(cmdsz, GFP_ATOMIC);
-       if (!pevtcmd) {
-               kfree(pcmd_obj);
-               return;
-       }
-
-       pcmd_obj->cmdcode = GEN_CMD_CODE(_Set_MLME_EVT);
-       pcmd_obj->cmdsz = cmdsz;
-       pcmd_obj->parmbuf = pevtcmd;
-
-       pcmd_obj->rsp = NULL;
-       pcmd_obj->rspsz  = 0;
-
-       pc2h_evt_hdr = (struct C2HEvent_Header *)(pevtcmd);
-       pc2h_evt_hdr->len = sizeof(struct stadel_event);
-       pc2h_evt_hdr->ID = GEN_EVT_CODE(_DelSTA);
-       pc2h_evt_hdr->seq = atomic_inc_return(&pmlmeext->event_seq);
-
-       pdel_sta_evt = (struct stadel_event*)(pevtcmd + sizeof(struct C2HEvent_Header));
-       ether_addr_copy((unsigned char *)&pdel_sta_evt->macaddr, MacAddr);
-       memcpy((unsigned char *)pdel_sta_evt->rsvd, (unsigned char *)&reason,
-              2);
-
-       psta = rtw_get_stainfo23a(&padapter->stapriv, MacAddr);
-       if (psta)
-               mac_id = (int)psta->mac_id;
-       else
-               mac_id = -1;
-
-       pdel_sta_evt->mac_id = mac_id;
-
-       DBG_8723A("report_del_sta_event23a: delete STA, mac_id =%d\n", mac_id);
-
-       rtw_enqueue_cmd23a(pcmdpriv, pcmd_obj);
-}
-
-void report_add_sta_event23a(struct rtw_adapter *padapter,
-                            unsigned char *MacAddr, int cam_idx)
-{
-       struct cmd_obj *pcmd_obj;
-       u8 *pevtcmd;
-       u32 cmdsz;
-       struct stassoc_event *padd_sta_evt;
-       struct C2HEvent_Header *pc2h_evt_hdr;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
-
-       pcmd_obj = kzalloc(sizeof(struct cmd_obj), GFP_ATOMIC);
-       if (!pcmd_obj)
-               return;
-
-       cmdsz = sizeof(struct stassoc_event) + sizeof(struct C2HEvent_Header);
-       pevtcmd = kzalloc(cmdsz, GFP_ATOMIC);
-       if (!pevtcmd) {
-               kfree(pcmd_obj);
-               return;
-       }
-
-       pcmd_obj->cmdcode = GEN_CMD_CODE(_Set_MLME_EVT);
-       pcmd_obj->cmdsz = cmdsz;
-       pcmd_obj->parmbuf = pevtcmd;
-
-       pcmd_obj->rsp = NULL;
-       pcmd_obj->rspsz  = 0;
-
-       pc2h_evt_hdr = (struct C2HEvent_Header *)(pevtcmd);
-       pc2h_evt_hdr->len = sizeof(struct stassoc_event);
-       pc2h_evt_hdr->ID = GEN_EVT_CODE(_AddSTA);
-       pc2h_evt_hdr->seq = atomic_inc_return(&pmlmeext->event_seq);
-
-       padd_sta_evt = (struct stassoc_event*)(pevtcmd + sizeof(struct C2HEvent_Header));
-       ether_addr_copy((unsigned char *)&padd_sta_evt->macaddr, MacAddr);
-       padd_sta_evt->cam_id = cam_idx;
-
-       DBG_8723A("report_add_sta_event23a: add STA\n");
-
-       rtw_enqueue_cmd23a(pcmdpriv, pcmd_obj);
-}
-
-/****************************************************************************
-
-Following are the event callback functions
-
-*****************************************************************************/
-
-/* for sta/adhoc mode */
-void update_sta_info23a(struct rtw_adapter *padapter, struct sta_info *psta)
-{
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-
-       /* ERP */
-       VCS_update23a(padapter, psta);
-
-       /* HT */
-       if (pmlmepriv->htpriv.ht_option) {
-               psta->htpriv.ht_option = true;
-
-               psta->htpriv.ampdu_enable = pmlmepriv->htpriv.ampdu_enable;
-
-               if (support_short_GI23a(padapter, &pmlmeinfo->ht_cap))
-                       psta->htpriv.sgi = true;
-
-               psta->qos_option = true;
-
-       } else {
-               psta->htpriv.ht_option = false;
-
-               psta->htpriv.ampdu_enable = false;
-
-               psta->htpriv.sgi = false;
-               psta->qos_option = false;
-
-       }
-       psta->htpriv.bwmode = pmlmeext->cur_bwmode;
-       psta->htpriv.ch_offset = pmlmeext->cur_ch_offset;
-
-       psta->htpriv.agg_enable_bitmap = 0x0;/* reset */
-       psta->htpriv.candidate_tid_bitmap = 0x0;/* reset */
-
-       /* QoS */
-       if (pmlmepriv->qos_option)
-               psta->qos_option = true;
-
-       psta->state = _FW_LINKED;
-}
-
-void mlmeext_joinbss_event_callback23a(struct rtw_adapter *padapter,
-                                      int join_res)
-{
-       struct sta_info *psta, *psta_bmc;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       struct wlan_bssid_ex *cur_network = &pmlmeinfo->network;
-       struct sta_priv *pstapriv = &padapter->stapriv;
-
-       if (join_res < 0) {
-               hw_var_set_mlme_join(padapter, 1);
-               hw_var_set_bssid(padapter, null_addr);
-
-               /* restore to initial setting. */
-               update_tx_basic_rate23a(padapter,
-                                       padapter->registrypriv.wireless_mode);
-
-               goto exit_mlmeext_joinbss_event_callback23a;
-       }
-
-       if ((pmlmeinfo->state&0x03) == MSR_ADHOC) {
-               /* for bc/mc */
-               psta_bmc = rtw_get_bcmc_stainfo23a(padapter);
-               if (psta_bmc) {
-                       pmlmeinfo->FW_sta_info[psta_bmc->mac_id].psta = psta_bmc;
-                       update_bmc_sta_support_rate23a(padapter, psta_bmc->mac_id);
-                       Update_RA_Entry23a(padapter, psta_bmc);
-               }
-       }
-
-       /* turn on dynamic functions */
-       rtl8723a_odm_support_ability_set(padapter, DYNAMIC_ALL_FUNC_ENABLE);
-
-       /*  update IOT-releated issue */
-       update_IOT_info23a(padapter);
-
-       HalSetBrateCfg23a(padapter, cur_network->SupportedRates);
-
-       /* BCN interval */
-       rtl8723a_set_beacon_interval(padapter, pmlmeinfo->bcn_interval);
-
-       /* update capability */
-       update_capinfo23a(padapter, pmlmeinfo->capability);
-
-       /* WMM, Update EDCA param */
-       WMMOnAssocRsp23a(padapter);
-
-       /* HT */
-       HTOnAssocRsp23a(padapter);
-
-       /* Set cur_channel&cur_bwmode&cur_ch_offset */
-       set_channel_bwmode23a(padapter, pmlmeext->cur_channel, pmlmeext->cur_ch_offset, pmlmeext->cur_bwmode);
-
-       psta = rtw_get_stainfo23a(pstapriv, cur_network->MacAddress);
-       if (psta) { /* only for infra. mode */
-               pmlmeinfo->FW_sta_info[psta->mac_id].psta = psta;
-
-               /* DBG_8723A("set_sta_rate23a\n"); */
-
-               psta->wireless_mode = pmlmeext->cur_wireless_mode;
-
-               /* set per sta rate after updating HT cap. */
-               set_sta_rate23a(padapter, psta);
-       }
-
-       hw_var_set_mlme_join(padapter, 2);
-
-       if ((pmlmeinfo->state&0x03) == MSR_INFRA) {
-               /*  correcting TSF */
-               rtw_correct_TSF(padapter);
-
-               /* set_link_timer(pmlmeext, DISCONNECT_TO); */
-       }
-
-       rtw_lps_ctrl_wk_cmd23a(padapter, LPS_CTRL_CONNECT, 0);
-
-exit_mlmeext_joinbss_event_callback23a:
-       DBG_8723A("=>%s\n", __func__);
-}
-
-void mlmeext_sta_add_event_callback23a(struct rtw_adapter *padapter,
-                                      struct sta_info *psta)
-{
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-
-       DBG_8723A("%s\n", __func__);
-
-       if ((pmlmeinfo->state & 0x03) == MSR_ADHOC) {
-       /* adhoc master or sta_count>1 */
-               if (pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS) {
-                       /* nothing to do */
-               } else { /* adhoc client */
-                       /*  correcting TSF */
-                       rtw_correct_TSF(padapter);
-
-                       /* start beacon */
-                       if (send_beacon23a(padapter) != _SUCCESS) {
-                               pmlmeinfo->FW_sta_info[psta->mac_id].status = 0;
-
-                               pmlmeinfo->state ^= MSR_ADHOC;
-
-                               return;
-                       }
-
-                       pmlmeinfo->state |= WIFI_FW_ASSOC_SUCCESS;
-               }
-               hw_var_set_mlme_join(padapter, 2);
-       }
-
-       pmlmeinfo->FW_sta_info[psta->mac_id].psta = psta;
-
-       /* rate radaptive */
-       Update_RA_Entry23a(padapter, psta);
-
-       /* update adhoc sta_info */
-       update_sta_info23a(padapter, psta);
-}
-
-void mlmeext_sta_del_event_callback23a(struct rtw_adapter *padapter)
-{
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-
-       if (is_client_associated_to_ap23a(padapter) ||
-           is_IBSS_empty23a(padapter)) {
-               /* set_opmode_cmd(padapter, infra_client_with_mlme); */
-
-               hw_var_set_mlme_disconnect(padapter);
-               hw_var_set_bssid(padapter, null_addr);
-
-               /* restore to initial setting. */
-               update_tx_basic_rate23a(padapter,
-                                       padapter->registrypriv.wireless_mode);
-
-               /* switch to the 20M Hz mode after disconnect */
-               pmlmeext->cur_bwmode = HT_CHANNEL_WIDTH_20;
-               pmlmeext->cur_ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
-
-               set_channel_bwmode23a(padapter, pmlmeext->cur_channel,
-                                     pmlmeext->cur_ch_offset,
-                                     pmlmeext->cur_bwmode);
-
-               flush_all_cam_entry23a(padapter);
-
-               pmlmeinfo->state = MSR_NOLINK;
-
-               /* set MSR to no link state -> infra. mode */
-               rtl8723a_set_media_status(padapter, MSR_INFRA);
-
-               del_timer_sync(&pmlmeext->link_timer);
-       }
-}
-
-static u8 chk_ap_is_alive(struct rtw_adapter *padapter, struct sta_info *psta)
-{
-       u8 ret = false;
-
-       if (sta_rx_data_pkts(psta) == sta_last_rx_data_pkts(psta) &&
-           sta_rx_beacon_pkts(psta) == sta_last_rx_beacon_pkts(psta) &&
-           sta_rx_probersp_pkts(psta) == sta_last_rx_probersp_pkts(psta))
-               ret = false;
-       else
-               ret = true;
-
-       sta_update_last_rx_pkts(psta);
-       return ret;
-}
-
-void linked_status_chk23a(struct rtw_adapter *padapter)
-{
-       u32 i;
-       struct sta_info *psta;
-       struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       struct sta_priv *pstapriv = &padapter->stapriv;
-
-       if (is_client_associated_to_ap23a(padapter)) {
-               /* linked infrastructure client mode */
-
-               int tx_chk = _SUCCESS, rx_chk = _SUCCESS;
-               int rx_chk_limit;
-
-               rx_chk_limit = 4;
-
-               psta = rtw_get_stainfo23a(pstapriv,
-                                         pmlmeinfo->network.MacAddress);
-               if (psta) {
-                       bool is_p2p_enable = false;
-
-                       if (chk_ap_is_alive(padapter, psta) == false)
-                               rx_chk = _FAIL;
-
-                       if (pxmitpriv->last_tx_pkts == pxmitpriv->tx_pkts)
-                               tx_chk = _FAIL;
-
-                       if (pmlmeext->active_keep_alive_check &&
-                           (rx_chk == _FAIL || tx_chk == _FAIL)) {
-                               u8 backup_oper_channel = 0;
-
-                               /* switch to correct channel of current
-                                  network  before issue keep-alive frames */
-                               if (rtw_get_oper_ch23a(padapter) !=
-                                   pmlmeext->cur_channel) {
-                                       backup_oper_channel =
-                                               rtw_get_oper_ch23a(padapter);
-                                       SelectChannel23a(padapter,
-                                                        pmlmeext->cur_channel);
-                               }
-
-                               if (rx_chk != _SUCCESS)
-                                       issue_probereq_ex(padapter, &pmlmeinfo->network.Ssid, psta->hwaddr, 3, 1);
-
-                               if ((tx_chk != _SUCCESS &&
-                                    pmlmeinfo->link_count++ == 0xf) ||
-                                   rx_chk != _SUCCESS) {
-                                       tx_chk = issue_nulldata23a(padapter,
-                                                                  psta->hwaddr,
-                                                                  0, 3, 1);
-                                       /* if tx acked and p2p disabled,
-                                          set rx_chk _SUCCESS to reset retry
-                                          count */
-                                       if (tx_chk == _SUCCESS &&
-                                           !is_p2p_enable)
-                                               rx_chk = _SUCCESS;
-                               }
-
-                               /* back to the original operation channel */
-                               if (backup_oper_channel>0)
-                                       SelectChannel23a(padapter,
-                                                        backup_oper_channel);
-                       } else {
-                               if (rx_chk != _SUCCESS) {
-                                       if (pmlmeext->retry == 0) {
-                                               issue_probereq(padapter, &pmlmeinfo->network.Ssid, pmlmeinfo->network.MacAddress);
-                                               issue_probereq(padapter, &pmlmeinfo->network.Ssid, pmlmeinfo->network.MacAddress);
-                                               issue_probereq(padapter, &pmlmeinfo->network.Ssid, pmlmeinfo->network.MacAddress);
-                                       }
-                               }
-
-                               if (tx_chk != _SUCCESS &&
-                                   pmlmeinfo->link_count++ == 0xf)
-                                       tx_chk = issue_nulldata23a(padapter,
-                                                                  NULL, 0, 1,
-                                                                  0);
-                       }
-
-                       if (rx_chk == _FAIL) {
-                               pmlmeext->retry++;
-                               if (pmlmeext->retry > rx_chk_limit) {
-                                       DBG_8723A_LEVEL(_drv_always_,
-                                                       "%s(%s): disconnect or "
-                                                       "roaming\n", __func__,
-                                                       padapter->pnetdev->name);
-                                       receive_disconnect23a(padapter, pmlmeinfo->network.MacAddress,
-                                               WLAN_REASON_EXPIRATION_CHK);
-                                       return;
-                               }
-                       } else
-                               pmlmeext->retry = 0;
-
-                       if (tx_chk == _FAIL)
-                               pmlmeinfo->link_count &= 0xf;
-                       else {
-                               pxmitpriv->last_tx_pkts = pxmitpriv->tx_pkts;
-                               pmlmeinfo->link_count = 0;
-                       }
-
-               }
-       } else if (is_client_associated_to_ibss23a(padapter)) {
-               /* linked IBSS mode */
-               /* for each assoc list entry to check the rx pkt counter */
-               for (i = IBSS_START_MAC_ID; i < NUM_STA; i++) {
-                       if (pmlmeinfo->FW_sta_info[i].status == 1) {
-                               psta = pmlmeinfo->FW_sta_info[i].psta;
-
-                               if (!psta)
-                                       continue;
-
-                               if (pmlmeinfo->FW_sta_info[i].rx_pkt ==
-                                   sta_rx_pkts(psta)) {
-
-                                       if (pmlmeinfo->FW_sta_info[i].retry<3) {
-                                               pmlmeinfo->FW_sta_info[i].retry++;
-                                       } else {
-                                               pmlmeinfo->FW_sta_info[i].retry = 0;
-                                               pmlmeinfo->FW_sta_info[i].status = 0;
-                                               report_del_sta_event23a(padapter, psta->hwaddr,
-                                                       65535/*  indicate disconnect caused by no rx */
-                                               );
-                                       }
-                               } else {
-                                       pmlmeinfo->FW_sta_info[i].retry = 0;
-                                       pmlmeinfo->FW_sta_info[i].rx_pkt = (u32)sta_rx_pkts(psta);
-                               }
-                       }
-               }
-               /* set_link_timer(pmlmeext, DISCONNECT_TO); */
-       }
-}
-
-static void survey_timer_hdl(unsigned long data)
-{
-       struct rtw_adapter *padapter = (struct rtw_adapter *)data;
-       struct cmd_obj *ph2c;
-       struct sitesurvey_parm *psurveyPara;
-       struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-
-       /* issue rtw_sitesurvey_cmd23a */
-       if (pmlmeext->sitesurvey_res.state > SCAN_START) {
-               if (pmlmeext->sitesurvey_res.state ==  SCAN_PROCESS)
-                       pmlmeext->sitesurvey_res.channel_idx++;
-
-               if (pmlmeext->scan_abort == true) {
-                       pmlmeext->sitesurvey_res.channel_idx =
-                               pmlmeext->sitesurvey_res.ch_num;
-                       DBG_8723A("%s idx:%d\n", __func__,
-                                 pmlmeext->sitesurvey_res.channel_idx);
-
-                       pmlmeext->scan_abort = false;/* reset */
-               }
-
-               ph2c = kzalloc(sizeof(struct cmd_obj), GFP_ATOMIC);
-               if (!ph2c)
-                       goto exit_survey_timer_hdl;
-
-               psurveyPara = kzalloc(sizeof(struct sitesurvey_parm),
-                                       GFP_ATOMIC);
-               if (!psurveyPara) {
-                       kfree(ph2c);
-                       goto exit_survey_timer_hdl;
-               }
-
-               init_h2fwcmd_w_parm_no_rsp(ph2c, psurveyPara,
-                                          GEN_CMD_CODE(_SiteSurvey));
-               rtw_enqueue_cmd23a(pcmdpriv, ph2c);
-       }
-
-exit_survey_timer_hdl:
-       return;
-}
-
-static void link_timer_hdl(unsigned long data)
-{
-       struct rtw_adapter *padapter = (struct rtw_adapter *)data;
-       /* static unsigned int          rx_pkt = 0; */
-       /* static u64                           tx_cnt = 0; */
-       /* struct xmit_priv *pxmitpriv = &padapter->xmitpriv; */
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       /* struct sta_priv              *pstapriv = &padapter->stapriv; */
-
-       if (pmlmeinfo->state & WIFI_FW_AUTH_NULL) {
-               DBG_8723A("link_timer_hdl:no beacon while connecting\n");
-               pmlmeinfo->state = MSR_NOLINK;
-               report_join_res23a(padapter, -3);
-       } else if (pmlmeinfo->state & WIFI_FW_AUTH_STATE) {
-               /* re-auth timer */
-               if (++pmlmeinfo->reauth_count > REAUTH_LIMIT) {
-                       /* if (pmlmeinfo->auth_algo != dot11AuthAlgrthm_Auto) */
-                       /*  */
-                               pmlmeinfo->state = 0;
-                               report_join_res23a(padapter, -1);
-                               return;
-                       /*  */
-                       /* else */
-                       /*  */
-                       /* pmlmeinfo->auth_algo = dot11AuthAlgrthm_Shared; */
-                       /* pmlmeinfo->reauth_count = 0; */
-                       /*  */
-               }
-
-               DBG_8723A("link_timer_hdl: auth timeout and try again\n");
-               pmlmeinfo->auth_seq = 1;
-               issue_auth(padapter, NULL, 0);
-               set_link_timer(pmlmeext, REAUTH_TO);
-       } else if (pmlmeinfo->state & WIFI_FW_ASSOC_STATE) {
-               /* re-assoc timer */
-               if (++pmlmeinfo->reassoc_count > REASSOC_LIMIT) {
-                       pmlmeinfo->state = MSR_NOLINK;
-                       report_join_res23a(padapter, -2);
-                       return;
-               }
-
-               DBG_8723A("link_timer_hdl: assoc timeout and try again\n");
-               issue_assocreq(padapter);
-               set_link_timer(pmlmeext, REASSOC_TO);
-       }
-}
-
-static void addba_timer_hdl(unsigned long data)
-{
-       struct sta_info *psta = (struct sta_info *)data;
-       struct ht_priv *phtpriv;
-
-       if (!psta)
-               return;
-
-       phtpriv = &psta->htpriv;
-
-       if (phtpriv->ht_option && phtpriv->ampdu_enable) {
-               if (phtpriv->candidate_tid_bitmap)
-                       phtpriv->candidate_tid_bitmap = 0x0;
-       }
-}
-
-void init_addba_retry_timer23a(struct sta_info *psta)
-{
-       setup_timer(&psta->addba_retry_timer, addba_timer_hdl,
-                   (unsigned long)psta);
-}
-
-void init_mlme_ext_timer23a(struct rtw_adapter *padapter)
-{
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-
-       setup_timer(&pmlmeext->survey_timer, survey_timer_hdl,
-                   (unsigned long)padapter);
-
-       setup_timer(&pmlmeext->link_timer, link_timer_hdl,
-                   (unsigned long)padapter);
-}
-
-int NULL_hdl23a(struct rtw_adapter *padapter, const u8 *pbuf)
-{
-       return H2C_SUCCESS;
-}
-
-int setopmode_hdl23a(struct rtw_adapter *padapter, const u8 *pbuf)
-{
-       enum nl80211_iftype type;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       const struct setopmode_parm *psetop = (struct setopmode_parm *)pbuf;
-
-       switch (psetop->mode) {
-       case NL80211_IFTYPE_P2P_GO:
-       case NL80211_IFTYPE_AP:
-               pmlmeinfo->state = MSR_AP;
-               type = MSR_AP;
-               break;
-       case NL80211_IFTYPE_P2P_CLIENT:
-       case NL80211_IFTYPE_STATION:
-               /*  clear state */
-               pmlmeinfo->state &= ~(BIT(0)|BIT(1));
-               /* set to STATION_STATE */
-               pmlmeinfo->state |= MSR_INFRA;
-               type = MSR_INFRA;
-               break;
-       case NL80211_IFTYPE_ADHOC:
-               type = MSR_ADHOC;
-               break;
-       default:
-               type = MSR_NOLINK;
-               break;
-       }
-
-       hw_var_set_opmode(padapter, type);
-       /* Set_NETYPE0_MSR(padapter, type); */
-
-       return H2C_SUCCESS;
-}
-
-int createbss_hdl23a(struct rtw_adapter *padapter, const u8 *pbuf)
-{
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       struct wlan_bssid_ex *pnetwork = &pmlmeinfo->network;
-       const struct wlan_bssid_ex *pparm = (struct wlan_bssid_ex *)pbuf;
-       /* u32  initialgain; */
-
-       if (pparm->ifmode == NL80211_IFTYPE_AP ||
-           pparm->ifmode == NL80211_IFTYPE_P2P_GO) {
-#ifdef CONFIG_8723AU_AP_MODE
-               if (pmlmeinfo->state == MSR_AP) {
-                       /* todo: */
-                       return H2C_SUCCESS;
-               }
-#endif
-       }
-
-       /* below is for ad-hoc master */
-       if (pparm->ifmode == NL80211_IFTYPE_ADHOC) {
-               rtw_joinbss_reset23a(padapter);
-
-               pmlmeext->cur_bwmode = HT_CHANNEL_WIDTH_20;
-               pmlmeext->cur_ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
-               pmlmeinfo->ERP_enable = 0;
-               pmlmeinfo->WMM_enable = 0;
-               pmlmeinfo->HT_enable = 0;
-               pmlmeinfo->HT_caps_enable = 0;
-               pmlmeinfo->HT_info_enable = 0;
-
-               /* disable dynamic functions, such as high power, DIG */
-               rtl8723a_odm_support_ability_backup(padapter);
-
-               rtl8723a_odm_support_ability_clr(padapter,
-                                                DYNAMIC_FUNC_DISABLE);
-
-               /* cancel link timer */
-               del_timer_sync(&pmlmeext->link_timer);
-
-               /* clear CAM */
-               flush_all_cam_entry23a(padapter);
-
-               if (pparm->IELength > MAX_IE_SZ)/* Check pbuf->IELength */
-                       return H2C_PARAMETERS_ERROR;
-
-               memcpy(pnetwork, pparm, sizeof(struct wlan_bssid_ex));
-
-               start_create_ibss(padapter);
-       }
-
-       return H2C_SUCCESS;
-}
-
-int join_cmd_hdl23a(struct rtw_adapter *padapter, const u8 *pbuf)
-{
-       struct registry_priv *pregpriv = &padapter->registrypriv;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       struct wlan_bssid_ex *pnetwork = &pmlmeinfo->network;
-       const struct wlan_bssid_ex *pparm = (struct wlan_bssid_ex *)pbuf;
-       struct ieee80211_ht_operation *pht_info;
-       u32 i;
-       u8 *p;
-       /* u32  initialgain; */
-       /* u32  acparm; */
-
-       /* check already connecting to AP or not */
-       if (pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS) {
-               if (pmlmeinfo->state & MSR_INFRA)
-                       issue_deauth_ex(padapter, pnetwork->MacAddress,
-                                       WLAN_REASON_DEAUTH_LEAVING, 5, 100);
-
-               pmlmeinfo->state = MSR_NOLINK;
-
-               /* clear CAM */
-               flush_all_cam_entry23a(padapter);
-
-               del_timer_sync(&pmlmeext->link_timer);
-
-               /* set MSR to nolink -> infra. mode */
-               rtl8723a_set_media_status(padapter, MSR_INFRA);
-
-               hw_var_set_mlme_disconnect(padapter);
-       }
-
-       rtw_joinbss_reset23a(padapter);
-
-       pmlmeext->cur_bwmode = HT_CHANNEL_WIDTH_20;
-       pmlmeext->cur_ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
-       pmlmeinfo->ERP_enable = 0;
-       pmlmeinfo->WMM_enable = 0;
-       pmlmeinfo->HT_enable = 0;
-       pmlmeinfo->HT_caps_enable = 0;
-       pmlmeinfo->HT_info_enable = 0;
-       pmlmeinfo->bwmode_updated = false;
-       /* pmlmeinfo->assoc_AP_vendor = HT_IOT_PEER_MAX; */
-
-       if (pparm->IELength > MAX_IE_SZ)/* Check pbuf->IELength */
-               return H2C_PARAMETERS_ERROR;
-
-       memcpy(pnetwork, pbuf, sizeof(struct wlan_bssid_ex));
-
-       /* Check AP vendor to move rtw_joinbss_cmd23a() */
-       /* pmlmeinfo->assoc_AP_vendor = check_assoc_AP23a(pnetwork->IEs,
-          pnetwork->IELength); */
-
-       for (i = 0; i < pnetwork->IELength;) {
-               p = pnetwork->IEs + i;
-
-               switch (p[0]) {
-               case WLAN_EID_VENDOR_SPECIFIC:/* Get WMM IE. */
-                       if (!memcmp(p + 2, WMM_OUI23A, 4))
-                               pmlmeinfo->WMM_enable = 1;
-                       break;
-
-               case WLAN_EID_HT_CAPABILITY:    /* Get HT Cap IE. */
-                       pmlmeinfo->HT_caps_enable = 1;
-                       break;
-
-               case WLAN_EID_HT_OPERATION:     /* Get HT Info IE. */
-                       pmlmeinfo->HT_info_enable = 1;
-
-                       /* spec case only for cisco's ap because cisco's ap
-                        * issue assoc rsp using mcs rate @40MHz or @20MHz */
-                       pht_info = (struct ieee80211_ht_operation *)(p + 2);
-
-                       if (pregpriv->cbw40_enable &&
-                           (pht_info->ht_param &
-                            IEEE80211_HT_PARAM_CHAN_WIDTH_ANY)) {
-                               /* switch to the 40M Hz mode according to AP */
-                               pmlmeext->cur_bwmode = HT_CHANNEL_WIDTH_40;
-                               switch (pht_info->ht_param &
-                                       IEEE80211_HT_PARAM_CHA_SEC_OFFSET) {
-                               case IEEE80211_HT_PARAM_CHA_SEC_ABOVE:
-                                       pmlmeext->cur_ch_offset =
-                                               HAL_PRIME_CHNL_OFFSET_LOWER;
-                                       break;
-
-                               case IEEE80211_HT_PARAM_CHA_SEC_BELOW:
-                                       pmlmeext->cur_ch_offset =
-                                               HAL_PRIME_CHNL_OFFSET_UPPER;
-                                       break;
-
-                               default:
-                                       pmlmeext->cur_ch_offset =
-                                               HAL_PRIME_CHNL_OFFSET_DONT_CARE;
-                                       break;
-                               }
-
-                               DBG_8723A("set ch/bw before connected\n");
-                       }
-                       break;
-
-               default:
-                       break;
-               }
-
-               i += (p[1] + 2);
-       }
-
-       hw_var_set_bssid(padapter, pmlmeinfo->network.MacAddress);
-       hw_var_set_mlme_join(padapter, 0);
-
-       /* cancel link timer */
-       del_timer_sync(&pmlmeext->link_timer);
-
-       start_clnt_join(padapter);
-
-       return H2C_SUCCESS;
-}
-
-int disconnect_hdl23a(struct rtw_adapter *padapter, const u8 *pbuf)
-{
-       const struct disconnect_parm *param = (struct disconnect_parm *)pbuf;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       struct wlan_bssid_ex *pnetwork = &pmlmeinfo->network;
-
-       if (is_client_associated_to_ap23a(padapter)) {
-               issue_deauth_ex(padapter, pnetwork->MacAddress,
-                               WLAN_REASON_DEAUTH_LEAVING,
-                               param->deauth_timeout_ms/100, 100);
-       }
-
-       /* set_opmode_cmd(padapter, infra_client_with_mlme); */
-
-       /* pmlmeinfo->state = MSR_NOLINK; */
-
-       hw_var_set_mlme_disconnect(padapter);
-       hw_var_set_bssid(padapter, null_addr);
-
-       /* restore to initial setting. */
-       update_tx_basic_rate23a(padapter, padapter->registrypriv.wireless_mode);
-
-       if ((pmlmeinfo->state & 0x03) == MSR_ADHOC ||
-           (pmlmeinfo->state & 0x03) == MSR_AP)
-               rtl8723a_set_bcn_func(padapter, 0);     /* Stop BCN */
-
-       /* set MSR to no link state -> infra. mode */
-       rtl8723a_set_media_status(padapter, MSR_INFRA);
-
-       pmlmeinfo->state = MSR_NOLINK;
-
-       /* switch to the 20M Hz mode after disconnect */
-       pmlmeext->cur_bwmode = HT_CHANNEL_WIDTH_20;
-       pmlmeext->cur_ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
-
-       set_channel_bwmode23a(padapter, pmlmeext->cur_channel,
-                             pmlmeext->cur_ch_offset, pmlmeext->cur_bwmode);
-
-       flush_all_cam_entry23a(padapter);
-
-       del_timer_sync(&pmlmeext->link_timer);
-
-       rtw_free_uc_swdec_pending_queue23a(padapter);
-
-       return H2C_SUCCESS;
-}
-
-static int
-rtw_scan_ch_decision(struct rtw_adapter *padapter,
-                    struct rtw_ieee80211_channel *out, u32 out_num,
-                    const struct rtw_ieee80211_channel *in, u32 in_num)
-{
-       int i, j;
-       int scan_ch_num = 0;
-       int set_idx;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-
-       /* clear out first */
-       memset(out, 0, sizeof(struct rtw_ieee80211_channel)*out_num);
-
-       /* acquire channels from in */
-       j = 0;
-       for (i = 0;i<in_num;i++) {
-               if (in[i].hw_value &&
-                   !(in[i].flags & IEEE80211_CHAN_DISABLED) &&
-                   (set_idx = rtw_ch_set_search_ch23a(pmlmeext->channel_set,
-                                                      in[i].hw_value)) >= 0) {
-                       memcpy(&out[j], &in[i],
-                              sizeof(struct rtw_ieee80211_channel));
-
-                       if (pmlmeext->channel_set[set_idx].ScanType ==
-                           SCAN_PASSIVE)
-                               out[j].flags &= IEEE80211_CHAN_NO_IR;
-
-                       j++;
-               }
-               if (j>= out_num)
-                       break;
-       }
-
-       /* if out is empty, use channel_set as default */
-       if (j == 0) {
-               for (i = 0;i<pmlmeext->max_chan_nums;i++) {
-                       out[i].hw_value = pmlmeext->channel_set[i].ChannelNum;
-
-                       if (pmlmeext->channel_set[i].ScanType == SCAN_PASSIVE)
-                               out[i].flags &= IEEE80211_CHAN_NO_IR;
-
-                       j++;
-               }
-       }
-
-       if (padapter->setband == GHZ_24) {                      /*  2.4G */
-               for (i = 0; i < j ; i++) {
-                       if (out[i].hw_value > 35)
-                               memset(&out[i], 0,
-                                      sizeof(struct rtw_ieee80211_channel));
-                       else
-                               scan_ch_num++;
-               }
-               j = scan_ch_num;
-       } else if  (padapter->setband == GHZ_50) {              /*  5G */
-               for (i = 0; i < j ; i++) {
-                       if (out[i].hw_value > 35) {
-                               memcpy(&out[scan_ch_num++], &out[i],
-                                      sizeof(struct rtw_ieee80211_channel));
-                       }
-               }
-               j = scan_ch_num;
-       } else
-               {}
-
-       return j;
-}
-
-int sitesurvey_cmd_hdl23a(struct rtw_adapter *padapter, const u8 *pbuf)
-{
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       const struct sitesurvey_parm *pparm = (struct sitesurvey_parm *)pbuf;
-       u8 bdelayscan = false;
-       u32 initialgain;
-       u32 i;
-
-       if (pmlmeext->sitesurvey_res.state == SCAN_DISABLE) {
-               pmlmeext->sitesurvey_res.state = SCAN_START;
-               pmlmeext->sitesurvey_res.bss_cnt = 0;
-               pmlmeext->sitesurvey_res.channel_idx = 0;
-
-               for (i = 0; i < RTW_SSID_SCAN_AMOUNT; i++) {
-                       if (pparm->ssid[i].ssid_len) {
-                               memcpy(pmlmeext->sitesurvey_res.ssid[i].ssid,
-                                      pparm->ssid[i].ssid,
-                                      IEEE80211_MAX_SSID_LEN);
-                               pmlmeext->sitesurvey_res.ssid[i].ssid_len =
-                                       pparm->ssid[i].ssid_len;
-                       } else {
-                               pmlmeext->sitesurvey_res.ssid[i].ssid_len = 0;
-                       }
-               }
-
-               pmlmeext->sitesurvey_res.ch_num =
-                       rtw_scan_ch_decision(padapter,
-                                            pmlmeext->sitesurvey_res.ch,
-                                            RTW_CHANNEL_SCAN_AMOUNT,
-                                            pparm->ch, pparm->ch_num);
-
-               pmlmeext->sitesurvey_res.scan_mode = pparm->scan_mode;
-
-               /* issue null data if associating to the AP */
-               if (is_client_associated_to_ap23a(padapter)) {
-                       pmlmeext->sitesurvey_res.state = SCAN_TXNULL;
-
-                       /* switch to correct channel of current network
-                          before issue keep-alive frames */
-                       if (rtw_get_oper_ch23a(padapter) !=
-                           pmlmeext->cur_channel)
-                               SelectChannel23a(padapter,
-                                                pmlmeext->cur_channel);
-
-                       issue_nulldata23a(padapter, NULL, 1, 3, 500);
-
-                       bdelayscan = true;
-               }
-
-               if (bdelayscan) {
-                       /* delay 50ms to protect nulldata(1). */
-                       set_survey_timer(pmlmeext, 50);
-                       return H2C_SUCCESS;
-               }
-       }
-
-       if (pmlmeext->sitesurvey_res.state == SCAN_START ||
-           pmlmeext->sitesurvey_res.state == SCAN_TXNULL) {
-               /* disable dynamic functions, such as high power, DIG */
-               rtl8723a_odm_support_ability_backup(padapter);
-               rtl8723a_odm_support_ability_clr(padapter,
-                                                DYNAMIC_FUNC_DISABLE);
-
-               /* config the initial gain under scanning, need to
-                  write the BB registers */
-               if (wdev_to_priv(padapter->rtw_wdev)->p2p_enabled == true)
-                       initialgain = 0x30;
-               else
-                       initialgain = 0x1E;
-
-               rtl8723a_set_initial_gain(padapter, initialgain);
-
-               /* set MSR to no link state */
-               rtl8723a_set_media_status(padapter, MSR_NOLINK);
-
-               rtl8723a_mlme_sitesurvey(padapter, 1);
-
-               pmlmeext->sitesurvey_res.state = SCAN_PROCESS;
-       }
-
-       rtw_site_survey(padapter);
-
-       return H2C_SUCCESS;
-}
-
-int setauth_hdl23a(struct rtw_adapter *padapter, const u8 *pbuf)
-{
-       const struct setauth_parm *pparm = (struct setauth_parm *)pbuf;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-
-       if (pparm->mode < 4)
-               pmlmeinfo->auth_algo = pparm->mode;
-
-       return H2C_SUCCESS;
-}
-
-int setkey_hdl23a(struct rtw_adapter *padapter, const u8 *pbuf)
-{
-       unsigned short ctrl;
-       const struct setkey_parm *pparm = (struct setkey_parm *)pbuf;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       unsigned char null_sta[] = {0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
-
-       /* main tx key for wep. */
-       if (pparm->set_tx)
-               pmlmeinfo->key_index = pparm->keyid;
-
-       /* write cam */
-       ctrl = BIT(15) | (pparm->algorithm) << 2 | pparm->keyid;
-
-       DBG_8723A_LEVEL(_drv_always_, "set group key to hw: alg:%d(WEP40-1 "
-                       "WEP104-5 TKIP-2 AES-4) keyid:%d\n",
-                       pparm->algorithm, pparm->keyid);
-       rtl8723a_cam_write(padapter, pparm->keyid, ctrl, null_sta, pparm->key);
-
-       /* allow multicast packets to driver */
-       rtl8723a_on_rcr_am(padapter);
-
-       return H2C_SUCCESS;
-}
-
-int set_stakey_hdl23a(struct rtw_adapter *padapter, const u8 *pbuf)
-{
-       u16 ctrl = 0;
-       u8 cam_id;/* cam_entry */
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       const struct set_stakey_parm *pparm = (struct set_stakey_parm *)pbuf;
-
-       /* cam_entry: */
-       /* 0~3 for default key */
-
-       /* for concurrent mode (ap+sta): */
-       /* default key is disable, using sw encrypt/decrypt */
-       /* cam_entry = 4  for sta mode (macid = 0) */
-       /* cam_entry(macid+3) = 5 ~ N for ap mode (aid = 1~N, macid = 2 ~N) */
-
-       /* for concurrent mode (sta+sta): */
-       /* default key is disable, using sw encrypt/decrypt */
-       /* cam_entry = 4 mapping to macid = 0 */
-       /* cam_entry = 5 mapping to macid = 2 */
-
-       cam_id = 4;
-
-       DBG_8723A_LEVEL(_drv_always_, "set pairwise key to hw: alg:%d(WEP40-1 "
-                       "WEP104-5 TKIP-2 AES-4) camid:%d\n",
-                       pparm->algorithm, cam_id);
-       if ((pmlmeinfo->state & 0x03) == MSR_AP) {
-               struct sta_info *psta;
-               struct sta_priv *pstapriv = &padapter->stapriv;
-
-               if (pparm->algorithm == 0) {    /*  clear cam entry */
-                       clear_cam_entry23a(padapter, pparm->id);
-                       return H2C_SUCCESS_RSP;
-               }
-
-               psta = rtw_get_stainfo23a(pstapriv, pparm->addr);
-               if (psta) {
-                       ctrl = BIT(15) | (pparm->algorithm << 2);
-
-                       DBG_8723A("r871x_set_stakey_hdl23a(): enc_algorithm "
-                                 "=%d\n", pparm->algorithm);
-
-                       if (psta->mac_id < 1 || psta->mac_id > (NUM_STA - 4)) {
-                               DBG_8723A("r871x_set_stakey_hdl23a():set_stakey"
-                                         " failed, mac_id(aid) =%d\n",
-                                         psta->mac_id);
-                               return H2C_REJECTED;
-                       }
-
-                       /* 0~3 for default key, cmd_id = macid + 3,
-                          macid = aid+1; */
-                       cam_id = psta->mac_id + 3;
-
-                       DBG_8723A("Write CAM, mac_addr =%pM, "
-                                 "cam_entry =%d\n", pparm->addr, cam_id);
-
-                       rtl8723a_cam_write(padapter, cam_id, ctrl,
-                                          pparm->addr, pparm->key);
-
-                       return H2C_SUCCESS_RSP;
-               } else {
-                       DBG_8723A("r871x_set_stakey_hdl23a(): sta has been "
-                                 "free\n");
-                       return H2C_REJECTED;
-               }
-       }
-
-       /* below for sta mode */
-
-       if (pparm->algorithm == 0) {    /*  clear cam entry */
-               clear_cam_entry23a(padapter, pparm->id);
-               return H2C_SUCCESS;
-       }
-
-       ctrl = BIT(15) | (pparm->algorithm << 2);
-
-       rtl8723a_cam_write(padapter, cam_id, ctrl, pparm->addr, pparm->key);
-
-       pmlmeinfo->enc_algo = pparm->algorithm;
-
-       return H2C_SUCCESS;
-}
-
-int add_ba_hdl23a(struct rtw_adapter *padapter, const u8 *pbuf)
-{
-       const struct addBaReq_parm *pparm = (struct addBaReq_parm *)pbuf;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       struct sta_info *psta;
-
-       psta = rtw_get_stainfo23a(&padapter->stapriv, pparm->addr);
-
-       if (!psta)
-               return H2C_SUCCESS;
-
-       if (((pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS) &&
-            pmlmeinfo->HT_enable) ||
-           (pmlmeinfo->state & 0x03) == MSR_AP) {
-               issue_action_BA23a(padapter, pparm->addr,
-                                  WLAN_ACTION_ADDBA_REQ, (u16)pparm->tid);
-               mod_timer(&psta->addba_retry_timer,
-                         jiffies + msecs_to_jiffies(ADDBA_TO));
-       } else
-               psta->htpriv.candidate_tid_bitmap &= ~BIT(pparm->tid);
-
-       return H2C_SUCCESS;
-}
-
-int set_tx_beacon_cmd23a(struct rtw_adapter *padapter)
-{
-       struct cmd_obj *ph2c;
-       struct Tx_Beacon_param *ptxBeacon_parm;
-       struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       u8 res = _SUCCESS;
-       int len_diff = 0;
-
-       ph2c = kzalloc(sizeof(struct cmd_obj), GFP_ATOMIC);
-       if (!ph2c) {
-               res = _FAIL;
-               goto exit;
-       }
-
-       ptxBeacon_parm = kzalloc(sizeof(struct Tx_Beacon_param), GFP_ATOMIC);
-       if (!ptxBeacon_parm) {
-               kfree(ph2c);
-               res = _FAIL;
-               goto exit;
-       }
-
-       memcpy(&ptxBeacon_parm->network, &pmlmeinfo->network,
-              sizeof(struct wlan_bssid_ex));
-
-       len_diff = update_hidden_ssid(ptxBeacon_parm->network.IEs,
-                                     ptxBeacon_parm->network.IELength,
-                                     pmlmeinfo->hidden_ssid_mode);
-       ptxBeacon_parm->network.IELength += len_diff;
-
-       init_h2fwcmd_w_parm_no_rsp(ph2c, ptxBeacon_parm,
-                                  GEN_CMD_CODE(_TX_Beacon));
-
-       res = rtw_enqueue_cmd23a(pcmdpriv, ph2c);
-
-exit:
-       return res;
-}
-
-int mlme_evt_hdl23a(struct rtw_adapter *padapter, const u8 *pbuf)
-{
-       u8 evt_code, evt_seq;
-       u16 evt_sz;
-       const struct C2HEvent_Header *c2h;
-       void (*event_callback)(struct rtw_adapter *dev, const u8 *pbuf);
-
-       c2h = (struct C2HEvent_Header *)pbuf;
-       evt_sz = c2h->len;
-       evt_seq = c2h->seq;
-       evt_code = c2h->ID;
-
-       /*  checking if event code is valid */
-       if (evt_code >= MAX_C2HEVT) {
-               RT_TRACE(_module_rtl871x_cmd_c_, _drv_err_,
-                        "Event Code(%d) mismatch!\n", evt_code);
-               goto _abort_event_;
-       }
-
-       /*  checking if event size match the event parm size */
-       if (wlanevents[evt_code].parmsize != 0 &&
-           wlanevents[evt_code].parmsize != evt_sz) {
-               RT_TRACE(_module_rtl871x_cmd_c_, _drv_err_,
-                        "Event(%d) Parm Size mismatch (%d vs %d)!\n",
-                        evt_code, wlanevents[evt_code].parmsize, evt_sz);
-               goto _abort_event_;
-       }
-
-       event_callback = wlanevents[evt_code].event_callback;
-       event_callback(padapter, pbuf + sizeof(struct C2HEvent_Header));
-
-_abort_event_:
-
-       return H2C_SUCCESS;
-}
-
-int h2c_msg_hdl23a(struct rtw_adapter *padapter, const u8 *pbuf)
-{
-       if (!pbuf)
-               return H2C_PARAMETERS_ERROR;
-
-       return H2C_SUCCESS;
-}
-
-int tx_beacon_hdl23a(struct rtw_adapter *padapter, const u8 *pbuf)
-{
-       if (send_beacon23a(padapter) == _FAIL) {
-               DBG_8723A("issue_beacon23a, fail!\n");
-               return H2C_PARAMETERS_ERROR;
-       }
-#ifdef CONFIG_8723AU_AP_MODE
-       else { /* tx bc/mc frames after update TIM */
-               struct sta_info *psta_bmc;
-               struct list_head *phead;
-               struct xmit_frame *pxmitframe, *ptmp;
-               struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-               struct sta_priv *pstapriv = &padapter->stapriv;
-
-               /* for BC/MC Frames */
-               psta_bmc = rtw_get_bcmc_stainfo23a(padapter);
-               if (!psta_bmc)
-                       return H2C_SUCCESS;
-
-               if (pstapriv->tim_bitmap & BIT(0) && psta_bmc->sleepq_len > 0) {
-                       msleep(10);/*  10ms, ATIM(HIQ) Windows */
-                       /* spin_lock_bh(&psta_bmc->sleep_q.lock); */
-                       spin_lock_bh(&pxmitpriv->lock);
-
-                       phead = get_list_head(&psta_bmc->sleep_q);
-
-                       list_for_each_entry_safe(pxmitframe, ptmp,
-                                                phead, list) {
-
-                               list_del_init(&pxmitframe->list);
-
-                               psta_bmc->sleepq_len--;
-                               if (psta_bmc->sleepq_len>0)
-                                       pxmitframe->attrib.mdata = 1;
-                               else
-                                       pxmitframe->attrib.mdata = 0;
-
-                               pxmitframe->attrib.triggered = 1;
-
-                               pxmitframe->attrib.qsel = 0x11;/* HIQ */
-
-                               rtl8723au_hal_xmitframe_enqueue(padapter,
-                                                               pxmitframe);
-                       }
-                       /* spin_unlock_bh(&psta_bmc->sleep_q.lock); */
-                       spin_unlock_bh(&pxmitpriv->lock);
-               }
-       }
-#endif
-
-       return H2C_SUCCESS;
-}
-
-int set_ch_hdl23a(struct rtw_adapter *padapter, const u8 *pbuf)
-{
-       const struct set_ch_parm *set_ch_parm;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-
-       if (!pbuf)
-               return H2C_PARAMETERS_ERROR;
-
-       set_ch_parm = (struct set_ch_parm *)pbuf;
-
-       DBG_8723A("%s(%s): ch:%u, bw:%u, ch_offset:%u\n", __func__,
-                 padapter->pnetdev->name, set_ch_parm->ch,
-                 set_ch_parm->bw, set_ch_parm->ch_offset);
-
-       pmlmeext->cur_channel = set_ch_parm->ch;
-       pmlmeext->cur_ch_offset = set_ch_parm->ch_offset;
-       pmlmeext->cur_bwmode = set_ch_parm->bw;
-
-       set_channel_bwmode23a(padapter, set_ch_parm->ch,
-                             set_ch_parm->ch_offset, set_ch_parm->bw);
-
-       return H2C_SUCCESS;
-}
-
-int set_chplan_hdl23a(struct rtw_adapter *padapter, const u8 *pbuf)
-{
-       const struct SetChannelPlan_param *setChannelPlan_param;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-
-       if (!pbuf)
-               return H2C_PARAMETERS_ERROR;
-
-       setChannelPlan_param = (struct SetChannelPlan_param *)pbuf;
-
-       pmlmeext->max_chan_nums =
-               init_channel_set(padapter, setChannelPlan_param->channel_plan,
-                                pmlmeext->channel_set);
-       init_channel_list(padapter, pmlmeext->channel_set,
-                         pmlmeext->max_chan_nums, &pmlmeext->channel_list);
-
-       return H2C_SUCCESS;
-}
-
-int led_blink_hdl23a(struct rtw_adapter *padapter, const u8 *pbuf)
-{
-       struct LedBlink_param *ledBlink_param;
-
-       if (!pbuf)
-               return H2C_PARAMETERS_ERROR;
-
-       ledBlink_param = (struct LedBlink_param *)pbuf;
-
-       return H2C_SUCCESS;
-}
-
-int set_csa_hdl23a(struct rtw_adapter *padapter, const u8 *pbuf)
-{
-       return H2C_REJECTED;
-}
-
-/*  TDLS_WRCR          : write RCR DATA BIT */
-/*  TDLS_SD_PTI                : issue peer traffic indication */
-/*  TDLS_CS_OFF                : go back to the channel linked with AP,
-                         terminating channel switch procedure */
-/*  TDLS_INIT_CH_SEN   : init channel sensing, receive all data and
-                         mgnt frame */
-/*  TDLS_DONE_CH_SEN   : channel sensing and report candidate channel */
-/*  TDLS_OFF_CH                : first time set channel to off channel */
-/*  TDLS_BASE_CH       : go back tp the channel linked with AP when set
-                         base channel as target channel */
-/*  TDLS_P_OFF_CH      : periodically go to off channel */
-/*  TDLS_P_BASE_CH     : periodically go back to base channel */
-/*  TDLS_RS_RCR                : restore RCR */
-/*  TDLS_CKALV_PH1     : check alive timer phase1 */
-/*  TDLS_CKALV_PH2     : check alive timer phase2 */
-/*  TDLS_FREE_STA      : free tdls sta */
-int tdls_hdl23a(struct rtw_adapter *padapter, const u8 *pbuf)
-{
-       return H2C_REJECTED;
-}
diff --git a/drivers/staging/rtl8723au/core/rtw_pwrctrl.c b/drivers/staging/rtl8723au/core/rtw_pwrctrl.c
deleted file mode 100644 (file)
index 2d43958..0000000
+++ /dev/null
@@ -1,607 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#define _RTW_PWRCTRL_C_
-
-#include <linux/mutex.h>
-#include <osdep_service.h>
-#include <drv_types.h>
-#include <osdep_intf.h>
-#include <rtl8723a_cmd.h>
-#include <rtw_sreset.h>
-
-#include <rtl8723a_bt_intf.h>
-#include <usb_ops_linux.h>
-
-void ips_enter23a(struct rtw_adapter *padapter)
-{
-       struct pwrctrl_priv *pwrpriv = &padapter->pwrctrlpriv;
-
-       mutex_lock(&pwrpriv->mutex_lock);
-
-       pwrpriv->bips_processing = true;
-
-       /*  syn ips_mode with request */
-       pwrpriv->ips_mode = pwrpriv->ips_mode_req;
-
-       pwrpriv->ips_enter23a_cnts++;
-       DBG_8723A("==>ips_enter23a cnts:%d\n", pwrpriv->ips_enter23a_cnts);
-       rtl8723a_BT_disable_coexist(padapter);
-
-       if (pwrpriv->change_rfpwrstate == rf_off) {
-               pwrpriv->bpower_saving = true;
-               DBG_8723A_LEVEL(_drv_always_, "nolinked power save enter\n");
-
-               if (pwrpriv->ips_mode == IPS_LEVEL_2)
-                       pwrpriv->bkeepfwalive = true;
-
-               rtw_ips_pwr_down23a(padapter);
-               pwrpriv->rf_pwrstate = rf_off;
-       }
-       pwrpriv->bips_processing = false;
-
-       mutex_unlock(&pwrpriv->mutex_lock);
-}
-
-int ips_leave23a(struct rtw_adapter *padapter)
-{
-       struct pwrctrl_priv *pwrpriv = &padapter->pwrctrlpriv;
-       struct security_priv *psecuritypriv = &padapter->securitypriv;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       int result = _SUCCESS;
-       int keyid;
-
-       mutex_lock(&pwrpriv->mutex_lock);
-
-       if (pwrpriv->rf_pwrstate == rf_off && !pwrpriv->bips_processing) {
-               pwrpriv->bips_processing = true;
-               pwrpriv->change_rfpwrstate = rf_on;
-               pwrpriv->ips_leave23a_cnts++;
-               DBG_8723A("==>ips_leave23a cnts:%d\n",
-                         pwrpriv->ips_leave23a_cnts);
-
-               result = rtw_ips_pwr_up23a(padapter);
-               if (result == _SUCCESS)
-                       pwrpriv->rf_pwrstate = rf_on;
-
-               DBG_8723A_LEVEL(_drv_always_, "nolinked power save leave\n");
-
-               if (psecuritypriv->dot11PrivacyAlgrthm ==
-                   WLAN_CIPHER_SUITE_WEP40 ||
-                   psecuritypriv->dot11PrivacyAlgrthm ==
-                   WLAN_CIPHER_SUITE_WEP104) {
-                       DBG_8723A("==>%s, channel(%d), processing(%x)\n",
-                                 __func__, padapter->mlmeextpriv.cur_channel,
-                                 pwrpriv->bips_processing);
-                       set_channel_bwmode23a(padapter,
-                                             padapter->mlmeextpriv.cur_channel,
-                                             HAL_PRIME_CHNL_OFFSET_DONT_CARE,
-                                             HT_CHANNEL_WIDTH_20);
-                       for (keyid = 0; keyid < 4; keyid++) {
-                               if (pmlmepriv->key_mask & BIT(keyid)) {
-                                       if (keyid ==
-                                           psecuritypriv->dot11PrivacyKeyIndex)
-                                               result = rtw_set_key23a(padapter, psecuritypriv, keyid, 1);
-                                       else
-                                               result = rtw_set_key23a(padapter, psecuritypriv, keyid, 0);
-                               }
-                       }
-               }
-
-               DBG_8723A("==> ips_leave23a.....LED(0x%08x)...\n",
-                         rtl8723au_read32(padapter, 0x4c));
-               pwrpriv->bips_processing = false;
-
-               pwrpriv->bkeepfwalive = false;
-               pwrpriv->bpower_saving = false;
-       }
-
-       mutex_unlock(&pwrpriv->mutex_lock);
-
-       return result;
-}
-
-
-static bool rtw_pwr_unassociated_idle(struct rtw_adapter *adapter)
-{
-       struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
-       struct xmit_priv *pxmit_priv = &adapter->xmitpriv;
-
-       bool ret = false;
-
-       if (time_after_eq(adapter->pwrctrlpriv.ips_deny_time, jiffies))
-               goto exit;
-
-       if (check_fwstate(pmlmepriv, WIFI_ASOC_STATE|WIFI_SITE_MONITOR) ||
-           check_fwstate(pmlmepriv, WIFI_UNDER_LINKING|WIFI_UNDER_WPS) ||
-           check_fwstate(pmlmepriv, WIFI_AP_STATE) ||
-           check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE|WIFI_ADHOC_STATE)){
-               goto exit;
-       }
-
-       if (pxmit_priv->free_xmitbuf_cnt != NR_XMITBUFF ||
-               pxmit_priv->free_xmit_extbuf_cnt != NR_XMIT_EXTBUFF) {
-               DBG_8723A_LEVEL(_drv_always_,
-                               "There are some pkts to transmit\n");
-               DBG_8723A_LEVEL(_drv_info_, "free_xmitbuf_cnt: %d, "
-                               "free_xmit_extbuf_cnt: %d\n",
-                               pxmit_priv->free_xmitbuf_cnt,
-                               pxmit_priv->free_xmit_extbuf_cnt);
-               goto exit;
-       }
-
-       ret = true;
-
-exit:
-       return ret;
-}
-
-void rtw_ps_processor23a(struct rtw_adapter *padapter)
-{
-       struct pwrctrl_priv *pwrpriv = &padapter->pwrctrlpriv;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-
-       pwrpriv->ps_processing = true;
-
-       if (pwrpriv->bips_processing == true)
-               goto exit;
-
-       if (pwrpriv->ips_mode_req == IPS_NONE)
-               goto exit;
-
-       if (!rtw_pwr_unassociated_idle(padapter))
-               goto exit;
-
-       if (pwrpriv->rf_pwrstate == rf_on &&
-           (pwrpriv->pwr_state_check_cnts % 4) == 0) {
-               DBG_8723A("==>%s .fw_state(%x)\n", __func__,
-                         get_fwstate(pmlmepriv));
-               pwrpriv->change_rfpwrstate = rf_off;
-               ips_enter23a(padapter);
-       }
-exit:
-       rtw_set_pwr_state_check_timer(&padapter->pwrctrlpriv);
-       pwrpriv->ps_processing = false;
-}
-
-static void pwr_state_check_handler(unsigned long data)
-{
-       struct rtw_adapter *padapter = (struct rtw_adapter *)data;
-
-       rtw_ps_cmd23a(padapter);
-}
-
-/*
- *
- * Parameters
- *   padapter
- *   pslv      power state level, only could be PS_STATE_S0 ~ PS_STATE_S4
- *
- */
-void rtw_set_rpwm23a(struct rtw_adapter *padapter, u8 pslv)
-{
-       u8 rpwm;
-       struct pwrctrl_priv *pwrpriv = &padapter->pwrctrlpriv;
-
-       pslv = PS_STATE(pslv);
-
-       if (pwrpriv->btcoex_rfon) {
-               if (pslv < PS_STATE_S4)
-                       pslv = PS_STATE_S3;
-       }
-
-       if (pwrpriv->rpwm == pslv) {
-               RT_TRACE(_module_rtl871x_pwrctrl_c_, _drv_err_,
-                        "%s: Already set rpwm[0x%02X], new = 0x%02X!\n",
-                        __func__, pwrpriv->rpwm, pslv);
-               return;
-       }
-
-       if (padapter->bSurpriseRemoved == true ||
-           padapter->hw_init_completed == false) {
-               RT_TRACE(_module_rtl871x_pwrctrl_c_, _drv_err_,
-                        "%s: SurpriseRemoved(%d) hw_init_completed(%d)\n",
-                        __func__, padapter->bSurpriseRemoved,
-                        padapter->hw_init_completed);
-
-               pwrpriv->cpwm = PS_STATE_S4;
-
-               return;
-       }
-
-       if (padapter->bDriverStopped == true) {
-               RT_TRACE(_module_rtl871x_pwrctrl_c_, _drv_err_,
-                        "%s: change power state(0x%02X) when DriverStopped\n",
-                        __func__, pslv);
-
-               if (pslv < PS_STATE_S2) {
-                       RT_TRACE(_module_rtl871x_pwrctrl_c_, _drv_err_,
-                                "%s: Reject to enter PS_STATE(0x%02X) lower than S2 when DriverStopped!!\n",
-                                __func__, pslv);
-                       return;
-               }
-       }
-
-       rpwm = pslv | pwrpriv->tog;
-       RT_TRACE(_module_rtl871x_pwrctrl_c_, _drv_notice_,
-                "rtw_set_rpwm23a: rpwm = 0x%02x cpwm = 0x%02x\n",
-                rpwm, pwrpriv->cpwm);
-
-       pwrpriv->rpwm = pslv;
-
-       rtl8723a_set_rpwm(padapter, rpwm);
-
-       pwrpriv->tog += 0x80;
-       pwrpriv->cpwm = pslv;
-}
-
-static bool PS_RDY_CHECK(struct rtw_adapter *padapter)
-{
-       unsigned long delta_time;
-       struct pwrctrl_priv *pwrpriv = &padapter->pwrctrlpriv;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-
-       delta_time = jiffies - pwrpriv->DelayLPSLastTimeStamp;
-
-       if (delta_time < LPS_DELAY_TIME)
-               return false;
-
-       if (!check_fwstate(pmlmepriv, _FW_LINKED) ||
-           check_fwstate(pmlmepriv, _FW_UNDER_SURVEY) ||
-           check_fwstate(pmlmepriv, WIFI_AP_STATE) ||
-           check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) ||
-           check_fwstate(pmlmepriv, WIFI_ADHOC_STATE))
-               return false;
-       if (pwrpriv->bInSuspend)
-               return false;
-       if (padapter->securitypriv.dot11AuthAlgrthm == dot11AuthAlgrthm_8021X &&
-           !padapter->securitypriv.binstallGrpkey) {
-               DBG_8723A("Group handshake still in progress !!!\n");
-               return false;
-       }
-       if (!rtw_cfg80211_pwr_mgmt(padapter))
-               return false;
-
-       return true;
-}
-
-void rtw_set_ps_mode23a(struct rtw_adapter *padapter, u8 ps_mode,
-                       u8 smart_ps, u8 bcn_ant_mode)
-{
-       struct pwrctrl_priv *pwrpriv = &padapter->pwrctrlpriv;
-
-       RT_TRACE(_module_rtl871x_pwrctrl_c_, _drv_notice_,
-                "%s: PowerMode =%d Smart_PS =%d\n",
-                __func__, ps_mode, smart_ps);
-
-       if (ps_mode > PM_Card_Disable) {
-               RT_TRACE(_module_rtl871x_pwrctrl_c_, _drv_err_,
-                        "ps_mode:%d error\n", ps_mode);
-               return;
-       }
-
-       if (pwrpriv->pwr_mode == ps_mode) {
-               if (PS_MODE_ACTIVE == ps_mode)
-                       return;
-
-               if (pwrpriv->smart_ps == smart_ps &&
-                   pwrpriv->bcn_ant_mode == bcn_ant_mode)
-                       return;
-       }
-
-       if (ps_mode == PS_MODE_ACTIVE) {
-               DBG_8723A("rtw_set_ps_mode23a: Leave 802.11 power save\n");
-
-               pwrpriv->pwr_mode = ps_mode;
-               rtw_set_rpwm23a(padapter, PS_STATE_S4);
-               rtl8723a_set_FwPwrMode_cmd(padapter, ps_mode);
-               pwrpriv->bFwCurrentInPSMode = false;
-       } else {
-               if (PS_RDY_CHECK(padapter) ||
-                   rtl8723a_BT_using_antenna_1(padapter)) {
-                       DBG_8723A("%s: Enter 802.11 power save\n", __func__);
-
-                       pwrpriv->bFwCurrentInPSMode = true;
-                       pwrpriv->pwr_mode = ps_mode;
-                       pwrpriv->smart_ps = smart_ps;
-                       pwrpriv->bcn_ant_mode = bcn_ant_mode;
-                       rtl8723a_set_FwPwrMode_cmd(padapter, ps_mode);
-
-                       rtw_set_rpwm23a(padapter, PS_STATE_S2);
-               }
-       }
-}
-
-/*
- * Return:
- *     0:      Leave OK
- *     -1:     Timeout
- *     -2:     Other error
- */
-s32 LPS_RF_ON_check23a(struct rtw_adapter *padapter, u32 delay_ms)
-{
-       unsigned long start_time, end_time;
-       u8 bAwake = false;
-       s32 err = 0;
-
-       start_time = jiffies;
-       end_time = start_time + msecs_to_jiffies(delay_ms);
-
-       while (1) {
-               bAwake = rtl8723a_get_fwlps_rf_on(padapter);
-               if (bAwake == true)
-                       break;
-
-               if (padapter->bSurpriseRemoved == true) {
-                       err = -2;
-                       DBG_8723A("%s: device surprise removed!!\n", __func__);
-                       break;
-               }
-
-               if (time_after(jiffies, end_time)) {
-                       err = -1;
-                       DBG_8723A("%s: Wait for FW LPS leave more than %u "
-                                 "ms!\n", __func__, delay_ms);
-                       break;
-               }
-               udelay(100);
-       }
-
-       return err;
-}
-
-/*     Description: */
-/*             Enter the leisure power save mode. */
-void LPS_Enter23a(struct rtw_adapter *padapter)
-{
-       struct pwrctrl_priv *pwrpriv = &padapter->pwrctrlpriv;
-
-       if (!PS_RDY_CHECK(padapter))
-               return;
-
-       if (pwrpriv->bLeisurePs) {
-               /*  Idle for a while if we connect to AP a while ago. */
-               if (pwrpriv->LpsIdleCount >= 2) { /*   4 Sec */
-                       if (pwrpriv->pwr_mode == PS_MODE_ACTIVE) {
-                               pwrpriv->bpower_saving = true;
-                               DBG_8723A("%s smart_ps:%d\n", __func__,
-                                         pwrpriv->smart_ps);
-                               /* For Tenda W311R IOT issue */
-                               rtw_set_ps_mode23a(padapter,
-                                                  pwrpriv->power_mgnt,
-                                                  pwrpriv->smart_ps, 0);
-                       }
-               } else
-                       pwrpriv->LpsIdleCount++;
-       }
-}
-
-/*     Description: */
-/*             Leave the leisure power save mode. */
-void LPS_Leave23a(struct rtw_adapter *padapter)
-{
-#define LPS_LEAVE_TIMEOUT_MS 100
-
-       struct pwrctrl_priv *pwrpriv = &padapter->pwrctrlpriv;
-
-       if (pwrpriv->bLeisurePs) {
-               if (pwrpriv->pwr_mode != PS_MODE_ACTIVE) {
-                       rtw_set_ps_mode23a(padapter, PS_MODE_ACTIVE, 0, 0);
-
-                       if (pwrpriv->pwr_mode == PS_MODE_ACTIVE)
-                               LPS_RF_ON_check23a(padapter,
-                                                  LPS_LEAVE_TIMEOUT_MS);
-               }
-       }
-
-       pwrpriv->bpower_saving = false;
-}
-
-/*  Description: Leave all power save mode: LPS, FwLPS, IPS if needed. */
-/*  Move code to function by tynli. 2010.03.26. */
-void LeaveAllPowerSaveMode23a(struct rtw_adapter *Adapter)
-{
-       struct mlme_priv *pmlmepriv = &Adapter->mlmepriv;
-       u8 enqueue = 0;
-
-       /* DBG_8723A("%s.....\n", __func__); */
-       if (check_fwstate(pmlmepriv, _FW_LINKED))
-               rtw_lps_ctrl_wk_cmd23a(Adapter, LPS_CTRL_LEAVE, enqueue);
-}
-
-void rtw_init_pwrctrl_priv23a(struct rtw_adapter *padapter)
-{
-       struct pwrctrl_priv *pwrctrlpriv = &padapter->pwrctrlpriv;
-
-       mutex_init(&pwrctrlpriv->mutex_lock);
-       pwrctrlpriv->rf_pwrstate = rf_on;
-       pwrctrlpriv->ips_enter23a_cnts = 0;
-       pwrctrlpriv->ips_leave23a_cnts = 0;
-       pwrctrlpriv->bips_processing = false;
-
-       pwrctrlpriv->ips_mode = padapter->registrypriv.ips_mode;
-       pwrctrlpriv->ips_mode_req = padapter->registrypriv.ips_mode;
-
-       pwrctrlpriv->pwr_state_check_interval = RTW_PWR_STATE_CHK_INTERVAL;
-       pwrctrlpriv->pwr_state_check_cnts = 0;
-       pwrctrlpriv->bInSuspend = false;
-       pwrctrlpriv->bkeepfwalive = false;
-
-       pwrctrlpriv->LpsIdleCount = 0;
-
-       /*  PS_MODE_MIN; */
-       pwrctrlpriv->power_mgnt = padapter->registrypriv.power_mgnt;
-       pwrctrlpriv->bLeisurePs =
-               (PS_MODE_ACTIVE != pwrctrlpriv->power_mgnt)?true:false;
-
-       pwrctrlpriv->bFwCurrentInPSMode = false;
-
-       pwrctrlpriv->rpwm = 0;
-       pwrctrlpriv->cpwm = PS_STATE_S4;
-
-       pwrctrlpriv->pwr_mode = PS_MODE_ACTIVE;
-       pwrctrlpriv->smart_ps = padapter->registrypriv.smart_ps;
-       pwrctrlpriv->bcn_ant_mode = 0;
-
-       pwrctrlpriv->tog = 0x80;
-
-       pwrctrlpriv->btcoex_rfon = false;
-
-       setup_timer(&pwrctrlpriv->pwr_state_check_timer,
-                   pwr_state_check_handler, (unsigned long)padapter);
-}
-
-void rtw_free_pwrctrl_priv(struct rtw_adapter *adapter)
-{
-}
-
-inline void rtw_set_ips_deny23a(struct rtw_adapter *padapter, u32 ms)
-{
-       struct pwrctrl_priv *pwrpriv = &padapter->pwrctrlpriv;
-
-       pwrpriv->ips_deny_time = jiffies + msecs_to_jiffies(ms);
-}
-
-/*
-* rtw_pwr_wakeup - Wake the NIC up from: 1)IPS. 2)USB autosuspend
-* @adapter: pointer to _adapter structure
-* @ips_deffer_ms: the ms will prevent from falling into IPS after wakeup
-* Return _SUCCESS or _FAIL
-*/
-
-int _rtw_pwr_wakeup23a(struct rtw_adapter *padapter, u32 ips_deffer_ms, const char *caller)
-{
-       struct pwrctrl_priv *pwrpriv = &padapter->pwrctrlpriv;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       int ret = _SUCCESS;
-       unsigned long start = jiffies;
-       unsigned long new_deny_time;
-
-       new_deny_time = jiffies + msecs_to_jiffies(ips_deffer_ms);
-
-       if (time_before(pwrpriv->ips_deny_time, new_deny_time))
-               pwrpriv->ips_deny_time = new_deny_time;
-
-       if (pwrpriv->ps_processing) {
-               DBG_8723A("%s wait ps_processing...\n", __func__);
-               while (pwrpriv->ps_processing &&
-                      jiffies_to_msecs(jiffies - start) <= 3000)
-                       msleep(10);
-               if (pwrpriv->ps_processing)
-                       DBG_8723A("%s wait ps_processing timeout\n", __func__);
-               else
-                       DBG_8723A("%s wait ps_processing done\n", __func__);
-       }
-
-       if (rtw_sreset_inprogress(padapter)) {
-               DBG_8723A("%s wait sreset_inprogress...\n", __func__);
-               while (rtw_sreset_inprogress(padapter) &&
-                      jiffies_to_msecs(jiffies - start) <= 4000)
-                       msleep(10);
-               if (rtw_sreset_inprogress(padapter))
-                       DBG_8723A("%s wait sreset_inprogress timeout\n",
-                                 __func__);
-               else
-                       DBG_8723A("%s wait sreset_inprogress done\n", __func__);
-       }
-
-       if (pwrpriv->bInSuspend) {
-               DBG_8723A("%s wait bInSuspend...\n", __func__);
-               while (pwrpriv->bInSuspend &&
-                      (jiffies_to_msecs(jiffies - start) <= 3000)) {
-                       msleep(10);
-               }
-               if (pwrpriv->bInSuspend)
-                       DBG_8723A("%s wait bInSuspend timeout\n", __func__);
-               else
-                       DBG_8723A("%s wait bInSuspend done\n", __func__);
-       }
-
-       /* System suspend is not allowed to wakeup */
-       if (pwrpriv->bInSuspend) {
-               ret = _FAIL;
-               goto exit;
-       }
-
-       /* I think this should be check in IPS, LPS, autosuspend functions... */
-       if (check_fwstate(pmlmepriv, _FW_LINKED)) {
-               ret = _SUCCESS;
-               goto exit;
-       }
-
-       if (rf_off == pwrpriv->rf_pwrstate) {
-               DBG_8723A("%s call ips_leave23a....\n", __func__);
-               if (ips_leave23a(padapter)== _FAIL) {
-                       DBG_8723A("======> ips_leave23a fail.............\n");
-                       ret = _FAIL;
-                       goto exit;
-               }
-       }
-
-       /* TODO: the following checking need to be merged... */
-       if (padapter->bDriverStopped || !padapter->bup ||
-           !padapter->hw_init_completed) {
-               DBG_8723A("%s: bDriverStopped =%d, bup =%d, hw_init_completed "
-                         "=%u\n", caller, padapter->bDriverStopped,
-                         padapter->bup, padapter->hw_init_completed);
-               ret = _FAIL;
-               goto exit;
-       }
-
-exit:
-       new_deny_time = jiffies + msecs_to_jiffies(ips_deffer_ms);
-       if (time_before(pwrpriv->ips_deny_time, new_deny_time))
-               pwrpriv->ips_deny_time = new_deny_time;
-       return ret;
-}
-
-int rtw_pm_set_lps23a(struct rtw_adapter *padapter, u8 mode)
-{
-       int ret = 0;
-       struct pwrctrl_priv *pwrctrlpriv = &padapter->pwrctrlpriv;
-
-       if (mode < PS_MODE_NUM) {
-               if (pwrctrlpriv->power_mgnt != mode) {
-                       if (PS_MODE_ACTIVE == mode)
-                               LeaveAllPowerSaveMode23a(padapter);
-                       else
-                               pwrctrlpriv->LpsIdleCount = 2;
-                       pwrctrlpriv->power_mgnt = mode;
-                       pwrctrlpriv->bLeisurePs =
-                               (PS_MODE_ACTIVE != pwrctrlpriv->power_mgnt) ?
-                               true:false;
-               }
-       } else
-               ret = -EINVAL;
-
-       return ret;
-}
-
-int rtw_pm_set_ips23a(struct rtw_adapter *padapter, u8 mode)
-{
-       struct pwrctrl_priv *pwrctrlpriv = &padapter->pwrctrlpriv;
-
-       if (mode != IPS_NORMAL && mode != IPS_LEVEL_2 && mode != IPS_NONE)
-               return -EINVAL;
-
-       pwrctrlpriv->ips_mode_req = mode;
-       if (mode == IPS_NONE) {
-               DBG_8723A("%s %s\n", __func__, "IPS_NONE");
-               if (padapter->bSurpriseRemoved == 0 &&
-                   rtw_pwr_wakeup(padapter) == _FAIL)
-                       return -EFAULT;
-       }
-
-       return 0;
-}
diff --git a/drivers/staging/rtl8723au/core/rtw_recv.c b/drivers/staging/rtl8723au/core/rtw_recv.c
deleted file mode 100644 (file)
index 150dabc..0000000
+++ /dev/null
@@ -1,2204 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#define _RTW_RECV_C_
-#include <osdep_service.h>
-#include <drv_types.h>
-#include <recv_osdep.h>
-#include <mlme_osdep.h>
-#include <linux/ip.h>
-#include <linux/if_ether.h>
-#include <usb_ops.h>
-#include <linux/ieee80211.h>
-#include <wifi.h>
-#include <rtl8723a_recv.h>
-#include <rtl8723a_xmit.h>
-
-void rtw_signal_stat_timer_hdl23a(unsigned long data);
-
-void _rtw_init_sta_recv_priv23a(struct sta_recv_priv *psta_recvpriv)
-{
-
-
-
-       spin_lock_init(&psta_recvpriv->lock);
-
-       /* for (i = 0; i<MAX_RX_NUMBLKS; i++) */
-       /*      _rtw_init_queue23a(&psta_recvpriv->blk_strms[i]); */
-
-       _rtw_init_queue23a(&psta_recvpriv->defrag_q);
-
-
-}
-
-int _rtw_init_recv_priv23a(struct recv_priv *precvpriv,
-                       struct rtw_adapter *padapter)
-{
-       struct recv_frame *precvframe;
-       int i;
-       int res = _SUCCESS;
-
-       spin_lock_init(&precvpriv->lock);
-
-       _rtw_init_queue23a(&precvpriv->free_recv_queue);
-       _rtw_init_queue23a(&precvpriv->recv_pending_queue);
-       _rtw_init_queue23a(&precvpriv->uc_swdec_pending_queue);
-
-       precvpriv->adapter = padapter;
-
-       for (i = 0; i < NR_RECVFRAME ; i++) {
-               precvframe = kzalloc(sizeof(struct recv_frame), GFP_KERNEL);
-               if (!precvframe)
-                       break;
-               INIT_LIST_HEAD(&precvframe->list);
-
-               list_add_tail(&precvframe->list,
-                             &precvpriv->free_recv_queue.queue);
-
-               precvframe->adapter = padapter;
-               precvframe++;
-       }
-
-       precvpriv->free_recvframe_cnt = i;
-       precvpriv->rx_pending_cnt = 1;
-
-       res = rtl8723au_init_recv_priv(padapter);
-
-       setup_timer(&precvpriv->signal_stat_timer, rtw_signal_stat_timer_hdl23a,
-                   (unsigned long)padapter);
-
-       precvpriv->signal_stat_sampling_interval = 1000; /* ms */
-
-       rtw_set_signal_stat_timer(precvpriv);
-
-       return res;
-}
-
-void _rtw_free_recv_priv23a(struct recv_priv *precvpriv)
-{
-       struct rtw_adapter *padapter = precvpriv->adapter;
-       struct recv_frame *precvframe, *ptmp;
-
-       rtw_free_uc_swdec_pending_queue23a(padapter);
-
-       list_for_each_entry_safe(precvframe, ptmp,
-                                &precvpriv->free_recv_queue.queue, list) {
-               list_del_init(&precvframe->list);
-               kfree(precvframe);
-       }
-
-       rtl8723au_free_recv_priv(padapter);
-}
-
-struct recv_frame *rtw_alloc_recvframe23a(struct rtw_queue *pfree_recv_queue)
-{
-       struct recv_frame *pframe;
-       struct rtw_adapter *padapter;
-       struct recv_priv *precvpriv;
-
-       spin_lock_bh(&pfree_recv_queue->lock);
-
-       pframe = list_first_entry_or_null(&pfree_recv_queue->queue,
-                                         struct recv_frame, list);
-       if (pframe) {
-               list_del_init(&pframe->list);
-               padapter = pframe->adapter;
-               if (padapter) {
-                       precvpriv = &padapter->recvpriv;
-                       if (pfree_recv_queue == &precvpriv->free_recv_queue)
-                               precvpriv->free_recvframe_cnt--;
-               }
-       }
-
-       spin_unlock_bh(&pfree_recv_queue->lock);
-
-       return pframe;
-}
-
-int rtw_free_recvframe23a(struct recv_frame *precvframe)
-{
-       struct rtw_adapter *padapter = precvframe->adapter;
-       struct recv_priv *precvpriv = &padapter->recvpriv;
-       struct rtw_queue *pfree_recv_queue;
-
-       if (precvframe->pkt) {
-               dev_kfree_skb_any(precvframe->pkt);/* free skb by driver */
-               precvframe->pkt = NULL;
-       }
-
-       pfree_recv_queue = &precvpriv->free_recv_queue;
-       spin_lock_bh(&pfree_recv_queue->lock);
-
-       list_del_init(&precvframe->list);
-
-       list_add_tail(&precvframe->list, get_list_head(pfree_recv_queue));
-
-       if (padapter) {
-               if (pfree_recv_queue == &precvpriv->free_recv_queue)
-                       precvpriv->free_recvframe_cnt++;
-       }
-
-       spin_unlock_bh(&pfree_recv_queue->lock);
-
-
-
-       return _SUCCESS;
-}
-
-int rtw_enqueue_recvframe23a(struct recv_frame *precvframe, struct rtw_queue *queue)
-{
-       struct rtw_adapter *padapter = precvframe->adapter;
-       struct recv_priv *precvpriv = &padapter->recvpriv;
-
-       spin_lock_bh(&queue->lock);
-
-       list_del_init(&precvframe->list);
-
-       list_add_tail(&precvframe->list, get_list_head(queue));
-
-       if (padapter) {
-               if (queue == &precvpriv->free_recv_queue)
-                       precvpriv->free_recvframe_cnt++;
-       }
-
-       spin_unlock_bh(&queue->lock);
-
-       return _SUCCESS;
-}
-
-/*
-caller : defrag ; recvframe_chk_defrag23a in recv_thread  (passive)
-pframequeue: defrag_queue : will be accessed in recv_thread  (passive)
-
-using spinlock to protect
-
-*/
-
-static void rtw_free_recvframe23a_queue(struct rtw_queue *pframequeue)
-{
-       struct recv_frame *hdr, *ptmp;
-       struct list_head *phead;
-
-       spin_lock(&pframequeue->lock);
-       phead = get_list_head(pframequeue);
-       list_for_each_entry_safe(hdr, ptmp, phead, list)
-               rtw_free_recvframe23a(hdr);
-       spin_unlock(&pframequeue->lock);
-}
-
-u32 rtw_free_uc_swdec_pending_queue23a(struct rtw_adapter *adapter)
-{
-       u32 cnt = 0;
-       struct recv_frame *pending_frame;
-
-       while ((pending_frame = rtw_alloc_recvframe23a(&adapter->recvpriv.uc_swdec_pending_queue))) {
-               rtw_free_recvframe23a(pending_frame);
-               DBG_8723A("%s: dequeue uc_swdec_pending_queue\n", __func__);
-               cnt++;
-       }
-
-       return cnt;
-}
-
-struct recv_buf *rtw_dequeue_recvbuf23a (struct rtw_queue *queue)
-{
-       unsigned long irqL;
-       struct recv_buf *precvbuf;
-
-       spin_lock_irqsave(&queue->lock, irqL);
-
-       precvbuf = list_first_entry_or_null(&queue->queue,
-                                           struct recv_buf, list);
-       if (precvbuf)
-               list_del_init(&precvbuf->list);
-
-       spin_unlock_irqrestore(&queue->lock, irqL);
-
-       return precvbuf;
-}
-
-int recvframe_chkmic(struct rtw_adapter *adapter,
-                    struct recv_frame *precvframe);
-int recvframe_chkmic(struct rtw_adapter *adapter,
-                    struct recv_frame *precvframe) {
-
-       int     i, res = _SUCCESS;
-       u32     datalen;
-       u8      miccode[8];
-       u8      bmic_err = false, brpt_micerror = true;
-       u8      *pframe, *payload, *pframemic;
-       u8      *mickey;
-       struct  sta_info *stainfo;
-       struct  rx_pkt_attrib *prxattrib = &precvframe->attrib;
-       struct  security_priv *psecuritypriv = &adapter->securitypriv;
-
-       struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-
-
-       stainfo = rtw_get_stainfo23a(&adapter->stapriv, &prxattrib->ta[0]);
-
-       if (prxattrib->encrypt == WLAN_CIPHER_SUITE_TKIP) {
-               RT_TRACE(_module_rtl871x_recv_c_, _drv_info_,
-                        "recvframe_chkmic:prxattrib->encrypt == WLAN_CIPHER_SUITE_TKIP\n");
-               RT_TRACE(_module_rtl871x_recv_c_, _drv_info_,
-                        "recvframe_chkmic:da = %pM\n", prxattrib->ra);
-
-               /* calculate mic code */
-               if (stainfo != NULL) {
-                       if (is_multicast_ether_addr(prxattrib->ra)) {
-                               mickey = &psecuritypriv->dot118021XGrprxmickey[prxattrib->key_index].skey[0];
-
-                               RT_TRACE(_module_rtl871x_recv_c_, _drv_info_,
-                                        "recvframe_chkmic: bcmc key\n");
-
-                               if (!psecuritypriv->binstallGrpkey) {
-                                       res = _FAIL;
-                                       RT_TRACE(_module_rtl871x_recv_c_,
-                                                _drv_err_,
-                                                "recvframe_chkmic:didn't install group key!\n");
-                                       DBG_8723A("\n recvframe_chkmic:didn't "
-                                                 "install group key!!!!!!\n");
-                                       goto exit;
-                               }
-                       } else {
-                               mickey = &stainfo->dot11tkiprxmickey.skey[0];
-                               RT_TRACE(_module_rtl871x_recv_c_, _drv_err_,
-                                        "recvframe_chkmic: unicast key\n");
-                       }
-
-                       /* icv_len included the mic code */
-                       datalen = precvframe->pkt->len-prxattrib->
-                               hdrlen-prxattrib->iv_len-prxattrib->icv_len - 8;
-                       pframe = precvframe->pkt->data;
-                       payload = pframe + prxattrib->hdrlen +
-                               prxattrib->iv_len;
-
-                       RT_TRACE(_module_rtl871x_recv_c_, _drv_info_,
-                                "prxattrib->iv_len =%d prxattrib->icv_len =%d\n",
-                                prxattrib->iv_len, prxattrib->icv_len);
-
-                       /* care the length of the data */
-                       rtw_seccalctkipmic23a(mickey, pframe, payload,
-                                          datalen, &miccode[0],
-                                          (unsigned char)prxattrib->priority);
-
-                       pframemic = payload + datalen;
-
-                       bmic_err = false;
-
-                       for (i = 0; i < 8; i++) {
-                               if (miccode[i] != *(pframemic + i)) {
-                                       RT_TRACE(_module_rtl871x_recv_c_,
-                                                _drv_err_,
-                                                "recvframe_chkmic:miccode[%d](%02x) != *(pframemic+%d)(%02x)\n",
-                                                i, miccode[i],
-                                                i, *(pframemic + i));
-                                       bmic_err = true;
-                               }
-                       }
-
-                       if (bmic_err == true) {
-                               int i;
-
-                               RT_TRACE(_module_rtl871x_recv_c_, _drv_err_,
-                                        "*(pframemic-8)-*(pframemic-1) =%*phC\n",
-                                        8, pframemic - 8);
-                               RT_TRACE(_module_rtl871x_recv_c_, _drv_err_,
-                                        "*(pframemic-16)-*(pframemic-9) =%*phC\n",
-                                        8, pframemic - 16);
-
-                               RT_TRACE(_module_rtl871x_recv_c_, _drv_err_,
-                                        "====== demp packet (len =%d) ======\n",
-                                        precvframe->pkt->len);
-                               for (i = 0; i < precvframe->pkt->len; i = i + 8) {
-                                       RT_TRACE(_module_rtl871x_recv_c_,
-                                                _drv_err_, "%*phC\n",
-                                                8, precvframe->pkt->data + i);
-                               }
-                               RT_TRACE(_module_rtl871x_recv_c_, _drv_err_,
-                                        "====== demp packet end [len =%d]======\n",
-                                        precvframe->pkt->len);
-                               RT_TRACE(_module_rtl871x_recv_c_, _drv_err_,
-                                        "hrdlen =%d\n", prxattrib->hdrlen);
-
-                               RT_TRACE(_module_rtl871x_recv_c_, _drv_err_,
-                                        "ra = %pM psecuritypriv->binstallGrpkey =%d\n",
-                                        prxattrib->ra,
-                                        psecuritypriv->binstallGrpkey);
-
-                               /*  double check key_index for some timing
-                                   issue, cannot compare with
-                                   psecuritypriv->dot118021XGrpKeyid also
-                                   cause timing issue */
-                               if ((is_multicast_ether_addr(prxattrib->ra)) &&
-                                   (prxattrib->key_index !=
-                                    pmlmeinfo->key_index))
-                                       brpt_micerror = false;
-
-                               if ((prxattrib->bdecrypted == true) &&
-                                   (brpt_micerror == true)) {
-                                       rtw_handle_tkip_mic_err23a(adapter, (u8)is_multicast_ether_addr(prxattrib->ra));
-                                       RT_TRACE(_module_rtl871x_recv_c_, _drv_err_,
-                                                "mic error :prxattrib->bdecrypted =%d\n",
-                                                prxattrib->bdecrypted);
-                                       DBG_8723A(" mic error :prxattrib->"
-                                                 "bdecrypted =%d\n",
-                                                 prxattrib->bdecrypted);
-                               } else {
-                                       RT_TRACE(_module_rtl871x_recv_c_,
-                                                _drv_err_,
-                                                "mic error :prxattrib->bdecrypted =%d\n",
-                                                prxattrib->bdecrypted);
-                                       DBG_8723A(" mic error :prxattrib->"
-                                                 "bdecrypted =%d\n",
-                                                 prxattrib->bdecrypted);
-                               }
-
-                               res = _FAIL;
-                       } else {
-                               /* mic checked ok */
-                               if (!psecuritypriv->bcheck_grpkey &&
-                                   is_multicast_ether_addr(prxattrib->ra)) {
-                                       psecuritypriv->bcheck_grpkey = 1;
-                                       RT_TRACE(_module_rtl871x_recv_c_,
-                                                _drv_err_,
-                                                "psecuritypriv->bcheck_grpkey = true\n");
-                               }
-                       }
-               } else {
-                       RT_TRACE(_module_rtl871x_recv_c_, _drv_err_,
-                                "recvframe_chkmic: rtw_get_stainfo23a ==NULL!!!\n");
-               }
-
-               skb_trim(precvframe->pkt, precvframe->pkt->len - 8);
-       }
-
-exit:
-
-
-
-       return res;
-}
-
-/* decrypt and set the ivlen, icvlen of the recv_frame */
-struct recv_frame *decryptor(struct rtw_adapter *padapter,
-                            struct recv_frame *precv_frame);
-struct recv_frame *decryptor(struct rtw_adapter *padapter,
-                            struct recv_frame *precv_frame)
-{
-       struct rx_pkt_attrib *prxattrib = &precv_frame->attrib;
-       struct security_priv *psecuritypriv = &padapter->securitypriv;
-       struct recv_frame *return_packet = precv_frame;
-       int res = _SUCCESS;
-
-       RT_TRACE(_module_rtl871x_recv_c_, _drv_info_,
-                "prxstat->decrypted =%x prxattrib->encrypt = 0x%03x\n",
-                prxattrib->bdecrypted, prxattrib->encrypt);
-
-       if (prxattrib->encrypt > 0) {
-               u8 *iv = precv_frame->pkt->data + prxattrib->hdrlen;
-
-               prxattrib->key_index = (((iv[3]) >> 6) & 0x3);
-
-               if (prxattrib->key_index > WEP_KEYS) {
-                       DBG_8723A("prxattrib->key_index(%d) > WEP_KEYS\n",
-                                 prxattrib->key_index);
-
-                       switch (prxattrib->encrypt) {
-                       case WLAN_CIPHER_SUITE_WEP40:
-                       case WLAN_CIPHER_SUITE_WEP104:
-                               prxattrib->key_index =
-                                       psecuritypriv->dot11PrivacyKeyIndex;
-                               break;
-                       case WLAN_CIPHER_SUITE_TKIP:
-                       case WLAN_CIPHER_SUITE_CCMP:
-                       default:
-                               prxattrib->key_index =
-                                       psecuritypriv->dot118021XGrpKeyid;
-                               break;
-                       }
-               }
-       }
-
-       if ((prxattrib->encrypt > 0) && ((prxattrib->bdecrypted == 0))) {
-               psecuritypriv->hw_decrypted = 0;
-               switch (prxattrib->encrypt) {
-               case WLAN_CIPHER_SUITE_WEP40:
-               case WLAN_CIPHER_SUITE_WEP104:
-                       rtw_wep_decrypt23a(padapter, precv_frame);
-                       break;
-               case WLAN_CIPHER_SUITE_TKIP:
-                       res = rtw_tkip_decrypt23a(padapter, precv_frame);
-                       break;
-               case WLAN_CIPHER_SUITE_CCMP:
-                       res = rtw_aes_decrypt23a(padapter, precv_frame);
-                       break;
-               default:
-                       break;
-               }
-       } else if (prxattrib->bdecrypted == 1 && prxattrib->encrypt > 0 &&
-                  (psecuritypriv->busetkipkey == 1 ||
-                   prxattrib->encrypt != WLAN_CIPHER_SUITE_TKIP)) {
-                       psecuritypriv->hw_decrypted = 1;
-       }
-
-       if (res == _FAIL) {
-               rtw_free_recvframe23a(return_packet);
-               return_packet = NULL;
-       }
-
-
-
-       return return_packet;
-}
-
-/* set the security information in the recv_frame */
-static struct recv_frame *portctrl(struct rtw_adapter *adapter,
-                                  struct recv_frame *precv_frame)
-{
-       u8 *psta_addr, *ptr;
-       uint auth_alg;
-       struct recv_frame *pfhdr;
-       struct sta_info *psta;
-       struct sta_priv *pstapriv ;
-       struct recv_frame *prtnframe;
-       u16 ether_type;
-       u16 eapol_type = ETH_P_PAE;/* for Funia BD's WPA issue */
-       struct rx_pkt_attrib *pattrib;
-
-       pstapriv = &adapter->stapriv;
-
-       auth_alg = adapter->securitypriv.dot11AuthAlgrthm;
-
-       pfhdr = precv_frame;
-       pattrib = &pfhdr->attrib;
-       psta_addr = pattrib->ta;
-       psta = rtw_get_stainfo23a(pstapriv, psta_addr);
-
-       RT_TRACE(_module_rtl871x_recv_c_, _drv_info_,
-                "########portctrl:adapter->securitypriv.dot11AuthAlgrthm =%d\n",
-                adapter->securitypriv.dot11AuthAlgrthm);
-
-       prtnframe = precv_frame;
-
-       if (auth_alg == dot11AuthAlgrthm_8021X) {
-               /* get ether_type */
-               ptr = pfhdr->pkt->data + pfhdr->attrib.hdrlen;
-
-               ether_type = (ptr[6] << 8) | ptr[7];
-
-               if (psta && psta->ieee8021x_blocked) {
-                       /* blocked */
-                       /* only accept EAPOL frame */
-                       RT_TRACE(_module_rtl871x_recv_c_, _drv_info_,
-                                "########portctrl:psta->ieee8021x_blocked ==1\n");
-
-                       if (ether_type != eapol_type) {
-                               /* free this frame */
-                               rtw_free_recvframe23a(precv_frame);
-                               prtnframe = NULL;
-                       }
-               }
-       }
-
-       return prtnframe;
-}
-
-int recv_decache(struct recv_frame *precv_frame, u8 bretry,
-                struct stainfo_rxcache *prxcache);
-int recv_decache(struct recv_frame *precv_frame, u8 bretry,
-                struct stainfo_rxcache *prxcache)
-{
-       int tid = precv_frame->attrib.priority;
-
-       u16 seq_ctrl = ((precv_frame->attrib.seq_num & 0xffff) << 4) |
-               (precv_frame->attrib.frag_num & 0xf);
-
-
-
-       if (tid > 15) {
-               RT_TRACE(_module_rtl871x_recv_c_, _drv_notice_,
-                        "recv_decache, (tid>15)! seq_ctrl = 0x%x, tid = 0x%x\n",
-                        seq_ctrl, tid);
-
-               return _FAIL;
-       }
-
-       if (1) { /* if (bretry) */
-               if (seq_ctrl == prxcache->tid_rxseq[tid]) {
-                       RT_TRACE(_module_rtl871x_recv_c_, _drv_notice_,
-                                "recv_decache, seq_ctrl = 0x%x, tid = 0x%x, tid_rxseq = 0x%x\n",
-                                seq_ctrl, tid, prxcache->tid_rxseq[tid]);
-
-                       return _FAIL;
-               }
-       }
-
-       prxcache->tid_rxseq[tid] = seq_ctrl;
-
-
-
-       return _SUCCESS;
-}
-
-void process23a_pwrbit_data(struct rtw_adapter *padapter,
-                        struct recv_frame *precv_frame);
-void process23a_pwrbit_data(struct rtw_adapter *padapter,
-                        struct recv_frame *precv_frame)
-{
-#ifdef CONFIG_8723AU_AP_MODE
-       unsigned char pwrbit;
-       struct sk_buff *skb = precv_frame->pkt;
-       struct ieee80211_hdr *hdr = (struct ieee80211_hdr *) skb->data;
-       struct rx_pkt_attrib *pattrib = &precv_frame->attrib;
-       struct sta_priv *pstapriv = &padapter->stapriv;
-       struct sta_info *psta;
-
-       psta = rtw_get_stainfo23a(pstapriv, pattrib->src);
-
-       if (psta) {
-               pwrbit = ieee80211_has_pm(hdr->frame_control);
-
-               if (pwrbit) {
-                       if (!(psta->state & WIFI_SLEEP_STATE))
-                               stop_sta_xmit23a(padapter, psta);
-               } else {
-                       if (psta->state & WIFI_SLEEP_STATE)
-                               wakeup_sta_to_xmit23a(padapter, psta);
-               }
-       }
-
-#endif
-}
-
-void process_wmmps_data(struct rtw_adapter *padapter,
-                       struct recv_frame *precv_frame);
-void process_wmmps_data(struct rtw_adapter *padapter,
-                       struct recv_frame *precv_frame)
-{
-#ifdef CONFIG_8723AU_AP_MODE
-       struct rx_pkt_attrib *pattrib = &precv_frame->attrib;
-       struct sta_priv *pstapriv = &padapter->stapriv;
-       struct sta_info *psta;
-
-       psta = rtw_get_stainfo23a(pstapriv, pattrib->src);
-
-       if (!psta)
-               return;
-
-
-       if (!psta->qos_option)
-               return;
-
-       if (!(psta->qos_info & 0xf))
-               return;
-
-       if (psta->state & WIFI_SLEEP_STATE) {
-               u8 wmmps_ac = 0;
-
-               switch (pattrib->priority) {
-               case 1:
-               case 2:
-                       wmmps_ac = psta->uapsd_bk & BIT(1);
-                       break;
-               case 4:
-               case 5:
-                       wmmps_ac = psta->uapsd_vi & BIT(1);
-                       break;
-               case 6:
-               case 7:
-                       wmmps_ac = psta->uapsd_vo & BIT(1);
-                       break;
-               case 0:
-               case 3:
-               default:
-                       wmmps_ac = psta->uapsd_be & BIT(1);
-                       break;
-               }
-
-               if (wmmps_ac) {
-                       if (psta->sleepq_ac_len > 0) {
-                               /* process received triggered frame */
-                               xmit_delivery_enabled_frames23a(padapter, psta);
-                       } else {
-                               /* issue one qos null frame with More data bit = 0 and the EOSP bit set (= 1) */
-                               issue_qos_nulldata23a(padapter, psta->hwaddr,
-                                                  (u16)pattrib->priority,
-                                                  0, 0);
-                       }
-               }
-       }
-
-#endif
-}
-
-static void count_rx_stats(struct rtw_adapter *padapter,
-                          struct recv_frame *prframe, struct sta_info *sta)
-{
-       int sz;
-       struct sta_info *psta = NULL;
-       struct stainfo_stats *pstats = NULL;
-       struct rx_pkt_attrib *pattrib = & prframe->attrib;
-       struct recv_priv *precvpriv = &padapter->recvpriv;
-
-       sz = prframe->pkt->len;
-       precvpriv->rx_bytes += sz;
-
-       padapter->mlmepriv.LinkDetectInfo.NumRxOkInPeriod++;
-
-       if ((!is_broadcast_ether_addr(pattrib->dst)) &&
-           (!is_multicast_ether_addr(pattrib->dst)))
-               padapter->mlmepriv.LinkDetectInfo.NumRxUnicastOkInPeriod++;
-
-       if (sta)
-               psta = sta;
-       else
-               psta = prframe->psta;
-
-       if (psta) {
-               pstats = &psta->sta_stats;
-
-               pstats->rx_data_pkts++;
-               pstats->rx_bytes += sz;
-       }
-}
-
-static int sta2sta_data_frame(struct rtw_adapter *adapter,
-                             struct recv_frame *precv_frame,
-                             struct sta_info**psta)
-{
-       struct sk_buff *skb = precv_frame->pkt;
-       struct ieee80211_hdr *hdr = (struct ieee80211_hdr *) skb->data;
-       int ret = _SUCCESS;
-       struct rx_pkt_attrib *pattrib = & precv_frame->attrib;
-       struct sta_priv *pstapriv = &adapter->stapriv;
-       struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
-       u8 *mybssid  = get_bssid(pmlmepriv);
-       u8 *myhwaddr = myid(&adapter->eeprompriv);
-       u8 *sta_addr = NULL;
-       int bmcast = is_multicast_ether_addr(pattrib->dst);
-
-
-
-       if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) ||
-           check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE)) {
-
-               /*  filter packets that SA is myself or multicast or broadcast */
-               if (ether_addr_equal(myhwaddr, pattrib->src)) {
-                       RT_TRACE(_module_rtl871x_recv_c_, _drv_err_,
-                                "SA == myself\n");
-                       ret = _FAIL;
-                       goto exit;
-               }
-
-               if (!ether_addr_equal(myhwaddr, pattrib->dst) && !bmcast) {
-                       ret = _FAIL;
-                       goto exit;
-               }
-
-               if (ether_addr_equal(pattrib->bssid, "\x0\x0\x0\x0\x0\x0") ||
-                   ether_addr_equal(mybssid, "\x0\x0\x0\x0\x0\x0") ||
-                   !ether_addr_equal(pattrib->bssid, mybssid)) {
-                       ret = _FAIL;
-                       goto exit;
-               }
-
-               sta_addr = pattrib->src;
-       } else if (check_fwstate(pmlmepriv, WIFI_STATION_STATE)) {
-               /*  For Station mode, sa and bssid should always be BSSID,
-                   and DA is my mac-address */
-               if (!ether_addr_equal(pattrib->bssid, pattrib->src)) {
-                       RT_TRACE(_module_rtl871x_recv_c_, _drv_err_,
-                                "bssid != TA under STATION_MODE; drop pkt\n");
-                       ret = _FAIL;
-                       goto exit;
-               }
-
-               sta_addr = pattrib->bssid;
-
-       } else if (check_fwstate(pmlmepriv, WIFI_AP_STATE)) {
-               if (bmcast) {
-                       /*  For AP mode, if DA == MCAST, then BSSID should be also MCAST */
-                       if (!is_multicast_ether_addr(pattrib->bssid)) {
-                               ret = _FAIL;
-                               goto exit;
-                       }
-               } else { /*  not mc-frame */
-                       /*  For AP mode, if DA is non-MCAST, then it must
-                           be BSSID, and bssid == BSSID */
-                       if (!ether_addr_equal(pattrib->bssid, pattrib->dst)) {
-                               ret = _FAIL;
-                               goto exit;
-                       }
-
-                       sta_addr = pattrib->src;
-               }
-       } else if (check_fwstate(pmlmepriv, WIFI_MP_STATE)) {
-               ether_addr_copy(pattrib->dst, hdr->addr1);
-               ether_addr_copy(pattrib->src, hdr->addr2);
-               ether_addr_copy(pattrib->bssid, hdr->addr3);
-               ether_addr_copy(pattrib->ra, pattrib->dst);
-               ether_addr_copy(pattrib->ta, pattrib->src);
-
-               sta_addr = mybssid;
-       } else {
-               ret  = _FAIL;
-       }
-
-       if (bmcast)
-               *psta = rtw_get_bcmc_stainfo23a(adapter);
-       else
-               *psta = rtw_get_stainfo23a(pstapriv, sta_addr); /*  get ap_info */
-
-       if (*psta == NULL) {
-               RT_TRACE(_module_rtl871x_recv_c_, _drv_err_,
-                        "can't get psta under sta2sta_data_frame ; drop pkt\n");
-               ret = _FAIL;
-               goto exit;
-       }
-
-exit:
-
-       return ret;
-}
-
-int ap2sta_data_frame(struct rtw_adapter *adapter,
-                     struct recv_frame *precv_frame,
-                     struct sta_info **psta);
-int ap2sta_data_frame(struct rtw_adapter *adapter,
-                     struct recv_frame *precv_frame,
-                     struct sta_info **psta)
-{
-       struct sk_buff *skb = precv_frame->pkt;
-       struct ieee80211_hdr *hdr = (struct ieee80211_hdr *) skb->data;
-       struct rx_pkt_attrib *pattrib = & precv_frame->attrib;
-       int ret = _SUCCESS;
-       struct sta_priv *pstapriv = &adapter->stapriv;
-       struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
-       u8 *mybssid  = get_bssid(pmlmepriv);
-       u8 *myhwaddr = myid(&adapter->eeprompriv);
-       int bmcast = is_multicast_ether_addr(pattrib->dst);
-
-
-
-       if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) &&
-           (check_fwstate(pmlmepriv, _FW_LINKED) ||
-            check_fwstate(pmlmepriv, _FW_UNDER_LINKING))) {
-
-               /* filter packets that SA is myself or multicast or broadcast */
-               if (ether_addr_equal(myhwaddr, pattrib->src)) {
-                       RT_TRACE(_module_rtl871x_recv_c_, _drv_err_,
-                                "SA == myself\n");
-                       ret = _FAIL;
-                       goto exit;
-               }
-
-               /*  da should be for me */
-               if (!ether_addr_equal(myhwaddr, pattrib->dst) && !bmcast) {
-                       RT_TRACE(_module_rtl871x_recv_c_, _drv_info_,
-                                "ap2sta_data_frame:  compare DA failed; DA=%pM\n",
-                                pattrib->dst);
-                       ret = _FAIL;
-                       goto exit;
-               }
-
-               /*  check BSSID */
-               if (ether_addr_equal(pattrib->bssid, "\x0\x0\x0\x0\x0\x0") ||
-                   ether_addr_equal(mybssid, "\x0\x0\x0\x0\x0\x0") ||
-                   !ether_addr_equal(pattrib->bssid, mybssid)) {
-                       RT_TRACE(_module_rtl871x_recv_c_, _drv_info_,
-                                "ap2sta_data_frame:  compare BSSID failed; BSSID=%pM\n",
-                                pattrib->bssid);
-                       RT_TRACE(_module_rtl871x_recv_c_, _drv_info_,
-                                "mybssid=%pM\n", mybssid);
-
-                       if (!bmcast) {
-                               DBG_8723A("issue_deauth23a to the nonassociated ap=%pM for the reason(7)\n",
-                                         pattrib->bssid);
-                               issue_deauth23a(adapter, pattrib->bssid,
-                                            WLAN_REASON_CLASS3_FRAME_FROM_NONASSOC_STA);
-                       }
-
-                       ret = _FAIL;
-                       goto exit;
-               }
-
-               if (bmcast)
-                       *psta = rtw_get_bcmc_stainfo23a(adapter);
-               else
-                       /*  get ap_info */
-                       *psta = rtw_get_stainfo23a(pstapriv, pattrib->bssid);
-
-               if (*psta == NULL) {
-                       RT_TRACE(_module_rtl871x_recv_c_, _drv_err_,
-                                "ap2sta: can't get psta under STATION_MODE; drop pkt\n");
-                       ret = _FAIL;
-                       goto exit;
-               }
-
-               if (ieee80211_is_nullfunc(hdr->frame_control)) {
-                       /* No data, will not indicate to upper layer,
-                          temporily count it here */
-                       count_rx_stats(adapter, precv_frame, *psta);
-                       ret = RTW_RX_HANDLED;
-                       goto exit;
-               }
-
-       } else if (check_fwstate(pmlmepriv, WIFI_MP_STATE) &&
-                  check_fwstate(pmlmepriv, _FW_LINKED)) {
-               ether_addr_copy(pattrib->dst, hdr->addr1);
-               ether_addr_copy(pattrib->src, hdr->addr2);
-               ether_addr_copy(pattrib->bssid, hdr->addr3);
-               ether_addr_copy(pattrib->ra, pattrib->dst);
-               ether_addr_copy(pattrib->ta, pattrib->src);
-
-               /*  */
-               ether_addr_copy(pattrib->bssid,  mybssid);
-
-               /*  get sta_info */
-               *psta = rtw_get_stainfo23a(pstapriv, pattrib->bssid);
-               if (*psta == NULL) {
-                       RT_TRACE(_module_rtl871x_recv_c_, _drv_err_,
-                                "can't get psta under MP_MODE ; drop pkt\n");
-                       ret = _FAIL;
-                       goto exit;
-               }
-       } else if (check_fwstate(pmlmepriv, WIFI_AP_STATE)) {
-               /* Special case */
-               ret = RTW_RX_HANDLED;
-               goto exit;
-       } else {
-               if (ether_addr_equal(myhwaddr, pattrib->dst) && !bmcast) {
-                       *psta = rtw_get_stainfo23a(pstapriv, pattrib->bssid);
-                       if (*psta == NULL) {
-                               DBG_8723A("issue_deauth23a to the ap=%pM for the reason(7)\n",
-                                         pattrib->bssid);
-
-                               issue_deauth23a(adapter, pattrib->bssid,
-                                            WLAN_REASON_CLASS3_FRAME_FROM_NONASSOC_STA);
-                       }
-               }
-
-               ret = _FAIL;
-       }
-
-exit:
-
-
-
-       return ret;
-}
-
-int sta2ap_data_frame(struct rtw_adapter *adapter,
-                     struct recv_frame *precv_frame,
-                     struct sta_info **psta);
-int sta2ap_data_frame(struct rtw_adapter *adapter,
-                     struct recv_frame *precv_frame,
-                     struct sta_info **psta)
-{
-       struct sk_buff *skb = precv_frame->pkt;
-       struct ieee80211_hdr *hdr = (struct ieee80211_hdr *) skb->data;
-       struct rx_pkt_attrib *pattrib = & precv_frame->attrib;
-       struct sta_priv *pstapriv = &adapter->stapriv;
-       struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
-       unsigned char *mybssid = get_bssid(pmlmepriv);
-       int ret = _SUCCESS;
-
-
-
-       if (check_fwstate(pmlmepriv, WIFI_AP_STATE)) {
-               /* For AP mode, RA = BSSID, TX = STA(SRC_ADDR), A3 = DST_ADDR */
-               if (!ether_addr_equal(pattrib->bssid, mybssid)) {
-                       ret = _FAIL;
-                       goto exit;
-               }
-
-               *psta = rtw_get_stainfo23a(pstapriv, pattrib->src);
-               if (*psta == NULL) {
-                       RT_TRACE(_module_rtl871x_recv_c_, _drv_err_,
-                                "can't get psta under AP_MODE; drop pkt\n");
-                       DBG_8723A("issue_deauth23a to sta=%pM for the reason(7)\n",
-                                 pattrib->src);
-
-                       issue_deauth23a(adapter, pattrib->src,
-                                    WLAN_REASON_CLASS3_FRAME_FROM_NONASSOC_STA);
-
-                       ret = RTW_RX_HANDLED;
-                       goto exit;
-               }
-
-               process23a_pwrbit_data(adapter, precv_frame);
-
-               /* We only get here if it's a data frame, so no need to
-                * confirm data frame type first */
-               if (ieee80211_is_data_qos(hdr->frame_control))
-                       process_wmmps_data(adapter, precv_frame);
-
-               if (ieee80211_is_nullfunc(hdr->frame_control)) {
-                       /* No data, will not indicate to upper layer,
-                          temporily count it here */
-                       count_rx_stats(adapter, precv_frame, *psta);
-                       ret = RTW_RX_HANDLED;
-                       goto exit;
-               }
-       } else {
-               u8 *myhwaddr = myid(&adapter->eeprompriv);
-
-               if (!ether_addr_equal(pattrib->ra, myhwaddr)) {
-                       ret = RTW_RX_HANDLED;
-                       goto exit;
-               }
-               DBG_8723A("issue_deauth23a to sta=%pM for the reason(7)\n",
-                         pattrib->src);
-               issue_deauth23a(adapter, pattrib->src,
-                            WLAN_REASON_CLASS3_FRAME_FROM_NONASSOC_STA);
-               ret = RTW_RX_HANDLED;
-               goto exit;
-       }
-
-exit:
-
-
-
-       return ret;
-}
-
-static int validate_recv_ctrl_frame(struct rtw_adapter *padapter,
-                                   struct recv_frame *precv_frame)
-{
-#ifdef CONFIG_8723AU_AP_MODE
-       struct rx_pkt_attrib *pattrib = &precv_frame->attrib;
-       struct sta_priv *pstapriv = &padapter->stapriv;
-       struct sk_buff *skb = precv_frame->pkt;
-       struct ieee80211_hdr *hdr = (struct ieee80211_hdr *) skb->data;
-
-       if (!ieee80211_is_ctl(hdr->frame_control))
-               return _FAIL;
-
-       /* receive the frames that ra(a1) is my address */
-       if (!ether_addr_equal(hdr->addr1, myid(&padapter->eeprompriv)))
-               return _FAIL;
-
-       /* only handle ps-poll */
-       if (ieee80211_is_pspoll(hdr->frame_control)) {
-               struct ieee80211_pspoll *psp = (struct ieee80211_pspoll *)hdr;
-               u16 aid;
-               u8 wmmps_ac = 0;
-               struct sta_info *psta = NULL;
-
-               aid = le16_to_cpu(psp->aid) & 0x3fff;
-               psta = rtw_get_stainfo23a(pstapriv, hdr->addr2);
-
-               if (!psta || psta->aid != aid)
-                       return _FAIL;
-
-               /* for rx pkt statistics */
-               psta->sta_stats.rx_ctrl_pkts++;
-
-               switch (pattrib->priority) {
-               case 1:
-               case 2:
-                       wmmps_ac = psta->uapsd_bk & BIT(0);
-                       break;
-               case 4:
-               case 5:
-                       wmmps_ac = psta->uapsd_vi & BIT(0);
-                       break;
-               case 6:
-               case 7:
-                       wmmps_ac = psta->uapsd_vo & BIT(0);
-                       break;
-               case 0:
-               case 3:
-               default:
-                       wmmps_ac = psta->uapsd_be & BIT(0);
-                       break;
-               }
-
-               if (wmmps_ac)
-                       return _FAIL;
-
-               if (psta->state & WIFI_STA_ALIVE_CHK_STATE) {
-                       DBG_8723A("%s alive check-rx ps-poll\n", __func__);
-                       psta->expire_to = pstapriv->expire_to;
-                       psta->state ^= WIFI_STA_ALIVE_CHK_STATE;
-               }
-
-               if ((psta->state & WIFI_SLEEP_STATE) &&
-                   (pstapriv->sta_dz_bitmap & CHKBIT(psta->aid))) {
-                       struct list_head *xmitframe_phead;
-                       struct xmit_frame *pxmitframe;
-                       struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-
-                       spin_lock_bh(&pxmitpriv->lock);
-
-                       xmitframe_phead = get_list_head(&psta->sleep_q);
-                       pxmitframe = list_first_entry_or_null(xmitframe_phead,
-                                                             struct xmit_frame,
-                                                             list);
-                       if (pxmitframe) {
-                               list_del_init(&pxmitframe->list);
-
-                               psta->sleepq_len--;
-
-                               if (psta->sleepq_len>0)
-                                       pxmitframe->attrib.mdata = 1;
-                               else
-                                       pxmitframe->attrib.mdata = 0;
-
-                               pxmitframe->attrib.triggered = 1;
-
-                               rtl8723au_hal_xmitframe_enqueue(padapter,
-                                                               pxmitframe);
-
-                               if (psta->sleepq_len == 0) {
-                                       pstapriv->tim_bitmap &= ~CHKBIT(psta->aid);
-                                       update_beacon23a(padapter, WLAN_EID_TIM,
-                                                        NULL, false);
-                               }
-
-                               spin_unlock_bh(&pxmitpriv->lock);
-
-                       } else {
-                               spin_unlock_bh(&pxmitpriv->lock);
-
-                               if (pstapriv->tim_bitmap & CHKBIT(psta->aid)) {
-                                       if (psta->sleepq_len == 0) {
-                                               DBG_8723A("no buffered packets "
-                                                         "to xmit\n");
-
-                                               /* issue nulldata with More data bit = 0 to indicate we have no buffered packets */
-                                               issue_nulldata23a(padapter,
-                                                              psta->hwaddr,
-                                                              0, 0, 0);
-                                       } else {
-                                               DBG_8723A("error!psta->sleepq"
-                                                         "_len =%d\n",
-                                                         psta->sleepq_len);
-                                               psta->sleepq_len = 0;
-                                       }
-
-                                       pstapriv->tim_bitmap &= ~CHKBIT(psta->aid);
-
-                                       update_beacon23a(padapter, WLAN_EID_TIM,
-                                                        NULL, false);
-                               }
-                       }
-               }
-       }
-
-#endif
-       return _FAIL;
-}
-
-struct recv_frame *recvframe_chk_defrag23a(struct rtw_adapter *padapter,
-                                       struct recv_frame *precv_frame);
-static int validate_recv_mgnt_frame(struct rtw_adapter *padapter,
-                                   struct recv_frame *precv_frame)
-{
-       struct sta_info *psta;
-       struct sk_buff *skb;
-       struct ieee80211_hdr *hdr;
-
-       RT_TRACE(_module_rtl871x_recv_c_, _drv_info_,
-                "+validate_recv_mgnt_frame\n");
-
-       precv_frame = recvframe_chk_defrag23a(padapter, precv_frame);
-       if (precv_frame == NULL) {
-               RT_TRACE(_module_rtl871x_recv_c_, _drv_notice_,
-                        "%s: fragment packet\n", __func__);
-               return _SUCCESS;
-       }
-
-       skb = precv_frame->pkt;
-       hdr = (struct ieee80211_hdr *) skb->data;
-
-               /* for rx pkt statistics */
-       psta = rtw_get_stainfo23a(&padapter->stapriv, hdr->addr2);
-       if (psta) {
-               psta->sta_stats.rx_mgnt_pkts++;
-
-               if (ieee80211_is_beacon(hdr->frame_control))
-                       psta->sta_stats.rx_beacon_pkts++;
-               else if (ieee80211_is_probe_req(hdr->frame_control))
-                       psta->sta_stats.rx_probereq_pkts++;
-               else if (ieee80211_is_probe_resp(hdr->frame_control)) {
-                       if (ether_addr_equal(padapter->eeprompriv.mac_addr,
-                                   hdr->addr1))
-                               psta->sta_stats.rx_probersp_pkts++;
-                       else if (is_broadcast_ether_addr(hdr->addr1) ||
-                                is_multicast_ether_addr(hdr->addr1))
-                               psta->sta_stats.rx_probersp_bm_pkts++;
-                       else
-                               psta->sta_stats.rx_probersp_uo_pkts++;
-               }
-       }
-
-       mgt_dispatcher23a(padapter, precv_frame);
-
-       return _SUCCESS;
-}
-
-static int validate_recv_data_frame(struct rtw_adapter *adapter,
-                                   struct recv_frame *precv_frame)
-{
-       u8 bretry;
-       u8 *psa, *pda;
-       struct sta_info *psta = NULL;
-       struct rx_pkt_attrib *pattrib = & precv_frame->attrib;
-       struct security_priv *psecuritypriv = &adapter->securitypriv;
-       int ret = _SUCCESS;
-       struct sk_buff *skb = precv_frame->pkt;
-       struct ieee80211_hdr *hdr = (struct ieee80211_hdr *) skb->data;
-
-
-
-       bretry = ieee80211_has_retry(hdr->frame_control);
-       pda = ieee80211_get_DA(hdr);
-       psa = ieee80211_get_SA(hdr);
-
-       ether_addr_copy(pattrib->dst, pda);
-       ether_addr_copy(pattrib->src, psa);
-
-       switch (hdr->frame_control &
-               cpu_to_le16(IEEE80211_FCTL_TODS | IEEE80211_FCTL_FROMDS)) {
-       case cpu_to_le16(0):
-               ether_addr_copy(pattrib->bssid, hdr->addr3);
-               ether_addr_copy(pattrib->ra, pda);
-               ether_addr_copy(pattrib->ta, psa);
-               ret = sta2sta_data_frame(adapter, precv_frame, &psta);
-               break;
-
-       case cpu_to_le16(IEEE80211_FCTL_FROMDS):
-               ether_addr_copy(pattrib->bssid, hdr->addr2);
-               ether_addr_copy(pattrib->ra, pda);
-               ether_addr_copy(pattrib->ta, hdr->addr2);
-               ret = ap2sta_data_frame(adapter, precv_frame, &psta);
-               break;
-
-       case cpu_to_le16(IEEE80211_FCTL_TODS):
-               ether_addr_copy(pattrib->bssid, hdr->addr1);
-               ether_addr_copy(pattrib->ra, hdr->addr1);
-               ether_addr_copy(pattrib->ta, psa);
-               ret = sta2ap_data_frame(adapter, precv_frame, &psta);
-               break;
-
-       case cpu_to_le16(IEEE80211_FCTL_TODS | IEEE80211_FCTL_FROMDS):
-               /*
-                * There is no BSSID in this case, but the driver has been
-                * using addr1 so far, so keep it for now.
-                */
-               ether_addr_copy(pattrib->bssid, hdr->addr1);
-               ether_addr_copy(pattrib->ra, hdr->addr1);
-               ether_addr_copy(pattrib->ta, hdr->addr2);
-               ret = _FAIL;
-               RT_TRACE(_module_rtl871x_recv_c_, _drv_err_, "case 3\n");
-               break;
-       }
-
-       if ((ret == _FAIL) || (ret == RTW_RX_HANDLED))
-               goto exit;
-
-       if (!psta) {
-               RT_TRACE(_module_rtl871x_recv_c_, _drv_err_,
-                        "after to_fr_ds_chk; psta == NULL\n");
-               ret = _FAIL;
-               goto exit;
-       }
-
-       precv_frame->psta = psta;
-
-       pattrib->hdrlen = sizeof(struct ieee80211_hdr_3addr);
-       if (ieee80211_has_a4(hdr->frame_control))
-               pattrib->hdrlen += ETH_ALEN;
-
-       /* parsing QC field */
-       if (pattrib->qos == 1) {
-               __le16 *qptr = (__le16 *)ieee80211_get_qos_ctl(hdr);
-               u16 qos_ctrl = le16_to_cpu(*qptr);
-
-               pattrib->priority = qos_ctrl & IEEE80211_QOS_CTL_TID_MASK;
-               pattrib->ack_policy = (qos_ctrl >> 5) & 3;
-               pattrib->amsdu =
-                       (qos_ctrl & IEEE80211_QOS_CTL_A_MSDU_PRESENT) >> 7;
-               pattrib->hdrlen += IEEE80211_QOS_CTL_LEN;
-
-               if (pattrib->priority != 0 && pattrib->priority != 3) {
-                       adapter->recvpriv.bIsAnyNonBEPkts = true;
-               }
-       } else {
-               pattrib->priority = 0;
-               pattrib->ack_policy = 0;
-               pattrib->amsdu = 0;
-       }
-
-       if (pattrib->order) { /* HT-CTRL 11n */
-               pattrib->hdrlen += 4;
-       }
-
-       precv_frame->preorder_ctrl = &psta->recvreorder_ctrl[pattrib->priority];
-
-       /*  decache, drop duplicate recv packets */
-       if (recv_decache(precv_frame, bretry, &psta->sta_recvpriv.rxcache) ==
-           _FAIL) {
-               RT_TRACE(_module_rtl871x_recv_c_, _drv_err_,
-                        "decache : drop pkt\n");
-               ret = _FAIL;
-               goto exit;
-       }
-
-       if (pattrib->privacy) {
-               RT_TRACE(_module_rtl871x_recv_c_, _drv_info_,
-                        "validate_recv_data_frame:pattrib->privacy =%x\n",
-                        pattrib->privacy);
-               RT_TRACE(_module_rtl871x_recv_c_, _drv_info_,
-                        "^^^^^^^^^^^is_multicast_ether_addr(pattrib->ra(0x%02x)) =%d^^^^^^^^^^^^^^^6\n",
-                        pattrib->ra[0],
-                        is_multicast_ether_addr(pattrib->ra));
-
-               GET_ENCRY_ALGO(psecuritypriv, psta, pattrib->encrypt,
-                              is_multicast_ether_addr(pattrib->ra));
-
-               RT_TRACE(_module_rtl871x_recv_c_, _drv_info_,
-                        "pattrib->encrypt =%d\n", pattrib->encrypt);
-
-               switch (pattrib->encrypt) {
-               case WLAN_CIPHER_SUITE_WEP40:
-               case WLAN_CIPHER_SUITE_WEP104:
-                       pattrib->iv_len = IEEE80211_WEP_IV_LEN;
-                       pattrib->icv_len = IEEE80211_WEP_ICV_LEN;
-                       break;
-               case WLAN_CIPHER_SUITE_TKIP:
-                       pattrib->iv_len = IEEE80211_TKIP_IV_LEN;
-                       pattrib->icv_len = IEEE80211_TKIP_ICV_LEN;
-                       break;
-               case WLAN_CIPHER_SUITE_CCMP:
-                       pattrib->iv_len = IEEE80211_CCMP_HDR_LEN;
-                       pattrib->icv_len = IEEE80211_CCMP_MIC_LEN;
-                       break;
-               default:
-                       pattrib->iv_len = 0;
-                       pattrib->icv_len = 0;
-                       break;
-               }
-       } else {
-               pattrib->encrypt = 0;
-               pattrib->iv_len = 0;
-               pattrib->icv_len = 0;
-       }
-
-exit:
-
-
-
-       return ret;
-}
-
-static void dump_rx_pkt(struct sk_buff *skb, u16 type, int level)
-{
-       int i;
-       u8 *ptr;
-
-       if ((level == 1) ||
-           ((level == 2) && (type == IEEE80211_FTYPE_MGMT)) ||
-           ((level == 3) && (type == IEEE80211_FTYPE_DATA))) {
-
-               ptr = skb->data;
-
-               DBG_8723A("#############################\n");
-
-               for (i = 0; i < 64; i = i + 8)
-                       DBG_8723A("%*phC:\n", 8, ptr + i);
-               DBG_8723A("#############################\n");
-       }
-}
-
-static int validate_recv_frame(struct rtw_adapter *adapter,
-                              struct recv_frame *precv_frame)
-{
-       /* shall check frame subtype, to / from ds, da, bssid */
-
-       /* then call check if rx seq/frag. duplicated. */
-       u8 type;
-       u8 subtype;
-       int retval = _SUCCESS;
-       struct rx_pkt_attrib *pattrib = & precv_frame->attrib;
-       struct sk_buff *skb = precv_frame->pkt;
-       struct ieee80211_hdr *hdr = (struct ieee80211_hdr *) skb->data;
-       u8 ver;
-       u8 bDumpRxPkt;
-       u16 seq_ctrl, fctl;
-
-       fctl = le16_to_cpu(hdr->frame_control);
-       ver = fctl & IEEE80211_FCTL_VERS;
-       type = fctl & IEEE80211_FCTL_FTYPE;
-       subtype = fctl & IEEE80211_FCTL_STYPE;
-
-       /* add version chk */
-       if (ver != 0) {
-               RT_TRACE(_module_rtl871x_recv_c_, _drv_err_,
-                        "validate_recv_data_frame fail! (ver!= 0)\n");
-               retval = _FAIL;
-               goto exit;
-       }
-
-       seq_ctrl = le16_to_cpu(hdr->seq_ctrl);
-       pattrib->frag_num = seq_ctrl & IEEE80211_SCTL_FRAG;
-       pattrib->seq_num = seq_ctrl >> 4;
-
-       pattrib->pw_save = ieee80211_has_pm(hdr->frame_control);
-       pattrib->mfrag = ieee80211_has_morefrags(hdr->frame_control);
-       pattrib->mdata = ieee80211_has_moredata(hdr->frame_control);
-       pattrib->privacy = ieee80211_has_protected(hdr->frame_control);
-       pattrib->order = ieee80211_has_order(hdr->frame_control);
-
-       GetHalDefVar8192CUsb(adapter, HAL_DEF_DBG_DUMP_RXPKT, &bDumpRxPkt);
-
-       if (unlikely(bDumpRxPkt == 1))
-               dump_rx_pkt(skb, type, bDumpRxPkt);
-
-       switch (type) {
-       case IEEE80211_FTYPE_MGMT:
-               retval = validate_recv_mgnt_frame(adapter, precv_frame);
-               if (retval == _FAIL) {
-                       RT_TRACE(_module_rtl871x_recv_c_, _drv_err_,
-                                "validate_recv_mgnt_frame fail\n");
-               }
-               retval = _FAIL; /*  only data frame return _SUCCESS */
-               break;
-       case IEEE80211_FTYPE_CTL:
-               retval = validate_recv_ctrl_frame(adapter, precv_frame);
-               if (retval == _FAIL) {
-                       RT_TRACE(_module_rtl871x_recv_c_, _drv_err_,
-                                "validate_recv_ctrl_frame fail\n");
-               }
-               retval = _FAIL; /*  only data frame return _SUCCESS */
-               break;
-       case IEEE80211_FTYPE_DATA:
-               pattrib->qos = (subtype & IEEE80211_STYPE_QOS_DATA) ? 1 : 0;
-               retval = validate_recv_data_frame(adapter, precv_frame);
-               if (retval == _FAIL) {
-                       struct recv_priv *precvpriv = &adapter->recvpriv;
-
-                       precvpriv->rx_drop++;
-               }
-               break;
-       default:
-               RT_TRACE(_module_rtl871x_recv_c_, _drv_err_,
-                        "validate_recv_data_frame fail! type = 0x%x\n", type);
-               retval = _FAIL;
-               break;
-       }
-
-exit:
-       return retval;
-}
-
-/* remove the wlanhdr and add the eth_hdr */
-
-static int wlanhdr_to_ethhdr (struct recv_frame *precvframe)
-{
-       u16     eth_type, len, hdrlen;
-       u8      bsnaphdr;
-       u8      *psnap;
-       struct rtw_adapter *adapter = precvframe->adapter;
-       struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
-
-       struct sk_buff *skb = precvframe->pkt;
-       u8 *ptr;
-       struct rx_pkt_attrib *pattrib = &precvframe->attrib;
-
-
-
-       ptr = skb->data;
-       hdrlen = pattrib->hdrlen;
-       psnap = ptr + hdrlen;
-       eth_type = (psnap[6] << 8) | psnap[7];
-       /* convert hdr + possible LLC headers into Ethernet header */
-       if ((ether_addr_equal(psnap, rfc1042_header) &&
-            eth_type != ETH_P_AARP && eth_type != ETH_P_IPX) ||
-           ether_addr_equal(psnap, bridge_tunnel_header)) {
-               /* remove RFC1042 or Bridge-Tunnel encapsulation
-                  and replace EtherType */
-               bsnaphdr = true;
-               hdrlen += SNAP_SIZE;
-       } else {
-               /* Leave Ethernet header part of hdr and full payload */
-               bsnaphdr = false;
-               eth_type = (psnap[0] << 8) | psnap[1];
-       }
-
-       len = skb->len - hdrlen;
-
-       RT_TRACE(_module_rtl871x_recv_c_, _drv_info_,
-                "=== pattrib->hdrlen: %x,  pattrib->iv_len:%x ===\n",
-                pattrib->hdrlen,  pattrib->iv_len);
-
-       pattrib->eth_type = eth_type;
-       if (check_fwstate(pmlmepriv, WIFI_MP_STATE)) {
-               ptr += hdrlen;
-               *ptr = 0x87;
-               *(ptr + 1) = 0x12;
-
-               eth_type = 0x8712;
-               /*  append rx status for mp test packets */
-
-               ptr = skb_pull(skb, (hdrlen - sizeof(struct ethhdr) + 2) - 24);
-               memcpy(ptr, skb->head, 24);
-               ptr += 24;
-       } else {
-               ptr = skb_pull(skb, (hdrlen - sizeof(struct ethhdr) +
-                                    (bsnaphdr ? 2:0)));
-       }
-
-       ether_addr_copy(ptr, pattrib->dst);
-       ether_addr_copy(ptr + ETH_ALEN, pattrib->src);
-
-       if (!bsnaphdr) {
-               put_unaligned_be16(len, ptr + 12);
-       }
-
-
-       return _SUCCESS;
-}
-
-/* perform defrag */
-struct recv_frame *recvframe_defrag(struct rtw_adapter *adapter,
-                                   struct rtw_queue *defrag_q);
-struct recv_frame *recvframe_defrag(struct rtw_adapter *adapter,
-                                   struct rtw_queue *defrag_q)
-{
-       struct list_head *phead;
-       u8 wlanhdr_offset;
-       u8 curfragnum;
-       struct recv_frame *pnfhdr, *ptmp;
-       struct recv_frame *prframe, *pnextrframe;
-       struct rtw_queue *pfree_recv_queue;
-       struct sk_buff *skb;
-
-       curfragnum = 0;
-       pfree_recv_queue = &adapter->recvpriv.free_recv_queue;
-
-       phead = get_list_head(defrag_q);
-       prframe = list_first_entry(phead, struct recv_frame, list);
-       list_del_init(&prframe->list);
-       skb = prframe->pkt;
-
-       if (curfragnum != prframe->attrib.frag_num) {
-               /* the first fragment number must be 0 */
-               /* free the whole queue */
-               rtw_free_recvframe23a(prframe);
-               rtw_free_recvframe23a_queue(defrag_q);
-
-               return NULL;
-       }
-
-       curfragnum++;
-
-       list_for_each_entry_safe(pnfhdr, ptmp, phead, list) {
-               pnextrframe = (struct recv_frame *)pnfhdr;
-               /* check the fragment sequence  (2nd ~n fragment frame) */
-
-               if (curfragnum != pnfhdr->attrib.frag_num) {
-                       /* the fragment number must be increasing
-                          (after decache) */
-                       /* release the defrag_q & prframe */
-                       rtw_free_recvframe23a(prframe);
-                       rtw_free_recvframe23a_queue(defrag_q);
-                       return NULL;
-               }
-
-               curfragnum++;
-
-               /* copy the 2nd~n fragment frame's payload to the
-                  first fragment */
-               /* get the 2nd~last fragment frame's payload */
-
-               wlanhdr_offset = pnfhdr->attrib.hdrlen + pnfhdr->attrib.iv_len;
-
-               skb_pull(pnfhdr->pkt, wlanhdr_offset);
-
-               /* append  to first fragment frame's tail
-                  (if privacy frame, pull the ICV) */
-
-               skb_trim(skb, skb->len - prframe->attrib.icv_len);
-
-               memcpy(skb_tail_pointer(skb), pnfhdr->pkt->data,
-                      pnfhdr->pkt->len);
-
-               skb_put(skb, pnfhdr->pkt->len);
-
-               prframe->attrib.icv_len = pnfhdr->attrib.icv_len;
-       }
-
-       /* free the defrag_q queue and return the prframe */
-       rtw_free_recvframe23a_queue(defrag_q);
-
-       RT_TRACE(_module_rtl871x_recv_c_, _drv_info_,
-                "Performance defrag!!!!!\n");
-
-       return prframe;
-}
-
-/* check if need to defrag, if needed queue the frame to defrag_q */
-struct recv_frame *recvframe_chk_defrag23a(struct rtw_adapter *padapter,
-                                       struct recv_frame *precv_frame)
-{
-       u8      ismfrag;
-       u8      fragnum;
-       u8      *psta_addr;
-       struct recv_frame *pfhdr;
-       struct sta_info *psta;
-       struct sta_priv *pstapriv;
-       struct list_head *phead;
-       struct recv_frame *prtnframe = NULL;
-       struct rtw_queue *pfree_recv_queue, *pdefrag_q;
-
-
-
-       pstapriv = &padapter->stapriv;
-
-       pfhdr = precv_frame;
-
-       pfree_recv_queue = &padapter->recvpriv.free_recv_queue;
-
-       /* need to define struct of wlan header frame ctrl */
-       ismfrag = pfhdr->attrib.mfrag;
-       fragnum = pfhdr->attrib.frag_num;
-
-       psta_addr = pfhdr->attrib.ta;
-       psta = rtw_get_stainfo23a(pstapriv, psta_addr);
-       if (!psta) {
-               struct ieee80211_hdr *hdr =
-                       (struct ieee80211_hdr *) pfhdr->pkt->data;
-               if (!ieee80211_is_data(hdr->frame_control)) {
-                       psta = rtw_get_bcmc_stainfo23a(padapter);
-                       pdefrag_q = &psta->sta_recvpriv.defrag_q;
-               } else
-                       pdefrag_q = NULL;
-       } else
-               pdefrag_q = &psta->sta_recvpriv.defrag_q;
-
-       if ((ismfrag == 0) && (fragnum == 0)) {
-               prtnframe = precv_frame;/* isn't a fragment frame */
-       }
-
-       if (ismfrag == 1) {
-               /* 0~(n-1) fragment frame */
-               /* enqueue to defraf_g */
-               if (pdefrag_q != NULL) {
-                       if (fragnum == 0) {
-                               /* the first fragment */
-                               if (!list_empty(&pdefrag_q->queue)) {
-                                       /* free current defrag_q */
-                                       rtw_free_recvframe23a_queue(pdefrag_q);
-                               }
-                       }
-
-                       /* Then enqueue the 0~(n-1) fragment into the
-                          defrag_q */
-
-                       /* spin_lock(&pdefrag_q->lock); */
-                       phead = get_list_head(pdefrag_q);
-                       list_add_tail(&pfhdr->list, phead);
-                       /* spin_unlock(&pdefrag_q->lock); */
-
-                       RT_TRACE(_module_rtl871x_recv_c_, _drv_info_,
-                                "Enqueuq: ismfrag = %d, fragnum = %d\n",
-                                ismfrag, fragnum);
-
-                       prtnframe = NULL;
-
-               } else {
-                       /* can't find this ta's defrag_queue,
-                          so free this recv_frame */
-                       rtw_free_recvframe23a(precv_frame);
-                       prtnframe = NULL;
-                       RT_TRACE(_module_rtl871x_recv_c_, _drv_err_,
-                                "Free because pdefrag_q == NULL: ismfrag = %d, fragnum = %d\n",
-                                ismfrag, fragnum);
-               }
-       }
-
-       if ((ismfrag == 0) && (fragnum != 0)) {
-               /* the last fragment frame */
-               /* enqueue the last fragment */
-               if (pdefrag_q != NULL) {
-                       /* spin_lock(&pdefrag_q->lock); */
-                       phead = get_list_head(pdefrag_q);
-                       list_add_tail(&pfhdr->list, phead);
-                       /* spin_unlock(&pdefrag_q->lock); */
-
-                       /* call recvframe_defrag to defrag */
-                       RT_TRACE(_module_rtl871x_recv_c_, _drv_info_,
-                                "defrag: ismfrag = %d, fragnum = %d\n",
-                                ismfrag, fragnum);
-                       precv_frame = recvframe_defrag(padapter, pdefrag_q);
-                       prtnframe = precv_frame;
-               } else {
-                       /* can't find this ta's defrag_queue,
-                          so free this recv_frame */
-                       rtw_free_recvframe23a(precv_frame);
-                       prtnframe = NULL;
-                       RT_TRACE(_module_rtl871x_recv_c_, _drv_err_,
-                                "Free because pdefrag_q == NULL: ismfrag = %d, fragnum = %d\n",
-                                ismfrag, fragnum);
-               }
-
-       }
-
-       if ((prtnframe != NULL) && (prtnframe->attrib.privacy)) {
-               /* after defrag we must check tkip mic code */
-               if (recvframe_chkmic(padapter,  prtnframe) == _FAIL) {
-                       RT_TRACE(_module_rtl871x_recv_c_, _drv_err_,
-                                "recvframe_chkmic(padapter,  prtnframe) ==_FAIL\n");
-                       rtw_free_recvframe23a(prtnframe);
-                       prtnframe = NULL;
-               }
-       }
-
-
-
-       return prtnframe;
-}
-
-int amsdu_to_msdu(struct rtw_adapter *padapter, struct recv_frame *prframe);
-int amsdu_to_msdu(struct rtw_adapter *padapter, struct recv_frame *prframe)
-{
-       struct rx_pkt_attrib *pattrib;
-       struct sk_buff *skb, *sub_skb;
-       struct sk_buff_head skb_list;
-
-       pattrib = &prframe->attrib;
-
-       skb = prframe->pkt;
-       skb_pull(skb, prframe->attrib.hdrlen);
-       __skb_queue_head_init(&skb_list);
-
-       ieee80211_amsdu_to_8023s(skb, &skb_list, NULL, 0, 0, false);
-
-       while (!skb_queue_empty(&skb_list)) {
-               sub_skb = __skb_dequeue(&skb_list);
-
-               sub_skb->protocol = eth_type_trans(sub_skb, padapter->pnetdev);
-               sub_skb->dev = padapter->pnetdev;
-
-               sub_skb->ip_summed = CHECKSUM_NONE;
-
-               netif_rx(sub_skb);
-       }
-
-       prframe->pkt = NULL;
-       rtw_free_recvframe23a(prframe);
-       return _SUCCESS;
-}
-
-int check_indicate_seq(struct recv_reorder_ctrl *preorder_ctrl, u16 seq_num);
-int check_indicate_seq(struct recv_reorder_ctrl *preorder_ctrl, u16 seq_num)
-{
-       u8      wsize = preorder_ctrl->wsize_b;
-       u16     wend = (preorder_ctrl->indicate_seq + wsize -1) & 0xFFF;
-
-       /*  Rx Reorder initialize condition. */
-       if (preorder_ctrl->indicate_seq == 0xFFFF)
-               preorder_ctrl->indicate_seq = seq_num;
-
-       /*  Drop out the packet which SeqNum is smaller than WinStart */
-       if (SN_LESS(seq_num, preorder_ctrl->indicate_seq))
-               return false;
-
-       /*  */
-       /*  Sliding window manipulation. Conditions includes: */
-       /*  1. Incoming SeqNum is equal to WinStart =>Window shift 1 */
-       /*  2. Incoming SeqNum is larger than the WinEnd => Window shift N */
-       /*  */
-       if (SN_EQUAL(seq_num, preorder_ctrl->indicate_seq)) {
-               preorder_ctrl->indicate_seq =
-                       (preorder_ctrl->indicate_seq + 1) & 0xFFF;
-       } else if (SN_LESS(wend, seq_num)) {
-               /*  boundary situation, when seq_num cross 0xFFF */
-               if (seq_num >= (wsize - 1))
-                       preorder_ctrl->indicate_seq = seq_num + 1 -wsize;
-               else
-                       preorder_ctrl->indicate_seq = 0xFFF - (wsize - (seq_num + 1)) + 1;
-       }
-       return true;
-}
-
-static int enqueue_reorder_recvframe23a(struct recv_reorder_ctrl *preorder_ctrl,
-                                       struct recv_frame *prframe)
-{
-       struct rx_pkt_attrib *pattrib = &prframe->attrib;
-       struct rtw_queue *ppending_recvframe_queue;
-       struct list_head *phead, *plist, *ptmp;
-       struct recv_frame *hdr;
-       struct rx_pkt_attrib *pnextattrib;
-
-       ppending_recvframe_queue = &preorder_ctrl->pending_recvframe_queue;
-       phead = get_list_head(ppending_recvframe_queue);
-
-       list_for_each_safe(plist, ptmp, phead) {
-               hdr = container_of(plist, struct recv_frame, list);
-               pnextattrib = &hdr->attrib;
-
-               if (SN_LESS(pnextattrib->seq_num, pattrib->seq_num)) {
-                       continue;
-               } else if (SN_EQUAL(pnextattrib->seq_num, pattrib->seq_num)) {
-                       /* Duplicate entry is found!! Do not insert current entry. */
-                       return false;
-               } else {
-                       break;
-               }
-
-       }
-
-       list_del_init(&prframe->list);
-
-       list_add_tail(&prframe->list, plist);
-
-       return true;
-}
-
-int recv_indicatepkts_in_order(struct rtw_adapter *padapter,
-                              struct recv_reorder_ctrl *preorder_ctrl,
-                              int bforced);
-int recv_indicatepkts_in_order(struct rtw_adapter *padapter,
-                              struct recv_reorder_ctrl *preorder_ctrl,
-                              int bforced)
-{
-       struct list_head *phead, *plist;
-       struct recv_frame *prframe;
-       struct rx_pkt_attrib *pattrib;
-       int bPktInBuf = false;
-       struct recv_priv *precvpriv;
-       struct rtw_queue *ppending_recvframe_queue;
-
-       precvpriv = &padapter->recvpriv;
-       ppending_recvframe_queue = &preorder_ctrl->pending_recvframe_queue;
-       phead = get_list_head(ppending_recvframe_queue);
-       plist = phead->next;
-
-       /*  Handling some condition for forced indicate case. */
-       if (bforced) {
-               if (list_empty(phead)) {
-                       return true;
-               }
-
-               prframe = container_of(plist, struct recv_frame, list);
-               pattrib = &prframe->attrib;
-               preorder_ctrl->indicate_seq = pattrib->seq_num;
-       }
-
-       /*  Prepare indication list and indication. */
-       /*  Check if there is any packet need indicate. */
-       while (!list_empty(phead)) {
-
-               prframe = container_of(plist, struct recv_frame, list);
-               pattrib = &prframe->attrib;
-
-               if (!SN_LESS(preorder_ctrl->indicate_seq, pattrib->seq_num)) {
-                       RT_TRACE(_module_rtl871x_recv_c_, _drv_notice_,
-                                "recv_indicatepkts_in_order: indicate =%d seq =%d amsdu =%d\n",
-                                preorder_ctrl->indicate_seq,
-                                pattrib->seq_num, pattrib->amsdu);
-
-                       plist = plist->next;
-                       list_del_init(&prframe->list);
-
-                       if (SN_EQUAL(preorder_ctrl->indicate_seq,
-                                    pattrib->seq_num)) {
-                               preorder_ctrl->indicate_seq =
-                                       (preorder_ctrl->indicate_seq + 1)&0xFFF;
-                       }
-
-                       if (!pattrib->amsdu) {
-                               if ((padapter->bDriverStopped == false) &&
-                                   (padapter->bSurpriseRemoved == false)) {
-                                       rtw_recv_indicatepkt23a(padapter, prframe);
-                               }
-                       } else {
-                               if (amsdu_to_msdu(padapter, prframe) !=
-                                   _SUCCESS)
-                                       rtw_free_recvframe23a(prframe);
-                       }
-
-                       /* Update local variables. */
-                       bPktInBuf = false;
-
-               } else {
-                       bPktInBuf = true;
-                       break;
-               }
-
-       }
-
-       return bPktInBuf;
-}
-
-int recv_indicatepkt_reorder(struct rtw_adapter *padapter,
-                            struct recv_frame *prframe);
-int recv_indicatepkt_reorder(struct rtw_adapter *padapter,
-                            struct recv_frame *prframe)
-{
-       int retval = _SUCCESS;
-       struct rx_pkt_attrib *pattrib;
-       struct recv_reorder_ctrl *preorder_ctrl;
-       struct rtw_queue *ppending_recvframe_queue;
-
-       pattrib = &prframe->attrib;
-       preorder_ctrl = prframe->preorder_ctrl;
-       ppending_recvframe_queue = &preorder_ctrl->pending_recvframe_queue;
-
-       if (!pattrib->amsdu) {
-               /* s1. */
-               wlanhdr_to_ethhdr(prframe);
-
-               if ((pattrib->qos!= 1) || (pattrib->eth_type == ETH_P_ARP) ||
-                   (pattrib->ack_policy != 0)) {
-                       if ((padapter->bDriverStopped == false) &&
-                           (padapter->bSurpriseRemoved == false)) {
-                               RT_TRACE(_module_rtl871x_recv_c_, _drv_notice_,
-                                        "@@@@  recv_indicatepkt_reorder -recv_func recv_indicatepkt\n");
-
-                               rtw_recv_indicatepkt23a(padapter, prframe);
-                               return _SUCCESS;
-                       }
-
-                       return _FAIL;
-               }
-
-               if (preorder_ctrl->enable == false) {
-                       /* indicate this recv_frame */
-                       preorder_ctrl->indicate_seq = pattrib->seq_num;
-                       rtw_recv_indicatepkt23a(padapter, prframe);
-
-                       preorder_ctrl->indicate_seq =
-                               (preorder_ctrl->indicate_seq + 1) % 4096;
-                       return _SUCCESS;
-               }
-       } else {
-                /* temp filter -> means didn't support A-MSDUs in a A-MPDU */
-               if (preorder_ctrl->enable == false) {
-                       preorder_ctrl->indicate_seq = pattrib->seq_num;
-                       retval = amsdu_to_msdu(padapter, prframe);
-
-                       preorder_ctrl->indicate_seq =
-                               (preorder_ctrl->indicate_seq + 1) % 4096;
-                       return retval;
-               }
-       }
-
-       spin_lock_bh(&ppending_recvframe_queue->lock);
-
-       RT_TRACE(_module_rtl871x_recv_c_, _drv_notice_,
-                "recv_indicatepkt_reorder: indicate =%d seq =%d\n",
-                preorder_ctrl->indicate_seq, pattrib->seq_num);
-
-       /* s2. check if winstart_b(indicate_seq) needs to been updated */
-       if (!check_indicate_seq(preorder_ctrl, pattrib->seq_num)) {
-               goto _err_exit;
-       }
-
-       /* s3. Insert all packet into Reorder Queue to maintain its ordering. */
-       if (!enqueue_reorder_recvframe23a(preorder_ctrl, prframe)) {
-               goto _err_exit;
-       }
-
-       /* s4. */
-       /*  Indication process. */
-       /*  After Packet dropping and Sliding Window shifting as above,
-           we can now just indicate the packets */
-       /*  with the SeqNum smaller than latest WinStart and buffer
-           other packets. */
-       /*  */
-       /*  For Rx Reorder condition: */
-       /*  1. All packets with SeqNum smaller than WinStart => Indicate */
-       /*  2. All packets with SeqNum larger than or equal to WinStart =>
-           Buffer it. */
-       /*  */
-
-       if (recv_indicatepkts_in_order(padapter, preorder_ctrl, false) == true) {
-               mod_timer(&preorder_ctrl->reordering_ctrl_timer,
-                         jiffies + msecs_to_jiffies(REORDER_WAIT_TIME));
-               spin_unlock_bh(&ppending_recvframe_queue->lock);
-       } else {
-               spin_unlock_bh(&ppending_recvframe_queue->lock);
-               del_timer_sync(&preorder_ctrl->reordering_ctrl_timer);
-       }
-       return _SUCCESS;
-
-_err_exit:
-
-       spin_unlock_bh(&ppending_recvframe_queue->lock);
-       return _FAIL;
-}
-
-void rtw_reordering_ctrl_timeout_handler23a(unsigned long pcontext)
-{
-       struct recv_reorder_ctrl *preorder_ctrl;
-       struct rtw_adapter *padapter;
-       struct rtw_queue *ppending_recvframe_queue;
-
-       preorder_ctrl = (struct recv_reorder_ctrl *)pcontext;
-       padapter = preorder_ctrl->padapter;
-       ppending_recvframe_queue = &preorder_ctrl->pending_recvframe_queue;
-
-       if (padapter->bDriverStopped || padapter->bSurpriseRemoved) {
-               return;
-       }
-
-       spin_lock_bh(&ppending_recvframe_queue->lock);
-
-       if (recv_indicatepkts_in_order(padapter, preorder_ctrl, true) == true) {
-               mod_timer(&preorder_ctrl->reordering_ctrl_timer,
-                         jiffies + msecs_to_jiffies(REORDER_WAIT_TIME));
-       }
-
-       spin_unlock_bh(&ppending_recvframe_queue->lock);
-}
-
-int process_recv_indicatepkts(struct rtw_adapter *padapter,
-                             struct recv_frame *prframe);
-int process_recv_indicatepkts(struct rtw_adapter *padapter,
-                             struct recv_frame *prframe)
-{
-       int retval = _SUCCESS;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct ht_priv *phtpriv = &pmlmepriv->htpriv;
-
-       if (phtpriv->ht_option == true) { /* B/G/N Mode */
-               /*  including perform A-MPDU Rx Ordering Buffer Control */
-               if (recv_indicatepkt_reorder(padapter, prframe) != _SUCCESS) {
-                       if ((padapter->bDriverStopped == false) &&
-                           (padapter->bSurpriseRemoved == false)) {
-                               retval = _FAIL;
-                               return retval;
-                       }
-               }
-       } else { /* B/G mode */
-               retval = wlanhdr_to_ethhdr(prframe);
-               if (retval != _SUCCESS) {
-                       RT_TRACE(_module_rtl871x_recv_c_, _drv_err_,
-                                "wlanhdr_to_ethhdr: drop pkt\n");
-                       return retval;
-               }
-
-               if ((padapter->bDriverStopped == false) &&
-                   (padapter->bSurpriseRemoved == false)) {
-                       /* indicate this recv_frame */
-                       RT_TRACE(_module_rtl871x_recv_c_, _drv_notice_,
-                                "@@@@ process_recv_indicatepkts- recv_func recv_indicatepkt\n");
-                       rtw_recv_indicatepkt23a(padapter, prframe);
-               } else {
-                       RT_TRACE(_module_rtl871x_recv_c_, _drv_notice_,
-                                "@@@@ process_recv_indicatepkts- recv_func free_indicatepkt\n");
-
-                       RT_TRACE(_module_rtl871x_recv_c_, _drv_notice_,
-                                "recv_func:bDriverStopped(%d) OR bSurpriseRemoved(%d)\n",
-                                padapter->bDriverStopped,
-                                padapter->bSurpriseRemoved);
-                       retval = _FAIL;
-                       return retval;
-               }
-
-       }
-
-       return retval;
-}
-
-static int recv_func_prehandle(struct rtw_adapter *padapter,
-                              struct recv_frame *rframe)
-{
-       int ret;
-
-       /* check the frame crtl field and decache */
-       ret = validate_recv_frame(padapter, rframe);
-       if (ret != _SUCCESS) {
-               RT_TRACE(_module_rtl871x_recv_c_, _drv_info_,
-                        "recv_func: validate_recv_frame fail! drop pkt\n");
-               rtw_free_recvframe23a(rframe);
-               goto exit;
-       }
-
-exit:
-       return ret;
-}
-
-static int recv_func_posthandle(struct rtw_adapter *padapter,
-                               struct recv_frame *prframe)
-{
-       int ret = _SUCCESS;
-       struct recv_frame *orig_prframe = prframe;
-       struct recv_priv *precvpriv = &padapter->recvpriv;
-
-       /*  DATA FRAME */
-       prframe = decryptor(padapter, prframe);
-       if (prframe == NULL) {
-               RT_TRACE(_module_rtl871x_recv_c_, _drv_err_,
-                        "decryptor: drop pkt\n");
-               ret = _FAIL;
-               goto _recv_data_drop;
-       }
-
-       prframe = recvframe_chk_defrag23a(padapter, prframe);
-       if (!prframe) {
-               RT_TRACE(_module_rtl871x_recv_c_, _drv_err_,
-                        "recvframe_chk_defrag23a: drop pkt\n");
-               goto _recv_data_drop;
-       }
-
-       /*
-        * Pull off crypto headers
-        */
-       if (prframe->attrib.iv_len > 0) {
-               skb_pull(prframe->pkt, prframe->attrib.iv_len);
-       }
-
-       if (prframe->attrib.icv_len > 0) {
-               skb_trim(prframe->pkt,
-                        prframe->pkt->len - prframe->attrib.icv_len);
-       }
-
-       prframe = portctrl(padapter, prframe);
-       if (!prframe) {
-               RT_TRACE(_module_rtl871x_recv_c_, _drv_err_,
-                        "portctrl: drop pkt\n");
-               ret = _FAIL;
-               goto _recv_data_drop;
-       }
-
-       count_rx_stats(padapter, prframe, NULL);
-
-       ret = process_recv_indicatepkts(padapter, prframe);
-       if (ret != _SUCCESS) {
-               RT_TRACE(_module_rtl871x_recv_c_, _drv_err_,
-                        "recv_func: process_recv_indicatepkts fail!\n");
-               rtw_free_recvframe23a(orig_prframe);/* free this recv_frame */
-               goto _recv_data_drop;
-       }
-       return ret;
-
-_recv_data_drop:
-       precvpriv->rx_drop++;
-       return ret;
-}
-
-int rtw_recv_entry23a(struct recv_frame *rframe)
-{
-       int ret, r;
-       struct rtw_adapter *padapter = rframe->adapter;
-       struct rx_pkt_attrib *prxattrib = &rframe->attrib;
-       struct recv_priv *recvpriv = &padapter->recvpriv;
-       struct security_priv *psecuritypriv = &padapter->securitypriv;
-       struct mlme_priv *mlmepriv = &padapter->mlmepriv;
-
-       /* check if need to handle uc_swdec_pending_queue*/
-       if (check_fwstate(mlmepriv, WIFI_STATION_STATE) &&
-           psecuritypriv->busetkipkey) {
-               struct recv_frame *pending_frame;
-
-               while ((pending_frame = rtw_alloc_recvframe23a(&padapter->recvpriv.uc_swdec_pending_queue))) {
-                       r = recv_func_posthandle(padapter, pending_frame);
-                       if (r == _SUCCESS)
-                               DBG_8723A("%s: dequeue uc_swdec_pending_queue\n", __func__);
-               }
-       }
-
-       ret = recv_func_prehandle(padapter, rframe);
-
-       if (ret == _SUCCESS) {
-               /* check if need to enqueue into uc_swdec_pending_queue*/
-               if (check_fwstate(mlmepriv, WIFI_STATION_STATE) &&
-                   !is_multicast_ether_addr(prxattrib->ra) &&
-                   prxattrib->encrypt > 0 &&
-                   (prxattrib->bdecrypted == 0) &&
-                   !is_wep_enc(psecuritypriv->dot11PrivacyAlgrthm) &&
-                   !psecuritypriv->busetkipkey) {
-                       rtw_enqueue_recvframe23a(rframe, &padapter->recvpriv.uc_swdec_pending_queue);
-                       DBG_8723A("%s: no key, enqueue uc_swdec_pending_queue\n", __func__);
-                       goto exit;
-               }
-
-               ret = recv_func_posthandle(padapter, rframe);
-
-               recvpriv->rx_pkts++;
-       }
-
-exit:
-       return ret;
-}
-
-void rtw_signal_stat_timer_hdl23a(unsigned long data)
-{
-       struct rtw_adapter *adapter = (struct rtw_adapter *)data;
-       struct recv_priv *recvpriv = &adapter->recvpriv;
-
-       u32 tmp_s, tmp_q;
-       u8 avg_signal_strength = 0;
-       u8 avg_signal_qual = 0;
-       u32 num_signal_strength = 0;
-       u32 num_signal_qual = 0;
-       u8 _alpha = 3;  /* this value is based on converging_constant = 5000 */
-                       /* and sampling_interval = 1000 */
-
-       if (recvpriv->signal_strength_data.update_req == 0) {
-               /*  update_req is clear, means we got rx */
-               avg_signal_strength = recvpriv->signal_strength_data.avg_val;
-               num_signal_strength = recvpriv->signal_strength_data.total_num;
-               /*  after avg_vals are acquired, we can re-stat */
-               /* the signal values */
-               recvpriv->signal_strength_data.update_req = 1;
-       }
-
-       if (recvpriv->signal_qual_data.update_req == 0) {
-               /*  update_req is clear, means we got rx */
-               avg_signal_qual = recvpriv->signal_qual_data.avg_val;
-               num_signal_qual = recvpriv->signal_qual_data.total_num;
-               /*  after avg_vals are acquired, we can re-stat */
-               /*the signal values */
-               recvpriv->signal_qual_data.update_req = 1;
-       }
-
-       /* update value of signal_strength, rssi, signal_qual */
-       if (!check_fwstate(&adapter->mlmepriv, _FW_UNDER_SURVEY)) {
-               tmp_s = avg_signal_strength + (_alpha - 1) *
-                        recvpriv->signal_strength;
-               if (tmp_s %_alpha)
-                       tmp_s = tmp_s / _alpha + 1;
-               else
-                       tmp_s = tmp_s / _alpha;
-               if (tmp_s > 100)
-                       tmp_s = 100;
-
-               tmp_q = avg_signal_qual + (_alpha - 1) * recvpriv->signal_qual;
-               if (tmp_q %_alpha)
-                       tmp_q = tmp_q / _alpha + 1;
-               else
-                       tmp_q = tmp_q / _alpha;
-               if (tmp_q > 100)
-                       tmp_q = 100;
-
-               recvpriv->signal_strength = tmp_s;
-               recvpriv->signal_qual = tmp_q;
-
-               DBG_8723A("%s signal_strength:%3u, signal_qual:%3u, "
-                         "num_signal_strength:%u, num_signal_qual:%u\n",
-                         __func__, recvpriv->signal_strength,
-                         recvpriv->signal_qual, num_signal_strength,
-                         num_signal_qual);
-       }
-
-       rtw_set_signal_stat_timer(recvpriv);
-}
diff --git a/drivers/staging/rtl8723au/core/rtw_security.c b/drivers/staging/rtl8723au/core/rtw_security.c
deleted file mode 100644 (file)
index 5a4cfdf..0000000
+++ /dev/null
@@ -1,1630 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#define  _RTW_SECURITY_C_
-
-#include <osdep_service.h>
-#include <drv_types.h>
-#include <wifi.h>
-#include <osdep_intf.h>
-
-/* WEP related ===== */
-
-#define CRC32_POLY 0x04c11db7
-
-struct arc4context {
-       u32 x;
-       u32 y;
-       u8 state[256];
-};
-
-static void arcfour_init(struct arc4context *parc4ctx, u8 *key, u32 key_len)
-{
-       u32 t, u;
-       u32 keyindex;
-       u32 stateindex;
-       u8 *state;
-       u32 counter;
-
-       state = parc4ctx->state;
-       parc4ctx->x = 0;
-       parc4ctx->y = 0;
-       for (counter = 0; counter < 256; counter++)
-               state[counter] = (u8)counter;
-       keyindex = 0;
-       stateindex = 0;
-       for (counter = 0; counter < 256; counter++) {
-               t = state[counter];
-               stateindex = (stateindex + key[keyindex] + t) & 0xff;
-               u = state[stateindex];
-               state[stateindex] = (u8)t;
-               state[counter] = (u8)u;
-               if (++keyindex >= key_len)
-                       keyindex = 0;
-       }
-
-}
-
-static u32 arcfour_byte(struct arc4context *parc4ctx)
-{
-       u32 x;
-       u32 y;
-       u32 sx, sy;
-       u8 *state;
-
-       state = parc4ctx->state;
-       x = (parc4ctx->x + 1) & 0xff;
-       sx = state[x];
-       y = (sx + parc4ctx->y) & 0xff;
-       sy = state[y];
-       parc4ctx->x = x;
-       parc4ctx->y = y;
-       state[y] = (u8)sx;
-       state[x] = (u8)sy;
-
-       return state[(sx + sy) & 0xff];
-}
-
-static void arcfour_encrypt(struct arc4context *parc4ctx, u8 *dest,
-                           u8 *src, u32 len)
-{
-       u32 i;
-
-       for (i = 0; i < len; i++)
-               dest[i] = src[i] ^ (unsigned char)arcfour_byte(parc4ctx);
-}
-
-static int bcrc32initialized;
-static u32 crc32_table[256];
-
-static u8 crc32_reverseBit(u8 data)
-{
-       u8 retval = ((data << 7) & 0x80) | ((data << 5) & 0x40) |
-               ((data << 3) & 0x20) | ((data << 1) & 0x10) |
-               ((data >> 1) & 0x08) | ((data >> 3) & 0x04) |
-               ((data >> 5) & 0x02) | ((data >> 7) & 0x01);
-       return retval;
-}
-
-static void crc32_init(void)
-{
-       int i, j;
-       u32 c;
-       u8 *p, *p1;
-       u8 k;
-
-       if (bcrc32initialized == 1)
-               return;
-
-       p = (u8 *) &c;
-       c = 0x12340000;
-
-       for (i = 0; i < 256; ++i) {
-               k = crc32_reverseBit((u8)i);
-
-               for (c = ((u32)k) << 24, j = 8; j > 0; --j)
-                       c = c & 0x80000000 ? (c << 1) ^ CRC32_POLY : (c << 1);
-
-               p1 = (u8 *)&crc32_table[i];
-
-               p1[0] = crc32_reverseBit(p[3]);
-               p1[1] = crc32_reverseBit(p[2]);
-               p1[2] = crc32_reverseBit(p[1]);
-               p1[3] = crc32_reverseBit(p[0]);
-       }
-
-       bcrc32initialized = 1;
-}
-
-static u32 getcrc32(u8 *buf, int len)
-{
-       u8 *p;
-       u32 crc;
-
-       if (bcrc32initialized == 0)
-               crc32_init();
-
-       crc = 0xffffffff; /* preload shift register, per CRC-32 spec */
-
-       for (p = buf; len > 0; ++p, --len)
-               crc = crc32_table[(crc ^ *p) & 0xff] ^ (crc >> 8);
-
-       return ~crc; /* transmit complement, per CRC-32 spec */
-}
-
-/* Need to consider the fragment  situation */
-void rtw_wep_encrypt23a(struct rtw_adapter *padapter,
-                    struct xmit_frame *pxmitframe)
-{
-       /*  exclude ICV */
-       __le32 crc;
-       struct arc4context mycontext;
-       int curfragnum, length, index;
-       u32 keylength;
-       u8 *pframe, *payload, *iv; /* wepkey */
-       u8 wepkey[16];
-       u8 hw_hdr_offset = 0;
-       struct pkt_attrib *pattrib = &pxmitframe->attrib;
-       struct security_priv *psecuritypriv = &padapter->securitypriv;
-       struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-
-       if (!pxmitframe->buf_addr)
-               return;
-
-       hw_hdr_offset = TXDESC_OFFSET;
-
-       pframe = pxmitframe->buf_addr + hw_hdr_offset;
-
-       /* start to encrypt each fragment */
-       if (pattrib->encrypt != WLAN_CIPHER_SUITE_WEP40 &&
-           pattrib->encrypt != WLAN_CIPHER_SUITE_WEP104)
-               return;
-
-       index = psecuritypriv->dot11PrivacyKeyIndex;
-       keylength = psecuritypriv->wep_key[index].keylen;
-
-       for (curfragnum = 0; curfragnum < pattrib->nr_frags ; curfragnum++) {
-               iv = pframe + pattrib->hdrlen;
-               memcpy(&wepkey[0], iv, 3);
-               memcpy(&wepkey[3], &psecuritypriv->wep_key[index].key,
-                      keylength);
-               payload = pframe + pattrib->iv_len + pattrib->hdrlen;
-
-               if ((curfragnum + 1) == pattrib->nr_frags) {
-                       /* the last fragment */
-                       length = pattrib->last_txcmdsz - pattrib->hdrlen -
-                               pattrib->iv_len - pattrib->icv_len;
-
-                       crc = cpu_to_le32(getcrc32(payload, length));
-
-                       arcfour_init(&mycontext, wepkey, 3 + keylength);
-                       arcfour_encrypt(&mycontext, payload, payload, length);
-                       arcfour_encrypt(&mycontext, payload + length,
-                                       (char *)&crc, 4);
-               } else {
-                       length = pxmitpriv->frag_len - pattrib->hdrlen -
-                               pattrib->iv_len - pattrib->icv_len;
-                       crc = cpu_to_le32(getcrc32(payload, length));
-                       arcfour_init(&mycontext, wepkey, 3 + keylength);
-                       arcfour_encrypt(&mycontext, payload, payload, length);
-                       arcfour_encrypt(&mycontext, payload + length,
-                                       (char *)&crc, 4);
-
-                       pframe += pxmitpriv->frag_len;
-                       pframe = PTR_ALIGN(pframe, 4);
-               }
-       }
-
-}
-
-void rtw_wep_decrypt23a(struct rtw_adapter *padapter,
-                    struct recv_frame *precvframe)
-{
-       /*  exclude ICV */
-       u32 actual_crc, expected_crc;
-       struct arc4context mycontext;
-       int length;
-       u32 keylength;
-       u8 *pframe, *payload, *iv, wepkey[16];
-       u8 keyindex;
-       struct rx_pkt_attrib *prxattrib = &precvframe->attrib;
-       struct security_priv *psecuritypriv = &padapter->securitypriv;
-       struct sk_buff *skb = precvframe->pkt;
-
-       pframe = skb->data;
-
-       /* start to decrypt recvframe */
-       if (prxattrib->encrypt != WLAN_CIPHER_SUITE_WEP40 &&
-           prxattrib->encrypt != WLAN_CIPHER_SUITE_WEP104)
-               return;
-
-       iv = pframe + prxattrib->hdrlen;
-       /* keyindex = (iv[3]&0x3); */
-       keyindex = prxattrib->key_index;
-       keylength = psecuritypriv->wep_key[keyindex].keylen;
-       memcpy(&wepkey[0], iv, 3);
-       /* memcpy(&wepkey[3], &psecuritypriv->dot11DefKey[psecuritypriv->dot11PrivacyKeyIndex].skey[0], keylength); */
-       memcpy(&wepkey[3], &psecuritypriv->wep_key[keyindex].key, keylength);
-       length = skb->len - prxattrib->hdrlen - prxattrib->iv_len;
-
-       payload = pframe + prxattrib->iv_len + prxattrib->hdrlen;
-
-       /* decrypt payload include icv */
-       arcfour_init(&mycontext, wepkey, 3 + keylength);
-       arcfour_encrypt(&mycontext, payload, payload, length);
-
-       /* calculate icv and compare the icv */
-       actual_crc = getcrc32(payload, length - 4);
-       expected_crc = get_unaligned_le32(&payload[length - 4]);
-
-       if (actual_crc != expected_crc) {
-               RT_TRACE(_module_rtl871x_security_c_, _drv_err_,
-                        "%s:icv CRC mismatch: "
-                        "actual: %08x, expected: %08x\n",
-                        __func__, actual_crc, expected_crc);
-       }
-}
-
-/* 3           ===== TKIP related ===== */
-
-static u32 secmicgetuint32(u8 *p)
-/*  Convert from Byte[] to u32 in a portable way */
-{
-       s32 i;
-       u32 res = 0;
-
-       for (i = 0; i < 4; i++)
-               res |= ((u32)(*p++)) << (8 * i);
-
-       return res;
-}
-
-static void secmicputuint32(u8 *p, u32 val)
-/*  Convert from long to Byte[] in a portable way */
-{
-       long i;
-
-       for (i = 0; i < 4; i++) {
-               *p++ = (u8) (val & 0xff);
-               val >>= 8;
-       }
-
-}
-
-static void secmicclear(struct mic_data *pmicdata)
-{
-/*  Reset the state to the empty message. */
-
-       pmicdata->L = pmicdata->K0;
-       pmicdata->R = pmicdata->K1;
-       pmicdata->nBytesInM = 0;
-       pmicdata->M = 0;
-
-}
-
-void rtw_secmicsetkey23a(struct mic_data *pmicdata, u8 *key)
-{
-       /*  Set the key */
-
-       pmicdata->K0 = secmicgetuint32(key);
-       pmicdata->K1 = secmicgetuint32(key + 4);
-       /*  and reset the message */
-       secmicclear(pmicdata);
-
-}
-
-void rtw_secmicappend23abyte23a(struct mic_data *pmicdata, u8 b)
-{
-
-       /*  Append the byte to our word-sized buffer */
-       pmicdata->M |= ((unsigned long)b) << (8 * pmicdata->nBytesInM);
-       pmicdata->nBytesInM++;
-       /*  Process the word if it is full. */
-       if (pmicdata->nBytesInM >= 4) {
-               pmicdata->L ^= pmicdata->M;
-               pmicdata->R ^= ROL32(pmicdata->L, 17);
-               pmicdata->L += pmicdata->R;
-               pmicdata->R ^= ((pmicdata->L & 0xff00ff00) >> 8) | ((pmicdata->L & 0x00ff00ff) << 8);
-               pmicdata->L += pmicdata->R;
-               pmicdata->R ^= ROL32(pmicdata->L, 3);
-               pmicdata->L += pmicdata->R;
-               pmicdata->R ^= ROR32(pmicdata->L, 2);
-               pmicdata->L += pmicdata->R;
-               /*  Clear the buffer */
-               pmicdata->M = 0;
-               pmicdata->nBytesInM = 0;
-       }
-
-}
-
-void rtw_secmicappend23a(struct mic_data *pmicdata, u8 *src, u32 nbytes)
-{
-
-       /*  This is simple */
-       while (nbytes > 0) {
-               rtw_secmicappend23abyte23a(pmicdata, *src++);
-               nbytes--;
-       }
-
-}
-
-void rtw_secgetmic23a(struct mic_data *pmicdata, u8 *dst)
-{
-
-       /*  Append the minimum padding */
-       rtw_secmicappend23abyte23a(pmicdata, 0x5a);
-       rtw_secmicappend23abyte23a(pmicdata, 0);
-       rtw_secmicappend23abyte23a(pmicdata, 0);
-       rtw_secmicappend23abyte23a(pmicdata, 0);
-       rtw_secmicappend23abyte23a(pmicdata, 0);
-       /*  and then zeroes until the length is a multiple of 4 */
-       while (pmicdata->nBytesInM != 0)
-               rtw_secmicappend23abyte23a(pmicdata, 0);
-       /*  The appendByte function has already computed the result. */
-       secmicputuint32(dst, pmicdata->L);
-       secmicputuint32(dst + 4, pmicdata->R);
-       /*  Reset to the empty message. */
-       secmicclear(pmicdata);
-
-}
-
-void rtw_seccalctkipmic23a(u8 *key, u8 *header, u8 *data, u32 data_len,
-                          u8 *mic_code, u8 pri)
-{
-
-       struct mic_data micdata;
-       u8 priority[4] = {0x0, 0x0, 0x0, 0x0};
-
-       rtw_secmicsetkey23a(&micdata, key);
-       priority[0] = pri;
-
-       /* Michael MIC pseudo header: DA, SA, 3 x 0, Priority */
-       if (header[1]&1) { /* ToDS == 1 */
-                       rtw_secmicappend23a(&micdata, &header[16], 6); /* DA */
-               if (header[1]&2) /* From Ds == 1 */
-                       rtw_secmicappend23a(&micdata, &header[24], 6);
-               else
-                       rtw_secmicappend23a(&micdata, &header[10], 6);
-       } else { /* ToDS == 0 */
-               rtw_secmicappend23a(&micdata, &header[4], 6); /* DA */
-               if (header[1]&2) /* From Ds == 1 */
-                       rtw_secmicappend23a(&micdata, &header[16], 6);
-               else
-                       rtw_secmicappend23a(&micdata, &header[10], 6);
-
-       }
-       rtw_secmicappend23a(&micdata, &priority[0], 4);
-
-       rtw_secmicappend23a(&micdata, data, data_len);
-
-       rtw_secgetmic23a(&micdata, mic_code);
-
-}
-
-/* macros for extraction/creation of unsigned char/unsigned short values  */
-#define RotR1(v16)   ((((v16) >> 1) & 0x7FFF) ^ (((v16) & 1) << 15))
-#define   Lo8(v16)   ((u8)((v16)       & 0x00FF))
-#define   Hi8(v16)   ((u8)(((v16) >> 8) & 0x00FF))
-#define  Lo16(v32)   ((u16)((v32)       & 0xFFFF))
-#define  Hi16(v32)   ((u16)(((v32) >> 16) & 0xFFFF))
-#define  Mk16(hi, lo) ((lo) ^ (((u16)(hi)) << 8))
-
-/* select the Nth 16-bit word of the temporal key unsigned char array TK[] */
-#define  TK16(N)     Mk16(tk[2 * (N) + 1], tk[2 * (N)])
-
-/* S-box lookup: 16 bits --> 16 bits */
-#define _S_(v16)     (Sbox1[0][Lo8(v16)] ^ Sbox1[1][Hi8(v16)])
-
-/* fixed algorithm "parameters" */
-#define PHASE1_LOOP_CNT   8    /* this needs to be "big enough"     */
-#define TA_SIZE           6    /*  48-bit transmitter address       */
-#define TK_SIZE          16    /* 128-bit temporal key              */
-#define P1K_SIZE         10    /*  80-bit Phase1 key                */
-#define RC4_KEY_SIZE     16    /* 128-bit RC4KEY (104 bits unknown) */
-
-/* 2-unsigned char by 2-unsigned char subset of the full AES S-box table */
-static const unsigned short Sbox1[2][256] = {
-       /* Sbox for hash (can be in ROM) */
-       {
-               0xC6A5, 0xF884, 0xEE99, 0xF68D, 0xFF0D, 0xD6BD, 0xDEB1, 0x9154,
-               0x6050, 0x0203, 0xCEA9, 0x567D, 0xE719, 0xB562, 0x4DE6, 0xEC9A,
-               0x8F45, 0x1F9D, 0x8940, 0xFA87, 0xEF15, 0xB2EB, 0x8EC9, 0xFB0B,
-               0x41EC, 0xB367, 0x5FFD, 0x45EA, 0x23BF, 0x53F7, 0xE496, 0x9B5B,
-               0x75C2, 0xE11C, 0x3DAE, 0x4C6A, 0x6C5A, 0x7E41, 0xF502, 0x834F,
-               0x685C, 0x51F4, 0xD134, 0xF908, 0xE293, 0xAB73, 0x6253, 0x2A3F,
-               0x080C, 0x9552, 0x4665, 0x9D5E, 0x3028, 0x37A1, 0x0A0F, 0x2FB5,
-               0x0E09, 0x2436, 0x1B9B, 0xDF3D, 0xCD26, 0x4E69, 0x7FCD, 0xEA9F,
-               0x121B, 0x1D9E, 0x5874, 0x342E, 0x362D, 0xDCB2, 0xB4EE, 0x5BFB,
-               0xA4F6, 0x764D, 0xB761, 0x7DCE, 0x527B, 0xDD3E, 0x5E71, 0x1397,
-               0xA6F5, 0xB968, 0x0000, 0xC12C, 0x4060, 0xE31F, 0x79C8, 0xB6ED,
-               0xD4BE, 0x8D46, 0x67D9, 0x724B, 0x94DE, 0x98D4, 0xB0E8, 0x854A,
-               0xBB6B, 0xC52A, 0x4FE5, 0xED16, 0x86C5, 0x9AD7, 0x6655, 0x1194,
-               0x8ACF, 0xE910, 0x0406, 0xFE81, 0xA0F0, 0x7844, 0x25BA, 0x4BE3,
-               0xA2F3, 0x5DFE, 0x80C0, 0x058A, 0x3FAD, 0x21BC, 0x7048, 0xF104,
-               0x63DF, 0x77C1, 0xAF75, 0x4263, 0x2030, 0xE51A, 0xFD0E, 0xBF6D,
-               0x814C, 0x1814, 0x2635, 0xC32F, 0xBEE1, 0x35A2, 0x88CC, 0x2E39,
-               0x9357, 0x55F2, 0xFC82, 0x7A47, 0xC8AC, 0xBAE7, 0x322B, 0xE695,
-               0xC0A0, 0x1998, 0x9ED1, 0xA37F, 0x4466, 0x547E, 0x3BAB, 0x0B83,
-               0x8CCA, 0xC729, 0x6BD3, 0x283C, 0xA779, 0xBCE2, 0x161D, 0xAD76,
-               0xDB3B, 0x6456, 0x744E, 0x141E, 0x92DB, 0x0C0A, 0x486C, 0xB8E4,
-               0x9F5D, 0xBD6E, 0x43EF, 0xC4A6, 0x39A8, 0x31A4, 0xD337, 0xF28B,
-               0xD532, 0x8B43, 0x6E59, 0xDAB7, 0x018C, 0xB164, 0x9CD2, 0x49E0,
-               0xD8B4, 0xACFA, 0xF307, 0xCF25, 0xCAAF, 0xF48E, 0x47E9, 0x1018,
-               0x6FD5, 0xF088, 0x4A6F, 0x5C72, 0x3824, 0x57F1, 0x73C7, 0x9751,
-               0xCB23, 0xA17C, 0xE89C, 0x3E21, 0x96DD, 0x61DC, 0x0D86, 0x0F85,
-               0xE090, 0x7C42, 0x71C4, 0xCCAA, 0x90D8, 0x0605, 0xF701, 0x1C12,
-               0xC2A3, 0x6A5F, 0xAEF9, 0x69D0, 0x1791, 0x9958, 0x3A27, 0x27B9,
-               0xD938, 0xEB13, 0x2BB3, 0x2233, 0xD2BB, 0xA970, 0x0789, 0x33A7,
-               0x2DB6, 0x3C22, 0x1592, 0xC920, 0x8749, 0xAAFF, 0x5078, 0xA57A,
-               0x038F, 0x59F8, 0x0980, 0x1A17, 0x65DA, 0xD731, 0x84C6, 0xD0B8,
-               0x82C3, 0x29B0, 0x5A77, 0x1E11, 0x7BCB, 0xA8FC, 0x6DD6, 0x2C3A,
-       },
-       { /* second half of table is unsigned char-reversed version of first! */
-               0xA5C6, 0x84F8, 0x99EE, 0x8DF6, 0x0DFF, 0xBDD6, 0xB1DE, 0x5491,
-               0x5060, 0x0302, 0xA9CE, 0x7D56, 0x19E7, 0x62B5, 0xE64D, 0x9AEC,
-               0x458F, 0x9D1F, 0x4089, 0x87FA, 0x15EF, 0xEBB2, 0xC98E, 0x0BFB,
-               0xEC41, 0x67B3, 0xFD5F, 0xEA45, 0xBF23, 0xF753, 0x96E4, 0x5B9B,
-               0xC275, 0x1CE1, 0xAE3D, 0x6A4C, 0x5A6C, 0x417E, 0x02F5, 0x4F83,
-               0x5C68, 0xF451, 0x34D1, 0x08F9, 0x93E2, 0x73AB, 0x5362, 0x3F2A,
-               0x0C08, 0x5295, 0x6546, 0x5E9D, 0x2830, 0xA137, 0x0F0A, 0xB52F,
-               0x090E, 0x3624, 0x9B1B, 0x3DDF, 0x26CD, 0x694E, 0xCD7F, 0x9FEA,
-               0x1B12, 0x9E1D, 0x7458, 0x2E34, 0x2D36, 0xB2DC, 0xEEB4, 0xFB5B,
-               0xF6A4, 0x4D76, 0x61B7, 0xCE7D, 0x7B52, 0x3EDD, 0x715E, 0x9713,
-               0xF5A6, 0x68B9, 0x0000, 0x2CC1, 0x6040, 0x1FE3, 0xC879, 0xEDB6,
-               0xBED4, 0x468D, 0xD967, 0x4B72, 0xDE94, 0xD498, 0xE8B0, 0x4A85,
-               0x6BBB, 0x2AC5, 0xE54F, 0x16ED, 0xC586, 0xD79A, 0x5566, 0x9411,
-               0xCF8A, 0x10E9, 0x0604, 0x81FE, 0xF0A0, 0x4478, 0xBA25, 0xE34B,
-               0xF3A2, 0xFE5D, 0xC080, 0x8A05, 0xAD3F, 0xBC21, 0x4870, 0x04F1,
-               0xDF63, 0xC177, 0x75AF, 0x6342, 0x3020, 0x1AE5, 0x0EFD, 0x6DBF,
-               0x4C81, 0x1418, 0x3526, 0x2FC3, 0xE1BE, 0xA235, 0xCC88, 0x392E,
-               0x5793, 0xF255, 0x82FC, 0x477A, 0xACC8, 0xE7BA, 0x2B32, 0x95E6,
-               0xA0C0, 0x9819, 0xD19E, 0x7FA3, 0x6644, 0x7E54, 0xAB3B, 0x830B,
-               0xCA8C, 0x29C7, 0xD36B, 0x3C28, 0x79A7, 0xE2BC, 0x1D16, 0x76AD,
-               0x3BDB, 0x5664, 0x4E74, 0x1E14, 0xDB92, 0x0A0C, 0x6C48, 0xE4B8,
-               0x5D9F, 0x6EBD, 0xEF43, 0xA6C4, 0xA839, 0xA431, 0x37D3, 0x8BF2,
-               0x32D5, 0x438B, 0x596E, 0xB7DA, 0x8C01, 0x64B1, 0xD29C, 0xE049,
-               0xB4D8, 0xFAAC, 0x07F3, 0x25CF, 0xAFCA, 0x8EF4, 0xE947, 0x1810,
-               0xD56F, 0x88F0, 0x6F4A, 0x725C, 0x2438, 0xF157, 0xC773, 0x5197,
-               0x23CB, 0x7CA1, 0x9CE8, 0x213E, 0xDD96, 0xDC61, 0x860D, 0x850F,
-               0x90E0, 0x427C, 0xC471, 0xAACC, 0xD890, 0x0506, 0x01F7, 0x121C,
-               0xA3C2, 0x5F6A, 0xF9AE, 0xD069, 0x9117, 0x5899, 0x273A, 0xB927,
-               0x38D9, 0x13EB, 0xB32B, 0x3322, 0xBBD2, 0x70A9, 0x8907, 0xA733,
-               0xB62D, 0x223C, 0x9215, 0x20C9, 0x4987, 0xFFAA, 0x7850, 0x7AA5,
-               0x8F03, 0xF859, 0x8009, 0x171A, 0xDA65, 0x31D7, 0xC684, 0xB8D0,
-               0xC382, 0xB029, 0x775A, 0x111E, 0xCB7B, 0xFCA8, 0xD66D, 0x3A2C,
-       }
-};
-
- /*
-**********************************************************************
-* Routine: Phase 1 -- generate P1K, given TA, TK, IV32
-*
-* Inputs:
-*     tk[]      = temporal key                         [128 bits]
-*     ta[]      = transmitter's MAC address            [ 48 bits]
-*     iv32      = upper 32 bits of IV                  [ 32 bits]
-* Output:
-*     p1k[]     = Phase 1 key                          [ 80 bits]
-*
-* Note:
-*     This function only needs to be called every 2**16 packets,
-*     although in theory it could be called every packet.
-*
-**********************************************************************
-*/
-static void phase1(u16 *p1k, const u8 *tk, const u8 *ta, u32 iv32)
-{
-       int  i;
-
-       /* Initialize the 80 bits of P1K[] from IV32 and TA[0..5] */
-       p1k[0]      = Lo16(iv32);
-       p1k[1]      = Hi16(iv32);
-       p1k[2]      = Mk16(ta[1], ta[0]); /* use TA[] as little-endian */
-       p1k[3]      = Mk16(ta[3], ta[2]);
-       p1k[4]      = Mk16(ta[5], ta[4]);
-
-       /* Now compute an unbalanced Feistel cipher with 80-bit block */
-       /* size on the 80-bit block P1K[], using the 128-bit key TK[] */
-       for (i = 0; i < PHASE1_LOOP_CNT; i++) {
-               /* Each add operation here is mod 2**16 */
-               p1k[0] += _S_(p1k[4] ^ TK16((i & 1) + 0));
-               p1k[1] += _S_(p1k[0] ^ TK16((i & 1) + 2));
-               p1k[2] += _S_(p1k[1] ^ TK16((i & 1) + 4));
-               p1k[3] += _S_(p1k[2] ^ TK16((i & 1) + 6));
-               p1k[4] += _S_(p1k[3] ^ TK16((i & 1) + 0));
-               p1k[4] +=  (unsigned short) i; /* avoid "slide attacks" */
-               }
-
-}
-
-/*
-**********************************************************************
-* Routine: Phase 2 -- generate RC4KEY, given TK, P1K, IV16
-*
-* Inputs:
-*     tk[]      = Temporal key                         [128 bits]
-*     p1k[]     = Phase 1 output key                   [ 80 bits]
-*     iv16      = low 16 bits of IV counter            [ 16 bits]
-* Output:
-*     rc4key[]  = the key used to encrypt the packet   [128 bits]
-*
-* Note:
-*     The value {TA, IV32, IV16} for Phase1/Phase2 must be unique
-*     across all packets using the same key TK value. Then, for a
-*     given value of TK[], this TKIP48 construction guarantees that
-*     the final RC4KEY value is unique across all packets.
-*
-* Suggested implementation optimization: if PPK[] is "overlaid"
-*     appropriately on RC4KEY[], there is no need for the final
-*     for loop below that copies the PPK[] result into RC4KEY[].
-*
-**********************************************************************
-*/
-static void phase2(u8 *rc4key, const u8 *tk, const u16 *p1k, u16 iv16)
-{
-       int  i;
-       u16 PPK[6]; /* temporary key for mixing    */
-
-       /* Note: all adds in the PPK[] equations below are mod 2**16 */
-       for (i = 0; i < 5; i++)
-               PPK[i] = p1k[i]; /* first, copy P1K to PPK */
-
-       PPK[5] = p1k[4] + iv16; /* next,  add in IV16 */
-
-       /* Bijective non-linear mixing of the 96 bits of PPK[0..5] */
-       PPK[0] += _S_(PPK[5] ^ TK16(0)); /* Mix key in each "round" */
-       PPK[1] += _S_(PPK[0] ^ TK16(1));
-       PPK[2] += _S_(PPK[1] ^ TK16(2));
-       PPK[3] += _S_(PPK[2] ^ TK16(3));
-       PPK[4] += _S_(PPK[3] ^ TK16(4));
-       PPK[5] += _S_(PPK[4] ^ TK16(5)); /* Total # S-box lookups == 6 */
-
-       /* Final sweep: bijective, "linear". Rotates kill LSB correlations */
-       PPK[0] +=  RotR1(PPK[5] ^ TK16(6));
-       PPK[1] +=  RotR1(PPK[0] ^ TK16(7)); /* Use all of TK[] in Phase2 */
-       PPK[2] +=  RotR1(PPK[1]);
-       PPK[3] +=  RotR1(PPK[2]);
-       PPK[4] +=  RotR1(PPK[3]);
-       PPK[5] +=  RotR1(PPK[4]);
-       /* Note: At this point, for a given key TK[0..15], the 96-bit output */
-       /*       value PPK[0..5] is guaranteed to be unique, as a function   */
-       /*       of the 96-bit "input" value   {TA, IV32, IV16}. That is,    */
-       /*       P1K is now a keyed permutation of {TA, IV32, IV16}.         */
-
-       /* Set RC4KEY[0..3], which includes "cleartext" portion of RC4 key   */
-       rc4key[0] = Hi8(iv16);                 /* RC4KEY[0..2] is the WEP IV */
-       rc4key[1] = (Hi8(iv16) | 0x20) & 0x7F; /* Help avoid weak (FMS) keys */
-       rc4key[2] = Lo8(iv16);
-       rc4key[3] = Lo8((PPK[5] ^ TK16(0)) >> 1);
-
-       /* Copy 96 bits of PPK[0..5] to RC4KEY[4..15]  (little-endian) */
-       for (i = 0; i < 6; i++) {
-               rc4key[4 + 2 * i] = Lo8(PPK[i]);
-               rc4key[5 + 2 * i] = Hi8(PPK[i]);
-       }
-
-}
-
-/* The hlen isn't include the IV */
-int rtw_tkip_encrypt23a(struct rtw_adapter *padapter,
-                       struct xmit_frame *pxmitframe)
-{
-       u16 pnl;
-       u32 pnh;
-       u8 rc4key[16];
-       u8 ttkey[16];
-       __le32 crc;
-       u8 hw_hdr_offset = 0;
-       struct arc4context mycontext;
-       int curfragnum, length;
-       u8 *pframe, *payload, *iv, *prwskey;
-       union pn48 dot11txpn;
-       struct sta_info *stainfo;
-       struct pkt_attrib *pattrib = &pxmitframe->attrib;
-       struct security_priv *psecuritypriv = &padapter->securitypriv;
-       struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-       int res = _SUCCESS;
-
-       if (pattrib->encrypt != WLAN_CIPHER_SUITE_TKIP)
-               return _FAIL;
-
-       if (!pxmitframe->buf_addr)
-               return _FAIL;
-
-       hw_hdr_offset = TXDESC_OFFSET;
-
-       pframe = pxmitframe->buf_addr + hw_hdr_offset;
-
-       if (pattrib->psta)
-               stainfo = pattrib->psta;
-       else {
-               DBG_8723A("%s, call rtw_get_stainfo()\n", __func__);
-               stainfo = rtw_get_stainfo23a(&padapter->stapriv,
-                                            &pattrib->ra[0]);
-       }
-
-       if (!stainfo) {
-               RT_TRACE(_module_rtl871x_security_c_, _drv_err_,
-                        "%s: stainfo == NULL!!!\n", __func__);
-               DBG_8723A("%s, psta == NUL\n", __func__);
-               return _FAIL;
-       }
-
-       RT_TRACE(_module_rtl871x_security_c_, _drv_err_,
-                "%s: stainfo!= NULL!!!\n", __func__);
-
-       if (!(stainfo->state & _FW_LINKED)) {
-               DBG_8723A("%s, psta->state(0x%x) != _FW_LINKED\n", __func__, stainfo->state);
-               return _FAIL;
-       }
-
-       if (is_multicast_ether_addr(pattrib->ra))
-               prwskey = psecuritypriv->dot118021XGrpKey[psecuritypriv->dot118021XGrpKeyid].skey;
-       else
-               prwskey = &stainfo->dot118021x_UncstKey.skey[0];
-
-       /* 4 start to encrypt each fragment */
-       for (curfragnum = 0; curfragnum < pattrib->nr_frags; curfragnum++) {
-               iv = pframe + pattrib->hdrlen;
-               payload = pframe + pattrib->iv_len + pattrib->hdrlen;
-
-               GET_TKIP_PN(iv, dot11txpn);
-
-               pnl = (u16)(dot11txpn.val);
-               pnh = (u32)(dot11txpn.val>>16);
-
-               phase1((u16 *)&ttkey[0], prwskey, &pattrib->ta[0], pnh);
-
-               phase2(&rc4key[0], prwskey, (u16 *)&ttkey[0], pnl);
-
-               if ((curfragnum + 1) == pattrib->nr_frags) { /* 4 the last fragment */
-                       length = (pattrib->last_txcmdsz -
-                                 pattrib->hdrlen -
-                                 pattrib->iv_len -
-                                 pattrib->icv_len);
-
-                       RT_TRACE(_module_rtl871x_security_c_, _drv_info_,
-                                "pattrib->iv_len =%x, pattrib->icv_len =%x\n",
-                                pattrib->iv_len,
-                                pattrib->icv_len);
-                       crc = cpu_to_le32(getcrc32(payload, length));
-
-                       arcfour_init(&mycontext, rc4key, 16);
-                       arcfour_encrypt(&mycontext, payload, payload, length);
-                       arcfour_encrypt(&mycontext, payload + length,
-                                       (char *)&crc, 4);
-
-               } else {
-                       length = (pxmitpriv->frag_len -
-                                 pattrib->hdrlen -
-                                 pattrib->iv_len -
-                                 pattrib->icv_len);
-
-                       crc = cpu_to_le32(getcrc32(payload, length));
-                       arcfour_init(&mycontext, rc4key, 16);
-                       arcfour_encrypt(&mycontext, payload, payload, length);
-                       arcfour_encrypt(&mycontext, payload + length,
-                                       (char *)&crc, 4);
-
-                       pframe += pxmitpriv->frag_len;
-                       pframe  = PTR_ALIGN(pframe, 4);
-               }
-       }
-
-       return res;
-}
-
-/* The hlen isn't include the IV */
-int rtw_tkip_decrypt23a(struct rtw_adapter *padapter,
-                       struct recv_frame *precvframe)
-{
-       u16 pnl;
-       u32 pnh;
-       u8 rc4key[16];
-       u8 ttkey[16];
-       u32 actual_crc, expected_crc;
-       struct arc4context mycontext;
-       int length;
-       u8 *pframe, *payload, *iv, *prwskey;
-       union pn48 dot11txpn;
-       struct sta_info *stainfo;
-       struct rx_pkt_attrib *prxattrib = &precvframe->attrib;
-       struct security_priv *psecuritypriv = &padapter->securitypriv;
-       struct sk_buff *skb = precvframe->pkt;
-       int res = _SUCCESS;
-
-       if (prxattrib->encrypt != WLAN_CIPHER_SUITE_TKIP)
-               return _FAIL;
-
-       pframe = skb->data;
-
-       stainfo = rtw_get_stainfo23a(&padapter->stapriv,
-                                    &prxattrib->ta[0]);
-       if (!stainfo) {
-               RT_TRACE(_module_rtl871x_security_c_, _drv_err_,
-                        "%s: stainfo == NULL!!!\n", __func__);
-               return _FAIL;
-       }
-
-       /* 4 start to decrypt recvframe */
-       if (is_multicast_ether_addr(prxattrib->ra)) {
-               if (psecuritypriv->binstallGrpkey == 0) {
-                       res = _FAIL;
-                       DBG_8723A("%s:rx bc/mc packets, but didn't install group key!!!!!!!!!!\n", __func__);
-                       goto exit;
-               }
-               prwskey = psecuritypriv->dot118021XGrpKey[prxattrib->key_index].skey;
-       } else {
-               RT_TRACE(_module_rtl871x_security_c_, _drv_err_,
-                        "%s: stainfo!= NULL!!!\n", __func__);
-               prwskey = &stainfo->dot118021x_UncstKey.skey[0];
-       }
-
-       iv = pframe + prxattrib->hdrlen;
-       payload = pframe + prxattrib->iv_len + prxattrib->hdrlen;
-       length = skb->len - prxattrib->hdrlen - prxattrib->iv_len;
-
-       GET_TKIP_PN(iv, dot11txpn);
-
-       pnl = (u16)(dot11txpn.val);
-       pnh = (u32)(dot11txpn.val>>16);
-
-       phase1((u16 *)&ttkey[0], prwskey, &prxattrib->ta[0], pnh);
-       phase2(&rc4key[0], prwskey, (unsigned short *)&ttkey[0], pnl);
-
-       /* 4 decrypt payload include icv */
-       arcfour_init(&mycontext, rc4key, 16);
-       arcfour_encrypt(&mycontext, payload, payload, length);
-
-       actual_crc = getcrc32(payload, length - 4);
-       expected_crc = get_unaligned_le32(&payload[length - 4]);
-
-       if (actual_crc != expected_crc) {
-               RT_TRACE(_module_rtl871x_security_c_, _drv_err_,
-                        "%s:icv CRC mismatch: "
-                        "actual: %08x, expected: %08x\n",
-                        __func__, actual_crc, expected_crc);
-               res = _FAIL;
-       }
-
-exit:
-       return res;
-}
-
-/* 3                   ===== AES related ===== */
-
-#define MAX_MSG_SIZE   2048
-/*****************************/
-/******** SBOX Table *********/
-/*****************************/
-
-static  u8 sbox_table[256] = {
-       0x63, 0x7c, 0x77, 0x7b, 0xf2, 0x6b, 0x6f, 0xc5,
-       0x30, 0x01, 0x67, 0x2b, 0xfe, 0xd7, 0xab, 0x76,
-       0xca, 0x82, 0xc9, 0x7d, 0xfa, 0x59, 0x47, 0xf0,
-       0xad, 0xd4, 0xa2, 0xaf, 0x9c, 0xa4, 0x72, 0xc0,
-       0xb7, 0xfd, 0x93, 0x26, 0x36, 0x3f, 0xf7, 0xcc,
-       0x34, 0xa5, 0xe5, 0xf1, 0x71, 0xd8, 0x31, 0x15,
-       0x04, 0xc7, 0x23, 0xc3, 0x18, 0x96, 0x05, 0x9a,
-       0x07, 0x12, 0x80, 0xe2, 0xeb, 0x27, 0xb2, 0x75,
-       0x09, 0x83, 0x2c, 0x1a, 0x1b, 0x6e, 0x5a, 0xa0,
-       0x52, 0x3b, 0xd6, 0xb3, 0x29, 0xe3, 0x2f, 0x84,
-       0x53, 0xd1, 0x00, 0xed, 0x20, 0xfc, 0xb1, 0x5b,
-       0x6a, 0xcb, 0xbe, 0x39, 0x4a, 0x4c, 0x58, 0xcf,
-       0xd0, 0xef, 0xaa, 0xfb, 0x43, 0x4d, 0x33, 0x85,
-       0x45, 0xf9, 0x02, 0x7f, 0x50, 0x3c, 0x9f, 0xa8,
-       0x51, 0xa3, 0x40, 0x8f, 0x92, 0x9d, 0x38, 0xf5,
-       0xbc, 0xb6, 0xda, 0x21, 0x10, 0xff, 0xf3, 0xd2,
-       0xcd, 0x0c, 0x13, 0xec, 0x5f, 0x97, 0x44, 0x17,
-       0xc4, 0xa7, 0x7e, 0x3d, 0x64, 0x5d, 0x19, 0x73,
-       0x60, 0x81, 0x4f, 0xdc, 0x22, 0x2a, 0x90, 0x88,
-       0x46, 0xee, 0xb8, 0x14, 0xde, 0x5e, 0x0b, 0xdb,
-       0xe0, 0x32, 0x3a, 0x0a, 0x49, 0x06, 0x24, 0x5c,
-       0xc2, 0xd3, 0xac, 0x62, 0x91, 0x95, 0xe4, 0x79,
-       0xe7, 0xc8, 0x37, 0x6d, 0x8d, 0xd5, 0x4e, 0xa9,
-       0x6c, 0x56, 0xf4, 0xea, 0x65, 0x7a, 0xae, 0x08,
-       0xba, 0x78, 0x25, 0x2e, 0x1c, 0xa6, 0xb4, 0xc6,
-       0xe8, 0xdd, 0x74, 0x1f, 0x4b, 0xbd, 0x8b, 0x8a,
-       0x70, 0x3e, 0xb5, 0x66, 0x48, 0x03, 0xf6, 0x0e,
-       0x61, 0x35, 0x57, 0xb9, 0x86, 0xc1, 0x1d, 0x9e,
-       0xe1, 0xf8, 0x98, 0x11, 0x69, 0xd9, 0x8e, 0x94,
-       0x9b, 0x1e, 0x87, 0xe9, 0xce, 0x55, 0x28, 0xdf,
-       0x8c, 0xa1, 0x89, 0x0d, 0xbf, 0xe6, 0x42, 0x68,
-       0x41, 0x99, 0x2d, 0x0f, 0xb0, 0x54, 0xbb, 0x16
-};
-
-/*****************************/
-/**** Function Prototypes ****/
-/*****************************/
-
-static void construct_mic_header2(u8 *mic_header2, u8 *mpdu, int a4_exists,
-                                 int qc_exists);
-
-static void xor_128(u8 *a, u8 *b, u8 *out)
-{
-       int i;
-
-       for (i = 0; i < 16; i++)
-               out[i] = a[i] ^ b[i];
-}
-
-static void xor_32(u8 *a, u8 *b, u8 *out)
-{
-       int i;
-
-       for (i = 0; i < 4; i++)
-               out[i] = a[i] ^ b[i];
-}
-
-static u8 sbox(u8 a)
-{
-       return sbox_table[(int)a];
-}
-
-static void next_key(u8 *key, int round)
-{
-       u8 rcon;
-       u8 sbox_key[4];
-       u8 rcon_table[12] = {
-               0x01, 0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80,
-               0x1b, 0x36, 0x36, 0x36
-       };
-
-       sbox_key[0] = sbox(key[13]);
-       sbox_key[1] = sbox(key[14]);
-       sbox_key[2] = sbox(key[15]);
-       sbox_key[3] = sbox(key[12]);
-
-       rcon = rcon_table[round];
-
-       xor_32(&key[0], sbox_key, &key[0]);
-       key[0] = key[0] ^ rcon;
-
-       xor_32(&key[4], &key[0], &key[4]);
-       xor_32(&key[8], &key[4], &key[8]);
-       xor_32(&key[12], &key[8], &key[12]);
-
-}
-
-static void byte_sub(u8 *in, u8 *out)
-{
-       int i;
-
-       for (i = 0; i < 16; i++)
-               out[i] = sbox(in[i]);
-}
-
-static void shift_row(u8 *in, u8 *out)
-{
-
-       out[0] =  in[0];
-       out[1] =  in[5];
-       out[2] =  in[10];
-       out[3] =  in[15];
-       out[4] =  in[4];
-       out[5] =  in[9];
-       out[6] =  in[14];
-       out[7] =  in[3];
-       out[8] =  in[8];
-       out[9] =  in[13];
-       out[10] = in[2];
-       out[11] = in[7];
-       out[12] = in[12];
-       out[13] = in[1];
-       out[14] = in[6];
-       out[15] = in[11];
-
-}
-
-static void mix_column(u8 *in, u8 *out)
-{
-       int i;
-       u8 add1b[4];
-       u8 add1bf7[4];
-       u8 rotl[4];
-       u8 swap_halfs[4];
-       u8 andf7[4];
-       u8 rotr[4];
-       u8 temp[4];
-       u8 tempb[4];
-
-       for (i = 0; i < 4; i++) {
-               if ((in[i] & 0x80) == 0x80)
-                       add1b[i] = 0x1b;
-               else
-                       add1b[i] = 0x00;
-       }
-
-       swap_halfs[0] = in[2]; /* Swap halfs */
-       swap_halfs[1] = in[3];
-       swap_halfs[2] = in[0];
-       swap_halfs[3] = in[1];
-
-       rotl[0] = in[3]; /* Rotate left 8 bits */
-       rotl[1] = in[0];
-       rotl[2] = in[1];
-       rotl[3] = in[2];
-
-       andf7[0] = in[0] & 0x7f;
-       andf7[1] = in[1] & 0x7f;
-       andf7[2] = in[2] & 0x7f;
-       andf7[3] = in[3] & 0x7f;
-
-       for (i = 3; i > 0; i--) { /* logical shift left 1 bit */
-               andf7[i] = andf7[i] << 1;
-               if ((andf7[i - 1] & 0x80) == 0x80)
-                       andf7[i] = (andf7[i] | 0x01);
-       }
-       andf7[0] = andf7[0] << 1;
-       andf7[0] = andf7[0] & 0xfe;
-
-       xor_32(add1b, andf7, add1bf7);
-
-       xor_32(in, add1bf7, rotr);
-
-       temp[0] = rotr[0]; /* Rotate right 8 bits */
-       rotr[0] = rotr[1];
-       rotr[1] = rotr[2];
-       rotr[2] = rotr[3];
-       rotr[3] = temp[0];
-
-       xor_32(add1bf7, rotr, temp);
-       xor_32(swap_halfs, rotl, tempb);
-       xor_32(temp, tempb, out);
-
-}
-
-static void aes128k128d(u8 *key, u8 *data, u8 *ciphertext)
-{
-       int round;
-       int i;
-       u8 intermediatea[16];
-       u8 intermediateb[16];
-       u8 round_key[16];
-
-       for (i = 0; i < 16; i++)
-               round_key[i] = key[i];
-
-       for (round = 0; round < 11; round++) {
-               if (round == 0) {
-                       xor_128(round_key, data, ciphertext);
-                       next_key(round_key, round);
-               } else if (round == 10) {
-                       byte_sub(ciphertext, intermediatea);
-                       shift_row(intermediatea, intermediateb);
-                       xor_128(intermediateb, round_key, ciphertext);
-               } else { /* 1 - 9 */
-                       byte_sub(ciphertext, intermediatea);
-                       shift_row(intermediatea, intermediateb);
-                       mix_column(&intermediateb[0], &intermediatea[0]);
-                       mix_column(&intermediateb[4], &intermediatea[4]);
-                       mix_column(&intermediateb[8], &intermediatea[8]);
-                       mix_column(&intermediateb[12], &intermediatea[12]);
-                       xor_128(intermediatea, round_key, ciphertext);
-                       next_key(round_key, round);
-               }
-       }
-
-}
-
-/************************************************/
-/* construct_mic_iv()                           */
-/* Builds the MIC IV from header fields and PN  */
-/************************************************/
-static void construct_mic_iv(u8 *mic_iv, int qc_exists, int a4_exists, u8 *mpdu,
-                            uint payload_length, u8 *pn_vector)
-{
-       int i;
-
-       mic_iv[0] = 0x59;
-       if (qc_exists && a4_exists)
-               mic_iv[1] = mpdu[30] & 0x0f; /* QoS_TC        */
-       if (qc_exists && !a4_exists)
-               mic_iv[1] = mpdu[24] & 0x0f; /* mute bits 7-4 */
-       if (!qc_exists)
-               mic_iv[1] = 0x00;
-       for (i = 2; i < 8; i++)
-               mic_iv[i] = mpdu[i + 8]; /* mic_iv[2:7] = A2[0:5] = mpdu[10:15] */
-       for (i = 8; i < 14; i++)
-               mic_iv[i] = pn_vector[13 - i]; /* mic_iv[8:13] = PN[5:0] */
-       mic_iv[14] = (unsigned char)(payload_length / 256);
-       mic_iv[15] = (unsigned char)(payload_length % 256);
-}
-
-/************************************************/
-/* construct_mic_header1()                      */
-/* Builds the first MIC header block from       */
-/* header fields.                               */
-/************************************************/
-static void construct_mic_header1(u8 *mic_header1, int header_length, u8 *mpdu)
-{
-       mic_header1[0] = (u8)((header_length - 2) / 256);
-       mic_header1[1] = (u8)((header_length - 2) % 256);
-       mic_header1[2] = mpdu[0] & 0xcf; /* Mute CF poll & CF ack bits */
-       mic_header1[3] = mpdu[1] & 0xc7; /* Mute retry, more data and pwr mgt bits */
-       mic_header1[4] = mpdu[4]; /* A1 */
-       mic_header1[5] = mpdu[5];
-       mic_header1[6] = mpdu[6];
-       mic_header1[7] = mpdu[7];
-       mic_header1[8] = mpdu[8];
-       mic_header1[9] = mpdu[9];
-       mic_header1[10] = mpdu[10]; /* A2 */
-       mic_header1[11] = mpdu[11];
-       mic_header1[12] = mpdu[12];
-       mic_header1[13] = mpdu[13];
-       mic_header1[14] = mpdu[14];
-       mic_header1[15] = mpdu[15];
-
-}
-
-/************************************************/
-/* construct_mic_header2()                      */
-/* Builds the last MIC header block from        */
-/* header fields.                               */
-/************************************************/
-static void construct_mic_header2(u8 *mic_header2, u8 *mpdu, int a4_exists,
-                                 int qc_exists)
-{
-       int i;
-
-       for (i = 0; i < 16; i++)
-               mic_header2[i] = 0x00;
-
-       mic_header2[0] = mpdu[16]; /* A3 */
-       mic_header2[1] = mpdu[17];
-       mic_header2[2] = mpdu[18];
-       mic_header2[3] = mpdu[19];
-       mic_header2[4] = mpdu[20];
-       mic_header2[5] = mpdu[21];
-
-       mic_header2[6] = 0x00;
-       mic_header2[7] = 0x00; /* mpdu[23]; */
-
-       if (!qc_exists && a4_exists) {
-               for (i = 0; i < 6; i++)
-                       mic_header2[8+i] = mpdu[24+i]; /* A4 */
-       }
-
-       if (qc_exists && !a4_exists) {
-               mic_header2[8] = mpdu[24] & 0x0f; /* mute bits 15 - 4 */
-               mic_header2[9] = mpdu[25] & 0x00;
-       }
-
-       if (qc_exists && a4_exists) {
-               for (i = 0; i < 6; i++)
-                       mic_header2[8+i] = mpdu[24+i]; /* A4 */
-
-               mic_header2[14] = mpdu[30] & 0x0f;
-               mic_header2[15] = mpdu[31] & 0x00;
-       }
-
-}
-
-/************************************************/
-/* construct_mic_header2()                      */
-/* Builds the last MIC header block from        */
-/* header fields.                               */
-/************************************************/
-static void construct_ctr_preload(u8 *ctr_preload, int a4_exists, int qc_exists,
-                                 u8 *mpdu, u8 *pn_vector, int c)
-{
-       int i = 0;
-
-       for (i = 0; i < 16; i++)
-               ctr_preload[i] = 0x00;
-
-       i = 0;
-
-       ctr_preload[0] = 0x01; /* flag */
-       if (qc_exists && a4_exists)
-               ctr_preload[1] = mpdu[30] & 0x0f; /* QoC_Control */
-       if (qc_exists && !a4_exists)
-               ctr_preload[1] = mpdu[24] & 0x0f;
-
-       for (i = 2; i < 8; i++)
-               ctr_preload[i] = mpdu[i + 8]; /* ctr_preload[2:7] = A2[0:5] = mpdu[10:15] */
-       for (i = 8; i < 14; i++)
-               ctr_preload[i] = pn_vector[13 - i]; /* ctr_preload[8:13] = PN[5:0] */
-       ctr_preload[14] =  (unsigned char) (c / 256); /* Ctr */
-       ctr_preload[15] =  (unsigned char) (c % 256);
-
-}
-
-/************************************/
-/* bitwise_xor()                    */
-/* A 128 bit, bitwise exclusive or  */
-/************************************/
-static void bitwise_xor(u8 *ina, u8 *inb, u8 *out)
-{
-       int i;
-
-       for (i = 0; i < 16; i++)
-               out[i] = ina[i] ^ inb[i];
-}
-
-static int aes_cipher(u8 *key, uint hdrlen, u8 *pframe, uint plen)
-{
-       uint qc_exists, a4_exists, i, j, payload_remainder,
-            num_blocks, payload_index;
-       u8 pn_vector[6];
-       u8 mic_iv[16];
-       u8 mic_header1[16];
-       u8 mic_header2[16];
-       u8 ctr_preload[16];
-       /* Intermediate Buffers */
-       u8 chain_buffer[16];
-       u8 aes_out[16];
-       u8 padded_buffer[16];
-       u8 mic[8];
-       struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)pframe;
-       u16 frsubtype = le16_to_cpu(hdr->frame_control) & IEEE80211_FCTL_STYPE;
-
-       memset((void *)mic_iv, 0, 16);
-       memset((void *)mic_header1, 0, 16);
-       memset((void *)mic_header2, 0, 16);
-       memset((void *)ctr_preload, 0, 16);
-       memset((void *)chain_buffer, 0, 16);
-       memset((void *)aes_out, 0, 16);
-       memset((void *)padded_buffer, 0, 16);
-
-       if ((hdrlen == sizeof(struct ieee80211_hdr_3addr) ||
-           (hdrlen == sizeof(struct ieee80211_qos_hdr))))
-               a4_exists = 0;
-       else
-               a4_exists = 1;
-
-       if (ieee80211_is_data(hdr->frame_control)) {
-               if ((frsubtype == IEEE80211_STYPE_DATA_CFACK) ||
-                   (frsubtype == IEEE80211_STYPE_DATA_CFPOLL) ||
-                   (frsubtype == IEEE80211_STYPE_DATA_CFACKPOLL)) {
-                       qc_exists = 1;
-                       if (hdrlen != sizeof(struct ieee80211_qos_hdr))
-                               hdrlen += 2;
-               } else if ((frsubtype == IEEE80211_STYPE_QOS_DATA) ||
-                          (frsubtype == IEEE80211_STYPE_QOS_DATA_CFACK) ||
-                          (frsubtype == IEEE80211_STYPE_QOS_DATA_CFPOLL) ||
-                          (frsubtype == IEEE80211_STYPE_QOS_DATA_CFACKPOLL)) {
-                       if (hdrlen != sizeof(struct ieee80211_qos_hdr))
-                               hdrlen += 2;
-                       qc_exists = 1;
-               } else {
-                       qc_exists = 0;
-               }
-       } else {
-               qc_exists = 0;
-       }
-       pn_vector[0] = pframe[hdrlen];
-       pn_vector[1] = pframe[hdrlen + 1];
-       pn_vector[2] = pframe[hdrlen + 4];
-       pn_vector[3] = pframe[hdrlen + 5];
-       pn_vector[4] = pframe[hdrlen + 6];
-       pn_vector[5] = pframe[hdrlen + 7];
-
-       construct_mic_iv(mic_iv, qc_exists, a4_exists, pframe, plen, pn_vector);
-
-       construct_mic_header1(mic_header1, hdrlen, pframe);
-       construct_mic_header2(mic_header2, pframe, a4_exists, qc_exists);
-
-       payload_remainder = plen % 16;
-       num_blocks = plen / 16;
-
-       /* Find start of payload */
-       payload_index = hdrlen + 8;
-
-       /* Calculate MIC */
-       aes128k128d(key, mic_iv, aes_out);
-       bitwise_xor(aes_out, mic_header1, chain_buffer);
-       aes128k128d(key, chain_buffer, aes_out);
-       bitwise_xor(aes_out, mic_header2, chain_buffer);
-       aes128k128d(key, chain_buffer, aes_out);
-
-       for (i = 0; i < num_blocks; i++) {
-               bitwise_xor(aes_out, &pframe[payload_index], chain_buffer);
-
-               payload_index += 16;
-               aes128k128d(key, chain_buffer, aes_out);
-       }
-
-       /* Add on the final payload block if it needs padding */
-       if (payload_remainder > 0) {
-               for (j = 0; j < 16; j++)
-                       padded_buffer[j] = 0x00;
-               for (j = 0; j < payload_remainder; j++)
-                       padded_buffer[j] = pframe[payload_index++];
-               bitwise_xor(aes_out, padded_buffer, chain_buffer);
-               aes128k128d(key, chain_buffer, aes_out);
-       }
-
-       for (j = 0; j < 8; j++)
-               mic[j] = aes_out[j];
-
-       /* Insert MIC into payload */
-       for (j = 0; j < 8; j++)
-               pframe[payload_index + j] = mic[j];
-
-       payload_index = hdrlen + 8;
-       for (i = 0; i < num_blocks; i++) {
-               construct_ctr_preload(ctr_preload, a4_exists, qc_exists,
-                                     pframe, pn_vector, i + 1);
-               aes128k128d(key, ctr_preload, aes_out);
-               bitwise_xor(aes_out, &pframe[payload_index], chain_buffer);
-               for (j = 0; j < 16; j++)
-                       pframe[payload_index++] = chain_buffer[j];
-       }
-
-       if (payload_remainder > 0) {
-               /* If there is a short final block, then pad it,
-                * encrypt it and copy the unpadded part back
-                */
-               construct_ctr_preload(ctr_preload, a4_exists, qc_exists, pframe,
-                                     pn_vector, num_blocks + 1);
-
-               for (j = 0; j < 16; j++)
-                       padded_buffer[j] = 0x00;
-               for (j = 0; j < payload_remainder; j++)
-                       padded_buffer[j] = pframe[payload_index + j];
-               aes128k128d(key, ctr_preload, aes_out);
-               bitwise_xor(aes_out, padded_buffer, chain_buffer);
-               for (j = 0; j < payload_remainder; j++)
-                       pframe[payload_index++] = chain_buffer[j];
-       }
-
-       /* Encrypt the MIC */
-       construct_ctr_preload(ctr_preload, a4_exists, qc_exists, pframe,
-                             pn_vector, 0);
-
-       for (j = 0; j < 16; j++)
-               padded_buffer[j] = 0x00;
-       for (j = 0; j < 8; j++)
-               padded_buffer[j] = pframe[j + hdrlen + 8 + plen];
-
-       aes128k128d(key, ctr_preload, aes_out);
-       bitwise_xor(aes_out, padded_buffer, chain_buffer);
-       for (j = 0; j < 8; j++)
-               pframe[payload_index++] = chain_buffer[j];
-
-       return _SUCCESS;
-}
-
-int rtw_aes_encrypt23a(struct rtw_adapter *padapter,
-                      struct xmit_frame *pxmitframe)
-{      /* exclude ICV */
-       /* Intermediate Buffers */
-       int curfragnum, length;
-       u8 *pframe, *prwskey;
-       u8 hw_hdr_offset = 0;
-       struct sta_info *stainfo;
-       struct pkt_attrib *pattrib = &pxmitframe->attrib;
-       struct security_priv *psecuritypriv = &padapter->securitypriv;
-       struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-       int res = _SUCCESS;
-
-       if (!pxmitframe->buf_addr)
-               return _FAIL;
-
-       hw_hdr_offset = TXDESC_OFFSET;
-
-       pframe = pxmitframe->buf_addr + hw_hdr_offset;
-
-       /* 4 start to encrypt each fragment */
-       if (pattrib->encrypt != WLAN_CIPHER_SUITE_CCMP)
-               return _FAIL;
-
-       if (pattrib->psta) {
-               stainfo = pattrib->psta;
-       } else {
-               DBG_8723A("%s, call rtw_get_stainfo23a()\n", __func__);
-               stainfo = rtw_get_stainfo23a(&padapter->stapriv, &pattrib->ra[0]);
-       }
-
-       if (!stainfo) {
-               RT_TRACE(_module_rtl871x_security_c_, _drv_err_,
-                        "%s: stainfo == NULL!!!\n", __func__);
-               DBG_8723A("%s, psta == NUL\n", __func__);
-               res = _FAIL;
-               goto out;
-       }
-       if (!(stainfo->state & _FW_LINKED)) {
-               DBG_8723A("%s, psta->state(0x%x) != _FW_LINKED\n",
-                         __func__, stainfo->state);
-               return _FAIL;
-       }
-       RT_TRACE(_module_rtl871x_security_c_, _drv_err_,
-                "%s: stainfo!= NULL!!!\n", __func__);
-
-       if (is_multicast_ether_addr(pattrib->ra))
-               prwskey = psecuritypriv->dot118021XGrpKey[psecuritypriv->dot118021XGrpKeyid].skey;
-       else
-               prwskey = &stainfo->dot118021x_UncstKey.skey[0];
-
-       for (curfragnum = 0; curfragnum < pattrib->nr_frags; curfragnum++) {
-               /* 4 the last fragment */
-               if ((curfragnum + 1) == pattrib->nr_frags) {
-                       length = pattrib->last_txcmdsz -
-                               pattrib->hdrlen-pattrib->iv_len -
-                               pattrib->icv_len;
-
-                       aes_cipher(prwskey, pattrib->hdrlen, pframe, length);
-               } else {
-                       length = pxmitpriv->frag_len-pattrib->hdrlen -
-                               pattrib->iv_len - pattrib->icv_len;
-
-                       aes_cipher(prwskey, pattrib->hdrlen, pframe, length);
-                       pframe += pxmitpriv->frag_len;
-                       pframe = PTR_ALIGN(pframe, 4);
-               }
-       }
-out:
-       return res;
-}
-
-static int aes_decipher(u8 *key, uint hdrlen, u8 *pframe, uint plen)
-{
-       static u8 message[MAX_MSG_SIZE];
-       uint qc_exists, a4_exists, i, j, payload_remainder,
-            num_blocks, payload_index;
-       int res = _SUCCESS;
-       u8 pn_vector[6];
-       u8 mic_iv[16];
-       u8 mic_header1[16];
-       u8 mic_header2[16];
-       u8 ctr_preload[16];
-       /* Intermediate Buffers */
-       u8 chain_buffer[16];
-       u8 aes_out[16];
-       u8 padded_buffer[16];
-       u8 mic[8];
-       struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)pframe;
-       u16 frsubtype = le16_to_cpu(hdr->frame_control) & IEEE80211_FCTL_STYPE;
-
-       memset((void *)mic_iv, 0, 16);
-       memset((void *)mic_header1, 0, 16);
-       memset((void *)mic_header2, 0, 16);
-       memset((void *)ctr_preload, 0, 16);
-       memset((void *)chain_buffer, 0, 16);
-       memset((void *)aes_out, 0, 16);
-       memset((void *)padded_buffer, 0, 16);
-
-       /* start to decrypt the payload */
-
-       num_blocks = (plen - 8) / 16; /* plen including llc, payload_length and mic) */
-
-       payload_remainder = (plen - 8) % 16;
-
-       pn_vector[0]  = pframe[hdrlen];
-       pn_vector[1]  = pframe[hdrlen + 1];
-       pn_vector[2]  = pframe[hdrlen + 4];
-       pn_vector[3]  = pframe[hdrlen + 5];
-       pn_vector[4]  = pframe[hdrlen + 6];
-       pn_vector[5]  = pframe[hdrlen + 7];
-
-       if ((hdrlen == sizeof(struct ieee80211_hdr_3addr) ||
-           (hdrlen == sizeof(struct ieee80211_qos_hdr))))
-               a4_exists = 0;
-       else
-               a4_exists = 1;
-
-       if (ieee80211_is_data(hdr->frame_control)) {
-               if ((frsubtype == IEEE80211_STYPE_DATA_CFACK) ||
-                   (frsubtype == IEEE80211_STYPE_DATA_CFPOLL) ||
-                   (frsubtype == IEEE80211_STYPE_DATA_CFACKPOLL)) {
-                       qc_exists = 1;
-                       if (hdrlen != sizeof(struct ieee80211_hdr_3addr))
-                               hdrlen += 2;
-               } else if ((frsubtype == IEEE80211_STYPE_QOS_DATA) ||
-                          (frsubtype == IEEE80211_STYPE_QOS_DATA_CFACK) ||
-                          (frsubtype == IEEE80211_STYPE_QOS_DATA_CFPOLL) ||
-                          (frsubtype == IEEE80211_STYPE_QOS_DATA_CFACKPOLL)) {
-                       if (hdrlen != sizeof(struct ieee80211_hdr_3addr))
-                               hdrlen += 2;
-                       qc_exists = 1;
-               } else {
-                       qc_exists = 0;
-               }
-       } else {
-               qc_exists = 0;
-       }
-
-       /* now, decrypt pframe with hdrlen offset and plen long */
-
-       payload_index = hdrlen + 8; /*  8 is for extiv */
-
-       for (i = 0; i < num_blocks; i++) {
-               construct_ctr_preload(ctr_preload, a4_exists, qc_exists,
-                                     pframe, pn_vector, i + 1);
-
-               aes128k128d(key, ctr_preload, aes_out);
-               bitwise_xor(aes_out, &pframe[payload_index], chain_buffer);
-
-               for (j = 0; j < 16; j++)
-                       pframe[payload_index++] = chain_buffer[j];
-       }
-
-       if (payload_remainder > 0) {
-               /* If there is a short final block, then pad it,
-                * encrypt it and copy the unpadded part back
-                */
-               construct_ctr_preload(ctr_preload, a4_exists, qc_exists, pframe,
-                                     pn_vector, num_blocks + 1);
-
-               for (j = 0; j < 16; j++)
-                       padded_buffer[j] = 0x00;
-               for (j = 0; j < payload_remainder; j++)
-                       padded_buffer[j] = pframe[payload_index + j];
-               aes128k128d(key, ctr_preload, aes_out);
-               bitwise_xor(aes_out, padded_buffer, chain_buffer);
-               for (j = 0; j < payload_remainder; j++)
-                       pframe[payload_index++] = chain_buffer[j];
-       }
-
-       /* start to calculate the mic */
-       if ((hdrlen + plen + 8) <= MAX_MSG_SIZE)
-               memcpy(message, pframe, (hdrlen + plen + 8)); /* 8 is for ext iv len */
-
-       pn_vector[0] = pframe[hdrlen];
-       pn_vector[1] = pframe[hdrlen + 1];
-       pn_vector[2] = pframe[hdrlen + 4];
-       pn_vector[3] = pframe[hdrlen + 5];
-       pn_vector[4] = pframe[hdrlen + 6];
-       pn_vector[5] = pframe[hdrlen + 7];
-
-       construct_mic_iv(mic_iv, qc_exists, a4_exists, message,
-                        plen - 8, pn_vector);
-
-       construct_mic_header1(mic_header1, hdrlen, message);
-       construct_mic_header2(mic_header2, message, a4_exists, qc_exists);
-
-       payload_remainder = (plen - 8) % 16;
-       num_blocks = (plen - 8) / 16;
-
-       /* Find start of payload */
-       payload_index = hdrlen + 8;
-
-       /* Calculate MIC */
-       aes128k128d(key, mic_iv, aes_out);
-       bitwise_xor(aes_out, mic_header1, chain_buffer);
-       aes128k128d(key, chain_buffer, aes_out);
-       bitwise_xor(aes_out, mic_header2, chain_buffer);
-       aes128k128d(key, chain_buffer, aes_out);
-
-       for (i = 0; i < num_blocks; i++) {
-               bitwise_xor(aes_out, &message[payload_index], chain_buffer);
-
-               payload_index += 16;
-               aes128k128d(key, chain_buffer, aes_out);
-       }
-
-       /* Add on the final payload block if it needs padding */
-       if (payload_remainder > 0) {
-               for (j = 0; j < 16; j++)
-                       padded_buffer[j] = 0x00;
-               for (j = 0; j < payload_remainder; j++)
-                       padded_buffer[j] = message[payload_index++];
-               bitwise_xor(aes_out, padded_buffer, chain_buffer);
-               aes128k128d(key, chain_buffer, aes_out);
-       }
-
-       for (j = 0 ; j < 8; j++)
-               mic[j] = aes_out[j];
-
-       /* Insert MIC into payload */
-       for (j = 0; j < 8; j++)
-               message[payload_index + j] = mic[j];
-
-       payload_index = hdrlen + 8;
-       for (i = 0; i < num_blocks; i++) {
-               construct_ctr_preload(ctr_preload, a4_exists, qc_exists,
-                                     message, pn_vector, i + 1);
-               aes128k128d(key, ctr_preload, aes_out);
-               bitwise_xor(aes_out, &message[payload_index], chain_buffer);
-               for (j = 0; j < 16; j++)
-                       message[payload_index++] = chain_buffer[j];
-       }
-
-       if (payload_remainder > 0) {
-               /* If there is a short final block, then pad it,
-                * encrypt it and copy the unpadded part back
-                */
-               construct_ctr_preload(ctr_preload, a4_exists, qc_exists,
-                                     message, pn_vector, num_blocks + 1);
-
-               for (j = 0; j < 16; j++)
-                       padded_buffer[j] = 0x00;
-               for (j = 0; j < payload_remainder; j++)
-                       padded_buffer[j] = message[payload_index + j];
-               aes128k128d(key, ctr_preload, aes_out);
-               bitwise_xor(aes_out, padded_buffer, chain_buffer);
-               for (j = 0; j < payload_remainder; j++)
-                       message[payload_index++] = chain_buffer[j];
-       }
-
-       /* Encrypt the MIC */
-       construct_ctr_preload(ctr_preload, a4_exists, qc_exists, message,
-                             pn_vector, 0);
-
-       for (j = 0; j < 16; j++)
-               padded_buffer[j] = 0x00;
-       for (j = 0; j < 8; j++)
-               padded_buffer[j] = message[j + hdrlen + 8 + plen - 8];
-
-       aes128k128d(key, ctr_preload, aes_out);
-       bitwise_xor(aes_out, padded_buffer, chain_buffer);
-       for (j = 0; j < 8; j++)
-               message[payload_index++] = chain_buffer[j];
-
-       /* compare the mic */
-       for (i = 0; i < 8; i++) {
-               if (pframe[hdrlen + 8 + plen - 8 + i] != message[hdrlen + 8 + plen - 8 + i]) {
-                       RT_TRACE(_module_rtl871x_security_c_, _drv_err_,
-                                "%s:mic check error mic[%d]: pframe(%x) != message(%x)\n",
-                                __func__, i,
-                                pframe[hdrlen + 8 + plen - 8 + i],
-                                message[hdrlen + 8 + plen - 8 + i]);
-                       DBG_8723A("%s:mic check error mic[%d]: pframe(%x) != message(%x)\n",
-                                 __func__, i,
-                                 pframe[hdrlen + 8 + plen - 8 + i],
-                                 message[hdrlen + 8 + plen - 8 + i]);
-                       res = _FAIL;
-               }
-       }
-       return res;
-}
-
-int rtw_aes_decrypt23a(struct rtw_adapter *padapter,
-                      struct recv_frame *precvframe)
-{      /*  exclude ICV */
-       struct sta_info *stainfo;
-       struct rx_pkt_attrib *prxattrib = &precvframe->attrib;
-       struct security_priv *psecuritypriv = &padapter->securitypriv;
-       struct sk_buff *skb = precvframe->pkt;
-       int length;
-       u8 *pframe, *prwskey;
-       int res = _SUCCESS;
-
-       pframe = skb->data;
-       /* 4 start to encrypt each fragment */
-       if (prxattrib->encrypt != WLAN_CIPHER_SUITE_CCMP)
-               return _FAIL;
-
-       stainfo = rtw_get_stainfo23a(&padapter->stapriv, &prxattrib->ta[0]);
-       if (!stainfo) {
-               RT_TRACE(_module_rtl871x_security_c_, _drv_err_,
-                        "%s: stainfo == NULL!!!\n", __func__);
-               res = _FAIL;
-               goto exit;
-       }
-
-       RT_TRACE(_module_rtl871x_security_c_, _drv_err_,
-                "%s: stainfo!= NULL!!!\n", __func__);
-
-       if (is_multicast_ether_addr(prxattrib->ra)) {
-               /* in concurrent we should use sw decrypt in
-                * group key, so we remove this message
-                */
-               if (!psecuritypriv->binstallGrpkey) {
-                       res = _FAIL;
-                       DBG_8723A("%s:rx bc/mc packets, but didn't install "
-                                 "group key!!!!!!!!!!\n", __func__);
-                       goto exit;
-               }
-               prwskey = psecuritypriv->dot118021XGrpKey[prxattrib->key_index].skey;
-               if (psecuritypriv->dot118021XGrpKeyid != prxattrib->key_index) {
-                       DBG_8723A("not match packet_index =%d, install_index ="
-                                 "%d\n", prxattrib->key_index,
-                                 psecuritypriv->dot118021XGrpKeyid);
-                       res = _FAIL;
-                       goto exit;
-               }
-       } else {
-               prwskey = &stainfo->dot118021x_UncstKey.skey[0];
-       }
-
-       length = skb->len - prxattrib->hdrlen - prxattrib->iv_len;
-
-       res = aes_decipher(prwskey, prxattrib->hdrlen, pframe, length);
-exit:
-       return res;
-}
-
-void rtw_use_tkipkey_handler23a(void *function_context)
-{
-       struct rtw_adapter *padapter = function_context;
-
-       RT_TRACE(_module_rtl871x_security_c_, _drv_err_,
-                "^^^%s ^^^\n", __func__);
-       padapter->securitypriv.busetkipkey = 1;
-       RT_TRACE(_module_rtl871x_security_c_, _drv_err_,
-                "^^^%s padapter->securitypriv.busetkipkey =%d^^^\n",
-                __func__, padapter->securitypriv.busetkipkey);
-}
diff --git a/drivers/staging/rtl8723au/core/rtw_sreset.c b/drivers/staging/rtl8723au/core/rtw_sreset.c
deleted file mode 100644 (file)
index 29a29d9..0000000
+++ /dev/null
@@ -1,214 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-
-#include <rtw_sreset.h>
-#include <usb_ops_linux.h>
-
-void rtw_sreset_init(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       struct sreset_priv *psrtpriv = &pHalData->srestpriv;
-
-       mutex_init(&psrtpriv->silentreset_mutex);
-       psrtpriv->silent_reset_inprogress = false;
-       psrtpriv->last_tx_time = 0;
-       psrtpriv->last_tx_complete_time = 0;
-}
-
-void rtw_sreset_reset_value(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       struct sreset_priv *psrtpriv = &pHalData->srestpriv;
-
-       psrtpriv->silent_reset_inprogress = false;
-       psrtpriv->last_tx_time = 0;
-       psrtpriv->last_tx_complete_time = 0;
-}
-
-bool rtw_sreset_inprogress(struct rtw_adapter *padapter)
-{
-       struct rtw_adapter *primary_adapter = GET_PRIMARY_ADAPTER(padapter);
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(primary_adapter);
-
-       return pHalData->srestpriv.silent_reset_inprogress;
-}
-
-static void sreset_restore_security_station(struct rtw_adapter *padapter)
-{
-       struct mlme_priv *mlmepriv = &padapter->mlmepriv;
-       struct sta_priv *pstapriv = &padapter->stapriv;
-       struct sta_info *psta;
-       struct mlme_ext_info *pmlmeinfo = &padapter->mlmeextpriv.mlmext_info;
-       u8 val8;
-
-       if (pmlmeinfo->auth_algo == dot11AuthAlgrthm_8021X)
-               val8 = 0xcc;
-       else
-               val8 = 0xcf;
-
-       rtl8723a_set_sec_cfg(padapter, val8);
-
-       if (padapter->securitypriv.dot11PrivacyAlgrthm ==
-           WLAN_CIPHER_SUITE_TKIP ||
-           padapter->securitypriv.dot11PrivacyAlgrthm ==
-           WLAN_CIPHER_SUITE_CCMP) {
-               psta = rtw_get_stainfo23a(pstapriv, get_bssid(mlmepriv));
-               if (psta == NULL) {
-                       /* DEBUG_ERR(("Set wpa_set_encryption: Obtain Sta_info fail\n")); */
-               } else {
-                       /* pairwise key */
-                       rtw_setstakey_cmd23a(padapter, (unsigned char *)psta, true);
-                       /* group key */
-                       rtw_set_key23a(padapter,&padapter->securitypriv, padapter->securitypriv.dot118021XGrpKeyid, 0);
-               }
-       }
-}
-
-static void sreset_restore_network_station(struct rtw_adapter *padapter)
-{
-       struct mlme_priv *mlmepriv = &padapter->mlmepriv;
-       struct mlme_ext_priv    *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       u8 threshold;
-
-       rtw_setopmode_cmd23a(padapter, NL80211_IFTYPE_STATION);
-
-       /*  TH = 1 => means that invalidate usb rx aggregation */
-       /*  TH = 0 => means that validate usb rx aggregation, use init value. */
-       if (mlmepriv->htpriv.ht_option) {
-               if (padapter->registrypriv.wifi_spec == 1)
-                       threshold = 1;
-               else
-                       threshold = 0;
-       } else
-               threshold = 1;
-
-       rtl8723a_set_rxdma_agg_pg_th(padapter, threshold);
-
-       set_channel_bwmode23a(padapter, pmlmeext->cur_channel,
-                             pmlmeext->cur_ch_offset, pmlmeext->cur_bwmode);
-
-       hw_var_set_bssid(padapter, pmlmeinfo->network.MacAddress);
-       hw_var_set_mlme_join(padapter, 0);
-
-       rtl8723a_set_media_status(padapter, pmlmeinfo->state & 0x3);
-
-       mlmeext_joinbss_event_callback23a(padapter, 1);
-       /* restore Sequence No. */
-       rtl8723au_write8(padapter, REG_NQOS_SEQ, padapter->xmitpriv.nqos_ssn);
-
-       sreset_restore_security_station(padapter);
-}
-
-static void sreset_restore_network_status(struct rtw_adapter *padapter)
-{
-       struct mlme_priv *mlmepriv = &padapter->mlmepriv;
-
-       if (check_fwstate(mlmepriv, WIFI_STATION_STATE)) {
-               DBG_8723A("%s(%s): fwstate:0x%08x - WIFI_STATION_STATE\n",
-                         __func__, padapter->pnetdev->name,
-                         get_fwstate(mlmepriv));
-               sreset_restore_network_station(padapter);
-#ifdef CONFIG_8723AU_AP_MODE
-       } else if (check_fwstate(mlmepriv, WIFI_AP_STATE)) {
-               DBG_8723A("%s(%s): fwstate:0x%08x - WIFI_AP_STATE\n",
-                         __func__, padapter->pnetdev->name,
-                         get_fwstate(mlmepriv));
-               rtw_ap_restore_network(padapter);
-#endif
-       } else if (check_fwstate(mlmepriv, WIFI_ADHOC_STATE)) {
-               DBG_8723A("%s(%s): fwstate:0x%08x - WIFI_ADHOC_STATE\n",
-                         __func__, padapter->pnetdev->name,
-                         get_fwstate(mlmepriv));
-       } else {
-               DBG_8723A("%s(%s): fwstate:0x%08x - ???\n", __func__,
-                         padapter->pnetdev->name, get_fwstate(mlmepriv));
-       }
-}
-
-static void sreset_stop_adapter(struct rtw_adapter *padapter)
-{
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct xmit_priv        *pxmitpriv = &padapter->xmitpriv;
-
-       if (padapter == NULL)
-               return;
-
-       DBG_8723A("%s(%s)\n", __func__, padapter->pnetdev->name);
-
-       if (!rtw_netif_queue_stopped(padapter->pnetdev))
-               netif_tx_stop_all_queues(padapter->pnetdev);
-
-       rtw_cancel_all_timer23a(padapter);
-
-       /* TODO: OS and HCI independent */
-       tasklet_kill(&pxmitpriv->xmit_tasklet);
-
-       if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY))
-               rtw_scan_abort23a(padapter);
-
-       if (check_fwstate(pmlmepriv, _FW_UNDER_LINKING))
-               rtw23a_join_to_handler((unsigned long)padapter);
-}
-
-static void sreset_start_adapter(struct rtw_adapter *padapter)
-{
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct xmit_priv        *pxmitpriv = &padapter->xmitpriv;
-
-       if (padapter == NULL)
-               return;
-
-       DBG_8723A("%s(%s)\n", __func__, padapter->pnetdev->name);
-
-       if (check_fwstate(pmlmepriv, _FW_LINKED))
-               sreset_restore_network_status(padapter);
-
-       /* TODO: OS and HCI independent */
-       tasklet_hi_schedule(&pxmitpriv->xmit_tasklet);
-
-       mod_timer(&padapter->mlmepriv.dynamic_chk_timer,
-                 jiffies + msecs_to_jiffies(2000));
-
-       if (rtw_netif_queue_stopped(padapter->pnetdev))
-               netif_tx_wake_all_queues(padapter->pnetdev);
-}
-
-void rtw_sreset_reset(struct rtw_adapter *active_adapter)
-{
-       struct rtw_adapter *padapter = GET_PRIMARY_ADAPTER(active_adapter);
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       struct sreset_priv *psrtpriv = &pHalData->srestpriv;
-       struct pwrctrl_priv *pwrpriv = &padapter->pwrctrlpriv;
-       unsigned long start = jiffies;
-
-       DBG_8723A("%s\n", __func__);
-
-       mutex_lock(&psrtpriv->silentreset_mutex);
-       psrtpriv->silent_reset_inprogress = true;
-       pwrpriv->change_rfpwrstate = rf_off;
-
-       sreset_stop_adapter(padapter);
-
-       ips_enter23a(padapter);
-       ips_leave23a(padapter);
-
-       sreset_start_adapter(padapter);
-       psrtpriv->silent_reset_inprogress = false;
-       mutex_unlock(&psrtpriv->silentreset_mutex);
-
-       DBG_8723A("%s done in %d ms\n", __func__,
-                 jiffies_to_msecs(jiffies - start));
-}
diff --git a/drivers/staging/rtl8723au/core/rtw_sta_mgt.c b/drivers/staging/rtl8723au/core/rtw_sta_mgt.c
deleted file mode 100644 (file)
index a9b778c..0000000
+++ /dev/null
@@ -1,439 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#define _RTW_STA_MGT_C_
-
-#include <osdep_service.h>
-#include <drv_types.h>
-#include <recv_osdep.h>
-#include <xmit_osdep.h>
-#include <mlme_osdep.h>
-#include <sta_info.h>
-#include <rtl8723a_hal.h>
-
-static const u8 bc_addr[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
-
-static void _rtw_init_stainfo(struct sta_info *psta)
-{
-       memset((u8 *)psta, 0, sizeof(struct sta_info));
-       spin_lock_init(&psta->lock);
-       INIT_LIST_HEAD(&psta->list);
-       INIT_LIST_HEAD(&psta->hash_list);
-       _rtw_init_queue23a(&psta->sleep_q);
-       psta->sleepq_len = 0;
-       _rtw_init_sta_xmit_priv23a(&psta->sta_xmitpriv);
-       _rtw_init_sta_recv_priv23a(&psta->sta_recvpriv);
-#ifdef CONFIG_8723AU_AP_MODE
-       INIT_LIST_HEAD(&psta->asoc_list);
-       INIT_LIST_HEAD(&psta->auth_list);
-       psta->expire_to = 0;
-       psta->flags = 0;
-       psta->capability = 0;
-       psta->bpairwise_key_installed = false;
-       psta->nonerp_set = 0;
-       psta->no_short_slot_time_set = 0;
-       psta->no_short_preamble_set = 0;
-       psta->no_ht_gf_set = 0;
-       psta->no_ht_set = 0;
-       psta->ht_20mhz_set = 0;
-       psta->keep_alive_trycnt = 0;
-#endif /*  CONFIG_8723AU_AP_MODE */
-}
-
-int _rtw_init_sta_priv23a(struct sta_priv *pstapriv)
-{
-       int i;
-
-       spin_lock_init(&pstapriv->sta_hash_lock);
-       pstapriv->asoc_sta_count = 0;
-       for (i = 0; i < NUM_STA; i++)
-               INIT_LIST_HEAD(&pstapriv->sta_hash[i]);
-
-#ifdef CONFIG_8723AU_AP_MODE
-       pstapriv->sta_dz_bitmap = 0;
-       pstapriv->tim_bitmap = 0;
-       INIT_LIST_HEAD(&pstapriv->asoc_list);
-       INIT_LIST_HEAD(&pstapriv->auth_list);
-       spin_lock_init(&pstapriv->asoc_list_lock);
-       spin_lock_init(&pstapriv->auth_list_lock);
-       pstapriv->asoc_list_cnt = 0;
-       pstapriv->auth_list_cnt = 0;
-       pstapriv->auth_to = 3; /*  3*2 = 6 sec */
-       pstapriv->assoc_to = 3;
-       /* pstapriv->expire_to = 900;  900*2 = 1800 sec = 30 min,
-           expire after no any traffic. */
-       /* pstapriv->expire_to = 30;  30*2 = 60 sec = 1 min,
-           expire after no any traffic. */
-       pstapriv->expire_to = 3; /*  3*2 = 6 sec */
-       pstapriv->max_num_sta = NUM_STA;
-#endif
-       return _SUCCESS;
-}
-
-int _rtw_free_sta_priv23a(struct sta_priv *pstapriv)
-{
-       struct list_head *phead;
-       struct sta_info *psta, *ptmp;
-       struct recv_reorder_ctrl *preorder_ctrl;
-       int index;
-
-       if (pstapriv) {
-               /*      delete all reordering_ctrl_timer                */
-               spin_lock_bh(&pstapriv->sta_hash_lock);
-               for (index = 0; index < NUM_STA; index++) {
-                       phead = &pstapriv->sta_hash[index];
-                       list_for_each_entry_safe(psta, ptmp, phead, hash_list) {
-                               int i;
-
-                               for (i = 0; i < 16 ; i++) {
-                                       preorder_ctrl = &psta->recvreorder_ctrl[i];
-                                       del_timer_sync(&preorder_ctrl->reordering_ctrl_timer);
-                               }
-                       }
-               }
-               spin_unlock_bh(&pstapriv->sta_hash_lock);
-               /*===============================*/
-       }
-       return _SUCCESS;
-}
-
-struct sta_info *
-rtw_alloc_stainfo23a(struct sta_priv *pstapriv, const u8 *hwaddr, gfp_t gfp)
-{
-       struct list_head        *phash_list;
-       struct sta_info *psta;
-       struct recv_reorder_ctrl *preorder_ctrl;
-       s32     index;
-       int i = 0;
-       u16  wRxSeqInitialValue = 0xffff;
-
-       psta = kmalloc(sizeof(struct sta_info), gfp);
-       if (!psta)
-               return NULL;
-
-       spin_lock_bh(&pstapriv->sta_hash_lock);
-
-       _rtw_init_stainfo(psta);
-
-       psta->padapter = pstapriv->padapter;
-
-       ether_addr_copy(psta->hwaddr, hwaddr);
-
-       index = wifi_mac_hash(hwaddr);
-
-       RT_TRACE(_module_rtl871x_sta_mgt_c_, _drv_info_,
-                "rtw_alloc_stainfo23a: index  = %x\n", index);
-       if (index >= NUM_STA) {
-               RT_TRACE(_module_rtl871x_sta_mgt_c_, _drv_err_,
-                        "ERROR => rtw_alloc_stainfo23a: index >= NUM_STA\n");
-               psta = NULL;
-               goto exit;
-       }
-       phash_list = &pstapriv->sta_hash[index];
-
-       list_add_tail(&psta->hash_list, phash_list);
-
-       pstapriv->asoc_sta_count++;
-
-/*  For the SMC router, the sequence number of first packet of WPS
-     handshake will be 0. */
-/*  In this case, this packet will be dropped by recv_decache function
-    if we use the 0x00 as the default value for tid_rxseq variable. */
-/*  So, we initialize the tid_rxseq variable as the 0xffff. */
-
-       for (i = 0; i < 16; i++)
-               memcpy(&psta->sta_recvpriv.rxcache.tid_rxseq[i],
-                       &wRxSeqInitialValue, 2);
-
-       RT_TRACE(_module_rtl871x_sta_mgt_c_, _drv_info_,
-                "alloc number_%d stainfo  with hwaddr = %pM\n",
-                pstapriv->asoc_sta_count, hwaddr);
-
-       init_addba_retry_timer23a(psta);
-
-       /* for A-MPDU Rx reordering buffer control */
-       for (i = 0; i < 16; i++) {
-               preorder_ctrl = &psta->recvreorder_ctrl[i];
-
-               preorder_ctrl->padapter = pstapriv->padapter;
-
-               preorder_ctrl->enable = false;
-
-               preorder_ctrl->indicate_seq = 0xffff;
-               preorder_ctrl->wend_b = 0xffff;
-               /* preorder_ctrl->wsize_b = (NR_RECVBUFF-2); */
-               preorder_ctrl->wsize_b = 64;/* 64; */
-
-               _rtw_init_queue23a(&preorder_ctrl->pending_recvframe_queue);
-
-               rtw_init_recv_timer23a(preorder_ctrl);
-       }
-       /* init for DM */
-       psta->rssi_stat.UndecoratedSmoothedPWDB = (-1);
-       psta->rssi_stat.UndecoratedSmoothedCCK = (-1);
-
-       /* init for the sequence number of received management frame */
-       psta->RxMgmtFrameSeqNum = 0xffff;
-exit:
-       spin_unlock_bh(&pstapriv->sta_hash_lock);
-       return psta;
-}
-
-/*  using pstapriv->sta_hash_lock to protect */
-int rtw_free_stainfo23a(struct rtw_adapter *padapter, struct sta_info *psta)
-{
-       struct recv_reorder_ctrl *preorder_ctrl;
-       struct  sta_xmit_priv   *pstaxmitpriv;
-       struct  xmit_priv       *pxmitpriv = &padapter->xmitpriv;
-       struct  sta_priv *pstapriv = &padapter->stapriv;
-       struct hw_xmit *phwxmit;
-       int i;
-
-       if (!psta)
-               goto exit;
-
-       spin_lock_bh(&psta->lock);
-       psta->state &= ~_FW_LINKED;
-       spin_unlock_bh(&psta->lock);
-
-       pstaxmitpriv = &psta->sta_xmitpriv;
-
-       spin_lock_bh(&pxmitpriv->lock);
-
-       rtw_free_xmitframe_queue23a(pxmitpriv, &psta->sleep_q);
-       psta->sleepq_len = 0;
-
-       /* vo */
-       rtw_free_xmitframe_queue23a(pxmitpriv, &pstaxmitpriv->vo_q.sta_pending);
-       list_del_init(&pstaxmitpriv->vo_q.tx_pending);
-       phwxmit = pxmitpriv->hwxmits;
-       phwxmit->accnt -= pstaxmitpriv->vo_q.qcnt;
-       pstaxmitpriv->vo_q.qcnt = 0;
-
-       /* vi */
-       rtw_free_xmitframe_queue23a(pxmitpriv, &pstaxmitpriv->vi_q.sta_pending);
-       list_del_init(&pstaxmitpriv->vi_q.tx_pending);
-       phwxmit = pxmitpriv->hwxmits+1;
-       phwxmit->accnt -= pstaxmitpriv->vi_q.qcnt;
-       pstaxmitpriv->vi_q.qcnt = 0;
-
-       /* be */
-       rtw_free_xmitframe_queue23a(pxmitpriv, &pstaxmitpriv->be_q.sta_pending);
-       list_del_init(&pstaxmitpriv->be_q.tx_pending);
-       phwxmit = pxmitpriv->hwxmits+2;
-       phwxmit->accnt -= pstaxmitpriv->be_q.qcnt;
-       pstaxmitpriv->be_q.qcnt = 0;
-
-       /* bk */
-       rtw_free_xmitframe_queue23a(pxmitpriv, &pstaxmitpriv->bk_q.sta_pending);
-       list_del_init(&pstaxmitpriv->bk_q.tx_pending);
-       phwxmit = pxmitpriv->hwxmits+3;
-       phwxmit->accnt -= pstaxmitpriv->bk_q.qcnt;
-       pstaxmitpriv->bk_q.qcnt = 0;
-
-       spin_unlock_bh(&pxmitpriv->lock);
-
-       list_del_init(&psta->hash_list);
-       RT_TRACE(_module_rtl871x_sta_mgt_c_, _drv_err_,
-                "free number_%d stainfo  with hwaddr = %pM\n",
-                pstapriv->asoc_sta_count, psta->hwaddr);
-       pstapriv->asoc_sta_count--;
-
-       /*  re-init sta_info; 20061114  will be init in alloc_stainfo */
-       /* _rtw_init_sta_xmit_priv23a(&psta->sta_xmitpriv); */
-       /* _rtw_init_sta_recv_priv23a(&psta->sta_recvpriv); */
-
-       del_timer_sync(&psta->addba_retry_timer);
-
-       /* for A-MPDU Rx reordering buffer control,
-          cancel reordering_ctrl_timer */
-       for (i = 0; i < 16; i++) {
-               struct list_head        *phead, *plist;
-               struct recv_frame *prframe;
-               struct rtw_queue *ppending_recvframe_queue;
-
-               preorder_ctrl = &psta->recvreorder_ctrl[i];
-
-               del_timer_sync(&preorder_ctrl->reordering_ctrl_timer);
-
-               ppending_recvframe_queue =
-                       &preorder_ctrl->pending_recvframe_queue;
-
-               spin_lock_bh(&ppending_recvframe_queue->lock);
-               phead =         get_list_head(ppending_recvframe_queue);
-               plist = phead->next;
-
-               while (!list_empty(phead)) {
-                       prframe = container_of(plist, struct recv_frame, list);
-                       plist = plist->next;
-                       list_del_init(&prframe->list);
-                       rtw_free_recvframe23a(prframe);
-               }
-               spin_unlock_bh(&ppending_recvframe_queue->lock);
-       }
-       if (!(psta->state & WIFI_AP_STATE))
-               rtl8723a_SetHalODMVar(padapter, HAL_ODM_STA_INFO, psta, false);
-#ifdef CONFIG_8723AU_AP_MODE
-       spin_lock_bh(&pstapriv->auth_list_lock);
-       if (!list_empty(&psta->auth_list)) {
-               list_del_init(&psta->auth_list);
-               pstapriv->auth_list_cnt--;
-       }
-       spin_unlock_bh(&pstapriv->auth_list_lock);
-
-       psta->expire_to = 0;
-
-       psta->sleepq_ac_len = 0;
-       psta->qos_info = 0;
-
-       psta->max_sp_len = 0;
-       psta->uapsd_bk = 0;
-       psta->uapsd_be = 0;
-       psta->uapsd_vi = 0;
-       psta->uapsd_vo = 0;
-
-       psta->has_legacy_ac = 0;
-
-       pstapriv->sta_dz_bitmap &= ~CHKBIT(psta->aid);
-       pstapriv->tim_bitmap &= ~CHKBIT(psta->aid);
-
-       if ((psta->aid > 0) && (pstapriv->sta_aid[psta->aid - 1] == psta)) {
-               pstapriv->sta_aid[psta->aid - 1] = NULL;
-               psta->aid = 0;
-       }
-#endif /*  CONFIG_8723AU_AP_MODE */
-
-       kfree(psta);
-exit:
-       return _SUCCESS;
-}
-
-/*  free all stainfo which in sta_hash[all] */
-void rtw_free_all_stainfo23a(struct rtw_adapter *padapter)
-{
-       struct list_head *phead;
-       struct sta_info *psta, *ptmp;
-       struct sta_priv *pstapriv = &padapter->stapriv;
-       struct sta_info *pbcmc_stainfo = rtw_get_bcmc_stainfo23a(padapter);
-       s32 index;
-
-       if (pstapriv->asoc_sta_count == 1)
-               return;
-
-       spin_lock_bh(&pstapriv->sta_hash_lock);
-       for (index = 0; index < NUM_STA; index++) {
-               phead = &pstapriv->sta_hash[index];
-               list_for_each_entry_safe(psta, ptmp, phead, hash_list) {
-                       if (pbcmc_stainfo != psta)
-                               rtw_free_stainfo23a(padapter, psta);
-               }
-       }
-       spin_unlock_bh(&pstapriv->sta_hash_lock);
-}
-
-/* any station allocated can be searched by hash list */
-struct sta_info *rtw_get_stainfo23a(struct sta_priv *pstapriv, const u8 *hwaddr)
-{
-       struct list_head *phead;
-       struct sta_info *pos, *psta = NULL;
-       u32 index;
-       const u8 *addr;
-
-       if (!hwaddr)
-               return NULL;
-
-       if (is_multicast_ether_addr(hwaddr))
-               addr = bc_addr;
-       else
-               addr = hwaddr;
-
-       index = wifi_mac_hash(addr);
-
-       spin_lock_bh(&pstapriv->sta_hash_lock);
-       phead = &pstapriv->sta_hash[index];
-       list_for_each_entry(pos, phead, hash_list) {
-               psta = pos;
-
-               /*  if found the matched address */
-               if (ether_addr_equal(psta->hwaddr, addr))
-                       break;
-
-               psta = NULL;
-       }
-       spin_unlock_bh(&pstapriv->sta_hash_lock);
-       return psta;
-}
-
-int rtw_init_bcmc_stainfo23a(struct rtw_adapter *padapter)
-{
-       struct  sta_priv *pstapriv = &padapter->stapriv;
-       struct sta_info         *psta;
-       struct tx_servq *ptxservq;
-       int res = _SUCCESS;
-
-       psta = rtw_alloc_stainfo23a(pstapriv, bc_addr, GFP_KERNEL);
-       if (!psta) {
-               res = _FAIL;
-               RT_TRACE(_module_rtl871x_sta_mgt_c_, _drv_err_,
-                        "rtw_alloc_stainfo23a fail\n");
-               return res;
-       }
-       /*  default broadcast & multicast use macid 1 */
-       psta->mac_id = 1;
-
-       ptxservq = &psta->sta_xmitpriv.be_q;
-       return _SUCCESS;
-}
-
-struct sta_info *rtw_get_bcmc_stainfo23a(struct rtw_adapter *padapter)
-{
-       struct sta_info         *psta;
-       struct sta_priv         *pstapriv = &padapter->stapriv;
-
-       psta = rtw_get_stainfo23a(pstapriv, bc_addr);
-       return psta;
-}
-
-bool rtw_access_ctrl23a(struct rtw_adapter *padapter, u8 *mac_addr)
-{
-       bool res = true;
-#ifdef CONFIG_8723AU_AP_MODE
-       struct list_head *phead;
-       struct rtw_wlan_acl_node *paclnode;
-       bool match = false;
-       struct sta_priv *pstapriv = &padapter->stapriv;
-       struct wlan_acl_pool *pacl_list = &pstapriv->acl_list;
-       struct rtw_queue *pacl_node_q = &pacl_list->acl_node_q;
-
-       spin_lock_bh(&pacl_node_q->lock);
-       phead = get_list_head(pacl_node_q);
-       list_for_each_entry(paclnode, phead, list) {
-               if (ether_addr_equal(paclnode->addr, mac_addr)) {
-                       if (paclnode->valid) {
-                               match = true;
-                               break;
-                       }
-               }
-       }
-       spin_unlock_bh(&pacl_node_q->lock);
-
-       if (pacl_list->mode == 1)/* accept unless in deny list */
-               res = (match) ?  false : true;
-       else if (pacl_list->mode == 2)/* deny unless in accept list */
-               res = (match) ?  true : false;
-       else
-                res = true;
-#endif
-       return res;
-}
diff --git a/drivers/staging/rtl8723au/core/rtw_wlan_util.c b/drivers/staging/rtl8723au/core/rtw_wlan_util.c
deleted file mode 100644 (file)
index 694cf17..0000000
+++ /dev/null
@@ -1,1537 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#define _RTW_WLAN_UTIL_C_
-
-#include <osdep_service.h>
-#include <drv_types.h>
-#include <linux/ieee80211.h>
-#include <wifi.h>
-#include <rtl8723a_spec.h>
-
-static unsigned char ARTHEROS_OUI1[] = {0x00, 0x03, 0x7f};
-static unsigned char ARTHEROS_OUI2[] = {0x00, 0x13, 0x74};
-
-static unsigned char BROADCOM_OUI1[] = {0x00, 0x10, 0x18};
-static unsigned char BROADCOM_OUI2[] = {0x00, 0x0a, 0xf7};
-
-static unsigned char CISCO_OUI[] = {0x00, 0x40, 0x96};
-static unsigned char MARVELL_OUI[] = {0x00, 0x50, 0x43};
-static unsigned char RALINK_OUI[] = {0x00, 0x0c, 0x43};
-static unsigned char REALTEK_OUI[] = {0x00, 0xe0, 0x4c};
-static unsigned char AIRGOCAP_OUI[] = {0x00, 0x0a, 0xf5};
-static unsigned char EPIGRAM_OUI[] = {0x00, 0x90, 0x4c};
-
-static unsigned char WPA_TKIP_CIPHER[4] = {0x00, 0x50, 0xf2, 0x02};
-static unsigned char RSN_TKIP_CIPHER[4] = {0x00, 0x0f, 0xac, 0x02};
-
-#define R2T_PHY_DELAY          0
-
-/* define WAIT_FOR_BCN_TO_MIN  3000 */
-#define WAIT_FOR_BCN_TO_MIN    6000
-#define WAIT_FOR_BCN_TO_MAX    20000
-
-static u8 rtw_basic_rate_cck[4] = {
-       IEEE80211_CCK_RATE_1MB | IEEE80211_BASIC_RATE_MASK,
-       IEEE80211_CCK_RATE_2MB | IEEE80211_BASIC_RATE_MASK,
-       IEEE80211_CCK_RATE_5MB | IEEE80211_BASIC_RATE_MASK,
-       IEEE80211_CCK_RATE_11MB | IEEE80211_BASIC_RATE_MASK
-};
-
-static u8 rtw_basic_rate_ofdm[3] = {
-       IEEE80211_OFDM_RATE_6MB | IEEE80211_BASIC_RATE_MASK,
-       IEEE80211_OFDM_RATE_12MB | IEEE80211_BASIC_RATE_MASK,
-       IEEE80211_OFDM_RATE_24MB | IEEE80211_BASIC_RATE_MASK
-};
-
-static u8 rtw_basic_rate_mix[7] = {
-       IEEE80211_CCK_RATE_1MB | IEEE80211_BASIC_RATE_MASK,
-       IEEE80211_CCK_RATE_2MB | IEEE80211_BASIC_RATE_MASK,
-       IEEE80211_CCK_RATE_5MB | IEEE80211_BASIC_RATE_MASK,
-       IEEE80211_CCK_RATE_11MB | IEEE80211_BASIC_RATE_MASK,
-       IEEE80211_OFDM_RATE_6MB | IEEE80211_BASIC_RATE_MASK,
-       IEEE80211_OFDM_RATE_12MB | IEEE80211_BASIC_RATE_MASK,
-       IEEE80211_OFDM_RATE_24MB | IEEE80211_BASIC_RATE_MASK
-};
-
-int cckrates_included23a(unsigned char *rate, int ratelen)
-{
-       int     i;
-
-       for (i = 0; i < ratelen; i++) {
-               if  (((rate[i]) & 0x7f) == 2 || ((rate[i]) & 0x7f) == 4 ||
-                    ((rate[i]) & 0x7f) == 11  || ((rate[i]) & 0x7f) == 22)
-                       return true;
-       }
-
-       return false;
-}
-
-int cckratesonly_included23a(unsigned char *rate, int ratelen)
-{
-       int     i;
-
-       for (i = 0; i < ratelen; i++) {
-               if  (((rate[i]) & 0x7f) != 2 && ((rate[i]) & 0x7f) != 4 &&
-                    ((rate[i]) & 0x7f) != 11 && ((rate[i]) & 0x7f) != 22)
-               return false;
-       }
-
-       return true;
-}
-
-unsigned char networktype_to_raid23a(unsigned char network_type)
-{
-       unsigned char raid;
-
-       switch (network_type) {
-       case WIRELESS_11B:
-               raid = RATR_INX_WIRELESS_B;
-               break;
-       case WIRELESS_11A:
-       case WIRELESS_11G:
-               raid = RATR_INX_WIRELESS_G;
-               break;
-       case WIRELESS_11BG:
-               raid = RATR_INX_WIRELESS_GB;
-               break;
-       case WIRELESS_11_24N:
-       case WIRELESS_11_5N:
-               raid = RATR_INX_WIRELESS_N;
-               break;
-       case WIRELESS_11A_5N:
-       case WIRELESS_11G_24N:
-               raid = RATR_INX_WIRELESS_NG;
-               break;
-       case WIRELESS_11BG_24N:
-               raid = RATR_INX_WIRELESS_NGB;
-               break;
-       default:
-               raid = RATR_INX_WIRELESS_GB;
-               break;
-       }
-       return raid;
-}
-
-u8 judge_network_type23a(struct rtw_adapter *padapter,
-                        unsigned char *rate, int ratelen)
-{
-       u8 network_type = 0;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-
-       if (pmlmeext->cur_channel > 14) {
-               if (pmlmeinfo->HT_enable)
-                       network_type = WIRELESS_11_5N;
-               network_type |= WIRELESS_11A;
-       } else {
-               if (pmlmeinfo->HT_enable)
-                       network_type = WIRELESS_11_24N;
-
-               if ((cckratesonly_included23a(rate, ratelen)) == true)
-                       network_type |= WIRELESS_11B;
-               else if ((cckrates_included23a(rate, ratelen)) == true)
-                       network_type |= WIRELESS_11BG;
-               else
-                       network_type |= WIRELESS_11G;
-       }
-       return  network_type;
-}
-
-static unsigned char ratetbl_val_2wifirate(unsigned char rate)
-{
-       unsigned char val = 0;
-
-       switch (rate & 0x7f) {
-       case 0:
-               val = IEEE80211_CCK_RATE_1MB;
-               break;
-       case 1:
-               val = IEEE80211_CCK_RATE_2MB;
-               break;
-       case 2:
-               val = IEEE80211_CCK_RATE_5MB;
-               break;
-       case 3:
-               val = IEEE80211_CCK_RATE_11MB;
-               break;
-       case 4:
-               val = IEEE80211_OFDM_RATE_6MB;
-               break;
-       case 5:
-               val = IEEE80211_OFDM_RATE_9MB;
-               break;
-       case 6:
-               val = IEEE80211_OFDM_RATE_12MB;
-               break;
-       case 7:
-               val = IEEE80211_OFDM_RATE_18MB;
-               break;
-       case 8:
-               val = IEEE80211_OFDM_RATE_24MB;
-               break;
-       case 9:
-               val = IEEE80211_OFDM_RATE_36MB;
-               break;
-       case 10:
-               val = IEEE80211_OFDM_RATE_48MB;
-               break;
-       case 11:
-               val = IEEE80211_OFDM_RATE_54MB;
-               break;
-       }
-       return val;
-}
-
-static int is_basicrate(struct rtw_adapter *padapter, unsigned char rate)
-{
-       int i;
-       unsigned char val;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-
-       for (i = 0; i < NumRates; i++) {
-               val = pmlmeext->basicrate[i];
-
-               if (val != 0xff && val != 0xfe) {
-                       if (rate == ratetbl_val_2wifirate(val))
-                               return true;
-               }
-       }
-
-       return false;
-}
-
-static unsigned int ratetbl2rateset(struct rtw_adapter *padapter,
-                                   unsigned char *rateset)
-{
-       int i;
-       unsigned char rate;
-       unsigned int len = 0;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-
-       for (i = 0; i < NumRates; i++) {
-               rate = pmlmeext->datarate[i];
-
-               switch (rate) {
-               case 0xff:
-                       return len;
-               case 0xfe:
-                       continue;
-               default:
-                       rate = ratetbl_val_2wifirate(rate);
-
-                       if (is_basicrate(padapter, rate) == true)
-                               rate |= IEEE80211_BASIC_RATE_MASK;
-
-                       rateset[len] = rate;
-                       len++;
-                       break;
-               }
-       }
-       return len;
-}
-
-void get_rate_set23a(struct rtw_adapter *padapter,
-                    unsigned char *pbssrate, int *bssrate_len)
-{
-       unsigned char supportedrates[NumRates];
-
-       memset(supportedrates, 0, NumRates);
-       *bssrate_len = ratetbl2rateset(padapter, supportedrates);
-       memcpy(pbssrate, supportedrates, *bssrate_len);
-}
-
-void UpdateBrateTbl23a(struct rtw_adapter *Adapter, u8 *mBratesOS)
-{
-       u8 i;
-       u8 rate;
-
-       /*  1M, 2M, 5.5M, 11M, 6M, 12M, 24M are mandatory. */
-       for (i = 0; i < NDIS_802_11_LENGTH_RATES_EX; i++) {
-               rate = mBratesOS[i] & 0x7f;
-               switch (rate) {
-               case IEEE80211_CCK_RATE_1MB:
-               case IEEE80211_CCK_RATE_2MB:
-               case IEEE80211_CCK_RATE_5MB:
-               case IEEE80211_CCK_RATE_11MB:
-               case IEEE80211_OFDM_RATE_6MB:
-               case IEEE80211_OFDM_RATE_12MB:
-               case IEEE80211_OFDM_RATE_24MB:
-                       mBratesOS[i] |= IEEE80211_BASIC_RATE_MASK;
-                       break;
-               default:
-                       break;
-               }
-       }
-}
-
-void Update23aTblForSoftAP(u8 *bssrateset, u32 bssratelen)
-{
-       u8 i;
-       u8 rate;
-
-       for (i = 0; i < bssratelen; i++) {
-               rate = bssrateset[i] & 0x7f;
-               switch (rate) {
-               case IEEE80211_CCK_RATE_1MB:
-               case IEEE80211_CCK_RATE_2MB:
-               case IEEE80211_CCK_RATE_5MB:
-               case IEEE80211_CCK_RATE_11MB:
-                       bssrateset[i] |= IEEE80211_BASIC_RATE_MASK;
-                       break;
-               }
-       }
-}
-
-inline u8 rtw_get_oper_ch23a(struct rtw_adapter *adapter)
-{
-       return adapter_to_dvobj(adapter)->oper_channel;
-}
-
-inline void rtw_set_oper_ch23a(struct rtw_adapter *adapter, u8 ch)
-{
-       adapter_to_dvobj(adapter)->oper_channel = ch;
-}
-
-inline void rtw_set_oper_bw23a(struct rtw_adapter *adapter, u8 bw)
-{
-       adapter_to_dvobj(adapter)->oper_bwmode = bw;
-}
-
-inline void rtw_set_oper_ch23aoffset23a(struct rtw_adapter *adapter, u8 offset)
-{
-       adapter_to_dvobj(adapter)->oper_ch_offset = offset;
-}
-
-void SelectChannel23a(struct rtw_adapter *padapter, unsigned char channel)
-{
-       mutex_lock(&adapter_to_dvobj(padapter)->setch_mutex);
-
-       /* saved channel info */
-       rtw_set_oper_ch23a(padapter, channel);
-
-       PHY_SwChnl8723A(padapter, channel);
-
-       mutex_unlock(&adapter_to_dvobj(padapter)->setch_mutex);
-}
-
-static void set_bwmode(struct rtw_adapter *padapter, unsigned short bwmode,
-                      unsigned char channel_offset)
-{
-       mutex_lock(&adapter_to_dvobj(padapter)->setbw_mutex);
-
-       /* saved bw info */
-       rtw_set_oper_bw23a(padapter, bwmode);
-       rtw_set_oper_ch23aoffset23a(padapter, channel_offset);
-
-       PHY_SetBWMode23a8723A(padapter, (enum ht_channel_width)bwmode,
-                             channel_offset);
-
-       mutex_unlock(&adapter_to_dvobj(padapter)->setbw_mutex);
-}
-
-void set_channel_bwmode23a(struct rtw_adapter *padapter, unsigned char channel,
-                          unsigned char channel_offset, unsigned short bwmode)
-{
-       u8 center_ch;
-
-       if (bwmode == HT_CHANNEL_WIDTH_20 ||
-           channel_offset == HAL_PRIME_CHNL_OFFSET_DONT_CARE) {
-               /* SelectChannel23a(padapter, channel); */
-               center_ch = channel;
-       } else {
-               /* switch to the proper channel */
-               if (channel_offset == HAL_PRIME_CHNL_OFFSET_LOWER) {
-                       /* SelectChannel23a(padapter, channel + 2); */
-                       center_ch = channel + 2;
-               } else {
-                       /* SelectChannel23a(padapter, channel - 2); */
-                       center_ch = channel - 2;
-               }
-       }
-
-       /* set Channel */
-       mutex_lock(&adapter_to_dvobj(padapter)->setch_mutex);
-
-       /* saved channel/bw info */
-       rtw_set_oper_ch23a(padapter, channel);
-       rtw_set_oper_bw23a(padapter, bwmode);
-       rtw_set_oper_ch23aoffset23a(padapter, channel_offset);
-
-       PHY_SwChnl8723A(padapter, center_ch); /*  set center channel */
-
-       mutex_unlock(&adapter_to_dvobj(padapter)->setch_mutex);
-
-       set_bwmode(padapter, bwmode, channel_offset);
-}
-
-inline u8 *get_my_bssid23a(struct wlan_bssid_ex *pnetwork)
-{
-       return pnetwork->MacAddress;
-}
-
-bool is_client_associated_to_ap23a(struct rtw_adapter *padapter)
-{
-       struct mlme_ext_priv *pmlmeext;
-       struct mlme_ext_info *pmlmeinfo;
-
-       if (!padapter)
-               return false;
-
-       pmlmeext = &padapter->mlmeextpriv;
-       pmlmeinfo = &pmlmeext->mlmext_info;
-
-       if (pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS &&
-           (pmlmeinfo->state & 0x03) == MSR_INFRA)
-               return true;
-       else
-               return false;
-}
-
-bool is_client_associated_to_ibss23a(struct rtw_adapter *padapter)
-{
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-
-       if (pmlmeinfo->state & WIFI_FW_ASSOC_SUCCESS &&
-           (pmlmeinfo->state & 0x03) == MSR_ADHOC)
-               return true;
-       else
-               return false;
-}
-
-bool is_IBSS_empty23a(struct rtw_adapter *padapter)
-{
-       unsigned int i;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-
-       for (i = IBSS_START_MAC_ID; i < NUM_STA; i++) {
-               if (pmlmeinfo->FW_sta_info[i].status == 1)
-                       return false;
-       }
-
-       return true;
-}
-
-unsigned int decide_wait_for_beacon_timeout23a(unsigned int bcn_interval)
-{
-       if ((bcn_interval << 2) < WAIT_FOR_BCN_TO_MIN)
-               return WAIT_FOR_BCN_TO_MIN;
-       else if ((bcn_interval << 2) > WAIT_FOR_BCN_TO_MAX)
-               return WAIT_FOR_BCN_TO_MAX;
-       else
-               return bcn_interval << 2;
-}
-
-void clear_cam_entry23a(struct rtw_adapter *padapter, u8 entry)
-{
-       unsigned char null_sta[] = {0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
-
-       unsigned char null_key[] = {0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-                                   0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-                                   0x00, 0x00, 0x00, 0x00};
-
-       rtl8723a_cam_write(padapter, entry, 0, null_sta, null_key);
-}
-
-int allocate_fw_sta_entry23a(struct rtw_adapter *padapter)
-{
-       unsigned int mac_id;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-
-       for (mac_id = IBSS_START_MAC_ID; mac_id < NUM_STA; mac_id++) {
-               if (pmlmeinfo->FW_sta_info[mac_id].status == 0) {
-                       pmlmeinfo->FW_sta_info[mac_id].status = 1;
-                       pmlmeinfo->FW_sta_info[mac_id].retry = 0;
-                       break;
-               }
-       }
-
-       return mac_id;
-}
-
-void flush_all_cam_entry23a(struct rtw_adapter *padapter)
-{
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-
-       rtl8723a_cam_invalidate_all(padapter);
-
-       memset(pmlmeinfo->FW_sta_info, 0, sizeof(pmlmeinfo->FW_sta_info));
-}
-
-int WMM_param_handler23a(struct rtw_adapter *padapter, const u8 *p)
-{
-       /* struct registry_priv *pregpriv = &padapter->registrypriv; */
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-
-       if (pmlmepriv->qos_option == 0) {
-               pmlmeinfo->WMM_enable = 0;
-               return _FAIL;
-       }
-
-       pmlmeinfo->WMM_enable = 1;
-       memcpy(&pmlmeinfo->WMM_param, p + 2 + 6,
-              sizeof(struct WMM_para_element));
-       return true;
-}
-
-void WMMOnAssocRsp23a(struct rtw_adapter *padapter)
-{
-       u8 ACI, ACM, AIFS, ECWMin, ECWMax, aSifsTime;
-       u8 acm_mask;
-       u16 TXOP;
-       u32 acParm, i;
-       u32 edca[4], inx[4];
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-       struct registry_priv *pregpriv = &padapter->registrypriv;
-
-       if (pmlmeinfo->WMM_enable == 0) {
-               padapter->mlmepriv.acm_mask = 0;
-               return;
-       }
-
-       acm_mask = 0;
-
-       if (pmlmeext->cur_wireless_mode == WIRELESS_11B)
-               aSifsTime = 10;
-       else
-               aSifsTime = 16;
-
-       for (i = 0; i < 4; i++) {
-               ACI = (pmlmeinfo->WMM_param.ac_param[i].ACI_AIFSN >> 5) & 0x03;
-               ACM = (pmlmeinfo->WMM_param.ac_param[i].ACI_AIFSN >> 4) & 0x01;
-
-               /* AIFS = AIFSN * slot time + SIFS - r2t phy delay */
-               AIFS = (pmlmeinfo->WMM_param.ac_param[i].ACI_AIFSN & 0x0f) *
-                       pmlmeinfo->slotTime + aSifsTime;
-
-               ECWMin = pmlmeinfo->WMM_param.ac_param[i].CW & 0x0f;
-               ECWMax = (pmlmeinfo->WMM_param.ac_param[i].CW & 0xf0) >> 4;
-               TXOP = le16_to_cpu(pmlmeinfo->WMM_param.ac_param[i].TXOP_limit);
-
-               acParm = AIFS | (ECWMin << 8) | (ECWMax << 12) | (TXOP << 16);
-
-               switch (ACI) {
-               case 0x0:
-                       rtl8723a_set_ac_param_be(padapter, acParm);
-                       acm_mask |= (ACM? BIT(1):0);
-                       edca[XMIT_BE_QUEUE] = acParm;
-                       break;
-               case 0x1:
-                       rtl8723a_set_ac_param_bk(padapter, acParm);
-                       /* acm_mask |= (ACM? BIT(0):0); */
-                       edca[XMIT_BK_QUEUE] = acParm;
-                       break;
-               case 0x2:
-                       rtl8723a_set_ac_param_vi(padapter, acParm);
-                       acm_mask |= (ACM? BIT(2):0);
-                       edca[XMIT_VI_QUEUE] = acParm;
-                       break;
-               case 0x3:
-                       rtl8723a_set_ac_param_vo(padapter, acParm);
-                       acm_mask |= (ACM? BIT(3):0);
-                       edca[XMIT_VO_QUEUE] = acParm;
-                       break;
-               }
-
-               DBG_8723A("WMM(%x): %x, %x\n", ACI, ACM, acParm);
-       }
-
-       if (padapter->registrypriv.acm_method == 1)
-               rtl8723a_set_acm_ctrl(padapter, acm_mask);
-       else
-               padapter->mlmepriv.acm_mask = acm_mask;
-
-       inx[0] = 0; inx[1] = 1; inx[2] = 2; inx[3] = 3;
-
-       if (pregpriv->wifi_spec == 1) {
-               u32 j, change_inx = false;
-
-               /* entry indx: 0->vo, 1->vi, 2->be, 3->bk. */
-               for (i = 0; i < 4; i++) {
-                       for (j = i+1; j < 4; j++) {
-                               /* compare CW and AIFS */
-                               if ((edca[j] & 0xFFFF) < (edca[i] & 0xFFFF)) {
-                                       change_inx = true;
-                               } else if ((edca[j] & 0xFFFF) ==
-                                          (edca[i] & 0xFFFF)) {
-                                       /* compare TXOP */
-                                       if ((edca[j] >> 16) > (edca[i] >> 16))
-                                               change_inx = true;
-                               }
-
-                               if (change_inx) {
-                                       swap(edca[i], edca[j]);
-                                       swap(inx[i], inx[j]);
-                                       change_inx = false;
-                               }
-                       }
-               }
-       }
-
-       for (i = 0; i<4; i++) {
-               pxmitpriv->wmm_para_seq[i] = inx[i];
-               DBG_8723A("wmm_para_seq(%d): %d\n", i,
-                         pxmitpriv->wmm_para_seq[i]);
-       }
-}
-
-static void bwmode_update_check(struct rtw_adapter *padapter, const u8 *p)
-{
-       struct ieee80211_ht_operation *pHT_info;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       struct registry_priv *pregistrypriv = &padapter->registrypriv;
-       struct ht_priv *phtpriv = &pmlmepriv->htpriv;
-       unsigned char new_bwmode;
-       unsigned char new_ch_offset;
-
-       if (!p)
-               return;
-       if (!phtpriv->ht_option)
-               return;
-       if (p[1] != sizeof(struct ieee80211_ht_operation))
-               return;
-
-       pHT_info = (struct ieee80211_ht_operation *)(p + 2);
-
-       if ((pHT_info->ht_param & IEEE80211_HT_PARAM_CHAN_WIDTH_ANY) &&
-           pregistrypriv->cbw40_enable) {
-               new_bwmode = HT_CHANNEL_WIDTH_40;
-
-               switch (pHT_info->ht_param & IEEE80211_HT_PARAM_CHA_SEC_OFFSET){
-               case IEEE80211_HT_PARAM_CHA_SEC_ABOVE:
-                       new_ch_offset = HAL_PRIME_CHNL_OFFSET_LOWER;
-                       break;
-               case IEEE80211_HT_PARAM_CHA_SEC_BELOW:
-                       new_ch_offset = HAL_PRIME_CHNL_OFFSET_UPPER;
-                       break;
-               default:
-                       new_ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
-                       break;
-               }
-       } else {
-               new_bwmode = HT_CHANNEL_WIDTH_20;
-               new_ch_offset = HAL_PRIME_CHNL_OFFSET_DONT_CARE;
-       }
-
-       if (new_bwmode != pmlmeext->cur_bwmode ||
-           new_ch_offset != pmlmeext->cur_ch_offset) {
-               pmlmeinfo->bwmode_updated = true;
-
-               pmlmeext->cur_bwmode = new_bwmode;
-               pmlmeext->cur_ch_offset = new_ch_offset;
-
-               /* update HT info also */
-               HT_info_handler23a(padapter, p);
-       } else
-               pmlmeinfo->bwmode_updated = false;
-
-       if (pmlmeinfo->bwmode_updated) {
-               struct sta_info *psta;
-               struct wlan_bssid_ex *cur_network = &pmlmeinfo->network;
-               struct sta_priv *pstapriv = &padapter->stapriv;
-
-               /* set_channel_bwmode23a(padapter, pmlmeext->cur_channel,
-                  pmlmeext->cur_ch_offset, pmlmeext->cur_bwmode); */
-
-               /* update ap's stainfo */
-               psta = rtw_get_stainfo23a(pstapriv, cur_network->MacAddress);
-               if (psta) {
-                       struct ht_priv *phtpriv_sta = &psta->htpriv;
-
-                       if (phtpriv_sta->ht_option) {
-                               /*  bwmode */
-                               phtpriv_sta->bwmode = pmlmeext->cur_bwmode;
-                               phtpriv_sta->ch_offset =
-                                       pmlmeext->cur_ch_offset;
-                       } else {
-                               phtpriv_sta->bwmode = HT_CHANNEL_WIDTH_20;
-                               phtpriv_sta->ch_offset =
-                                       HAL_PRIME_CHNL_OFFSET_DONT_CARE;
-                       }
-               }
-       }
-}
-
-void HT_caps_handler23a(struct rtw_adapter *padapter, const u8 *p)
-{
-       unsigned int i;
-       u8 rf_type;
-       u8 max_AMPDU_len, min_MPDU_spacing;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct ht_priv *phtpriv = &pmlmepriv->htpriv;
-       struct ieee80211_ht_cap *cap;
-       u8 *dstcap;
-
-       if (!p)
-               return;
-
-       if (!phtpriv->ht_option)
-               return;
-
-       pmlmeinfo->HT_caps_enable = 1;
-
-       cap = &pmlmeinfo->ht_cap;
-       dstcap = (u8 *)cap;
-       for (i = 0; i < p[1]; i++) {
-               if (i != 2) {
-                       dstcap[i] &= p[i + 2];
-               } else {
-                       /* modify from  fw by Thomas 2010/11/17 */
-                       if ((cap->ampdu_params_info &
-                            IEEE80211_HT_AMPDU_PARM_FACTOR) >
-                           (p[i + 2] & IEEE80211_HT_AMPDU_PARM_FACTOR))
-                               max_AMPDU_len = p[i + 2] &
-                                       IEEE80211_HT_AMPDU_PARM_FACTOR;
-                       else
-                               max_AMPDU_len = cap->ampdu_params_info &
-                                       IEEE80211_HT_AMPDU_PARM_FACTOR;
-
-                       if ((cap->ampdu_params_info &
-                            IEEE80211_HT_AMPDU_PARM_DENSITY) >
-                           (p[i + 2] & IEEE80211_HT_AMPDU_PARM_DENSITY))
-                               min_MPDU_spacing = cap->ampdu_params_info &
-                                       IEEE80211_HT_AMPDU_PARM_DENSITY;
-                       else
-                               min_MPDU_spacing = p[i + 2] &
-                                       IEEE80211_HT_AMPDU_PARM_DENSITY;
-
-                       cap->ampdu_params_info =
-                               max_AMPDU_len | min_MPDU_spacing;
-               }
-       }
-
-       rf_type = rtl8723a_get_rf_type(padapter);
-
-       /* update the MCS rates */
-       for (i = 0; i < IEEE80211_HT_MCS_MASK_LEN; i++) {
-               if (rf_type == RF_1T1R || rf_type == RF_1T2R)
-                       cap->mcs.rx_mask[i] &= MCS_rate_1R23A[i];
-               else
-                       cap->mcs.rx_mask[i] &= MCS_rate_2R23A[i];
-       }
-}
-
-void HT_info_handler23a(struct rtw_adapter *padapter, const u8 *p)
-{
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct ht_priv *phtpriv = &pmlmepriv->htpriv;
-
-       if (!p)
-               return;
-
-       if (!phtpriv->ht_option)
-               return;
-
-       if (p[1] != sizeof(struct ieee80211_ht_operation))
-               return;
-
-       pmlmeinfo->HT_info_enable = 1;
-       memcpy(&pmlmeinfo->HT_info, p + 2, p[1]);
-}
-
-void HTOnAssocRsp23a(struct rtw_adapter *padapter)
-{
-       unsigned char max_AMPDU_len;
-       unsigned char min_MPDU_spacing;
-       /* struct registry_priv  *pregpriv = &padapter->registrypriv; */
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-
-       DBG_8723A("%s\n", __func__);
-
-       if (pmlmeinfo->HT_info_enable && pmlmeinfo->HT_caps_enable)
-               pmlmeinfo->HT_enable = 1;
-       else {
-               pmlmeinfo->HT_enable = 0;
-               /* set_channel_bwmode23a(padapter, pmlmeext->cur_channel,
-                  pmlmeext->cur_ch_offset, pmlmeext->cur_bwmode); */
-               return;
-       }
-
-       /* handle A-MPDU parameter field */
-       /*
-               AMPDU_para [1:0]:Max AMPDU Len => 0:8k , 1:16k, 2:32k, 3:64k
-               AMPDU_para [4:2]:Min MPDU Start Spacing
-       */
-       max_AMPDU_len = pmlmeinfo->ht_cap.ampdu_params_info &
-               IEEE80211_HT_AMPDU_PARM_FACTOR;
-
-       min_MPDU_spacing =
-               (pmlmeinfo->ht_cap.ampdu_params_info &
-                IEEE80211_HT_AMPDU_PARM_DENSITY) >> 2;
-
-       rtl8723a_set_ampdu_min_space(padapter, min_MPDU_spacing);
-       rtl8723a_set_ampdu_factor(padapter, max_AMPDU_len);
-}
-
-void ERP_IE_handler23a(struct rtw_adapter *padapter, const u8 *p)
-{
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-
-       if (p[1] > 1)
-               return;
-
-       pmlmeinfo->ERP_enable = 1;
-       memcpy(&pmlmeinfo->ERP_IE, p + 2, p[1]);
-}
-
-void VCS_update23a(struct rtw_adapter *padapter, struct sta_info *psta)
-{
-       struct registry_priv *pregpriv = &padapter->registrypriv;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-
-       switch (pregpriv->vrtl_carrier_sense) { /* 0:off 1:on 2:auto */
-       case 0: /* off */
-               psta->rtsen = 0;
-               psta->cts2self = 0;
-               break;
-       case 1: /* on */
-               if (pregpriv->vcs_type == RTS_CTS) {
-                       psta->rtsen = 1;
-                       psta->cts2self = 0;
-               } else {
-                       psta->rtsen = 0;
-                       psta->cts2self = 1;
-               }
-               break;
-       case 2: /* auto */
-       default:
-               if (pmlmeinfo->ERP_enable && pmlmeinfo->ERP_IE & BIT(1)) {
-                       if (pregpriv->vcs_type == RTS_CTS) {
-                               psta->rtsen = 1;
-                               psta->cts2self = 0;
-                       } else {
-                               psta->rtsen = 0;
-                               psta->cts2self = 1;
-                       }
-               } else {
-                       psta->rtsen = 0;
-                       psta->cts2self = 0;
-               }
-               break;
-       }
-}
-
-int rtw_check_bcn_info23a(struct rtw_adapter *Adapter,
-                         struct ieee80211_mgmt *mgmt, u32 pkt_len)
-{
-       struct wlan_network *cur_network = &Adapter->mlmepriv.cur_network;
-       struct ieee80211_ht_operation *pht_info;
-       unsigned short val16;
-       u8 crypto, bcn_channel;
-       int group_cipher = 0, pairwise_cipher = 0, is_8021x = 0, r;
-       int pie_len, ssid_len, privacy;
-       const u8 *p, *ssid;
-
-       if (!is_client_associated_to_ap23a(Adapter))
-               return _SUCCESS;
-
-       if (unlikely(!ieee80211_is_beacon(mgmt->frame_control))) {
-               printk(KERN_WARNING "%s: received a non beacon frame!\n",
-                      __func__);
-               return _FAIL;
-       }
-
-       if (!ether_addr_equal(cur_network->network.MacAddress, mgmt->bssid)) {
-               DBG_8723A("%s: linked but recv other bssid bcn %pM %pM\n",
-                         __func__, mgmt->bssid,
-                         cur_network->network.MacAddress);
-               return _FAIL;
-       }
-
-       /* check bw and channel offset */
-       /* parsing HT_CAP_IE */
-       pie_len = pkt_len - offsetof(struct ieee80211_mgmt, u.beacon.variable);
-
-       /* Checking for channel */
-       p = cfg80211_find_ie(WLAN_EID_DS_PARAMS, mgmt->u.beacon.variable,
-                            pie_len);
-       if (p)
-               bcn_channel = p[2];
-       else {
-               /* In 5G, some ap do not have DSSET IE checking HT
-                  info for channel */
-               p = cfg80211_find_ie(WLAN_EID_HT_OPERATION,
-                                    mgmt->u.beacon.variable, pie_len);
-
-               if (p && p[1] > 0) {
-                       pht_info = (struct ieee80211_ht_operation *)(p + 2);
-                       bcn_channel = pht_info->primary_chan;
-               } else { /* we don't find channel IE, so don't check it */
-                       DBG_8723A("Oops: %s we don't find channel IE, so don't "
-                                 "check it\n", __func__);
-                       bcn_channel = Adapter->mlmeextpriv.cur_channel;
-               }
-       }
-       if (bcn_channel != Adapter->mlmeextpriv.cur_channel) {
-               DBG_8723A("%s beacon channel:%d cur channel:%d disconnect\n",
-                         __func__, bcn_channel,
-                         Adapter->mlmeextpriv.cur_channel);
-               goto _mismatch;
-       }
-
-       /* checking SSID */
-       p = cfg80211_find_ie(WLAN_EID_SSID, mgmt->u.beacon.variable, pie_len);
-       if (p && p[1]) {
-               ssid = p + 2;
-               ssid_len = p[1];
-       } else {
-               DBG_8723A("%s marc: cannot find SSID for survey event\n",
-                         __func__);
-               ssid = NULL;
-               ssid_len = 0;
-       }
-
-       RT_TRACE(_module_rtl871x_mlme_c_, _drv_info_,
-                "%s bssid.Ssid.Ssid:%s bssid.Ssid.SsidLength:%d cur_network->network.Ssid.Ssid:%s len:%d\n",
-                __func__, ssid, ssid_len, cur_network->network.Ssid.ssid,
-                cur_network->network.Ssid.ssid_len);
-
-       if (ssid_len != cur_network->network.Ssid.ssid_len || ssid_len > 32 ||
-           (ssid_len &&
-            memcmp(ssid, cur_network->network.Ssid.ssid, ssid_len))) {
-               DBG_8723A("%s(), SSID is not match return FAIL\n", __func__);
-               goto _mismatch;
-       }
-
-       /* check encryption info */
-       val16 = le16_to_cpu(mgmt->u.beacon.capab_info);
-
-       if (val16 & WLAN_CAPABILITY_PRIVACY)
-               privacy = 1;
-       else
-               privacy = 0;
-
-       RT_TRACE(_module_rtl871x_mlme_c_, _drv_info_,
-                "%s(): cur_network->network.Privacy is %d, bssid.Privacy is %d\n",
-                __func__, cur_network->network.Privacy, privacy);
-       if (cur_network->network.Privacy != privacy) {
-               DBG_8723A("%s(), privacy is not match return FAIL\n", __func__);
-               goto _mismatch;
-       }
-
-       p = cfg80211_find_ie(WLAN_EID_RSN, mgmt->u.beacon.variable, pie_len);
-       if (p && p[1]) {
-               crypto = ENCRYP_PROTOCOL_WPA2;
-               if (p && p[1]) {
-                       r = rtw_parse_wpa2_ie23a(p, p[1] + 2, &group_cipher,
-                                                &pairwise_cipher, &is_8021x);
-                       if (r == _SUCCESS)
-                               RT_TRACE(_module_rtl871x_mlme_c_, _drv_info_,
-                                        "%s pnetwork->pairwise_cipher: %d, pnetwork->group_cipher: %d, is_802x : %d\n",
-                                        __func__, pairwise_cipher,
-                                        group_cipher, is_8021x);
-                       }
-       } else {
-               p = cfg80211_find_vendor_ie(WLAN_OUI_MICROSOFT,
-                                           WLAN_OUI_TYPE_MICROSOFT_WPA,
-                                           mgmt->u.beacon.variable, pie_len);
-               if (p && p[1]) {
-                       crypto = ENCRYP_PROTOCOL_WPA;
-                       r = rtw_parse_wpa_ie23a(p, p[1] + 2, &group_cipher,
-                                               &pairwise_cipher, &is_8021x);
-                       if (r == _SUCCESS)
-                               RT_TRACE(_module_rtl871x_mlme_c_, _drv_info_,
-                                        "%s pnetwork->pairwise_cipher: %d, group_cipher is %d, is_8021x is %d\n",
-                                        __func__, pairwise_cipher,
-                                        group_cipher, is_8021x);
-               } else {
-                       if (privacy)
-                               crypto = ENCRYP_PROTOCOL_WEP;
-                       else
-                               crypto = ENCRYP_PROTOCOL_OPENSYS;
-               }
-       }
-
-       if (cur_network->BcnInfo.encryp_protocol != crypto) {
-               DBG_8723A("%s(): encryption mismatch, return FAIL\n", __func__);
-               goto _mismatch;
-       }
-
-       if (crypto == ENCRYP_PROTOCOL_WPA || crypto == ENCRYP_PROTOCOL_WPA2) {
-               RT_TRACE(_module_rtl871x_mlme_c_, _drv_err_,
-                        "%s cur_network->group_cipher is %d: %d\n", __func__,
-                        cur_network->BcnInfo.group_cipher, group_cipher);
-               if (pairwise_cipher != cur_network->BcnInfo.pairwise_cipher ||
-                   group_cipher != cur_network->BcnInfo.group_cipher) {
-                       DBG_8723A("%s pairwise_cipher(%x:%x) or group_cipher "
-                                 "(%x:%x) is not match, return FAIL\n",
-                                 __func__, pairwise_cipher,
-                                 cur_network->BcnInfo.pairwise_cipher,
-                                 group_cipher,
-                                 cur_network->BcnInfo.group_cipher);
-                       goto _mismatch;
-               }
-
-               if (is_8021x != cur_network->BcnInfo.is_8021x) {
-                       DBG_8723A("%s authentication is not match, return "
-                                 "FAIL\n", __func__);
-                       goto _mismatch;
-               }
-       }
-
-       return _SUCCESS;
-
-_mismatch:
-
-       return _FAIL;
-}
-
-void update_beacon23a_info(struct rtw_adapter *padapter,
-                          struct ieee80211_mgmt *mgmt,
-                          uint pkt_len, struct sta_info *psta)
-{
-       unsigned int len;
-       const u8 *p;
-
-       len = pkt_len - offsetof(struct ieee80211_mgmt, u.beacon.variable);
-
-       p = cfg80211_find_ie(WLAN_EID_HT_OPERATION, mgmt->u.beacon.variable,
-                            len);
-       if (p)
-               bwmode_update_check(padapter, p);
-
-       p = cfg80211_find_ie(WLAN_EID_ERP_INFO, mgmt->u.beacon.variable, len);
-       if (p) {
-               ERP_IE_handler23a(padapter, p);
-               VCS_update23a(padapter, psta);
-       }
-}
-
-bool is_ap_in_tkip23a(struct rtw_adapter *padapter)
-{
-       u32 i;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       struct wlan_bssid_ex *cur_network = &pmlmeinfo->network;
-       const u8 *p;
-
-       if (cur_network->capability & WLAN_CAPABILITY_PRIVACY) {
-               for (i = 0; i < pmlmeinfo->network.IELength;) {
-                       p = pmlmeinfo->network.IEs + i;
-
-                       switch (p[0]) {
-                       case WLAN_EID_VENDOR_SPECIFIC:
-                               if (!memcmp(p + 2, RTW_WPA_OUI23A_TYPE, 4) &&
-                                   !memcmp(p + 2 + 12, WPA_TKIP_CIPHER, 4))
-                                       return true;
-                               break;
-                       case WLAN_EID_RSN:
-                               if (!memcmp(p + 2 + 8, RSN_TKIP_CIPHER, 4))
-                                       return true;
-                               break;
-                       default:
-                               break;
-                       }
-                       i += (p[1] + 2);
-               }
-               return false;
-       } else
-               return false;
-}
-
-bool should_forbid_n_rate23a(struct rtw_adapter *padapter)
-{
-       u32 i;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct wlan_bssid_ex  *cur_network = &pmlmepriv->cur_network.network;
-       const u8 *p;
-
-       if (cur_network->capability & WLAN_CAPABILITY_PRIVACY) {
-               for (i = 0; i < cur_network->IELength;) {
-                       p = cur_network->IEs + i;
-
-                       switch (p[0]) {
-                       case WLAN_EID_VENDOR_SPECIFIC:
-                               if (!memcmp(p + 2, RTW_WPA_OUI23A_TYPE, 4) &&
-                                   (!memcmp(p + 2 + 12,
-                                            WPA_CIPHER_SUITE_CCMP23A, 4) ||
-                                    !memcmp(p + 2 + 16,
-                                            WPA_CIPHER_SUITE_CCMP23A, 4)))
-                                       return false;
-                               break;
-                       case WLAN_EID_RSN:
-                               if (!memcmp(p + 2 + 8,
-                                           RSN_CIPHER_SUITE_CCMP23A, 4) ||
-                                   !memcmp(p + 2 + 12,
-                                           RSN_CIPHER_SUITE_CCMP23A, 4))
-                               return false;
-                       default:
-                               break;
-                       }
-
-                       i += (p[1] + 2);
-               }
-               return true;
-       } else {
-               return false;
-       }
-}
-
-bool is_ap_in_wep23a(struct rtw_adapter *padapter)
-{
-       u32 i;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       struct wlan_bssid_ex *cur_network = &pmlmeinfo->network;
-       const u8 *p;
-
-       if (cur_network->capability & WLAN_CAPABILITY_PRIVACY) {
-               for (i = 0; i < pmlmeinfo->network.IELength;) {
-                       p = pmlmeinfo->network.IEs + i;
-
-                       switch (p[0]) {
-                       case WLAN_EID_VENDOR_SPECIFIC:
-                               if (!memcmp(p + 2, RTW_WPA_OUI23A_TYPE, 4))
-                                       return false;
-                               break;
-                       case WLAN_EID_RSN:
-                               return false;
-
-                       default:
-                               break;
-                       }
-
-                       i += (p[1] + 2);
-               }
-
-               return true;
-       } else
-               return false;
-}
-
-static int wifirate2_ratetbl_inx23a(unsigned char rate)
-{
-       int inx = 0;
-
-       rate = rate & 0x7f;
-
-       switch (rate) {
-       case 54*2:
-               inx = 11;
-               break;
-       case 48*2:
-               inx = 10;
-               break;
-       case 36*2:
-               inx = 9;
-               break;
-       case 24*2:
-               inx = 8;
-               break;
-       case 18*2:
-               inx = 7;
-               break;
-       case 12*2:
-               inx = 6;
-               break;
-       case 9*2:
-               inx = 5;
-               break;
-       case 6*2:
-               inx = 4;
-               break;
-       case 11*2:
-               inx = 3;
-               break;
-       case 11:
-               inx = 2;
-               break;
-       case 2*2:
-               inx = 1;
-               break;
-       case 1*2:
-               inx = 0;
-               break;
-       }
-       return inx;
-}
-
-unsigned int update_basic_rate23a(unsigned char *ptn, unsigned int ptn_sz)
-{
-       unsigned int i, num_of_rate;
-       unsigned int mask = 0;
-
-       num_of_rate = (ptn_sz > NumRates)? NumRates: ptn_sz;
-
-       for (i = 0; i < num_of_rate; i++) {
-               if ((*(ptn + i)) & 0x80)
-                       mask |= 0x1 << wifirate2_ratetbl_inx23a(*(ptn + i));
-       }
-       return mask;
-}
-
-unsigned int update_supported_rate23a(unsigned char *ptn, unsigned int ptn_sz)
-{
-       unsigned int i, num_of_rate;
-       unsigned int mask = 0;
-
-       num_of_rate = (ptn_sz > NumRates) ? NumRates : ptn_sz;
-
-       for (i = 0; i < num_of_rate; i++)
-               mask |= 0x1 << wifirate2_ratetbl_inx23a(*(ptn + i));
-       return mask;
-}
-
-unsigned int update_MSC_rate23a(struct ieee80211_ht_cap *pHT_caps)
-{
-       unsigned int mask;
-
-       mask = pHT_caps->mcs.rx_mask[0] << 12 |
-               pHT_caps->mcs.rx_mask[1] << 20;
-
-       return mask;
-}
-
-int support_short_GI23a(struct rtw_adapter *padapter,
-                       struct ieee80211_ht_cap *pHT_caps)
-{
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       unsigned char bit_offset;
-
-       if (!pmlmeinfo->HT_enable)
-               return _FAIL;
-       if (pmlmeinfo->assoc_AP_vendor == HT_IOT_PEER_RALINK)
-               return _FAIL;
-       bit_offset = (pmlmeext->cur_bwmode & HT_CHANNEL_WIDTH_40)? 6: 5;
-
-       if (pHT_caps->cap_info & cpu_to_le16(0x1 << bit_offset))
-               return _SUCCESS;
-       else
-               return _FAIL;
-}
-
-unsigned char get_highest_rate_idx23a(u32 mask)
-{
-       int i;
-       unsigned char rate_idx = 0;
-
-       for (i = 27; i >= 0; i--) {
-               if (mask & BIT(i)) {
-                       rate_idx = i;
-                       break;
-               }
-       }
-       return rate_idx;
-}
-
-void Update_RA_Entry23a(struct rtw_adapter *padapter, struct sta_info *psta)
-{
-       rtw_hal_update_ra_mask23a(psta, 0);
-}
-
-static void enable_rate_adaptive(struct rtw_adapter *padapter,
-                                struct sta_info *psta)
-{
-       Update_RA_Entry23a(padapter, psta);
-}
-
-void set_sta_rate23a(struct rtw_adapter *padapter, struct sta_info *psta)
-{
-       /* rate adaptive */
-       enable_rate_adaptive(padapter, psta);
-}
-
-/*  Update RRSR and Rate for USERATE */
-void update_tx_basic_rate23a(struct rtw_adapter *padapter, u8 wirelessmode)
-{
-       unsigned char supported_rates[NDIS_802_11_LENGTH_RATES_EX];
-
-       memset(supported_rates, 0, NDIS_802_11_LENGTH_RATES_EX);
-
-       if (wirelessmode == WIRELESS_11B) {
-               memcpy(supported_rates, rtw_basic_rate_cck, 4);
-       } else if (wirelessmode & WIRELESS_11B) {
-               memcpy(supported_rates, rtw_basic_rate_mix, 7);
-       } else {
-               memcpy(supported_rates, rtw_basic_rate_ofdm, 3);
-       }
-
-       if (wirelessmode & WIRELESS_11B)
-               update_mgnt_tx_rate23a(padapter, IEEE80211_CCK_RATE_1MB);
-       else
-               update_mgnt_tx_rate23a(padapter, IEEE80211_OFDM_RATE_6MB);
-
-       HalSetBrateCfg23a(padapter, supported_rates);
-}
-
-unsigned char check_assoc_AP23a(u8 *pframe, uint len)
-{
-       int i;
-       u8 epigram_vendor_flag;
-       u8 ralink_vendor_flag;
-       const u8 *p;
-
-       epigram_vendor_flag = 0;
-       ralink_vendor_flag = 0;
-
-       for (i = 0; i < len;) {
-               p = pframe + i;
-
-               switch (p[0]) {
-               case WLAN_EID_VENDOR_SPECIFIC:
-                       if (!memcmp(p + 2, ARTHEROS_OUI1, 3) ||
-                           !memcmp(p + 2, ARTHEROS_OUI2, 3)) {
-                               DBG_8723A("link to Artheros AP\n");
-                               return HT_IOT_PEER_ATHEROS;
-                       } else if (!memcmp(p + 2, BROADCOM_OUI1, 3) ||
-                                  !memcmp(p + 2, BROADCOM_OUI2, 3)) {
-                               DBG_8723A("link to Broadcom AP\n");
-                               return HT_IOT_PEER_BROADCOM;
-                       } else if (!memcmp(p + 2, MARVELL_OUI, 3)) {
-                               DBG_8723A("link to Marvell AP\n");
-                               return HT_IOT_PEER_MARVELL;
-                       } else if (!memcmp(p + 2, RALINK_OUI, 3)) {
-                               if (!ralink_vendor_flag)
-                                       ralink_vendor_flag = 1;
-                               else {
-                                       DBG_8723A("link to Ralink AP\n");
-                                       return HT_IOT_PEER_RALINK;
-                               }
-                       } else if (!memcmp(p + 2, CISCO_OUI, 3)) {
-                               DBG_8723A("link to Cisco AP\n");
-                               return HT_IOT_PEER_CISCO;
-                       } else if (!memcmp(p + 2, REALTEK_OUI, 3)) {
-                               DBG_8723A("link to Realtek 96B\n");
-                               return HT_IOT_PEER_REALTEK;
-                       } else if (!memcmp(p + 2, AIRGOCAP_OUI, 3)) {
-                               DBG_8723A("link to Airgo Cap\n");
-                               return HT_IOT_PEER_AIRGO;
-                       } else if (!memcmp(p + 2, EPIGRAM_OUI, 3)) {
-                               epigram_vendor_flag = 1;
-                               if (ralink_vendor_flag) {
-                                       DBG_8723A("link to Tenda W311R AP\n");
-                                       return HT_IOT_PEER_TENDA;
-                               } else
-                                       DBG_8723A("Capture EPIGRAM_OUI\n");
-                       } else
-                               break;
-               default:
-                       break;
-               }
-
-               i += (p[1] + 2);
-       }
-
-       if (ralink_vendor_flag && !epigram_vendor_flag) {
-               DBG_8723A("link to Ralink AP\n");
-               return HT_IOT_PEER_RALINK;
-       } else if (ralink_vendor_flag && epigram_vendor_flag) {
-               DBG_8723A("link to Tenda W311R AP\n");
-               return HT_IOT_PEER_TENDA;
-       } else {
-               DBG_8723A("link to new AP\n");
-               return HT_IOT_PEER_UNKNOWN;
-       }
-}
-
-void update_IOT_info23a(struct rtw_adapter *padapter)
-{
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-
-       switch (pmlmeinfo->assoc_AP_vendor) {
-       case HT_IOT_PEER_MARVELL:
-               pmlmeinfo->turboMode_cts2self = 1;
-               pmlmeinfo->turboMode_rtsen = 0;
-               break;
-       case HT_IOT_PEER_RALINK:
-               pmlmeinfo->turboMode_cts2self = 0;
-               pmlmeinfo->turboMode_rtsen = 1;
-               /* disable high power */
-               rtl8723a_odm_support_ability_clr(padapter, (u32)
-                                                ~DYNAMIC_BB_DYNAMIC_TXPWR);
-               break;
-       case HT_IOT_PEER_REALTEK:
-               /* rtw_write16(padapter, 0x4cc, 0xffff); */
-               /* rtw_write16(padapter, 0x546, 0x01c0); */
-               /* disable high power */
-               rtl8723a_odm_support_ability_clr(padapter, (u32)
-                                                ~DYNAMIC_BB_DYNAMIC_TXPWR);
-               break;
-       default:
-               pmlmeinfo->turboMode_cts2self = 0;
-               pmlmeinfo->turboMode_rtsen = 1;
-               break;
-       }
-}
-
-void update_capinfo23a(struct rtw_adapter *Adapter, u16 updateCap)
-{
-       struct mlme_ext_priv *pmlmeext = &Adapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-
-       if (updateCap & cShortPreamble) {
-               /*  Short Preamble */
-               if (pmlmeinfo->preamble_mode != PREAMBLE_SHORT) {
-                       /*  PREAMBLE_LONG or PREAMBLE_AUTO */
-                       pmlmeinfo->preamble_mode = PREAMBLE_SHORT;
-                       rtl8723a_ack_preamble(Adapter, true);
-               }
-       } else { /*  Long Preamble */
-               if (pmlmeinfo->preamble_mode != PREAMBLE_LONG) {
-                       /*  PREAMBLE_SHORT or PREAMBLE_AUTO */
-                       pmlmeinfo->preamble_mode = PREAMBLE_LONG;
-                       rtl8723a_ack_preamble(Adapter, false);
-               }
-       }
-       if (updateCap & cIBSS) {
-               /* Filen: See 802.11-2007 p.91 */
-               pmlmeinfo->slotTime = NON_SHORT_SLOT_TIME;
-       } else {
-               /* Filen: See 802.11-2007 p.90 */
-               if (pmlmeext->cur_wireless_mode &
-                   (WIRELESS_11G | WIRELESS_11_24N)) {
-                       if (updateCap & cShortSlotTime) { /*  Short Slot Time */
-                               if (pmlmeinfo->slotTime != SHORT_SLOT_TIME)
-                                       pmlmeinfo->slotTime = SHORT_SLOT_TIME;
-                       } else { /*  Long Slot Time */
-                               if (pmlmeinfo->slotTime != NON_SHORT_SLOT_TIME)
-                                       pmlmeinfo->slotTime =
-                                               NON_SHORT_SLOT_TIME;
-                       }
-               } else if (pmlmeext->cur_wireless_mode &
-                          (WIRELESS_11A | WIRELESS_11_5N)) {
-                       pmlmeinfo->slotTime = SHORT_SLOT_TIME;
-               } else {
-                       /* B Mode */
-                       pmlmeinfo->slotTime = NON_SHORT_SLOT_TIME;
-               }
-       }
-       rtl8723a_set_slot_time(Adapter, pmlmeinfo->slotTime);
-}
-
-void update_wireless_mode23a(struct rtw_adapter *padapter)
-{
-       int ratelen, network_type = 0;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       struct wlan_bssid_ex *cur_network = &pmlmeinfo->network;
-       unsigned char *rate = cur_network->SupportedRates;
-
-       ratelen = rtw_get_rateset_len23a(cur_network->SupportedRates);
-
-       if ((pmlmeinfo->HT_info_enable) && (pmlmeinfo->HT_caps_enable))
-               pmlmeinfo->HT_enable = 1;
-
-       if (pmlmeext->cur_channel > 14) {
-               if (pmlmeinfo->HT_enable)
-                       network_type = WIRELESS_11_5N;
-               network_type |= WIRELESS_11A;
-       } else {
-               if (pmlmeinfo->HT_enable)
-                       network_type = WIRELESS_11_24N;
-
-               if (cckratesonly_included23a(rate, ratelen) == true)
-                       network_type |= WIRELESS_11B;
-               else if (cckrates_included23a(rate, ratelen) == true)
-                       network_type |= WIRELESS_11BG;
-               else
-                       network_type |= WIRELESS_11G;
-       }
-
-       pmlmeext->cur_wireless_mode =
-               network_type & padapter->registrypriv.wireless_mode;
-
-       /* 0x0808 -> for CCK, 0x0a0a -> for OFDM */
-       /* change this value if having IOT issues. */
-       rtl8723a_set_resp_sifs(padapter, 0x08, 0x08, 0x0a, 0x0a);
-
-       if (pmlmeext->cur_wireless_mode & WIRELESS_11B)
-               update_mgnt_tx_rate23a(padapter, IEEE80211_CCK_RATE_1MB);
-        else
-               update_mgnt_tx_rate23a(padapter, IEEE80211_OFDM_RATE_6MB);
-}
-
-void update_bmc_sta_support_rate23a(struct rtw_adapter *padapter, u32 mac_id)
-{
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-
-       if (pmlmeext->cur_wireless_mode & WIRELESS_11B) {
-               /*  Only B, B/G, and B/G/N AP could use CCK rate */
-               memcpy((pmlmeinfo->FW_sta_info[mac_id].SupportedRates),
-                      rtw_basic_rate_cck, 4);
-       } else {
-               memcpy(pmlmeinfo->FW_sta_info[mac_id].SupportedRates,
-                      rtw_basic_rate_ofdm, 3);
-       }
-}
-
-int update_sta_support_rate23a(struct rtw_adapter *padapter, u8 *pvar_ie,
-                              uint var_ie_len, int cam_idx)
-{
-       int supportRateNum = 0;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       const u8 *p;
-
-       p = cfg80211_find_ie(WLAN_EID_SUPP_RATES, pvar_ie, var_ie_len);
-       if (!p)
-               return _FAIL;
-
-       memcpy(pmlmeinfo->FW_sta_info[cam_idx].SupportedRates, p + 2, p[1]);
-       supportRateNum = p[1];
-
-       p = cfg80211_find_ie(WLAN_EID_EXT_SUPP_RATES, pvar_ie, var_ie_len);
-       if (p)
-               memcpy(pmlmeinfo->FW_sta_info[cam_idx].SupportedRates +
-                      supportRateNum, p + 2, p[1]);
-       return _SUCCESS;
-}
-
-void process_addba_req23a(struct rtw_adapter *padapter,
-                         u8 *paddba_req, u8 *addr)
-{
-       struct sta_info *psta;
-       u16 tid, start_seq, param;
-       struct recv_reorder_ctrl *preorder_ctrl;
-       struct sta_priv *pstapriv = &padapter->stapriv;
-       struct ADDBA_request *preq = (struct ADDBA_request *)paddba_req;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-
-       psta = rtw_get_stainfo23a(pstapriv, addr);
-
-       if (psta) {
-               start_seq = le16_to_cpu(preq->BA_starting_seqctrl) >> 4;
-
-               param = le16_to_cpu(preq->BA_para_set);
-               tid = (param >> 2) & 0x0f;
-
-               preorder_ctrl = &psta->recvreorder_ctrl[tid];
-
-               preorder_ctrl->indicate_seq = 0xffff;
-
-               preorder_ctrl->enable = (pmlmeinfo->bAcceptAddbaReq == true) ?
-                       true : false;
-       }
-}
diff --git a/drivers/staging/rtl8723au/core/rtw_xmit.c b/drivers/staging/rtl8723au/core/rtw_xmit.c
deleted file mode 100644 (file)
index 003576d..0000000
+++ /dev/null
@@ -1,2337 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#define _RTW_XMIT_C_
-
-#include <osdep_service.h>
-#include <drv_types.h>
-#include <wifi.h>
-#include <osdep_intf.h>
-#include <linux/ip.h>
-#include <usb_ops.h>
-#include <rtl8723a_xmit.h>
-
-static void _init_txservq(struct tx_servq *ptxservq)
-{
-
-       INIT_LIST_HEAD(&ptxservq->tx_pending);
-       _rtw_init_queue23a(&ptxservq->sta_pending);
-       ptxservq->qcnt = 0;
-
-}
-
-void   _rtw_init_sta_xmit_priv23a(struct sta_xmit_priv *psta_xmitpriv)
-{
-
-       spin_lock_init(&psta_xmitpriv->lock);
-
-       /* for (i = 0 ; i < MAX_NUMBLKS; i++) */
-       /*      _init_txservq(&psta_xmitpriv->blk_q[i]); */
-
-       _init_txservq(&psta_xmitpriv->be_q);
-       _init_txservq(&psta_xmitpriv->bk_q);
-       _init_txservq(&psta_xmitpriv->vi_q);
-       _init_txservq(&psta_xmitpriv->vo_q);
-       INIT_LIST_HEAD(&psta_xmitpriv->legacy_dz);
-       INIT_LIST_HEAD(&psta_xmitpriv->apsd);
-
-}
-
-int _rtw_init_xmit_priv23a(struct xmit_priv *pxmitpriv,
-                          struct rtw_adapter *padapter)
-{
-       int i;
-       struct xmit_buf *pxmitbuf;
-       struct xmit_frame *pxframe;
-       int res = _SUCCESS;
-       u32 max_xmit_extbuf_size = MAX_XMIT_EXTBUF_SZ;
-       u32 num_xmit_extbuf = NR_XMIT_EXTBUFF;
-
-       spin_lock_init(&pxmitpriv->lock);
-       spin_lock_init(&pxmitpriv->lock_sctx);
-
-       pxmitpriv->adapter = padapter;
-
-       _rtw_init_queue23a(&pxmitpriv->be_pending);
-       _rtw_init_queue23a(&pxmitpriv->bk_pending);
-       _rtw_init_queue23a(&pxmitpriv->vi_pending);
-       _rtw_init_queue23a(&pxmitpriv->vo_pending);
-       _rtw_init_queue23a(&pxmitpriv->bm_pending);
-
-       _rtw_init_queue23a(&pxmitpriv->free_xmit_queue);
-
-       for (i = 0; i < NR_XMITFRAME; i++) {
-               pxframe = kzalloc(sizeof(struct xmit_frame), GFP_KERNEL);
-               if (!pxframe)
-                       break;
-               INIT_LIST_HEAD(&pxframe->list);
-
-               pxframe->padapter = padapter;
-               pxframe->frame_tag = NULL_FRAMETAG;
-
-               list_add_tail(&pxframe->list,
-                             &pxmitpriv->free_xmit_queue.queue);
-       }
-
-       pxmitpriv->free_xmitframe_cnt = i;
-
-       pxmitpriv->frag_len = MAX_FRAG_THRESHOLD;
-
-       /* init xmit_buf */
-       _rtw_init_queue23a(&pxmitpriv->free_xmitbuf_queue);
-       INIT_LIST_HEAD(&pxmitpriv->xmitbuf_list);
-       _rtw_init_queue23a(&pxmitpriv->pending_xmitbuf_queue);
-
-       for (i = 0; i < NR_XMITBUFF; i++) {
-               pxmitbuf = kzalloc(sizeof(struct xmit_buf), GFP_KERNEL);
-               if (!pxmitbuf)
-                       goto fail;
-               INIT_LIST_HEAD(&pxmitbuf->list);
-               INIT_LIST_HEAD(&pxmitbuf->list2);
-
-               pxmitbuf->padapter = padapter;
-
-               /* Tx buf allocation may fail sometimes, so sleep and retry. */
-               res = rtw_os_xmit_resource_alloc23a(padapter, pxmitbuf,
-                                                (MAX_XMITBUF_SZ + XMITBUF_ALIGN_SZ));
-               if (res == _FAIL) {
-                       goto fail;
-               }
-
-               list_add_tail(&pxmitbuf->list,
-                             &pxmitpriv->free_xmitbuf_queue.queue);
-               list_add_tail(&pxmitbuf->list2,
-                             &pxmitpriv->xmitbuf_list);
-       }
-
-       pxmitpriv->free_xmitbuf_cnt = NR_XMITBUFF;
-
-       /* init xframe_ext queue,  the same count as extbuf  */
-       _rtw_init_queue23a(&pxmitpriv->free_xframe_ext_queue);
-
-       for (i = 0; i < num_xmit_extbuf; i++) {
-               pxframe = kzalloc(sizeof(struct xmit_frame), GFP_KERNEL);
-               if (!pxframe)
-                       break;
-               INIT_LIST_HEAD(&pxframe->list);
-
-               pxframe->padapter = padapter;
-               pxframe->frame_tag = NULL_FRAMETAG;
-
-               pxframe->pkt = NULL;
-
-               pxframe->buf_addr = NULL;
-               pxframe->pxmitbuf = NULL;
-
-               pxframe->ext_tag = 1;
-
-               list_add_tail(&pxframe->list,
-                             &pxmitpriv->free_xframe_ext_queue.queue);
-       }
-       pxmitpriv->free_xframe_ext_cnt = i;
-
-       /*  Init xmit extension buff */
-       _rtw_init_queue23a(&pxmitpriv->free_xmit_extbuf_queue);
-       INIT_LIST_HEAD(&pxmitpriv->xmitextbuf_list);
-
-       for (i = 0; i < num_xmit_extbuf; i++) {
-               pxmitbuf = kzalloc(sizeof(struct xmit_buf), GFP_KERNEL);
-               if (!pxmitbuf)
-                       goto fail;
-               INIT_LIST_HEAD(&pxmitbuf->list);
-               INIT_LIST_HEAD(&pxmitbuf->list2);
-
-               pxmitbuf->padapter = padapter;
-
-               /* Tx buf allocation may fail sometimes, so sleep and retry. */
-               res = rtw_os_xmit_resource_alloc23a(padapter, pxmitbuf,
-                                                max_xmit_extbuf_size + XMITBUF_ALIGN_SZ);
-               if (res == _FAIL) {
-                       goto exit;
-               }
-
-               list_add_tail(&pxmitbuf->list,
-                             &pxmitpriv->free_xmit_extbuf_queue.queue);
-               list_add_tail(&pxmitbuf->list2,
-                             &pxmitpriv->xmitextbuf_list);
-       }
-
-       pxmitpriv->free_xmit_extbuf_cnt = num_xmit_extbuf;
-
-       rtw_alloc_hwxmits23a(padapter);
-       rtw_init_hwxmits23a(pxmitpriv->hwxmits, pxmitpriv->hwxmit_entry);
-
-       for (i = 0; i < 4; i ++)
-               pxmitpriv->wmm_para_seq[i] = i;
-
-       pxmitpriv->ack_tx = false;
-       mutex_init(&pxmitpriv->ack_tx_mutex);
-       rtw_sctx_init23a(&pxmitpriv->ack_tx_ops, 0);
-       tasklet_init(&padapter->xmitpriv.xmit_tasklet,
-                    (void(*)(unsigned long))rtl8723au_xmit_tasklet,
-                    (unsigned long)padapter);
-
-exit:
-
-       return res;
-fail:
-       goto exit;
-}
-
-void _rtw_free_xmit_priv23a(struct xmit_priv *pxmitpriv)
-{
-       struct rtw_adapter *padapter = pxmitpriv->adapter;
-       struct xmit_frame *pxframe, *ptmp;
-       struct xmit_buf *pxmitbuf, *ptmp2;
-
-       list_for_each_entry_safe(pxframe, ptmp,
-                                &pxmitpriv->free_xmit_queue.queue, list) {
-               list_del_init(&pxframe->list);
-               rtw_os_xmit_complete23a(padapter, pxframe);
-               kfree(pxframe);
-       }
-
-       list_for_each_entry_safe(pxmitbuf, ptmp2,
-                                &pxmitpriv->xmitbuf_list, list2) {
-               list_del_init(&pxmitbuf->list2);
-               rtw_os_xmit_resource_free23a(padapter, pxmitbuf);
-               kfree(pxmitbuf);
-       }
-
-       /* free xframe_ext queue,  the same count as extbuf  */
-       list_for_each_entry_safe(pxframe, ptmp,
-                                &pxmitpriv->free_xframe_ext_queue.queue,
-                                list) {
-               list_del_init(&pxframe->list);
-               rtw_os_xmit_complete23a(padapter, pxframe);
-               kfree(pxframe);
-       }
-
-       /*  free xmit extension buff */
-       list_for_each_entry_safe(pxmitbuf, ptmp2,
-                                &pxmitpriv->xmitextbuf_list, list2) {
-               list_del_init(&pxmitbuf->list2);
-               rtw_os_xmit_resource_free23a(padapter, pxmitbuf);
-               kfree(pxmitbuf);
-       }
-
-       rtw_free_hwxmits23a(padapter);
-       mutex_destroy(&pxmitpriv->ack_tx_mutex);
-}
-
-static void update_attrib_vcs_info(struct rtw_adapter *padapter, struct xmit_frame *pxmitframe)
-{
-       u32     sz;
-       struct pkt_attrib       *pattrib = &pxmitframe->attrib;
-       struct sta_info *psta = pattrib->psta;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-
-       if (pattrib->psta) {
-               psta = pattrib->psta;
-       } else {
-               DBG_8723A("%s, call rtw_get_stainfo23a()\n", __func__);
-               psta = rtw_get_stainfo23a(&padapter->stapriv, &pattrib->ra[0]);
-       }
-
-       if (psta == NULL) {
-               DBG_8723A("%s, psta == NUL\n", __func__);
-               return;
-       }
-
-       if (!(psta->state &_FW_LINKED)) {
-               DBG_8723A("%s, psta->state(0x%x) != _FW_LINKED\n", __func__, psta->state);
-               return;
-       }
-
-       if (pattrib->nr_frags != 1)
-               sz = padapter->xmitpriv.frag_len;
-       else /* no frag */
-               sz = pattrib->last_txcmdsz;
-
-       /*  (1) RTS_Threshold is compared to the MPDU, not MSDU. */
-       /*  (2) If there are more than one frag in  this MSDU, only the first frag uses protection frame. */
-       /*              Other fragments are protected by previous fragment. */
-       /*              So we only need to check the length of first fragment. */
-       if (pmlmeext->cur_wireless_mode < WIRELESS_11_24N  || padapter->registrypriv.wifi_spec) {
-               if (sz > padapter->registrypriv.rts_thresh) {
-                       pattrib->vcs_mode = RTS_CTS;
-               } else {
-                       if (psta->rtsen)
-                               pattrib->vcs_mode = RTS_CTS;
-                       else if (psta->cts2self)
-                               pattrib->vcs_mode = CTS_TO_SELF;
-                       else
-                               pattrib->vcs_mode = NONE_VCS;
-               }
-       } else {
-               while (true) {
-                       /* IOT action */
-                       if (pmlmeinfo->assoc_AP_vendor == HT_IOT_PEER_ATHEROS &&
-                           pattrib->ampdu_en &&
-                           padapter->securitypriv.dot11PrivacyAlgrthm ==
-                           WLAN_CIPHER_SUITE_CCMP) {
-                               pattrib->vcs_mode = CTS_TO_SELF;
-                               break;
-                       }
-
-                       /* check ERP protection */
-                       if (psta->rtsen || psta->cts2self) {
-                               if (psta->rtsen)
-                                       pattrib->vcs_mode = RTS_CTS;
-                               else if (psta->cts2self)
-                                       pattrib->vcs_mode = CTS_TO_SELF;
-
-                               break;
-                       }
-
-                       /* check HT op mode */
-                       if (pattrib->ht_en) {
-                               u8 HTOpMode = pmlmeinfo->HT_protection;
-
-                               if ((pmlmeext->cur_bwmode && (HTOpMode == 2 || HTOpMode == 3)) ||
-                                   (!pmlmeext->cur_bwmode && HTOpMode == 3)) {
-                                       pattrib->vcs_mode = RTS_CTS;
-                                       break;
-                               }
-                       }
-
-                       /* check rts */
-                       if (sz > padapter->registrypriv.rts_thresh) {
-                               pattrib->vcs_mode = RTS_CTS;
-                               break;
-                       }
-
-                       /* to do list: check MIMO power save condition. */
-
-                       /* check AMPDU aggregation for TXOP */
-                       if (pattrib->ampdu_en) {
-                               pattrib->vcs_mode = RTS_CTS;
-                               break;
-                       }
-
-                       pattrib->vcs_mode = NONE_VCS;
-                       break;
-               }
-       }
-}
-
-static void update_attrib_phy_info(struct pkt_attrib *pattrib, struct sta_info *psta)
-{
-       /*if (psta->rtsen)
-               pattrib->vcs_mode = RTS_CTS;
-       else if (psta->cts2self)
-               pattrib->vcs_mode = CTS_TO_SELF;
-       else
-               pattrib->vcs_mode = NONE_VCS;*/
-
-       pattrib->mdata = 0;
-       pattrib->eosp = 0;
-       pattrib->triggered = 0;
-
-       /* qos_en, ht_en, init rate, , bw, ch_offset, sgi */
-       pattrib->qos_en = psta->qos_option;
-
-       pattrib->raid = psta->raid;
-       pattrib->ht_en = psta->htpriv.ht_option;
-       pattrib->bwmode = psta->htpriv.bwmode;
-       pattrib->ch_offset = psta->htpriv.ch_offset;
-       pattrib->sgi = psta->htpriv.sgi;
-       pattrib->ampdu_en = false;
-
-       pattrib->retry_ctrl = false;
-}
-
-u8 qos_acm23a(u8 acm_mask, u8 priority)
-{
-       u8 change_priority = priority;
-
-       switch (priority) {
-       case 0:
-       case 3:
-               if (acm_mask & BIT(1))
-                       change_priority = 1;
-               break;
-       case 1:
-       case 2:
-               break;
-       case 4:
-       case 5:
-               if (acm_mask & BIT(2))
-                       change_priority = 0;
-               break;
-       case 6:
-       case 7:
-               if (acm_mask & BIT(3))
-                       change_priority = 5;
-               break;
-       default:
-               DBG_8723A("qos_acm23a(): invalid pattrib->priority: %d!!!\n",
-                         priority);
-               change_priority = 0;
-               break;
-       }
-
-       return change_priority;
-}
-
-static void set_qos(struct sk_buff *skb, struct pkt_attrib *pattrib)
-{
-       u8 *pframe = skb->data;
-       struct iphdr *ip_hdr;
-       u8 UserPriority = 0;
-
-       /*  get UserPriority from IP hdr */
-       if (pattrib->ether_type == ETH_P_IP) {
-               ip_hdr = (struct iphdr *)(pframe + ETH_HLEN);
-               UserPriority = ip_hdr->tos >> 5;
-       } else if (pattrib->ether_type == ETH_P_PAE) {
-               /*  "When priority processing of data frames is supported, */
-               /*  a STA's SME should send EAPOL-Key frames at the highest
-                   priority." */
-               UserPriority = 7;
-       }
-
-       pattrib->priority = UserPriority;
-       pattrib->hdrlen = sizeof(struct ieee80211_qos_hdr);
-       pattrib->type = IEEE80211_FTYPE_DATA | IEEE80211_STYPE_QOS_DATA;
-}
-
-static int update_attrib(struct rtw_adapter *padapter,
-                        struct sk_buff *skb, struct pkt_attrib *pattrib)
-{
-       struct sta_info *psta = NULL;
-       int bmcast;
-       struct sta_priv *pstapriv = &padapter->stapriv;
-       struct security_priv *psecuritypriv = &padapter->securitypriv;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       int res = _SUCCESS;
-       struct ethhdr *ehdr = (struct ethhdr *) skb->data;
-
-       pattrib->ether_type = ntohs(ehdr->h_proto);
-
-       ether_addr_copy(pattrib->dst, ehdr->h_dest);
-       ether_addr_copy(pattrib->src, ehdr->h_source);
-
-       pattrib->pctrl = 0;
-
-       if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) ||
-           check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE)) {
-               ether_addr_copy(pattrib->ra, pattrib->dst);
-               ether_addr_copy(pattrib->ta, pattrib->src);
-       } else if (check_fwstate(pmlmepriv, WIFI_STATION_STATE)) {
-               ether_addr_copy(pattrib->ra, get_bssid(pmlmepriv));
-               ether_addr_copy(pattrib->ta, pattrib->src);
-       } else if (check_fwstate(pmlmepriv, WIFI_AP_STATE)) {
-               ether_addr_copy(pattrib->ra, pattrib->dst);
-               ether_addr_copy(pattrib->ta, get_bssid(pmlmepriv));
-       }
-
-       pattrib->pktlen = skb->len - ETH_HLEN;
-
-       if (pattrib->ether_type == ETH_P_IP) {
-               /*  The following is for DHCP and ARP packet, we use cck1M
-                   to tx these packets and let LPS awake some time */
-               /*  to prevent DHCP protocol fail */
-               pattrib->dhcp_pkt = 0;
-               /* MINIMUM_DHCP_PACKET_SIZE) { */
-               if (pattrib->pktlen > 282 + 24) {
-                       if (pattrib->ether_type == ETH_P_IP) {/*  IP header */
-                               u8 *pframe = skb->data;
-
-                               pframe += ETH_HLEN;
-
-                               if ((pframe[21] == 68 && pframe[23] == 67) ||
-                                   (pframe[21] == 67 && pframe[23] == 68)) {
-                                       /*  68 : UDP BOOTP client */
-                                       /*  67 : UDP BOOTP server */
-                                       RT_TRACE(_module_rtl871x_xmit_c_,
-                                                _drv_err_,
-                                                "======================update_attrib: get DHCP Packet\n");
-                                       pattrib->dhcp_pkt = 1;
-                               }
-                       }
-               }
-       } else if (pattrib->ether_type == ETH_P_PAE) {
-               DBG_8723A_LEVEL(_drv_always_, "send eapol packet\n");
-       }
-
-       if ((pattrib->ether_type == ETH_P_PAE) || (pattrib->dhcp_pkt == 1)) {
-               rtw_set_scan_deny(padapter, 3000);
-       }
-
-       /*  If EAPOL , ARP , OR DHCP packet, driver must be in active mode. */
-       if ((pattrib->ether_type == ETH_P_ARP) ||
-           (pattrib->ether_type == ETH_P_PAE) || (pattrib->dhcp_pkt == 1)) {
-               rtw_lps_ctrl_wk_cmd23a(padapter, LPS_CTRL_SPECIAL_PACKET, 1);
-       }
-
-       bmcast = is_multicast_ether_addr(pattrib->ra);
-
-       /*  get sta_info */
-       if (bmcast) {
-               psta = rtw_get_bcmc_stainfo23a(padapter);
-       } else {
-               psta = rtw_get_stainfo23a(pstapriv, pattrib->ra);
-               if (psta == NULL) { /*  if we cannot get psta => drrp the pkt */
-                       RT_TRACE(_module_rtl871x_xmit_c_, _drv_alert_,
-                                "update_attrib => get sta_info fail, ra:%pM\n",
-                                pattrib->ra);
-                       res = _FAIL;
-                       goto exit;
-               } else if (check_fwstate(pmlmepriv, WIFI_AP_STATE) &&
-                          (!(psta->state & _FW_LINKED))) {
-                       res = _FAIL;
-                       goto exit;
-               }
-       }
-
-       if (psta) {
-               pattrib->mac_id = psta->mac_id;
-               /* DBG_8723A("%s ==> mac_id(%d)\n", __func__, pattrib->mac_id); */
-               pattrib->psta = psta;
-       } else {
-               /*  if we cannot get psta => drop the pkt */
-               RT_TRACE(_module_rtl871x_xmit_c_, _drv_alert_,
-                        "update_attrib => get sta_info fail, ra:%pM\n",
-                        pattrib->ra);
-               res = _FAIL;
-               goto exit;
-       }
-
-       pattrib->ack_policy = 0;
-       /*  get ether_hdr_len */
-
-       /* pattrib->ether_type == 0x8100) ? (14 + 4): 14; vlan tag */
-       pattrib->pkt_hdrlen = ETH_HLEN;
-
-       pattrib->hdrlen = sizeof(struct ieee80211_hdr_3addr);
-       pattrib->type = IEEE80211_FTYPE_DATA;
-       pattrib->priority = 0;
-
-       if (check_fwstate(pmlmepriv, WIFI_AP_STATE | WIFI_ADHOC_STATE |
-                         WIFI_ADHOC_MASTER_STATE)) {
-               if (psta->qos_option)
-                       set_qos(skb, pattrib);
-       } else {
-               if (pmlmepriv->qos_option) {
-                       set_qos(skb, pattrib);
-
-                       if (pmlmepriv->acm_mask != 0) {
-                               pattrib->priority = qos_acm23a(pmlmepriv->acm_mask,
-                                                           pattrib->priority);
-                       }
-               }
-       }
-
-       if (psta->ieee8021x_blocked == true) {
-               RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_,
-                        "psta->ieee8021x_blocked == true\n");
-
-               pattrib->encrypt = 0;
-
-               if ((pattrib->ether_type != ETH_P_PAE) &&
-                   !check_fwstate(pmlmepriv, WIFI_MP_STATE)) {
-                       RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_,
-                                "psta->ieee8021x_blocked == true,  pattrib->ether_type(%.4x) != 0x888e\n",
-                                pattrib->ether_type);
-                       res = _FAIL;
-                       goto exit;
-               }
-       } else {
-               GET_ENCRY_ALGO(psecuritypriv, psta, pattrib->encrypt, bmcast);
-
-               switch (psecuritypriv->dot11AuthAlgrthm) {
-               case dot11AuthAlgrthm_Open:
-               case dot11AuthAlgrthm_Shared:
-               case dot11AuthAlgrthm_Auto:
-                       pattrib->key_idx =
-                               (u8)psecuritypriv->dot11PrivacyKeyIndex;
-                       break;
-               case dot11AuthAlgrthm_8021X:
-                       if (bmcast)
-                               pattrib->key_idx =
-                                       (u8)psecuritypriv->dot118021XGrpKeyid;
-                       else
-                               pattrib->key_idx = 0;
-                       break;
-               default:
-                       pattrib->key_idx = 0;
-                       break;
-               }
-
-       }
-
-       switch (pattrib->encrypt) {
-       case WLAN_CIPHER_SUITE_WEP40:
-       case WLAN_CIPHER_SUITE_WEP104:
-               pattrib->iv_len = IEEE80211_WEP_IV_LEN;
-               pattrib->icv_len = IEEE80211_WEP_ICV_LEN;
-               break;
-
-       case WLAN_CIPHER_SUITE_TKIP:
-               pattrib->iv_len = IEEE80211_TKIP_IV_LEN;
-               pattrib->icv_len = IEEE80211_TKIP_ICV_LEN;
-
-               if (!padapter->securitypriv.busetkipkey) {
-                       RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_,
-                                "padapter->securitypriv.busetkipkey(%d) == false drop packet\n",
-                                padapter->securitypriv.busetkipkey);
-                       res = _FAIL;
-                       goto exit;
-               }
-
-               break;
-       case WLAN_CIPHER_SUITE_CCMP:
-               RT_TRACE(_module_rtl871x_xmit_c_, _drv_info_,
-                        "pattrib->encrypt =%d (WLAN_CIPHER_SUITE_CCMP)\n",
-                        pattrib->encrypt);
-               pattrib->iv_len = IEEE80211_CCMP_HDR_LEN;
-               pattrib->icv_len = IEEE80211_CCMP_MIC_LEN;
-               break;
-
-       default:
-               pattrib->iv_len = 0;
-               pattrib->icv_len = 0;
-               break;
-       }
-
-       RT_TRACE(_module_rtl871x_xmit_c_, _drv_info_,
-                "update_attrib: encrypt =%d\n", pattrib->encrypt);
-
-       if (pattrib->encrypt && !psecuritypriv->hw_decrypted) {
-               pattrib->bswenc = true;
-               RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_,
-                        "update_attrib: encrypt =%d bswenc = true\n",
-                        pattrib->encrypt);
-       } else {
-               pattrib->bswenc = false;
-               RT_TRACE(_module_rtl871x_xmit_c_, _drv_info_,
-                        "update_attrib: bswenc = false\n");
-       }
-       update_attrib_phy_info(pattrib, psta);
-
-exit:
-
-       return res;
-}
-
-static int xmitframe_addmic(struct rtw_adapter *padapter,
-                           struct xmit_frame *pxmitframe) {
-       struct mic_data micdata;
-       struct sta_info *stainfo;
-       struct pkt_attrib *pattrib = &pxmitframe->attrib;
-       struct security_priv *psecuritypriv = &padapter->securitypriv;
-       struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-       int curfragnum, length;
-       u8 *pframe, *payload, mic[8];
-       u8 priority[4]= {0x0, 0x0, 0x0, 0x0};
-       u8 hw_hdr_offset = 0;
-       int bmcst = is_multicast_ether_addr(pattrib->ra);
-
-       if (pattrib->psta) {
-               stainfo = pattrib->psta;
-       } else {
-               DBG_8723A("%s, call rtw_get_stainfo23a()\n", __func__);
-               stainfo = rtw_get_stainfo23a(&padapter->stapriv, &pattrib->ra[0]);
-       }
-
-       if (!stainfo) {
-               DBG_8723A("%s, psta == NUL\n", __func__);
-               return _FAIL;
-       }
-
-       if (!(stainfo->state &_FW_LINKED)) {
-               DBG_8723A("%s, psta->state(0x%x) != _FW_LINKED\n",
-                         __func__, stainfo->state);
-               return _FAIL;
-       }
-
-       hw_hdr_offset = TXDESC_OFFSET;
-
-       if (pattrib->encrypt == WLAN_CIPHER_SUITE_TKIP) {
-               /* encode mic code */
-               if (stainfo) {
-                       u8 null_key[16]={0x0, 0x0, 0x0, 0x0,
-                                        0x0, 0x0, 0x0, 0x0,
-                                        0x0, 0x0, 0x0, 0x0,
-                                        0x0, 0x0, 0x0, 0x0};
-
-                       pframe = pxmitframe->buf_addr + hw_hdr_offset;
-
-                       if (bmcst) {
-                               if (!memcmp(psecuritypriv->dot118021XGrptxmickey[psecuritypriv->dot118021XGrpKeyid].skey, null_key, 16)) {
-                                       return _FAIL;
-                               }
-                               /* start to calculate the mic code */
-                               rtw_secmicsetkey23a(&micdata, psecuritypriv->dot118021XGrptxmickey[psecuritypriv->dot118021XGrpKeyid].skey);
-                       } else {
-                               if (!memcmp(&stainfo->dot11tkiptxmickey.skey[0],
-                                           null_key, 16)) {
-                                       return _FAIL;
-                               }
-                               /* start to calculate the mic code */
-                               rtw_secmicsetkey23a(&micdata, &stainfo->dot11tkiptxmickey.skey[0]);
-                       }
-
-                       if (pframe[1] & 1) {   /* ToDS == 1 */
-                               /* DA */
-                               rtw_secmicappend23a(&micdata, &pframe[16], 6);
-                               if (pframe[1] & 2)  /* From Ds == 1 */
-                                       rtw_secmicappend23a(&micdata,
-                                                        &pframe[24], 6);
-                               else
-                                       rtw_secmicappend23a(&micdata,
-                                                        &pframe[10], 6);
-                       } else {        /* ToDS == 0 */
-                               /* DA */
-                               rtw_secmicappend23a(&micdata, &pframe[4], 6);
-                               if (pframe[1] & 2)  /* From Ds == 1 */
-                                       rtw_secmicappend23a(&micdata,
-                                                        &pframe[16], 6);
-                               else
-                                       rtw_secmicappend23a(&micdata,
-                                                        &pframe[10], 6);
-                       }
-
-                       /* if (pmlmepriv->qos_option == 1) */
-                       if (pattrib->qos_en)
-                               priority[0] = (u8)pxmitframe->attrib.priority;
-
-                       rtw_secmicappend23a(&micdata, &priority[0], 4);
-
-                       payload = pframe;
-
-                       for (curfragnum = 0; curfragnum < pattrib->nr_frags;
-                            curfragnum++) {
-                               payload = PTR_ALIGN(payload, 4);
-                               RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_,
-                                        "=== curfragnum =%d, pframe = 0x%.2x, 0x%.2x, 0x%.2x, 0x%.2x, 0x%.2x, 0x%.2x, 0x%.2x, 0x%.2x,!!!\n",
-                                        curfragnum, *payload, *(payload + 1),
-                                        *(payload + 2), *(payload + 3),
-                                        *(payload + 4), *(payload + 5),
-                                        *(payload + 6), *(payload + 7));
-
-                               payload = payload + pattrib->hdrlen +
-                                       pattrib->iv_len;
-                               RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_,
-                                        "curfragnum =%d pattrib->hdrlen =%d pattrib->iv_len =%d\n",
-                                        curfragnum,
-                                        pattrib->hdrlen, pattrib->iv_len);
-                               if ((curfragnum + 1) == pattrib->nr_frags) {
-                                       length = pattrib->last_txcmdsz -
-                                               pattrib->hdrlen -
-                                               pattrib->iv_len -
-                                               ((pattrib->bswenc) ?
-                                                pattrib->icv_len : 0);
-                                       rtw_secmicappend23a(&micdata, payload,
-                                                        length);
-                                       payload = payload + length;
-                               } else {
-                                       length = pxmitpriv->frag_len -
-                                               pattrib->hdrlen -
-                                               pattrib->iv_len -
-                                               ((pattrib->bswenc) ?
-                                                pattrib->icv_len : 0);
-                                       rtw_secmicappend23a(&micdata, payload,
-                                                        length);
-                                       payload = payload + length +
-                                               pattrib->icv_len;
-                                       RT_TRACE(_module_rtl871x_xmit_c_,
-                                                _drv_err_,
-                                                "curfragnum =%d length =%d pattrib->icv_len =%d\n",
-                                                curfragnum, length,
-                                                pattrib->icv_len);
-                               }
-                       }
-                       rtw_secgetmic23a(&micdata, &mic[0]);
-                       RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_,
-                                "xmitframe_addmic: before add mic code!!\n");
-                       RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_,
-                                "xmitframe_addmic: pattrib->last_txcmdsz =%d!!!\n",
-                                pattrib->last_txcmdsz);
-                       RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_,
-                                "xmitframe_addmic: mic[0]= 0x%.2x , mic[1]=0x%.2x , mic[2]= 0x%.2x , mic[3]= 0x%.2x\nmic[4]= 0x%.2x , mic[5]= 0x%.2x , mic[6]= 0x%.2x , mic[7]= 0x%.2x !!!!\n",
-                                mic[0], mic[1], mic[2], mic[3],
-                                mic[4], mic[5], mic[6], mic[7]);
-                       /* add mic code  and add the mic code length
-                          in last_txcmdsz */
-
-                       memcpy(payload, &mic[0], 8);
-                       pattrib->last_txcmdsz += 8;
-
-                       RT_TRACE(_module_rtl871x_xmit_c_, _drv_info_,
-                                "======== last pkt ========\n");
-                       payload = payload - pattrib->last_txcmdsz + 8;
-                       for (curfragnum = 0; curfragnum < pattrib->last_txcmdsz;
-                            curfragnum = curfragnum + 8) {
-                               RT_TRACE(_module_rtl871x_xmit_c_, _drv_info_,
-                                        "%.2x,  %.2x,  %.2x,  %.2x,  %.2x,  %.2x,  %.2x,  %.2x\n",
-                                        *(payload + curfragnum),
-                                        *(payload + curfragnum + 1),
-                                        *(payload + curfragnum + 2),
-                                        *(payload + curfragnum + 3),
-                                        *(payload + curfragnum + 4),
-                                        *(payload + curfragnum + 5),
-                                        *(payload + curfragnum + 6),
-                                        *(payload + curfragnum + 7));
-                       }
-               } else {
-                       RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_,
-                                "xmitframe_addmic: rtw_get_stainfo23a ==NULL!!!\n");
-               }
-       }
-
-       return _SUCCESS;
-}
-
-static int xmitframe_swencrypt(struct rtw_adapter *padapter,
-                              struct xmit_frame *pxmitframe)
-{
-       struct pkt_attrib *pattrib = &pxmitframe->attrib;
-
-       /* if ((psecuritypriv->sw_encrypt)||(pattrib->bswenc)) */
-       if (pattrib->bswenc) {
-               /* DBG_8723A("start xmitframe_swencrypt\n"); */
-               RT_TRACE(_module_rtl871x_xmit_c_, _drv_alert_,
-                        "### xmitframe_swencrypt\n");
-               switch (pattrib->encrypt) {
-               case WLAN_CIPHER_SUITE_WEP40:
-               case WLAN_CIPHER_SUITE_WEP104:
-                       rtw_wep_encrypt23a(padapter, pxmitframe);
-                       break;
-               case WLAN_CIPHER_SUITE_TKIP:
-                       rtw_tkip_encrypt23a(padapter, pxmitframe);
-                       break;
-               case WLAN_CIPHER_SUITE_CCMP:
-                       rtw_aes_encrypt23a(padapter, pxmitframe);
-                       break;
-               default:
-                               break;
-               }
-
-       } else {
-               RT_TRACE(_module_rtl871x_xmit_c_, _drv_notice_,
-                        "### xmitframe_hwencrypt\n");
-       }
-
-       return _SUCCESS;
-}
-
-static int rtw_make_wlanhdr(struct rtw_adapter *padapter, u8 *hdr,
-                           struct pkt_attrib *pattrib)
-{
-       struct ieee80211_hdr *pwlanhdr = (struct ieee80211_hdr *)hdr;
-       struct ieee80211_qos_hdr *qoshdr;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       u8 qos_option = false;
-       int res = _SUCCESS;
-
-       struct sta_info *psta;
-
-       int bmcst = is_multicast_ether_addr(pattrib->ra);
-
-       if (pattrib->psta) {
-               psta = pattrib->psta;
-       } else {
-               DBG_8723A("%s, call rtw_get_stainfo23a()\n", __func__);
-               if (bmcst) {
-                       psta = rtw_get_bcmc_stainfo23a(padapter);
-               } else {
-                       psta = rtw_get_stainfo23a(&padapter->stapriv, pattrib->ra);
-               }
-       }
-
-       if (psta == NULL) {
-               DBG_8723A("%s, psta == NUL\n", __func__);
-               return _FAIL;
-       }
-
-       if (!(psta->state &_FW_LINKED)) {
-               DBG_8723A("%s, psta->state(0x%x) != _FW_LINKED\n", __func__, psta->state);
-               return _FAIL;
-       }
-
-       memset(hdr, 0, WLANHDR_OFFSET);
-
-       pwlanhdr->frame_control = cpu_to_le16(pattrib->type);
-
-       if (pattrib->type & IEEE80211_FTYPE_DATA) {
-               if (check_fwstate(pmlmepriv,  WIFI_STATION_STATE)) {
-                       /* to_ds = 1, fr_ds = 0; */
-                       /* Data transfer to AP */
-                       pwlanhdr->frame_control |=
-                               cpu_to_le16(IEEE80211_FCTL_TODS);
-                       ether_addr_copy(pwlanhdr->addr1, get_bssid(pmlmepriv));
-                       ether_addr_copy(pwlanhdr->addr2, pattrib->src);
-                       ether_addr_copy(pwlanhdr->addr3, pattrib->dst);
-
-                       if (pmlmepriv->qos_option)
-                               qos_option = true;
-
-               } else if (check_fwstate(pmlmepriv,  WIFI_AP_STATE)) {
-                       /* to_ds = 0, fr_ds = 1; */
-                       pwlanhdr->frame_control |=
-                               cpu_to_le16(IEEE80211_FCTL_FROMDS);
-                       ether_addr_copy(pwlanhdr->addr1, pattrib->dst);
-                       ether_addr_copy(pwlanhdr->addr2, get_bssid(pmlmepriv));
-                       ether_addr_copy(pwlanhdr->addr3, pattrib->src);
-
-                       if (psta->qos_option)
-                               qos_option = true;
-               } else if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) ||
-                          check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE)) {
-                       ether_addr_copy(pwlanhdr->addr1, pattrib->dst);
-                       ether_addr_copy(pwlanhdr->addr2, pattrib->src);
-                       ether_addr_copy(pwlanhdr->addr3, get_bssid(pmlmepriv));
-
-                       if (psta->qos_option)
-                               qos_option = true;
-               }
-               else {
-                       RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_,
-                                "fw_state:%x is not allowed to xmit frame\n",
-                                get_fwstate(pmlmepriv));
-                       res = _FAIL;
-                       goto exit;
-               }
-               if (pattrib->mdata)
-                       pwlanhdr->frame_control |=
-                               cpu_to_le16(IEEE80211_FCTL_MOREDATA);
-               if (pattrib->encrypt)
-                       pwlanhdr->frame_control |=
-                               cpu_to_le16(IEEE80211_FCTL_PROTECTED);
-               if (qos_option) {
-                       qoshdr = (struct ieee80211_qos_hdr *)hdr;
-
-                       qoshdr->qos_ctrl = cpu_to_le16(
-                               pattrib->priority & IEEE80211_QOS_CTL_TID_MASK);
-
-                       qoshdr->qos_ctrl |= cpu_to_le16(
-                               (pattrib->ack_policy << 5) &
-                               IEEE80211_QOS_CTL_ACK_POLICY_MASK);
-
-                       if (pattrib->eosp)
-                               qoshdr->qos_ctrl |=
-                                       cpu_to_le16(IEEE80211_QOS_CTL_EOSP);
-               }
-               /* TODO: fill HT Control Field */
-
-               /* Update Seq Num will be handled by f/w */
-               if (psta) {
-                       psta->sta_xmitpriv.txseq_tid[pattrib->priority]++;
-                       psta->sta_xmitpriv.txseq_tid[pattrib->priority] &= 0xFFF;
-                       pattrib->seqnum = psta->sta_xmitpriv.txseq_tid[pattrib->priority];
-                       /* We dont need to worry about frag bits here */
-                       pwlanhdr->seq_ctrl = cpu_to_le16(IEEE80211_SN_TO_SEQ(
-                                                             pattrib->seqnum));
-                       /* check if enable ampdu */
-                       if (pattrib->ht_en && psta->htpriv.ampdu_enable) {
-                               if (pattrib->priority >= 16)
-                                       printk(KERN_WARNING "%s: Invalid "
-                                              "pattrib->priority %i\n",
-                                              __func__, pattrib->priority);
-                               if (psta->htpriv.agg_enable_bitmap &
-                                   BIT(pattrib->priority))
-                                       pattrib->ampdu_en = true;
-                       }
-                       /* re-check if enable ampdu by BA_starting_seqctrl */
-                       if (pattrib->ampdu_en) {
-                               u16 tx_seq;
-
-                               tx_seq = psta->BA_starting_seqctrl[pattrib->priority & 0x0f];
-
-                               /* check BA_starting_seqctrl */
-                               if (SN_LESS(pattrib->seqnum, tx_seq)) {
-                                       /* DBG_8723A("tx ampdu seqnum(%d) < tx_seq(%d)\n", pattrib->seqnum, tx_seq); */
-                                       pattrib->ampdu_en = false;/* AGG BK */
-                               } else if (SN_EQUAL(pattrib->seqnum, tx_seq)) {
-                                       psta->BA_starting_seqctrl[pattrib->priority & 0x0f] = (tx_seq+1)&0xfff;
-                                       pattrib->ampdu_en = true;/* AGG EN */
-                               } else {
-                                       /* DBG_8723A("tx ampdu over run\n"); */
-                                       psta->BA_starting_seqctrl[pattrib->priority & 0x0f] = (pattrib->seqnum+1)&0xfff;
-                                       pattrib->ampdu_en = true;/* AGG EN */
-                               }
-                       }
-               }
-       }
-exit:
-       return res;
-}
-
-s32 rtw_txframes_pending23a(struct rtw_adapter *padapter)
-{
-       struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-
-       return (!list_empty(&pxmitpriv->be_pending.queue)) ||
-               (!list_empty(&pxmitpriv->bk_pending.queue)) ||
-               (!list_empty(&pxmitpriv->vi_pending.queue)) ||
-               (!list_empty(&pxmitpriv->vo_pending.queue));
-}
-
-s32 rtw_txframes_sta_ac_pending23a(struct rtw_adapter *padapter,
-                               struct pkt_attrib *pattrib)
-{
-       struct sta_info *psta;
-       struct tx_servq *ptxservq;
-       int priority = pattrib->priority;
-
-       if (pattrib->psta) {
-               psta = pattrib->psta;
-       } else {
-               DBG_8723A("%s, call rtw_get_stainfo23a()\n", __func__);
-               psta = rtw_get_stainfo23a(&padapter->stapriv, &pattrib->ra[0]);
-       }
-       if (psta == NULL) {
-               DBG_8723A("%s, psta == NUL\n", __func__);
-               return 0;
-       }
-       if (!(psta->state &_FW_LINKED)) {
-               DBG_8723A("%s, psta->state(0x%x) != _FW_LINKED\n", __func__,
-                         psta->state);
-               return 0;
-       }
-       switch (priority) {
-       case 1:
-       case 2:
-               ptxservq = &psta->sta_xmitpriv.bk_q;
-               break;
-       case 4:
-       case 5:
-               ptxservq = &psta->sta_xmitpriv.vi_q;
-               break;
-       case 6:
-       case 7:
-               ptxservq = &psta->sta_xmitpriv.vo_q;
-               break;
-       case 0:
-       case 3:
-       default:
-               ptxservq = &psta->sta_xmitpriv.be_q;
-               break;
-       }
-       return ptxservq->qcnt;
-}
-
-/* Logical Link Control(LLC) SubNetwork Attachment Point(SNAP) header
- * IEEE LLC/SNAP header contains 8 octets
- * First 3 octets comprise the LLC portion
- * SNAP portion, 5 octets, is divided into two fields:
- *     Organizationally Unique Identifier(OUI), 3 octets,
- *     type, defined by that organization, 2 octets.
- */
-static int rtw_put_snap(u8 *data, u16 h_proto)
-{
-       if (h_proto == ETH_P_IPX || h_proto == ETH_P_AARP)
-               ether_addr_copy(data, bridge_tunnel_header);
-       else
-               ether_addr_copy(data, rfc1042_header);
-
-       data += ETH_ALEN;
-       put_unaligned_be16(h_proto, data);
-       return ETH_ALEN + sizeof(u16);
-}
-
-/*
-
-This sub-routine will perform all the following:
-
-1. remove 802.3 header.
-2. create wlan_header, based on the info in pxmitframe
-3. append sta's iv/ext-iv
-4. append LLC
-5. move frag chunk from pframe to pxmitframe->mem
-6. apply sw-encrypt, if necessary.
-
-*/
-int rtw_xmitframe_coalesce23a(struct rtw_adapter *padapter, struct sk_buff *skb,
-                             struct xmit_frame *pxmitframe)
-{
-       struct sta_info *psta;
-       struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-       struct pkt_attrib *pattrib = &pxmitframe->attrib;
-       struct ieee80211_hdr *hdr;
-       s32 frg_inx, frg_len, mpdu_len, llc_sz, mem_sz;
-       u8 *pframe, *mem_start;
-       u8 hw_hdr_offset;
-       u8 *pbuf_start;
-       u8 *pdata = skb->data;
-       int data_len = skb->len;
-       s32 bmcst = is_multicast_ether_addr(pattrib->ra);
-       int res = _SUCCESS;
-
-       if (pattrib->psta)
-               psta = pattrib->psta;
-       else {
-               DBG_8723A("%s, call rtw_get_stainfo23a()\n", __func__);
-               psta = rtw_get_stainfo23a(&padapter->stapriv, pattrib->ra);
-       }
-
-       if (!psta) {
-               DBG_8723A("%s, psta == NUL\n", __func__);
-               return _FAIL;
-       }
-
-       if (!(psta->state &_FW_LINKED)) {
-               DBG_8723A("%s, psta->state(0x%x) != _FW_LINKED\n",
-                         __func__, psta->state);
-               return _FAIL;
-       }
-
-       if (!pxmitframe->buf_addr) {
-               DBG_8723A("==> %s buf_addr == NULL\n", __func__);
-               return _FAIL;
-       }
-
-       pbuf_start = pxmitframe->buf_addr;
-
-       hw_hdr_offset = TXDESC_OFFSET;
-
-       mem_start = pbuf_start + hw_hdr_offset;
-
-       if (rtw_make_wlanhdr(padapter, mem_start, pattrib) == _FAIL) {
-               RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_,
-                        "%s: rtw_make_wlanhdr fail; drop pkt\n", __func__);
-               res = _FAIL;
-               goto exit;
-       }
-
-       pdata += pattrib->pkt_hdrlen;
-       data_len -= pattrib->pkt_hdrlen;
-
-       frg_inx = 0;
-       frg_len = pxmitpriv->frag_len - 4;/* 2346-4 = 2342 */
-
-       while (1) {
-               llc_sz = 0;
-
-               mpdu_len = frg_len;
-
-               pframe = mem_start;
-               hdr = (struct ieee80211_hdr *)mem_start;
-
-               pframe += pattrib->hdrlen;
-               mpdu_len -= pattrib->hdrlen;
-
-               /* adding icv, if necessary... */
-               if (pattrib->iv_len) {
-                       if (psta) {
-                               switch (pattrib->encrypt) {
-                               case WLAN_CIPHER_SUITE_WEP40:
-                               case WLAN_CIPHER_SUITE_WEP104:
-                                       WEP_IV(pattrib->iv, psta->dot11txpn,
-                                              pattrib->key_idx);
-                                       break;
-                               case WLAN_CIPHER_SUITE_TKIP:
-                                       if (bmcst)
-                                               TKIP_IV(pattrib->iv,
-                                                       psta->dot11txpn,
-                                                       pattrib->key_idx);
-                                       else
-                                               TKIP_IV(pattrib->iv,
-                                                       psta->dot11txpn, 0);
-                                       break;
-                               case WLAN_CIPHER_SUITE_CCMP:
-                                       if (bmcst)
-                                               AES_IV(pattrib->iv,
-                                                      psta->dot11txpn,
-                                                      pattrib->key_idx);
-                                       else
-                                               AES_IV(pattrib->iv,
-                                                      psta->dot11txpn, 0);
-                                       break;
-                               }
-                       }
-
-                       memcpy(pframe, pattrib->iv, pattrib->iv_len);
-
-                       RT_TRACE(_module_rtl871x_xmit_c_, _drv_notice_,
-                                "rtw_xmiaframe_coalesce23a: keyid =%d pattrib->iv[3]=%.2x pframe =%.2x %.2x %.2x %.2x\n",
-                                padapter->securitypriv.dot11PrivacyKeyIndex,
-                                pattrib->iv[3], *pframe, *(pframe+1),
-                                *(pframe+2), *(pframe+3));
-                       pframe += pattrib->iv_len;
-                       mpdu_len -= pattrib->iv_len;
-               }
-               if (frg_inx == 0) {
-                       llc_sz = rtw_put_snap(pframe, pattrib->ether_type);
-                       pframe += llc_sz;
-                       mpdu_len -= llc_sz;
-               }
-
-               if (pattrib->icv_len > 0 && pattrib->bswenc)
-                       mpdu_len -= pattrib->icv_len;
-
-               if (bmcst)
-                       /*  don't do fragment to broadcast/multicast packets */
-                       mem_sz = min_t(s32, data_len, pattrib->pktlen);
-               else
-                       mem_sz = min_t(s32, data_len, mpdu_len);
-
-               memcpy(pframe, pdata, mem_sz);
-
-               pframe += mem_sz;
-               pdata += mem_sz;
-               data_len -= mem_sz;
-
-               if ((pattrib->icv_len >0) && (pattrib->bswenc)) {
-                       memcpy(pframe, pattrib->icv, pattrib->icv_len);
-                       pframe += pattrib->icv_len;
-               }
-
-               frg_inx++;
-
-               if (bmcst || data_len <= 0) {
-                       pattrib->nr_frags = frg_inx;
-
-                       pattrib->last_txcmdsz = pattrib->hdrlen +
-                                               pattrib->iv_len +
-                                               ((pattrib->nr_frags == 1) ?
-                                               llc_sz : 0) +
-                                               ((pattrib->bswenc) ?
-                                               pattrib->icv_len : 0) + mem_sz;
-                       hdr->frame_control &=
-                               ~cpu_to_le16(IEEE80211_FCTL_MOREFRAGS);
-
-                       break;
-               } else {
-                       RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_,
-                                "%s: There're still something in packet!\n",
-                                __func__);
-               }
-               hdr->frame_control |= cpu_to_le16(IEEE80211_FCTL_MOREFRAGS);
-
-               mem_start = PTR_ALIGN(pframe, 4) + hw_hdr_offset;
-               memcpy(mem_start, pbuf_start + hw_hdr_offset, pattrib->hdrlen);
-       }
-
-       if (xmitframe_addmic(padapter, pxmitframe) == _FAIL) {
-               RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_,
-                        "xmitframe_addmic(padapter, pxmitframe) == _FAIL\n");
-               DBG_8723A("xmitframe_addmic(padapter, pxmitframe) == _FAIL\n");
-               res = _FAIL;
-               goto exit;
-       }
-
-       xmitframe_swencrypt(padapter, pxmitframe);
-
-       if (bmcst == false)
-               update_attrib_vcs_info(padapter, pxmitframe);
-       else
-               pattrib->vcs_mode = NONE_VCS;
-
-exit:
-       return res;
-}
-
-void rtw_update_protection23a(struct rtw_adapter *padapter, u8 *ie, uint ie_len)
-{
-       struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-       struct registry_priv *pregistrypriv = &padapter->registrypriv;
-       uint protection;
-       const u8 *p;
-
-       switch (pregistrypriv->vrtl_carrier_sense) {
-       case DISABLE_VCS:
-               pxmitpriv->vcs = NONE_VCS;
-               break;
-       case ENABLE_VCS:
-               break;
-       case AUTO_VCS:
-       default:
-               p = cfg80211_find_ie(WLAN_EID_ERP_INFO, ie, ie_len);
-               if (!p)
-                       pxmitpriv->vcs = NONE_VCS;
-               else {
-                       protection = (*(p + 2)) & BIT(1);
-                       if (protection) {
-                               if (pregistrypriv->vcs_type == RTS_CTS)
-                                       pxmitpriv->vcs = RTS_CTS;
-                               else
-                                       pxmitpriv->vcs = CTS_TO_SELF;
-                       } else {
-                               pxmitpriv->vcs = NONE_VCS;
-                       }
-               }
-               break;
-       }
-}
-
-void rtw_count_tx_stats23a(struct rtw_adapter *padapter, struct xmit_frame *pxmitframe, int sz)
-{
-       struct sta_info *psta = NULL;
-       struct stainfo_stats *pstats = NULL;
-       struct xmit_priv        *pxmitpriv = &padapter->xmitpriv;
-       struct mlme_priv        *pmlmepriv = &padapter->mlmepriv;
-
-       if (pxmitframe->frame_tag == DATA_FRAMETAG) {
-               pxmitpriv->tx_bytes += sz;
-               pmlmepriv->LinkDetectInfo.NumTxOkInPeriod++;
-
-               psta = pxmitframe->attrib.psta;
-               if (psta) {
-                       pstats = &psta->sta_stats;
-                       pstats->tx_pkts++;
-                       pstats->tx_bytes += sz;
-               }
-       }
-}
-
-struct xmit_buf *rtw_alloc_xmitbuf23a_ext(struct xmit_priv *pxmitpriv)
-{
-       unsigned long irqL;
-       struct xmit_buf *pxmitbuf =  NULL;
-       struct list_head *phead;
-       struct rtw_queue *pfree_queue = &pxmitpriv->free_xmit_extbuf_queue;
-
-       spin_lock_irqsave(&pfree_queue->lock, irqL);
-
-       phead = get_list_head(pfree_queue);
-
-       if (!list_empty(phead)) {
-               pxmitbuf = list_first_entry(phead, struct xmit_buf, list);
-
-               list_del_init(&pxmitbuf->list);
-
-               pxmitpriv->free_xmit_extbuf_cnt--;
-               pxmitbuf->priv_data = NULL;
-               pxmitbuf->ext_tag = true;
-
-               if (pxmitbuf->sctx) {
-                       DBG_8723A("%s pxmitbuf->sctx is not NULL\n", __func__);
-                       rtw23a_sctx_done_err(&pxmitbuf->sctx, RTW_SCTX_DONE_BUF_ALLOC);
-               }
-       }
-
-       spin_unlock_irqrestore(&pfree_queue->lock, irqL);
-
-       return pxmitbuf;
-}
-
-int rtw_free_xmitbuf_ext23a(struct xmit_priv *pxmitpriv,
-                           struct xmit_buf *pxmitbuf)
-{
-       unsigned long irqL;
-       struct rtw_queue *pfree_queue = &pxmitpriv->free_xmit_extbuf_queue;
-
-       if (pxmitbuf == NULL)
-               return _FAIL;
-
-       spin_lock_irqsave(&pfree_queue->lock, irqL);
-
-       list_del_init(&pxmitbuf->list);
-
-       list_add_tail(&pxmitbuf->list, get_list_head(pfree_queue));
-       pxmitpriv->free_xmit_extbuf_cnt++;
-
-       spin_unlock_irqrestore(&pfree_queue->lock, irqL);
-
-       return _SUCCESS;
-}
-
-struct xmit_buf *rtw_alloc_xmitbuf23a(struct xmit_priv *pxmitpriv)
-{
-       unsigned long irqL;
-       struct xmit_buf *pxmitbuf =  NULL;
-       struct list_head *phead;
-       struct rtw_queue *pfree_xmitbuf_queue = &pxmitpriv->free_xmitbuf_queue;
-
-       /* DBG_8723A("+rtw_alloc_xmitbuf23a\n"); */
-
-       spin_lock_irqsave(&pfree_xmitbuf_queue->lock, irqL);
-
-       phead = get_list_head(pfree_xmitbuf_queue);
-
-       if (!list_empty(phead)) {
-               pxmitbuf = list_first_entry(phead, struct xmit_buf, list);
-
-               list_del_init(&pxmitbuf->list);
-
-               pxmitpriv->free_xmitbuf_cnt--;
-               pxmitbuf->priv_data = NULL;
-               pxmitbuf->ext_tag = false;
-               pxmitbuf->flags = XMIT_VO_QUEUE;
-
-               if (pxmitbuf->sctx) {
-                       DBG_8723A("%s pxmitbuf->sctx is not NULL\n", __func__);
-                       rtw23a_sctx_done_err(&pxmitbuf->sctx, RTW_SCTX_DONE_BUF_ALLOC);
-               }
-       }
-
-       spin_unlock_irqrestore(&pfree_xmitbuf_queue->lock, irqL);
-
-       return pxmitbuf;
-}
-
-int rtw_free_xmitbuf23a(struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf)
-{
-       unsigned long irqL;
-       struct rtw_queue *pfree_xmitbuf_queue = &pxmitpriv->free_xmitbuf_queue;
-
-       /* DBG_8723A("+rtw_free_xmitbuf23a\n"); */
-
-       if (pxmitbuf == NULL)
-               return _FAIL;
-
-       if (pxmitbuf->sctx) {
-               DBG_8723A("%s pxmitbuf->sctx is not NULL\n", __func__);
-               rtw23a_sctx_done_err(&pxmitbuf->sctx, RTW_SCTX_DONE_BUF_FREE);
-       }
-
-       if (pxmitbuf->ext_tag) {
-               rtw_free_xmitbuf_ext23a(pxmitpriv, pxmitbuf);
-       } else {
-               spin_lock_irqsave(&pfree_xmitbuf_queue->lock, irqL);
-
-               list_del_init(&pxmitbuf->list);
-
-               list_add_tail(&pxmitbuf->list,
-                             get_list_head(pfree_xmitbuf_queue));
-
-               pxmitpriv->free_xmitbuf_cnt++;
-               spin_unlock_irqrestore(&pfree_xmitbuf_queue->lock, irqL);
-       }
-
-       return _SUCCESS;
-}
-
-static void rtw_init_xmitframe(struct xmit_frame *pxframe)
-{
-       if (pxframe !=  NULL) {
-               /* default value setting */
-               pxframe->buf_addr = NULL;
-               pxframe->pxmitbuf = NULL;
-
-               memset(&pxframe->attrib, 0, sizeof(struct pkt_attrib));
-               /* pxframe->attrib.psta = NULL; */
-
-               pxframe->frame_tag = DATA_FRAMETAG;
-
-               pxframe->pkt = NULL;
-               pxframe->pkt_offset = 1;/* default use pkt_offset to fill tx desc */
-
-               pxframe->ack_report = 0;
-       }
-}
-
-/*
-Calling context:
-1. OS_TXENTRY
-2. RXENTRY (rx_thread or RX_ISR/RX_CallBack)
-
-If we turn on USE_RXTHREAD, then, no need for critical section.
-Otherwise, we must use _enter/_exit critical to protect free_xmit_queue...
-
-Must be very very cautious...
-
-*/
-static struct xmit_frame *rtw_alloc_xmitframe(struct xmit_priv *pxmitpriv)
-{
-       struct xmit_frame *pxframe;
-       struct rtw_queue *pfree_xmit_queue = &pxmitpriv->free_xmit_queue;
-
-       spin_lock_bh(&pfree_xmit_queue->lock);
-
-       pxframe = list_first_entry_or_null(&pfree_xmit_queue->queue,
-                                          struct xmit_frame, list);
-       if (!pxframe) {
-               RT_TRACE(_module_rtl871x_xmit_c_, _drv_info_,
-                        "rtw_alloc_xmitframe:%d\n",
-                        pxmitpriv->free_xmitframe_cnt);
-       } else {
-               list_del_init(&pxframe->list);
-               pxmitpriv->free_xmitframe_cnt--;
-               RT_TRACE(_module_rtl871x_xmit_c_, _drv_info_,
-                        "rtw_alloc_xmitframe():free_xmitframe_cnt =%d\n",
-                        pxmitpriv->free_xmitframe_cnt);
-       }
-
-       spin_unlock_bh(&pfree_xmit_queue->lock);
-
-       rtw_init_xmitframe(pxframe);
-
-       return pxframe;
-}
-
-struct xmit_frame *rtw_alloc_xmitframe23a_ext(struct xmit_priv *pxmitpriv)
-{
-       struct xmit_frame *pxframe;
-       struct rtw_queue *queue = &pxmitpriv->free_xframe_ext_queue;
-
-       spin_lock_bh(&queue->lock);
-
-       pxframe = list_first_entry_or_null(&queue->queue,
-                                          struct xmit_frame, list);
-       if (!pxframe) {
-               RT_TRACE(_module_rtl871x_xmit_c_, _drv_info_,
-                        "rtw_alloc_xmitframe23a_ext:%d\n",
-                        pxmitpriv->free_xframe_ext_cnt);
-       } else {
-               list_del_init(&pxframe->list);
-               pxmitpriv->free_xframe_ext_cnt--;
-               RT_TRACE(_module_rtl871x_xmit_c_, _drv_info_,
-                        "rtw_alloc_xmitframe23a_ext():free_xmitframe_cnt =%d\n",
-                        pxmitpriv->free_xframe_ext_cnt);
-       }
-
-       spin_unlock_bh(&queue->lock);
-
-       rtw_init_xmitframe(pxframe);
-
-       return pxframe;
-}
-
-s32 rtw_free_xmitframe23a(struct xmit_priv *pxmitpriv, struct xmit_frame *pxmitframe)
-{
-       struct rtw_queue *queue = NULL;
-       struct rtw_adapter *padapter = pxmitpriv->adapter;
-       struct sk_buff *pndis_pkt = NULL;
-
-       if (pxmitframe == NULL) {
-               RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_,
-                        "====== rtw_free_xmitframe23a():pxmitframe == NULL!!!!!!!!!!\n");
-               goto exit;
-       }
-
-       if (pxmitframe->pkt) {
-               pndis_pkt = pxmitframe->pkt;
-               pxmitframe->pkt = NULL;
-       }
-
-       if (pxmitframe->ext_tag == 0)
-               queue = &pxmitpriv->free_xmit_queue;
-       else if (pxmitframe->ext_tag == 1)
-               queue = &pxmitpriv->free_xframe_ext_queue;
-
-       if (!queue)
-               goto check_pkt_complete;
-       spin_lock_bh(&queue->lock);
-
-       list_del_init(&pxmitframe->list);
-       list_add_tail(&pxmitframe->list, get_list_head(queue));
-       if (pxmitframe->ext_tag == 0) {
-               pxmitpriv->free_xmitframe_cnt++;
-               RT_TRACE(_module_rtl871x_xmit_c_, _drv_debug_,
-                        "rtw_free_xmitframe23a():free_xmitframe_cnt =%d\n",
-                        pxmitpriv->free_xmitframe_cnt);
-       } else if (pxmitframe->ext_tag == 1) {
-               pxmitpriv->free_xframe_ext_cnt++;
-               RT_TRACE(_module_rtl871x_xmit_c_, _drv_debug_,
-                        "rtw_free_xmitframe23a():free_xframe_ext_cnt =%d\n",
-                        pxmitpriv->free_xframe_ext_cnt);
-       }
-
-       spin_unlock_bh(&queue->lock);
-
-check_pkt_complete:
-
-       if (pndis_pkt)
-               rtw_os_pkt_complete23a(padapter, pndis_pkt);
-
-exit:
-
-       return _SUCCESS;
-}
-
-void rtw_free_xmitframe_queue23a(struct xmit_priv *pxmitpriv,
-                                struct rtw_queue *pframequeue)
-{
-       struct list_head *phead;
-       struct xmit_frame *pxmitframe, *ptmp;
-
-       spin_lock_bh(&pframequeue->lock);
-       phead = get_list_head(pframequeue);
-       list_for_each_entry_safe(pxmitframe, ptmp, phead, list)
-               rtw_free_xmitframe23a(pxmitpriv, pxmitframe);
-       spin_unlock_bh(&pframequeue->lock);
-
-}
-
-int rtw_xmitframe_enqueue23a(struct rtw_adapter *padapter,
-                            struct xmit_frame *pxmitframe)
-{
-       if (rtw_xmit23a_classifier(padapter, pxmitframe) == _FAIL) {
-               RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_,
-                        "rtw_xmitframe_enqueue23a: drop xmit pkt for classifier fail\n");
-               return _FAIL;
-       }
-
-       return _SUCCESS;
-}
-
-static struct xmit_frame *
-dequeue_one_xmitframe(struct xmit_priv *pxmitpriv, struct hw_xmit *phwxmit,
-                     struct tx_servq *ptxservq, struct rtw_queue *pframe_queue)
-{
-       struct list_head *phead;
-       struct xmit_frame *pxmitframe = NULL;
-
-       phead = get_list_head(pframe_queue);
-
-       if (!list_empty(phead)) {
-               pxmitframe = list_first_entry(phead, struct xmit_frame, list);
-               list_del_init(&pxmitframe->list);
-               ptxservq->qcnt--;
-       }
-       return pxmitframe;
-}
-
-struct xmit_frame *
-rtw_dequeue_xframe23a(struct xmit_priv *pxmitpriv, struct hw_xmit *phwxmit_i,
-                  int entry)
-{
-       struct list_head *sta_phead;
-       struct hw_xmit *phwxmit;
-       struct tx_servq *ptxservq = NULL, *ptmp;
-       struct rtw_queue *pframe_queue = NULL;
-       struct xmit_frame *pxmitframe = NULL;
-       struct rtw_adapter *padapter = pxmitpriv->adapter;
-       struct registry_priv    *pregpriv = &padapter->registrypriv;
-       int i, inx[4];
-
-       inx[0] = 0;
-       inx[1] = 1;
-       inx[2] = 2;
-       inx[3] = 3;
-       if (pregpriv->wifi_spec == 1) {
-               int j;
-
-               for (j = 0; j < 4; j++)
-                       inx[j] = pxmitpriv->wmm_para_seq[j];
-       }
-
-       spin_lock_bh(&pxmitpriv->lock);
-
-       for (i = 0; i < entry; i++) {
-               phwxmit = phwxmit_i + inx[i];
-
-               sta_phead = get_list_head(phwxmit->sta_queue);
-               list_for_each_entry_safe(ptxservq, ptmp, sta_phead,
-                                        tx_pending) {
-                       pframe_queue = &ptxservq->sta_pending;
-
-                       pxmitframe = dequeue_one_xmitframe(pxmitpriv, phwxmit, ptxservq, pframe_queue);
-
-                       if (pxmitframe) {
-                               phwxmit->accnt--;
-
-                               /* Remove sta node when there is no pending packets. */
-                               /* must be done after get_next and
-                                  before break */
-                               if (list_empty(&pframe_queue->queue))
-                                       list_del_init(&ptxservq->tx_pending);
-                               goto exit;
-                       }
-               }
-       }
-exit:
-       spin_unlock_bh(&pxmitpriv->lock);
-       return pxmitframe;
-}
-
-struct tx_servq *rtw_get_sta_pending23a(struct rtw_adapter *padapter, struct sta_info *psta, int up, u8 *ac)
-{
-       struct tx_servq *ptxservq = NULL;
-
-       switch (up) {
-       case 1:
-       case 2:
-               ptxservq = &psta->sta_xmitpriv.bk_q;
-               *(ac) = 3;
-               RT_TRACE(_module_rtl871x_xmit_c_, _drv_info_,
-                        "rtw_get_sta_pending23a : BK\n");
-               break;
-       case 4:
-       case 5:
-               ptxservq = &psta->sta_xmitpriv.vi_q;
-               *(ac) = 1;
-               RT_TRACE(_module_rtl871x_xmit_c_, _drv_info_,
-                        "rtw_get_sta_pending23a : VI\n");
-               break;
-       case 6:
-       case 7:
-               ptxservq = &psta->sta_xmitpriv.vo_q;
-               *(ac) = 0;
-               RT_TRACE(_module_rtl871x_xmit_c_, _drv_info_,
-                        "rtw_get_sta_pending23a : VO\n");
-               break;
-       case 0:
-       case 3:
-       default:
-               ptxservq = &psta->sta_xmitpriv.be_q;
-               *(ac) = 2;
-               RT_TRACE(_module_rtl871x_xmit_c_, _drv_info_,
-                        "rtw_get_sta_pending23a : BE\n");
-               break;
-       }
-       return ptxservq;
-}
-
-/*
- * Will enqueue pxmitframe to the proper queue,
- * and indicate it to xx_pending list.....
- */
-int rtw_xmit23a_classifier(struct rtw_adapter *padapter,
-                          struct xmit_frame *pxmitframe)
-{
-       struct sta_info *psta;
-       struct tx_servq *ptxservq;
-       struct pkt_attrib       *pattrib = &pxmitframe->attrib;
-       struct sta_priv *pstapriv = &padapter->stapriv;
-       struct hw_xmit  *phwxmits =  padapter->xmitpriv.hwxmits;
-       u8      ac_index;
-       int res = _SUCCESS;
-
-       if (pattrib->psta) {
-               psta = pattrib->psta;
-       } else {
-               DBG_8723A("%s, call rtw_get_stainfo23a()\n", __func__);
-               psta = rtw_get_stainfo23a(pstapriv, pattrib->ra);
-       }
-       if (psta == NULL) {
-               res = _FAIL;
-               DBG_8723A("rtw_xmit23a_classifier: psta == NULL\n");
-               RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_,
-                        "rtw_xmit23a_classifier: psta == NULL\n");
-               goto exit;
-       }
-       if (!(psta->state & _FW_LINKED)) {
-               DBG_8723A("%s, psta->state(0x%x) != _FW_LINKED\n", __func__,
-                         psta->state);
-               return _FAIL;
-       }
-       ptxservq = rtw_get_sta_pending23a(padapter, psta, pattrib->priority,
-                                      (u8 *)(&ac_index));
-
-       if (list_empty(&ptxservq->tx_pending)) {
-               list_add_tail(&ptxservq->tx_pending,
-                             get_list_head(phwxmits[ac_index].sta_queue));
-       }
-
-       list_add_tail(&pxmitframe->list, get_list_head(&ptxservq->sta_pending));
-       ptxservq->qcnt++;
-       phwxmits[ac_index].accnt++;
-exit:
-       return res;
-}
-
-void rtw_alloc_hwxmits23a(struct rtw_adapter *padapter)
-{
-       struct hw_xmit *hwxmits;
-       struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-       int size;
-
-       pxmitpriv->hwxmit_entry = HWXMIT_ENTRY;
-
-       size = sizeof(struct hw_xmit) * (pxmitpriv->hwxmit_entry + 1);
-       pxmitpriv->hwxmits = kzalloc(size, GFP_KERNEL);
-
-       hwxmits = pxmitpriv->hwxmits;
-
-       if (pxmitpriv->hwxmit_entry == 5) {
-               /* pxmitpriv->bmc_txqueue.head = 0; */
-               /* hwxmits[0] .phwtxqueue = &pxmitpriv->bmc_txqueue; */
-               hwxmits[0] .sta_queue = &pxmitpriv->bm_pending;
-
-               /* pxmitpriv->vo_txqueue.head = 0; */
-               /* hwxmits[1] .phwtxqueue = &pxmitpriv->vo_txqueue; */
-               hwxmits[1] .sta_queue = &pxmitpriv->vo_pending;
-
-               /* pxmitpriv->vi_txqueue.head = 0; */
-               /* hwxmits[2] .phwtxqueue = &pxmitpriv->vi_txqueue; */
-               hwxmits[2] .sta_queue = &pxmitpriv->vi_pending;
-
-               /* pxmitpriv->bk_txqueue.head = 0; */
-               /* hwxmits[3] .phwtxqueue = &pxmitpriv->bk_txqueue; */
-               hwxmits[3] .sta_queue = &pxmitpriv->bk_pending;
-
-               /* pxmitpriv->be_txqueue.head = 0; */
-               /* hwxmits[4] .phwtxqueue = &pxmitpriv->be_txqueue; */
-               hwxmits[4] .sta_queue = &pxmitpriv->be_pending;
-
-       } else if (pxmitpriv->hwxmit_entry == 4) {
-
-               /* pxmitpriv->vo_txqueue.head = 0; */
-               /* hwxmits[0] .phwtxqueue = &pxmitpriv->vo_txqueue; */
-               hwxmits[0] .sta_queue = &pxmitpriv->vo_pending;
-
-               /* pxmitpriv->vi_txqueue.head = 0; */
-               /* hwxmits[1] .phwtxqueue = &pxmitpriv->vi_txqueue; */
-               hwxmits[1] .sta_queue = &pxmitpriv->vi_pending;
-
-               /* pxmitpriv->be_txqueue.head = 0; */
-               /* hwxmits[2] .phwtxqueue = &pxmitpriv->be_txqueue; */
-               hwxmits[2] .sta_queue = &pxmitpriv->be_pending;
-
-               /* pxmitpriv->bk_txqueue.head = 0; */
-               /* hwxmits[3] .phwtxqueue = &pxmitpriv->bk_txqueue; */
-               hwxmits[3] .sta_queue = &pxmitpriv->bk_pending;
-       } else {
-
-       }
-}
-
-void rtw_free_hwxmits23a(struct rtw_adapter *padapter)
-{
-       struct hw_xmit *hwxmits;
-       struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-
-       hwxmits = pxmitpriv->hwxmits;
-       kfree(hwxmits);
-}
-
-void rtw_init_hwxmits23a(struct hw_xmit *phwxmit, int entry)
-{
-       int i;
-
-       for (i = 0; i < entry; i++, phwxmit++)
-               phwxmit->accnt = 0;
-}
-
-u32 rtw_get_ff_hwaddr23a(struct xmit_frame *pxmitframe)
-{
-       u32 addr;
-       struct pkt_attrib *pattrib = &pxmitframe->attrib;
-
-       switch (pattrib->qsel) {
-       case 0:
-       case 3:
-               addr = BE_QUEUE_INX;
-               break;
-       case 1:
-       case 2:
-               addr = BK_QUEUE_INX;
-               break;
-       case 4:
-       case 5:
-               addr = VI_QUEUE_INX;
-               break;
-       case 6:
-       case 7:
-               addr = VO_QUEUE_INX;
-               break;
-       case 0x10:
-               addr = BCN_QUEUE_INX;
-               break;
-       case 0x11:/* BC/MC in PS (HIQ) */
-               addr = HIGH_QUEUE_INX;
-               break;
-       case 0x12:
-       default:
-               addr = MGT_QUEUE_INX;
-               break;
-       }
-
-       return addr;
-}
-
-/*
- * The main transmit(tx) entry
- *
- * Return
- *     1       enqueue
- *     0       success, hardware will handle this xmit frame(packet)
- *     <0      fail
- */
-int rtw_xmit23a(struct rtw_adapter *padapter, struct sk_buff *skb)
-{
-       struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-       struct xmit_frame *pxmitframe = NULL;
-       int res;
-
-       pxmitframe = rtw_alloc_xmitframe(pxmitpriv);
-
-       if (pxmitframe == NULL) {
-               RT_TRACE(_module_xmit_osdep_c_, _drv_err_,
-                        "rtw_xmit23a: no more pxmitframe\n");
-               return -1;
-       }
-
-       res = update_attrib(padapter, skb, &pxmitframe->attrib);
-
-       if (res == _FAIL) {
-               RT_TRACE(_module_xmit_osdep_c_, _drv_err_,
-                        "rtw_xmit23a: update attrib fail\n");
-               rtw_free_xmitframe23a(pxmitpriv, pxmitframe);
-               return -1;
-       }
-       pxmitframe->pkt = skb;
-
-       pxmitframe->attrib.qsel = pxmitframe->attrib.priority;
-
-#ifdef CONFIG_8723AU_AP_MODE
-       spin_lock_bh(&pxmitpriv->lock);
-       if (xmitframe_enqueue_for_sleeping_sta23a(padapter, pxmitframe)) {
-               spin_unlock_bh(&pxmitpriv->lock);
-               return 1;
-       }
-       spin_unlock_bh(&pxmitpriv->lock);
-#endif
-
-       if (rtl8723au_hal_xmit(padapter, pxmitframe) == false)
-               return 1;
-
-       return 0;
-}
-
-#if defined(CONFIG_8723AU_AP_MODE)
-
-int xmitframe_enqueue_for_sleeping_sta23a(struct rtw_adapter *padapter, struct xmit_frame *pxmitframe)
-{
-       int ret = false;
-       struct sta_info *psta = NULL;
-       struct sta_priv *pstapriv = &padapter->stapriv;
-       struct pkt_attrib *pattrib = &pxmitframe->attrib;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       int bmcst = is_multicast_ether_addr(pattrib->ra);
-
-       if (!check_fwstate(pmlmepriv, WIFI_AP_STATE))
-               return ret;
-
-       if (pattrib->psta) {
-               psta = pattrib->psta;
-       } else {
-               DBG_8723A("%s, call rtw_get_stainfo23a()\n", __func__);
-               psta = rtw_get_stainfo23a(pstapriv, pattrib->ra);
-       }
-
-       if (psta == NULL) {
-               DBG_8723A("%s, psta == NUL\n", __func__);
-               return false;
-       }
-
-       if (!(psta->state & _FW_LINKED)) {
-               DBG_8723A("%s, psta->state(0x%x) != _FW_LINKED\n", __func__,
-                         psta->state);
-               return false;
-       }
-
-       if (pattrib->triggered == 1) {
-               if (bmcst)
-                       pattrib->qsel = 0x11;/* HIQ */
-               return ret;
-       }
-
-       if (bmcst) {
-               spin_lock_bh(&psta->sleep_q.lock);
-
-               if (pstapriv->sta_dz_bitmap) {
-                       /* if anyone sta is in ps mode */
-                       list_del_init(&pxmitframe->list);
-
-                       /* spin_lock_bh(&psta->sleep_q.lock); */
-
-                       list_add_tail(&pxmitframe->list, get_list_head(&psta->sleep_q));
-
-                       psta->sleepq_len++;
-
-                       pstapriv->tim_bitmap |= BIT(0);/*  */
-                       pstapriv->sta_dz_bitmap |= BIT(0);
-
-                       /* DBG_8723A("enqueue, sq_len =%d, tim =%x\n", psta->sleepq_len, pstapriv->tim_bitmap); */
-
-                       /* tx bc/mc packets after update bcn */
-                       update_beacon23a(padapter, WLAN_EID_TIM, NULL, false);
-
-                       /* spin_unlock_bh(&psta->sleep_q.lock); */
-
-                       ret = true;
-
-               }
-
-               spin_unlock_bh(&psta->sleep_q.lock);
-
-               return ret;
-
-       }
-
-       spin_lock_bh(&psta->sleep_q.lock);
-
-       if (psta->state&WIFI_SLEEP_STATE) {
-               u8 wmmps_ac = 0;
-
-               if (pstapriv->sta_dz_bitmap & CHKBIT(psta->aid)) {
-                       list_del_init(&pxmitframe->list);
-
-                       /* spin_lock_bh(&psta->sleep_q.lock); */
-
-                       list_add_tail(&pxmitframe->list, get_list_head(&psta->sleep_q));
-
-                       psta->sleepq_len++;
-
-                       switch (pattrib->priority) {
-                       case 1:
-                       case 2:
-                               wmmps_ac = psta->uapsd_bk & BIT(0);
-                               break;
-                       case 4:
-                       case 5:
-                               wmmps_ac = psta->uapsd_vi & BIT(0);
-                               break;
-                       case 6:
-                       case 7:
-                               wmmps_ac = psta->uapsd_vo & BIT(0);
-                               break;
-                       case 0:
-                       case 3:
-                       default:
-                               wmmps_ac = psta->uapsd_be & BIT(0);
-                               break;
-                       }
-
-                       if (wmmps_ac)
-                               psta->sleepq_ac_len++;
-
-                       if (((psta->has_legacy_ac) && (!wmmps_ac)) ||
-                          ((!psta->has_legacy_ac) && (wmmps_ac))) {
-                               pstapriv->tim_bitmap |= CHKBIT(psta->aid);
-
-                               if (psta->sleepq_len == 1) {
-                                       /* update BCN for TIM IE */
-                                       update_beacon23a(padapter, WLAN_EID_TIM,
-                                                        NULL, false);
-                               }
-                       }
-
-                       /* spin_unlock_bh(&psta->sleep_q.lock); */
-
-                       /* if (psta->sleepq_len > (NR_XMITFRAME>>3)) */
-                       /*  */
-                       /*      wakeup_sta_to_xmit23a(padapter, psta); */
-                       /*  */
-
-                       ret = true;
-
-               }
-
-       }
-
-       spin_unlock_bh(&psta->sleep_q.lock);
-
-       return ret;
-}
-
-static void
-dequeue_xmitframes_to_sleeping_queue(struct rtw_adapter *padapter,
-                                    struct sta_info *psta,
-                                    struct rtw_queue *pframequeue)
-{
-       int ret;
-       struct list_head *phead;
-       u8 ac_index;
-       struct tx_servq *ptxservq;
-       struct pkt_attrib *pattrib;
-       struct xmit_frame *pxmitframe, *ptmp;
-       struct hw_xmit *phwxmits = padapter->xmitpriv.hwxmits;
-
-       phead = get_list_head(pframequeue);
-       list_for_each_entry_safe(pxmitframe, ptmp, phead, list) {
-               ret = xmitframe_enqueue_for_sleeping_sta23a(padapter, pxmitframe);
-
-               if (ret == true) {
-                       pattrib = &pxmitframe->attrib;
-
-                       ptxservq = rtw_get_sta_pending23a(padapter, psta, pattrib->priority, (u8 *)(&ac_index));
-
-                       ptxservq->qcnt--;
-                       phwxmits[ac_index].accnt--;
-               } else {
-                       /* DBG_8723A("xmitframe_enqueue_for_sleeping_sta23a return false\n"); */
-               }
-       }
-}
-
-void stop_sta_xmit23a(struct rtw_adapter *padapter, struct sta_info *psta)
-{
-       struct sta_info *psta_bmc;
-       struct sta_xmit_priv *pstaxmitpriv;
-       struct sta_priv *pstapriv = &padapter->stapriv;
-       struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-
-       pstaxmitpriv = &psta->sta_xmitpriv;
-
-       /* for BC/MC Frames */
-       psta_bmc = rtw_get_bcmc_stainfo23a(padapter);
-
-       spin_lock_bh(&pxmitpriv->lock);
-
-       psta->state |= WIFI_SLEEP_STATE;
-
-       pstapriv->sta_dz_bitmap |= CHKBIT(psta->aid);
-
-       dequeue_xmitframes_to_sleeping_queue(padapter, psta, &pstaxmitpriv->vo_q.sta_pending);
-       list_del_init(&pstaxmitpriv->vo_q.tx_pending);
-
-       dequeue_xmitframes_to_sleeping_queue(padapter, psta, &pstaxmitpriv->vi_q.sta_pending);
-       list_del_init(&pstaxmitpriv->vi_q.tx_pending);
-
-       dequeue_xmitframes_to_sleeping_queue(padapter, psta,
-                                            &pstaxmitpriv->be_q.sta_pending);
-       list_del_init(&pstaxmitpriv->be_q.tx_pending);
-
-       dequeue_xmitframes_to_sleeping_queue(padapter, psta,
-                                            &pstaxmitpriv->bk_q.sta_pending);
-       list_del_init(&pstaxmitpriv->bk_q.tx_pending);
-
-       /* for BC/MC Frames */
-       pstaxmitpriv = &psta_bmc->sta_xmitpriv;
-       dequeue_xmitframes_to_sleeping_queue(padapter, psta_bmc,
-                                            &pstaxmitpriv->be_q.sta_pending);
-       list_del_init(&pstaxmitpriv->be_q.tx_pending);
-
-       spin_unlock_bh(&pxmitpriv->lock);
-}
-
-void wakeup_sta_to_xmit23a(struct rtw_adapter *padapter, struct sta_info *psta)
-{
-       u8 update_mask = 0, wmmps_ac = 0;
-       struct sta_info *psta_bmc;
-       struct list_head *phead;
-       struct xmit_frame *pxmitframe = NULL, *ptmp;
-       struct sta_priv *pstapriv = &padapter->stapriv;
-       struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-
-       spin_lock_bh(&pxmitpriv->lock);
-       phead = get_list_head(&psta->sleep_q);
-       list_for_each_entry_safe(pxmitframe, ptmp, phead, list) {
-               list_del_init(&pxmitframe->list);
-
-               switch (pxmitframe->attrib.priority) {
-               case 1:
-               case 2:
-                       wmmps_ac = psta->uapsd_bk & BIT(1);
-                       break;
-               case 4:
-               case 5:
-                       wmmps_ac = psta->uapsd_vi & BIT(1);
-                       break;
-               case 6:
-               case 7:
-                       wmmps_ac = psta->uapsd_vo & BIT(1);
-                       break;
-               case 0:
-               case 3:
-               default:
-                       wmmps_ac = psta->uapsd_be & BIT(1);
-                       break;
-               }
-
-               psta->sleepq_len--;
-               if (psta->sleepq_len > 0)
-                       pxmitframe->attrib.mdata = 1;
-               else
-                       pxmitframe->attrib.mdata = 0;
-
-               if (wmmps_ac) {
-                       psta->sleepq_ac_len--;
-                       if (psta->sleepq_ac_len > 0) {
-                               pxmitframe->attrib.mdata = 1;
-                               pxmitframe->attrib.eosp = 0;
-                       } else {
-                               pxmitframe->attrib.mdata = 0;
-                               pxmitframe->attrib.eosp = 1;
-                       }
-               }
-
-               pxmitframe->attrib.triggered = 1;
-               rtl8723au_hal_xmitframe_enqueue(padapter, pxmitframe);
-       }
-
-       if (psta->sleepq_len == 0) {
-               pstapriv->tim_bitmap &= ~CHKBIT(psta->aid);
-
-               /* update BCN for TIM IE */
-               update_mask = BIT(0);
-
-               if (psta->state&WIFI_SLEEP_STATE)
-                       psta->state ^= WIFI_SLEEP_STATE;
-
-               if (psta->state & WIFI_STA_ALIVE_CHK_STATE) {
-                       psta->expire_to = pstapriv->expire_to;
-                       psta->state ^= WIFI_STA_ALIVE_CHK_STATE;
-               }
-
-               pstapriv->sta_dz_bitmap &= ~CHKBIT(psta->aid);
-       }
-       /* spin_unlock_bh(&psta->sleep_q.lock); */
-       spin_unlock_bh(&pxmitpriv->lock);
-
-       /* for BC/MC Frames */
-       psta_bmc = rtw_get_bcmc_stainfo23a(padapter);
-       if (!psta_bmc)
-               return;
-
-       if ((pstapriv->sta_dz_bitmap&0xfffe) == 0x0) {
-               /* no any sta in ps mode */
-               spin_lock_bh(&pxmitpriv->lock);
-               phead = get_list_head(&psta_bmc->sleep_q);
-               list_for_each_entry_safe(pxmitframe, ptmp, phead, list) {
-                       list_del_init(&pxmitframe->list);
-
-                       psta_bmc->sleepq_len--;
-                       if (psta_bmc->sleepq_len > 0)
-                               pxmitframe->attrib.mdata = 1;
-                       else
-                               pxmitframe->attrib.mdata = 0;
-
-                       pxmitframe->attrib.triggered = 1;
-                       rtl8723au_hal_xmitframe_enqueue(padapter, pxmitframe);
-               }
-               if (psta_bmc->sleepq_len == 0) {
-                       pstapriv->tim_bitmap &= ~BIT(0);
-                       pstapriv->sta_dz_bitmap &= ~BIT(0);
-
-                       /* update BCN for TIM IE */
-                       /* update_BCNTIM(padapter); */
-                       update_mask |= BIT(1);
-               }
-               /* spin_unlock_bh(&psta_bmc->sleep_q.lock); */
-               spin_unlock_bh(&pxmitpriv->lock);
-       }
-
-       if (update_mask)
-               update_beacon23a(padapter, WLAN_EID_TIM, NULL, false);
-}
-
-void xmit_delivery_enabled_frames23a(struct rtw_adapter *padapter,
-                                 struct sta_info *psta)
-{
-       u8 wmmps_ac = 0;
-       struct list_head *phead;
-       struct xmit_frame *pxmitframe, *ptmp;
-       struct sta_priv *pstapriv = &padapter->stapriv;
-       struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-
-       /* spin_lock_bh(&psta->sleep_q.lock); */
-       spin_lock_bh(&pxmitpriv->lock);
-       phead = get_list_head(&psta->sleep_q);
-       list_for_each_entry_safe(pxmitframe, ptmp, phead, list) {
-               switch (pxmitframe->attrib.priority) {
-               case 1:
-               case 2:
-                       wmmps_ac = psta->uapsd_bk & BIT(1);
-                       break;
-               case 4:
-               case 5:
-                       wmmps_ac = psta->uapsd_vi & BIT(1);
-                       break;
-               case 6:
-               case 7:
-                       wmmps_ac = psta->uapsd_vo & BIT(1);
-                       break;
-               case 0:
-               case 3:
-               default:
-                       wmmps_ac = psta->uapsd_be & BIT(1);
-                       break;
-               }
-
-               if (!wmmps_ac)
-                       continue;
-
-               list_del_init(&pxmitframe->list);
-
-               psta->sleepq_len--;
-               psta->sleepq_ac_len--;
-
-               if (psta->sleepq_ac_len > 0) {
-                       pxmitframe->attrib.mdata = 1;
-                       pxmitframe->attrib.eosp = 0;
-               } else {
-                       pxmitframe->attrib.mdata = 0;
-                       pxmitframe->attrib.eosp = 1;
-               }
-
-               pxmitframe->attrib.triggered = 1;
-
-               rtl8723au_hal_xmitframe_enqueue(padapter, pxmitframe);
-
-               if ((psta->sleepq_ac_len == 0) && (!psta->has_legacy_ac) &&
-                   (wmmps_ac)) {
-                       pstapriv->tim_bitmap &= ~CHKBIT(psta->aid);
-
-                       /* update BCN for TIM IE */
-                       update_beacon23a(padapter, WLAN_EID_TIM, NULL, false);
-               }
-       }
-       spin_unlock_bh(&pxmitpriv->lock);
-}
-
-#endif
-
-void rtw_sctx_init23a(struct submit_ctx *sctx, int timeout_ms)
-{
-       sctx->timeout_ms = timeout_ms;
-       init_completion(&sctx->done);
-       sctx->status = RTW_SCTX_SUBMITTED;
-}
-
-int rtw_sctx_wait23a(struct submit_ctx *sctx)
-{
-       int ret = _FAIL;
-       unsigned long expire;
-       int status = 0;
-
-       expire = sctx->timeout_ms ? msecs_to_jiffies(sctx->timeout_ms) :
-                MAX_SCHEDULE_TIMEOUT;
-       if (!wait_for_completion_timeout(&sctx->done, expire)) {
-               /* timeout, do something?? */
-               status = RTW_SCTX_DONE_TIMEOUT;
-               DBG_8723A("%s timeout\n", __func__);
-       } else {
-               status = sctx->status;
-       }
-
-       if (status == RTW_SCTX_DONE_SUCCESS)
-               ret = _SUCCESS;
-
-       return ret;
-}
-
-static bool rtw_sctx_chk_waring_status(int status)
-{
-       switch (status) {
-       case RTW_SCTX_DONE_UNKNOWN:
-       case RTW_SCTX_DONE_BUF_ALLOC:
-       case RTW_SCTX_DONE_BUF_FREE:
-       case RTW_SCTX_DONE_DRV_STOP:
-       case RTW_SCTX_DONE_DEV_REMOVE:
-               return true;
-       default:
-               return false;
-       }
-}
-
-void rtw23a_sctx_done_err(struct submit_ctx **sctx, int status)
-{
-       if (*sctx) {
-               if (rtw_sctx_chk_waring_status(status))
-                       DBG_8723A("%s status:%d\n", __func__, status);
-               (*sctx)->status = status;
-               complete(&(*sctx)->done);
-               *sctx = NULL;
-       }
-}
-
-int rtw_ack_tx_wait23a(struct xmit_priv *pxmitpriv, u32 timeout_ms)
-{
-       struct submit_ctx *pack_tx_ops = &pxmitpriv->ack_tx_ops;
-
-       pack_tx_ops->timeout_ms = timeout_ms;
-       pack_tx_ops->status = RTW_SCTX_SUBMITTED;
-
-       return rtw_sctx_wait23a(pack_tx_ops);
-}
-
diff --git a/drivers/staging/rtl8723au/hal/Hal8723PwrSeq.c b/drivers/staging/rtl8723au/hal/Hal8723PwrSeq.c
deleted file mode 100644 (file)
index 747f86c..0000000
+++ /dev/null
@@ -1,80 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-
-#include "Hal8723PwrSeq.h"
-
-/*
-    drivers should parse below arrays and do the corresponding actions
-*/
-/* 3 Power on  Array */
-struct wlan_pwr_cfg rtl8723AU_power_on_flow[RTL8723A_TRANS_CARDEMU_TO_ACT_STEPS+RTL8723A_TRANS_END_STEPS] = {
-       RTL8723A_TRANS_CARDEMU_TO_ACT
-       RTL8723A_TRANS_END
-};
-
-/* 3 Radio off GPIO Array */
-struct wlan_pwr_cfg rtl8723AU_radio_off_flow[RTL8723A_TRANS_ACT_TO_CARDEMU_STEPS+RTL8723A_TRANS_END_STEPS] = {
-       RTL8723A_TRANS_ACT_TO_CARDEMU
-       RTL8723A_TRANS_END
-};
-
-/* 3 Card Disable Array */
-struct wlan_pwr_cfg rtl8723AU_card_disable_flow[RTL8723A_TRANS_ACT_TO_CARDEMU_STEPS+RTL8723A_TRANS_CARDEMU_TO_PDN_STEPS+RTL8723A_TRANS_END_STEPS] = {
-       RTL8723A_TRANS_ACT_TO_CARDEMU
-       RTL8723A_TRANS_CARDEMU_TO_CARDDIS
-       RTL8723A_TRANS_END
-};
-
-/* 3 Card Enable Array */
-struct wlan_pwr_cfg rtl8723AU_card_enable_flow[RTL8723A_TRANS_ACT_TO_CARDEMU_STEPS+RTL8723A_TRANS_CARDEMU_TO_PDN_STEPS+RTL8723A_TRANS_END_STEPS] = {
-       RTL8723A_TRANS_CARDDIS_TO_CARDEMU
-       RTL8723A_TRANS_CARDEMU_TO_ACT
-       RTL8723A_TRANS_END
-};
-
-/* 3 Suspend Array */
-struct wlan_pwr_cfg rtl8723AU_suspend_flow[RTL8723A_TRANS_ACT_TO_CARDEMU_STEPS+RTL8723A_TRANS_CARDEMU_TO_SUS_STEPS+RTL8723A_TRANS_END_STEPS] = {
-       RTL8723A_TRANS_ACT_TO_CARDEMU
-       RTL8723A_TRANS_CARDEMU_TO_SUS
-       RTL8723A_TRANS_END
-};
-
-/* 3 Resume Array */
-struct wlan_pwr_cfg rtl8723AU_resume_flow[RTL8723A_TRANS_ACT_TO_CARDEMU_STEPS+RTL8723A_TRANS_CARDEMU_TO_SUS_STEPS+RTL8723A_TRANS_END_STEPS] = {
-       RTL8723A_TRANS_SUS_TO_CARDEMU
-       RTL8723A_TRANS_CARDEMU_TO_ACT
-       RTL8723A_TRANS_END
-};
-
-/* 3 HWPDN Array */
-struct wlan_pwr_cfg rtl8723AU_hwpdn_flow[RTL8723A_TRANS_ACT_TO_CARDEMU_STEPS+RTL8723A_TRANS_CARDEMU_TO_PDN_STEPS+RTL8723A_TRANS_END_STEPS] = {
-       RTL8723A_TRANS_ACT_TO_CARDEMU
-       RTL8723A_TRANS_CARDEMU_TO_PDN
-       RTL8723A_TRANS_END
-};
-
-/* 3 Enter LPS */
-struct wlan_pwr_cfg rtl8723AU_enter_lps_flow[RTL8723A_TRANS_ACT_TO_LPS_STEPS+RTL8723A_TRANS_END_STEPS] = {
-       /* FW behavior */
-       RTL8723A_TRANS_ACT_TO_LPS
-       RTL8723A_TRANS_END
-};
-
-/* 3 Leave LPS */
-struct wlan_pwr_cfg rtl8723AU_leave_lps_flow[RTL8723A_TRANS_LPS_TO_ACT_STEPS+RTL8723A_TRANS_END_STEPS] = {
-       /* FW behavior */
-       RTL8723A_TRANS_LPS_TO_ACT
-       RTL8723A_TRANS_END
-};
diff --git a/drivers/staging/rtl8723au/hal/Hal8723UHWImg_CE.c b/drivers/staging/rtl8723au/hal/Hal8723UHWImg_CE.c
deleted file mode 100644 (file)
index 56833da..0000000
+++ /dev/null
@@ -1,136 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-
-/*Created on  2013/01/14, 15:51*/
-#include "odm_precomp.h"
-
-u32 Rtl8723UPHY_REG_Array_PG[Rtl8723UPHY_REG_Array_PGLength] = {
-       0xe00, 0xffffffff, 0x0a0c0c0c,
-       0xe04, 0xffffffff, 0x02040608,
-       0xe08, 0x0000ff00, 0x00000000,
-       0x86c, 0xffffff00, 0x00000000,
-       0xe10, 0xffffffff, 0x0a0c0d0e,
-       0xe14, 0xffffffff, 0x02040608,
-       0xe18, 0xffffffff, 0x0a0c0d0e,
-       0xe1c, 0xffffffff, 0x02040608,
-       0x830, 0xffffffff, 0x0a0c0c0c,
-       0x834, 0xffffffff, 0x02040608,
-       0x838, 0xffffff00, 0x00000000,
-       0x86c, 0x000000ff, 0x00000000,
-       0x83c, 0xffffffff, 0x0a0c0d0e,
-       0x848, 0xffffffff, 0x02040608,
-       0x84c, 0xffffffff, 0x0a0c0d0e,
-       0x868, 0xffffffff, 0x02040608,
-       0xe00, 0xffffffff, 0x00000000,
-       0xe04, 0xffffffff, 0x00000000,
-       0xe08, 0x0000ff00, 0x00000000,
-       0x86c, 0xffffff00, 0x00000000,
-       0xe10, 0xffffffff, 0x00000000,
-       0xe14, 0xffffffff, 0x00000000,
-       0xe18, 0xffffffff, 0x00000000,
-       0xe1c, 0xffffffff, 0x00000000,
-       0x830, 0xffffffff, 0x00000000,
-       0x834, 0xffffffff, 0x00000000,
-       0x838, 0xffffff00, 0x00000000,
-       0x86c, 0x000000ff, 0x00000000,
-       0x83c, 0xffffffff, 0x00000000,
-       0x848, 0xffffffff, 0x00000000,
-       0x84c, 0xffffffff, 0x00000000,
-       0x868, 0xffffffff, 0x00000000,
-       0xe00, 0xffffffff, 0x04040404,
-       0xe04, 0xffffffff, 0x00020204,
-       0xe08, 0x0000ff00, 0x00000000,
-       0x86c, 0xffffff00, 0x00000000,
-       0xe10, 0xffffffff, 0x06060606,
-       0xe14, 0xffffffff, 0x00020406,
-       0xe18, 0xffffffff, 0x00000000,
-       0xe1c, 0xffffffff, 0x00000000,
-       0x830, 0xffffffff, 0x04040404,
-       0x834, 0xffffffff, 0x00020204,
-       0x838, 0xffffff00, 0x00000000,
-       0x86c, 0x000000ff, 0x00000000,
-       0x83c, 0xffffffff, 0x06060606,
-       0x848, 0xffffffff, 0x00020406,
-       0x84c, 0xffffffff, 0x00000000,
-       0x868, 0xffffffff, 0x00000000,
-       0xe00, 0xffffffff, 0x00000000,
-       0xe04, 0xffffffff, 0x00000000,
-       0xe08, 0x0000ff00, 0x00000000,
-       0x86c, 0xffffff00, 0x00000000,
-       0xe10, 0xffffffff, 0x00000000,
-       0xe14, 0xffffffff, 0x00000000,
-       0xe18, 0xffffffff, 0x00000000,
-       0xe1c, 0xffffffff, 0x00000000,
-       0x830, 0xffffffff, 0x00000000,
-       0x834, 0xffffffff, 0x00000000,
-       0x838, 0xffffff00, 0x00000000,
-       0x86c, 0x000000ff, 0x00000000,
-       0x83c, 0xffffffff, 0x00000000,
-       0x848, 0xffffffff, 0x00000000,
-       0x84c, 0xffffffff, 0x00000000,
-       0x868, 0xffffffff, 0x00000000,
-       0xe00, 0xffffffff, 0x00000000,
-       0xe04, 0xffffffff, 0x00000000,
-       0xe08, 0x0000ff00, 0x00000000,
-       0x86c, 0xffffff00, 0x00000000,
-       0xe10, 0xffffffff, 0x00000000,
-       0xe14, 0xffffffff, 0x00000000,
-       0xe18, 0xffffffff, 0x00000000,
-       0xe1c, 0xffffffff, 0x00000000,
-       0x830, 0xffffffff, 0x00000000,
-       0x834, 0xffffffff, 0x00000000,
-       0x838, 0xffffff00, 0x00000000,
-       0x86c, 0x000000ff, 0x00000000,
-       0x83c, 0xffffffff, 0x00000000,
-       0x848, 0xffffffff, 0x00000000,
-       0x84c, 0xffffffff, 0x00000000,
-       0x868, 0xffffffff, 0x00000000,
-       0xe00, 0xffffffff, 0x04040404,
-       0xe04, 0xffffffff, 0x00020204,
-       0xe08, 0x0000ff00, 0x00000000,
-       0x86c, 0xffffff00, 0x00000000,
-       0xe10, 0xffffffff, 0x00000000,
-       0xe14, 0xffffffff, 0x00000000,
-       0xe18, 0xffffffff, 0x00000000,
-       0xe1c, 0xffffffff, 0x00000000,
-       0x830, 0xffffffff, 0x04040404,
-       0x834, 0xffffffff, 0x00020204,
-       0x838, 0xffffff00, 0x00000000,
-       0x86c, 0x000000ff, 0x00000000,
-       0x83c, 0xffffffff, 0x00000000,
-       0x848, 0xffffffff, 0x00000000,
-       0x84c, 0xffffffff, 0x00000000,
-       0x868, 0xffffffff, 0x00000000,
-       0xe00, 0xffffffff, 0x00000000,
-       0xe04, 0xffffffff, 0x00000000,
-       0xe08, 0x0000ff00, 0x00000000,
-       0x86c, 0xffffff00, 0x00000000,
-       0xe10, 0xffffffff, 0x00000000,
-       0xe14, 0xffffffff, 0x00000000,
-       0xe18, 0xffffffff, 0x00000000,
-       0xe1c, 0xffffffff, 0x00000000,
-       0x830, 0xffffffff, 0x00000000,
-       0x834, 0xffffffff, 0x00000000,
-       0x838, 0xffffff00, 0x00000000,
-       0x86c, 0x000000ff, 0x00000000,
-       0x83c, 0xffffffff, 0x00000000,
-       0x848, 0xffffffff, 0x00000000,
-       0x84c, 0xffffffff, 0x00000000,
-       0x868, 0xffffffff, 0x00000000,
-       };
-
-u32 Rtl8723UMACPHY_Array_PG[Rtl8723UMACPHY_Array_PGLength] = {
-       0x0,
-};
diff --git a/drivers/staging/rtl8723au/hal/HalDMOutSrc8723A_CE.c b/drivers/staging/rtl8723au/hal/HalDMOutSrc8723A_CE.c
deleted file mode 100644 (file)
index 3f9ec9e..0000000
+++ /dev/null
@@ -1,1097 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-/*  Description: */
-/*  This file is for 92CE/92CU dynamic mechanism only */
-
-/*  include files */
-
-#include "odm_precomp.h"
-#include <usb_ops_linux.h>
-
-#define                DPK_DELTA_MAPPING_NUM   13
-#define                index_mapping_HP_NUM    15
-/* 091212 chiyokolin */
-static void
-odm_TXPowerTrackingCallback_ThermalMeter_92C(struct rtw_adapter *Adapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(Adapter);
-       struct dm_priv *pdmpriv = &pHalData->dmpriv;
-       u8 ThermalValue = 0, delta, delta_LCK, delta_IQK, delta_HP;
-       int ele_A, ele_D, TempCCk, X, value32;
-       int Y, ele_C;
-       s8 OFDM_index[2], CCK_index = 0, OFDM_index_old[2] = {0};
-       s8 CCK_index_old = 0;
-       int i = 0;
-       u8 OFDM_min_index = 6, rf; /* OFDM BB Swing should be less than +3.0dB*/
-       u8 ThermalValue_HP_count = 0;
-       u32 ThermalValue_HP = 0;
-       s32 index_mapping_HP[index_mapping_HP_NUM] = {
-               0, 1, 3, 4, 6,
-               7, 9, 10, 12, 13,
-               15, 16, 18, 19, 21
-       };
-       s8 index_HP;
-
-       pdmpriv->TXPowerTrackingCallbackCnt++;  /* cosa add for debug */
-       pdmpriv->bTXPowerTrackingInit = true;
-
-       if (pHalData->CurrentChannel == 14 && !pdmpriv->bCCKinCH14)
-               pdmpriv->bCCKinCH14 = true;
-       else if (pHalData->CurrentChannel != 14 && pdmpriv->bCCKinCH14)
-               pdmpriv->bCCKinCH14 = false;
-
-       ThermalValue = (u8)PHY_QueryRFReg(Adapter, RF_PATH_A, RF_T_METER,
-                                         0x1f);/*  0x24: RF Reg[4:0]    */
-
-       rtl8723a_phy_ap_calibrate(Adapter, (ThermalValue -
-                                 pHalData->EEPROMThermalMeter));
-
-       if (pHalData->rf_type == RF_2T2R)
-               rf = 2;
-       else
-               rf = 1;
-
-       if (ThermalValue) {
-               /* Query OFDM path A default setting     */
-               ele_D = rtl8723au_read32(Adapter, rOFDM0_XATxIQImbalance) &
-                       bMaskOFDM_D;
-               for (i = 0; i < OFDM_TABLE_SIZE_92C; i++) {
-                       /* find the index */
-                       if (ele_D == (OFDMSwingTable23A[i]&bMaskOFDM_D)) {
-                               OFDM_index_old[0] = (u8)i;
-                               break;
-                       }
-               }
-
-               /* Query OFDM path B default setting  */
-               if (pHalData->rf_type == RF_2T2R) {
-                       ele_D = rtl8723au_read32(Adapter,
-                                                rOFDM0_XBTxIQImbalance);
-                       ele_D &= bMaskOFDM_D;
-                       for (i = 0; i < OFDM_TABLE_SIZE_92C; i++) {     /* find the index  */
-                               if (ele_D == (OFDMSwingTable23A[i]&bMaskOFDM_D)) {
-                                       OFDM_index_old[1] = (u8)i;
-                                       break;
-                               }
-                       }
-               }
-
-               /* Query CCK default setting From 0xa24 */
-               TempCCk = rtl8723au_read32(Adapter, rCCK0_TxFilter2) & bMaskCCK;
-               for (i = 0 ; i < CCK_TABLE_SIZE ; i++) {
-                       if (pdmpriv->bCCKinCH14) {
-                               if (!memcmp(&TempCCk,
-                                           &CCKSwingTable_Ch1423A[i][2], 4)) {
-                                       CCK_index_old = (u8)i;
-                                       break;
-                               }
-                       } else {
-                               if (!memcmp(&TempCCk,
-                                           &CCKSwingTable_Ch1_Ch1323A[i][2], 4)) {
-                                       CCK_index_old = (u8)i;
-                                       break;
-                               }
-                       }
-               }
-
-               if (!pdmpriv->ThermalValue) {
-                       pdmpriv->ThermalValue = pHalData->EEPROMThermalMeter;
-                       pdmpriv->ThermalValue_LCK = ThermalValue;
-                       pdmpriv->ThermalValue_IQK = ThermalValue;
-                       pdmpriv->ThermalValue_DPK = pHalData->EEPROMThermalMeter;
-
-                       for (i = 0; i < rf; i++) {
-                               pdmpriv->OFDM_index_HP[i] = OFDM_index_old[i];
-                               pdmpriv->OFDM_index[i] = OFDM_index_old[i];
-                       }
-                       pdmpriv->CCK_index_HP = CCK_index_old;
-                       pdmpriv->CCK_index = CCK_index_old;
-               }
-
-               if (pHalData->BoardType == BOARD_USB_High_PA) {
-                       pdmpriv->ThermalValue_HP[pdmpriv->ThermalValue_HP_index] = ThermalValue;
-                       pdmpriv->ThermalValue_HP_index++;
-                       if (pdmpriv->ThermalValue_HP_index == HP_THERMAL_NUM)
-                               pdmpriv->ThermalValue_HP_index = 0;
-
-                       for (i = 0; i < HP_THERMAL_NUM; i++) {
-                               if (pdmpriv->ThermalValue_HP[i]) {
-                                       ThermalValue_HP += pdmpriv->ThermalValue_HP[i];
-                                       ThermalValue_HP_count++;
-                               }
-                       }
-
-                       if (ThermalValue_HP_count)
-                               ThermalValue = (u8)(ThermalValue_HP / ThermalValue_HP_count);
-               }
-
-               delta = (ThermalValue > pdmpriv->ThermalValue) ?
-                       (ThermalValue - pdmpriv->ThermalValue) :
-                       (pdmpriv->ThermalValue - ThermalValue);
-               if (pHalData->BoardType == BOARD_USB_High_PA) {
-                       if (pdmpriv->bDoneTxpower)
-                               delta_HP = (ThermalValue > pdmpriv->ThermalValue) ?
-                                          (ThermalValue - pdmpriv->ThermalValue) :
-                                          (pdmpriv->ThermalValue - ThermalValue);
-                       else
-                               delta_HP = ThermalValue > pHalData->EEPROMThermalMeter ?
-                                          (ThermalValue - pHalData->EEPROMThermalMeter) :
-                                          (pHalData->EEPROMThermalMeter - ThermalValue);
-               } else {
-                       delta_HP = 0;
-               }
-               delta_LCK = (ThermalValue > pdmpriv->ThermalValue_LCK) ?
-                           (ThermalValue - pdmpriv->ThermalValue_LCK) :
-                           (pdmpriv->ThermalValue_LCK - ThermalValue);
-               delta_IQK = (ThermalValue > pdmpriv->ThermalValue_IQK) ?
-                           (ThermalValue - pdmpriv->ThermalValue_IQK) :
-                           (pdmpriv->ThermalValue_IQK - ThermalValue);
-
-               if (delta_LCK > 1) {
-                       pdmpriv->ThermalValue_LCK = ThermalValue;
-                       rtl8723a_phy_lc_calibrate(Adapter);
-               }
-
-               if ((delta > 0 || delta_HP > 0) && pdmpriv->TxPowerTrackControl) {
-                       if (pHalData->BoardType == BOARD_USB_High_PA) {
-                               pdmpriv->bDoneTxpower = true;
-                               delta_HP = ThermalValue > pHalData->EEPROMThermalMeter ?
-                                          (ThermalValue - pHalData->EEPROMThermalMeter) :
-                                          (pHalData->EEPROMThermalMeter - ThermalValue);
-
-                               if (delta_HP > index_mapping_HP_NUM-1)
-                                       index_HP = index_mapping_HP[index_mapping_HP_NUM-1];
-                               else
-                                       index_HP = index_mapping_HP[delta_HP];
-
-                               if (ThermalValue > pHalData->EEPROMThermalMeter) {
-                                       /* set larger Tx power */
-                                       for (i = 0; i < rf; i++)
-                                               OFDM_index[i] = pdmpriv->OFDM_index_HP[i] - index_HP;
-                                       CCK_index = pdmpriv->CCK_index_HP - index_HP;
-                               } else {
-                                       for (i = 0; i < rf; i++)
-                                               OFDM_index[i] = pdmpriv->OFDM_index_HP[i] + index_HP;
-                                       CCK_index = pdmpriv->CCK_index_HP + index_HP;
-                               }
-
-                               delta_HP = (ThermalValue > pdmpriv->ThermalValue) ?
-                                          (ThermalValue - pdmpriv->ThermalValue) :
-                                          (pdmpriv->ThermalValue - ThermalValue);
-                       } else {
-                               if (ThermalValue > pdmpriv->ThermalValue) {
-                                       for (i = 0; i < rf; i++)
-                                               pdmpriv->OFDM_index[i] -= delta;
-                                       pdmpriv->CCK_index -= delta;
-                               } else {
-                                       for (i = 0; i < rf; i++)
-                                               pdmpriv->OFDM_index[i] += delta;
-                                       pdmpriv->CCK_index += delta;
-                               }
-                       }
-
-                       /* no adjust */
-                       if (pHalData->BoardType != BOARD_USB_High_PA) {
-                               if (ThermalValue > pHalData->EEPROMThermalMeter) {
-                                       for (i = 0; i < rf; i++)
-                                               OFDM_index[i] = pdmpriv->OFDM_index[i]+1;
-                                       CCK_index = pdmpriv->CCK_index+1;
-                               } else {
-                                       for (i = 0; i < rf; i++)
-                                               OFDM_index[i] = pdmpriv->OFDM_index[i];
-                                       CCK_index = pdmpriv->CCK_index;
-                               }
-                       }
-                       for (i = 0; i < rf; i++) {
-                               if (OFDM_index[i] > (OFDM_TABLE_SIZE_92C-1))
-                                       OFDM_index[i] = (OFDM_TABLE_SIZE_92C-1);
-                               else if (OFDM_index[i] < OFDM_min_index)
-                                       OFDM_index[i] = OFDM_min_index;
-                       }
-
-                       if (CCK_index > (CCK_TABLE_SIZE-1))
-                               CCK_index = CCK_TABLE_SIZE-1;
-                       else if (CCK_index < 0)
-                               CCK_index = 0;
-               }
-
-               if (pdmpriv->TxPowerTrackControl &&
-                   (delta != 0 || delta_HP != 0)) {
-                       /* Adujst OFDM Ant_A according to IQK result */
-                       ele_D = (OFDMSwingTable23A[OFDM_index[0]] & 0xFFC00000)>>22;
-                       X = pdmpriv->RegE94;
-                       Y = pdmpriv->RegE9C;
-
-                       if (X != 0) {
-                               if ((X & 0x00000200) != 0)
-                                       X = X | 0xFFFFFC00;
-                               ele_A = ((X * ele_D)>>8)&0x000003FF;
-
-                               /* new element C = element D x Y */
-                               if ((Y & 0x00000200) != 0)
-                                       Y = Y | 0xFFFFFC00;
-                               ele_C = ((Y * ele_D)>>8)&0x000003FF;
-
-                               /* write new elements A, C, D to regC80 and regC94, element B is always 0 */
-                               value32 = (ele_D<<22)|((ele_C&0x3F)<<16)|ele_A;
-                               rtl8723au_write32(Adapter,
-                                                 rOFDM0_XATxIQImbalance,
-                                                 value32);
-
-                               value32 = (ele_C&0x000003C0)>>6;
-                               PHY_SetBBReg(Adapter, rOFDM0_XCTxAFE, bMaskH4Bits, value32);
-
-                               value32 = ((X * ele_D)>>7)&0x01;
-                               PHY_SetBBReg(Adapter, rOFDM0_ECCAThreshold,
-                                            BIT(31), value32);
-
-                               value32 = ((Y * ele_D)>>7)&0x01;
-                               PHY_SetBBReg(Adapter, rOFDM0_ECCAThreshold,
-                                            BIT(29), value32);
-                       } else {
-                               rtl8723au_write32(Adapter,
-                                                 rOFDM0_XATxIQImbalance,
-                                                 OFDMSwingTable23A[OFDM_index[0]]);
-                               PHY_SetBBReg(Adapter, rOFDM0_XCTxAFE,
-                                            bMaskH4Bits, 0x00);
-                               PHY_SetBBReg(Adapter, rOFDM0_ECCAThreshold,
-                                            BIT(31) | BIT(29), 0x00);
-                       }
-
-                       /* Adjust CCK according to IQK result */
-                       if (!pdmpriv->bCCKinCH14) {
-                               rtl8723au_write8(Adapter, 0xa22, CCKSwingTable_Ch1_Ch1323A[CCK_index][0]);
-                               rtl8723au_write8(Adapter, 0xa23, CCKSwingTable_Ch1_Ch1323A[CCK_index][1]);
-                               rtl8723au_write8(Adapter, 0xa24, CCKSwingTable_Ch1_Ch1323A[CCK_index][2]);
-                               rtl8723au_write8(Adapter, 0xa25, CCKSwingTable_Ch1_Ch1323A[CCK_index][3]);
-                               rtl8723au_write8(Adapter, 0xa26, CCKSwingTable_Ch1_Ch1323A[CCK_index][4]);
-                               rtl8723au_write8(Adapter, 0xa27, CCKSwingTable_Ch1_Ch1323A[CCK_index][5]);
-                               rtl8723au_write8(Adapter, 0xa28, CCKSwingTable_Ch1_Ch1323A[CCK_index][6]);
-                               rtl8723au_write8(Adapter, 0xa29, CCKSwingTable_Ch1_Ch1323A[CCK_index][7]);
-                       } else {
-                               rtl8723au_write8(Adapter, 0xa22, CCKSwingTable_Ch1423A[CCK_index][0]);
-                               rtl8723au_write8(Adapter, 0xa23, CCKSwingTable_Ch1423A[CCK_index][1]);
-                               rtl8723au_write8(Adapter, 0xa24, CCKSwingTable_Ch1423A[CCK_index][2]);
-                               rtl8723au_write8(Adapter, 0xa25, CCKSwingTable_Ch1423A[CCK_index][3]);
-                               rtl8723au_write8(Adapter, 0xa26, CCKSwingTable_Ch1423A[CCK_index][4]);
-                               rtl8723au_write8(Adapter, 0xa27, CCKSwingTable_Ch1423A[CCK_index][5]);
-                               rtl8723au_write8(Adapter, 0xa28, CCKSwingTable_Ch1423A[CCK_index][6]);
-                               rtl8723au_write8(Adapter, 0xa29, CCKSwingTable_Ch1423A[CCK_index][7]);
-                       }
-
-                       if (pHalData->rf_type == RF_2T2R) {
-                               ele_D = (OFDMSwingTable23A[(u8)OFDM_index[1]] & 0xFFC00000)>>22;
-
-                               /* new element A = element D x X */
-                               X = pdmpriv->RegEB4;
-                               Y = pdmpriv->RegEBC;
-
-                               if (X != 0) {
-                                       if ((X & 0x00000200) != 0)      /* consider minus */
-                                               X = X | 0xFFFFFC00;
-                                       ele_A = ((X * ele_D)>>8)&0x000003FF;
-
-                                       /* new element C = element D x Y */
-                                       if ((Y & 0x00000200) != 0)
-                                               Y = Y | 0xFFFFFC00;
-                                       ele_C = ((Y * ele_D)>>8)&0x00003FF;
-
-                                       /* write new elements A, C, D to regC88 and regC9C, element B is always 0 */
-                                       value32 = (ele_D<<22)|((ele_C&0x3F)<<16) | ele_A;
-                                       rtl8723au_write32(Adapter, rOFDM0_XBTxIQImbalance, value32);
-
-                                       value32 = (ele_C&0x000003C0)>>6;
-                                       PHY_SetBBReg(Adapter, rOFDM0_XDTxAFE, bMaskH4Bits, value32);
-
-                                       value32 = ((X * ele_D)>>7)&0x01;
-                                       PHY_SetBBReg(Adapter,
-                                                    rOFDM0_ECCAThreshold,
-                                                    BIT(27), value32);
-
-                                       value32 = ((Y * ele_D)>>7)&0x01;
-                                       PHY_SetBBReg(Adapter,
-                                                    rOFDM0_ECCAThreshold,
-                                                    BIT(25), value32);
-                               } else {
-                                       rtl8723au_write32(Adapter,
-                                                         rOFDM0_XBTxIQImbalance,
-                                                         OFDMSwingTable23A[OFDM_index[1]]);
-                                       PHY_SetBBReg(Adapter,
-                                                    rOFDM0_XDTxAFE,
-                                                    bMaskH4Bits, 0x00);
-                                       PHY_SetBBReg(Adapter,
-                                                    rOFDM0_ECCAThreshold,
-                                                    BIT(27) | BIT(25), 0x00);
-                               }
-                       }
-
-               }
-               if (delta_IQK > 3) {
-                       pdmpriv->ThermalValue_IQK = ThermalValue;
-                       rtl8723a_phy_iq_calibrate(Adapter, false);
-               }
-
-               /* update thermal meter value */
-               if (pdmpriv->TxPowerTrackControl)
-                       pdmpriv->ThermalValue = ThermalValue;
-       }
-       pdmpriv->TXPowercount = 0;
-}
-
-/*     Description: */
-/*             - Dispatch TxPower Tracking direct call ONLY for 92s. */
-/*             - We shall NOT schedule Workitem within PASSIVE LEVEL, which will cause system resource */
-/*                leakage under some platform. */
-/*     Assumption: */
-/*             PASSIVE_LEVEL when this routine is called. */
-static void ODM_TXPowerTracking92CDirectCall(struct rtw_adapter *Adapter)
-{
-       odm_TXPowerTrackingCallback_ThermalMeter_92C(Adapter);
-}
-
-void rtl8723a_odm_check_tx_power_tracking(struct rtw_adapter *Adapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(Adapter);
-       struct dm_priv *pdmpriv = &pHalData->dmpriv;
-
-       if (!pdmpriv->TM_Trigger) {             /* at least delay 1 sec */
-               PHY_SetRFReg(Adapter, RF_PATH_A, RF_T_METER, bRFRegOffsetMask, 0x60);
-
-               pdmpriv->TM_Trigger = 1;
-               return;
-       } else {
-               ODM_TXPowerTracking92CDirectCall(Adapter);
-               pdmpriv->TM_Trigger = 0;
-       }
-}
-
-/*     IQK */
-#define MAX_TOLERANCE          5
-#define IQK_DELAY_TIME         1       /* ms */
-
-static u8 _PHY_PathA_IQK(struct rtw_adapter *pAdapter, bool configPathB)
-{
-       u32 regEAC, regE94, regE9C, regEA4;
-       u8 result = 0x00;
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(pAdapter);
-
-       /* path-A IQK setting */
-       rtl8723au_write32(pAdapter, rTx_IQK_Tone_A, 0x10008c1f);
-       rtl8723au_write32(pAdapter, rRx_IQK_Tone_A, 0x10008c1f);
-       rtl8723au_write32(pAdapter, rTx_IQK_PI_A, 0x82140102);
-
-       rtl8723au_write32(pAdapter, rRx_IQK_PI_A, configPathB ? 0x28160202 :
-               IS_81xxC_VENDOR_UMC_B_CUT(pHalData->VersionID)?0x28160202:0x28160502);
-
-       /* path-B IQK setting */
-       if (configPathB) {
-               rtl8723au_write32(pAdapter, rTx_IQK_Tone_B, 0x10008c22);
-               rtl8723au_write32(pAdapter, rRx_IQK_Tone_B, 0x10008c22);
-               rtl8723au_write32(pAdapter, rTx_IQK_PI_B, 0x82140102);
-               rtl8723au_write32(pAdapter, rRx_IQK_PI_B, 0x28160202);
-       }
-
-       /* LO calibration setting */
-       rtl8723au_write32(pAdapter, rIQK_AGC_Rsp, 0x001028d1);
-
-       /* One shot, path A LOK & IQK */
-       rtl8723au_write32(pAdapter, rIQK_AGC_Pts, 0xf9000000);
-       rtl8723au_write32(pAdapter, rIQK_AGC_Pts, 0xf8000000);
-
-       /*  delay x ms */
-       /* PlatformStallExecution(IQK_DELAY_TIME*1000); */
-       udelay(IQK_DELAY_TIME*1000);
-
-       /*  Check failed */
-       regEAC = rtl8723au_read32(pAdapter, rRx_Power_After_IQK_A_2);
-       regE94 = rtl8723au_read32(pAdapter, rTx_Power_Before_IQK_A);
-       regE9C = rtl8723au_read32(pAdapter, rTx_Power_After_IQK_A);
-       regEA4 = rtl8723au_read32(pAdapter, rRx_Power_Before_IQK_A_2);
-
-       if (!(regEAC & BIT(28)) &&
-           (((regE94 & 0x03FF0000)>>16) != 0x142) &&
-           (((regE9C & 0x03FF0000)>>16) != 0x42))
-               result |= 0x01;
-       else                    /* if Tx not OK, ignore Rx */
-               return result;
-
-       if (!(regEAC & BIT(27)) && /* if Tx is OK, check whether Rx is OK */
-           (((regEA4 & 0x03FF0000)>>16) != 0x132) &&
-           (((regEAC & 0x03FF0000)>>16) != 0x36))
-               result |= 0x02;
-       else
-               DBG_8723A("Path A Rx IQK fail!!\n");
-       return result;
-}
-
-static u8 _PHY_PathB_IQK(struct rtw_adapter *pAdapter)
-{
-       u32 regEAC, regEB4, regEBC, regEC4, regECC;
-       u8 result = 0x00;
-
-       /* One shot, path B LOK & IQK */
-       rtl8723au_write32(pAdapter, rIQK_AGC_Cont, 0x00000002);
-       rtl8723au_write32(pAdapter, rIQK_AGC_Cont, 0x00000000);
-
-       /*  delay x ms */
-       udelay(IQK_DELAY_TIME*1000);
-
-       /*  Check failed */
-       regEAC = rtl8723au_read32(pAdapter, rRx_Power_After_IQK_A_2);
-       regEB4 = rtl8723au_read32(pAdapter, rTx_Power_Before_IQK_B);
-       regEBC = rtl8723au_read32(pAdapter, rTx_Power_After_IQK_B);
-       regEC4 = rtl8723au_read32(pAdapter, rRx_Power_Before_IQK_B_2);
-       regECC = rtl8723au_read32(pAdapter, rRx_Power_After_IQK_B_2);
-
-       if (!(regEAC & BIT(31)) &&
-           (((regEB4 & 0x03FF0000)>>16) != 0x142) &&
-           (((regEBC & 0x03FF0000)>>16) != 0x42))
-               result |= 0x01;
-       else
-               return result;
-
-       if (!(regEAC & BIT(30)) &&
-           (((regEC4 & 0x03FF0000)>>16) != 0x132) &&
-           (((regECC & 0x03FF0000)>>16) != 0x36))
-               result |= 0x02;
-       else
-               DBG_8723A("Path B Rx IQK fail!!\n");
-       return result;
-}
-
-static void _PHY_PathAFillIQKMatrix(struct rtw_adapter *pAdapter,
-       bool bIQKOK,
-       int result[][8],
-       u8 final_candidate,
-       bool bTxOnly
-       )
-{
-       u32 Oldval_0, X, TX0_A, reg;
-       s32 Y, TX0_C;
-
-       DBG_8723A("Path A IQ Calibration %s !\n", (bIQKOK)?"Success":"Failed");
-
-       if (final_candidate == 0xFF) {
-               return;
-       } else if (bIQKOK) {
-               Oldval_0 = rtl8723au_read32(pAdapter, rOFDM0_XATxIQImbalance);
-               Oldval_0 = (Oldval_0 >> 22) & 0x3FF;
-
-               X = result[final_candidate][0];
-               if ((X & 0x00000200) != 0)
-                       X = X | 0xFFFFFC00;
-               TX0_A = (X * Oldval_0) >> 8;
-               PHY_SetBBReg(pAdapter, rOFDM0_XATxIQImbalance, 0x3FF, TX0_A);
-               PHY_SetBBReg(pAdapter, rOFDM0_ECCAThreshold, BIT(31),
-                            ((X * Oldval_0>>7) & 0x1));
-
-               Y = result[final_candidate][1];
-               if ((Y & 0x00000200) != 0)
-                       Y = Y | 0xFFFFFC00;
-               TX0_C = (Y * Oldval_0) >> 8;
-               PHY_SetBBReg(pAdapter, rOFDM0_XCTxAFE, 0xF0000000,
-                            ((TX0_C&0x3C0)>>6));
-               PHY_SetBBReg(pAdapter, rOFDM0_XATxIQImbalance, 0x003F0000,
-                            (TX0_C&0x3F));
-               PHY_SetBBReg(pAdapter, rOFDM0_ECCAThreshold, BIT(29),
-                            ((Y * Oldval_0>>7) & 0x1));
-
-               if (bTxOnly) {
-                       DBG_8723A("_PHY_PathAFillIQKMatrix only Tx OK\n");
-                       return;
-               }
-
-               reg = result[final_candidate][2];
-               PHY_SetBBReg(pAdapter, rOFDM0_XARxIQImbalance, 0x3FF, reg);
-
-               reg = result[final_candidate][3] & 0x3F;
-               PHY_SetBBReg(pAdapter, rOFDM0_XARxIQImbalance, 0xFC00, reg);
-
-               reg = (result[final_candidate][3] >> 6) & 0xF;
-               PHY_SetBBReg(pAdapter, rOFDM0_RxIQExtAnta, 0xF0000000, reg);
-       }
-}
-
-static void _PHY_PathBFillIQKMatrix(struct rtw_adapter *pAdapter, bool bIQKOK, int result[][8], u8 final_candidate, bool bTxOnly)
-{
-       u32 Oldval_1, X, TX1_A, reg;
-       s32 Y, TX1_C;
-
-       DBG_8723A("Path B IQ Calibration %s !\n", (bIQKOK)?"Success":"Failed");
-
-       if (final_candidate == 0xFF) {
-               return;
-       } else if (bIQKOK) {
-               Oldval_1 = rtl8723au_read32(pAdapter, rOFDM0_XBTxIQImbalance);
-               Oldval_1 = (Oldval_1 >> 22) & 0x3FF;
-
-               X = result[final_candidate][4];
-               if ((X & 0x00000200) != 0)
-                       X = X | 0xFFFFFC00;
-               TX1_A = (X * Oldval_1) >> 8;
-               PHY_SetBBReg(pAdapter, rOFDM0_XBTxIQImbalance, 0x3FF, TX1_A);
-               PHY_SetBBReg(pAdapter, rOFDM0_ECCAThreshold, BIT(27),
-                            ((X * Oldval_1 >> 7) & 0x1));
-
-               Y = result[final_candidate][5];
-               if ((Y & 0x00000200) != 0)
-                       Y = Y | 0xFFFFFC00;
-               TX1_C = (Y * Oldval_1) >> 8;
-               PHY_SetBBReg(pAdapter, rOFDM0_XDTxAFE, 0xF0000000,
-                            ((TX1_C & 0x3C0) >> 6));
-               PHY_SetBBReg(pAdapter, rOFDM0_XBTxIQImbalance, 0x003F0000,
-                            (TX1_C & 0x3F));
-               PHY_SetBBReg(pAdapter, rOFDM0_ECCAThreshold, BIT(25),
-                            ((Y * Oldval_1 >> 7) & 0x1));
-
-               if (bTxOnly)
-                       return;
-
-               reg = result[final_candidate][6];
-               PHY_SetBBReg(pAdapter, rOFDM0_XBRxIQImbalance, 0x3FF, reg);
-
-               reg = result[final_candidate][7] & 0x3F;
-               PHY_SetBBReg(pAdapter, rOFDM0_XBRxIQImbalance, 0xFC00, reg);
-
-               reg = (result[final_candidate][7] >> 6) & 0xF;
-               PHY_SetBBReg(pAdapter, rOFDM0_AGCRSSITable, 0x0000F000, reg);
-       }
-}
-
-static void _PHY_SaveADDARegisters(struct rtw_adapter *pAdapter, u32 *ADDAReg, u32 *ADDABackup, u32 RegisterNum)
-{
-       u32 i;
-
-       for (i = 0 ; i < RegisterNum ; i++) {
-               ADDABackup[i] = rtl8723au_read32(pAdapter, ADDAReg[i]);
-       }
-}
-
-static void _PHY_SaveMACRegisters(struct rtw_adapter *pAdapter, u32 *MACReg,
-                                 u32 *MACBackup)
-{
-       u32 i;
-
-       for (i = 0 ; i < (IQK_MAC_REG_NUM - 1); i++) {
-               MACBackup[i] = rtl8723au_read8(pAdapter, MACReg[i]);
-       }
-       MACBackup[i] = rtl8723au_read32(pAdapter, MACReg[i]);
-}
-
-static void _PHY_ReloadADDARegisters(struct rtw_adapter *pAdapter,
-                                    u32 *ADDAReg, u32 *ADDABackup,
-                                    u32 RegiesterNum)
-{
-       u32 i;
-
-       for (i = 0 ; i < RegiesterNum ; i++) {
-               rtl8723au_write32(pAdapter, ADDAReg[i], ADDABackup[i]);
-       }
-}
-
-static void _PHY_ReloadMACRegisters(struct rtw_adapter *pAdapter,
-                                   u32 *MACReg, u32 *MACBackup)
-{
-       u32 i;
-
-       for (i = 0 ; i < (IQK_MAC_REG_NUM - 1); i++)
-               rtl8723au_write8(pAdapter, MACReg[i], (u8)MACBackup[i]);
-
-       rtl8723au_write32(pAdapter, MACReg[i], MACBackup[i]);
-}
-
-static void _PHY_PathADDAOn(struct rtw_adapter *pAdapter, u32 *ADDAReg,
-                           bool isPathAOn, bool is2T)
-{
-       u32 pathOn;
-       u32 i;
-
-       pathOn = isPathAOn ? 0x04db25a4 : 0x0b1b25a4;
-       if (!is2T) {
-               pathOn = 0x0bdb25a0;
-               rtl8723au_write32(pAdapter, ADDAReg[0], 0x0b1b25a0);
-       } else {
-               rtl8723au_write32(pAdapter, ADDAReg[0], pathOn);
-       }
-
-       for (i = 1 ; i < IQK_ADDA_REG_NUM ; i++)
-               rtl8723au_write32(pAdapter, ADDAReg[i], pathOn);
-}
-
-static void _PHY_MACSettingCalibration(struct rtw_adapter *pAdapter,
-                                      u32 *MACReg, u32 *MACBackup)
-{
-       u32 i = 0;
-
-       rtl8723au_write8(pAdapter, MACReg[i], 0x3F);
-
-       for (i = 1 ; i < (IQK_MAC_REG_NUM - 1); i++) {
-               rtl8723au_write8(pAdapter, MACReg[i],
-                                (u8)(MACBackup[i] & ~BIT(3)));
-       }
-       rtl8723au_write8(pAdapter, MACReg[i], (u8)(MACBackup[i] & ~BIT(5)));
-}
-
-static void _PHY_PathAStandBy(struct rtw_adapter *pAdapter)
-{
-       rtl8723au_write32(pAdapter, rFPGA0_IQK, 0x0);
-       rtl8723au_write32(pAdapter, 0x840, 0x00010000);
-       rtl8723au_write32(pAdapter, rFPGA0_IQK, 0x80800000);
-}
-
-static void _PHY_PIModeSwitch(struct rtw_adapter *pAdapter, bool PIMode)
-{
-       u32 mode;
-
-       mode = PIMode ? 0x01000100 : 0x01000000;
-       rtl8723au_write32(pAdapter, 0x820, mode);
-       rtl8723au_write32(pAdapter, 0x828, mode);
-}
-
-/*
-return false => do IQK again
-*/
-static bool _PHY_SimularityCompare(struct rtw_adapter *pAdapter, int result[][8], u8 c1, u8 c2)
-{
-       u32 i, j, diff, SimularityBitMap, bound = 0;
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(pAdapter);
-       u8 final_candidate[2] = {0xFF, 0xFF};   /* for path A and path B */
-       bool bResult = true;
-
-       if (pHalData->rf_type == RF_2T2R)
-               bound = 8;
-       else
-               bound = 4;
-
-       SimularityBitMap = 0;
-
-       for (i = 0; i < bound; i++) {
-               diff = (result[c1][i] > result[c2][i]) ? (result[c1][i] - result[c2][i]) : (result[c2][i] - result[c1][i]);
-               if (diff > MAX_TOLERANCE) {
-                       if ((i == 2 || i == 6) && !SimularityBitMap) {
-                               if (result[c1][i]+result[c1][i+1] == 0)
-                                       final_candidate[(i/4)] = c2;
-                               else if (result[c2][i]+result[c2][i+1] == 0)
-                                       final_candidate[(i/4)] = c1;
-                               else
-                                       SimularityBitMap = SimularityBitMap|(1<<i);
-                       } else {
-                               SimularityBitMap = SimularityBitMap|(1<<i);
-                       }
-               }
-       }
-
-       if (SimularityBitMap == 0) {
-               for (i = 0; i < (bound/4); i++) {
-                       if (final_candidate[i] != 0xFF) {
-                               for (j = i*4; j < (i+1)*4-2; j++)
-                                       result[3][j] = result[final_candidate[i]][j];
-                               bResult = false;
-                       }
-               }
-               return bResult;
-       } else if (!(SimularityBitMap & 0x0F)) {
-               /* path A OK */
-               for (i = 0; i < 4; i++)
-                       result[3][i] = result[c1][i];
-               return false;
-       } else if (!(SimularityBitMap & 0xF0) && pHalData->rf_type == RF_2T2R) {
-               /* path B OK */
-               for (i = 4; i < 8; i++)
-                       result[3][i] = result[c1][i];
-               return false;
-       } else {
-               return false;
-       }
-}
-
-static void _PHY_IQCalibrate(struct rtw_adapter *pAdapter, int result[][8], u8 t, bool is2T)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(pAdapter);
-       struct dm_priv *pdmpriv = &pHalData->dmpriv;
-       u32 i;
-       u8 PathAOK, PathBOK;
-       u32 ADDA_REG[IQK_ADDA_REG_NUM] = {
-               rFPGA0_XCD_SwitchControl, rBlue_Tooth,
-               rRx_Wait_CCA, rTx_CCK_RFON,
-               rTx_CCK_BBON, rTx_OFDM_RFON,
-               rTx_OFDM_BBON, rTx_To_Rx,
-               rTx_To_Tx, rRx_CCK,
-               rRx_OFDM, rRx_Wait_RIFS,
-               rRx_TO_Rx, rStandby,
-               rSleep, rPMPD_ANAEN
-       };
-
-       u32 IQK_MAC_REG[IQK_MAC_REG_NUM] = {
-               REG_TXPAUSE, REG_BCN_CTRL,
-               REG_BCN_CTRL_1, REG_GPIO_MUXCFG
-       };
-
-       u32 IQK_BB_REG_92C[IQK_BB_REG_NUM] = {
-               rOFDM0_TRxPathEnable, rOFDM0_TRMuxPar,
-               rFPGA0_XCD_RFInterfaceSW, rConfig_AntA, rConfig_AntB,
-               rFPGA0_XAB_RFInterfaceSW, rFPGA0_XA_RFInterfaceOE,
-               rFPGA0_XB_RFInterfaceOE, rFPGA0_RFMOD
-       };
-
-       const u32 retryCount = 2;
-
-       /*  Note: IQ calibration must be performed after loading  */
-       /*              PHY_REG.txt , and radio_a, radio_b.txt   */
-
-       u32 bbvalue;
-
-       if (t == 0) {
-               bbvalue = rtl8723au_read32(pAdapter, rFPGA0_RFMOD);
-
-               /*  Save ADDA parameters, turn Path A ADDA on */
-               _PHY_SaveADDARegisters(pAdapter, ADDA_REG, pdmpriv->ADDA_backup, IQK_ADDA_REG_NUM);
-               _PHY_SaveMACRegisters(pAdapter, IQK_MAC_REG, pdmpriv->IQK_MAC_backup);
-               _PHY_SaveADDARegisters(pAdapter, IQK_BB_REG_92C, pdmpriv->IQK_BB_backup, IQK_BB_REG_NUM);
-       }
-       _PHY_PathADDAOn(pAdapter, ADDA_REG, true, is2T);
-
-       if (t == 0)
-               pdmpriv->bRfPiEnable = (u8)
-                       PHY_QueryBBReg(pAdapter, rFPGA0_XA_HSSIParameter1,
-                                      BIT(8));
-
-       if (!pdmpriv->bRfPiEnable) {
-               /*  Switch BB to PI mode to do IQ Calibration. */
-               _PHY_PIModeSwitch(pAdapter, true);
-       }
-
-       PHY_SetBBReg(pAdapter, rFPGA0_RFMOD, BIT(24), 0x00);
-       rtl8723au_write32(pAdapter, rOFDM0_TRxPathEnable, 0x03a05600);
-       rtl8723au_write32(pAdapter, rOFDM0_TRMuxPar, 0x000800e4);
-       rtl8723au_write32(pAdapter, rFPGA0_XCD_RFInterfaceSW, 0x22204000);
-       PHY_SetBBReg(pAdapter, rFPGA0_XAB_RFInterfaceSW, BIT(10), 0x01);
-       PHY_SetBBReg(pAdapter, rFPGA0_XAB_RFInterfaceSW, BIT(26), 0x01);
-       PHY_SetBBReg(pAdapter, rFPGA0_XA_RFInterfaceOE, BIT(10), 0x00);
-       PHY_SetBBReg(pAdapter, rFPGA0_XB_RFInterfaceOE, BIT(10), 0x00);
-
-       if (is2T) {
-               rtl8723au_write32(pAdapter,
-                                 rFPGA0_XA_LSSIParameter, 0x00010000);
-               rtl8723au_write32(pAdapter,
-                                 rFPGA0_XB_LSSIParameter, 0x00010000);
-       }
-
-       /* MAC settings */
-       _PHY_MACSettingCalibration(pAdapter, IQK_MAC_REG, pdmpriv->IQK_MAC_backup);
-
-       /* Page B init */
-       rtl8723au_write32(pAdapter, rConfig_AntA, 0x00080000);
-
-       if (is2T)
-               rtl8723au_write32(pAdapter, rConfig_AntB, 0x00080000);
-
-       /*  IQ calibration setting */
-       rtl8723au_write32(pAdapter, rFPGA0_IQK, 0x80800000);
-       rtl8723au_write32(pAdapter, rTx_IQK, 0x01007c00);
-       rtl8723au_write32(pAdapter, rRx_IQK, 0x01004800);
-
-       for (i = 0 ; i < retryCount ; i++) {
-               PathAOK = _PHY_PathA_IQK(pAdapter, is2T);
-               if (PathAOK == 0x03) {
-                               DBG_8723A("Path A IQK Success!!\n");
-                               result[t][0] = (rtl8723au_read32(pAdapter, rTx_Power_Before_IQK_A)&0x3FF0000)>>16;
-                               result[t][1] = (rtl8723au_read32(pAdapter, rTx_Power_After_IQK_A)&0x3FF0000)>>16;
-                               result[t][2] = (rtl8723au_read32(pAdapter, rRx_Power_Before_IQK_A_2)&0x3FF0000)>>16;
-                               result[t][3] = (rtl8723au_read32(pAdapter, rRx_Power_After_IQK_A_2)&0x3FF0000)>>16;
-                       break;
-               } else if (i == (retryCount-1) && PathAOK == 0x01) {
-                       /* Tx IQK OK */
-                       DBG_8723A("Path A IQK Only  Tx Success!!\n");
-
-                       result[t][0] = (rtl8723au_read32(pAdapter, rTx_Power_Before_IQK_A)&0x3FF0000)>>16;
-                       result[t][1] = (rtl8723au_read32(pAdapter, rTx_Power_After_IQK_A)&0x3FF0000)>>16;
-               }
-       }
-
-       if (0x00 == PathAOK) {
-               DBG_8723A("Path A IQK failed!!\n");
-       }
-
-       if (is2T) {
-               _PHY_PathAStandBy(pAdapter);
-
-               /*  Turn Path B ADDA on */
-               _PHY_PathADDAOn(pAdapter, ADDA_REG, false, is2T);
-
-               for (i = 0 ; i < retryCount ; i++) {
-                       PathBOK = _PHY_PathB_IQK(pAdapter);
-                       if (PathBOK == 0x03) {
-                               DBG_8723A("Path B IQK Success!!\n");
-                               result[t][4] = (rtl8723au_read32(pAdapter, rTx_Power_Before_IQK_B)&0x3FF0000)>>16;
-                               result[t][5] = (rtl8723au_read32(pAdapter, rTx_Power_After_IQK_B)&0x3FF0000)>>16;
-                               result[t][6] = (rtl8723au_read32(pAdapter, rRx_Power_Before_IQK_B_2)&0x3FF0000)>>16;
-                               result[t][7] = (rtl8723au_read32(pAdapter, rRx_Power_After_IQK_B_2)&0x3FF0000)>>16;
-                               break;
-                       } else if (i == (retryCount - 1) && PathBOK == 0x01) {
-                               /* Tx IQK OK */
-                               DBG_8723A("Path B Only Tx IQK Success!!\n");
-                               result[t][4] = (rtl8723au_read32(pAdapter, rTx_Power_Before_IQK_B)&0x3FF0000)>>16;
-                               result[t][5] = (rtl8723au_read32(pAdapter, rTx_Power_After_IQK_B)&0x3FF0000)>>16;
-                       }
-               }
-
-               if (0x00 == PathBOK) {
-                       DBG_8723A("Path B IQK failed!!\n");
-               }
-       }
-
-       /* Back to BB mode, load original value */
-       rtl8723au_write32(pAdapter, rFPGA0_IQK, 0);
-
-       if (t != 0) {
-               if (!pdmpriv->bRfPiEnable) {
-                       /*  Switch back BB to SI mode after finish IQ Calibration. */
-                       _PHY_PIModeSwitch(pAdapter, false);
-               }
-
-               /*  Reload ADDA power saving parameters */
-               _PHY_ReloadADDARegisters(pAdapter, ADDA_REG, pdmpriv->ADDA_backup, IQK_ADDA_REG_NUM);
-
-               /*  Reload MAC parameters */
-               _PHY_ReloadMACRegisters(pAdapter, IQK_MAC_REG, pdmpriv->IQK_MAC_backup);
-
-               /*  Reload BB parameters */
-               _PHY_ReloadADDARegisters(pAdapter, IQK_BB_REG_92C, pdmpriv->IQK_BB_backup, IQK_BB_REG_NUM);
-
-               /*  Restore RX initial gain */
-               rtl8723au_write32(pAdapter,
-                                 rFPGA0_XA_LSSIParameter, 0x00032ed3);
-               if (is2T) {
-                       rtl8723au_write32(pAdapter,
-                                         rFPGA0_XB_LSSIParameter, 0x00032ed3);
-               }
-
-               /* load 0xe30 IQC default value */
-               rtl8723au_write32(pAdapter, rTx_IQK_Tone_A, 0x01008c00);
-               rtl8723au_write32(pAdapter, rRx_IQK_Tone_A, 0x01008c00);
-
-       }
-}
-
-static void _PHY_LCCalibrate(struct rtw_adapter *pAdapter, bool is2T)
-{
-       u8 tmpReg;
-       u32 RF_Amode = 0, RF_Bmode = 0, LC_Cal;
-
-       /* Check continuous TX and Packet TX */
-       tmpReg = rtl8723au_read8(pAdapter, 0xd03);
-
-       if ((tmpReg&0x70) != 0) {
-               /* Deal with contisuous TX case */
-               /* disable all continuous TX */
-               rtl8723au_write8(pAdapter, 0xd03, tmpReg&0x8F);
-       } else {
-               /*  Deal with Packet TX case */
-               /*  block all queues */
-               rtl8723au_write8(pAdapter, REG_TXPAUSE, 0xFF);
-       }
-
-       if ((tmpReg&0x70) != 0) {
-               /* 1. Read original RF mode */
-               /* Path-A */
-               RF_Amode = PHY_QueryRFReg(pAdapter, RF_PATH_A, RF_AC, bMask12Bits);
-
-               /* Path-B */
-               if (is2T)
-                       RF_Bmode = PHY_QueryRFReg(pAdapter, RF_PATH_B, RF_AC, bMask12Bits);
-
-               /* 2. Set RF mode = standby mode */
-               /* Path-A */
-               PHY_SetRFReg(pAdapter, RF_PATH_A, RF_AC, bMask12Bits, (RF_Amode&0x8FFFF)|0x10000);
-
-               /* Path-B */
-               if (is2T)
-                       PHY_SetRFReg(pAdapter, RF_PATH_B, RF_AC, bMask12Bits, (RF_Bmode&0x8FFFF)|0x10000);
-       }
-
-       /* 3. Read RF reg18 */
-       LC_Cal = PHY_QueryRFReg(pAdapter, RF_PATH_A, RF_CHNLBW, bMask12Bits);
-
-       /* 4. Set LC calibration begin */
-       PHY_SetRFReg(pAdapter, RF_PATH_A, RF_CHNLBW, bMask12Bits, LC_Cal|0x08000);
-
-       msleep(100);
-
-       /* Restore original situation */
-       if ((tmpReg&0x70) != 0) {       /* Deal with contuous TX case  */
-               /* Path-A */
-               rtl8723au_write8(pAdapter, 0xd03, tmpReg);
-               PHY_SetRFReg(pAdapter, RF_PATH_A, RF_AC, bMask12Bits, RF_Amode);
-
-               /* Path-B */
-               if (is2T)
-                       PHY_SetRFReg(pAdapter, RF_PATH_B, RF_AC, bMask12Bits, RF_Bmode);
-       } else /*  Deal with Packet TX case */
-               rtl8723au_write8(pAdapter, REG_TXPAUSE, 0x00);
-}
-
-/* Analog Pre-distortion calibration */
-#define                APK_BB_REG_NUM  8
-#define                APK_CURVE_REG_NUM 4
-#define                PATH_NUM                2
-
-void rtl8723a_phy_iq_calibrate(struct rtw_adapter *pAdapter, bool bReCovery)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(pAdapter);
-       struct dm_priv *pdmpriv = &pHalData->dmpriv;
-       s32 result[4][8];       /* last is final result */
-       u8 i, final_candidate;
-       bool bPathAOK, bPathBOK;
-       s32 RegE94, RegE9C, RegEA4, RegEAC, RegEB4, RegEBC, RegEC4;
-       s32 RegECC, RegTmp = 0;
-       bool is12simular, is13simular, is23simular;
-       bool bStartContTx = false, bSingleTone = false;
-       bool bCarrierSuppression = false;
-       u32 IQK_BB_REG_92C[IQK_BB_REG_NUM] = {
-               rOFDM0_XARxIQImbalance, rOFDM0_XBRxIQImbalance,
-               rOFDM0_ECCAThreshold, rOFDM0_AGCRSSITable,
-               rOFDM0_XATxIQImbalance, rOFDM0_XBTxIQImbalance,
-               rOFDM0_XCTxAFE, rOFDM0_XDTxAFE,
-               rOFDM0_RxIQExtAnta
-       };
-
-       /* ignore IQK when continuous Tx */
-       if (bStartContTx || bSingleTone || bCarrierSuppression)
-               return;
-
-       if (bReCovery) {
-               _PHY_ReloadADDARegisters(pAdapter, IQK_BB_REG_92C, pdmpriv->IQK_BB_backup_recover, 9);
-               return;
-       }
-       DBG_8723A("IQK:Start!!!\n");
-
-       for (i = 0; i < 8; i++) {
-               result[0][i] = 0;
-               result[1][i] = 0;
-               result[2][i] = 0;
-               result[3][i] = 0;
-       }
-       final_candidate = 0xff;
-       bPathAOK = false;
-       bPathBOK = false;
-       is12simular = false;
-       is23simular = false;
-       is13simular = false;
-
-       for (i = 0; i < 3; i++) {
-               if (pHalData->rf_type == RF_2T2R)
-                       _PHY_IQCalibrate(pAdapter, result, i, true);
-               else /*  For 88C 1T1R */
-                       _PHY_IQCalibrate(pAdapter, result, i, false);
-
-               if (i == 1) {
-                       is12simular = _PHY_SimularityCompare(pAdapter, result, 0, 1);
-                       if (is12simular) {
-                               final_candidate = 0;
-                               break;
-                       }
-               }
-
-               if (i == 2) {
-                       is13simular = _PHY_SimularityCompare(pAdapter, result, 0, 2);
-                       if (is13simular) {
-                               final_candidate = 0;
-                               break;
-                       }
-
-                       is23simular = _PHY_SimularityCompare(pAdapter, result, 1, 2);
-                       if (is23simular) {
-                               final_candidate = 1;
-                       } else {
-                               for (i = 0; i < 8; i++)
-                                       RegTmp += result[3][i];
-
-                               if (RegTmp != 0)
-                                       final_candidate = 3;
-                               else
-                                       final_candidate = 0xFF;
-                       }
-               }
-       }
-
-       for (i = 0; i < 4; i++) {
-               RegE94 = result[i][0];
-               RegE9C = result[i][1];
-               RegEA4 = result[i][2];
-               RegEAC = result[i][3];
-               RegEB4 = result[i][4];
-               RegEBC = result[i][5];
-               RegEC4 = result[i][6];
-               RegECC = result[i][7];
-       }
-
-       if (final_candidate != 0xff) {
-               RegE94 = result[final_candidate][0];
-               pdmpriv->RegE94 =  RegE94;
-               RegE9C = result[final_candidate][1];
-               pdmpriv->RegE9C = RegE9C;
-               RegEA4 = result[final_candidate][2];
-               RegEAC = result[final_candidate][3];
-               RegEB4 = result[final_candidate][4];
-               pdmpriv->RegEB4 = RegEB4;
-               RegEBC = result[final_candidate][5];
-               pdmpriv->RegEBC = RegEBC;
-               RegEC4 = result[final_candidate][6];
-               RegECC = result[final_candidate][7];
-               DBG_8723A("IQK: final_candidate is %x\n", final_candidate);
-               DBG_8723A("IQK: RegE94 =%x RegE9C =%x RegEA4 =%x RegEAC =%x RegEB4 =%x RegEBC =%x RegEC4 =%x RegECC =%x\n ",
-                         RegE94, RegE9C, RegEA4, RegEAC, RegEB4, RegEBC, RegEC4, RegECC);
-               bPathAOK = bPathBOK = true;
-       } else {
-               RegE94 = RegEB4 = pdmpriv->RegE94 = pdmpriv->RegEB4 = 0x100;    /* X default value */
-               RegE9C = RegEBC = pdmpriv->RegE9C = pdmpriv->RegEBC = 0x0;              /* Y default value */
-       }
-
-       if ((RegE94 != 0)/*&&(RegEA4 != 0)*/)
-               _PHY_PathAFillIQKMatrix(pAdapter, bPathAOK, result, final_candidate, (RegEA4 == 0));
-
-       if (pHalData->rf_type == RF_2T2R) {
-               if ((RegEB4 != 0)/*&&(RegEC4 != 0)*/)
-                       _PHY_PathBFillIQKMatrix(pAdapter, bPathBOK, result,
-                                               final_candidate, (RegEC4 == 0));
-       }
-
-       _PHY_SaveADDARegisters(pAdapter, IQK_BB_REG_92C, pdmpriv->IQK_BB_backup_recover, 9);
-}
-
-void rtl8723a_phy_lc_calibrate(struct rtw_adapter *pAdapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(pAdapter);
-       struct mlme_ext_priv *pmlmeext = &pAdapter->mlmeextpriv;
-       bool bStartContTx = false, bSingleTone = false, bCarrierSuppression = false;
-
-       /* ignore IQK when continuous Tx */
-       if (bStartContTx || bSingleTone || bCarrierSuppression)
-               return;
-
-       if (pmlmeext->sitesurvey_res.state == SCAN_PROCESS)
-               return;
-
-       if (pHalData->rf_type == RF_2T2R)
-               _PHY_LCCalibrate(pAdapter, true);
-       else    /*  For 88C 1T1R */
-               _PHY_LCCalibrate(pAdapter, false);
-}
-
-void
-rtl8723a_phy_ap_calibrate(struct rtw_adapter *pAdapter, char delta)
-{
-}
diff --git a/drivers/staging/rtl8723au/hal/HalHWImg8723A_BB.c b/drivers/staging/rtl8723au/hal/HalHWImg8723A_BB.c
deleted file mode 100644 (file)
index 8d3ea6c..0000000
+++ /dev/null
@@ -1,565 +0,0 @@
-/******************************************************************************
-*
-* Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
-*
-* This program is free software; you can redistribute it and/or modify it
-* under the terms of version 2 of the GNU General Public License as
-* published by the Free Software Foundation.
-*
-* This program is distributed in the hope that it will be useful, but WITHOUT
-* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
-* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
-* more details.
-*
-******************************************************************************/
-
-#include "odm_precomp.h"
-
-static bool CheckCondition(const u32  Condition, const u32  Hex)
-{
-       u32 _board     = (Hex & 0x000000FF);
-       u32 _interface = (Hex & 0x0000FF00) >> 8;
-       u32 _platform  = (Hex & 0x00FF0000) >> 16;
-       u32 cond = Condition;
-
-       if (Condition == 0xCDCDCDCD)
-               return true;
-
-       cond = Condition & 0x000000FF;
-       if ((_board == cond) && cond != 0x00)
-               return false;
-
-       cond = Condition & 0x0000FF00;
-       cond >>= 8;
-       if ((_interface & cond) == 0 && cond != 0x07)
-               return false;
-
-       cond = Condition & 0x00FF0000;
-       cond >>= 16;
-       if ((_platform & cond) == 0 && cond != 0x0F)
-               return false;
-       return true;
-}
-
-/******************************************************************************
-*                           AGC_TAB_1T.TXT
-******************************************************************************/
-
-static u32 Array_AGC_TAB_1T_8723A[] = {
-       0xC78, 0x7B000001,
-       0xC78, 0x7B010001,
-       0xC78, 0x7B020001,
-       0xC78, 0x7B030001,
-       0xC78, 0x7B040001,
-       0xC78, 0x7B050001,
-       0xC78, 0x7A060001,
-       0xC78, 0x79070001,
-       0xC78, 0x78080001,
-       0xC78, 0x77090001,
-       0xC78, 0x760A0001,
-       0xC78, 0x750B0001,
-       0xC78, 0x740C0001,
-       0xC78, 0x730D0001,
-       0xC78, 0x720E0001,
-       0xC78, 0x710F0001,
-       0xC78, 0x70100001,
-       0xC78, 0x6F110001,
-       0xC78, 0x6E120001,
-       0xC78, 0x6D130001,
-       0xC78, 0x6C140001,
-       0xC78, 0x6B150001,
-       0xC78, 0x6A160001,
-       0xC78, 0x69170001,
-       0xC78, 0x68180001,
-       0xC78, 0x67190001,
-       0xC78, 0x661A0001,
-       0xC78, 0x651B0001,
-       0xC78, 0x641C0001,
-       0xC78, 0x631D0001,
-       0xC78, 0x621E0001,
-       0xC78, 0x611F0001,
-       0xC78, 0x60200001,
-       0xC78, 0x49210001,
-       0xC78, 0x48220001,
-       0xC78, 0x47230001,
-       0xC78, 0x46240001,
-       0xC78, 0x45250001,
-       0xC78, 0x44260001,
-       0xC78, 0x43270001,
-       0xC78, 0x42280001,
-       0xC78, 0x41290001,
-       0xC78, 0x402A0001,
-       0xC78, 0x262B0001,
-       0xC78, 0x252C0001,
-       0xC78, 0x242D0001,
-       0xC78, 0x232E0001,
-       0xC78, 0x222F0001,
-       0xC78, 0x21300001,
-       0xC78, 0x20310001,
-       0xC78, 0x06320001,
-       0xC78, 0x05330001,
-       0xC78, 0x04340001,
-       0xC78, 0x03350001,
-       0xC78, 0x02360001,
-       0xC78, 0x01370001,
-       0xC78, 0x00380001,
-       0xC78, 0x00390001,
-       0xC78, 0x003A0001,
-       0xC78, 0x003B0001,
-       0xC78, 0x003C0001,
-       0xC78, 0x003D0001,
-       0xC78, 0x003E0001,
-       0xC78, 0x003F0001,
-       0xC78, 0x7B400001,
-       0xC78, 0x7B410001,
-       0xC78, 0x7B420001,
-       0xC78, 0x7B430001,
-       0xC78, 0x7B440001,
-       0xC78, 0x7B450001,
-       0xC78, 0x7A460001,
-       0xC78, 0x79470001,
-       0xC78, 0x78480001,
-       0xC78, 0x77490001,
-       0xC78, 0x764A0001,
-       0xC78, 0x754B0001,
-       0xC78, 0x744C0001,
-       0xC78, 0x734D0001,
-       0xC78, 0x724E0001,
-       0xC78, 0x714F0001,
-       0xC78, 0x70500001,
-       0xC78, 0x6F510001,
-       0xC78, 0x6E520001,
-       0xC78, 0x6D530001,
-       0xC78, 0x6C540001,
-       0xC78, 0x6B550001,
-       0xC78, 0x6A560001,
-       0xC78, 0x69570001,
-       0xC78, 0x68580001,
-       0xC78, 0x67590001,
-       0xC78, 0x665A0001,
-       0xC78, 0x655B0001,
-       0xC78, 0x645C0001,
-       0xC78, 0x635D0001,
-       0xC78, 0x625E0001,
-       0xC78, 0x615F0001,
-       0xC78, 0x60600001,
-       0xC78, 0x49610001,
-       0xC78, 0x48620001,
-       0xC78, 0x47630001,
-       0xC78, 0x46640001,
-       0xC78, 0x45650001,
-       0xC78, 0x44660001,
-       0xC78, 0x43670001,
-       0xC78, 0x42680001,
-       0xC78, 0x41690001,
-       0xC78, 0x406A0001,
-       0xC78, 0x266B0001,
-       0xC78, 0x256C0001,
-       0xC78, 0x246D0001,
-       0xC78, 0x236E0001,
-       0xC78, 0x226F0001,
-       0xC78, 0x21700001,
-       0xC78, 0x20710001,
-       0xC78, 0x06720001,
-       0xC78, 0x05730001,
-       0xC78, 0x04740001,
-       0xC78, 0x03750001,
-       0xC78, 0x02760001,
-       0xC78, 0x01770001,
-       0xC78, 0x00780001,
-       0xC78, 0x00790001,
-       0xC78, 0x007A0001,
-       0xC78, 0x007B0001,
-       0xC78, 0x007C0001,
-       0xC78, 0x007D0001,
-       0xC78, 0x007E0001,
-       0xC78, 0x007F0001,
-       0xC78, 0x3800001E,
-       0xC78, 0x3801001E,
-       0xC78, 0x3802001E,
-       0xC78, 0x3803001E,
-       0xC78, 0x3804001E,
-       0xC78, 0x3805001E,
-       0xC78, 0x3806001E,
-       0xC78, 0x3807001E,
-       0xC78, 0x3808001E,
-       0xC78, 0x3C09001E,
-       0xC78, 0x3E0A001E,
-       0xC78, 0x400B001E,
-       0xC78, 0x440C001E,
-       0xC78, 0x480D001E,
-       0xC78, 0x4C0E001E,
-       0xC78, 0x500F001E,
-       0xC78, 0x5210001E,
-       0xC78, 0x5611001E,
-       0xC78, 0x5A12001E,
-       0xC78, 0x5E13001E,
-       0xC78, 0x6014001E,
-       0xC78, 0x6015001E,
-       0xC78, 0x6016001E,
-       0xC78, 0x6217001E,
-       0xC78, 0x6218001E,
-       0xC78, 0x6219001E,
-       0xC78, 0x621A001E,
-       0xC78, 0x621B001E,
-       0xC78, 0x621C001E,
-       0xC78, 0x621D001E,
-       0xC78, 0x621E001E,
-       0xC78, 0x621F001E,
-};
-
-#define READ_NEXT_PAIR(v1, v2, i)                      \
-       do {                                            \
-               i += 2; v1 = Array[i]; v2 = Array[i+1]; \
-       } while (0)
-
-void ODM_ReadAndConfig_AGC_TAB_1T_8723A(struct dm_odm_t *pDM_Odm)
-{
-       u32 hex;
-       u32 i;
-       u8 platform = 0x04;
-       u8 board = pDM_Odm->BoardType;
-       u32 ArrayLen = ARRAY_SIZE(Array_AGC_TAB_1T_8723A);
-       u32 *Array = Array_AGC_TAB_1T_8723A;
-
-       hex = board;
-       hex += ODM_ITRF_USB << 8;
-       hex += platform << 16;
-       hex += 0xFF000000;
-       for (i = 0; i < ArrayLen; i += 2) {
-               u32 v1 = Array[i];
-               u32 v2 = Array[i+1];
-
-               /*  This (offset, data) pair meets the condition. */
-               if (v1 < 0xCDCDCDCD) {
-                       odm_ConfigBB_AGC_8723A(pDM_Odm, v1, v2);
-                       continue;
-               } else {
-                       if (!CheckCondition(Array[i], hex)) {
-                               /* Discard the following (offset, data) pairs */
-                               READ_NEXT_PAIR(v1, v2, i);
-                               while (v2 != 0xDEAD &&
-                                      v2 != 0xCDEF &&
-                                      v2 != 0xCDCD && i < ArrayLen - 2)
-                                       READ_NEXT_PAIR(v1, v2, i);
-                               i -= 2; /*  prevent from for-loop += 2 */
-                       } else {
-                               /*  Configure matched pairs and skip to
-                                   end of if-else. */
-                               READ_NEXT_PAIR(v1, v2, i);
-                               while (v2 != 0xDEAD &&
-                                      v2 != 0xCDEF &&
-                                      v2 != 0xCDCD && i < ArrayLen - 2) {
-                                       odm_ConfigBB_AGC_8723A(pDM_Odm, v1, v2);
-                                       READ_NEXT_PAIR(v1, v2, i);
-                               }
-                               while (v2 != 0xDEAD && i < ArrayLen - 2)
-                                       READ_NEXT_PAIR(v1, v2, i);
-                       }
-               }
-       }
-}
-
-/******************************************************************************
-*                           PHY_REG_1T.TXT
-******************************************************************************/
-
-static u32 Array_PHY_REG_1T_8723A[] = {
-       0x800, 0x80040000,
-       0x804, 0x00000003,
-       0x808, 0x0000FC00,
-       0x80C, 0x0000000A,
-       0x810, 0x10001331,
-       0x814, 0x020C3D10,
-       0x818, 0x02200385,
-       0x81C, 0x00000000,
-       0x820, 0x01000100,
-       0x824, 0x00390004,
-       0x828, 0x00000000,
-       0x82C, 0x00000000,
-       0x830, 0x00000000,
-       0x834, 0x00000000,
-       0x838, 0x00000000,
-       0x83C, 0x00000000,
-       0x840, 0x00010000,
-       0x844, 0x00000000,
-       0x848, 0x00000000,
-       0x84C, 0x00000000,
-       0x850, 0x00000000,
-       0x854, 0x00000000,
-       0x858, 0x569A569A,
-       0x85C, 0x001B25A4,
-       0x860, 0x66F60110,
-       0x864, 0x061F0130,
-       0x868, 0x00000000,
-       0x86C, 0x32323200,
-       0x870, 0x07000760,
-       0x874, 0x22004000,
-       0x878, 0x00000808,
-       0x87C, 0x00000000,
-       0x880, 0xC0083070,
-       0x884, 0x000004D5,
-       0x888, 0x00000000,
-       0x88C, 0xCCC000C0,
-       0x890, 0x00000800,
-       0x894, 0xFFFFFFFE,
-       0x898, 0x40302010,
-       0x89C, 0x00706050,
-       0x900, 0x00000000,
-       0x904, 0x00000023,
-       0x908, 0x00000000,
-       0x90C, 0x81121111,
-       0xA00, 0x00D047C8,
-       0xA04, 0x80FF000C,
-       0xA08, 0x8C838300,
-       0xA0C, 0x2E68120F,
-       0xA10, 0x9500BB78,
-       0xA14, 0x11144028,
-       0xA18, 0x00881117,
-       0xA1C, 0x89140F00,
-       0xA20, 0x1A1B0000,
-       0xA24, 0x090E1317,
-       0xA28, 0x00000204,
-       0xA2C, 0x00D30000,
-       0xA70, 0x101FBF00,
-       0xA74, 0x00000007,
-       0xA78, 0x00000900,
-       0xC00, 0x48071D40,
-       0xC04, 0x03A05611,
-       0xC08, 0x000000E4,
-       0xC0C, 0x6C6C6C6C,
-       0xC10, 0x08800000,
-       0xC14, 0x40000100,
-       0xC18, 0x08800000,
-       0xC1C, 0x40000100,
-       0xC20, 0x00000000,
-       0xC24, 0x00000000,
-       0xC28, 0x00000000,
-       0xC2C, 0x00000000,
-       0xC30, 0x69E9AC44,
-       0xFF0F011F, 0xABCD,
-       0xC34, 0x469652CF,
-       0xCDCDCDCD, 0xCDCD,
-       0xC34, 0x469652AF,
-       0xFF0F011F, 0xDEAD,
-       0xC38, 0x49795994,
-       0xC3C, 0x0A97971C,
-       0xC40, 0x1F7C403F,
-       0xC44, 0x000100B7,
-       0xC48, 0xEC020107,
-       0xC4C, 0x007F037F,
-       0xC50, 0x69543420,
-       0xC54, 0x43BC0094,
-       0xC58, 0x69543420,
-       0xC5C, 0x433C0094,
-       0xC60, 0x00000000,
-       0xFF0F011F, 0xABCD,
-       0xC64, 0x7116848B,
-       0xCDCDCDCD, 0xCDCD,
-       0xC64, 0x7112848B,
-       0xFF0F011F, 0xDEAD,
-       0xC68, 0x47C00BFF,
-       0xC6C, 0x00000036,
-       0xC70, 0x2C7F000D,
-       0xC74, 0x018610DB,
-       0xC78, 0x0000001F,
-       0xC7C, 0x00B91612,
-       0xC80, 0x40000100,
-       0xC84, 0x20F60000,
-       0xC88, 0x40000100,
-       0xC8C, 0x20200000,
-       0xC90, 0x00121820,
-       0xC94, 0x00000000,
-       0xC98, 0x00121820,
-       0xC9C, 0x00007F7F,
-       0xCA0, 0x00000000,
-       0xCA4, 0x00000080,
-       0xCA8, 0x00000000,
-       0xCAC, 0x00000000,
-       0xCB0, 0x00000000,
-       0xCB4, 0x00000000,
-       0xCB8, 0x00000000,
-       0xCBC, 0x28000000,
-       0xCC0, 0x00000000,
-       0xCC4, 0x00000000,
-       0xCC8, 0x00000000,
-       0xCCC, 0x00000000,
-       0xCD0, 0x00000000,
-       0xCD4, 0x00000000,
-       0xCD8, 0x64B22427,
-       0xCDC, 0x00766932,
-       0xCE0, 0x00222222,
-       0xCE4, 0x00000000,
-       0xCE8, 0x37644302,
-       0xCEC, 0x2F97D40C,
-       0xD00, 0x00080740,
-       0xD04, 0x00020401,
-       0xD08, 0x0000907F,
-       0xD0C, 0x20010201,
-       0xD10, 0xA0633333,
-       0xD14, 0x3333BC43,
-       0xD18, 0x7A8F5B6B,
-       0xD2C, 0xCC979975,
-       0xD30, 0x00000000,
-       0xD34, 0x80608000,
-       0xD38, 0x00000000,
-       0xD3C, 0x00027293,
-       0xD40, 0x00000000,
-       0xD44, 0x00000000,
-       0xD48, 0x00000000,
-       0xD4C, 0x00000000,
-       0xD50, 0x6437140A,
-       0xD54, 0x00000000,
-       0xD58, 0x00000000,
-       0xD5C, 0x30032064,
-       0xD60, 0x4653DE68,
-       0xD64, 0x04518A3C,
-       0xD68, 0x00002101,
-       0xD6C, 0x2A201C16,
-       0xD70, 0x1812362E,
-       0xD74, 0x322C2220,
-       0xD78, 0x000E3C24,
-       0xE00, 0x2A2A2A2A,
-       0xE04, 0x2A2A2A2A,
-       0xE08, 0x03902A2A,
-       0xE10, 0x2A2A2A2A,
-       0xE14, 0x2A2A2A2A,
-       0xE18, 0x2A2A2A2A,
-       0xE1C, 0x2A2A2A2A,
-       0xE28, 0x00000000,
-       0xE30, 0x1000DC1F,
-       0xE34, 0x10008C1F,
-       0xE38, 0x02140102,
-       0xE3C, 0x681604C2,
-       0xE40, 0x01007C00,
-       0xE44, 0x01004800,
-       0xE48, 0xFB000000,
-       0xE4C, 0x000028D1,
-       0xE50, 0x1000DC1F,
-       0xE54, 0x10008C1F,
-       0xE58, 0x02140102,
-       0xE5C, 0x28160D05,
-       0xE60, 0x00000008,
-       0xE68, 0x001B25A4,
-       0xE6C, 0x631B25A0,
-       0xE70, 0x631B25A0,
-       0xE74, 0x081B25A0,
-       0xE78, 0x081B25A0,
-       0xE7C, 0x081B25A0,
-       0xE80, 0x081B25A0,
-       0xE84, 0x631B25A0,
-       0xE88, 0x081B25A0,
-       0xE8C, 0x631B25A0,
-       0xED0, 0x631B25A0,
-       0xED4, 0x631B25A0,
-       0xED8, 0x631B25A0,
-       0xEDC, 0x001B25A0,
-       0xEE0, 0x001B25A0,
-       0xEEC, 0x6B1B25A0,
-       0xF14, 0x00000003,
-       0xF4C, 0x00000000,
-       0xF00, 0x00000300,
-};
-
-void ODM_ReadAndConfig_PHY_REG_1T_8723A(struct dm_odm_t *pDM_Odm)
-{
-       u32 hex = 0;
-       u32 i = 0;
-       u8  platform = 0x04;
-       u8  board = pDM_Odm->BoardType;
-       u32 ArrayLen = ARRAY_SIZE(Array_PHY_REG_1T_8723A);
-       u32 *Array = Array_PHY_REG_1T_8723A;
-
-       hex += board;
-       hex += ODM_ITRF_USB << 8;
-       hex += platform << 16;
-       hex += 0xFF000000;
-       for (i = 0; i < ArrayLen; i += 2) {
-               u32 v1 = Array[i];
-               u32 v2 = Array[i+1];
-
-               /*  This (offset, data) pair meets the condition. */
-               if (v1 < 0xCDCDCDCD) {
-                       odm_ConfigBB_PHY_8723A(pDM_Odm, v1, v2);
-                       continue;
-               } else {
-                       if (!CheckCondition(Array[i], hex)) {
-                               /* Discard the following (offset, data) pairs */
-                               READ_NEXT_PAIR(v1, v2, i);
-                               while (v2 != 0xDEAD &&
-                                      v2 != 0xCDEF &&
-                                      v2 != 0xCDCD && i < ArrayLen - 2)
-                                       READ_NEXT_PAIR(v1, v2, i);
-                               i -= 2; /*  prevent from for-loop += 2 */
-                       } else {
-                               /*  Configure matched pairs and skip to
-                                   end of if-else. */
-                               READ_NEXT_PAIR(v1, v2, i);
-                               while (v2 != 0xDEAD &&
-                                      v2 != 0xCDEF &&
-                                      v2 != 0xCDCD && i < ArrayLen - 2) {
-                                       odm_ConfigBB_PHY_8723A(pDM_Odm, v1, v2);
-                                       READ_NEXT_PAIR(v1, v2, i);
-                               }
-                               while (v2 != 0xDEAD && i < ArrayLen - 2)
-                                       READ_NEXT_PAIR(v1, v2, i);
-                       }
-               }
-       }
-}
-
-/******************************************************************************
-*                           PHY_REG_MP.TXT
-******************************************************************************/
-
-static u32 Array_PHY_REG_MP_8723A[] = {
-       0xC30, 0x69E9AC4A,
-       0xC3C, 0x0A979718,
-};
-
-void ODM_ReadAndConfig_PHY_REG_MP_8723A(struct dm_odm_t *pDM_Odm)
-{
-       u32 hex = 0;
-       u32 i;
-       u8 platform = 0x04;
-       u8 board = pDM_Odm->BoardType;
-       u32 ArrayLen = ARRAY_SIZE(Array_PHY_REG_MP_8723A);
-       u32 *Array = Array_PHY_REG_MP_8723A;
-
-       hex += board;
-       hex += ODM_ITRF_USB << 8;
-       hex += platform << 16;
-       hex += 0xFF000000;
-       for (i = 0; i < ArrayLen; i += 2) {
-               u32 v1 = Array[i];
-               u32 v2 = Array[i+1];
-
-               /*  This (offset, data) pair meets the condition. */
-               if (v1 < 0xCDCDCDCD) {
-                       odm_ConfigBB_PHY_8723A(pDM_Odm, v1, v2);
-                       continue;
-               } else {
-                       if (!CheckCondition(Array[i], hex)) {
-                               /* Discard the following (offset, data) pairs */
-                               READ_NEXT_PAIR(v1, v2, i);
-                               while (v2 != 0xDEAD &&
-                                      v2 != 0xCDEF &&
-                                      v2 != 0xCDCD && i < ArrayLen - 2)
-                                       READ_NEXT_PAIR(v1, v2, i);
-                               i -= 2; /*  prevent from for-loop += 2 */
-                       } else {
-                               /* Configure matched pairs and skip to
-                                  end of if-else. */
-                               READ_NEXT_PAIR(v1, v2, i);
-                               while (v2 != 0xDEAD &&
-                                      v2 != 0xCDEF &&
-                                      v2 != 0xCDCD && i < ArrayLen - 2) {
-                                       odm_ConfigBB_PHY_8723A(pDM_Odm, v1, v2);
-                                       READ_NEXT_PAIR(v1, v2, i);
-                               }
-                               while (v2 != 0xDEAD && i < ArrayLen - 2)
-                                       READ_NEXT_PAIR(v1, v2, i);
-                       }
-               }
-       }
-}
diff --git a/drivers/staging/rtl8723au/hal/HalHWImg8723A_MAC.c b/drivers/staging/rtl8723au/hal/HalHWImg8723A_MAC.c
deleted file mode 100644 (file)
index 9bf6859..0000000
+++ /dev/null
@@ -1,187 +0,0 @@
-/******************************************************************************
-*
-* Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
-*
-* This program is free software; you can redistribute it and/or modify it
-* under the terms of version 2 of the GNU General Public License as
-* published by the Free Software Foundation.
-*
-* This program is distributed in the hope that it will be useful, but WITHOUT
-* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
-* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
-* more details.
-*
-******************************************************************************/
-
-#include "odm_precomp.h"
-
-static bool CheckCondition(const u32  Condition, const u32  Hex)
-{
-       u32 _board     = (Hex & 0x000000FF);
-       u32 _interface = (Hex & 0x0000FF00) >> 8;
-       u32 _platform  = (Hex & 0x00FF0000) >> 16;
-       u32 cond = Condition;
-
-       if (Condition == 0xCDCDCDCD)
-               return true;
-
-       cond = Condition & 0x000000FF;
-       if ((_board == cond) && cond != 0x00)
-               return false;
-
-       cond = Condition & 0x0000FF00;
-       cond >>= 8;
-       if ((_interface & cond) == 0 && cond != 0x07)
-               return false;
-
-       cond = Condition & 0x00FF0000;
-       cond >>= 16;
-       if ((_platform & cond) == 0 && cond != 0x0F)
-               return false;
-       return true;
-}
-
-/******************************************************************************
-*                           MAC_REG.TXT
-******************************************************************************/
-
-static u32 Array_MAC_REG_8723A[] = {
-               0x420, 0x00000080,
-               0x423, 0x00000000,
-               0x430, 0x00000000,
-               0x431, 0x00000000,
-               0x432, 0x00000000,
-               0x433, 0x00000001,
-               0x434, 0x00000004,
-               0x435, 0x00000005,
-               0x436, 0x00000006,
-               0x437, 0x00000007,
-               0x438, 0x00000000,
-               0x439, 0x00000000,
-               0x43A, 0x00000000,
-               0x43B, 0x00000001,
-               0x43C, 0x00000004,
-               0x43D, 0x00000005,
-               0x43E, 0x00000006,
-               0x43F, 0x00000007,
-               0x440, 0x0000005D,
-               0x441, 0x00000001,
-               0x442, 0x00000000,
-               0x444, 0x00000015,
-               0x445, 0x000000F0,
-               0x446, 0x0000000F,
-               0x447, 0x00000000,
-               0x458, 0x00000041,
-               0x459, 0x000000A8,
-               0x45A, 0x00000072,
-               0x45B, 0x000000B9,
-               0x460, 0x00000066,
-               0x461, 0x00000066,
-               0x462, 0x00000008,
-               0x463, 0x00000003,
-               0x4C8, 0x000000FF,
-               0x4C9, 0x00000008,
-               0x4CC, 0x000000FF,
-               0x4CD, 0x000000FF,
-               0x4CE, 0x00000001,
-               0x500, 0x00000026,
-               0x501, 0x000000A2,
-               0x502, 0x0000002F,
-               0x503, 0x00000000,
-               0x504, 0x00000028,
-               0x505, 0x000000A3,
-               0x506, 0x0000005E,
-               0x507, 0x00000000,
-               0x508, 0x0000002B,
-               0x509, 0x000000A4,
-               0x50A, 0x0000005E,
-               0x50B, 0x00000000,
-               0x50C, 0x0000004F,
-               0x50D, 0x000000A4,
-               0x50E, 0x00000000,
-               0x50F, 0x00000000,
-               0x512, 0x0000001C,
-               0x514, 0x0000000A,
-               0x515, 0x00000010,
-               0x516, 0x0000000A,
-               0x517, 0x00000010,
-               0x51A, 0x00000016,
-               0x524, 0x0000000F,
-               0x525, 0x0000004F,
-               0x546, 0x00000040,
-               0x547, 0x00000000,
-               0x550, 0x00000010,
-               0x551, 0x00000010,
-               0x559, 0x00000002,
-               0x55A, 0x00000002,
-               0x55D, 0x000000FF,
-               0x605, 0x00000030,
-               0x608, 0x0000000E,
-               0x609, 0x0000002A,
-               0x652, 0x00000020,
-               0x63C, 0x0000000A,
-               0x63D, 0x0000000A,
-               0x63E, 0x0000000E,
-               0x63F, 0x0000000E,
-               0x66E, 0x00000005,
-               0x700, 0x00000021,
-               0x701, 0x00000043,
-               0x702, 0x00000065,
-               0x703, 0x00000087,
-               0x708, 0x00000021,
-               0x709, 0x00000043,
-               0x70A, 0x00000065,
-               0x70B, 0x00000087,
-};
-
-void ODM_ReadAndConfig_MAC_REG_8723A(struct dm_odm_t *pDM_Odm)
-{
-       #define READ_NEXT_PAIR(v1, v2, i)                       \
-                do {                                           \
-                       i += 2; v1 = Array[i]; v2 = Array[i+1]; \
-                } while (0)
-
-       u32     hex         = 0;
-       u32     i           = 0;
-       u8     platform    = 0x04;
-       u8     board       = pDM_Odm->BoardType;
-       u32     ArrayLen    = ARRAY_SIZE(Array_MAC_REG_8723A);
-       u32 *Array       = Array_MAC_REG_8723A;
-
-       hex += board;
-       hex += ODM_ITRF_USB << 8;
-       hex += platform << 16;
-       hex += 0xFF000000;
-       for (i = 0; i < ArrayLen; i += 2) {
-               u32 v1 = Array[i];
-               u32 v2 = Array[i+1];
-
-               /*  This (offset, data) pair meets the condition. */
-               if (v1 < 0xCDCDCDCD) {
-                       odm_ConfigMAC_8723A(pDM_Odm, v1, (u8)v2);
-                       continue;
-               } else {
-                       if (!CheckCondition(Array[i], hex)) {
-                               /* Discard the following (offset, data) pairs. */
-                               READ_NEXT_PAIR(v1, v2, i);
-                               while (v2 != 0xDEAD &&
-                                      v2 != 0xCDEF &&
-                                      v2 != 0xCDCD && i < ArrayLen - 2)
-                                       READ_NEXT_PAIR(v1, v2, i);
-                               i -= 2; /*  prevent from for-loop += 2 */
-                       } else {
-                               /*  Configure matched pairs and skip to end of if-else. */
-                               READ_NEXT_PAIR(v1, v2, i);
-                               while (v2 != 0xDEAD &&
-                                      v2 != 0xCDEF &&
-                                      v2 != 0xCDCD && i < ArrayLen - 2) {
-                                       odm_ConfigMAC_8723A(pDM_Odm, v1, (u8)v2);
-                                       READ_NEXT_PAIR(v1, v2, i);
-                               }
-
-                               while (v2 != 0xDEAD && i < ArrayLen - 2)
-                                       READ_NEXT_PAIR(v1, v2, i);
-                       }
-               }
-       }
-}
diff --git a/drivers/staging/rtl8723au/hal/HalHWImg8723A_RF.c b/drivers/staging/rtl8723au/hal/HalHWImg8723A_RF.c
deleted file mode 100644 (file)
index 286f3ea..0000000
+++ /dev/null
@@ -1,259 +0,0 @@
-/******************************************************************************
-*
-* Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
-*
-* This program is free software; you can redistribute it and/or modify it
-* under the terms of version 2 of the GNU General Public License as
-* published by the Free Software Foundation.
-*
-* This program is distributed in the hope that it will be useful, but WITHOUT
-* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
-* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
-* more details.
-*
-******************************************************************************/
-
-#include "odm_precomp.h"
-
-static bool CheckCondition(const u32  Condition, const u32  Hex)
-{
-       u32 _board     = (Hex & 0x000000FF);
-       u32 _interface = (Hex & 0x0000FF00) >> 8;
-       u32 _platform  = (Hex & 0x00FF0000) >> 16;
-       u32 cond = Condition;
-
-       if (Condition == 0xCDCDCDCD)
-               return true;
-
-       cond = Condition & 0x000000FF;
-       if ((_board == cond) && cond != 0x00)
-               return false;
-
-       cond = Condition & 0x0000FF00;
-       cond >>= 8;
-       if ((_interface & cond) == 0 && cond != 0x07)
-               return false;
-
-       cond = Condition & 0x00FF0000;
-       cond >>= 16;
-       if ((_platform & cond) == 0 && cond != 0x0F)
-               return false;
-       return true;
-}
-
-/******************************************************************************
-*                           RadioA_1T.TXT
-******************************************************************************/
-
-static u32 Array_RadioA_1T_8723A[] = {
-       0x000, 0x00030159,
-       0x001, 0x00031284,
-       0x002, 0x00098000,
-       0xFF0F011F, 0xABCD,
-       0x003, 0x00018C63,
-       0xCDCDCDCD, 0xCDCD,
-       0x003, 0x00039C63,
-       0xFF0F011F, 0xDEAD,
-       0x004, 0x000210E7,
-       0x009, 0x0002044F,
-       0x00A, 0x0001A3F1,
-       0x00B, 0x00014787,
-       0x00C, 0x000896FE,
-       0x00D, 0x0000E02C,
-       0x00E, 0x00039CE7,
-       0x00F, 0x00000451,
-       0x019, 0x00000000,
-       0x01A, 0x00030355,
-       0x01B, 0x00060A00,
-       0x01C, 0x000FC378,
-       0x01D, 0x000A1250,
-       0x01E, 0x0000024F,
-       0x01F, 0x00000000,
-       0x020, 0x0000B614,
-       0x021, 0x0006C000,
-       0x022, 0x00000000,
-       0x023, 0x00001558,
-       0x024, 0x00000060,
-       0x025, 0x00000483,
-       0x026, 0x0004F000,
-       0x027, 0x000EC7D9,
-       0x028, 0x00057730,
-       0x029, 0x00004783,
-       0x02A, 0x00000001,
-       0x02B, 0x00021334,
-       0x02A, 0x00000000,
-       0x02B, 0x00000054,
-       0x02A, 0x00000001,
-       0x02B, 0x00000808,
-       0x02B, 0x00053333,
-       0x02C, 0x0000000C,
-       0x02A, 0x00000002,
-       0x02B, 0x00000808,
-       0x02B, 0x0005B333,
-       0x02C, 0x0000000D,
-       0x02A, 0x00000003,
-       0x02B, 0x00000808,
-       0x02B, 0x00063333,
-       0x02C, 0x0000000D,
-       0x02A, 0x00000004,
-       0x02B, 0x00000808,
-       0x02B, 0x0006B333,
-       0x02C, 0x0000000D,
-       0x02A, 0x00000005,
-       0x02B, 0x00000808,
-       0x02B, 0x00073333,
-       0x02C, 0x0000000D,
-       0x02A, 0x00000006,
-       0x02B, 0x00000709,
-       0x02B, 0x0005B333,
-       0x02C, 0x0000000D,
-       0x02A, 0x00000007,
-       0x02B, 0x00000709,
-       0x02B, 0x00063333,
-       0x02C, 0x0000000D,
-       0x02A, 0x00000008,
-       0x02B, 0x0000060A,
-       0x02B, 0x0004B333,
-       0x02C, 0x0000000D,
-       0x02A, 0x00000009,
-       0x02B, 0x0000060A,
-       0x02B, 0x00053333,
-       0x02C, 0x0000000D,
-       0x02A, 0x0000000A,
-       0x02B, 0x0000060A,
-       0x02B, 0x0005B333,
-       0x02C, 0x0000000D,
-       0x02A, 0x0000000B,
-       0x02B, 0x0000060A,
-       0x02B, 0x00063333,
-       0x02C, 0x0000000D,
-       0x02A, 0x0000000C,
-       0x02B, 0x0000060A,
-       0x02B, 0x0006B333,
-       0x02C, 0x0000000D,
-       0x02A, 0x0000000D,
-       0x02B, 0x0000060A,
-       0x02B, 0x00073333,
-       0x02C, 0x0000000D,
-       0x02A, 0x0000000E,
-       0x02B, 0x0000050B,
-       0x02B, 0x00066666,
-       0x02C, 0x0000001A,
-       0x02A, 0x000E0000,
-       0x010, 0x0004000F,
-       0x011, 0x000E31FC,
-       0x010, 0x0006000F,
-       0x011, 0x000FF9F8,
-       0x010, 0x0002000F,
-       0x011, 0x000203F9,
-       0x010, 0x0003000F,
-       0x011, 0x000FF500,
-       0x010, 0x00000000,
-       0x011, 0x00000000,
-       0x010, 0x0008000F,
-       0x011, 0x0003F100,
-       0x010, 0x0009000F,
-       0x011, 0x00023100,
-       0x012, 0x00032000,
-       0x012, 0x00071000,
-       0x012, 0x000B0000,
-       0x012, 0x000FC000,
-       0x013, 0x000287B3,
-       0x013, 0x000244B7,
-       0x013, 0x000204AB,
-       0x013, 0x0001C49F,
-       0x013, 0x00018493,
-       0x013, 0x0001429B,
-       0x013, 0x00010299,
-       0x013, 0x0000C29C,
-       0x013, 0x000081A0,
-       0x013, 0x000040AC,
-       0x013, 0x00000020,
-       0x014, 0x0001944C,
-       0x014, 0x00059444,
-       0x014, 0x0009944C,
-       0x014, 0x000D9444,
-       0xFF0F011F, 0xABCD,
-       0x015, 0x0000F424,
-       0x015, 0x0004F424,
-       0x015, 0x0008F424,
-       0x015, 0x000CF424,
-       0xCDCDCDCD, 0xCDCD,
-       0x015, 0x0000F474,
-       0x015, 0x0004F477,
-       0x015, 0x0008F455,
-       0x015, 0x000CF455,
-       0xFF0F011F, 0xDEAD,
-       0x016, 0x00000339,
-       0x016, 0x00040339,
-       0x016, 0x00080339,
-       0xFF0F011F, 0xABCD,
-       0x016, 0x000C0356,
-       0xCDCDCDCD, 0xCDCD,
-       0x016, 0x000C0366,
-       0xFF0F011F, 0xDEAD,
-       0x000, 0x00010159,
-       0x018, 0x0000F401,
-       0x0FE, 0x00000000,
-       0x0FE, 0x00000000,
-       0x01F, 0x00000003,
-       0x0FE, 0x00000000,
-       0x0FE, 0x00000000,
-       0x01E, 0x00000247,
-       0x01F, 0x00000000,
-       0x000, 0x00030159,
-};
-
-void ODM_ReadAndConfig_RadioA_1T_8723A(struct dm_odm_t *pDM_Odm)
-{
-       #define READ_NEXT_PAIR(v1, v2, i)                       \
-                do {                                           \
-                        i += 2; v1 = Array[i]; v2 = Array[i+1];\
-                } while (0)
-
-       u32     hex         = 0;
-       u32     i           = 0;
-       u8     platform    = 0x04;
-       u8     board       = pDM_Odm->BoardType;
-       u32     ArrayLen    = ARRAY_SIZE(Array_RadioA_1T_8723A);
-       u32 *Array = Array_RadioA_1T_8723A;
-
-       hex += board;
-       hex += ODM_ITRF_USB << 8;
-       hex += platform << 16;
-       hex += 0xFF000000;
-
-       for (i = 0; i < ArrayLen; i += 2) {
-               u32 v1 = Array[i];
-               u32 v2 = Array[i+1];
-
-               /*  This (offset, data) pair meets the condition. */
-               if (v1 < 0xCDCDCDCD) {
-                       odm_ConfigRFReg_8723A(pDM_Odm, v1, v2, RF_PATH_A, v1);
-                       continue;
-               } else {
-                       if (!CheckCondition(Array[i], hex)) {
-                               /*  Discard the following (offset, data) pairs. */
-                               READ_NEXT_PAIR(v1, v2, i);
-                               while (v2 != 0xDEAD &&
-                                      v2 != 0xCDEF &&
-                                      v2 != 0xCDCD && i < ArrayLen - 2)
-                                       READ_NEXT_PAIR(v1, v2, i);
-                               i -= 2; /*  prevent from for-loop += 2 */
-                       } else {
-                               /*  Configure matched pairs and skip to end of if-else. */
-                               READ_NEXT_PAIR(v1, v2, i);
-                               while (v2 != 0xDEAD &&
-                                      v2 != 0xCDEF &&
-                                      v2 != 0xCDCD && i < ArrayLen - 2) {
-                                       odm_ConfigRFReg_8723A(pDM_Odm, v1, v2,
-                                                             RF_PATH_A, v1);
-                                       READ_NEXT_PAIR(v1, v2, i);
-                               }
-
-                               while (v2 != 0xDEAD && i < ArrayLen - 2)
-                                       READ_NEXT_PAIR(v1, v2, i);
-                       }
-               }
-       }
-}
diff --git a/drivers/staging/rtl8723au/hal/HalPwrSeqCmd.c b/drivers/staging/rtl8723au/hal/HalPwrSeqCmd.c
deleted file mode 100644 (file)
index 0a3d96e..0000000
+++ /dev/null
@@ -1,156 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-/*++
-Copyright (c) Realtek Semiconductor Corp. All rights reserved.
-
-Module Name:
-       HalPwrSeqCmd.c
-
-Abstract:
-       Implement HW Power sequence configuration CMD handling routine for
-       Realtek devices.
-
-Major Change History:
-       When       Who               What
-       ---------- ---------------   -------------------------------
-       2011-10-26 Lucas            Modify to be compatible with SD4-CE driver.
-       2011-07-07 Roger            Create.
-
---*/
-#include <HalPwrSeqCmd.h>
-#include <usb_ops_linux.h>
-
-/*  */
-/*     Description: */
-/*             This routine deal with the Power Configuration CMDs parsing
-               for RTL8723/RTL8188E Series IC. */
-/*  */
-/*     Assumption: */
-/*             We should follow specific format which was released from
-               HW SD. */
-/*  */
-/*     2011.07.07, added by Roger. */
-/*  */
-u8 HalPwrSeqCmdParsing23a(struct rtw_adapter *padapter, u8 CutVersion,
-                      u8 FabVersion, u8 InterfaceType,
-                      struct wlan_pwr_cfg PwrSeqCmd[])
-{
-       struct wlan_pwr_cfg PwrCfgCmd;
-       u8 bPollingBit;
-       u32 AryIdx = 0;
-       u8 value;
-       u32 offset;
-       u32 pollingCount = 0;   /*  polling autoload done. */
-       u32 maxPollingCnt = 5000;
-
-       do {
-               PwrCfgCmd = PwrSeqCmd[AryIdx];
-
-               RT_TRACE(_module_hal_init_c_, _drv_info_,
-                        "HalPwrSeqCmdParsing23a: offset(%#x) cut_msk(%#x) fab_msk(%#x) interface_msk(%#x) base(%#x) cmd(%#x) msk(%#x) value(%#x)\n",
-                        GET_PWR_CFG_OFFSET(PwrCfgCmd),
-                        GET_PWR_CFG_CUT_MASK(PwrCfgCmd),
-                        GET_PWR_CFG_FAB_MASK(PwrCfgCmd),
-                        GET_PWR_CFG_INTF_MASK(PwrCfgCmd),
-                        GET_PWR_CFG_BASE(PwrCfgCmd),
-                        GET_PWR_CFG_CMD(PwrCfgCmd),
-                        GET_PWR_CFG_MASK(PwrCfgCmd),
-                        GET_PWR_CFG_VALUE(PwrCfgCmd));
-
-               /* 2 Only Handle the command whose FAB, CUT, and Interface are
-                  matched */
-               if ((GET_PWR_CFG_FAB_MASK(PwrCfgCmd) & FabVersion) &&
-                   (GET_PWR_CFG_CUT_MASK(PwrCfgCmd) & CutVersion) &&
-                   (GET_PWR_CFG_INTF_MASK(PwrCfgCmd) & InterfaceType)) {
-                       switch (GET_PWR_CFG_CMD(PwrCfgCmd)) {
-                       case PWR_CMD_READ:
-                               RT_TRACE(_module_hal_init_c_, _drv_info_,
-                                        "HalPwrSeqCmdParsing23a: PWR_CMD_READ\n");
-                               break;
-
-                       case PWR_CMD_WRITE:
-                               RT_TRACE(_module_hal_init_c_, _drv_info_,
-                                        "HalPwrSeqCmdParsing23a: PWR_CMD_WRITE\n");
-                               offset = GET_PWR_CFG_OFFSET(PwrCfgCmd);
-
-                               /*  Read the value from system register */
-                               value = rtl8723au_read8(padapter, offset);
-
-                               value &= ~(GET_PWR_CFG_MASK(PwrCfgCmd));
-                               value |= (GET_PWR_CFG_VALUE(PwrCfgCmd) &
-                                         GET_PWR_CFG_MASK(PwrCfgCmd));
-
-                               /*  Write the value back to system register */
-                               rtl8723au_write8(padapter, offset, value);
-                               break;
-
-                       case PWR_CMD_POLLING:
-                               RT_TRACE(_module_hal_init_c_, _drv_info_,
-                                        "HalPwrSeqCmdParsing23a: PWR_CMD_POLLING\n");
-
-                               bPollingBit = false;
-                               offset = GET_PWR_CFG_OFFSET(PwrCfgCmd);
-                               do {
-                                       value = rtl8723au_read8(padapter,
-                                                               offset);
-
-                                       value &= GET_PWR_CFG_MASK(PwrCfgCmd);
-                                       if (value ==
-                                           (GET_PWR_CFG_VALUE(PwrCfgCmd) &
-                                            GET_PWR_CFG_MASK(PwrCfgCmd)))
-                                               bPollingBit = true;
-                                       else
-                                               udelay(10);
-
-                                       if (pollingCount++ > maxPollingCnt) {
-                                               DBG_8723A("Fail to polling "
-                                                         "Offset[%#x]\n",
-                                                         offset);
-                                               return false;
-                                       }
-                               } while (!bPollingBit);
-
-                               break;
-
-                       case PWR_CMD_DELAY:
-                               RT_TRACE(_module_hal_init_c_, _drv_info_,
-                                        "HalPwrSeqCmdParsing23a: PWR_CMD_DELAY\n");
-                               if (GET_PWR_CFG_VALUE(PwrCfgCmd) ==
-                                   PWRSEQ_DELAY_US)
-                                       udelay(GET_PWR_CFG_OFFSET(PwrCfgCmd));
-                               else
-                                       udelay(GET_PWR_CFG_OFFSET(PwrCfgCmd) *
-                                              1000);
-                               break;
-
-                       case PWR_CMD_END:
-                               /*  When this command is parsed, end
-                                   the process */
-                               RT_TRACE(_module_hal_init_c_, _drv_info_,
-                                        "HalPwrSeqCmdParsing23a: PWR_CMD_END\n");
-                               return true;
-
-                       default:
-                               RT_TRACE(_module_hal_init_c_, _drv_err_,
-                                        "HalPwrSeqCmdParsing23a: Unknown CMD!!\n");
-                               break;
-                       }
-               }
-
-               AryIdx++;       /* Add Array Index */
-       } while (1);
-
-       return true;
-}
diff --git a/drivers/staging/rtl8723au/hal/hal_com.c b/drivers/staging/rtl8723au/hal/hal_com.c
deleted file mode 100644 (file)
index 9d7b11b..0000000
+++ /dev/null
@@ -1,853 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#include <osdep_service.h>
-#include <drv_types.h>
-
-#include <hal_intf.h>
-#include <hal_com.h>
-#include <rtl8723a_hal.h>
-#include <usb_ops_linux.h>
-
-#define _HAL_INIT_C_
-
-#define        EEPROM_CHANNEL_PLAN_BY_HW_MASK  0x80
-
-/* return the final channel plan decision */
-/* hw_channel_plan:  channel plan from HW (efuse/eeprom) */
-/* sw_channel_plan:  channel plan from SW (registry/module param) */
-/* def_channel_plan: channel plan used when the former two is invalid */
-u8 hal_com_get_channel_plan23a(struct rtw_adapter *padapter, u8 hw_channel_plan,
-                           u8 sw_channel_plan, u8 def_channel_plan,
-                           bool AutoLoadFail)
-{
-       u8 swConfig;
-       u8 chnlPlan;
-
-       swConfig = true;
-       if (!AutoLoadFail) {
-               if (!rtw_is_channel_plan_valid(sw_channel_plan))
-                       swConfig = false;
-               if (hw_channel_plan & EEPROM_CHANNEL_PLAN_BY_HW_MASK)
-                       swConfig = false;
-       }
-
-       if (swConfig == true)
-               chnlPlan = sw_channel_plan;
-       else
-               chnlPlan = hw_channel_plan & (~EEPROM_CHANNEL_PLAN_BY_HW_MASK);
-
-       if (!rtw_is_channel_plan_valid(chnlPlan))
-               chnlPlan = def_channel_plan;
-
-       return chnlPlan;
-}
-
-u8 MRateToHwRate23a(u8 rate)
-{
-       u8 ret = DESC_RATE1M;
-
-       switch (rate) {
-               /*  CCK and OFDM non-HT rates */
-       case IEEE80211_CCK_RATE_1MB:
-               ret = DESC_RATE1M;
-               break;
-       case IEEE80211_CCK_RATE_2MB:
-               ret = DESC_RATE2M;
-               break;
-       case IEEE80211_CCK_RATE_5MB:
-               ret = DESC_RATE5_5M;
-               break;
-       case IEEE80211_CCK_RATE_11MB:
-               ret = DESC_RATE11M;
-               break;
-       case IEEE80211_OFDM_RATE_6MB:
-               ret = DESC_RATE6M;
-               break;
-       case IEEE80211_OFDM_RATE_9MB:
-               ret = DESC_RATE9M;
-               break;
-       case IEEE80211_OFDM_RATE_12MB:
-               ret = DESC_RATE12M;
-               break;
-       case IEEE80211_OFDM_RATE_18MB:
-               ret = DESC_RATE18M;
-               break;
-       case IEEE80211_OFDM_RATE_24MB:
-               ret = DESC_RATE24M;
-               break;
-       case IEEE80211_OFDM_RATE_36MB:
-               ret = DESC_RATE36M;
-               break;
-       case IEEE80211_OFDM_RATE_48MB:
-               ret = DESC_RATE48M;
-               break;
-       case IEEE80211_OFDM_RATE_54MB:
-               ret = DESC_RATE54M;
-               break;
-
-               /*  HT rates since here */
-               /* case MGN_MCS0:       ret = DESC_RATEMCS0;    break; */
-               /* case MGN_MCS1:       ret = DESC_RATEMCS1;    break; */
-               /* case MGN_MCS2:       ret = DESC_RATEMCS2;    break; */
-               /* case MGN_MCS3:       ret = DESC_RATEMCS3;    break; */
-               /* case MGN_MCS4:       ret = DESC_RATEMCS4;    break; */
-               /* case MGN_MCS5:       ret = DESC_RATEMCS5;    break; */
-               /* case MGN_MCS6:       ret = DESC_RATEMCS6;    break; */
-               /* case MGN_MCS7:       ret = DESC_RATEMCS7;    break; */
-
-       default:
-               break;
-       }
-       return ret;
-}
-
-void HalSetBrateCfg23a(struct rtw_adapter *padapter, u8 *mBratesOS)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       u8 i, is_brate, brate;
-       u16 brate_cfg = 0;
-       u8 rate_index;
-
-       for (i = 0; i < NDIS_802_11_LENGTH_RATES_EX; i++) {
-               is_brate = mBratesOS[i] & IEEE80211_BASIC_RATE_MASK;
-               brate = mBratesOS[i] & 0x7f;
-
-               if (is_brate) {
-                       switch (brate) {
-                       case IEEE80211_CCK_RATE_1MB:
-                               brate_cfg |= RATE_1M;
-                               break;
-                       case IEEE80211_CCK_RATE_2MB:
-                               brate_cfg |= RATE_2M;
-                               break;
-                       case IEEE80211_CCK_RATE_5MB:
-                               brate_cfg |= RATE_5_5M;
-                               break;
-                       case IEEE80211_CCK_RATE_11MB:
-                               brate_cfg |= RATE_11M;
-                               break;
-                       case IEEE80211_OFDM_RATE_6MB:
-                               brate_cfg |= RATE_6M;
-                               break;
-                       case IEEE80211_OFDM_RATE_9MB:
-                               brate_cfg |= RATE_9M;
-                               break;
-                       case IEEE80211_OFDM_RATE_12MB:
-                               brate_cfg |= RATE_12M;
-                               break;
-                       case IEEE80211_OFDM_RATE_18MB:
-                               brate_cfg |= RATE_18M;
-                               break;
-                       case IEEE80211_OFDM_RATE_24MB:
-                               brate_cfg |= RATE_24M;
-                               break;
-                       case IEEE80211_OFDM_RATE_36MB:
-                               brate_cfg |= RATE_36M;
-                               break;
-                       case IEEE80211_OFDM_RATE_48MB:
-                               brate_cfg |= RATE_48M;
-                               break;
-                       case IEEE80211_OFDM_RATE_54MB:
-                               brate_cfg |= RATE_54M;
-                               break;
-                       }
-               }
-       }
-
-       /*  2007.01.16, by Emily */
-       /*  Select RRSR (in Legacy-OFDM and CCK) */
-       /*  For 8190, we select only 24M, 12M, 6M, 11M, 5.5M, 2M,
-           and 1M from the Basic rate. */
-       /*  We do not use other rates. */
-       /* 2011.03.30 add by Luke Lee */
-       /* CCK 2M ACK should be disabled for some BCM and Atheros AP IOT */
-       /* because CCK 2M has poor TXEVM */
-       /* CCK 5.5M & 11M ACK should be enabled for better
-          performance */
-
-       brate_cfg = (brate_cfg | 0xd) & 0x15d;
-       pHalData->BasicRateSet = brate_cfg;
-       brate_cfg |= 0x01;      /*  default enable 1M ACK rate */
-       DBG_8723A("HW_VAR_BASIC_RATE: BrateCfg(%#x)\n", brate_cfg);
-
-       /*  Set RRSR rate table. */
-       rtl8723au_write8(padapter, REG_RRSR, brate_cfg & 0xff);
-       rtl8723au_write8(padapter, REG_RRSR + 1, (brate_cfg >> 8) & 0xff);
-       rtl8723au_write8(padapter, REG_RRSR + 2,
-                        rtl8723au_read8(padapter, REG_RRSR + 2) & 0xf0);
-
-       rate_index = 0;
-       /*  Set RTS initial rate */
-       while (brate_cfg > 0x1) {
-               brate_cfg >>= 1;
-               rate_index++;
-       }
-               /*  Ziv - Check */
-       rtl8723au_write8(padapter, REG_INIRTS_RATE_SEL, rate_index);
-}
-
-static void _OneOutPipeMapping(struct rtw_adapter *pAdapter)
-{
-       struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(pAdapter);
-
-       pdvobjpriv->Queue2Pipe[0] = pdvobjpriv->RtOutPipe[0];   /* VO */
-       pdvobjpriv->Queue2Pipe[1] = pdvobjpriv->RtOutPipe[0];   /* VI */
-       pdvobjpriv->Queue2Pipe[2] = pdvobjpriv->RtOutPipe[0];   /* BE */
-       pdvobjpriv->Queue2Pipe[3] = pdvobjpriv->RtOutPipe[0];   /* BK */
-
-       pdvobjpriv->Queue2Pipe[4] = pdvobjpriv->RtOutPipe[0];   /* BCN */
-       pdvobjpriv->Queue2Pipe[5] = pdvobjpriv->RtOutPipe[0];   /* MGT */
-       pdvobjpriv->Queue2Pipe[6] = pdvobjpriv->RtOutPipe[0];   /* HIGH */
-       pdvobjpriv->Queue2Pipe[7] = pdvobjpriv->RtOutPipe[0];   /* TXCMD */
-}
-
-static void _TwoOutPipeMapping(struct rtw_adapter *pAdapter, bool bWIFICfg)
-{
-       struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(pAdapter);
-
-       if (bWIFICfg) {         /* WMM */
-               /*    BK,   BE,   VI,   VO,   BCN,  CMD,  MGT, HIGH, HCCA */
-               /*     0,    1,    0,    1,     0,    0,    0,    0,    0 }; */
-               /* 0:H, 1:L */
-               pdvobjpriv->Queue2Pipe[0] = pdvobjpriv->RtOutPipe[1]; /* VO */
-               pdvobjpriv->Queue2Pipe[1] = pdvobjpriv->RtOutPipe[0]; /* VI */
-               pdvobjpriv->Queue2Pipe[2] = pdvobjpriv->RtOutPipe[1]; /* BE */
-               pdvobjpriv->Queue2Pipe[3] = pdvobjpriv->RtOutPipe[0]; /* BK */
-
-               pdvobjpriv->Queue2Pipe[4] = pdvobjpriv->RtOutPipe[0]; /* BCN */
-               pdvobjpriv->Queue2Pipe[5] = pdvobjpriv->RtOutPipe[0]; /* MGT */
-               pdvobjpriv->Queue2Pipe[6] = pdvobjpriv->RtOutPipe[0]; /* HIGH */
-               pdvobjpriv->Queue2Pipe[7] = pdvobjpriv->RtOutPipe[0]; /* TXCMD*/
-       } else {                /* typical setting */
-               /*    BK,   BE,   VI,   VO,   BCN,  CMD,  MGT, HIGH, HCCA */
-               /*     1,    1,    0,    0,     0,    0,    0,    0,    0 }; */
-               /* 0:H, 1:L */
-               pdvobjpriv->Queue2Pipe[0] = pdvobjpriv->RtOutPipe[0]; /* VO */
-               pdvobjpriv->Queue2Pipe[1] = pdvobjpriv->RtOutPipe[0]; /* VI */
-               pdvobjpriv->Queue2Pipe[2] = pdvobjpriv->RtOutPipe[1]; /* BE */
-               pdvobjpriv->Queue2Pipe[3] = pdvobjpriv->RtOutPipe[1]; /* BK */
-
-               pdvobjpriv->Queue2Pipe[4] = pdvobjpriv->RtOutPipe[0]; /* BCN */
-               pdvobjpriv->Queue2Pipe[5] = pdvobjpriv->RtOutPipe[0]; /* MGT */
-               pdvobjpriv->Queue2Pipe[6] = pdvobjpriv->RtOutPipe[0]; /* HIGH */
-               pdvobjpriv->Queue2Pipe[7] = pdvobjpriv->RtOutPipe[0]; /* TXCMD*/
-       }
-}
-
-static void _ThreeOutPipeMapping(struct rtw_adapter *pAdapter, bool bWIFICfg)
-{
-       struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(pAdapter);
-
-       if (bWIFICfg) {         /* for WMM */
-               /*    BK,   BE,   VI,   VO,   BCN,  CMD,  MGT, HIGH, HCCA */
-               /*     1,    2,    1,    0,     0,    0,    0,    0,    0 }; */
-               /* 0:H, 1:N, 2:L */
-               pdvobjpriv->Queue2Pipe[0] = pdvobjpriv->RtOutPipe[0]; /* VO */
-               pdvobjpriv->Queue2Pipe[1] = pdvobjpriv->RtOutPipe[1]; /* VI */
-               pdvobjpriv->Queue2Pipe[2] = pdvobjpriv->RtOutPipe[2]; /* BE */
-               pdvobjpriv->Queue2Pipe[3] = pdvobjpriv->RtOutPipe[1]; /* BK */
-
-               pdvobjpriv->Queue2Pipe[4] = pdvobjpriv->RtOutPipe[0]; /* BCN */
-               pdvobjpriv->Queue2Pipe[5] = pdvobjpriv->RtOutPipe[0]; /* MGT */
-               pdvobjpriv->Queue2Pipe[6] = pdvobjpriv->RtOutPipe[0]; /* HIGH */
-               pdvobjpriv->Queue2Pipe[7] = pdvobjpriv->RtOutPipe[0]; /* TXCMD*/
-       } else {                /* typical setting */
-               /*    BK,   BE,   VI,   VO,   BCN,  CMD,  MGT, HIGH, HCCA */
-               /*     2,    2,    1,    0,     0,    0,    0,    0,    0 }; */
-               /* 0:H, 1:N, 2:L */
-               pdvobjpriv->Queue2Pipe[0] = pdvobjpriv->RtOutPipe[0]; /* VO */
-               pdvobjpriv->Queue2Pipe[1] = pdvobjpriv->RtOutPipe[1]; /* VI */
-               pdvobjpriv->Queue2Pipe[2] = pdvobjpriv->RtOutPipe[2]; /* BE */
-               pdvobjpriv->Queue2Pipe[3] = pdvobjpriv->RtOutPipe[2]; /* BK */
-
-               pdvobjpriv->Queue2Pipe[4] = pdvobjpriv->RtOutPipe[0]; /* BCN */
-               pdvobjpriv->Queue2Pipe[5] = pdvobjpriv->RtOutPipe[0]; /* MGT */
-               pdvobjpriv->Queue2Pipe[6] = pdvobjpriv->RtOutPipe[0]; /* HIGH */
-               pdvobjpriv->Queue2Pipe[7] = pdvobjpriv->RtOutPipe[0]; /* TXCMD*/
-       }
-}
-
-bool Hal_MappingOutPipe23a(struct rtw_adapter *pAdapter, u8 NumOutPipe)
-{
-       struct registry_priv *pregistrypriv = &pAdapter->registrypriv;
-       bool bWIFICfg = (pregistrypriv->wifi_spec) ? true : false;
-       bool result = true;
-
-       switch (NumOutPipe) {
-       case 2:
-               _TwoOutPipeMapping(pAdapter, bWIFICfg);
-               break;
-       case 3:
-               _ThreeOutPipeMapping(pAdapter, bWIFICfg);
-               break;
-       case 1:
-               _OneOutPipeMapping(pAdapter);
-               break;
-       default:
-               result = false;
-               break;
-       }
-
-       return result;
-}
-
-/*
-* C2H event format:
-* Field         TRIGGER                CONTENT    CMD_SEQ      CMD_LEN          CMD_ID
-* BITS  [127:120]      [119:16]      [15:8]              [7:4]            [3:0]
-*/
-
-void c2h_evt_clear23a(struct rtw_adapter *adapter)
-{
-       rtl8723au_write8(adapter, REG_C2HEVT_CLEAR, C2H_EVT_HOST_CLOSE);
-}
-
-int c2h_evt_read23a(struct rtw_adapter *adapter, u8 *buf)
-{
-       int ret = _FAIL;
-       struct c2h_evt_hdr *c2h_evt;
-       int i;
-       u8 trigger;
-
-       if (buf == NULL)
-               goto exit;
-
-       trigger = rtl8723au_read8(adapter, REG_C2HEVT_CLEAR);
-
-       if (trigger == C2H_EVT_HOST_CLOSE)
-               goto exit;      /* Not ready */
-       if (trigger != C2H_EVT_FW_CLOSE)
-               goto clear_evt; /* Not a valid value */
-
-       c2h_evt = (struct c2h_evt_hdr *)buf;
-
-       memset(c2h_evt, 0, 16);
-
-       *buf = rtl8723au_read8(adapter, REG_C2HEVT_MSG_NORMAL);
-       *(buf + 1) = rtl8723au_read8(adapter, REG_C2HEVT_MSG_NORMAL + 1);
-
-       RT_PRINT_DATA(_module_hal_init_c_, _drv_info_, "c2h_evt_read23a(): ",
-                     &c2h_evt, sizeof(c2h_evt));
-
-       if (0) {
-               DBG_8723A("%s id:%u, len:%u, seq:%u, trigger:0x%02x\n",
-                         __func__, c2h_evt->id, c2h_evt->plen, c2h_evt->seq,
-                         trigger);
-       }
-
-       /* Read the content */
-       for (i = 0; i < c2h_evt->plen; i++)
-               c2h_evt->payload[i] = rtl8723au_read8(adapter,
-                                               REG_C2HEVT_MSG_NORMAL +
-                                               sizeof(*c2h_evt) + i);
-
-       RT_PRINT_DATA(_module_hal_init_c_, _drv_info_,
-                     "c2h_evt_read23a(): Command Content:\n", c2h_evt->payload,
-                     c2h_evt->plen);
-
-       ret = _SUCCESS;
-
-clear_evt:
-       /*
-        * Clear event to notify FW we have read the command.
-        * If this field isn't clear, the FW won't update the
-        * next command message.
-        */
-       c2h_evt_clear23a(adapter);
-exit:
-       return ret;
-}
-
-void
-rtl8723a_set_ampdu_min_space(struct rtw_adapter *padapter, u8 MinSpacingToSet)
-{
-       u8 SecMinSpace;
-
-       if (MinSpacingToSet <= 7) {
-               switch (padapter->securitypriv.dot11PrivacyAlgrthm) {
-               case 0:
-               case WLAN_CIPHER_SUITE_CCMP:
-                       SecMinSpace = 0;
-                       break;
-
-               case WLAN_CIPHER_SUITE_WEP40:
-               case WLAN_CIPHER_SUITE_WEP104:
-               case WLAN_CIPHER_SUITE_TKIP:
-                       SecMinSpace = 6;
-                       break;
-               default:
-                       SecMinSpace = 7;
-                       break;
-               }
-
-               if (MinSpacingToSet < SecMinSpace)
-                       MinSpacingToSet = SecMinSpace;
-
-               MinSpacingToSet |=
-                       rtl8723au_read8(padapter, REG_AMPDU_MIN_SPACE) & 0xf8;
-               rtl8723au_write8(padapter, REG_AMPDU_MIN_SPACE,
-                                MinSpacingToSet);
-       }
-}
-
-void rtl8723a_set_ampdu_factor(struct rtw_adapter *padapter, u8 FactorToSet)
-{
-       u8 RegToSet_Normal[4] = { 0x41, 0xa8, 0x72, 0xb9 };
-       u8 MaxAggNum;
-       u8 *pRegToSet;
-       u8 index = 0;
-
-       pRegToSet = RegToSet_Normal;    /*  0xb972a841; */
-
-       if (rtl8723a_BT_enabled(padapter) &&
-           rtl8723a_BT_using_antenna_1(padapter))
-               MaxAggNum = 0x8;
-       else
-               MaxAggNum = 0xF;
-
-       if (FactorToSet <= 3) {
-               FactorToSet = 1 << (FactorToSet + 2);
-               if (FactorToSet > MaxAggNum)
-                       FactorToSet = MaxAggNum;
-
-               for (index = 0; index < 4; index++) {
-                       if ((pRegToSet[index] & 0xf0) > (FactorToSet << 4))
-                               pRegToSet[index] = (pRegToSet[index] & 0x0f) |
-                                       (FactorToSet << 4);
-
-                       if ((pRegToSet[index] & 0x0f) > FactorToSet)
-                               pRegToSet[index] = (pRegToSet[index] & 0xf0) |
-                                       FactorToSet;
-
-                       rtl8723au_write8(padapter, REG_AGGLEN_LMT + index,
-                                        pRegToSet[index]);
-               }
-       }
-}
-
-void rtl8723a_set_acm_ctrl(struct rtw_adapter *padapter, u8 ctrl)
-{
-       u8 hwctrl = 0;
-
-       if (ctrl != 0) {
-               hwctrl |= AcmHw_HwEn;
-
-               if (ctrl & BIT(1))      /*  BE */
-                       hwctrl |= AcmHw_BeqEn;
-
-               if (ctrl & BIT(2))      /*  VI */
-                       hwctrl |= AcmHw_ViqEn;
-
-               if (ctrl & BIT(3))      /*  VO */
-                       hwctrl |= AcmHw_VoqEn;
-       }
-
-       DBG_8723A("[HW_VAR_ACM_CTRL] Write 0x%02X\n", hwctrl);
-       rtl8723au_write8(padapter, REG_ACMHWCTRL, hwctrl);
-}
-
-void rtl8723a_set_media_status(struct rtw_adapter *padapter, u8 status)
-{
-       u8 val8;
-
-       val8 = rtl8723au_read8(padapter, MSR) & 0x0c;
-       val8 |= status;
-       rtl8723au_write8(padapter, MSR, val8);
-}
-
-void rtl8723a_set_media_status1(struct rtw_adapter *padapter, u8 status)
-{
-       u8 val8;
-
-       val8 = rtl8723au_read8(padapter, MSR) & 0x03;
-       val8 |= status << 2;
-       rtl8723au_write8(padapter, MSR, val8);
-}
-
-void rtl8723a_set_bcn_func(struct rtw_adapter *padapter, u8 val)
-{
-       if (val)
-               SetBcnCtrlReg23a(padapter, EN_BCN_FUNCTION | EN_TXBCN_RPT, 0);
-       else
-               SetBcnCtrlReg23a(padapter, 0, EN_BCN_FUNCTION | EN_TXBCN_RPT);
-}
-
-void rtl8723a_check_bssid(struct rtw_adapter *padapter, u8 val)
-{
-       u32 val32;
-
-       val32 = rtl8723au_read32(padapter, REG_RCR);
-       if (val)
-               val32 |= RCR_CBSSID_DATA | RCR_CBSSID_BCN;
-       else
-               val32 &= ~(RCR_CBSSID_DATA | RCR_CBSSID_BCN);
-       rtl8723au_write32(padapter, REG_RCR, val32);
-}
-
-void rtl8723a_mlme_sitesurvey(struct rtw_adapter *padapter, u8 flag)
-{
-       if (flag) {     /* under sitesurvey */
-               u32 v32;
-
-               /*  config RCR to receive different BSSID & not
-                   to receive data frame */
-               v32 = rtl8723au_read32(padapter, REG_RCR);
-               v32 &= ~(RCR_CBSSID_BCN);
-               rtl8723au_write32(padapter, REG_RCR, v32);
-               /*  reject all data frame */
-               rtl8723au_write16(padapter, REG_RXFLTMAP2, 0);
-
-               /*  disable update TSF */
-               SetBcnCtrlReg23a(padapter, DIS_TSF_UDT, 0);
-       } else {        /* sitesurvey done */
-
-               struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-               struct mlme_ext_info *pmlmeinfo;
-               u32 v32;
-
-               pmlmeinfo = &pmlmeext->mlmext_info;
-
-               if ((is_client_associated_to_ap23a(padapter) == true) ||
-                   ((pmlmeinfo->state & 0x03) == MSR_ADHOC) ||
-                   ((pmlmeinfo->state & 0x03) == MSR_AP)) {
-                       /*  enable to rx data frame */
-                       rtl8723au_write16(padapter, REG_RXFLTMAP2, 0xFFFF);
-
-                       /*  enable update TSF */
-                       SetBcnCtrlReg23a(padapter, 0, DIS_TSF_UDT);
-               }
-
-               v32 = rtl8723au_read32(padapter, REG_RCR);
-               v32 |= RCR_CBSSID_BCN;
-               rtl8723au_write32(padapter, REG_RCR, v32);
-       }
-
-       rtl8723a_BT_wifiscan_notify(padapter, flag ? true : false);
-}
-
-void rtl8723a_on_rcr_am(struct rtw_adapter *padapter)
-{
-       rtl8723au_write32(padapter, REG_RCR,
-                   rtl8723au_read32(padapter, REG_RCR) | RCR_AM);
-       DBG_8723A("%s, %d, RCR = %x\n", __func__, __LINE__,
-                 rtl8723au_read32(padapter, REG_RCR));
-}
-
-void rtl8723a_off_rcr_am(struct rtw_adapter *padapter)
-{
-       rtl8723au_write32(padapter, REG_RCR,
-                   rtl8723au_read32(padapter, REG_RCR) & (~RCR_AM));
-       DBG_8723A("%s, %d, RCR = %x\n", __func__, __LINE__,
-                 rtl8723au_read32(padapter, REG_RCR));
-}
-
-void rtl8723a_set_slot_time(struct rtw_adapter *padapter, u8 slottime)
-{
-       u8 u1bAIFS, aSifsTime;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-
-       rtl8723au_write8(padapter, REG_SLOT, slottime);
-
-       if (pmlmeinfo->WMM_enable == 0) {
-               if (pmlmeext->cur_wireless_mode == WIRELESS_11B)
-                       aSifsTime = 10;
-               else
-                       aSifsTime = 16;
-
-               u1bAIFS = aSifsTime + (2 * pmlmeinfo->slotTime);
-
-               /*  <Roger_EXP> Temporary removed, 2008.06.20. */
-               rtl8723au_write8(padapter, REG_EDCA_VO_PARAM, u1bAIFS);
-               rtl8723au_write8(padapter, REG_EDCA_VI_PARAM, u1bAIFS);
-               rtl8723au_write8(padapter, REG_EDCA_BE_PARAM, u1bAIFS);
-               rtl8723au_write8(padapter, REG_EDCA_BK_PARAM, u1bAIFS);
-       }
-}
-
-void rtl8723a_ack_preamble(struct rtw_adapter *padapter, u8 bShortPreamble)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       u8 regTmp;
-
-       /*  Joseph marked out for Netgear 3500 TKIP
-           channel 7 issue.(Temporarily) */
-       regTmp = (pHalData->nCur40MhzPrimeSC) << 5;
-       /* regTmp = 0; */
-       if (bShortPreamble)
-               regTmp |= 0x80;
-       rtl8723au_write8(padapter, REG_RRSR + 2, regTmp);
-}
-
-void rtl8723a_set_sec_cfg(struct rtw_adapter *padapter, u8 sec)
-{
-       rtl8723au_write8(padapter, REG_SECCFG, sec);
-}
-
-void rtl8723a_cam_empty_entry(struct rtw_adapter *padapter, u8 ucIndex)
-{
-       u8 i;
-       u32 ulCommand = 0;
-       u32 ulContent = 0;
-       u32 ulEncAlgo = CAM_AES;
-
-       for (i = 0; i < CAM_CONTENT_COUNT; i++) {
-               /*  filled id in CAM config 2 byte */
-               if (i == 0) {
-                       ulContent |= (ucIndex & 0x03) |
-                               ((u16) (ulEncAlgo) << 2);
-                       /* ulContent |= CAM_VALID; */
-               } else {
-                       ulContent = 0;
-               }
-               /*  polling bit, and No Write enable, and address */
-               ulCommand = CAM_CONTENT_COUNT * ucIndex + i;
-               ulCommand = ulCommand | CAM_POLLINIG | CAM_WRITE;
-               /*  write content 0 is equall to mark invalid */
-               /* delay_ms(40); */
-               rtl8723au_write32(padapter, WCAMI, ulContent);
-               /* delay_ms(40); */
-               rtl8723au_write32(padapter, REG_CAMCMD, ulCommand);
-       }
-}
-
-void rtl8723a_cam_invalidate_all(struct rtw_adapter *padapter)
-{
-       rtl8723au_write32(padapter, REG_CAMCMD, CAM_POLLINIG | BIT(30));
-}
-
-void rtl8723a_cam_write(struct rtw_adapter *padapter,
-                       u8 entry, u16 ctrl, const u8 *mac, const u8 *key)
-{
-       u32 cmd;
-       unsigned int i, val, addr;
-       int j;
-
-       addr = entry << 3;
-
-       for (j = 5; j >= 0; j--) {
-               switch (j) {
-               case 0:
-                       val = ctrl | (mac[0] << 16) | (mac[1] << 24);
-                       break;
-               case 1:
-                       val = mac[2] | (mac[3] << 8) |
-                               (mac[4] << 16) | (mac[5] << 24);
-                       break;
-               default:
-                       i = (j - 2) << 2;
-                       val = key[i] | (key[i+1] << 8) |
-                               (key[i+2] << 16) | (key[i+3] << 24);
-                       break;
-               }
-
-               rtl8723au_write32(padapter, WCAMI, val);
-               cmd = CAM_POLLINIG | CAM_WRITE | (addr + j);
-               rtl8723au_write32(padapter, REG_CAMCMD, cmd);
-
-               /* DBG_8723A("%s => cam write: %x, %x\n", __func__, cmd, val);*/
-       }
-}
-
-void rtl8723a_fifo_cleanup(struct rtw_adapter *padapter)
-{
-#define RW_RELEASE_EN          BIT(18)
-#define RXDMA_IDLE             BIT(17)
-
-       struct pwrctrl_priv *pwrpriv = &padapter->pwrctrlpriv;
-       u8 trycnt = 100;
-
-       /*  pause tx */
-       rtl8723au_write8(padapter, REG_TXPAUSE, 0xff);
-
-       /*  keep sn */
-       padapter->xmitpriv.nqos_ssn = rtl8723au_read8(padapter, REG_NQOS_SEQ);
-
-       if (pwrpriv->bkeepfwalive != true) {
-               u32 v32;
-
-               /*  RX DMA stop */
-               v32 = rtl8723au_read32(padapter, REG_RXPKT_NUM);
-               v32 |= RW_RELEASE_EN;
-               rtl8723au_write32(padapter, REG_RXPKT_NUM, v32);
-               do {
-                       v32 = rtl8723au_read32(padapter,
-                                              REG_RXPKT_NUM) & RXDMA_IDLE;
-                       if (!v32)
-                               break;
-               } while (trycnt--);
-               if (trycnt == 0)
-                       DBG_8723A("Stop RX DMA failed......\n");
-
-               /*  RQPN Load 0 */
-               rtl8723au_write16(padapter, REG_RQPN_NPQ, 0);
-               rtl8723au_write32(padapter, REG_RQPN, 0x80000000);
-               mdelay(10);
-       }
-}
-
-void rtl8723a_bcn_valid(struct rtw_adapter *padapter)
-{
-       /* BCN_VALID, BIT16 of REG_TDECTRL = BIT0 of REG_TDECTRL+2,
-          write 1 to clear, Clear by sw */
-       rtl8723au_write8(padapter, REG_TDECTRL + 2,
-                        rtl8723au_read8(padapter, REG_TDECTRL + 2) | BIT(0));
-}
-
-bool rtl8723a_get_bcn_valid(struct rtw_adapter *padapter)
-{
-       bool retval;
-
-       retval = (rtl8723au_read8(padapter, REG_TDECTRL + 2) & BIT(0)) ? true : false;
-
-       return retval;
-}
-
-void rtl8723a_set_beacon_interval(struct rtw_adapter *padapter, u16 interval)
-{
-       rtl8723au_write16(padapter, REG_BCN_INTERVAL, interval);
-}
-
-void rtl8723a_set_resp_sifs(struct rtw_adapter *padapter,
-                           u8 r2t1, u8 r2t2, u8 t2t1, u8 t2t2)
-{
-       /* SIFS_Timer = 0x0a0a0808; */
-       /* RESP_SIFS for CCK */
-       /*  SIFS_T2T_CCK (0x08) */
-       rtl8723au_write8(padapter, REG_R2T_SIFS, r2t1);
-       /* SIFS_R2T_CCK(0x08) */
-       rtl8723au_write8(padapter, REG_R2T_SIFS + 1, r2t2);
-       /* RESP_SIFS for OFDM */
-       /* SIFS_T2T_OFDM (0x0a) */
-       rtl8723au_write8(padapter, REG_T2T_SIFS, t2t1);
-       /* SIFS_R2T_OFDM(0x0a) */
-       rtl8723au_write8(padapter, REG_T2T_SIFS + 1, t2t2);
-}
-
-void rtl8723a_set_ac_param_vo(struct rtw_adapter *padapter, u32 vo)
-{
-       rtl8723au_write32(padapter, REG_EDCA_VO_PARAM, vo);
-}
-
-void rtl8723a_set_ac_param_vi(struct rtw_adapter *padapter, u32 vi)
-{
-       rtl8723au_write32(padapter, REG_EDCA_VI_PARAM, vi);
-}
-
-void rtl8723a_set_ac_param_be(struct rtw_adapter *padapter, u32 be)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-
-       pHalData->AcParam_BE = be;
-       rtl8723au_write32(padapter, REG_EDCA_BE_PARAM, be);
-}
-
-void rtl8723a_set_ac_param_bk(struct rtw_adapter *padapter, u32 bk)
-{
-       rtl8723au_write32(padapter, REG_EDCA_BK_PARAM, bk);
-}
-
-void rtl8723a_set_rxdma_agg_pg_th(struct rtw_adapter *padapter, u8 val)
-{
-       rtl8723au_write8(padapter, REG_RXDMA_AGG_PG_TH, val);
-}
-
-void rtl8723a_set_initial_gain(struct rtw_adapter *padapter, u32 rx_gain)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       struct dig_t *pDigTable = &pHalData->odmpriv.DM_DigTable;
-
-       if (rx_gain == 0xff)    /* restore rx gain */
-               ODM_Write_DIG23a(&pHalData->odmpriv, pDigTable->BackupIGValue);
-       else {
-               pDigTable->BackupIGValue = pDigTable->CurIGValue;
-               ODM_Write_DIG23a(&pHalData->odmpriv, rx_gain);
-       }
-}
-
-void rtl8723a_odm_support_ability_restore(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-
-       pHalData->odmpriv.SupportAbility = pHalData->odmpriv.BK_SupportAbility;
-}
-
-void rtl8723a_odm_support_ability_backup(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-
-       pHalData->odmpriv.BK_SupportAbility = pHalData->odmpriv.SupportAbility;
-}
-
-void rtl8723a_odm_support_ability_set(struct rtw_adapter *padapter, u32 val)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-
-       if (val == DYNAMIC_ALL_FUNC_ENABLE)
-               pHalData->odmpriv.SupportAbility = pHalData->dmpriv.InitODMFlag;
-       else
-               pHalData->odmpriv.SupportAbility |= val;
-}
-
-void rtl8723a_odm_support_ability_clr(struct rtw_adapter *padapter, u32 val)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-
-       pHalData->odmpriv.SupportAbility &= val;
-}
-
-void rtl8723a_set_rpwm(struct rtw_adapter *padapter, u8 val)
-{
-       rtl8723au_write8(padapter, REG_USB_HRPWM, val);
-}
-
-u8 rtl8723a_get_rf_type(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-
-       return pHalData->rf_type;
-}
-
-bool rtl8723a_get_fwlps_rf_on(struct rtw_adapter *padapter)
-{
-       bool retval;
-       u32 valRCR;
-
-       /*  When we halt NIC, we should check if FW LPS is leave. */
-
-       if ((padapter->bSurpriseRemoved == true) ||
-           (padapter->pwrctrlpriv.rf_pwrstate == rf_off)) {
-               /*  If it is in HW/SW Radio OFF or IPS state, we do
-                   not check Fw LPS Leave, because Fw is unload. */
-               retval = true;
-       } else {
-               valRCR = rtl8723au_read32(padapter, REG_RCR);
-               if (valRCR & 0x00070000)
-                       retval = false;
-               else
-                       retval = true;
-       }
-
-       return retval;
-}
-
-bool rtl8723a_chk_hi_queue_empty(struct rtw_adapter *padapter)
-{
-       u32 hgq;
-
-       hgq = rtl8723au_read32(padapter, REG_HGQ_INFORMATION);
-
-       return ((hgq & 0x0000ff00) == 0) ? true : false;
-}
diff --git a/drivers/staging/rtl8723au/hal/hal_intf.c b/drivers/staging/rtl8723au/hal/hal_intf.c
deleted file mode 100644 (file)
index 5383e69..0000000
+++ /dev/null
@@ -1,42 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-
-#define _HAL_INTF_C_
-#include <osdep_service.h>
-#include <drv_types.h>
-
-#include <hal_intf.h>
-
-#include <rtl8723a_hal.h>
-
-void rtw_hal_update_ra_mask23a(struct sta_info *psta, u8 rssi_level)
-{
-       struct rtw_adapter *padapter;
-       struct mlme_priv *pmlmepriv;
-
-       if (!psta)
-               return;
-
-       padapter = psta->padapter;
-
-       pmlmepriv = &padapter->mlmepriv;
-
-       if (check_fwstate(pmlmepriv, WIFI_AP_STATE)) {
-#ifdef CONFIG_8723AU_AP_MODE
-               add_RATid23a(padapter, psta, rssi_level);
-#endif
-       } else
-               rtl8723a_update_ramask(padapter, psta->mac_id, rssi_level);
-}
diff --git a/drivers/staging/rtl8723au/hal/odm.c b/drivers/staging/rtl8723au/hal/odm.c
deleted file mode 100644 (file)
index e279c34..0000000
+++ /dev/null
@@ -1,1732 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-
-#include "odm_precomp.h"
-#include "usb_ops_linux.h"
-
-static const u16 dB_Invert_Table[8][12] = {
-       {1, 1, 1, 2, 2, 2, 2, 3, 3, 3, 4, 4},
-       {4, 5, 6, 6, 7, 8, 9, 10, 11, 13, 14, 16},
-       {18, 20, 22, 25, 28, 32, 35, 40, 45, 50, 56, 63},
-       {71, 79, 89, 100, 112, 126, 141, 158, 178, 200, 224, 251},
-       {282, 316, 355, 398, 447, 501, 562, 631, 708, 794, 891, 1000},
-       {1122, 1259, 1413, 1585, 1778, 1995, 2239, 2512, 2818, 3162, 3548, 3981},
-       {4467, 5012, 5623, 6310, 7079, 7943, 8913, 10000, 11220, 12589, 14125, 15849},
-       {17783, 19953, 22387, 25119, 28184, 31623, 35481, 39811, 44668, 50119, 56234, 65535}
-};
-
-static u32 EDCAParam[HT_IOT_PEER_MAX][3] = {          /*  UL                   DL */
-       {0x5ea42b, 0x5ea42b, 0x5ea42b}, /* 0:unknown AP */
-       {0xa44f, 0x5ea44f, 0x5e431c}, /*  1:realtek AP */
-       {0x5ea42b, 0x5ea42b, 0x5ea42b}, /*  2:unknown AP => realtek_92SE */
-       {0x5ea32b, 0x5ea42b, 0x5e4322}, /*  3:broadcom AP */
-       {0x5ea422, 0x00a44f, 0x00a44f}, /*  4:ralink AP */
-       {0x5ea322, 0x00a630, 0x00a44f}, /*  5:atheros AP */
-       {0x5e4322, 0x5e4322, 0x5e4322},/*  6:cisco AP */
-       {0x5ea44f, 0x00a44f, 0x5ea42b}, /*  8:marvell AP */
-       {0x5ea42b, 0x5ea42b, 0x5ea42b}, /*  10:unknown AP => 92U AP */
-       {0x5ea42b, 0xa630, 0x5e431c}, /*  11:airgocap AP */
-};
-
-/*  EDCA Parameter for AP/ADSL   by Mingzhi 2011-11-22 */
-
-/*  Global var */
-u32 OFDMSwingTable23A[OFDM_TABLE_SIZE_92D] = {
-       0x7f8001fe, /*  0, +6.0dB */
-       0x788001e2, /*  1, +5.5dB */
-       0x71c001c7, /*  2, +5.0dB */
-       0x6b8001ae, /*  3, +4.5dB */
-       0x65400195, /*  4, +4.0dB */
-       0x5fc0017f, /*  5, +3.5dB */
-       0x5a400169, /*  6, +3.0dB */
-       0x55400155, /*  7, +2.5dB */
-       0x50800142, /*  8, +2.0dB */
-       0x4c000130, /*  9, +1.5dB */
-       0x47c0011f, /*  10, +1.0dB */
-       0x43c0010f, /*  11, +0.5dB */
-       0x40000100, /*  12, +0dB */
-       0x3c8000f2, /*  13, -0.5dB */
-       0x390000e4, /*  14, -1.0dB */
-       0x35c000d7, /*  15, -1.5dB */
-       0x32c000cb, /*  16, -2.0dB */
-       0x300000c0, /*  17, -2.5dB */
-       0x2d4000b5, /*  18, -3.0dB */
-       0x2ac000ab, /*  19, -3.5dB */
-       0x288000a2, /*  20, -4.0dB */
-       0x26000098, /*  21, -4.5dB */
-       0x24000090, /*  22, -5.0dB */
-       0x22000088, /*  23, -5.5dB */
-       0x20000080, /*  24, -6.0dB */
-       0x1e400079, /*  25, -6.5dB */
-       0x1c800072, /*  26, -7.0dB */
-       0x1b00006c, /*  27. -7.5dB */
-       0x19800066, /*  28, -8.0dB */
-       0x18000060, /*  29, -8.5dB */
-       0x16c0005b, /*  30, -9.0dB */
-       0x15800056, /*  31, -9.5dB */
-       0x14400051, /*  32, -10.0dB */
-       0x1300004c, /*  33, -10.5dB */
-       0x12000048, /*  34, -11.0dB */
-       0x11000044, /*  35, -11.5dB */
-       0x10000040, /*  36, -12.0dB */
-       0x0f00003c,/*  37, -12.5dB */
-       0x0e400039,/*  38, -13.0dB */
-       0x0d800036,/*  39, -13.5dB */
-       0x0cc00033,/*  40, -14.0dB */
-       0x0c000030,/*  41, -14.5dB */
-       0x0b40002d,/*  42, -15.0dB */
-};
-
-u8 CCKSwingTable_Ch1_Ch1323A[CCK_TABLE_SIZE][8] = {
-       {0x36, 0x35, 0x2e, 0x25, 0x1c, 0x12, 0x09, 0x04}, /*  0, +0dB */
-       {0x33, 0x32, 0x2b, 0x23, 0x1a, 0x11, 0x08, 0x04}, /*  1, -0.5dB */
-       {0x30, 0x2f, 0x29, 0x21, 0x19, 0x10, 0x08, 0x03}, /*  2, -1.0dB */
-       {0x2d, 0x2d, 0x27, 0x1f, 0x18, 0x0f, 0x08, 0x03}, /*  3, -1.5dB */
-       {0x2b, 0x2a, 0x25, 0x1e, 0x16, 0x0e, 0x07, 0x03}, /*  4, -2.0dB */
-       {0x28, 0x28, 0x22, 0x1c, 0x15, 0x0d, 0x07, 0x03}, /*  5, -2.5dB */
-       {0x26, 0x25, 0x21, 0x1b, 0x14, 0x0d, 0x06, 0x03}, /*  6, -3.0dB */
-       {0x24, 0x23, 0x1f, 0x19, 0x13, 0x0c, 0x06, 0x03}, /*  7, -3.5dB */
-       {0x22, 0x21, 0x1d, 0x18, 0x11, 0x0b, 0x06, 0x02}, /*  8, -4.0dB */
-       {0x20, 0x20, 0x1b, 0x16, 0x11, 0x08, 0x05, 0x02}, /*  9, -4.5dB */
-       {0x1f, 0x1e, 0x1a, 0x15, 0x10, 0x0a, 0x05, 0x02}, /*  10, -5.0dB */
-       {0x1d, 0x1c, 0x18, 0x14, 0x0f, 0x0a, 0x05, 0x02}, /*  11, -5.5dB */
-       {0x1b, 0x1a, 0x17, 0x13, 0x0e, 0x09, 0x04, 0x02}, /*  12, -6.0dB */
-       {0x1a, 0x19, 0x16, 0x12, 0x0d, 0x09, 0x04, 0x02}, /*  13, -6.5dB */
-       {0x18, 0x17, 0x15, 0x11, 0x0c, 0x08, 0x04, 0x02}, /*  14, -7.0dB */
-       {0x17, 0x16, 0x13, 0x10, 0x0c, 0x08, 0x04, 0x02}, /*  15, -7.5dB */
-       {0x16, 0x15, 0x12, 0x0f, 0x0b, 0x07, 0x04, 0x01}, /*  16, -8.0dB */
-       {0x14, 0x14, 0x11, 0x0e, 0x0b, 0x07, 0x03, 0x02}, /*  17, -8.5dB */
-       {0x13, 0x13, 0x10, 0x0d, 0x0a, 0x06, 0x03, 0x01}, /*  18, -9.0dB */
-       {0x12, 0x12, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01}, /*  19, -9.5dB */
-       {0x11, 0x11, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01}, /*  20, -10.0dB */
-       {0x10, 0x10, 0x0e, 0x0b, 0x08, 0x05, 0x03, 0x01}, /*  21, -10.5dB */
-       {0x0f, 0x0f, 0x0d, 0x0b, 0x08, 0x05, 0x03, 0x01}, /*  22, -11.0dB */
-       {0x0e, 0x0e, 0x0c, 0x0a, 0x08, 0x05, 0x02, 0x01}, /*  23, -11.5dB */
-       {0x0d, 0x0d, 0x0c, 0x0a, 0x07, 0x05, 0x02, 0x01}, /*  24, -12.0dB */
-       {0x0d, 0x0c, 0x0b, 0x09, 0x07, 0x04, 0x02, 0x01}, /*  25, -12.5dB */
-       {0x0c, 0x0c, 0x0a, 0x09, 0x06, 0x04, 0x02, 0x01}, /*  26, -13.0dB */
-       {0x0b, 0x0b, 0x0a, 0x08, 0x06, 0x04, 0x02, 0x01}, /*  27, -13.5dB */
-       {0x0b, 0x0a, 0x09, 0x08, 0x06, 0x04, 0x02, 0x01}, /*  28, -14.0dB */
-       {0x0a, 0x0a, 0x09, 0x07, 0x05, 0x03, 0x02, 0x01}, /*  29, -14.5dB */
-       {0x0a, 0x09, 0x08, 0x07, 0x05, 0x03, 0x02, 0x01}, /*  30, -15.0dB */
-       {0x09, 0x09, 0x08, 0x06, 0x05, 0x03, 0x01, 0x01}, /*  31, -15.5dB */
-       {0x09, 0x08, 0x07, 0x06, 0x04, 0x03, 0x01, 0x01}        /*  32, -16.0dB */
-};
-
-u8 CCKSwingTable_Ch1423A[CCK_TABLE_SIZE][8] = {
-       {0x36, 0x35, 0x2e, 0x1b, 0x00, 0x00, 0x00, 0x00}, /*  0, +0dB */
-       {0x33, 0x32, 0x2b, 0x19, 0x00, 0x00, 0x00, 0x00}, /*  1, -0.5dB */
-       {0x30, 0x2f, 0x29, 0x18, 0x00, 0x00, 0x00, 0x00}, /*  2, -1.0dB */
-       {0x2d, 0x2d, 0x17, 0x17, 0x00, 0x00, 0x00, 0x00}, /*  3, -1.5dB */
-       {0x2b, 0x2a, 0x25, 0x15, 0x00, 0x00, 0x00, 0x00}, /*  4, -2.0dB */
-       {0x28, 0x28, 0x24, 0x14, 0x00, 0x00, 0x00, 0x00}, /*  5, -2.5dB */
-       {0x26, 0x25, 0x21, 0x13, 0x00, 0x00, 0x00, 0x00}, /*  6, -3.0dB */
-       {0x24, 0x23, 0x1f, 0x12, 0x00, 0x00, 0x00, 0x00}, /*  7, -3.5dB */
-       {0x22, 0x21, 0x1d, 0x11, 0x00, 0x00, 0x00, 0x00}, /*  8, -4.0dB */
-       {0x20, 0x20, 0x1b, 0x10, 0x00, 0x00, 0x00, 0x00}, /*  9, -4.5dB */
-       {0x1f, 0x1e, 0x1a, 0x0f, 0x00, 0x00, 0x00, 0x00}, /*  10, -5.0dB */
-       {0x1d, 0x1c, 0x18, 0x0e, 0x00, 0x00, 0x00, 0x00}, /*  11, -5.5dB */
-       {0x1b, 0x1a, 0x17, 0x0e, 0x00, 0x00, 0x00, 0x00}, /*  12, -6.0dB */
-       {0x1a, 0x19, 0x16, 0x0d, 0x00, 0x00, 0x00, 0x00}, /*  13, -6.5dB */
-       {0x18, 0x17, 0x15, 0x0c, 0x00, 0x00, 0x00, 0x00}, /*  14, -7.0dB */
-       {0x17, 0x16, 0x13, 0x0b, 0x00, 0x00, 0x00, 0x00}, /*  15, -7.5dB */
-       {0x16, 0x15, 0x12, 0x0b, 0x00, 0x00, 0x00, 0x00}, /*  16, -8.0dB */
-       {0x14, 0x14, 0x11, 0x0a, 0x00, 0x00, 0x00, 0x00}, /*  17, -8.5dB */
-       {0x13, 0x13, 0x10, 0x0a, 0x00, 0x00, 0x00, 0x00}, /*  18, -9.0dB */
-       {0x12, 0x12, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00}, /*  19, -9.5dB */
-       {0x11, 0x11, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00}, /*  20, -10.0dB */
-       {0x10, 0x10, 0x0e, 0x08, 0x00, 0x00, 0x00, 0x00}, /*  21, -10.5dB */
-       {0x0f, 0x0f, 0x0d, 0x08, 0x00, 0x00, 0x00, 0x00}, /*  22, -11.0dB */
-       {0x0e, 0x0e, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00}, /*  23, -11.5dB */
-       {0x0d, 0x0d, 0x0c, 0x07, 0x00, 0x00, 0x00, 0x00}, /*  24, -12.0dB */
-       {0x0d, 0x0c, 0x0b, 0x06, 0x00, 0x00, 0x00, 0x00}, /*  25, -12.5dB */
-       {0x0c, 0x0c, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00}, /*  26, -13.0dB */
-       {0x0b, 0x0b, 0x0a, 0x06, 0x00, 0x00, 0x00, 0x00}, /*  27, -13.5dB */
-       {0x0b, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00}, /*  28, -14.0dB */
-       {0x0a, 0x0a, 0x09, 0x05, 0x00, 0x00, 0x00, 0x00}, /*  29, -14.5dB */
-       {0x0a, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00}, /*  30, -15.0dB */
-       {0x09, 0x09, 0x08, 0x05, 0x00, 0x00, 0x00, 0x00}, /*  31, -15.5dB */
-       {0x09, 0x08, 0x07, 0x04, 0x00, 0x00, 0x00, 0x00}        /*  32, -16.0dB */
-};
-
-/*  Local Function predefine. */
-
-/* START------------COMMON INFO RELATED--------------- */
-void odm_CommonInfoSelfInit23a(struct dm_odm_t *pDM_Odm);
-
-static void odm_CommonInfoSelfUpdate(struct hal_data_8723a *pHalData);
-
-void odm_CmnInfoInit_Debug23a(struct dm_odm_t *pDM_Odm);
-
-void odm_CmnInfoUpdate_Debug23a(struct dm_odm_t *pDM_Odm);
-
-/* START---------------DIG--------------------------- */
-void odm_FalseAlarmCounterStatistics23a(struct dm_odm_t *pDM_Odm);
-
-void odm_DIG23aInit(struct dm_odm_t *pDM_Odm);
-
-void odm_DIG23a(struct rtw_adapter *adapter);
-
-void odm_CCKPacketDetectionThresh23a(struct dm_odm_t *pDM_Odm);
-/* END---------------DIG--------------------------- */
-
-/* START-------BB POWER SAVE----------------------- */
-void odm23a_DynBBPSInit(struct dm_odm_t *pDM_Odm);
-
-
-/* END---------BB POWER SAVE----------------------- */
-
-void odm_DynamicTxPower23aInit(struct dm_odm_t *pDM_Odm);
-
-static void odm_RSSIMonitorCheck(struct dm_odm_t *pDM_Odm);
-void odm_DynamicTxPower23a(struct dm_odm_t *pDM_Odm);
-
-static void odm_RefreshRateAdaptiveMask(struct dm_odm_t *pDM_Odm);
-
-void odm_RateAdaptiveMaskInit23a(struct dm_odm_t *pDM_Odm);
-
-static void odm_TXPowerTrackingInit(struct dm_odm_t *pDM_Odm);
-
-static void odm_EdcaTurboCheck23a(struct dm_odm_t *pDM_Odm);
-static void ODM_EdcaTurboInit23a(struct dm_odm_t *pDM_Odm);
-
-#define                RxDefaultAnt1           0x65a9
-#define        RxDefaultAnt2           0x569a
-
-bool odm_StaDefAntSel(struct dm_odm_t *pDM_Odm,
-       u32 OFDM_Ant1_Cnt,
-       u32 OFDM_Ant2_Cnt,
-       u32 CCK_Ant1_Cnt,
-       u32 CCK_Ant2_Cnt,
-       u8 *pDefAnt
-       );
-
-void odm_SetRxIdleAnt(struct dm_odm_t *pDM_Odm,
-       u8 Ant,
-       bool   bDualPath
-);
-
-/* 3 Export Interface */
-
-/*  2011/09/21 MH Add to describe different team necessary resource allocate?? */
-void ODM23a_DMInit(struct dm_odm_t *pDM_Odm)
-{
-       /* For all IC series */
-       odm_CommonInfoSelfInit23a(pDM_Odm);
-       odm_CmnInfoInit_Debug23a(pDM_Odm);
-       odm_DIG23aInit(pDM_Odm);
-       odm_RateAdaptiveMaskInit23a(pDM_Odm);
-
-       odm23a_DynBBPSInit(pDM_Odm);
-       odm_DynamicTxPower23aInit(pDM_Odm);
-       odm_TXPowerTrackingInit(pDM_Odm);
-       ODM_EdcaTurboInit23a(pDM_Odm);
-}
-
-/*  2011/09/20 MH This is the entry pointer for all team to execute HW out source DM. */
-/*  You can not add any dummy function here, be care, you can only use DM structure */
-/*  to perform any new ODM_DM. */
-void ODM_DMWatchdog23a(struct rtw_adapter *adapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(adapter);
-       struct dm_odm_t *pDM_Odm = &pHalData->odmpriv;
-       struct pwrctrl_priv *pwrctrlpriv = &adapter->pwrctrlpriv;
-
-       /* 2012.05.03 Luke: For all IC series */
-       odm_CmnInfoUpdate_Debug23a(pDM_Odm);
-       odm_CommonInfoSelfUpdate(pHalData);
-       odm_FalseAlarmCounterStatistics23a(pDM_Odm);
-       odm_RSSIMonitorCheck(pDM_Odm);
-
-       /* 8723A or 8189ES platform */
-       /* NeilChen--2012--08--24-- */
-       /* Fix Leave LPS issue */
-       if ((pDM_Odm->Adapter->pwrctrlpriv.pwr_mode != PS_MODE_ACTIVE) &&/*  in LPS mode */
-           (pDM_Odm->SupportICType & ODM_RTL8723A)) {
-                       ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, ("----Step1: odm_DIG23a is in LPS mode\n"));
-                       ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, ("---Step2: 8723AS is in LPS mode\n"));
-                       odm_DIG23abyRSSI_LPS(pDM_Odm);
-       } else {
-               odm_DIG23a(adapter);
-       }
-
-       odm_CCKPacketDetectionThresh23a(pDM_Odm);
-
-       if (pwrctrlpriv->bpower_saving)
-               return;
-
-       odm_RefreshRateAdaptiveMask(pDM_Odm);
-
-
-       odm_EdcaTurboCheck23a(pDM_Odm);
-}
-
-/*  */
-/*  Init /.. Fixed HW value. Only init time. */
-/*  */
-void ODM_CmnInfoInit23a(struct dm_odm_t *pDM_Odm,
-               enum odm_cmninfo CmnInfo,
-               u32 Value
-       )
-{
-       /* ODM_RT_TRACE(pDM_Odm,); */
-
-       /*  */
-       /*  This section is used for init value */
-       /*  */
-       switch  (CmnInfo) {
-       /*  Fixed ODM value. */
-       case    ODM_CMNINFO_MP_TEST_CHIP:
-               pDM_Odm->bIsMPChip = (u8)Value;
-               break;
-       case    ODM_CMNINFO_IC_TYPE:
-               pDM_Odm->SupportICType = Value;
-               break;
-       case    ODM_CMNINFO_CUT_VER:
-               pDM_Odm->CutVersion = (u8)Value;
-               break;
-       case    ODM_CMNINFO_FAB_VER:
-               pDM_Odm->FabVersion = (u8)Value;
-               break;
-       case    ODM_CMNINFO_BOARD_TYPE:
-               pDM_Odm->BoardType = (u8)Value;
-               break;
-       case    ODM_CMNINFO_EXT_LNA:
-               pDM_Odm->ExtLNA = (u8)Value;
-               break;
-       case    ODM_CMNINFO_EXT_PA:
-               pDM_Odm->ExtPA = (u8)Value;
-               break;
-       case    ODM_CMNINFO_EXT_TRSW:
-               pDM_Odm->ExtTRSW = (u8)Value;
-               break;
-       case    ODM_CMNINFO_BINHCT_TEST:
-               pDM_Odm->bInHctTest = (bool)Value;
-               break;
-       case    ODM_CMNINFO_BWIFI_TEST:
-               pDM_Odm->bWIFITest = (bool)Value;
-               break;
-       case    ODM_CMNINFO_SMART_CONCURRENT:
-               pDM_Odm->bDualMacSmartConcurrent = (bool)Value;
-               break;
-       /* To remove the compiler warning, must add an empty default statement to handle the other values. */
-       default:
-               /* do nothing */
-               break;
-       }
-}
-
-void ODM_CmnInfoPtrArrayHook23a(struct dm_odm_t *pDM_Odm, enum odm_cmninfo CmnInfo,
-                               u16 Index, void *pValue)
-{
-       /*  Hook call by reference pointer. */
-       switch  (CmnInfo) {
-       /*  Dynamic call by reference pointer. */
-       case    ODM_CMNINFO_STA_STATUS:
-               pDM_Odm->pODM_StaInfo[Index] = (struct sta_info *)pValue;
-               break;
-       /* To remove the compiler warning, must add an empty default statement to handle the other values. */
-       default:
-               /* do nothing */
-               break;
-       }
-}
-
-/*  Update Band/CHannel/.. The values are dynamic but non-per-packet. */
-void ODM_CmnInfoUpdate23a(struct dm_odm_t *pDM_Odm, u32 CmnInfo, u64 Value)
-{
-       /*  This init variable may be changed in run time. */
-       switch  (CmnInfo) {
-       case    ODM_CMNINFO_WIFI_DIRECT:
-               pDM_Odm->bWIFI_Direct = (bool)Value;
-               break;
-       case    ODM_CMNINFO_WIFI_DISPLAY:
-               pDM_Odm->bWIFI_Display = (bool)Value;
-               break;
-       case    ODM_CMNINFO_LINK:
-               pDM_Odm->bLinked = (bool)Value;
-               break;
-       case    ODM_CMNINFO_RSSI_MIN:
-               pDM_Odm->RSSI_Min = (u8)Value;
-               break;
-       case    ODM_CMNINFO_DBG_COMP:
-               pDM_Odm->DebugComponents = Value;
-               break;
-       case    ODM_CMNINFO_DBG_LEVEL:
-               pDM_Odm->DebugLevel = (u32)Value;
-               break;
-       case    ODM_CMNINFO_RA_THRESHOLD_HIGH:
-               pDM_Odm->RateAdaptive.HighRSSIThresh = (u8)Value;
-               break;
-       case    ODM_CMNINFO_RA_THRESHOLD_LOW:
-               pDM_Odm->RateAdaptive.LowRSSIThresh = (u8)Value;
-               break;
-       }
-
-}
-
-void odm_CommonInfoSelfInit23a(struct dm_odm_t *pDM_Odm)
-{
-       u32 val32;
-
-       val32 = rtl8723au_read32(pDM_Odm->Adapter, rFPGA0_XA_HSSIParameter2);
-       if (val32 & BIT(9))
-               pDM_Odm->bCckHighPower = true;
-       else
-               pDM_Odm->bCckHighPower = false;
-
-       pDM_Odm->RFPathRxEnable =
-               rtl8723au_read32(pDM_Odm->Adapter, rOFDM0_TRxPathEnable) & 0x0F;
-
-       ODM_InitDebugSetting23a(pDM_Odm);
-}
-
-static void odm_CommonInfoSelfUpdate(struct hal_data_8723a *pHalData)
-{
-       struct dm_odm_t *pDM_Odm = &pHalData->odmpriv;
-       struct sta_info *pEntry;
-       u8 EntryCnt = 0;
-       u8 i;
-
-       for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++) {
-               pEntry = pDM_Odm->pODM_StaInfo[i];
-               if (pEntry)
-                       EntryCnt++;
-       }
-       if (EntryCnt == 1)
-               pDM_Odm->bOneEntryOnly = true;
-       else
-               pDM_Odm->bOneEntryOnly = false;
-}
-
-void odm_CmnInfoInit_Debug23a(struct dm_odm_t *pDM_Odm)
-{
-       ODM_RT_TRACE(pDM_Odm, ODM_COMP_COMMON, ODM_DBG_LOUD, ("odm_CmnInfoInit_Debug23a ==>\n"));
-       ODM_RT_TRACE(pDM_Odm, ODM_COMP_COMMON, ODM_DBG_LOUD, ("SupportAbility = 0x%x\n", pDM_Odm->SupportAbility));
-       ODM_RT_TRACE(pDM_Odm, ODM_COMP_COMMON, ODM_DBG_LOUD, ("SupportICType = 0x%x\n", pDM_Odm->SupportICType));
-       ODM_RT_TRACE(pDM_Odm, ODM_COMP_COMMON, ODM_DBG_LOUD, ("CutVersion =%d\n", pDM_Odm->CutVersion));
-       ODM_RT_TRACE(pDM_Odm, ODM_COMP_COMMON, ODM_DBG_LOUD, ("FabVersion =%d\n", pDM_Odm->FabVersion));
-       ODM_RT_TRACE(pDM_Odm, ODM_COMP_COMMON, ODM_DBG_LOUD, ("BoardType =%d\n", pDM_Odm->BoardType));
-       ODM_RT_TRACE(pDM_Odm, ODM_COMP_COMMON, ODM_DBG_LOUD, ("ExtLNA =%d\n", pDM_Odm->ExtLNA));
-       ODM_RT_TRACE(pDM_Odm, ODM_COMP_COMMON, ODM_DBG_LOUD, ("ExtPA =%d\n", pDM_Odm->ExtPA));
-       ODM_RT_TRACE(pDM_Odm, ODM_COMP_COMMON, ODM_DBG_LOUD, ("ExtTRSW =%d\n", pDM_Odm->ExtTRSW));
-       ODM_RT_TRACE(pDM_Odm, ODM_COMP_COMMON, ODM_DBG_LOUD, ("bInHctTest =%d\n", pDM_Odm->bInHctTest));
-       ODM_RT_TRACE(pDM_Odm, ODM_COMP_COMMON, ODM_DBG_LOUD, ("bWIFITest =%d\n", pDM_Odm->bWIFITest));
-       ODM_RT_TRACE(pDM_Odm, ODM_COMP_COMMON, ODM_DBG_LOUD, ("bDualMacSmartConcurrent =%d\n", pDM_Odm->bDualMacSmartConcurrent));
-
-}
-
-void odm_CmnInfoUpdate_Debug23a(struct dm_odm_t *pDM_Odm)
-{
-       ODM_RT_TRACE(pDM_Odm, ODM_COMP_COMMON, ODM_DBG_LOUD, ("odm_CmnInfoUpdate_Debug23a ==>\n"));
-       ODM_RT_TRACE(pDM_Odm, ODM_COMP_COMMON, ODM_DBG_LOUD, ("bWIFI_Direct =%d\n", pDM_Odm->bWIFI_Direct));
-       ODM_RT_TRACE(pDM_Odm, ODM_COMP_COMMON, ODM_DBG_LOUD, ("bWIFI_Display =%d\n", pDM_Odm->bWIFI_Display));
-       ODM_RT_TRACE(pDM_Odm, ODM_COMP_COMMON, ODM_DBG_LOUD, ("bLinked =%d\n", pDM_Odm->bLinked));
-       ODM_RT_TRACE(pDM_Odm, ODM_COMP_COMMON, ODM_DBG_LOUD, ("RSSI_Min =%d\n", pDM_Odm->RSSI_Min));
-}
-
-void ODM_Write_DIG23a(struct dm_odm_t *pDM_Odm,        u8 CurrentIGI)
-{
-       struct rtw_adapter *adapter = pDM_Odm->Adapter;
-       struct dig_t *pDM_DigTable = &pDM_Odm->DM_DigTable;
-       u32 val32;
-
-       if (pDM_DigTable->CurIGValue != CurrentIGI) {
-               val32 = rtl8723au_read32(adapter, ODM_REG_IGI_A_11N);
-               val32 &= ~ODM_BIT_IGI_11N;
-               val32 |= CurrentIGI;
-               rtl8723au_write32(adapter, ODM_REG_IGI_A_11N, val32);
-               ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD,
-                            ("CurrentIGI(0x%02x). \n", CurrentIGI));
-               pDM_DigTable->CurIGValue = CurrentIGI;
-       }
-       ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD,
-                    ("ODM_Write_DIG23a():CurrentIGI = 0x%x \n", CurrentIGI));
-}
-
-/* Need LPS mode for CE platform --2012--08--24--- */
-/* 8723AS/8189ES */
-void odm_DIG23abyRSSI_LPS(struct dm_odm_t *pDM_Odm)
-{
-       struct rtw_adapter *pAdapter = pDM_Odm->Adapter;
-       struct false_alarm_stats *pFalseAlmCnt = &pDM_Odm->FalseAlmCnt;
-       u8 RSSI_Lower = DM_DIG_MIN_NIC;   /* 0x1E or 0x1C */
-       u8 bFwCurrentInPSMode = false;
-       u8 CurrentIGI = pDM_Odm->RSSI_Min;
-
-       if (!(pDM_Odm->SupportICType & ODM_RTL8723A))
-               return;
-
-       CurrentIGI = CurrentIGI+RSSI_OFFSET_DIG;
-       bFwCurrentInPSMode = pAdapter->pwrctrlpriv.bFwCurrentInPSMode;
-
-       /*  Using FW PS mode to make IGI */
-       if (bFwCurrentInPSMode) {
-               ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD,
-                            ("---Neil---odm_DIG23a is in LPS mode\n"));
-               /* Adjust by  FA in LPS MODE */
-               if (pFalseAlmCnt->Cnt_all > DM_DIG_FA_TH2_LPS)
-                       CurrentIGI = CurrentIGI+2;
-               else if (pFalseAlmCnt->Cnt_all > DM_DIG_FA_TH1_LPS)
-                       CurrentIGI = CurrentIGI+1;
-               else if (pFalseAlmCnt->Cnt_all < DM_DIG_FA_TH0_LPS)
-                       CurrentIGI = CurrentIGI-1;
-       } else {
-               CurrentIGI = RSSI_Lower;
-       }
-
-       /* Lower bound checking */
-
-       /* RSSI Lower bound check */
-       if ((pDM_Odm->RSSI_Min-10) > DM_DIG_MIN_NIC)
-               RSSI_Lower = (pDM_Odm->RSSI_Min-10);
-       else
-               RSSI_Lower = DM_DIG_MIN_NIC;
-
-       /* Upper and Lower Bound checking */
-        if (CurrentIGI > DM_DIG_MAX_NIC)
-               CurrentIGI = DM_DIG_MAX_NIC;
-        else if (CurrentIGI < RSSI_Lower)
-               CurrentIGI = RSSI_Lower;
-
-       ODM_Write_DIG23a(pDM_Odm, CurrentIGI);
-}
-
-void odm_DIG23aInit(struct dm_odm_t *pDM_Odm)
-{
-       struct dig_t *pDM_DigTable = &pDM_Odm->DM_DigTable;
-       u32 val32;
-
-       val32 = rtl8723au_read32(pDM_Odm->Adapter, ODM_REG_IGI_A_11N);
-       pDM_DigTable->CurIGValue = val32 & ODM_BIT_IGI_11N;
-
-       pDM_DigTable->RssiLowThresh     = DM_DIG_THRESH_LOW;
-       pDM_DigTable->RssiHighThresh    = DM_DIG_THRESH_HIGH;
-       pDM_DigTable->FALowThresh       = DM_FALSEALARM_THRESH_LOW;
-       pDM_DigTable->FAHighThresh      = DM_FALSEALARM_THRESH_HIGH;
-       if (pDM_Odm->BoardType == ODM_BOARD_HIGHPWR) {
-               pDM_DigTable->rx_gain_range_max = DM_DIG_MAX_NIC;
-               pDM_DigTable->rx_gain_range_min = DM_DIG_MIN_NIC;
-       } else {
-               pDM_DigTable->rx_gain_range_max = DM_DIG_MAX_NIC;
-               pDM_DigTable->rx_gain_range_min = DM_DIG_MIN_NIC;
-       }
-       pDM_DigTable->BackoffVal = DM_DIG_BACKOFF_DEFAULT;
-       pDM_DigTable->BackoffVal_range_max = DM_DIG_BACKOFF_MAX;
-       pDM_DigTable->BackoffVal_range_min = DM_DIG_BACKOFF_MIN;
-       pDM_DigTable->PreCCK_CCAThres = 0xFF;
-       pDM_DigTable->CurCCK_CCAThres = 0x83;
-       pDM_DigTable->ForbiddenIGI = DM_DIG_MIN_NIC;
-       pDM_DigTable->LargeFAHit = 0;
-       pDM_DigTable->Recover_cnt = 0;
-       pDM_DigTable->DIG_Dynamic_MIN_0 = DM_DIG_MIN_NIC;
-       pDM_DigTable->DIG_Dynamic_MIN_1 = DM_DIG_MIN_NIC;
-       pDM_DigTable->bMediaConnect_0 = false;
-       pDM_DigTable->bMediaConnect_1 = false;
-}
-
-void odm_DIG23a(struct rtw_adapter *adapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(adapter);
-       struct dm_odm_t *pDM_Odm = &pHalData->odmpriv;
-       struct dig_t *pDM_DigTable = &pDM_Odm->DM_DigTable;
-       struct false_alarm_stats *pFalseAlmCnt = &pDM_Odm->FalseAlmCnt;
-       u8 DIG_Dynamic_MIN;
-       u8 DIG_MaxOfMin;
-       bool FirstConnect, FirstDisConnect;
-       u8 dm_dig_max, dm_dig_min;
-       u8 CurrentIGI = pDM_DigTable->CurIGValue;
-
-       ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD,
-                    ("odm_DIG23a() ==>\n"));
-       if (adapter->mlmepriv.bScanInProcess) {
-               ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD,
-                            ("odm_DIG23a() Return: In Scan Progress \n"));
-               return;
-       }
-
-       DIG_Dynamic_MIN = pDM_DigTable->DIG_Dynamic_MIN_0;
-       FirstConnect = (pDM_Odm->bLinked) && (!pDM_DigTable->bMediaConnect_0);
-       FirstDisConnect = (!pDM_Odm->bLinked) &&
-               (pDM_DigTable->bMediaConnect_0);
-
-       /* 1 Boundary Decision */
-       if ((pDM_Odm->SupportICType & ODM_RTL8723A) &&
-           (pDM_Odm->BoardType == ODM_BOARD_HIGHPWR || pDM_Odm->ExtLNA)) {
-               dm_dig_max = DM_DIG_MAX_NIC_HP;
-               dm_dig_min = DM_DIG_MIN_NIC_HP;
-               DIG_MaxOfMin = DM_DIG_MAX_AP_HP;
-       } else {
-               dm_dig_max = DM_DIG_MAX_NIC;
-               dm_dig_min = DM_DIG_MIN_NIC;
-               DIG_MaxOfMin = DM_DIG_MAX_AP;
-       }
-
-       if (pDM_Odm->bLinked) {
-             /* 2 8723A Series, offset need to be 10 */
-               if (pDM_Odm->SupportICType == ODM_RTL8723A) {
-                       /* 2 Upper Bound */
-                       if ((pDM_Odm->RSSI_Min + 10) > DM_DIG_MAX_NIC)
-                               pDM_DigTable->rx_gain_range_max = DM_DIG_MAX_NIC;
-                       else if ((pDM_Odm->RSSI_Min + 10) < DM_DIG_MIN_NIC)
-                               pDM_DigTable->rx_gain_range_max = DM_DIG_MIN_NIC;
-                       else
-                               pDM_DigTable->rx_gain_range_max = pDM_Odm->RSSI_Min + 10;
-
-                       /* 2 If BT is Concurrent, need to set Lower Bound */
-                       DIG_Dynamic_MIN = DM_DIG_MIN_NIC;
-               } else {
-                       /* 2 Modify DIG upper bound */
-                       if ((pDM_Odm->RSSI_Min + 20) > dm_dig_max)
-                               pDM_DigTable->rx_gain_range_max = dm_dig_max;
-                       else if ((pDM_Odm->RSSI_Min + 20) < dm_dig_min)
-                               pDM_DigTable->rx_gain_range_max = dm_dig_min;
-                       else
-                               pDM_DigTable->rx_gain_range_max = pDM_Odm->RSSI_Min + 20;
-
-                       /* 2 Modify DIG lower bound */
-                       if (pDM_Odm->bOneEntryOnly) {
-                               if (pDM_Odm->RSSI_Min < dm_dig_min)
-                                       DIG_Dynamic_MIN = dm_dig_min;
-                               else if (pDM_Odm->RSSI_Min > DIG_MaxOfMin)
-                                       DIG_Dynamic_MIN = DIG_MaxOfMin;
-                               else
-                                       DIG_Dynamic_MIN = pDM_Odm->RSSI_Min;
-                               ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD,
-                                            ("odm_DIG23a() : bOneEntryOnly = true,  DIG_Dynamic_MIN = 0x%x\n",
-                                            DIG_Dynamic_MIN));
-                               ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD,
-                                            ("odm_DIG23a() : pDM_Odm->RSSI_Min =%d\n",
-                                            pDM_Odm->RSSI_Min));
-                       } else {
-                               DIG_Dynamic_MIN = dm_dig_min;
-                       }
-               }
-       } else {
-               pDM_DigTable->rx_gain_range_max = dm_dig_max;
-               DIG_Dynamic_MIN = dm_dig_min;
-               ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG23a() : No Link\n"));
-       }
-
-       /* 1 Modify DIG lower bound, deal with abnormally large false alarm */
-       if (pFalseAlmCnt->Cnt_all > 10000) {
-               ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD,
-                            ("dm_DIG(): Abnornally false alarm case. \n"));
-
-               if (pDM_DigTable->LargeFAHit != 3)
-                       pDM_DigTable->LargeFAHit++;
-               if (pDM_DigTable->ForbiddenIGI < CurrentIGI) {
-                       pDM_DigTable->ForbiddenIGI = CurrentIGI;
-                       pDM_DigTable->LargeFAHit = 1;
-               }
-
-               if (pDM_DigTable->LargeFAHit >= 3) {
-                       if ((pDM_DigTable->ForbiddenIGI+1) > pDM_DigTable->rx_gain_range_max)
-                               pDM_DigTable->rx_gain_range_min = pDM_DigTable->rx_gain_range_max;
-                       else
-                               pDM_DigTable->rx_gain_range_min = (pDM_DigTable->ForbiddenIGI + 1);
-                       pDM_DigTable->Recover_cnt = 3600; /* 3600 = 2hr */
-               }
-       } else {
-               /* Recovery mechanism for IGI lower bound */
-               if (pDM_DigTable->Recover_cnt != 0) {
-                       pDM_DigTable->Recover_cnt--;
-               } else {
-                       if (pDM_DigTable->LargeFAHit < 3) {
-                               if ((pDM_DigTable->ForbiddenIGI - 1) < DIG_Dynamic_MIN) {
-                                       pDM_DigTable->ForbiddenIGI = DIG_Dynamic_MIN; /* DM_DIG_MIN; */
-                                       pDM_DigTable->rx_gain_range_min = DIG_Dynamic_MIN; /* DM_DIG_MIN; */
-                                       ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD,
-                                                    ("odm_DIG23a(): Normal Case: At Lower Bound\n"));
-                               } else {
-                                       pDM_DigTable->ForbiddenIGI--;
-                                       pDM_DigTable->rx_gain_range_min = (pDM_DigTable->ForbiddenIGI + 1);
-                                       ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD,
-                                                    ("odm_DIG23a(): Normal Case: Approach Lower Bound\n"));
-                               }
-                       } else {
-                               pDM_DigTable->LargeFAHit = 0;
-                       }
-               }
-       }
-       ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG23a(): pDM_DigTable->LargeFAHit =%d\n", pDM_DigTable->LargeFAHit));
-
-       /* 1 Adjust initial gain by false alarm */
-       if (pDM_Odm->bLinked) {
-               ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG23a(): DIG AfterLink\n"));
-               if (FirstConnect) {
-                       CurrentIGI = pDM_Odm->RSSI_Min;
-                       ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, ("DIG: First Connect\n"));
-               } else {
-                       if (pFalseAlmCnt->Cnt_all > DM_DIG_FA_TH2)
-                               CurrentIGI = CurrentIGI + 4;/* pDM_DigTable->CurIGValue = pDM_DigTable->PreIGValue+2; */
-                       else if (pFalseAlmCnt->Cnt_all > DM_DIG_FA_TH1)
-                               CurrentIGI = CurrentIGI + 2;/* pDM_DigTable->CurIGValue = pDM_DigTable->PreIGValue+1; */
-                       else if (pFalseAlmCnt->Cnt_all < DM_DIG_FA_TH0)
-                               CurrentIGI = CurrentIGI - 2;/* pDM_DigTable->CurIGValue = pDM_DigTable->PreIGValue-1; */
-               }
-       } else {
-               ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG23a(): DIG BeforeLink\n"));
-               if (FirstDisConnect) {
-                       CurrentIGI = pDM_DigTable->rx_gain_range_min;
-                       ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG23a(): First DisConnect \n"));
-               } else {
-                       /* 2012.03.30 LukeLee: enable DIG before link but with very high thresholds */
-                       if (pFalseAlmCnt->Cnt_all > 10000)
-                               CurrentIGI = CurrentIGI + 2;/* pDM_DigTable->CurIGValue = pDM_DigTable->PreIGValue+2; */
-                       else if (pFalseAlmCnt->Cnt_all > 8000)
-                               CurrentIGI = CurrentIGI + 1;/* pDM_DigTable->CurIGValue = pDM_DigTable->PreIGValue+1; */
-                       else if (pFalseAlmCnt->Cnt_all < 500)
-                               CurrentIGI = CurrentIGI - 1;/* pDM_DigTable->CurIGValue = pDM_DigTable->PreIGValue-1; */
-                       ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG23a(): England DIG \n"));
-               }
-       }
-       ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG23a(): DIG End Adjust IGI\n"));
-       /* 1 Check initial gain by upper/lower bound */
-       if (CurrentIGI > pDM_DigTable->rx_gain_range_max)
-               CurrentIGI = pDM_DigTable->rx_gain_range_max;
-       if (CurrentIGI < pDM_DigTable->rx_gain_range_min)
-               CurrentIGI = pDM_DigTable->rx_gain_range_min;
-
-       ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG23a(): rx_gain_range_max = 0x%x, rx_gain_range_min = 0x%x\n",
-               pDM_DigTable->rx_gain_range_max, pDM_DigTable->rx_gain_range_min));
-       ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG23a(): TotalFA =%d\n", pFalseAlmCnt->Cnt_all));
-       ODM_RT_TRACE(pDM_Odm, ODM_COMP_DIG, ODM_DBG_LOUD, ("odm_DIG23a(): CurIGValue = 0x%x\n", CurrentIGI));
-
-       /* 2 High power RSSI threshold */
-
-       ODM_Write_DIG23a(pDM_Odm, CurrentIGI);/* ODM_Write_DIG23a(pDM_Odm, pDM_DigTable->CurIGValue); */
-       pDM_DigTable->bMediaConnect_0 = pDM_Odm->bLinked;
-       pDM_DigTable->DIG_Dynamic_MIN_0 = DIG_Dynamic_MIN;
-}
-
-/* 3 ============================================================ */
-/* 3 FASLE ALARM CHECK */
-/* 3 ============================================================ */
-
-void odm_FalseAlarmCounterStatistics23a(struct dm_odm_t *pDM_Odm)
-{
-       struct rtw_adapter *adapter = pDM_Odm->Adapter;
-       struct false_alarm_stats *FalseAlmCnt = &pDM_Odm->FalseAlmCnt;
-       u32 ret_value, val32;
-
-       /* hold ofdm counter */
-       /* hold page C counter */
-       val32 = rtl8723au_read32(adapter, ODM_REG_OFDM_FA_HOLDC_11N);
-       val32 |= BIT(31);
-       rtl8723au_write32(adapter, ODM_REG_OFDM_FA_HOLDC_11N, val32);
-       /* hold page D counter */
-       val32 = rtl8723au_read32(adapter, ODM_REG_OFDM_FA_RSTD_11N);
-       val32 |= BIT(31);
-       rtl8723au_write32(adapter, ODM_REG_OFDM_FA_RSTD_11N, val32);
-       ret_value = rtl8723au_read32(adapter, ODM_REG_OFDM_FA_TYPE1_11N);
-       FalseAlmCnt->Cnt_Fast_Fsync = (ret_value&0xffff);
-       FalseAlmCnt->Cnt_SB_Search_fail = (ret_value & 0xffff0000)>>16;
-       ret_value = rtl8723au_read32(adapter, ODM_REG_OFDM_FA_TYPE2_11N);
-       FalseAlmCnt->Cnt_OFDM_CCA = (ret_value&0xffff);
-       FalseAlmCnt->Cnt_Parity_Fail = (ret_value & 0xffff0000)>>16;
-       ret_value = rtl8723au_read32(adapter, ODM_REG_OFDM_FA_TYPE3_11N);
-       FalseAlmCnt->Cnt_Rate_Illegal = (ret_value&0xffff);
-       FalseAlmCnt->Cnt_Crc8_fail = (ret_value & 0xffff0000)>>16;
-       ret_value = rtl8723au_read32(adapter, ODM_REG_OFDM_FA_TYPE4_11N);
-       FalseAlmCnt->Cnt_Mcs_fail = (ret_value&0xffff);
-
-       FalseAlmCnt->Cnt_Ofdm_fail = FalseAlmCnt->Cnt_Parity_Fail +
-               FalseAlmCnt->Cnt_Rate_Illegal +
-               FalseAlmCnt->Cnt_Crc8_fail +
-               FalseAlmCnt->Cnt_Mcs_fail +
-               FalseAlmCnt->Cnt_Fast_Fsync +
-               FalseAlmCnt->Cnt_SB_Search_fail;
-       /* hold cck counter */
-       val32 = rtl8723au_read32(adapter, ODM_REG_CCK_FA_RST_11N);
-       val32 |= (BIT(12) | BIT(14));
-       rtl8723au_write32(adapter, ODM_REG_CCK_FA_RST_11N, val32);
-
-       ret_value = rtl8723au_read32(adapter, ODM_REG_CCK_FA_LSB_11N) & 0xff;
-       FalseAlmCnt->Cnt_Cck_fail = ret_value;
-       ret_value = rtl8723au_read32(adapter, ODM_REG_CCK_FA_MSB_11N) >> 16;
-       FalseAlmCnt->Cnt_Cck_fail += (ret_value & 0xff00);
-
-       ret_value = rtl8723au_read32(adapter, ODM_REG_CCK_CCA_CNT_11N);
-       FalseAlmCnt->Cnt_CCK_CCA =
-               ((ret_value&0xFF)<<8) | ((ret_value&0xFF00)>>8);
-
-       FalseAlmCnt->Cnt_all = (FalseAlmCnt->Cnt_Fast_Fsync +
-                               FalseAlmCnt->Cnt_SB_Search_fail +
-                               FalseAlmCnt->Cnt_Parity_Fail +
-                               FalseAlmCnt->Cnt_Rate_Illegal +
-                               FalseAlmCnt->Cnt_Crc8_fail +
-                               FalseAlmCnt->Cnt_Mcs_fail +
-                               FalseAlmCnt->Cnt_Cck_fail);
-
-       FalseAlmCnt->Cnt_CCA_all =
-               FalseAlmCnt->Cnt_OFDM_CCA + FalseAlmCnt->Cnt_CCK_CCA;
-
-       if (pDM_Odm->SupportICType >= ODM_RTL8723A) {
-               /* reset false alarm counter registers */
-               val32 = rtl8723au_read32(adapter, ODM_REG_OFDM_FA_RSTC_11N);
-               val32 |= BIT(31);
-               rtl8723au_write32(adapter, ODM_REG_OFDM_FA_RSTC_11N, val32);
-               val32 = rtl8723au_read32(adapter, ODM_REG_OFDM_FA_RSTC_11N);
-               val32 &= ~BIT(31);
-               rtl8723au_write32(adapter, ODM_REG_OFDM_FA_RSTC_11N, val32);
-
-               val32 = rtl8723au_read32(adapter, ODM_REG_OFDM_FA_RSTD_11N);
-               val32 |= BIT(27);
-               rtl8723au_write32(adapter, ODM_REG_OFDM_FA_RSTD_11N, val32);
-               val32 = rtl8723au_read32(adapter, ODM_REG_OFDM_FA_RSTD_11N);
-               val32 &= ~BIT(27);
-               rtl8723au_write32(adapter, ODM_REG_OFDM_FA_RSTD_11N, val32);
-
-               /* update ofdm counter */
-                /* update page C counter */
-               val32 = rtl8723au_read32(adapter, ODM_REG_OFDM_FA_HOLDC_11N);
-               val32 &= ~BIT(31);
-               rtl8723au_write32(adapter, ODM_REG_OFDM_FA_HOLDC_11N, val32);
-
-                /* update page D counter */
-               val32 = rtl8723au_read32(adapter, ODM_REG_OFDM_FA_RSTD_11N);
-               val32 &= ~BIT(31);
-               rtl8723au_write32(adapter, ODM_REG_OFDM_FA_RSTD_11N, val32);
-
-               /* reset CCK CCA counter */
-               val32 = rtl8723au_read32(adapter, ODM_REG_CCK_FA_RST_11N);
-               val32 &= ~(BIT(12) | BIT(13) | BIT(14) | BIT(15));
-               rtl8723au_write32(adapter, ODM_REG_CCK_FA_RST_11N, val32);
-
-               val32 = rtl8723au_read32(adapter, ODM_REG_CCK_FA_RST_11N);
-               val32 |= (BIT(13) | BIT(15));
-               rtl8723au_write32(adapter, ODM_REG_CCK_FA_RST_11N, val32);
-       }
-
-       ODM_RT_TRACE(pDM_Odm, ODM_COMP_FA_CNT, ODM_DBG_LOUD,
-                    ("Enter odm_FalseAlarmCounterStatistics23a\n"));
-       ODM_RT_TRACE(pDM_Odm, ODM_COMP_FA_CNT, ODM_DBG_LOUD,
-                    ("Cnt_Fast_Fsync =%d, Cnt_SB_Search_fail =%d\n",
-                     FalseAlmCnt->Cnt_Fast_Fsync,
-                     FalseAlmCnt->Cnt_SB_Search_fail));
-       ODM_RT_TRACE(pDM_Odm, ODM_COMP_FA_CNT, ODM_DBG_LOUD,
-                    ("Cnt_Parity_Fail =%d, Cnt_Rate_Illegal =%d\n",
-                     FalseAlmCnt->Cnt_Parity_Fail,
-                     FalseAlmCnt->Cnt_Rate_Illegal));
-       ODM_RT_TRACE(pDM_Odm, ODM_COMP_FA_CNT, ODM_DBG_LOUD,
-                    ("Cnt_Crc8_fail =%d, Cnt_Mcs_fail =%d\n",
-                     FalseAlmCnt->Cnt_Crc8_fail, FalseAlmCnt->Cnt_Mcs_fail));
-
-       ODM_RT_TRACE(pDM_Odm, ODM_COMP_FA_CNT, ODM_DBG_LOUD,
-                    ("Cnt_Cck_fail =%d\n", FalseAlmCnt->Cnt_Cck_fail));
-       ODM_RT_TRACE(pDM_Odm, ODM_COMP_FA_CNT, ODM_DBG_LOUD,
-                    ("Cnt_Ofdm_fail =%d\n", FalseAlmCnt->Cnt_Ofdm_fail));
-       ODM_RT_TRACE(pDM_Odm, ODM_COMP_FA_CNT, ODM_DBG_LOUD,
-                    ("Total False Alarm =%d\n", FalseAlmCnt->Cnt_all));
-}
-
-/* 3 ============================================================ */
-/* 3 CCK Packet Detect Threshold */
-/* 3 ============================================================ */
-
-void odm_CCKPacketDetectionThresh23a(struct dm_odm_t *pDM_Odm)
-{
-       struct false_alarm_stats *FalseAlmCnt = &pDM_Odm->FalseAlmCnt;
-       u8 CurCCK_CCAThres;
-
-       if (pDM_Odm->ExtLNA)
-               return;
-
-       if (pDM_Odm->bLinked) {
-               if (pDM_Odm->RSSI_Min > 25) {
-                       CurCCK_CCAThres = 0xcd;
-               } else if (pDM_Odm->RSSI_Min <= 25 && pDM_Odm->RSSI_Min > 10) {
-                       CurCCK_CCAThres = 0x83;
-               } else {
-                       if (FalseAlmCnt->Cnt_Cck_fail > 1000)
-                               CurCCK_CCAThres = 0x83;
-                       else
-                               CurCCK_CCAThres = 0x40;
-               }
-       } else {
-               if (FalseAlmCnt->Cnt_Cck_fail > 1000)
-                       CurCCK_CCAThres = 0x83;
-               else
-                       CurCCK_CCAThres = 0x40;
-       }
-
-       ODM_Write_CCK_CCA_Thres23a(pDM_Odm, CurCCK_CCAThres);
-}
-
-void ODM_Write_CCK_CCA_Thres23a(struct dm_odm_t *pDM_Odm, u8 CurCCK_CCAThres)
-{
-       struct dig_t *pDM_DigTable = &pDM_Odm->DM_DigTable;
-
-       if (pDM_DigTable->CurCCK_CCAThres != CurCCK_CCAThres)
-               rtl8723au_write8(pDM_Odm->Adapter, ODM_REG(CCK_CCA, pDM_Odm),
-                                CurCCK_CCAThres);
-       pDM_DigTable->PreCCK_CCAThres = pDM_DigTable->CurCCK_CCAThres;
-       pDM_DigTable->CurCCK_CCAThres = CurCCK_CCAThres;
-}
-
-/* 3 ============================================================ */
-/* 3 BB Power Save */
-/* 3 ============================================================ */
-void odm23a_DynBBPSInit(struct dm_odm_t *pDM_Odm)
-{
-       struct dynamic_pwr_sav *pDM_PSTable = &pDM_Odm->DM_PSTable;
-
-       pDM_PSTable->PreCCAState = CCA_MAX;
-       pDM_PSTable->CurCCAState = CCA_MAX;
-       pDM_PSTable->PreRFState = RF_MAX;
-       pDM_PSTable->CurRFState = RF_MAX;
-       pDM_PSTable->Rssi_val_min = 0;
-       pDM_PSTable->initialize = 0;
-}
-
-
-void ODM_RF_Saving23a(struct dm_odm_t *pDM_Odm, u8 bForceInNormal)
-{
-       struct dynamic_pwr_sav *pDM_PSTable = &pDM_Odm->DM_PSTable;
-       struct rtw_adapter *adapter = pDM_Odm->Adapter;
-       u32 val32;
-       u8 Rssi_Up_bound = 30;
-       u8 Rssi_Low_bound = 25;
-       if (pDM_PSTable->initialize == 0) {
-
-               pDM_PSTable->Reg874 =
-                       rtl8723au_read32(adapter, 0x874) & 0x1CC000;
-               pDM_PSTable->RegC70 =
-                       rtl8723au_read32(adapter, 0xc70) & BIT(3);
-               pDM_PSTable->Reg85C =
-                       rtl8723au_read32(adapter, 0x85c) & 0xFF000000;
-               pDM_PSTable->RegA74 = rtl8723au_read32(adapter, 0xa74) & 0xF000;
-               pDM_PSTable->initialize = 1;
-       }
-
-       if (!bForceInNormal) {
-               if (pDM_Odm->RSSI_Min != 0xFF) {
-                       if (pDM_PSTable->PreRFState == RF_Normal) {
-                               if (pDM_Odm->RSSI_Min >= Rssi_Up_bound)
-                                       pDM_PSTable->CurRFState = RF_Save;
-                               else
-                                       pDM_PSTable->CurRFState = RF_Normal;
-                       } else {
-                               if (pDM_Odm->RSSI_Min <= Rssi_Low_bound)
-                                       pDM_PSTable->CurRFState = RF_Normal;
-                               else
-                                       pDM_PSTable->CurRFState = RF_Save;
-                       }
-               } else {
-                       pDM_PSTable->CurRFState = RF_MAX;
-               }
-       } else {
-               pDM_PSTable->CurRFState = RF_Normal;
-       }
-
-       if (pDM_PSTable->PreRFState != pDM_PSTable->CurRFState) {
-               if (pDM_PSTable->CurRFState == RF_Save) {
-                       /*  <tynli_note> 8723 RSSI report will be wrong.
-                        * Set 0x874[5]= 1 when enter BB power saving mode. */
-                       /*  Suggested by SD3 Yu-Nan. 2011.01.20. */
-                       /* Reg874[5]= 1b'1 */
-                       if (pDM_Odm->SupportICType == ODM_RTL8723A) {
-                               val32 = rtl8723au_read32(adapter, 0x874);
-                               val32 |= BIT(5);
-                               rtl8723au_write32(adapter, 0x874, val32);
-                       }
-                       /* Reg874[20:18]= 3'b010 */
-                       val32 = rtl8723au_read32(adapter, 0x874);
-                       val32 &= ~(BIT(18) | BIT(20));
-                       val32 |= BIT(19);
-                       rtl8723au_write32(adapter, 0x874, val32);
-                       /* RegC70[3]= 1'b0 */
-                       val32 = rtl8723au_read32(adapter, 0xc70);
-                       val32 &= ~BIT(3);
-                       rtl8723au_write32(adapter, 0xc70, val32);
-                       /* Reg85C[31:24]= 0x63 */
-                       val32 = rtl8723au_read32(adapter, 0x85c);
-                       val32 &= 0x00ffffff;
-                       val32 |= 0x63000000;
-                       rtl8723au_write32(adapter, 0x85c, val32);
-                       /* Reg874[15:14]= 2'b10 */
-                       val32 = rtl8723au_read32(adapter, 0x874);
-                       val32 &= ~BIT(14);
-                       val32 |= BIT(15);
-                       rtl8723au_write32(adapter, 0x874, val32);
-                       /* RegA75[7:4]= 0x3 */
-                       val32 = rtl8723au_read32(adapter, 0xa74);
-                       val32 &= ~(BIT(14) | BIT(15));
-                       val32 |= (BIT(12) | BIT(13));
-                       rtl8723au_write32(adapter, 0xa74, val32);
-                       /* Reg818[28]= 1'b0 */
-                       val32 = rtl8723au_read32(adapter, 0x818);
-                       val32 &= ~BIT(28);
-                       rtl8723au_write32(adapter, 0x818, val32);
-                       /* Reg818[28]= 1'b1 */
-                       val32 = rtl8723au_read32(adapter, 0x818);
-                       val32 |= BIT(28);
-                       rtl8723au_write32(adapter, 0x818, val32);
-               } else {
-                       val32 = rtl8723au_read32(adapter, 0x874);
-                       val32 |= pDM_PSTable->Reg874;
-                       rtl8723au_write32(adapter, 0x874, val32);
-
-                       val32 = rtl8723au_read32(adapter, 0xc70);
-                       val32 |= pDM_PSTable->RegC70;
-                       rtl8723au_write32(adapter, 0xc70, val32);
-
-                       val32 = rtl8723au_read32(adapter, 0x85c);
-                       val32 |= pDM_PSTable->Reg85C;
-                       rtl8723au_write32(adapter, 0x85c, val32);
-
-                       val32 = rtl8723au_read32(adapter, 0xa74);
-                       val32 |= pDM_PSTable->RegA74;
-                       rtl8723au_write32(adapter, 0xa74, val32);
-
-                       val32 = rtl8723au_read32(adapter, 0x818);
-                       val32 &= ~BIT(28);
-                       rtl8723au_write32(adapter, 0x818, val32);
-
-                       /* Reg874[5]= 1b'0 */
-                       if (pDM_Odm->SupportICType == ODM_RTL8723A) {
-                               val32 = rtl8723au_read32(adapter, 0x874);
-                               val32 &= ~BIT(5);
-                               rtl8723au_write32(adapter, 0x874, val32);
-                       }
-               }
-               pDM_PSTable->PreRFState = pDM_PSTable->CurRFState;
-       }
-}
-
-/* 3 ============================================================ */
-/* 3 RATR MASK */
-/* 3 ============================================================ */
-/* 3 ============================================================ */
-/* 3 Rate Adaptive */
-/* 3 ============================================================ */
-
-void odm_RateAdaptiveMaskInit23a(struct dm_odm_t *pDM_Odm)
-{
-       struct odm_rate_adapt *pOdmRA = &pDM_Odm->RateAdaptive;
-
-       pOdmRA->Type = DM_Type_ByDriver;
-
-       pOdmRA->RATRState = DM_RATR_STA_INIT;
-       pOdmRA->HighRSSIThresh = 50;
-       pOdmRA->LowRSSIThresh = 20;
-}
-
-u32 ODM_Get_Rate_Bitmap23a(struct hal_data_8723a *pHalData, u32 macid,
-                          u32 ra_mask, u8 rssi_level)
-{
-       struct dm_odm_t *pDM_Odm = &pHalData->odmpriv;
-       struct sta_info *pEntry;
-       u32 rate_bitmap = 0x0fffffff;
-       u8 WirelessMode;
-
-       pEntry = pDM_Odm->pODM_StaInfo[macid];
-       if (!pEntry)
-               return ra_mask;
-
-       WirelessMode = pEntry->wireless_mode;
-
-       switch (WirelessMode) {
-       case ODM_WM_B:
-               if (ra_mask & 0x0000000c)               /* 11M or 5.5M enable */
-                       rate_bitmap = 0x0000000d;
-               else
-                       rate_bitmap = 0x0000000f;
-               break;
-       case (ODM_WM_A|ODM_WM_G):
-               if (rssi_level == DM_RATR_STA_HIGH)
-                       rate_bitmap = 0x00000f00;
-               else
-                       rate_bitmap = 0x00000ff0;
-               break;
-       case (ODM_WM_B|ODM_WM_G):
-               if (rssi_level == DM_RATR_STA_HIGH)
-                       rate_bitmap = 0x00000f00;
-               else if (rssi_level == DM_RATR_STA_MIDDLE)
-                       rate_bitmap = 0x00000ff0;
-               else
-                       rate_bitmap = 0x00000ff5;
-               break;
-       case (ODM_WM_B|ODM_WM_G|ODM_WM_N24G):
-       case (ODM_WM_A|ODM_WM_B|ODM_WM_G|ODM_WM_N24G):
-               if (pHalData->rf_type == RF_1T2R ||
-                   pHalData->rf_type == RF_1T1R) {
-                       if (rssi_level == DM_RATR_STA_HIGH) {
-                               rate_bitmap = 0x000f0000;
-                       } else if (rssi_level == DM_RATR_STA_MIDDLE) {
-                               rate_bitmap = 0x000ff000;
-                       } else {
-                               if (pHalData->CurrentChannelBW ==
-                                   HT_CHANNEL_WIDTH_40)
-                                       rate_bitmap = 0x000ff015;
-                               else
-                                       rate_bitmap = 0x000ff005;
-                       }
-               } else {
-                       if (rssi_level == DM_RATR_STA_HIGH) {
-                               rate_bitmap = 0x0f8f0000;
-                       } else if (rssi_level == DM_RATR_STA_MIDDLE) {
-                               rate_bitmap = 0x0f8ff000;
-                       } else {
-                               if (pHalData->CurrentChannelBW ==
-                                   HT_CHANNEL_WIDTH_40)
-                                       rate_bitmap = 0x0f8ff015;
-                               else
-                                       rate_bitmap = 0x0f8ff005;
-                       }
-               }
-               break;
-       default:
-               /* case WIRELESS_11_24N: */
-               /* case WIRELESS_11_5N: */
-               if (pHalData->rf_type == RF_1T2R)
-                       rate_bitmap = 0x000fffff;
-               else
-                       rate_bitmap = 0x0fffffff;
-               break;
-       }
-
-       ODM_RT_TRACE(pDM_Odm, ODM_COMP_RA_MASK, ODM_DBG_LOUD,
-       (" ==> rssi_level:0x%02x, WirelessMode:0x%02x, rate_bitmap:0x%08x \n",
-        rssi_level, WirelessMode, rate_bitmap));
-
-       return rate_bitmap;
-}
-
-/*-----------------------------------------------------------------------------
- * Function:   odm_RefreshRateAdaptiveMask()
- *
- * Overview:   Update rate table mask according to rssi
- *
- * Input:              NONE
- *
- * Output:             NONE
- *
- * Return:             NONE
- *
- * Revised History:
- *When         Who             Remark
- *05/27/2009   hpfan   Create Version 0.
- *
- *---------------------------------------------------------------------------*/
-static void odm_RefreshRateAdaptiveMask(struct dm_odm_t *pDM_Odm)
-{
-       struct rtw_adapter *pAdapter = pDM_Odm->Adapter;
-       u32 smoothed;
-       u8 i;
-
-       if (pAdapter->bDriverStopped) {
-               ODM_RT_TRACE(pDM_Odm, ODM_COMP_RA_MASK, ODM_DBG_TRACE,
-                            ("<---- %s: driver is going to unload\n",
-                             __func__));
-               return;
-       }
-
-       for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++) {
-               struct sta_info *pstat = pDM_Odm->pODM_StaInfo[i];
-               if (pstat) {
-                       smoothed = pstat->rssi_stat.UndecoratedSmoothedPWDB;
-                       if (ODM_RAStateCheck23a(pDM_Odm, smoothed, false,
-                                               &pstat->rssi_level)) {
-                               ODM_RT_TRACE(pDM_Odm, ODM_COMP_RA_MASK,
-                                            ODM_DBG_LOUD,
-                                            ("RSSI:%d, RSSI_LEVEL:%d\n",
-                                             smoothed,
-                                             pstat->rssi_level));
-                               rtw_hal_update_ra_mask23a(pstat,
-                                                         pstat->rssi_level);
-                       }
-               }
-       }
-}
-
-/*  Return Value: bool */
-/*  - true: RATRState is changed. */
-bool ODM_RAStateCheck23a(struct dm_odm_t *pDM_Odm, s32 RSSI, bool bForceUpdate,
-                        u8 *pRATRState)
-{
-       struct odm_rate_adapt *pRA = &pDM_Odm->RateAdaptive;
-       const u8 GoUpGap = 5;
-       u8 HighRSSIThreshForRA = pRA->HighRSSIThresh;
-       u8 LowRSSIThreshForRA = pRA->LowRSSIThresh;
-       u8 RATRState;
-
-       /*  Threshold Adjustment: */
-       /*  when RSSI state trends to go up one or two levels, make sure RSSI is high enough. */
-       /*  Here GoUpGap is added to solve the boundary's level alternation issue. */
-       switch (*pRATRState) {
-       case DM_RATR_STA_INIT:
-       case DM_RATR_STA_HIGH:
-               break;
-       case DM_RATR_STA_MIDDLE:
-               HighRSSIThreshForRA += GoUpGap;
-               break;
-       case DM_RATR_STA_LOW:
-               HighRSSIThreshForRA += GoUpGap;
-               LowRSSIThreshForRA += GoUpGap;
-               break;
-       default:
-               ODM_RT_ASSERT(pDM_Odm, false, ("wrong rssi level setting %d !",
-                                              *pRATRState));
-               break;
-       }
-
-       /*  Decide RATRState by RSSI. */
-       if (RSSI > HighRSSIThreshForRA)
-               RATRState = DM_RATR_STA_HIGH;
-       else if (RSSI > LowRSSIThreshForRA)
-               RATRState = DM_RATR_STA_MIDDLE;
-       else
-               RATRState = DM_RATR_STA_LOW;
-
-       if (*pRATRState != RATRState || bForceUpdate) {
-               ODM_RT_TRACE(pDM_Odm, ODM_COMP_RA_MASK, ODM_DBG_LOUD,
-                            ("RSSI Level %d -> %d\n", *pRATRState, RATRState));
-               *pRATRState = RATRState;
-               return true;
-       }
-       return false;
-}
-
-/* 3 ============================================================ */
-/* 3 Dynamic Tx Power */
-/* 3 ============================================================ */
-
-void odm_DynamicTxPower23aInit(struct dm_odm_t *pDM_Odm)
-{
-       struct rtw_adapter *Adapter = pDM_Odm->Adapter;
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(Adapter);
-       struct dm_priv *pdmpriv = &pHalData->dmpriv;
-
-       /*
-        * This is never changed, so we should be able to clean up the
-        * code checking for different values in rtl8723a_rf6052.c
-        */
-       pdmpriv->DynamicTxHighPowerLvl = TxHighPwrLevel_Normal;
-}
-
-static void
-FindMinimumRSSI(struct rtw_adapter *pAdapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(pAdapter);
-       struct dm_priv *pdmpriv = &pHalData->dmpriv;
-       struct dm_odm_t *pDM_Odm = &pHalData->odmpriv;
-
-       /* 1 1.Determine the minimum RSSI */
-
-       if (!pDM_Odm->bLinked && !pdmpriv->EntryMinUndecoratedSmoothedPWDB)
-               pdmpriv->MinUndecoratedPWDBForDM = 0;
-       else
-               pdmpriv->MinUndecoratedPWDBForDM =
-                       pdmpriv->EntryMinUndecoratedSmoothedPWDB;
-}
-
-static void odm_RSSIMonitorCheck(struct dm_odm_t *pDM_Odm)
-{
-       struct rtw_adapter *Adapter = pDM_Odm->Adapter;
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(Adapter);
-       struct dm_priv *pdmpriv = &pHalData->dmpriv;
-       int i;
-       int MaxDB = 0, MinDB = 0xff;
-       u8 sta_cnt = 0;
-       u32 tmpdb;
-       u32 PWDB_rssi[NUM_STA] = {0};/* 0~15]:MACID, [16~31]:PWDB_rssi */
-       struct sta_info *psta;
-
-       if (!pDM_Odm->bLinked)
-               return;
-
-       for (i = 0; i < ODM_ASSOCIATE_ENTRY_NUM; i++) {
-               psta = pDM_Odm->pODM_StaInfo[i];
-               if (psta) {
-                       if (psta->rssi_stat.UndecoratedSmoothedPWDB < MinDB)
-                               MinDB = psta->rssi_stat.UndecoratedSmoothedPWDB;
-
-                       if (psta->rssi_stat.UndecoratedSmoothedPWDB > MaxDB)
-                               MaxDB = psta->rssi_stat.UndecoratedSmoothedPWDB;
-
-                       if (psta->rssi_stat.UndecoratedSmoothedPWDB != -1) {
-                               tmpdb = psta->rssi_stat.UndecoratedSmoothedPWDB;
-                               PWDB_rssi[sta_cnt++] = psta->mac_id |
-                                       (tmpdb << 16);
-                       }
-               }
-       }
-
-       for (i = 0; i < sta_cnt; i++) {
-               if (PWDB_rssi[i] != (0))
-                       rtl8723a_set_rssi_cmd(Adapter, PWDB_rssi[i]);
-       }
-
-       pdmpriv->EntryMaxUndecoratedSmoothedPWDB = MaxDB;
-
-       if (MinDB != 0xff) /*  If associated entry is found */
-               pdmpriv->EntryMinUndecoratedSmoothedPWDB = MinDB;
-       else
-               pdmpriv->EntryMinUndecoratedSmoothedPWDB = 0;
-
-       FindMinimumRSSI(Adapter);/* get pdmpriv->MinUndecoratedPWDBForDM */
-
-       ODM_CmnInfoUpdate23a(&pHalData->odmpriv, ODM_CMNINFO_RSSI_MIN,
-                            pdmpriv->MinUndecoratedPWDBForDM);
-}
-
-/* endif */
-/* 3 ============================================================ */
-/* 3 Tx Power Tracking */
-/* 3 ============================================================ */
-
-static void odm_TXPowerTrackingInit(struct dm_odm_t *pDM_Odm)
-{
-       struct rtw_adapter *Adapter = pDM_Odm->Adapter;
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(Adapter);
-       struct dm_priv *pdmpriv = &pHalData->dmpriv;
-
-       pdmpriv->bTXPowerTracking = true;
-       pdmpriv->TXPowercount = 0;
-       pdmpriv->bTXPowerTrackingInit = false;
-       pdmpriv->TxPowerTrackControl = true;
-       MSG_8723A("pdmpriv->TxPowerTrackControl = %d\n",
-                 pdmpriv->TxPowerTrackControl);
-
-       pDM_Odm->RFCalibrateInfo.TxPowerTrackControl = true;
-}
-
-/* EDCA Turbo */
-static void ODM_EdcaTurboInit23a(struct dm_odm_t *pDM_Odm)
-{
-       struct rtw_adapter *Adapter = pDM_Odm->Adapter;
-
-       pDM_Odm->DM_EDCA_Table.bCurrentTurboEDCA = false;
-       Adapter->recvpriv.bIsAnyNonBEPkts = false;
-
-       ODM_RT_TRACE(pDM_Odm, ODM_COMP_EDCA_TURBO, ODM_DBG_LOUD,
-                    ("Orginial VO PARAM: 0x%x\n",
-                     rtl8723au_read32(Adapter, ODM_EDCA_VO_PARAM)));
-       ODM_RT_TRACE(pDM_Odm, ODM_COMP_EDCA_TURBO, ODM_DBG_LOUD,
-                    ("Orginial VI PARAM: 0x%x\n",
-                     rtl8723au_read32(Adapter, ODM_EDCA_VI_PARAM)));
-       ODM_RT_TRACE(pDM_Odm, ODM_COMP_EDCA_TURBO, ODM_DBG_LOUD,
-                    ("Orginial BE PARAM: 0x%x\n",
-                     rtl8723au_read32(Adapter, ODM_EDCA_BE_PARAM)));
-       ODM_RT_TRACE(pDM_Odm, ODM_COMP_EDCA_TURBO, ODM_DBG_LOUD,
-                    ("Orginial BK PARAM: 0x%x\n",
-                     rtl8723au_read32(Adapter, ODM_EDCA_BK_PARAM)));
-}
-
-static void odm_EdcaTurboCheck23a(struct dm_odm_t *pDM_Odm)
-{
-       struct rtw_adapter *Adapter = pDM_Odm->Adapter;
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(Adapter);
-       struct xmit_priv *pxmitpriv = &Adapter->xmitpriv;
-       struct recv_priv *precvpriv = &Adapter->recvpriv;
-       struct registry_priv *pregpriv = &Adapter->registrypriv;
-       struct mlme_ext_priv *pmlmeext = &Adapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       u32 trafficIndex;
-       u32 edca_param;
-       u64 cur_tx_bytes;
-       u64 cur_rx_bytes;
-
-       /*  For AP/ADSL use struct rtl8723a_priv * */
-       /*  For CE/NIC use struct rtw_adapter * */
-
-       /*
-        * 2011/09/29 MH In HW integration first stage, we provide 4
-        * different handle to operate at the same time. In the stage2/3,
-        * we need to prive universal interface and merge all HW dynamic
-        * mechanism.
-        */
-
-       if ((pregpriv->wifi_spec == 1))/*  (pmlmeinfo->HT_enable == 0)) */
-               goto dm_CheckEdcaTurbo_EXIT;
-
-       if (pmlmeinfo->assoc_AP_vendor >=  HT_IOT_PEER_MAX)
-               goto dm_CheckEdcaTurbo_EXIT;
-
-       if (rtl8723a_BT_disable_EDCA_turbo(Adapter))
-               goto dm_CheckEdcaTurbo_EXIT;
-
-       /*  Check if the status needs to be changed. */
-       if (!precvpriv->bIsAnyNonBEPkts) {
-               cur_tx_bytes = pxmitpriv->tx_bytes - pxmitpriv->last_tx_bytes;
-               cur_rx_bytes = precvpriv->rx_bytes - precvpriv->last_rx_bytes;
-
-               /* traffic, TX or RX */
-               if ((pmlmeinfo->assoc_AP_vendor == HT_IOT_PEER_RALINK) ||
-                   (pmlmeinfo->assoc_AP_vendor == HT_IOT_PEER_ATHEROS)) {
-                       if (cur_tx_bytes > (cur_rx_bytes << 2)) {
-                               /*  Uplink TP is present. */
-                               trafficIndex = UP_LINK;
-                       } else { /*  Balance TP is present. */
-                               trafficIndex = DOWN_LINK;
-                       }
-               } else {
-                       if (cur_rx_bytes > (cur_tx_bytes << 2)) {
-                               /*  Downlink TP is present. */
-                               trafficIndex = DOWN_LINK;
-                       } else { /*  Balance TP is present. */
-                               trafficIndex = UP_LINK;
-                       }
-               }
-
-               if ((pDM_Odm->DM_EDCA_Table.prv_traffic_idx != trafficIndex) ||
-                   (!pDM_Odm->DM_EDCA_Table.bCurrentTurboEDCA)) {
-                       if ((pmlmeinfo->assoc_AP_vendor == HT_IOT_PEER_CISCO) &&
-                           (pmlmeext->cur_wireless_mode & WIRELESS_11_24N))
-                               edca_param = EDCAParam[pmlmeinfo->assoc_AP_vendor][trafficIndex];
-                       else
-                               edca_param = EDCAParam[HT_IOT_PEER_UNKNOWN][trafficIndex];
-                       rtl8723au_write32(Adapter, REG_EDCA_BE_PARAM,
-                                         edca_param);
-
-                       pDM_Odm->DM_EDCA_Table.prv_traffic_idx = trafficIndex;
-               }
-
-               pDM_Odm->DM_EDCA_Table.bCurrentTurboEDCA = true;
-       } else {
-               /*  Turn Off EDCA turbo here. */
-               /*  Restore original EDCA according to the declaration of AP. */
-               if (pDM_Odm->DM_EDCA_Table.bCurrentTurboEDCA) {
-                       rtl8723au_write32(Adapter, REG_EDCA_BE_PARAM,
-                                         pHalData->AcParam_BE);
-                       pDM_Odm->DM_EDCA_Table.bCurrentTurboEDCA = false;
-               }
-       }
-
-dm_CheckEdcaTurbo_EXIT:
-       /*  Set variables for next time. */
-       precvpriv->bIsAnyNonBEPkts = false;
-       pxmitpriv->last_tx_bytes = pxmitpriv->tx_bytes;
-       precvpriv->last_rx_bytes = precvpriv->rx_bytes;
-}
-
-u32 GetPSDData(struct dm_odm_t *pDM_Odm, unsigned int point,
-              u8 initial_gain_psd)
-{
-       struct rtw_adapter *adapter = pDM_Odm->Adapter;
-       u32 psd_report, val32;
-
-       /* Set DCO frequency index, offset = (40MHz/SamplePts)*point */
-       val32 = rtl8723au_read32(adapter, 0x808);
-       val32 &= ~0x3ff;
-       val32 |= (point & 0x3ff);
-       rtl8723au_write32(adapter, 0x808, val32);
-
-       /* Start PSD calculation, Reg808[22]= 0->1 */
-       val32 = rtl8723au_read32(adapter, 0x808);
-       val32 |= BIT(22);
-       rtl8723au_write32(adapter, 0x808, val32);
-       /* Need to wait for HW PSD report */
-       udelay(30);
-       val32 = rtl8723au_read32(adapter, 0x808);
-       val32 &= ~BIT(22);
-       rtl8723au_write32(adapter, 0x808, val32);
-       /* Read PSD report, Reg8B4[15:0] */
-       psd_report = rtl8723au_read32(adapter, 0x8B4) & 0x0000FFFF;
-
-       psd_report = (u32)(ConvertTo_dB23a(psd_report)) +
-               (u32)(initial_gain_psd-0x1c);
-
-       return psd_report;
-}
-
-u32 ConvertTo_dB23a(u32 Value)
-{
-       u8 i;
-       u8 j;
-       u32 dB;
-
-       Value = Value & 0xFFFF;
-
-       for (i = 0; i < 8; i++) {
-               if (Value <= dB_Invert_Table[i][11])
-                       break;
-       }
-
-       if (i >= 8)
-               return 96;      /*  maximum 96 dB */
-
-       for (j = 0; j < 12; j++) {
-               if (Value <= dB_Invert_Table[i][j])
-                       break;
-       }
-
-       dB = i*12 + j + 1;
-
-       return dB;
-}
-
-/*  */
-/*  Description: */
-/* Set Single/Dual Antenna default setting for products that do not
- * do detection in advance. */
-/*  */
-/*  Added by Joseph, 2012.03.22 */
-/*  */
-void ODM_SingleDualAntennaDefaultSetting(struct dm_odm_t *pDM_Odm)
-{
-       struct sw_ant_sw *pDM_SWAT_Table = &pDM_Odm->DM_SWAT_Table;
-
-       pDM_SWAT_Table->ANTA_ON = true;
-       pDM_SWAT_Table->ANTB_ON = true;
-}
-
-/* 2 8723A ANT DETECT */
-
-static void odm_PHY_SaveAFERegisters(struct dm_odm_t *pDM_Odm, u32 *AFEReg,
-                                    u32 *AFEBackup, u32 RegisterNum)
-{
-       u32 i;
-
-       for (i = 0 ; i < RegisterNum ; i++)
-               AFEBackup[i] = rtl8723au_read32(pDM_Odm->Adapter, AFEReg[i]);
-}
-
-static void odm_PHY_ReloadAFERegisters(struct dm_odm_t *pDM_Odm, u32 *AFEReg,
-                                      u32 *AFEBackup, u32 RegiesterNum)
-{
-       u32 i;
-
-       for (i = 0 ; i < RegiesterNum; i++)
-               rtl8723au_write32(pDM_Odm->Adapter, AFEReg[i], AFEBackup[i]);
-}
-
-/* 2 8723A ANT DETECT */
-/*  Description: */
-/* Implement IQK single tone for RF DPK loopback and BB PSD scanning. */
-/* This function is cooperated with BB team Neil. */
-bool ODM_SingleDualAntennaDetection(struct dm_odm_t *pDM_Odm, u8 mode)
-{
-       struct sw_ant_sw *pDM_SWAT_Table = &pDM_Odm->DM_SWAT_Table;
-       struct rtw_adapter *adapter = pDM_Odm->Adapter;
-       u32 CurrentChannel, RfLoopReg;
-       u8 n;
-       u32 Reg88c, Regc08, Reg874, Regc50, val32;
-       u8 initial_gain = 0x5a;
-       u32 PSD_report_tmp;
-       u32 AntA_report = 0x0, AntB_report = 0x0, AntO_report = 0x0;
-       bool bResult = true;
-       u32 AFE_Backup[16];
-       u32 AFE_REG_8723A[16] = {
-               rRx_Wait_CCA, rTx_CCK_RFON,
-               rTx_CCK_BBON, rTx_OFDM_RFON,
-               rTx_OFDM_BBON, rTx_To_Rx,
-               rTx_To_Tx, rRx_CCK,
-               rRx_OFDM, rRx_Wait_RIFS,
-               rRx_TO_Rx, rStandby,
-               rSleep, rPMPD_ANAEN,
-               rFPGA0_XCD_SwitchControl, rBlue_Tooth};
-
-       if (!(pDM_Odm->SupportICType & ODM_RTL8723A))
-               return bResult;
-
-       if (!(pDM_Odm->SupportAbility&ODM_BB_ANT_DIV))
-               return bResult;
-       /* 1 Backup Current RF/BB Settings */
-
-       CurrentChannel = ODM_GetRFReg(pDM_Odm, RF_PATH_A, ODM_CHANNEL,
-                                     bRFRegOffsetMask);
-       RfLoopReg = ODM_GetRFReg(pDM_Odm, RF_PATH_A, 0x00, bRFRegOffsetMask);
-       /*  change to Antenna A */
-       val32 = rtl8723au_read32(adapter, rFPGA0_XA_RFInterfaceOE);
-       val32 &= ~0x300;
-       val32 |= 0x100;         /* Enable antenna A */
-       rtl8723au_write32(adapter, rFPGA0_XA_RFInterfaceOE, val32);
-
-       /*  Step 1: USE IQK to transmitter single tone */
-
-       udelay(10);
-
-       /* Store A Path Register 88c, c08, 874, c50 */
-       Reg88c = rtl8723au_read32(adapter, rFPGA0_AnalogParameter4);
-       Regc08 = rtl8723au_read32(adapter, rOFDM0_TRMuxPar);
-       Reg874 = rtl8723au_read32(adapter, rFPGA0_XCD_RFInterfaceSW);
-       Regc50 = rtl8723au_read32(adapter, rOFDM0_XAAGCCore1);
-
-       /*  Store AFE Registers */
-       odm_PHY_SaveAFERegisters(pDM_Odm, AFE_REG_8723A, AFE_Backup, 16);
-
-       /* Set PSD 128 pts */
-       val32 = rtl8723au_read32(adapter, rFPGA0_PSDFunction);
-       val32 &= ~(BIT(14) | BIT(15));
-       rtl8723au_write32(adapter, rFPGA0_PSDFunction, val32);
-
-       /*  To SET CH1 to do */
-       ODM_SetRFReg(pDM_Odm, RF_PATH_A, ODM_CHANNEL, bRFRegOffsetMask, 0x01);
-
-       /*  AFE all on step */
-       rtl8723au_write32(adapter, rRx_Wait_CCA, 0x6FDB25A4);
-       rtl8723au_write32(adapter, rTx_CCK_RFON, 0x6FDB25A4);
-       rtl8723au_write32(adapter, rTx_CCK_BBON, 0x6FDB25A4);
-       rtl8723au_write32(adapter, rTx_OFDM_RFON, 0x6FDB25A4);
-       rtl8723au_write32(adapter, rTx_OFDM_BBON, 0x6FDB25A4);
-       rtl8723au_write32(adapter, rTx_To_Rx, 0x6FDB25A4);
-       rtl8723au_write32(adapter, rTx_To_Tx, 0x6FDB25A4);
-       rtl8723au_write32(adapter, rRx_CCK, 0x6FDB25A4);
-       rtl8723au_write32(adapter, rRx_OFDM, 0x6FDB25A4);
-       rtl8723au_write32(adapter, rRx_Wait_RIFS, 0x6FDB25A4);
-       rtl8723au_write32(adapter, rRx_TO_Rx, 0x6FDB25A4);
-       rtl8723au_write32(adapter, rStandby, 0x6FDB25A4);
-       rtl8723au_write32(adapter, rSleep, 0x6FDB25A4);
-       rtl8723au_write32(adapter, rPMPD_ANAEN, 0x6FDB25A4);
-       rtl8723au_write32(adapter, rFPGA0_XCD_SwitchControl, 0x6FDB25A4);
-       rtl8723au_write32(adapter, rBlue_Tooth, 0x6FDB25A4);
-
-       /*  3 wire Disable */
-       rtl8723au_write32(adapter, rFPGA0_AnalogParameter4, 0xCCF000C0);
-
-       /* BB IQK Setting */
-       rtl8723au_write32(adapter, rOFDM0_TRMuxPar, 0x000800E4);
-       rtl8723au_write32(adapter, rFPGA0_XCD_RFInterfaceSW, 0x22208000);
-
-       /* IQK setting tone@ 4.34Mhz */
-       rtl8723au_write32(adapter, rTx_IQK_Tone_A, 0x10008C1C);
-       rtl8723au_write32(adapter, rTx_IQK, 0x01007c00);
-
-       /* Page B init */
-       rtl8723au_write32(adapter, rConfig_AntA, 0x00080000);
-       rtl8723au_write32(adapter, rConfig_AntA, 0x0f600000);
-       rtl8723au_write32(adapter, rRx_IQK, 0x01004800);
-       rtl8723au_write32(adapter, rRx_IQK_Tone_A, 0x10008c1f);
-       rtl8723au_write32(adapter, rTx_IQK_PI_A, 0x82150008);
-       rtl8723au_write32(adapter, rRx_IQK_PI_A, 0x28150008);
-       rtl8723au_write32(adapter, rIQK_AGC_Rsp, 0x001028d0);
-
-       /* RF loop Setting */
-       ODM_SetRFReg(pDM_Odm, RF_PATH_A, 0x0, 0xFFFFF, 0x50008);
-
-       /* IQK Single tone start */
-       rtl8723au_write32(adapter, rFPGA0_IQK, 0x80800000);
-       rtl8723au_write32(adapter, rIQK_AGC_Pts, 0xf8000000);
-       udelay(1000);
-       PSD_report_tmp = 0x0;
-
-       for (n = 0; n < 2; n++) {
-               PSD_report_tmp =  GetPSDData(pDM_Odm, 14, initial_gain);
-               if (PSD_report_tmp > AntA_report)
-                       AntA_report = PSD_report_tmp;
-       }
-
-       PSD_report_tmp = 0x0;
-
-       val32 = rtl8723au_read32(adapter, rFPGA0_XA_RFInterfaceOE);
-       val32 &= ~0x300;
-       val32 |= 0x200;         /* Enable antenna B */
-       rtl8723au_write32(adapter, rFPGA0_XA_RFInterfaceOE, val32);
-       udelay(10);
-
-       for (n = 0; n < 2; n++) {
-               PSD_report_tmp =  GetPSDData(pDM_Odm, 14, initial_gain);
-               if (PSD_report_tmp > AntB_report)
-                       AntB_report = PSD_report_tmp;
-       }
-
-       /*  change to open case */
-       /*  change to Ant A and B all open case */
-       val32 = rtl8723au_read32(adapter, rFPGA0_XA_RFInterfaceOE);
-       val32 &= ~0x300;
-       rtl8723au_write32(adapter, rFPGA0_XA_RFInterfaceOE, val32);
-       udelay(10);
-
-       for (n = 0; n < 2; n++) {
-               PSD_report_tmp =  GetPSDData(pDM_Odm, 14, initial_gain);
-               if (PSD_report_tmp > AntO_report)
-                       AntO_report = PSD_report_tmp;
-       }
-
-       /* Close IQK Single Tone function */
-       rtl8723au_write32(adapter, rFPGA0_IQK, 0x00000000);
-       PSD_report_tmp = 0x0;
-
-       /* 1 Return to antanna A */
-       val32 = rtl8723au_read32(adapter, rFPGA0_XA_RFInterfaceOE);
-       val32 &= ~0x300;
-       val32 |= 0x100;         /* Enable antenna A */
-       rtl8723au_write32(adapter, rFPGA0_XA_RFInterfaceOE, val32);
-       rtl8723au_write32(adapter, rFPGA0_AnalogParameter4, Reg88c);
-       rtl8723au_write32(adapter, rOFDM0_TRMuxPar, Regc08);
-       rtl8723au_write32(adapter, rFPGA0_XCD_RFInterfaceSW, Reg874);
-       val32 = rtl8723au_read32(adapter, rOFDM0_XAAGCCore1);
-       val32 &= ~0x7f;
-       val32 |= 0x40;
-       rtl8723au_write32(adapter, rOFDM0_XAAGCCore1, val32);
-
-       rtl8723au_write32(adapter, rOFDM0_XAAGCCore1, Regc50);
-       ODM_SetRFReg(pDM_Odm, RF_PATH_A, RF_CHNLBW, bRFRegOffsetMask,
-                    CurrentChannel);
-       ODM_SetRFReg(pDM_Odm, RF_PATH_A, 0x00, bRFRegOffsetMask, RfLoopReg);
-
-       /* Reload AFE Registers */
-       odm_PHY_ReloadAFERegisters(pDM_Odm, AFE_REG_8723A, AFE_Backup, 16);
-
-       ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD,
-                    ("psd_report_A[%d]= %d \n", 2416, AntA_report));
-       ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD,
-                    ("psd_report_B[%d]= %d \n", 2416, AntB_report));
-       ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD,
-                    ("psd_report_O[%d]= %d \n", 2416, AntO_report));
-
-       /* 2 Test Ant B based on Ant A is ON */
-       if (mode == ANTTESTB) {
-               if (AntA_report >= 100) {
-                       if (AntB_report > (AntA_report+1)) {
-                               pDM_SWAT_Table->ANTB_ON = false;
-                               ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("ODM_SingleDualAntennaDetection(): Single Antenna A\n"));
-                       } else {
-                               pDM_SWAT_Table->ANTB_ON = true;
-                               ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("ODM_SingleDualAntennaDetection(): Dual Antenna is A and B\n"));
-                       }
-               } else {
-                       ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD, ("ODM_SingleDualAntennaDetection(): Need to check again\n"));
-                       pDM_SWAT_Table->ANTB_ON = false; /*  Set Antenna B off as default */
-                       bResult = false;
-               }
-       } else if (mode == ANTTESTALL) {
-               /* 2 Test Ant A and B based on DPDT Open */
-               if ((AntO_report >= 100) & (AntO_report < 118)) {
-                       if (AntA_report > (AntO_report+1)) {
-                               pDM_SWAT_Table->ANTA_ON = false;
-                               ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV,
-                                            ODM_DBG_LOUD, ("Ant A is OFF"));
-                       } else {
-                               pDM_SWAT_Table->ANTA_ON = true;
-                               ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV,
-                                            ODM_DBG_LOUD, ("Ant A is ON"));
-                       }
-
-                       if (AntB_report > (AntO_report+2)) {
-                               pDM_SWAT_Table->ANTB_ON = false;
-                               ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV,
-                                            ODM_DBG_LOUD, ("Ant B is OFF"));
-                       } else {
-                               pDM_SWAT_Table->ANTB_ON = true;
-                               ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV,
-                                            ODM_DBG_LOUD, ("Ant B is ON"));
-                       }
-               }
-       } else {
-               ODM_RT_TRACE(pDM_Odm, ODM_COMP_ANT_DIV, ODM_DBG_LOUD,
-               ("ODM_SingleDualAntennaDetection(): Need to check again\n"));
-               /*  Set Antenna A on as default */
-               pDM_SWAT_Table->ANTA_ON = true;
-               /*  Set Antenna B off as default */
-               pDM_SWAT_Table->ANTB_ON = false;
-               bResult = false;
-       }
-
-       return bResult;
-}
diff --git a/drivers/staging/rtl8723au/hal/odm_HWConfig.c b/drivers/staging/rtl8723au/hal/odm_HWConfig.c
deleted file mode 100644 (file)
index 0562f61..0000000
+++ /dev/null
@@ -1,396 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-
-/*  */
-/*  include files */
-/*  */
-
-#include "odm_precomp.h"
-
-static u8 odm_QueryRxPwrPercentage(s8 AntPower)
-{
-       if ((AntPower <= -100) || (AntPower >= 20))
-               return  0;
-       else if (AntPower >= 0)
-               return  100;
-       else
-               return  100 + AntPower;
-}
-
-static s32 odm_SignalScaleMapping_92CSeries(struct dm_odm_t *pDM_Odm, s32 CurrSig)
-{
-       s32 RetSig = 0;
-
-       if (CurrSig >= 51 && CurrSig <= 100)
-               RetSig = 100;
-       else if (CurrSig >= 41 && CurrSig <= 50)
-               RetSig = 80 + ((CurrSig - 40)*2);
-       else if (CurrSig >= 31 && CurrSig <= 40)
-               RetSig = 66 + (CurrSig - 30);
-       else if (CurrSig >= 21 && CurrSig <= 30)
-               RetSig = 54 + (CurrSig - 20);
-       else if (CurrSig >= 10 && CurrSig <= 20)
-               RetSig = 42 + (((CurrSig - 10) * 2) / 3);
-       else if (CurrSig >= 5 && CurrSig <= 9)
-               RetSig = 22 + (((CurrSig - 5) * 3) / 2);
-       else if (CurrSig >= 1 && CurrSig <= 4)
-               RetSig = 6 + (((CurrSig - 1) * 3) / 2);
-       else
-               RetSig = CurrSig;
-
-       return RetSig;
-}
-
-static s32 odm_SignalScaleMapping(struct dm_odm_t *pDM_Odm, s32 CurrSig)
-{
-       return odm_SignalScaleMapping_92CSeries(pDM_Odm, CurrSig);
-}
-
-static u8
-odm_EVMdbToPercentage(
-       s8 Value
-  )
-{
-       /*  */
-       /*  -33dB~0dB to 0%~99% */
-       /*  */
-       s8 ret_val;
-
-       ret_val = Value;
-
-       if (ret_val >= 0)
-               ret_val = 0;
-       if (ret_val <= -33)
-               ret_val = -33;
-
-       ret_val = 0 - ret_val;
-       ret_val *= 3;
-
-       if (ret_val == 99)
-               ret_val = 100;
-
-       return ret_val;
-}
-
-static void odm_RxPhyStatus92CSeries_Parsing(struct dm_odm_t *pDM_Odm,
-                                            struct phy_info *pPhyInfo,
-                                            u8 *pPhyStatus,
-                                            struct odm_packet_info *pPktinfo)
-{
-       struct phy_status_rpt *pPhyStaRpt = (struct phy_status_rpt *)pPhyStatus;
-       u8 i, Max_spatial_stream;
-       s8 rx_pwr[4], rx_pwr_all = 0;
-       u8 EVM, PWDB_ALL = 0, PWDB_ALL_BT;
-       u8 RSSI, total_rssi = 0;
-       u8 isCCKrate = 0;
-       u8 rf_rx_num = 0;
-       u8 cck_highpwr = 0;
-
-       isCCKrate = (pPktinfo->Rate <= DESC92C_RATE11M) ? true : false;
-       pPhyInfo->RxMIMOSignalQuality[RF_PATH_A] = -1;
-       pPhyInfo->RxMIMOSignalQuality[RF_PATH_B] = -1;
-
-       if (isCCKrate) {
-               u8 report;
-               u8 cck_agc_rpt;
-
-               pDM_Odm->PhyDbgInfo.NumQryPhyStatusCCK++;
-               /*  (1)Hardware does not provide RSSI for CCK */
-               /*  (2)PWDB, Average PWDB cacluated by hardware (for rate adaptive) */
-
-               cck_highpwr = pDM_Odm->bCckHighPower;
-
-               cck_agc_rpt =  pPhyStaRpt->cck_agc_rpt_ofdm_cfosho_a;
-
-               /* The RSSI formula should be modified according to the gain table */
-               if (!cck_highpwr) {
-                       report = (cck_agc_rpt & 0xc0)>>6;
-                       switch (report) {
-                       /*  Modify the RF RNA gain value to -40, -20, -2, 14 by Jenyu's suggestion */
-                       /*  Note: different RF with the different RNA gain. */
-                       case 0x3:
-                               rx_pwr_all = -46 - (cck_agc_rpt & 0x3e);
-                               break;
-                       case 0x2:
-                               rx_pwr_all = -26 - (cck_agc_rpt & 0x3e);
-                               break;
-                       case 0x1:
-                               rx_pwr_all = -12 - (cck_agc_rpt & 0x3e);
-                               break;
-                       case 0x0:
-                               rx_pwr_all = 16 - (cck_agc_rpt & 0x3e);
-                               break;
-                       }
-               } else {
-                       report = (cck_agc_rpt & 0x60)>>5;
-                       switch (report) {
-                       case 0x3:
-                               rx_pwr_all = -46 - ((cck_agc_rpt & 0x1f)<<1);
-                               break;
-                       case 0x2:
-                               rx_pwr_all = -26 - ((cck_agc_rpt & 0x1f)<<1);
-                               break;
-                       case 0x1:
-                               rx_pwr_all = -12 - ((cck_agc_rpt & 0x1f)<<1);
-                               break;
-                       case 0x0:
-                               rx_pwr_all = 16 - ((cck_agc_rpt & 0x1f)<<1);
-                               break;
-                       }
-               }
-
-               PWDB_ALL = odm_QueryRxPwrPercentage(rx_pwr_all);
-
-               /* Modification for ext-LNA board */
-               if (pDM_Odm->BoardType == ODM_BOARD_HIGHPWR) {
-                       if ((cck_agc_rpt>>7) == 0) {
-                               PWDB_ALL = (PWDB_ALL > 94) ? 100 : (PWDB_ALL+6);
-                       } else {
-                               if (PWDB_ALL > 38)
-                                       PWDB_ALL -= 16;
-                               else
-                                       PWDB_ALL = (PWDB_ALL <= 16) ? (PWDB_ALL>>2) : (PWDB_ALL-12);
-                       }
-
-                       /* CCK modification */
-                       if (PWDB_ALL > 25 && PWDB_ALL <= 60)
-                               PWDB_ALL += 6;
-               } else { /* Modification for int-LNA board */
-                       if (PWDB_ALL > 99)
-                               PWDB_ALL -= 8;
-                       else if (PWDB_ALL > 50 && PWDB_ALL <= 68)
-                               PWDB_ALL += 4;
-               }
-               pPhyInfo->RxPWDBAll = PWDB_ALL;
-               pPhyInfo->BTRxRSSIPercentage = PWDB_ALL;
-               pPhyInfo->RecvSignalPower = rx_pwr_all;
-               /*  (3) Get Signal Quality (EVM) */
-               if (pPktinfo->bPacketMatchBSSID) {
-                       u8      SQ, SQ_rpt;
-
-                       SQ_rpt = pPhyStaRpt->cck_sig_qual_ofdm_pwdb_all;
-
-                       if (SQ_rpt > 64)
-                               SQ = 0;
-                       else if (SQ_rpt < 20)
-                               SQ = 100;
-                       else
-                               SQ = ((64-SQ_rpt) * 100) / 44;
-
-                       pPhyInfo->SignalQuality = SQ;
-                       pPhyInfo->RxMIMOSignalQuality[RF_PATH_A] = SQ;
-                       pPhyInfo->RxMIMOSignalQuality[RF_PATH_B] = -1;
-               }
-       } else { /* is OFDM rate */
-               pDM_Odm->PhyDbgInfo.NumQryPhyStatusOFDM++;
-
-               /*  (1)Get RSSI for HT rate */
-
-               for (i = RF_PATH_A; i < RF_PATH_MAX; i++) {
-                       /*  2008/01/30 MH we will judge RF RX path now. */
-                       if (pDM_Odm->RFPathRxEnable & BIT(i))
-                               rf_rx_num++;
-
-                       rx_pwr[i] = ((pPhyStaRpt->path_agc[i].gain & 0x3F)*2) - 110;
-
-                       pPhyInfo->RxPwr[i] = rx_pwr[i];
-
-                       /* Translate DBM to percentage. */
-                       RSSI = odm_QueryRxPwrPercentage(rx_pwr[i]);
-                       total_rssi += RSSI;
-
-                       /* Modification for ext-LNA board */
-                       if (pDM_Odm->BoardType == ODM_BOARD_HIGHPWR) {
-                               if ((pPhyStaRpt->path_agc[i].trsw) == 1)
-                                       RSSI = (RSSI > 94) ? 100 : (RSSI+6);
-                               else
-                                       RSSI = (RSSI <= 16) ? (RSSI>>3) : (RSSI-16);
-
-                               if ((RSSI <= 34) && (RSSI >= 4))
-                                       RSSI -= 4;
-                       }
-
-                       pPhyInfo->RxMIMOSignalStrength[i] = (u8) RSSI;
-
-                       /* Get Rx snr value in DB */
-                       pPhyInfo->RxSNR[i] = pDM_Odm->PhyDbgInfo.RxSNRdB[i] = (s32)(pPhyStaRpt->path_rxsnr[i]/2);
-               }
-
-               /*  (2)PWDB, Average PWDB cacluated by hardware (for rate adaptive) */
-               rx_pwr_all = (((pPhyStaRpt->cck_sig_qual_ofdm_pwdb_all) >> 1) & 0x7f)-110;
-
-               PWDB_ALL = odm_QueryRxPwrPercentage(rx_pwr_all);
-               PWDB_ALL_BT = PWDB_ALL;
-
-               pPhyInfo->RxPWDBAll = PWDB_ALL;
-               pPhyInfo->BTRxRSSIPercentage = PWDB_ALL_BT;
-               pPhyInfo->RxPower = rx_pwr_all;
-               pPhyInfo->RecvSignalPower = rx_pwr_all;
-
-               /*  (3)EVM of HT rate */
-               if (pPktinfo->Rate >= DESC92C_RATEMCS8 && pPktinfo->Rate <= DESC92C_RATEMCS15)
-                       Max_spatial_stream = 2; /* both spatial stream make sense */
-               else
-                       Max_spatial_stream = 1; /* only spatial stream 1 makes sense */
-
-               for (i = 0; i < Max_spatial_stream; i++) {
-                       /*  Do not use shift operation like "rx_evmX >>= 1" because the compilor of free build environment */
-                       /*  fill most significant bit to "zero" when doing shifting operation which may change a negative */
-                       /*  value to positive one, then the dbm value (which is supposed to be negative)  is not correct anymore. */
-                       EVM = odm_EVMdbToPercentage((pPhyStaRpt->stream_rxevm[i]));     /* dbm */
-
-                       if (pPktinfo->bPacketMatchBSSID) {
-                               if (i == RF_PATH_A) {
-                                       /*  Fill value in RFD, Get the first spatial stream only */
-                                       pPhyInfo->SignalQuality = (u8)(EVM & 0xff);
-                               }
-                               pPhyInfo->RxMIMOSignalQuality[i] = (u8)(EVM & 0xff);
-                       }
-               }
-       }
-       /* UI BSS List signal strength(in percentage), make it good looking, from 0~100. */
-       /* It is assigned to the BSS List in GetValueFromBeaconOrProbeRsp(). */
-       if (isCCKrate) {
-               pPhyInfo->SignalStrength = (u8)(odm_SignalScaleMapping(pDM_Odm, PWDB_ALL));/* PWDB_ALL; */
-       } else {
-               if (rf_rx_num != 0)
-                       pPhyInfo->SignalStrength = (u8)(odm_SignalScaleMapping(pDM_Odm, total_rssi /= rf_rx_num));
-       }
-}
-
-static void odm_Process_RSSIForDM(struct dm_odm_t *pDM_Odm,
-                                 struct phy_info *pPhyInfo,
-                                 struct odm_packet_info *pPktinfo)
-{
-       s32 UndecoratedSmoothedPWDB, UndecoratedSmoothedCCK;
-       s32 UndecoratedSmoothedOFDM, RSSI_Ave;
-       u8 isCCKrate = 0;
-       u8 RSSI_max, RSSI_min, i;
-       u32 OFDM_pkt = 0;
-       u32 Weighting = 0;
-       struct sta_info *pEntry;
-
-       if (pPktinfo->StationID == 0xFF)
-               return;
-
-       pEntry = pDM_Odm->pODM_StaInfo[pPktinfo->StationID];
-       if (!pEntry)
-               return;
-       if ((!pPktinfo->bPacketMatchBSSID))
-               return;
-
-       isCCKrate = (pPktinfo->Rate <= DESC92C_RATE11M) ? true : false;
-
-       /* Smart Antenna Debug Message------------------*/
-
-       UndecoratedSmoothedCCK =  pEntry->rssi_stat.UndecoratedSmoothedCCK;
-       UndecoratedSmoothedOFDM = pEntry->rssi_stat.UndecoratedSmoothedOFDM;
-       UndecoratedSmoothedPWDB = pEntry->rssi_stat.UndecoratedSmoothedPWDB;
-
-       if (pPktinfo->bPacketToSelf || pPktinfo->bPacketBeacon) {
-               if (!isCCKrate) { /* ofdm rate */
-                       if (pPhyInfo->RxMIMOSignalStrength[RF_PATH_B] == 0) {
-                               RSSI_Ave = pPhyInfo->RxMIMOSignalStrength[RF_PATH_A];
-                       } else {
-                               if (pPhyInfo->RxMIMOSignalStrength[RF_PATH_A] > pPhyInfo->RxMIMOSignalStrength[RF_PATH_B]) {
-                                       RSSI_max = pPhyInfo->RxMIMOSignalStrength[RF_PATH_A];
-                                       RSSI_min = pPhyInfo->RxMIMOSignalStrength[RF_PATH_B];
-                               } else {
-                                       RSSI_max = pPhyInfo->RxMIMOSignalStrength[RF_PATH_B];
-                                       RSSI_min = pPhyInfo->RxMIMOSignalStrength[RF_PATH_A];
-                               }
-                               if ((RSSI_max - RSSI_min) < 3)
-                                       RSSI_Ave = RSSI_max;
-                               else if ((RSSI_max - RSSI_min) < 6)
-                                       RSSI_Ave = RSSI_max - 1;
-                               else if ((RSSI_max - RSSI_min) < 10)
-                                       RSSI_Ave = RSSI_max - 2;
-                               else
-                                       RSSI_Ave = RSSI_max - 3;
-                       }
-
-                       /* 1 Process OFDM RSSI */
-                       if (UndecoratedSmoothedOFDM <= 0) {
-                               /*  initialize */
-                               UndecoratedSmoothedOFDM = pPhyInfo->RxPWDBAll;
-                       } else {
-                               if (pPhyInfo->RxPWDBAll > (u32)UndecoratedSmoothedOFDM) {
-                                       UndecoratedSmoothedOFDM =
-                                                       (((UndecoratedSmoothedOFDM)*(Rx_Smooth_Factor-1)) +
-                                                       (RSSI_Ave)) / (Rx_Smooth_Factor);
-                                       UndecoratedSmoothedOFDM = UndecoratedSmoothedOFDM + 1;
-                               } else {
-                                       UndecoratedSmoothedOFDM =
-                                                       (((UndecoratedSmoothedOFDM)*(Rx_Smooth_Factor-1)) +
-                                                       (RSSI_Ave)) / (Rx_Smooth_Factor);
-                               }
-                       }
-                       pEntry->rssi_stat.PacketMap =
-                               (pEntry->rssi_stat.PacketMap<<1) | BIT(0);
-               } else {
-                       RSSI_Ave = pPhyInfo->RxPWDBAll;
-
-                       /* 1 Process CCK RSSI */
-                       if (UndecoratedSmoothedCCK <= 0) {
-                               /*  initialize */
-                               UndecoratedSmoothedCCK = pPhyInfo->RxPWDBAll;
-                       } else {
-                               if (pPhyInfo->RxPWDBAll > (u32)UndecoratedSmoothedCCK) {
-                                       UndecoratedSmoothedCCK =
-                                                       (((UndecoratedSmoothedCCK)*(Rx_Smooth_Factor-1)) +
-                                                       (pPhyInfo->RxPWDBAll)) / (Rx_Smooth_Factor);
-                                       UndecoratedSmoothedCCK = UndecoratedSmoothedCCK + 1;
-                               } else {
-                                       UndecoratedSmoothedCCK =
-                                                       (((UndecoratedSmoothedCCK)*(Rx_Smooth_Factor-1)) +
-                                                       (pPhyInfo->RxPWDBAll)) / (Rx_Smooth_Factor);
-                               }
-                       }
-                       pEntry->rssi_stat.PacketMap = pEntry->rssi_stat.PacketMap<<1;
-               }
-
-               /* 2011.07.28 LukeLee: modified to prevent unstable CCK RSSI */
-               if (pEntry->rssi_stat.ValidBit >= 64)
-                       pEntry->rssi_stat.ValidBit = 64;
-               else
-                       pEntry->rssi_stat.ValidBit++;
-
-               for (i = 0; i < pEntry->rssi_stat.ValidBit; i++)
-                       OFDM_pkt +=
-                               (u8)(pEntry->rssi_stat.PacketMap>>i) & BIT(0);
-
-               if (pEntry->rssi_stat.ValidBit == 64) {
-                       Weighting = ((OFDM_pkt<<4) > 64)?64:(OFDM_pkt<<4);
-                       UndecoratedSmoothedPWDB = (Weighting*UndecoratedSmoothedOFDM+(64-Weighting)*UndecoratedSmoothedCCK)>>6;
-               } else {
-                       if (pEntry->rssi_stat.ValidBit != 0)
-                               UndecoratedSmoothedPWDB = (OFDM_pkt*UndecoratedSmoothedOFDM+(pEntry->rssi_stat.ValidBit-OFDM_pkt)*UndecoratedSmoothedCCK)/pEntry->rssi_stat.ValidBit;
-                       else
-                               UndecoratedSmoothedPWDB = 0;
-               }
-               pEntry->rssi_stat.UndecoratedSmoothedCCK = UndecoratedSmoothedCCK;
-               pEntry->rssi_stat.UndecoratedSmoothedOFDM = UndecoratedSmoothedOFDM;
-               pEntry->rssi_stat.UndecoratedSmoothedPWDB = UndecoratedSmoothedPWDB;
-       }
-}
-
-void ODM_PhyStatusQuery23a(struct dm_odm_t *pDM_Odm, struct phy_info *pPhyInfo,
-                          u8 *pPhyStatus, struct odm_packet_info *pPktinfo)
-{
-       odm_RxPhyStatus92CSeries_Parsing(pDM_Odm, pPhyInfo,
-                                        pPhyStatus, pPktinfo);
-
-       odm_Process_RSSIForDM(pDM_Odm, pPhyInfo, pPktinfo);
-}
diff --git a/drivers/staging/rtl8723au/hal/odm_RegConfig8723A.c b/drivers/staging/rtl8723au/hal/odm_RegConfig8723A.c
deleted file mode 100644 (file)
index a63c6cb..0000000
+++ /dev/null
@@ -1,88 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-
-#include "odm_precomp.h"
-#include "usb_ops_linux.h"
-
-void
-odm_ConfigRFReg_8723A(
-       struct dm_odm_t *pDM_Odm,
-       u32                                     Addr,
-       u32                                     Data,
-       enum RF_RADIO_PATH     RF_PATH,
-       u32                                 RegAddr
-       )
-{
-       if (Addr == 0xfe) {
-               msleep(50);
-       } else if (Addr == 0xfd) {
-               mdelay(5);
-       } else if (Addr == 0xfc) {
-               mdelay(1);
-       } else if (Addr == 0xfb) {
-               udelay(50);
-       } else if (Addr == 0xfa) {
-               udelay(5);
-       } else if (Addr == 0xf9) {
-               udelay(1);
-       } else {
-               ODM_SetRFReg(pDM_Odm, RF_PATH, RegAddr, bRFRegOffsetMask, Data);
-               /*  Add 1us delay between BB/RF register setting. */
-               udelay(1);
-       }
-}
-
-void odm_ConfigMAC_8723A(struct dm_odm_t *pDM_Odm, u32 addr, u8        data)
-{
-       rtl8723au_write8(pDM_Odm->Adapter, addr, data);
-       ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_LOUD,
-                    ("===> %s: [MAC_REG] %08X %08X\n", __func__, addr, data));
-}
-
-void odm_ConfigBB_AGC_8723A(struct dm_odm_t *pDM_Odm, u32 addr, u32 data)
-{
-       rtl8723au_write32(pDM_Odm->Adapter, addr, data);
-       /*  Add 1us delay between BB/RF register setting. */
-       udelay(1);
-
-       ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_LOUD,
-                    ("===> %s: [AGC_TAB] %08X %08X\n", __func__, addr, data));
-}
-
-void
-odm_ConfigBB_PHY_8723A(struct dm_odm_t *pDM_Odm, u32 addr, u32 data)
-{
-       if (addr == 0xfe)
-               msleep(50);
-       else if (addr == 0xfd)
-               mdelay(5);
-       else if (addr == 0xfc)
-               mdelay(1);
-       else if (addr == 0xfb)
-               udelay(50);
-       else if (addr == 0xfa)
-               udelay(5);
-       else if (addr == 0xf9)
-               udelay(1);
-       else if (addr == 0xa24)
-               pDM_Odm->RFCalibrateInfo.RegA24 = data;
-       rtl8723au_write32(pDM_Odm->Adapter, addr, data);
-
-       /*  Add 1us delay between BB/RF register setting. */
-       udelay(1);
-
-       ODM_RT_TRACE(pDM_Odm, ODM_COMP_INIT, ODM_DBG_LOUD,
-                    ("===> %s: [PHY_REG] %08X %08X\n", __func__, addr, data));
-}
diff --git a/drivers/staging/rtl8723au/hal/odm_debug.c b/drivers/staging/rtl8723au/hal/odm_debug.c
deleted file mode 100644 (file)
index cb2bdda..0000000
+++ /dev/null
@@ -1,39 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-
-#include "odm_precomp.h"
-
-void ODM_InitDebugSetting23a(struct dm_odm_t *pDM_Odm)
-{
-       pDM_Odm->DebugLevel = ODM_DBG_TRACE;
-       pDM_Odm->DebugComponents = 0;
-}
-
-u32 GlobalDebugLevel23A;
-
-void rt_trace(int comp, int level, const char *fmt, ...)
-{
-       struct va_format vaf;
-       va_list args;
-
-       va_start(args, fmt);
-
-       vaf.fmt = fmt;
-       vaf.va = &args;
-
-       pr_info(DRIVER_PREFIX " [0x%08x,%d] %pV", comp, level, &vaf);
-
-       va_end(args);
-}
diff --git a/drivers/staging/rtl8723au/hal/odm_interface.c b/drivers/staging/rtl8723au/hal/odm_interface.c
deleted file mode 100644 (file)
index d8f6790..0000000
+++ /dev/null
@@ -1,49 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-
-/*  */
-/*  include files */
-/*  */
-
-#include "odm_precomp.h"
-/*  */
-/*  ODM IO Relative API. */
-/*  */
-#include <usb_ops_linux.h>
-
-void ODM_SetRFReg(
-       struct dm_odm_t *pDM_Odm,
-       enum RF_RADIO_PATH      eRFPath,
-       u32                             RegAddr,
-       u32                             BitMask,
-       u32                             Data
-       )
-{
-       struct rtw_adapter *Adapter = pDM_Odm->Adapter;
-
-       PHY_SetRFReg(Adapter, eRFPath, RegAddr, BitMask, Data);
-}
-
-u32 ODM_GetRFReg(
-       struct dm_odm_t *pDM_Odm,
-       enum RF_RADIO_PATH      eRFPath,
-       u32                             RegAddr,
-       u32                             BitMask
-       )
-{
-       struct rtw_adapter *Adapter = pDM_Odm->Adapter;
-
-       return PHY_QueryRFReg(Adapter, eRFPath, RegAddr, BitMask);
-}
diff --git a/drivers/staging/rtl8723au/hal/rtl8723a_bt-coexist.c b/drivers/staging/rtl8723au/hal/rtl8723a_bt-coexist.c
deleted file mode 100644 (file)
index 47e8d69..0000000
+++ /dev/null
@@ -1,11265 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- *published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#include <drv_types.h>
-#include <rtl8723a_hal.h>
-#include <usb_ops_linux.h>
-
-#define DIS_PS_RX_BCN
-
-u32 BTCoexDbgLevel = _bt_dbg_off_;
-
-#define RTPRINT(_Comp, _Level, Fmt)\
-do {\
-       if ((BTCoexDbgLevel == _bt_dbg_on_)) {\
-               printk Fmt;\
-       }                                       \
-} while (0)
-
-#define RTPRINT_ADDR(dbgtype, dbgflag, printstr, _Ptr)\
-if ((BTCoexDbgLevel == _bt_dbg_on_)) {\
-       u32 __i;                                                \
-       u8 *ptr = (u8 *)_Ptr;   \
-       printk printstr;                                \
-       printk(" ");                                    \
-       for (__i = 0; __i < 6; __i++)           \
-               printk("%02X%s", ptr[__i], (__i == 5)?"":"-");          \
-       printk("\n");                                                   \
-}
-#define RTPRINT_DATA(dbgtype, dbgflag, _TitleString, _HexData, _HexDataLen)\
-if ((BTCoexDbgLevel == _bt_dbg_on_)) {\
-       u32 __i;                                                \
-       u8 *ptr = (u8 *)_HexData;                               \
-       printk(_TitleString);                                   \
-       for (__i = 0; __i < (u32)_HexDataLen; __i++) {          \
-               printk("%02X%s", ptr[__i], (((__i + 1) % 4) == 0)?"  ":" ");\
-               if (((__i + 1) % 16) == 0)                      \
-                       printk("\n");                           \
-       }                                                               \
-       printk("\n");                                                   \
-}
-/*  Added by Annie, 2005-11-22. */
-#define MAX_STR_LEN    64
-/*  I want to see ASCII 33 to 126 only. Otherwise, I print '?'. */
-#define PRINTABLE(_ch) (_ch >= ' ' && _ch <= '~')
-#define RT_PRINT_STR(_Comp, _Level, _TitleString, _Ptr, _Len)          \
-       {                                                               \
-               u32 __i;                                                \
-               u8 buffer[MAX_STR_LEN];                                 \
-               u32 length = (_Len < MAX_STR_LEN) ? _Len : (MAX_STR_LEN-1);\
-               memset(buffer, 0, MAX_STR_LEN);                         \
-               memcpy(buffer, (u8 *)_Ptr, length);                     \
-               for (__i = 0; __i < length; __i++) {                    \
-                       if (!PRINTABLE(buffer[__i]))                    \
-                               buffer[__i] = '?';                      \
-               }                                                       \
-               buffer[length] = '\0';                                  \
-               printk(_TitleString);                                   \
-               printk(": %d, <%s>\n", _Len, buffer);                   \
-       }
-
-#define DCMD_Printf(...)
-#define RT_ASSERT(...)
-
-
-#define GetDefaultAdapter(padapter)    padapter
-
-#define PlatformZeroMemory(ptr, sz)    memset(ptr, 0, sz)
-
-#define GET_UNDECORATED_AVERAGE_RSSI(padapter) \
-                       (GET_HAL_DATA(padapter)->dmpriv.EntryMinUndecoratedSmoothedPWDB)
-#define RT_RF_CHANGE_SOURCE u32
-
-enum {
-       RT_JOIN_INFRA   = 1,
-       RT_JOIN_IBSS  = 2,
-       RT_START_IBSS = 3,
-       RT_NO_ACTION  = 4,
-};
-
-/*  power saving */
-
-/*  ===== Below this line is sync from SD7 driver COMMOM/BT.c ===== */
-
-static u8 BT_Operation(struct rtw_adapter *padapter)
-{
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-
-       if (pBtMgnt->BtOperationOn)
-               return true;
-       else
-               return false;
-}
-
-static u8 BT_IsLegalChannel(struct rtw_adapter *padapter, u8 channel)
-{
-       struct rt_channel_info *pChanneList = NULL;
-       u8 channelLen, i;
-
-       pChanneList = padapter->mlmeextpriv.channel_set;
-       channelLen = padapter->mlmeextpriv.max_chan_nums;
-
-       for (i = 0; i < channelLen; i++) {
-               RTPRINT(FIOCTL, IOCTL_STATE,
-                       ("Check if chnl(%d) in channel plan contains bt target chnl(%d) for BT connection\n",
-                        pChanneList[i].ChannelNum, channel));
-               if ((channel == pChanneList[i].ChannelNum) ||
-                   (channel == pChanneList[i].ChannelNum + 2))
-                       return channel;
-       }
-       return 0;
-}
-
-void BT_SignalCompensation(struct rtw_adapter *padapter, u8 *rssi_wifi, u8 *rssi_bt)
-{
-       BTDM_SignalCompensation(padapter, rssi_wifi, rssi_bt);
-}
-
-void rtl8723a_BT_wifiscan_notify(struct rtw_adapter *padapter, u8 scanType)
-{
-       BTHCI_WifiScanNotify(padapter, scanType);
-       BTDM_CheckAntSelMode(padapter);
-       BTDM_WifiScanNotify(padapter, scanType);
-}
-
-void rtl8723a_BT_wifiassociate_notify(struct rtw_adapter *padapter, u8 action)
-{
-       /*  action : */
-       /*  true = associate start */
-       /*  false = associate finished */
-       if (action)
-               BTDM_CheckAntSelMode(padapter);
-
-       BTDM_WifiAssociateNotify(padapter, action);
-}
-
-void BT_HaltProcess(struct rtw_adapter *padapter)
-{
-       BTDM_ForHalt(padapter);
-}
-
-/*  ===== End of sync from SD7 driver COMMOM/BT.c ===== */
-
-#define i64fmt         "ll"
-#define UINT64_C(v)  (v)
-
-#define FillOctetString(_os, _octet, _len)             \
-       (_os).Octet = (u8 *)(_octet);                   \
-       (_os).Length = (_len);
-
-static enum rt_status PlatformIndicateBTEvent(
-       struct rtw_adapter *padapter,
-       void                                            *pEvntData,
-       u32                                             dataLen
-       )
-{
-       enum rt_status  rt_status = RT_STATUS_FAILURE;
-
-       RTPRINT(FIOCTL, IOCTL_BT_EVENT_DETAIL, ("BT event start, %d bytes data to Transferred!!\n", dataLen));
-       RTPRINT_DATA(FIOCTL, IOCTL_BT_EVENT_DETAIL, "To transfer Hex Data :\n",
-               pEvntData, dataLen);
-
-       BT_EventParse(padapter, pEvntData, dataLen);
-
-       printk(KERN_WARNING "%s: Linux has no way to report BT event!!\n", __func__);
-
-       RTPRINT(FIOCTL, IOCTL_BT_EVENT_DETAIL, ("BT event end, %s\n",
-               (rt_status == RT_STATUS_SUCCESS) ? "SUCCESS" : "FAIL"));
-
-       return rt_status;
-}
-
-/*  ===== Below this line is sync from SD7 driver COMMOM/bt_hci.c ===== */
-
-static u8 bthci_GetLocalChannel(struct rtw_adapter *padapter)
-{
-       return padapter->mlmeextpriv.cur_channel;
-}
-
-static u8 bthci_GetCurrentEntryNum(struct rtw_adapter *padapter, u8 PhyHandle)
-{
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       u8 i;
-
-       for (i = 0; i < MAX_BT_ASOC_ENTRY_NUM; i++) {
-               if ((pBTInfo->BtAsocEntry[i].bUsed) &&
-                   (pBTInfo->BtAsocEntry[i].PhyLinkCmdData.BtPhyLinkhandle == PhyHandle))
-                       return i;
-       }
-
-       return 0xFF;
-}
-
-static void bthci_DecideBTChannel(struct rtw_adapter *padapter, u8 EntryNum)
-{
-/*PMGNT_INFO pMgntInfo = &padapter->MgntInfo; */
-       struct mlme_priv *pmlmepriv;
-       struct bt_30info *pBTInfo;
-       struct bt_mgnt *pBtMgnt;
-       struct bt_hci_info *pBtHciInfo;
-       struct chnl_txpower_triple *pTriple_subband = NULL;
-       struct common_triple *pTriple;
-       u8 i, j, localchnl, firstRemoteLegalChnlInTriplet = 0;
-       u8 regulatory_skipLen = 0;
-       u8 subbandTripletCnt = 0;
-
-       pmlmepriv = &padapter->mlmepriv;
-       pBTInfo = GET_BT_INFO(padapter);
-       pBtMgnt = &pBTInfo->BtMgnt;
-       pBtHciInfo = &pBTInfo->BtHciInfo;
-
-       pBtMgnt->CheckChnlIsSuit = true;
-       localchnl = bthci_GetLocalChannel(padapter);
-
-       pTriple = (struct common_triple *)
-               &pBtHciInfo->BTPreChnllist[COUNTRY_STR_LEN];
-
-       /*  contains country string, len is 3 */
-       for (i = 0; i < (pBtHciInfo->BtPreChnlListLen-COUNTRY_STR_LEN); i += 3, pTriple++) {
-               /*  */
-               /*  check every triplet, an triplet may be */
-               /*  regulatory extension identifier or sub-band triplet */
-               /*  */
-               if (pTriple->byte_1st == 0xc9) {
-                       /*  Regulatory Extension Identifier, skip it */
-                       RTPRINT(FIOCTL, (IOCTL_BT_HCICMD|IOCTL_BT_LOGO),
-                               ("Find Regulatory ID, regulatory class = %d\n", pTriple->byte_2nd));
-                       regulatory_skipLen += 3;
-                       pTriple_subband = NULL;
-                       continue;
-               } else {        /*  Sub-band triplet */
-                       RTPRINT(FIOCTL, (IOCTL_BT_HCICMD|IOCTL_BT_LOGO), ("Find Sub-band triplet \n"));
-                       subbandTripletCnt++;
-                       pTriple_subband = (struct chnl_txpower_triple *)pTriple;
-                       /*  if remote first legal channel not found, then find first remote channel */
-                       /*  and it's legal for our channel plan. */
-
-                       /*  search the sub-band triplet and find if remote channel is legal to our channel plan. */
-                       for (j = pTriple_subband->FirstChnl; j < (pTriple_subband->FirstChnl+pTriple_subband->NumChnls); j++) {
-                               RTPRINT(FIOCTL, (IOCTL_BT_HCICMD|IOCTL_BT_LOGO), (" Check if chnl(%d) is legal\n", j));
-                               if (BT_IsLegalChannel(padapter, j)) {
-                                       /*  remote channel is legal for our channel plan. */
-                                       firstRemoteLegalChnlInTriplet = j;
-                                       RTPRINT(FIOCTL, (IOCTL_BT_HCICMD|IOCTL_BT_LOGO),
-                                               ("Find first remote legal channel : %d\n",
-                                               firstRemoteLegalChnlInTriplet));
-
-                                       /*  If we find a remote legal channel in the sub-band triplet */
-                                       /*  and only BT connection is established(local not connect to any AP or IBSS), */
-                                       /*  then we just switch channel to remote channel. */
-                                       if (!(check_fwstate(pmlmepriv, WIFI_ASOC_STATE|WIFI_ADHOC_STATE|WIFI_AP_STATE) ||
-                                           BTHCI_HsConnectionEstablished(padapter))) {
-                                               pBtMgnt->BTChannel = firstRemoteLegalChnlInTriplet;
-                                               RTPRINT(FIOCTL, (IOCTL_BT_HCICMD|IOCTL_BT_LOGO), ("Remote legal channel (%d) is selected, Local not connect to any!!\n", pBtMgnt->BTChannel));
-                                               return;
-                                       } else {
-                                               if ((localchnl >= firstRemoteLegalChnlInTriplet) &&
-                                                   (localchnl < (pTriple_subband->FirstChnl+pTriple_subband->NumChnls))) {
-                                                       pBtMgnt->BTChannel = localchnl;
-                                                       RTPRINT(FIOCTL, (IOCTL_BT_HCICMD|IOCTL_BT_LOGO), ("Local channel (%d) is selected, wifi or BT connection exists\n", pBtMgnt->BTChannel));
-                                                       return;
-                                               }
-                                       }
-                                       break;
-                               }
-                       }
-               }
-       }
-
-       if (subbandTripletCnt) {
-               /* if any preferred channel triplet exists */
-               RTPRINT(FIOCTL, (IOCTL_BT_HCICMD|IOCTL_BT_LOGO), ("There are %d sub band triplet exists, ", subbandTripletCnt));
-               if (firstRemoteLegalChnlInTriplet == 0) {
-                       /* no legal channel is found, reject the connection. */
-                       RTPRINT(FIOCTL, (IOCTL_BT_HCICMD|IOCTL_BT_LOGO), ("no legal channel is found!!\n"));
-               } else {
-                       /*  Remote Legal channel is found but not match to local */
-                       /* wifi connection exists), so reject the connection. */
-                       RTPRINT(FIOCTL, (IOCTL_BT_HCICMD|IOCTL_BT_LOGO),
-                               ("Remote Legal channel is found but not match to local(wifi connection exists)!!\n"));
-               }
-               pBtMgnt->CheckChnlIsSuit = false;
-       } else {
-               /*  There are not any preferred channel triplet exists */
-               /*  Use current legal channel as the bt channel. */
-               RTPRINT(FIOCTL, (IOCTL_BT_HCICMD|IOCTL_BT_LOGO), ("No sub band triplet exists!!\n"));
-       }
-       pBtMgnt->BTChannel = localchnl;
-       RTPRINT(FIOCTL, (IOCTL_BT_HCICMD|IOCTL_BT_LOGO), ("Local channel (%d) is selected!!\n", pBtMgnt->BTChannel));
-}
-
-/* Success:return true */
-/* Fail:return false */
-static u8 bthci_GetAssocInfo(struct rtw_adapter *padapter, u8 EntryNum)
-{
-       struct bt_30info *pBTInfo;
-       struct bt_hci_info *pBtHciInfo;
-       u8 tempBuf[256];
-       u8 i = 0;
-       u8 BaseMemoryShift = 0;
-       u16     TotalLen = 0;
-       struct amp_assoc_structure *pAmpAsoc;
-
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("GetAssocInfo start\n"));
-       pBTInfo = GET_BT_INFO(padapter);
-       pBtHciInfo = &pBTInfo->BtHciInfo;
-
-       if (pBTInfo->BtAsocEntry[EntryNum].AmpAsocCmdData.LenSoFar == 0) {
-               if (pBTInfo->BtAsocEntry[EntryNum].AmpAsocCmdData.AMPAssocRemLen < (MAX_AMP_ASSOC_FRAG_LEN))
-                       TotalLen = pBTInfo->BtAsocEntry[EntryNum].AmpAsocCmdData.AMPAssocRemLen;
-               else if (pBTInfo->BtAsocEntry[EntryNum].AmpAsocCmdData.AMPAssocRemLen == (MAX_AMP_ASSOC_FRAG_LEN))
-                       TotalLen = MAX_AMP_ASSOC_FRAG_LEN;
-       } else if (pBTInfo->BtAsocEntry[EntryNum].AmpAsocCmdData.LenSoFar > 0)
-               TotalLen = pBTInfo->BtAsocEntry[EntryNum].AmpAsocCmdData.LenSoFar;
-
-       while ((pBTInfo->BtAsocEntry[EntryNum].AmpAsocCmdData.LenSoFar >= BaseMemoryShift) || TotalLen > BaseMemoryShift) {
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD_DETAIL, ("GetAssocInfo, TotalLen =%d, BaseMemoryShift =%d\n", TotalLen, BaseMemoryShift));
-               memcpy(tempBuf,
-                       (u8 *)pBTInfo->BtAsocEntry[EntryNum].AmpAsocCmdData.AMPAssocfragment+BaseMemoryShift,
-                       TotalLen-BaseMemoryShift);
-               RTPRINT_DATA(FIOCTL, IOCTL_BT_HCICMD_DETAIL, "GetAssocInfo :\n",
-                       tempBuf, TotalLen-BaseMemoryShift);
-
-               pAmpAsoc = (struct amp_assoc_structure *)tempBuf;
-               le16_to_cpus(&pAmpAsoc->Length);
-               BaseMemoryShift += 3 + pAmpAsoc->Length;
-
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("TypeID = 0x%x, ", pAmpAsoc->TypeID));
-               RTPRINT_DATA(FIOCTL, IOCTL_BT_HCICMD, "Hex Data: \n", pAmpAsoc->Data, pAmpAsoc->Length);
-               switch (pAmpAsoc->TypeID) {
-               case AMP_MAC_ADDR:
-                       RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("==> AMP_MAC_ADDR\n"));
-                       if (pAmpAsoc->Length > 6)
-                               return false;
-                       memcpy(pBTInfo->BtAsocEntry[EntryNum].BTRemoteMACAddr, pAmpAsoc->Data, 6);
-                       RTPRINT_ADDR(FIOCTL, IOCTL_BT_HCICMD, ("Remote Mac address \n"), pBTInfo->BtAsocEntry[EntryNum].BTRemoteMACAddr);
-                       break;
-               case AMP_PREFERRED_CHANNEL_LIST:
-                       RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("==> AMP_PREFERRED_CHANNEL_LIST\n"));
-                       pBtHciInfo->BtPreChnlListLen = pAmpAsoc->Length;
-                       memcpy(pBtHciInfo->BTPreChnllist,
-                               pAmpAsoc->Data,
-                               pBtHciInfo->BtPreChnlListLen);
-                       RTPRINT_DATA(FIOCTL, IOCTL_BT_HCICMD, "Preferred channel list : \n", pBtHciInfo->BTPreChnllist, pBtHciInfo->BtPreChnlListLen);
-                       bthci_DecideBTChannel(padapter, EntryNum);
-                       break;
-               case AMP_CONNECTED_CHANNEL:
-                       RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("==> AMP_CONNECTED_CHANNEL\n"));
-                       pBtHciInfo->BTConnectChnlListLen = pAmpAsoc->Length;
-                       memcpy(pBtHciInfo->BTConnectChnllist,
-                               pAmpAsoc->Data,
-                               pBtHciInfo->BTConnectChnlListLen);
-                       break;
-               case AMP_80211_PAL_CAP_LIST:
-                       RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("==> AMP_80211_PAL_CAP_LIST\n"));
-                       pBTInfo->BtAsocEntry[EntryNum].BTCapability = *(u32 *)(pAmpAsoc->Data);
-                       if (pBTInfo->BtAsocEntry[EntryNum].BTCapability & 0x00000001) {
-                               /*  TODO: */
-
-                               /* Signifies PAL capable of utilizing received activity reports. */
-                       }
-                       if (pBTInfo->BtAsocEntry[EntryNum].BTCapability & 0x00000002) {
-                               /*  TODO: */
-                               /* Signifies PAL is capable of utilizing scheduling information received in an activity reports. */
-                       }
-                       break;
-               case AMP_80211_PAL_VISION:
-                       pBtHciInfo->BTPalVersion = *(u8 *)(pAmpAsoc->Data);
-                       pBtHciInfo->BTPalCompanyID = *(u16 *)(((u8 *)(pAmpAsoc->Data))+1);
-                       pBtHciInfo->BTPalsubversion = *(u16 *)(((u8 *)(pAmpAsoc->Data))+3);
-                       RTPRINT(FIOCTL, (IOCTL_BT_HCICMD|IOCTL_BT_LOGO), ("==> AMP_80211_PAL_VISION PalVersion  0x%x, PalCompanyID  0x%x, Palsubversion 0x%x\n",
-                               pBtHciInfo->BTPalVersion,
-                               pBtHciInfo->BTPalCompanyID,
-                               pBtHciInfo->BTPalsubversion));
-                       break;
-               default:
-                       RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("==> Unsupport TypeID !!\n"));
-                       break;
-               }
-               i++;
-       }
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("GetAssocInfo end\n"));
-
-       return true;
-}
-
-static u8 bthci_AddEntry(struct rtw_adapter *padapter)
-{
-       struct bt_30info *pBTInfo;
-       struct bt_mgnt *pBtMgnt;
-       u8 i;
-
-       pBTInfo = GET_BT_INFO(padapter);
-       pBtMgnt = &pBTInfo->BtMgnt;
-
-       for (i = 0; i < MAX_BT_ASOC_ENTRY_NUM; i++) {
-               if (pBTInfo->BtAsocEntry[i].bUsed == false) {
-                       pBTInfo->BtAsocEntry[i].bUsed = true;
-                       pBtMgnt->CurrentConnectEntryNum = i;
-                       break;
-               }
-       }
-
-       if (i == MAX_BT_ASOC_ENTRY_NUM) {
-               RTPRINT(FIOCTL, IOCTL_STATE, ("bthci_AddEntry(), Add entry fail!!\n"));
-               return false;
-       }
-       return true;
-}
-
-static u8 bthci_DiscardTxPackets(struct rtw_adapter *padapter, u16 LLH)
-{
-       return false;
-}
-
-static u8
-bthci_CheckLogLinkBehavior(
-       struct rtw_adapter *padapter,
-       struct hci_flow_spec                    TxFlowSpec
-       )
-{
-       u8 ID = TxFlowSpec.Identifier;
-       u8 ServiceType = TxFlowSpec.ServiceType;
-       u16     MaxSDUSize = TxFlowSpec.MaximumSDUSize;
-       u32     SDUInterArrivatime = TxFlowSpec.SDUInterArrivalTime;
-       u8 match = false;
-
-       switch (ID) {
-       case 1:
-               if (ServiceType == BT_LL_BE) {
-                       match = true;
-                       RTPRINT(FIOCTL, (IOCTL_BT_EVENT|IOCTL_BT_LOGO), ("Logical Link Type =  TX best effort flowspec\n"));
-               } else if ((ServiceType == BT_LL_GU) && (MaxSDUSize == 0xffff)) {
-                       match = true;
-                       RTPRINT(FIOCTL, (IOCTL_BT_EVENT|IOCTL_BT_LOGO), ("Logical Link Type =  RX guaranteed latency flowspec\n"));
-               } else if ((ServiceType == BT_LL_GU) && (MaxSDUSize == 2500)) {
-                       RTPRINT(FIOCTL, (IOCTL_BT_EVENT|IOCTL_BT_LOGO), ("Logical Link Type =  RX guaranteed Large latency flowspec\n"));
-               }
-               break;
-       case 2:
-               if (ServiceType == BT_LL_BE) {
-                       match = true;
-                       RTPRINT(FIOCTL, (IOCTL_BT_EVENT|IOCTL_BT_LOGO), ("Logical Link Type =  RX best effort flowspec\n"));
-
-               }
-               break;
-       case 3:
-               if ((ServiceType == BT_LL_GU) && (MaxSDUSize == 1492)) {
-                       match = true;
-                       RTPRINT(FIOCTL, (IOCTL_BT_EVENT|IOCTL_BT_LOGO), ("Logical Link Type =  TX guaranteed latency flowspec\n"));
-               } else if ((ServiceType == BT_LL_GU) && (MaxSDUSize == 2500)) {
-                       RTPRINT(FIOCTL, (IOCTL_BT_EVENT|IOCTL_BT_LOGO), ("Logical Link Type =  TX guaranteed Large latency flowspec\n"));
-               }
-               break;
-       case 4:
-               if (ServiceType == BT_LL_BE) {
-                       if ((SDUInterArrivatime == 0xffffffff) && (ServiceType == BT_LL_BE) && (MaxSDUSize == 1492)) {
-                               match = true;
-                               RTPRINT(FIOCTL, (IOCTL_BT_EVENT|IOCTL_BT_LOGO), ("Logical Link Type =  TX/RX aggregated best effort flowspec\n"));
-                       }
-               } else if (ServiceType == BT_LL_GU) {
-                       if (SDUInterArrivatime == 100) {
-                               match = true;
-                               RTPRINT(FIOCTL, (IOCTL_BT_EVENT|IOCTL_BT_LOGO), ("Logical Link Type =  TX/RX guaranteed bandwidth flowspec\n"));
-                       }
-               }
-               break;
-       default:
-               RTPRINT(FIOCTL, (IOCTL_BT_EVENT|IOCTL_BT_LOGO), ("Logical Link Type =  Unknow Type !!!!!!!!\n"));
-               break;
-       }
-
-       RTPRINT(FIOCTL, (IOCTL_BT_HCICMD|IOCTL_BT_LOGO),
-               ("ID = 0x%x, ServiceType = 0x%x, MaximumSDUSize = 0x%x, SDUInterArrivalTime = 0x%x, AccessLatency = 0x%x, FlushTimeout = 0x%x\n",
-               TxFlowSpec.Identifier, TxFlowSpec.ServiceType, MaxSDUSize,
-               SDUInterArrivatime, TxFlowSpec.AccessLatency, TxFlowSpec.FlushTimeout));
-       return match;
-}
-
-static u16 bthci_AssocMACAddr(struct rtw_adapter *padapter, void       *pbuf)
-{
-       struct amp_assoc_structure *pAssoStrc = (struct amp_assoc_structure *)pbuf;
-       pAssoStrc->TypeID = AMP_MAC_ADDR;
-       pAssoStrc->Length = 0x06;
-       memcpy(&pAssoStrc->Data[0], padapter->eeprompriv.mac_addr, 6);
-       RTPRINT_DATA(FIOCTL, (IOCTL_BT_HCICMD|IOCTL_BT_HCICMD_DETAIL|IOCTL_BT_LOGO),
-                    ("AssocMACAddr : \n"), pAssoStrc, pAssoStrc->Length+3);
-
-       return pAssoStrc->Length + 3;
-}
-
-static u16
-bthci_PALCapabilities(
-       struct rtw_adapter *padapter,
-       void    *pbuf
-       )
-{
-       struct amp_assoc_structure *pAssoStrc = (struct amp_assoc_structure *)pbuf;
-
-       pAssoStrc->TypeID = AMP_80211_PAL_CAP_LIST;
-       pAssoStrc->Length = 0x04;
-
-       pAssoStrc->Data[0] = 0x00;
-       pAssoStrc->Data[1] = 0x00;
-
-       RTPRINT_DATA(FIOCTL, IOCTL_BT_HCICMD_DETAIL, ("PALCapabilities:\n"), pAssoStrc, pAssoStrc->Length+3);
-       RTPRINT(FIOCTL, IOCTL_BT_LOGO, ("PALCapabilities \n"));
-
-       RTPRINT(FIOCTL, IOCTL_BT_LOGO, (" TypeID = 0x%x,\n Length = 0x%x,\n Content = 0x0000\n",
-               pAssoStrc->TypeID,
-               pAssoStrc->Length));
-
-       return pAssoStrc->Length + 3;
-}
-
-static u16 bthci_AssocPreferredChannelList(struct rtw_adapter *padapter,
-                                          void *pbuf, u8 EntryNum)
-{
-       struct bt_30info *pBTInfo;
-       struct amp_assoc_structure *pAssoStrc;
-       struct amp_pref_chnl_regulatory *pReg;
-       struct chnl_txpower_triple *pTriple;
-       char ctrString[3] = {'X', 'X', 'X'};
-       u32 len = 0;
-       u8 preferredChnl;
-
-       pBTInfo = GET_BT_INFO(padapter);
-       pAssoStrc = (struct amp_assoc_structure *)pbuf;
-       pReg = (struct amp_pref_chnl_regulatory *)&pAssoStrc->Data[3];
-
-       preferredChnl = bthci_GetLocalChannel(padapter);
-       pAssoStrc->TypeID = AMP_PREFERRED_CHANNEL_LIST;
-
-       /*  locale unknown */
-       memcpy(&pAssoStrc->Data[0], &ctrString[0], 3);
-       pReg->reXId = 201;
-       pReg->regulatoryClass = 254;
-       pReg->coverageClass = 0;
-       len += 6;
-       RTPRINT(FIOCTL, (IOCTL_BT_HCICMD | IOCTL_BT_LOGO), ("PREFERRED_CHNL_LIST\n"));
-       RTPRINT(FIOCTL, (IOCTL_BT_HCICMD | IOCTL_BT_LOGO), ("XXX, 201, 254, 0\n"));
-       /*  at the following, chnl 1~11 should be contained */
-       pTriple = (struct chnl_txpower_triple *)&pAssoStrc->Data[len];
-
-       /*  (1) if any wifi or bt HS connection exists */
-       if ((pBTInfo->BtAsocEntry[EntryNum].AMPRole == AMP_BTAP_CREATOR) ||
-           (check_fwstate(&padapter->mlmepriv, WIFI_ASOC_STATE |
-                          WIFI_ADHOC_STATE | WIFI_ADHOC_MASTER_STATE |
-                          WIFI_AP_STATE)) ||
-           BTHCI_HsConnectionEstablished(padapter)) {
-               pTriple->FirstChnl = preferredChnl;
-               pTriple->NumChnls = 1;
-               pTriple->MaxTxPowerInDbm = 20;
-               len += 3;
-               RTPRINT(FIOCTL, (IOCTL_BT_HCICMD | IOCTL_BT_LOGO), ("First Channel = %d, Channel Num = %d, MaxDbm = %d\n",
-                       pTriple->FirstChnl,
-                       pTriple->NumChnls,
-                       pTriple->MaxTxPowerInDbm));
-       }
-
-       pAssoStrc->Length = (u16)len;
-       RTPRINT_DATA(FIOCTL, IOCTL_BT_HCICMD, ("AssocPreferredChannelList : \n"), pAssoStrc, pAssoStrc->Length+3);
-
-       return pAssoStrc->Length + 3;
-}
-
-static u16 bthci_AssocPALVer(struct rtw_adapter *padapter, void *pbuf)
-{
-       struct amp_assoc_structure *pAssoStrc = (struct amp_assoc_structure *)pbuf;
-       u8 *pu1Tmp;
-       u16     *pu2Tmp;
-
-       pAssoStrc->TypeID = AMP_80211_PAL_VISION;
-       pAssoStrc->Length = 0x5;
-       pu1Tmp = &pAssoStrc->Data[0];
-       *pu1Tmp = 0x1;  /*  PAL Version */
-       pu2Tmp = (u16 *)&pAssoStrc->Data[1];
-       *pu2Tmp = 0x5D; /*  SIG Company identifier of 802.11 PAL vendor */
-       pu2Tmp = (u16 *)&pAssoStrc->Data[3];
-       *pu2Tmp = 0x1;  /*  PAL Sub-version specifier */
-
-       RTPRINT_DATA(FIOCTL, IOCTL_BT_HCICMD_DETAIL, ("AssocPALVer : \n"), pAssoStrc, pAssoStrc->Length+3);
-       RTPRINT(FIOCTL, IOCTL_BT_LOGO, ("AssocPALVer \n"));
-
-       RTPRINT(FIOCTL, IOCTL_BT_LOGO, (" TypeID = 0x%x,\n Length = 0x%x,\n PAL Version = 0x01,\n PAL vendor = 0x01,\n PAL Sub-version specifier = 0x01\n",
-               pAssoStrc->TypeID,
-               pAssoStrc->Length));
-       return pAssoStrc->Length + 3;
-}
-
-static u8 bthci_CheckRfStateBeforeConnect(struct rtw_adapter *padapter)
-{
-       struct bt_30info *pBTInfo;
-       enum rt_rf_power_state          RfState;
-
-       pBTInfo = GET_BT_INFO(padapter);
-
-       RfState = padapter->pwrctrlpriv.rf_pwrstate;
-
-       if (RfState != rf_on) {
-               mod_timer(&pBTInfo->BTPsDisableTimer,
-                         jiffies + msecs_to_jiffies(50));
-               return false;
-       }
-       return true;
-}
-
-static void bthci_ResponderStartToScan(struct rtw_adapter *padapter)
-{
-}
-
-static u8 bthci_PhyLinkConnectionInProgress(struct rtw_adapter *padapter, u8 PhyLinkHandle)
-{
-       struct bt_30info *pBTInfo;
-       struct bt_mgnt *pBtMgnt;
-
-       pBTInfo = GET_BT_INFO(padapter);
-       pBtMgnt = &pBTInfo->BtMgnt;
-
-       if (pBtMgnt->bPhyLinkInProgress &&
-               (pBtMgnt->BtCurrentPhyLinkhandle == PhyLinkHandle))
-               return true;
-       return false;
-}
-
-static void bthci_ResetFlowSpec(struct rtw_adapter *padapter, u8 EntryNum, u8 index)
-{
-       struct bt_30info *pBTinfo;
-
-       pBTinfo = GET_BT_INFO(padapter);
-
-       pBTinfo->BtAsocEntry[EntryNum].LogLinkCmdData[index].BtLogLinkhandle = 0;
-       pBTinfo->BtAsocEntry[EntryNum].LogLinkCmdData[index].BtPhyLinkhandle = 0;
-       pBTinfo->BtAsocEntry[EntryNum].LogLinkCmdData[index].bLLCompleteEventIsSet = false;
-       pBTinfo->BtAsocEntry[EntryNum].LogLinkCmdData[index].bLLCancelCMDIsSetandComplete = false;
-       pBTinfo->BtAsocEntry[EntryNum].LogLinkCmdData[index].BtTxFlowSpecID = 0;
-       pBTinfo->BtAsocEntry[EntryNum].LogLinkCmdData[index].TxPacketCount = 0;
-
-       pBTinfo->BtAsocEntry[EntryNum].LogLinkCmdData[index].Tx_Flow_Spec.Identifier = 0x01;
-       pBTinfo->BtAsocEntry[EntryNum].LogLinkCmdData[index].Tx_Flow_Spec.ServiceType = SERVICE_BEST_EFFORT;
-       pBTinfo->BtAsocEntry[EntryNum].LogLinkCmdData[index].Tx_Flow_Spec.MaximumSDUSize = 0xffff;
-       pBTinfo->BtAsocEntry[EntryNum].LogLinkCmdData[index].Tx_Flow_Spec.SDUInterArrivalTime = 0xffffffff;
-       pBTinfo->BtAsocEntry[EntryNum].LogLinkCmdData[index].Tx_Flow_Spec.AccessLatency = 0xffffffff;
-       pBTinfo->BtAsocEntry[EntryNum].LogLinkCmdData[index].Tx_Flow_Spec.FlushTimeout = 0xffffffff;
-
-       pBTinfo->BtAsocEntry[EntryNum].LogLinkCmdData[index].Rx_Flow_Spec.Identifier = 0x01;
-       pBTinfo->BtAsocEntry[EntryNum].LogLinkCmdData[index].Rx_Flow_Spec.ServiceType = SERVICE_BEST_EFFORT;
-       pBTinfo->BtAsocEntry[EntryNum].LogLinkCmdData[index].Rx_Flow_Spec.MaximumSDUSize = 0xffff;
-       pBTinfo->BtAsocEntry[EntryNum].LogLinkCmdData[index].Rx_Flow_Spec.SDUInterArrivalTime = 0xffffffff;
-       pBTinfo->BtAsocEntry[EntryNum].LogLinkCmdData[index].Rx_Flow_Spec.AccessLatency = 0xffffffff;
-       pBTinfo->BtAsocEntry[EntryNum].LogLinkCmdData[index].Rx_Flow_Spec.FlushTimeout = 0xffffffff;
-}
-
-static void bthci_ResetEntry(struct rtw_adapter *padapter, u8 EntryNum)
-{
-       struct bt_30info *pBTinfo;
-       struct bt_mgnt *pBtMgnt;
-       u8 j;
-
-       pBTinfo = GET_BT_INFO(padapter);
-       pBtMgnt = &pBTinfo->BtMgnt;
-
-       pBTinfo->BtAsocEntry[EntryNum].bUsed = false;
-       pBTinfo->BtAsocEntry[EntryNum].BtCurrentState = HCI_STATE_DISCONNECTED;
-       pBTinfo->BtAsocEntry[EntryNum].BtNextState = HCI_STATE_DISCONNECTED;
-
-       pBTinfo->BtAsocEntry[EntryNum].AmpAsocCmdData.AMPAssocRemLen = 0;
-       pBTinfo->BtAsocEntry[EntryNum].AmpAsocCmdData.BtPhyLinkhandle = 0;
-       if (pBTinfo->BtAsocEntry[EntryNum].AmpAsocCmdData.AMPAssocfragment != NULL)
-               memset(pBTinfo->BtAsocEntry[EntryNum].AmpAsocCmdData.AMPAssocfragment, 0, TOTAL_ALLOCIATE_ASSOC_LEN);
-       pBTinfo->BtAsocEntry[EntryNum].AmpAsocCmdData.LenSoFar = 0;
-
-       pBTinfo->BtAsocEntry[EntryNum].PhyLinkCmdData.BtAMPKeyType = 0;
-       pBTinfo->BtAsocEntry[EntryNum].PhyLinkCmdData.BtPhyLinkhandle = 0;
-       memset(pBTinfo->BtAsocEntry[EntryNum].PhyLinkCmdData.BtAMPKey, 0,
-              pBTinfo->BtAsocEntry[EntryNum].PhyLinkCmdData.BtAMPKeyLen);
-       pBTinfo->BtAsocEntry[EntryNum].PhyLinkCmdData.BtAMPKeyLen = 0;
-
-       /* 0x640; 0.625ms*1600 = 1000ms, 0.625ms*16000 = 10000ms */
-       pBTinfo->BtAsocEntry[EntryNum].PhyLinkCmdData.LinkSuperversionTimeout = 0x3e80;
-
-       pBTinfo->BtAsocEntry[EntryNum].AMPRole = AMP_BTAP_NONE;
-
-       pBTinfo->BtAsocEntry[EntryNum].mAssoc = false;
-       pBTinfo->BtAsocEntry[EntryNum].b4waySuccess = false;
-
-       /*  Reset BT WPA */
-       pBTinfo->BtAsocEntry[EntryNum].KeyReplayCounter = 0;
-       pBTinfo->BtAsocEntry[EntryNum].BTWPAAuthState = STATE_WPA_AUTH_UNINITIALIZED;
-
-       pBTinfo->BtAsocEntry[EntryNum].bSendSupervisionPacket = false;
-       pBTinfo->BtAsocEntry[EntryNum].NoRxPktCnt = 0;
-       pBTinfo->BtAsocEntry[EntryNum].ShortRangeMode = 0;
-       pBTinfo->BtAsocEntry[EntryNum].rxSuvpPktCnt = 0;
-
-       for (j = 0; j < MAX_LOGICAL_LINK_NUM; j++)
-               bthci_ResetFlowSpec(padapter, EntryNum, j);
-
-       pBtMgnt->BTAuthCount = 0;
-       pBtMgnt->BTAsocCount = 0;
-       pBtMgnt->BTCurrentConnectType = BT_DISCONNECT;
-       pBtMgnt->BTReceiveConnectPkt = BT_DISCONNECT;
-
-       HALBT_RemoveKey(padapter, EntryNum);
-}
-
-static void bthci_RemoveEntryByEntryNum(struct rtw_adapter *padapter, u8 EntryNum)
-{
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-
-       bthci_ResetEntry(padapter, EntryNum);
-
-       if (pBtMgnt->CurrentBTConnectionCnt > 0)
-               pBtMgnt->CurrentBTConnectionCnt--;
-
-       RTPRINT(FIOCTL, IOCTL_STATE, ("[BT Flag], CurrentBTConnectionCnt = %d!!\n",
-               pBtMgnt->CurrentBTConnectionCnt));
-
-       if (pBtMgnt->CurrentBTConnectionCnt > 0) {
-               pBtMgnt->BtOperationOn = true;
-       } else {
-               pBtMgnt->BtOperationOn = false;
-               RTPRINT(FIOCTL, IOCTL_STATE, ("[BT Flag], Bt Operation OFF!!\n"));
-       }
-
-       if (!pBtMgnt->BtOperationOn) {
-               del_timer_sync(&pBTInfo->BTHCIDiscardAclDataTimer);
-               del_timer_sync(&pBTInfo->BTBeaconTimer);
-               pBtMgnt->bStartSendSupervisionPkt = false;
-       }
-}
-
-static u8
-bthci_CommandCompleteHeader(
-       u8 *pbuf,
-       u16             OGF,
-       u16             OCF,
-       enum hci_status status
-       )
-{
-       struct packet_irp_hcievent_data *PPacketIrpEvent = (struct packet_irp_hcievent_data *)pbuf;
-       u8 NumHCI_Comm = 0x1;
-
-       PPacketIrpEvent->EventCode = HCI_EVENT_COMMAND_COMPLETE;
-       PPacketIrpEvent->Data[0] = NumHCI_Comm; /* packet # */
-       PPacketIrpEvent->Data[1] = HCIOPCODELOW(OCF, OGF);
-       PPacketIrpEvent->Data[2] = HCIOPCODEHIGHT(OCF, OGF);
-
-       if (OGF == OGF_EXTENSION) {
-               if (OCF == HCI_SET_RSSI_VALUE) {
-                       RTPRINT(FIOCTL, (IOCTL_BT_EVENT_PERIODICAL),
-                               ("[BT event], CommandComplete, Num_HCI_Comm = 0x%x, Opcode = 0x%02x%02x, status = 0x%x, OGF = 0x%x, OCF = 0x%x\n",
-                               NumHCI_Comm, (HCIOPCODEHIGHT(OCF, OGF)), (HCIOPCODELOW(OCF, OGF)), status, OGF, OCF));
-               } else {
-                       RTPRINT(FIOCTL, (IOCTL_BT_HCICMD_EXT),
-                               ("[BT event], CommandComplete, Num_HCI_Comm = 0x%x, Opcode = 0x%02x%02x, status = 0x%x, OGF = 0x%x, OCF = 0x%x\n",
-                               NumHCI_Comm, (HCIOPCODEHIGHT(OCF, OGF)), (HCIOPCODELOW(OCF, OGF)), status, OGF, OCF));
-               }
-       } else {
-               RTPRINT(FIOCTL, (IOCTL_BT_EVENT|IOCTL_BT_LOGO),
-                       ("[BT event], CommandComplete, Num_HCI_Comm = 0x%x, Opcode = 0x%02x%02x, status = 0x%x, OGF = 0x%x, OCF = 0x%x\n",
-                       NumHCI_Comm, (HCIOPCODEHIGHT(OCF, OGF)), (HCIOPCODELOW(OCF, OGF)), status, OGF, OCF));
-       }
-       return 3;
-}
-
-static u8 bthci_ExtensionEventHeaderRtk(u8 *pbuf, u8 extensionEvent)
-{
-       struct packet_irp_hcievent_data *PPacketIrpEvent = (struct packet_irp_hcievent_data *)pbuf;
-       PPacketIrpEvent->EventCode = HCI_EVENT_EXTENSION_RTK;
-       PPacketIrpEvent->Data[0] = extensionEvent;      /* extension event code */
-
-       return 1;
-}
-
-static enum rt_status
-bthci_IndicateEvent(
-       struct rtw_adapter *padapter,
-       void            *pEvntData,
-       u32             dataLen
-       )
-{
-       return PlatformIndicateBTEvent(padapter, pEvntData, dataLen);
-}
-
-static void
-bthci_EventWriteRemoteAmpAssoc(
-       struct rtw_adapter *padapter,
-       enum hci_status status,
-       u8 PLHandle
-       )
-{
-       u8 localBuf[TmpLocalBufSize] = "";
-       u8 *pRetPar;
-       u8 len = 0;
-       struct packet_irp_hcievent_data *PPacketIrpEvent;
-
-       PlatformZeroMemory(&localBuf[0], TmpLocalBufSize);
-       PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-       len += bthci_CommandCompleteHeader(&localBuf[0],
-               OGF_STATUS_PARAMETERS,
-               HCI_WRITE_REMOTE_AMP_ASSOC,
-               status);
-       RTPRINT(FIOCTL, (IOCTL_BT_HCICMD|IOCTL_BT_LOGO), ("PhyLinkHandle = 0x%x, status = %d\n", PLHandle, status));
-       /*  Return parameters starts from here */
-       pRetPar = &PPacketIrpEvent->Data[len];
-       pRetPar[0] = status;            /* status */
-       pRetPar[1] = PLHandle;
-       len += 2;
-       PPacketIrpEvent->Length = len;
-
-       bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-}
-
-static void
-bthci_EventEnhancedFlushComplete(
-       struct rtw_adapter *padapter,
-       u16                                     LLH
-       )
-{
-       u8 localBuf[4] = "";
-       struct packet_irp_hcievent_data *PPacketIrpEvent;
-
-       RTPRINT(FIOCTL, IOCTL_BT_EVENT, ("EventEnhancedFlushComplete, LLH = 0x%x\n", LLH));
-
-       PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-       PPacketIrpEvent->EventCode = HCI_EVENT_ENHANCED_FLUSH_COMPLETE;
-       PPacketIrpEvent->Length = 2;
-       /* Logical link handle */
-       PPacketIrpEvent->Data[0] = TWOBYTE_LOWBYTE(LLH);
-       PPacketIrpEvent->Data[1] = TWOBYTE_HIGHTBYTE(LLH);
-
-       bthci_IndicateEvent(padapter, PPacketIrpEvent, 4);
-}
-
-static void
-bthci_EventShortRangeModeChangeComplete(
-       struct rtw_adapter *padapter,
-       enum hci_status                         HciStatus,
-       u8              ShortRangeState,
-       u8              EntryNum
-       )
-{
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_hci_info *pBtHciInfo = &pBTInfo->BtHciInfo;
-       u8 localBuf[5] = "";
-       struct packet_irp_hcievent_data *PPacketIrpEvent;
-
-       if (!(pBtHciInfo->BTEventMaskPage2 & EMP2_HCI_EVENT_SHORT_RANGE_MODE_CHANGE_COMPLETE)) {
-               RTPRINT(FIOCTL, IOCTL_BT_EVENT,
-                       ("[BT event], Short Range Mode Change Complete, Ignore to send this event due to event mask page 2\n"));
-               return;
-       }
-       RTPRINT(FIOCTL, IOCTL_BT_EVENT, ("[BT event], Short Range Mode Change Complete, Status = %d\n , PLH = 0x%x\n, Short_Range_Mode_State = 0x%x\n",
-               HciStatus, pBTInfo->BtAsocEntry[EntryNum].PhyLinkCmdData.BtPhyLinkhandle, ShortRangeState));
-
-       PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-       PPacketIrpEvent->EventCode = HCI_EVENT_SHORT_RANGE_MODE_CHANGE_COMPLETE;
-       PPacketIrpEvent->Length = 3;
-       PPacketIrpEvent->Data[0] = HciStatus;
-       PPacketIrpEvent->Data[1] = pBTInfo->BtAsocEntry[EntryNum].PhyLinkCmdData.BtPhyLinkhandle;
-       PPacketIrpEvent->Data[2] = ShortRangeState;
-       bthci_IndicateEvent(padapter, PPacketIrpEvent, 5);
-}
-
-static void bthci_EventSendFlowSpecModifyComplete(struct rtw_adapter *padapter,
-                                                 enum hci_status HciStatus,
-                                                 u16 logicHandle)
-{
-       u8 localBuf[5] = "";
-       struct packet_irp_hcievent_data *PPacketIrpEvent;
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_hci_info *pBtHciInfo = &pBTInfo->BtHciInfo;
-
-       if (!(pBtHciInfo->BTEventMaskPage2 & EMP2_HCI_EVENT_FLOW_SPEC_MODIFY_COMPLETE)) {
-               RTPRINT(FIOCTL, (IOCTL_BT_EVENT|IOCTL_BT_LOGO),
-                       ("[BT event], Flow Spec Modify Complete, Ignore to send this event due to event mask page 2\n"));
-               return;
-       }
-       RTPRINT(FIOCTL, (IOCTL_BT_EVENT|IOCTL_BT_LOGO),
-               ("[BT event], Flow Spec Modify Complete, status = 0x%x, LLH = 0x%x\n", HciStatus, logicHandle));
-       PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-       PPacketIrpEvent->EventCode = HCI_EVENT_FLOW_SPEC_MODIFY_COMPLETE;
-       PPacketIrpEvent->Length = 3;
-
-       PPacketIrpEvent->Data[0] = HciStatus;
-       /* Logical link handle */
-       PPacketIrpEvent->Data[1] = TWOBYTE_LOWBYTE(logicHandle);
-       PPacketIrpEvent->Data[2] = TWOBYTE_HIGHTBYTE(logicHandle);
-
-       bthci_IndicateEvent(padapter, PPacketIrpEvent, 5);
-}
-
-static void
-bthci_EventExtWifiScanNotify(
-       struct rtw_adapter *padapter,
-       u8                      scanType
-       )
-{
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-       u8 len = 0;
-       u8 localBuf[7] = "";
-       u8 *pRetPar;
-       u8 *pu1Temp;
-       struct packet_irp_hcievent_data *PPacketIrpEvent;
-
-       if (!pBtMgnt->BtOperationOn)
-               return;
-
-       PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-       len += bthci_ExtensionEventHeaderRtk(&localBuf[0], HCI_EVENT_EXT_WIFI_SCAN_NOTIFY);
-
-       /*  Return parameters starts from here */
-       pRetPar = &PPacketIrpEvent->Data[len];
-       pu1Temp = (u8 *)&pRetPar[0];
-       *pu1Temp = scanType;
-       len += 1;
-
-       PPacketIrpEvent->Length = len;
-
-       if (bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2) == RT_STATUS_SUCCESS) {
-               RTPRINT(FIOCTL, IOCTL_BT_EVENT, ("[BT event], Wifi scan notify, scan type = %d\n",
-                       scanType));
-       }
-}
-
-static void
-bthci_EventAMPReceiverReport(
-       struct rtw_adapter *padapter,
-       u8 Reason
-       )
-{
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_hci_info *pBtHciInfo = &pBTInfo->BtHciInfo;
-
-       if (pBtHciInfo->bTestNeedReport) {
-               u8 localBuf[20] = "";
-               u32     *pu4Temp;
-               u16     *pu2Temp;
-               struct packet_irp_hcievent_data *PPacketIrpEvent;
-
-               RTPRINT(FIOCTL, (IOCTL_BT_EVENT|IOCTL_BT_LOGO), (" HCI_EVENT_AMP_RECEIVER_REPORT\n"));
-               PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-               PPacketIrpEvent->EventCode = HCI_EVENT_AMP_RECEIVER_REPORT;
-               PPacketIrpEvent->Length = 2;
-
-               PPacketIrpEvent->Data[0] = pBtHciInfo->TestCtrType;
-
-               PPacketIrpEvent->Data[1] = Reason;
-
-               pu4Temp = (u32 *)&PPacketIrpEvent->Data[2];
-               *pu4Temp = pBtHciInfo->TestEventType;
-
-               pu2Temp = (u16 *)&PPacketIrpEvent->Data[6];
-               *pu2Temp = pBtHciInfo->TestNumOfFrame;
-
-               pu2Temp = (u16 *)&PPacketIrpEvent->Data[8];
-               *pu2Temp = pBtHciInfo->TestNumOfErrFrame;
-
-               pu4Temp = (u32 *)&PPacketIrpEvent->Data[10];
-               *pu4Temp = pBtHciInfo->TestNumOfBits;
-
-               pu4Temp = (u32 *)&PPacketIrpEvent->Data[14];
-               *pu4Temp = pBtHciInfo->TestNumOfErrBits;
-
-               bthci_IndicateEvent(padapter, PPacketIrpEvent, 20);
-
-               /* Return to Idel state with RX and TX off. */
-
-       }
-
-       pBtHciInfo->TestNumOfFrame = 0x00;
-}
-
-static void
-bthci_EventChannelSelected(
-       struct rtw_adapter *padapter,
-       u8      EntryNum
-       )
-{
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_hci_info *pBtHciInfo = &pBTInfo->BtHciInfo;
-       u8 localBuf[3] = "";
-       struct packet_irp_hcievent_data *PPacketIrpEvent;
-
-       if (!(pBtHciInfo->BTEventMaskPage2 & EMP2_HCI_EVENT_CHANNEL_SELECT)) {
-               RTPRINT(FIOCTL, IOCTL_BT_EVENT,
-                       ("[BT event], Channel Selected, Ignore to send this event due to event mask page 2\n"));
-               return;
-       }
-
-       RTPRINT(FIOCTL, IOCTL_BT_EVENT|IOCTL_STATE,
-               ("[BT event], Channel Selected, PhyLinkHandle %d\n",
-               pBTInfo->BtAsocEntry[EntryNum].PhyLinkCmdData.BtPhyLinkhandle));
-
-       PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-       PPacketIrpEvent->EventCode = HCI_EVENT_CHANNEL_SELECT;
-       PPacketIrpEvent->Length = 1;
-       PPacketIrpEvent->Data[0] = pBTInfo->BtAsocEntry[EntryNum].PhyLinkCmdData.BtPhyLinkhandle;
-       bthci_IndicateEvent(padapter, PPacketIrpEvent, 3);
-}
-
-static void
-bthci_EventDisconnectPhyLinkComplete(
-       struct rtw_adapter *padapter,
-       enum hci_status                         HciStatus,
-       enum hci_status                         Reason,
-       u8              EntryNum
-       )
-{
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_hci_info *pBtHciInfo = &pBTInfo->BtHciInfo;
-       u8 localBuf[5] = "";
-       struct packet_irp_hcievent_data *PPacketIrpEvent;
-
-       if (!(pBtHciInfo->BTEventMaskPage2 & EMP2_HCI_EVENT_DISCONNECT_PHY_LINK_COMPLETE)) {
-               RTPRINT(FIOCTL, IOCTL_BT_EVENT,
-                       ("[BT event], Disconnect Physical Link Complete, Ignore to send this event due to event mask page 2\n"));
-               return;
-       }
-       RTPRINT(FIOCTL, IOCTL_BT_EVENT,
-               ("[BT event], Disconnect Physical Link Complete, Status = 0x%x, PLH = 0x%x Reason = 0x%x\n",
-               HciStatus, pBTInfo->BtAsocEntry[EntryNum].PhyLinkCmdData.BtPhyLinkhandle, Reason));
-       PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-       PPacketIrpEvent->EventCode = HCI_EVENT_DISCONNECT_PHY_LINK_COMPLETE;
-       PPacketIrpEvent->Length = 3;
-       PPacketIrpEvent->Data[0] = HciStatus;
-       PPacketIrpEvent->Data[1] = pBTInfo->BtAsocEntry[EntryNum].PhyLinkCmdData.BtPhyLinkhandle;
-       PPacketIrpEvent->Data[2] = Reason;
-       bthci_IndicateEvent(padapter, PPacketIrpEvent, 5);
-}
-
-static void
-bthci_EventPhysicalLinkComplete(
-       struct rtw_adapter *padapter,
-       enum hci_status                         HciStatus,
-       u8              EntryNum,
-       u8              PLHandle
-       )
-{
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-       struct bt_hci_info *pBtHciInfo = &pBTInfo->BtHciInfo;
-       struct bt_dgb *pBtDbg = &pBTInfo->BtDbg;
-       u8 localBuf[4] = "";
-       struct packet_irp_hcievent_data *PPacketIrpEvent;
-       u8 PL_handle;
-
-       pBtMgnt->bPhyLinkInProgress = false;
-       pBtDbg->dbgHciInfo.hciCmdPhyLinkStatus = HciStatus;
-       if (!(pBtHciInfo->BTEventMaskPage2 & EMP2_HCI_EVENT_PHY_LINK_COMPLETE)) {
-               RTPRINT(FIOCTL, IOCTL_BT_EVENT,
-                       ("[BT event], Physical Link Complete, Ignore to send this event due to event mask page 2\n"));
-               return;
-       }
-
-       if (EntryNum == 0xff) {
-               /*  connection not started yet, just use the input physical link handle to response. */
-               PL_handle = PLHandle;
-       } else {
-               /*  connection is under progress, use the phy link handle we recorded. */
-               PL_handle  = pBTInfo->BtAsocEntry[EntryNum].PhyLinkCmdData.BtPhyLinkhandle;
-               pBTInfo->BtAsocEntry[EntryNum].bNeedPhysLinkCompleteEvent = false;
-       }
-
-       RTPRINT(FIOCTL, IOCTL_BT_EVENT, ("[BT event], Physical Link Complete, Status = 0x%x PhyLinkHandle = 0x%x\n", HciStatus,
-               PL_handle));
-
-       PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-       PPacketIrpEvent->EventCode = HCI_EVENT_PHY_LINK_COMPLETE;
-       PPacketIrpEvent->Length = 2;
-
-       PPacketIrpEvent->Data[0] = HciStatus;
-       PPacketIrpEvent->Data[1] = PL_handle;
-       bthci_IndicateEvent(padapter, PPacketIrpEvent, 4);
-
-}
-
-static void
-bthci_EventCommandStatus(
-       struct rtw_adapter *padapter,
-       u8              OGF,
-       u16                                     OCF,
-       enum hci_status                         HciStatus
-       )
-{
-
-       u8 localBuf[6] = "";
-       struct packet_irp_hcievent_data *PPacketIrpEvent;
-       u8 Num_Hci_Comm = 0x1;
-       RTPRINT(FIOCTL, IOCTL_BT_EVENT,
-               ("[BT event], CommandStatus, Opcode = 0x%02x%02x, OGF = 0x%x,  OCF = 0x%x, Status = 0x%x, Num_HCI_COMM = 0x%x\n",
-               (HCIOPCODEHIGHT(OCF, OGF)), (HCIOPCODELOW(OCF, OGF)), OGF, OCF, HciStatus, Num_Hci_Comm));
-
-       PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-       PPacketIrpEvent->EventCode = HCI_EVENT_COMMAND_STATUS;
-       PPacketIrpEvent->Length = 4;
-       PPacketIrpEvent->Data[0] = HciStatus;   /* current pending */
-       PPacketIrpEvent->Data[1] = Num_Hci_Comm;        /* packet # */
-       PPacketIrpEvent->Data[2] = HCIOPCODELOW(OCF, OGF);
-       PPacketIrpEvent->Data[3] = HCIOPCODEHIGHT(OCF, OGF);
-
-       bthci_IndicateEvent(padapter, PPacketIrpEvent, 6);
-
-}
-
-static void
-bthci_EventLogicalLinkComplete(
-       struct rtw_adapter *padapter,
-       enum hci_status                         HciStatus,
-       u8              PhyLinkHandle,
-       u16                                     LogLinkHandle,
-       u8              LogLinkIndex,
-       u8              EntryNum
-       )
-{
-/*PMGNT_INFO pMgntInfo = &padapter->MgntInfo; */
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_hci_info *pBtHciInfo = &pBTInfo->BtHciInfo;
-       u8 localBuf[7] = "";
-       struct packet_irp_hcievent_data *PPacketIrpEvent;
-
-       if (!(pBtHciInfo->BTEventMaskPage2 & EMP2_HCI_EVENT_LOGICAL_LINK_COMPLETE)) {
-               RTPRINT(FIOCTL, IOCTL_BT_EVENT,
-                       ("[BT event], Logical Link Complete, Ignore to send this event due to event mask page 2\n"));
-               return;
-       }
-       RTPRINT(FIOCTL, IOCTL_BT_EVENT, ("[BT event], Logical Link Complete, PhyLinkHandle = 0x%x,  LogLinkHandle = 0x%x, Status = 0x%x\n",
-               PhyLinkHandle, LogLinkHandle, HciStatus));
-
-       PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-       PPacketIrpEvent->EventCode = HCI_EVENT_LOGICAL_LINK_COMPLETE;
-       PPacketIrpEvent->Length = 5;
-
-       PPacketIrpEvent->Data[0] = HciStatus;/* status code */
-       /* Logical link handle */
-       PPacketIrpEvent->Data[1] = TWOBYTE_LOWBYTE(LogLinkHandle);
-       PPacketIrpEvent->Data[2] = TWOBYTE_HIGHTBYTE(LogLinkHandle);
-       /* Physical link handle */
-       PPacketIrpEvent->Data[3] = TWOBYTE_LOWBYTE(PhyLinkHandle);
-       /* corresponding Tx flow spec ID */
-       if (HciStatus == HCI_STATUS_SUCCESS) {
-               PPacketIrpEvent->Data[4] =
-                       pBTInfo->BtAsocEntry[EntryNum].LogLinkCmdData[LogLinkIndex].Tx_Flow_Spec.Identifier;
-       } else {
-               PPacketIrpEvent->Data[4] = 0x0;
-       }
-
-       bthci_IndicateEvent(padapter, PPacketIrpEvent, 7);
-}
-
-static void
-bthci_EventDisconnectLogicalLinkComplete(
-       struct rtw_adapter *padapter,
-       enum hci_status                         HciStatus,
-       u16                                     LogLinkHandle,
-       enum hci_status                         Reason
-       )
-{
-       u8 localBuf[6] = "";
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_hci_info *pBtHciInfo = &pBTInfo->BtHciInfo;
-       struct packet_irp_hcievent_data *PPacketIrpEvent;
-
-       if (!(pBtHciInfo->BTEventMaskPage2 & EMP2_HCI_EVENT_DISCONNECT_LOGICAL_LINK_COMPLETE)) {
-               RTPRINT(FIOCTL, IOCTL_BT_EVENT, ("[BT event], Disconnect Logical Link Complete, Ignore to send this event due to event mask page 2\n"));
-               return;
-       }
-       RTPRINT(FIOCTL, IOCTL_BT_EVENT, ("[BT event], Disconnect Logical Link Complete, Status = 0x%x, LLH = 0x%x Reason = 0x%x\n", HciStatus, LogLinkHandle, Reason));
-
-       PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-       PPacketIrpEvent->EventCode = HCI_EVENT_DISCONNECT_LOGICAL_LINK_COMPLETE;
-       PPacketIrpEvent->Length = 4;
-
-       PPacketIrpEvent->Data[0] = HciStatus;
-       /* Logical link handle */
-       PPacketIrpEvent->Data[1] = TWOBYTE_LOWBYTE(LogLinkHandle);
-       PPacketIrpEvent->Data[2] = TWOBYTE_HIGHTBYTE(LogLinkHandle);
-       /* Disconnect reason */
-       PPacketIrpEvent->Data[3] = Reason;
-
-       bthci_IndicateEvent(padapter, PPacketIrpEvent, 6);
-}
-
-static void
-bthci_EventFlushOccurred(
-       struct rtw_adapter *padapter,
-       u16                                     LogLinkHandle
-       )
-{
-       u8 localBuf[4] = "";
-       struct packet_irp_hcievent_data *PPacketIrpEvent;
-       RTPRINT(FIOCTL, IOCTL_BT_EVENT, ("bthci_EventFlushOccurred(), LLH = 0x%x\n", LogLinkHandle));
-
-       PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-       PPacketIrpEvent->EventCode = HCI_EVENT_FLUSH_OCCRUED;
-       PPacketIrpEvent->Length = 2;
-       /* Logical link handle */
-       PPacketIrpEvent->Data[0] = TWOBYTE_LOWBYTE(LogLinkHandle);
-       PPacketIrpEvent->Data[1] = TWOBYTE_HIGHTBYTE(LogLinkHandle);
-
-       bthci_IndicateEvent(padapter, PPacketIrpEvent, 4);
-}
-
-static enum hci_status
-bthci_BuildPhysicalLink(
-       struct rtw_adapter *padapter,
-       struct packet_irp_hcicmd_data *pHciCmd,
-       u16     OCF
-)
-{
-       enum hci_status         status = HCI_STATUS_SUCCESS;
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-       u8 EntryNum, PLH;
-
-       /* Send HCI Command status event to AMP. */
-       bthci_EventCommandStatus(padapter,
-                       LINK_CONTROL_COMMANDS,
-                       OCF,
-                       HCI_STATUS_SUCCESS);
-
-       PLH = *((u8 *)pHciCmd->Data);
-
-       /*  Check if resource or bt connection is under progress, if yes, reject the link creation. */
-       if (!bthci_AddEntry(padapter)) {
-               status = HCI_STATUS_CONNECT_RJT_LIMIT_RESOURCE;
-               bthci_EventPhysicalLinkComplete(padapter, status, INVALID_ENTRY_NUM, PLH);
-               return status;
-       }
-
-       EntryNum = pBtMgnt->CurrentConnectEntryNum;
-       pBTInfo->BtAsocEntry[EntryNum].PhyLinkCmdData.BtPhyLinkhandle = PLH;
-       pBtMgnt->BtCurrentPhyLinkhandle = PLH;
-
-       if (pBTInfo->BtAsocEntry[EntryNum].AmpAsocCmdData.AMPAssocfragment == NULL) {
-               RTPRINT(FIOCTL, (IOCTL_BT_HCICMD|IOCTL_BT_LOGO), ("Create/Accept PhysicalLink, AMP controller is busy\n"));
-               status = HCI_STATUS_CONTROLLER_BUSY;
-               bthci_EventPhysicalLinkComplete(padapter, status, INVALID_ENTRY_NUM, PLH);
-               return status;
-       }
-
-       /*  Record Key and the info */
-       pBTInfo->BtAsocEntry[EntryNum].PhyLinkCmdData.BtAMPKeyLen = (*((u8 *)pHciCmd->Data+1));
-       pBTInfo->BtAsocEntry[EntryNum].PhyLinkCmdData.BtAMPKeyType = (*((u8 *)pHciCmd->Data+2));
-       memcpy(pBTInfo->BtAsocEntry[EntryNum].PhyLinkCmdData.BtAMPKey,
-               (((u8 *)pHciCmd->Data+3)), pBTInfo->BtAsocEntry[EntryNum].PhyLinkCmdData.BtAMPKeyLen);
-       memcpy(pBTInfo->BtAsocEntry[EntryNum].PMK, pBTInfo->BtAsocEntry[EntryNum].PhyLinkCmdData.BtAMPKey, PMK_LEN);
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("BuildPhysicalLink, EntryNum = %d, PLH = 0x%x  KeyLen = 0x%x, KeyType = 0x%x\n",
-               EntryNum, pBTInfo->BtAsocEntry[EntryNum].PhyLinkCmdData.BtPhyLinkhandle,
-               pBTInfo->BtAsocEntry[EntryNum].PhyLinkCmdData.BtAMPKeyLen,
-               pBTInfo->BtAsocEntry[EntryNum].PhyLinkCmdData.BtAMPKeyType));
-       RTPRINT_DATA(FIOCTL, (IOCTL_BT_LOGO|IOCTL_BT_HCICMD), ("BtAMPKey\n"), pBTInfo->BtAsocEntry[EntryNum].PhyLinkCmdData.BtAMPKey,
-               pBTInfo->BtAsocEntry[EntryNum].PhyLinkCmdData.BtAMPKeyLen);
-       RTPRINT_DATA(FIOCTL, (IOCTL_BT_LOGO|IOCTL_BT_HCICMD), ("PMK\n"), pBTInfo->BtAsocEntry[EntryNum].PMK,
-               PMK_LEN);
-
-       if (OCF == HCI_CREATE_PHYSICAL_LINK) {
-               /* These macros require braces */
-               BTHCI_SM_WITH_INFO(padapter, HCI_STATE_DISCONNECTED, STATE_CMD_CREATE_PHY_LINK, EntryNum);
-       } else if (OCF == HCI_ACCEPT_PHYSICAL_LINK) {
-               BTHCI_SM_WITH_INFO(padapter, HCI_STATE_DISCONNECTED, STATE_CMD_ACCEPT_PHY_LINK, EntryNum);
-       }
-
-       return status;
-}
-
-static void
-bthci_BuildLogicalLink(
-       struct rtw_adapter *padapter,
-       struct packet_irp_hcicmd_data *pHciCmd,
-       u16 OCF
-       )
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-       struct bt_30info *pBTinfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTinfo->BtMgnt;
-       u8 PhyLinkHandle, EntryNum;
-       static u16 AssignLogHandle = 1;
-
-       struct hci_flow_spec    TxFlowSpec;
-       struct hci_flow_spec    RxFlowSpec;
-       u32     MaxSDUSize, ArriveTime, Bandwidth;
-
-       PhyLinkHandle = *((u8 *)pHciCmd->Data);
-
-       EntryNum = bthci_GetCurrentEntryNum(padapter, PhyLinkHandle);
-
-       memcpy(&TxFlowSpec,
-               &pHciCmd->Data[1], sizeof(struct hci_flow_spec));
-       memcpy(&RxFlowSpec,
-               &pHciCmd->Data[17], sizeof(struct hci_flow_spec));
-
-       MaxSDUSize = TxFlowSpec.MaximumSDUSize;
-       ArriveTime = TxFlowSpec.SDUInterArrivalTime;
-
-       if (bthci_CheckLogLinkBehavior(padapter, TxFlowSpec) && bthci_CheckLogLinkBehavior(padapter, RxFlowSpec))
-               Bandwidth = BTTOTALBANDWIDTH;
-       else if (MaxSDUSize == 0xffff && ArriveTime == 0xffffffff)
-               Bandwidth = BTTOTALBANDWIDTH;
-       else
-               Bandwidth = MaxSDUSize*8*1000/(ArriveTime+244);
-
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD,
-               ("BuildLogicalLink, PhyLinkHandle = 0x%x, MaximumSDUSize = 0x%x, SDUInterArrivalTime = 0x%x, Bandwidth = 0x%x\n",
-               PhyLinkHandle, MaxSDUSize, ArriveTime, Bandwidth));
-
-       if (EntryNum == 0xff) {
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("Invalid Physical Link handle = 0x%x, status = HCI_STATUS_UNKNOW_CONNECT_ID, return\n", PhyLinkHandle));
-               status = HCI_STATUS_UNKNOW_CONNECT_ID;
-
-               /* When we receive Create/Accept logical link command, we should send command status event first. */
-               bthci_EventCommandStatus(padapter,
-                       LINK_CONTROL_COMMANDS,
-                       OCF,
-                       status);
-               return;
-       }
-
-       if (!pBtMgnt->bLogLinkInProgress) {
-               if (bthci_PhyLinkConnectionInProgress(padapter, PhyLinkHandle)) {
-                       RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("Physical link connection in progress, status = HCI_STATUS_CMD_DISALLOW, return\n"));
-                       status = HCI_STATUS_CMD_DISALLOW;
-
-                       pBtMgnt->bPhyLinkInProgressStartLL = true;
-                       /* When we receive Create/Accept logical link command, we should send command status event first. */
-                       bthci_EventCommandStatus(padapter,
-                               LINK_CONTROL_COMMANDS,
-                               OCF,
-                               status);
-
-                       return;
-               }
-
-               if (Bandwidth > BTTOTALBANDWIDTH) {
-                       RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("status = HCI_STATUS_QOS_REJECT, Bandwidth = 0x%x, return\n", Bandwidth));
-                       status = HCI_STATUS_QOS_REJECT;
-
-                       /* When we receive Create/Accept logical link command, we should send command status event first. */
-                       bthci_EventCommandStatus(padapter,
-                               LINK_CONTROL_COMMANDS,
-                               OCF,
-                               status);
-               } else {
-                       RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("status = HCI_STATUS_SUCCESS\n"));
-                       status = HCI_STATUS_SUCCESS;
-
-                       /* When we receive Create/Accept logical link command, we should send command status event first. */
-                       bthci_EventCommandStatus(padapter,
-                               LINK_CONTROL_COMMANDS,
-                               OCF,
-                               status);
-
-               }
-
-               if (pBTinfo->BtAsocEntry[EntryNum].BtCurrentState != HCI_STATE_CONNECTED) {
-                       bthci_EventLogicalLinkComplete(padapter,
-                               HCI_STATUS_CMD_DISALLOW, 0, 0, 0, EntryNum);
-               } else {
-                       u8 i, find = 0;
-
-                       pBtMgnt->bLogLinkInProgress = true;
-
-                       /*  find an unused logical link index and copy the data */
-                       for (i = 0; i < MAX_LOGICAL_LINK_NUM; i++) {
-                               if (pBTinfo->BtAsocEntry[EntryNum].LogLinkCmdData[i].BtLogLinkhandle == 0) {
-                                       enum hci_status LogCompEventstatus = HCI_STATUS_SUCCESS;
-
-                                       pBTinfo->BtAsocEntry[EntryNum].LogLinkCmdData[i].BtPhyLinkhandle = *((u8 *)pHciCmd->Data);
-                                       pBTinfo->BtAsocEntry[EntryNum].LogLinkCmdData[i].BtLogLinkhandle = AssignLogHandle;
-                                       RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("BuildLogicalLink, EntryNum = %d, physical link handle = 0x%x, logical link handle = 0x%x\n",
-                                               EntryNum, pBTinfo->BtAsocEntry[EntryNum].PhyLinkCmdData.BtPhyLinkhandle,
-                                                                 pBTinfo->BtAsocEntry[EntryNum].LogLinkCmdData[i].BtLogLinkhandle));
-                                       memcpy(&pBTinfo->BtAsocEntry[EntryNum].LogLinkCmdData[i].Tx_Flow_Spec,
-                                               &TxFlowSpec, sizeof(struct hci_flow_spec));
-                                       memcpy(&pBTinfo->BtAsocEntry[EntryNum].LogLinkCmdData[i].Rx_Flow_Spec,
-                                               &RxFlowSpec, sizeof(struct hci_flow_spec));
-
-                                       pBTinfo->BtAsocEntry[EntryNum].LogLinkCmdData[i].bLLCompleteEventIsSet = false;
-
-                                       if (pBTinfo->BtAsocEntry[EntryNum].LogLinkCmdData[i].bLLCancelCMDIsSetandComplete)
-                                               LogCompEventstatus = HCI_STATUS_UNKNOW_CONNECT_ID;
-                                       bthci_EventLogicalLinkComplete(padapter,
-                                               LogCompEventstatus,
-                                               pBTinfo->BtAsocEntry[EntryNum].LogLinkCmdData[i].BtPhyLinkhandle,
-                                               pBTinfo->BtAsocEntry[EntryNum].LogLinkCmdData[i].BtLogLinkhandle, i, EntryNum);
-
-                                       pBTinfo->BtAsocEntry[EntryNum].LogLinkCmdData[i].bLLCompleteEventIsSet = true;
-
-                                       find = 1;
-                                       pBtMgnt->BtCurrentLogLinkhandle = AssignLogHandle;
-                                       AssignLogHandle++;
-                                       break;
-                               }
-                       }
-
-                       if (!find) {
-                               bthci_EventLogicalLinkComplete(padapter,
-                                       HCI_STATUS_CONNECT_RJT_LIMIT_RESOURCE, 0, 0, 0, EntryNum);
-                       }
-                       pBtMgnt->bLogLinkInProgress = false;
-               }
-       } else {
-               bthci_EventLogicalLinkComplete(padapter,
-                       HCI_STATUS_CONTROLLER_BUSY, 0, 0, 0, EntryNum);
-       }
-
-}
-
-static void
-bthci_StartBeaconAndConnect(
-       struct rtw_adapter *padapter,
-       struct packet_irp_hcicmd_data *pHciCmd,
-       u8 CurrentAssocNum
-       )
-{
-/*PMGNT_INFO pMgntInfo = &padapter->MgntInfo; */
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("StartBeaconAndConnect, CurrentAssocNum =%d, AMPRole =%d\n",
-               CurrentAssocNum,
-               pBTInfo->BtAsocEntry[CurrentAssocNum].AMPRole));
-
-       if (!pBtMgnt->CheckChnlIsSuit) {
-               bthci_EventPhysicalLinkComplete(padapter, HCI_STATUS_CONNECT_REJ_NOT_SUIT_CHNL_FOUND, CurrentAssocNum, INVALID_PL_HANDLE);
-               bthci_RemoveEntryByEntryNum(padapter, CurrentAssocNum);
-               return;
-       }
-
-       if (pBTInfo->BtAsocEntry[CurrentAssocNum].AMPRole == AMP_BTAP_CREATOR) {
-               snprintf((char *)pBTInfo->BtAsocEntry[CurrentAssocNum].BTSsidBuf, 32,
-                        "AMP-%pMF", padapter->eeprompriv.mac_addr);
-       } else if (pBTInfo->BtAsocEntry[CurrentAssocNum].AMPRole == AMP_BTAP_JOINER) {
-               snprintf((char *)pBTInfo->BtAsocEntry[CurrentAssocNum].BTSsidBuf, 32,
-                        "AMP-%pMF", pBTInfo->BtAsocEntry[CurrentAssocNum].BTRemoteMACAddr);
-       }
-
-       FillOctetString(pBTInfo->BtAsocEntry[CurrentAssocNum].BTSsid, pBTInfo->BtAsocEntry[CurrentAssocNum].BTSsidBuf, 21);
-       pBTInfo->BtAsocEntry[CurrentAssocNum].BTSsid.Length = 21;
-
-       /* To avoid set the start ap or connect twice, or the original connection will be disconnected. */
-       if (!pBtMgnt->bBTConnectInProgress) {
-               pBtMgnt->bBTConnectInProgress = true;
-               RTPRINT(FIOCTL, IOCTL_STATE, ("[BT Flag], BT Connect in progress ON!!\n"));
-               BTHCI_SM_WITH_INFO(padapter, HCI_STATE_STARTING, STATE_CMD_MAC_START_COMPLETE, CurrentAssocNum);
-
-               /*  20100325 Joseph: Check RF ON/OFF. */
-               /*  If RF OFF, it reschedule connecting operation after 50ms. */
-               if (!bthci_CheckRfStateBeforeConnect(padapter))
-                       return;
-
-               if (pBTInfo->BtAsocEntry[CurrentAssocNum].AMPRole == AMP_BTAP_CREATOR) {
-                       /* These macros need braces */
-                       BTHCI_SM_WITH_INFO(padapter, HCI_STATE_CONNECTING, STATE_CMD_MAC_CONNECT_COMPLETE, CurrentAssocNum);
-               } else if (pBTInfo->BtAsocEntry[CurrentAssocNum].AMPRole == AMP_BTAP_JOINER) {
-                       bthci_ResponderStartToScan(padapter);
-               }
-       }
-       RT_PRINT_STR(_module_rtl871x_mlme_c_, _drv_notice_,
-                    "StartBeaconAndConnect, SSID:\n",
-                    pBTInfo->BtAsocEntry[pBtMgnt->CurrentConnectEntryNum].BTSsid.Octet,
-                    pBTInfo->BtAsocEntry[pBtMgnt->CurrentConnectEntryNum].BTSsid.Length);
-}
-
-static void bthci_ResetBtMgnt(struct bt_mgnt *pBtMgnt)
-{
-       pBtMgnt->BtOperationOn = false;
-       pBtMgnt->bBTConnectInProgress = false;
-       pBtMgnt->bLogLinkInProgress = false;
-       pBtMgnt->bPhyLinkInProgress = false;
-       pBtMgnt->bPhyLinkInProgressStartLL = false;
-       pBtMgnt->DisconnectEntryNum = 0xff;
-       pBtMgnt->bStartSendSupervisionPkt = false;
-       pBtMgnt->JoinerNeedSendAuth = false;
-       pBtMgnt->CurrentBTConnectionCnt = 0;
-       pBtMgnt->BTCurrentConnectType = BT_DISCONNECT;
-       pBtMgnt->BTReceiveConnectPkt = BT_DISCONNECT;
-       pBtMgnt->BTAuthCount = 0;
-       pBtMgnt->btLogoTest = 0;
-}
-
-static void bthci_ResetBtHciInfo(struct bt_hci_info *pBtHciInfo)
-{
-       pBtHciInfo->BTEventMask = 0;
-       pBtHciInfo->BTEventMaskPage2 = 0;
-       pBtHciInfo->ConnAcceptTimeout =  10000;
-       pBtHciInfo->PageTimeout  =  0x30;
-       pBtHciInfo->LocationDomainAware = 0x0;
-       pBtHciInfo->LocationDomain = 0x5858;
-       pBtHciInfo->LocationDomainOptions = 0x58;
-       pBtHciInfo->LocationOptions = 0x0;
-       pBtHciInfo->FlowControlMode = 0x1;      /*  0:Packet based data flow control mode(BR/EDR), 1: Data block based data flow control mode(AMP). */
-
-       pBtHciInfo->enFlush_LLH = 0;
-       pBtHciInfo->FLTO_LLH = 0;
-
-       /* Test command only */
-       pBtHciInfo->bTestIsEnd = true;
-       pBtHciInfo->bInTestMode = false;
-       pBtHciInfo->bTestNeedReport = false;
-       pBtHciInfo->TestScenario = 0xff;
-       pBtHciInfo->TestReportInterval = 0x01;
-       pBtHciInfo->TestCtrType = 0x5d;
-       pBtHciInfo->TestEventType = 0x00;
-       pBtHciInfo->TestNumOfFrame = 0;
-       pBtHciInfo->TestNumOfErrFrame = 0;
-       pBtHciInfo->TestNumOfBits = 0;
-       pBtHciInfo->TestNumOfErrBits = 0;
-}
-
-static void bthci_ResetBtSec(struct rtw_adapter *padapter, struct bt_security *pBtSec)
-{
-/*PMGNT_INFO   pMgntInfo = &padapter->MgntInfo; */
-
-       /*  Set BT used HW or SW encrypt !! */
-       if (GET_HAL_DATA(padapter)->bBTMode)
-               pBtSec->bUsedHwEncrypt = true;
-       else
-               pBtSec->bUsedHwEncrypt = false;
-       RT_TRACE(_module_rtl871x_security_c_, _drv_info_,
-                "%s: bUsedHwEncrypt =%d\n", __func__, pBtSec->bUsedHwEncrypt);
-
-       pBtSec->RSNIE.Octet = pBtSec->RSNIEBuf;
-}
-
-static void bthci_ResetBtExtInfo(struct bt_mgnt *pBtMgnt)
-{
-       u8 i;
-
-       for (i = 0; i < MAX_BT_ASOC_ENTRY_NUM; i++) {
-               pBtMgnt->ExtConfig.linkInfo[i].ConnectHandle = 0;
-               pBtMgnt->ExtConfig.linkInfo[i].IncomingTrafficMode = 0;
-               pBtMgnt->ExtConfig.linkInfo[i].OutgoingTrafficMode = 0;
-               pBtMgnt->ExtConfig.linkInfo[i].BTProfile = BT_PROFILE_NONE;
-               pBtMgnt->ExtConfig.linkInfo[i].BTCoreSpec = BT_SPEC_2_1_EDR;
-               pBtMgnt->ExtConfig.linkInfo[i].BT_RSSI = 0;
-               pBtMgnt->ExtConfig.linkInfo[i].TrafficProfile = BT_PROFILE_NONE;
-               pBtMgnt->ExtConfig.linkInfo[i].linkRole = BT_LINK_MASTER;
-       }
-
-       pBtMgnt->ExtConfig.CurrentConnectHandle = 0;
-       pBtMgnt->ExtConfig.CurrentIncomingTrafficMode = 0;
-       pBtMgnt->ExtConfig.CurrentOutgoingTrafficMode = 0;
-       pBtMgnt->ExtConfig.MIN_BT_RSSI = 0;
-       pBtMgnt->ExtConfig.NumberOfHandle = 0;
-       pBtMgnt->ExtConfig.NumberOfSCO = 0;
-       pBtMgnt->ExtConfig.CurrentBTStatus = 0;
-       pBtMgnt->ExtConfig.HCIExtensionVer = 0;
-
-       pBtMgnt->ExtConfig.bManualControl = false;
-       pBtMgnt->ExtConfig.bBTBusy = false;
-       pBtMgnt->ExtConfig.bBTA2DPBusy = false;
-}
-
-static enum hci_status bthci_CmdReset(struct rtw_adapter *_padapter, u8 bNeedSendEvent)
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-       struct rtw_adapter *padapter;
-/*PMGNT_INFO pMgntInfo = &padapter->MgntInfo; */
-       struct bt_30info *pBTInfo;
-       struct bt_mgnt *pBtMgnt;
-       struct bt_hci_info *pBtHciInfo;
-       struct bt_security *pBtSec;
-       struct bt_dgb *pBtDbg;
-       u8 i;
-
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("bthci_CmdReset()\n"));
-
-       padapter = GetDefaultAdapter(_padapter);
-       pBTInfo = GET_BT_INFO(padapter);
-       pBtMgnt = &pBTInfo->BtMgnt;
-       pBtHciInfo = &pBTInfo->BtHciInfo;
-       pBtSec = &pBTInfo->BtSec;
-       pBtDbg = &pBTInfo->BtDbg;
-
-       pBTInfo->padapter = padapter;
-
-       for (i = 0; i < MAX_BT_ASOC_ENTRY_NUM; i++)
-               bthci_ResetEntry(padapter, i);
-
-       bthci_ResetBtMgnt(pBtMgnt);
-       bthci_ResetBtHciInfo(pBtHciInfo);
-       bthci_ResetBtSec(padapter, pBtSec);
-
-       pBtMgnt->BTChannel = BT_Default_Chnl;
-       pBtMgnt->CheckChnlIsSuit = true;
-
-       pBTInfo->BTBeaconTmrOn = false;
-
-       pBtMgnt->bCreateSpportQos = true;
-
-       del_timer_sync(&pBTInfo->BTHCIDiscardAclDataTimer);
-       del_timer_sync(&pBTInfo->BTBeaconTimer);
-
-       HALBT_SetRtsCtsNoLenLimit(padapter);
-       /*  */
-       /*  Maybe we need to take care Group != AES case !! */
-       /*  now we Pairwise and Group all used AES !! */
-
-       bthci_ResetBtExtInfo(pBtMgnt);
-
-       /* send command complete event here when all data are received. */
-       if (bNeedSendEvent) {
-               u8 localBuf[6] = "";
-               u8 *pRetPar;
-               u8 len = 0;
-               struct packet_irp_hcievent_data *PPacketIrpEvent;
-
-               PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-               len += bthci_CommandCompleteHeader(&localBuf[0],
-                       OGF_SET_EVENT_MASK_COMMAND,
-                       HCI_RESET,
-                       status);
-
-               /*  Return parameters starts from here */
-               pRetPar = &PPacketIrpEvent->Data[len];
-               pRetPar[0] = status;            /* status */
-               len += 1;
-               PPacketIrpEvent->Length = len;
-
-               bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-       }
-
-       return status;
-}
-
-static enum hci_status
-bthci_CmdWriteRemoteAMPAssoc(
-       struct rtw_adapter *padapter,
-       struct packet_irp_hcicmd_data *pHciCmd
-       )
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_dgb *pBtDbg = &pBTInfo->BtDbg;
-       u8 CurrentAssocNum;
-       u8 PhyLinkHandle;
-
-       pBtDbg->dbgHciInfo.hciCmdCntWriteRemoteAmpAssoc++;
-       PhyLinkHandle = *((u8 *)pHciCmd->Data);
-       CurrentAssocNum = bthci_GetCurrentEntryNum(padapter, PhyLinkHandle);
-
-       if (CurrentAssocNum == 0xff) {
-               RTPRINT(FIOCTL, (IOCTL_BT_HCICMD|IOCTL_BT_LOGO), ("WriteRemoteAMPAssoc, No such Handle in the Entry\n"));
-               status = HCI_STATUS_UNKNOW_CONNECT_ID;
-               bthci_EventWriteRemoteAmpAssoc(padapter, status, PhyLinkHandle);
-               return status;
-       }
-
-       if (pBTInfo->BtAsocEntry[CurrentAssocNum].AmpAsocCmdData.AMPAssocfragment == NULL) {
-               RTPRINT(FIOCTL, (IOCTL_BT_HCICMD|IOCTL_BT_LOGO), ("WriteRemoteAMPAssoc, AMP controller is busy\n"));
-               status = HCI_STATUS_CONTROLLER_BUSY;
-               bthci_EventWriteRemoteAmpAssoc(padapter, status, PhyLinkHandle);
-               return status;
-       }
-
-       pBTInfo->BtAsocEntry[CurrentAssocNum].AmpAsocCmdData.BtPhyLinkhandle = PhyLinkHandle;/* u8 *)pHciCmd->Data); */
-       pBTInfo->BtAsocEntry[CurrentAssocNum].AmpAsocCmdData.LenSoFar = *((u16 *)((u8 *)pHciCmd->Data+1));
-       pBTInfo->BtAsocEntry[CurrentAssocNum].AmpAsocCmdData.AMPAssocRemLen = *((u16 *)((u8 *)pHciCmd->Data+3));
-
-       RTPRINT(FIOCTL, (IOCTL_BT_HCICMD_DETAIL|IOCTL_BT_LOGO), ("WriteRemoteAMPAssoc, LenSoFar = 0x%x, AssocRemLen = 0x%x\n",
-               pBTInfo->BtAsocEntry[CurrentAssocNum].AmpAsocCmdData.LenSoFar,
-               pBTInfo->BtAsocEntry[CurrentAssocNum].AmpAsocCmdData.AMPAssocRemLen));
-
-       RTPRINT_DATA(FIOCTL, (IOCTL_BT_HCICMD_DETAIL|IOCTL_BT_LOGO),
-                    ("WriteRemoteAMPAssoc fragment \n"),
-                    pHciCmd->Data,
-                    pBTInfo->BtAsocEntry[CurrentAssocNum].AmpAsocCmdData.AMPAssocRemLen+5);
-       if ((pBTInfo->BtAsocEntry[CurrentAssocNum].AmpAsocCmdData.AMPAssocRemLen) > MAX_AMP_ASSOC_FRAG_LEN) {
-               memcpy(((u8 *)pBTInfo->BtAsocEntry[CurrentAssocNum].AmpAsocCmdData.AMPAssocfragment+(pBTInfo->BtAsocEntry[CurrentAssocNum].AmpAsocCmdData.LenSoFar*(sizeof(u8)))),
-                       (u8 *)pHciCmd->Data+5,
-                       MAX_AMP_ASSOC_FRAG_LEN);
-       } else {
-               memcpy((u8 *)(pBTInfo->BtAsocEntry[CurrentAssocNum].AmpAsocCmdData.AMPAssocfragment)+(pBTInfo->BtAsocEntry[CurrentAssocNum].AmpAsocCmdData.LenSoFar*(sizeof(u8))),
-                       ((u8 *)pHciCmd->Data+5),
-                       (pBTInfo->BtAsocEntry[CurrentAssocNum].AmpAsocCmdData.AMPAssocRemLen));
-
-               RTPRINT_DATA(FIOCTL, (IOCTL_BT_HCICMD_DETAIL|IOCTL_BT_LOGO), "WriteRemoteAMPAssoc :\n",
-                       pHciCmd->Data+5, pBTInfo->BtAsocEntry[CurrentAssocNum].AmpAsocCmdData.AMPAssocRemLen);
-
-               if (!bthci_GetAssocInfo(padapter, CurrentAssocNum))
-                       status = HCI_STATUS_INVALID_HCI_CMD_PARA_VALUE;
-
-               bthci_EventWriteRemoteAmpAssoc(padapter, status, PhyLinkHandle);
-
-               bthci_StartBeaconAndConnect(padapter, pHciCmd, CurrentAssocNum);
-       }
-
-       return status;
-}
-
-/* 7.3.13 */
-static enum hci_status bthci_CmdReadConnectionAcceptTimeout(struct rtw_adapter *padapter)
-{
-       enum hci_status         status = HCI_STATUS_SUCCESS;
-/*PMGNT_INFO           pMgntInfo = &padapter->MgntInfo; */
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_hci_info *pBtHciInfo = &pBTInfo->BtHciInfo;
-       u8 localBuf[8] = "";
-       u8 *pRetPar;
-       u8 len = 0;
-       struct packet_irp_hcievent_data *PPacketIrpEvent;
-       u16 *pu2Temp;
-
-       PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-       len += bthci_CommandCompleteHeader(&localBuf[0],
-               OGF_SET_EVENT_MASK_COMMAND,
-               HCI_READ_CONNECTION_ACCEPT_TIMEOUT,
-               status);
-
-       /*  Return parameters starts from here */
-       pRetPar = &PPacketIrpEvent->Data[len];
-       pRetPar[0] = status;            /* status */
-       pu2Temp = (u16 *)&pRetPar[1];           /*  Conn_Accept_Timeout */
-       *pu2Temp = pBtHciInfo->ConnAcceptTimeout;
-       len += 3;
-       PPacketIrpEvent->Length = len;
-
-       bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-
-       return status;
-}
-
-/* 7.3.14 */
-static enum hci_status
-bthci_CmdWriteConnectionAcceptTimeout(
-       struct rtw_adapter *padapter,
-       struct packet_irp_hcicmd_data *pHciCmd
-       )
-{
-       enum hci_status         status = HCI_STATUS_SUCCESS;
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_hci_info *pBtHciInfo = &pBTInfo->BtHciInfo;
-       u16     *pu2Temp;
-       u8 localBuf[6] = "";
-       u8 *pRetPar;
-       u8 len = 0;
-       struct packet_irp_hcievent_data *PPacketIrpEvent;
-
-       pu2Temp = (u16 *)&pHciCmd->Data[0];
-       pBtHciInfo->ConnAcceptTimeout = *pu2Temp;
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD_DETAIL, ("ConnAcceptTimeout = 0x%x",
-               pBtHciInfo->ConnAcceptTimeout));
-
-       /* send command complete event here when all data are received. */
-       PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-       len += bthci_CommandCompleteHeader(&localBuf[0],
-               OGF_SET_EVENT_MASK_COMMAND,
-               HCI_WRITE_CONNECTION_ACCEPT_TIMEOUT,
-               status);
-
-       /*  Return parameters starts from here */
-       pRetPar = &PPacketIrpEvent->Data[len];
-       pRetPar[0] = status;            /* status */
-       len += 1;
-       PPacketIrpEvent->Length = len;
-
-       bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-
-       return status;
-}
-
-static enum hci_status
-bthci_CmdReadPageTimeout(
-       struct rtw_adapter *padapter,
-       struct packet_irp_hcicmd_data *pHciCmd
-       )
-{
-       enum hci_status         status = HCI_STATUS_SUCCESS;
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_hci_info *pBtHciInfo = &pBTInfo->BtHciInfo;
-       u8 localBuf[8] = "";
-       u8 *pRetPar;
-       u8 len = 0;
-       struct packet_irp_hcievent_data *PPacketIrpEvent;
-       u16 *pu2Temp;
-
-       PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-       len += bthci_CommandCompleteHeader(&localBuf[0],
-               OGF_SET_EVENT_MASK_COMMAND,
-               HCI_READ_PAGE_TIMEOUT,
-               status);
-
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("Read PageTimeout = 0x%x\n", pBtHciInfo->PageTimeout));
-       /*  Return parameters starts from here */
-       pRetPar = &PPacketIrpEvent->Data[len];
-       pRetPar[0] = status;            /* status */
-       pu2Temp = (u16 *)&pRetPar[1];           /*  Page_Timeout */
-       *pu2Temp = pBtHciInfo->PageTimeout;
-       len += 3;
-       PPacketIrpEvent->Length = len;
-
-       bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-
-       return status;
-}
-
-static enum hci_status
-bthci_CmdWritePageTimeout(
-       struct rtw_adapter *padapter,
-       struct packet_irp_hcicmd_data *pHciCmd
-       )
-{
-       enum hci_status         status = HCI_STATUS_SUCCESS;
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_hci_info *pBtHciInfo = &pBTInfo->BtHciInfo;
-       u16     *pu2Temp;
-
-       pu2Temp = (u16 *)&pHciCmd->Data[0];
-       pBtHciInfo->PageTimeout = *pu2Temp;
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("Write PageTimeout = 0x%x\n",
-               pBtHciInfo->PageTimeout));
-
-       /* send command complete event here when all data are received. */
-       {
-               u8 localBuf[6] = "";
-               u8 *pRetPar;
-               u8 len = 0;
-               struct packet_irp_hcievent_data *PPacketIrpEvent;
-
-               PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-               len += bthci_CommandCompleteHeader(&localBuf[0],
-                       OGF_SET_EVENT_MASK_COMMAND,
-                       HCI_WRITE_PAGE_TIMEOUT,
-                       status);
-
-               /*  Return parameters starts from here */
-               pRetPar = &PPacketIrpEvent->Data[len];
-               pRetPar[0] = status;            /* status */
-               len += 1;
-               PPacketIrpEvent->Length = len;
-
-               bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-       }
-
-       return status;
-}
-
-static enum hci_status
-bthci_CmdReadLinkSupervisionTimeout(
-       struct rtw_adapter *padapter,
-       struct packet_irp_hcicmd_data *pHciCmd
-       )
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-       struct bt_30info *pBTinfo = GET_BT_INFO(padapter);
-       u8 physicalLinkHandle, EntryNum;
-
-       physicalLinkHandle = *((u8 *)pHciCmd->Data);
-
-       EntryNum = bthci_GetCurrentEntryNum(padapter, physicalLinkHandle);
-
-       if (EntryNum == 0xff) {
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("ReadLinkSupervisionTimeout, No such Handle in the Entry\n"));
-               status = HCI_STATUS_UNKNOW_CONNECT_ID;
-               return status;
-       }
-
-       if (pBTinfo->BtAsocEntry[EntryNum].PhyLinkCmdData.BtPhyLinkhandle != physicalLinkHandle)
-               status = HCI_STATUS_UNKNOW_CONNECT_ID;
-
-       {
-               u8 localBuf[10] = "";
-               u8 *pRetPar;
-               u8 len = 0;
-               struct packet_irp_hcievent_data *PPacketIrpEvent;
-               u16 *pu2Temp;
-
-               PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-               len += bthci_CommandCompleteHeader(&localBuf[0],
-                       OGF_SET_EVENT_MASK_COMMAND,
-                       HCI_READ_LINK_SUPERVISION_TIMEOUT,
-                       status);
-
-               /*  Return parameters starts from here */
-               pRetPar = &PPacketIrpEvent->Data[len];
-               pRetPar[0] = status;
-               pRetPar[1] = pBTinfo->BtAsocEntry[EntryNum].PhyLinkCmdData.BtPhyLinkhandle;
-               pRetPar[2] = 0;
-               pu2Temp = (u16 *)&pRetPar[3];           /*  Conn_Accept_Timeout */
-               *pu2Temp = pBTinfo->BtAsocEntry[EntryNum].PhyLinkCmdData.LinkSuperversionTimeout;
-               len += 5;
-               PPacketIrpEvent->Length = len;
-
-               bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-       }
-
-       return status;
-}
-
-static enum hci_status
-bthci_CmdWriteLinkSupervisionTimeout(
-       struct rtw_adapter *padapter,
-       struct packet_irp_hcicmd_data *pHciCmd
-       )
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-       struct bt_30info *pBTinfo = GET_BT_INFO(padapter);
-       u8 physicalLinkHandle, EntryNum;
-
-       physicalLinkHandle = *((u8 *)pHciCmd->Data);
-
-       EntryNum = bthci_GetCurrentEntryNum(padapter, physicalLinkHandle);
-
-       if (EntryNum == 0xff) {
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("WriteLinkSupervisionTimeout, No such Handle in the Entry\n"));
-               status = HCI_STATUS_UNKNOW_CONNECT_ID;
-       } else {
-               if (pBTinfo->BtAsocEntry[EntryNum].PhyLinkCmdData.BtPhyLinkhandle != physicalLinkHandle) {
-                       status = HCI_STATUS_UNKNOW_CONNECT_ID;
-               } else {
-                       pBTinfo->BtAsocEntry[EntryNum].PhyLinkCmdData.LinkSuperversionTimeout = *((u16 *)(((u8 *)pHciCmd->Data)+2));
-                       RTPRINT(FIOCTL, IOCTL_STATE, ("BT Write LinkSuperversionTimeout[%d] = 0x%x\n",
-                               EntryNum, pBTinfo->BtAsocEntry[EntryNum].PhyLinkCmdData.LinkSuperversionTimeout));
-               }
-       }
-
-       {
-               u8 localBuf[8] = "";
-               u8 *pRetPar;
-               u8 len = 0;
-               struct packet_irp_hcievent_data *PPacketIrpEvent;
-
-               PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-               len += bthci_CommandCompleteHeader(&localBuf[0],
-                       OGF_SET_EVENT_MASK_COMMAND,
-                       HCI_WRITE_LINK_SUPERVISION_TIMEOUT,
-                       status);
-
-               /*  Return parameters starts from here */
-               pRetPar = &PPacketIrpEvent->Data[len];
-               pRetPar[0] = status;
-               pRetPar[1] = pBTinfo->BtAsocEntry[EntryNum].PhyLinkCmdData.BtPhyLinkhandle;
-               pRetPar[2] = 0;
-               len += 3;
-               PPacketIrpEvent->Length = len;
-
-               bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-       }
-
-       return status;
-}
-
-static enum hci_status
-bthci_CmdEnhancedFlush(
-       struct rtw_adapter *padapter,
-       struct packet_irp_hcicmd_data *pHciCmd
-       )
-{
-       enum hci_status         status = HCI_STATUS_SUCCESS;
-       struct bt_30info *pBTinfo = GET_BT_INFO(padapter);
-       struct bt_hci_info *pBtHciInfo = &pBTinfo->BtHciInfo;
-       u16             logicHandle;
-       u8 Packet_Type;
-
-       logicHandle = *((u16 *)&pHciCmd->Data[0]);
-       Packet_Type = pHciCmd->Data[2];
-
-       if (Packet_Type != 0)
-               status = HCI_STATUS_INVALID_HCI_CMD_PARA_VALUE;
-       else
-               pBtHciInfo->enFlush_LLH = logicHandle;
-
-       if (bthci_DiscardTxPackets(padapter, pBtHciInfo->enFlush_LLH))
-               bthci_EventFlushOccurred(padapter, pBtHciInfo->enFlush_LLH);
-
-       /*  should send command status event */
-       bthci_EventCommandStatus(padapter,
-                       OGF_SET_EVENT_MASK_COMMAND,
-                       HCI_ENHANCED_FLUSH,
-                       status);
-
-       if (pBtHciInfo->enFlush_LLH) {
-               bthci_EventEnhancedFlushComplete(padapter, pBtHciInfo->enFlush_LLH);
-               pBtHciInfo->enFlush_LLH = 0;
-       }
-
-       return status;
-}
-
-static enum hci_status
-bthci_CmdReadLogicalLinkAcceptTimeout(
-       struct rtw_adapter *padapter,
-       struct packet_irp_hcicmd_data *pHciCmd
-       )
-{
-       enum hci_status         status = HCI_STATUS_SUCCESS;
-/*PMGNT_INFO           pMgntInfo = &padapter->MgntInfo; */
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_hci_info *pBtHciInfo = &pBTInfo->BtHciInfo;
-       u8 localBuf[8] = "";
-       u8 *pRetPar;
-       u8 len = 0;
-       struct packet_irp_hcievent_data *PPacketIrpEvent;
-       u16 *pu2Temp;
-
-       PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-       len += bthci_CommandCompleteHeader(&localBuf[0],
-               OGF_SET_EVENT_MASK_COMMAND,
-               HCI_READ_LOGICAL_LINK_ACCEPT_TIMEOUT,
-               status);
-
-       /*  Return parameters starts from here */
-       pRetPar = &PPacketIrpEvent->Data[len];
-       pRetPar[0] = status;
-
-       pu2Temp = (u16 *)&pRetPar[1];           /*  Conn_Accept_Timeout */
-       *pu2Temp = pBtHciInfo->LogicalAcceptTimeout;
-       len += 3;
-       PPacketIrpEvent->Length = len;
-
-       bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-
-       return status;
-}
-
-static enum hci_status
-bthci_CmdWriteLogicalLinkAcceptTimeout(
-       struct rtw_adapter *padapter,
-       struct packet_irp_hcicmd_data *pHciCmd
-       )
-{
-       enum hci_status         status = HCI_STATUS_SUCCESS;
-/*PMGNT_INFO           pMgntInfo = &padapter->MgntInfo; */
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_hci_info *pBtHciInfo = &pBTInfo->BtHciInfo;
-       u8 localBuf[6] = "";
-       u8 *pRetPar;
-       u8 len = 0;
-       struct packet_irp_hcievent_data *PPacketIrpEvent;
-
-       pBtHciInfo->LogicalAcceptTimeout = *((u16 *)pHciCmd->Data);
-
-       PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-       len += bthci_CommandCompleteHeader(&localBuf[0],
-               OGF_SET_EVENT_MASK_COMMAND,
-               HCI_WRITE_LOGICAL_LINK_ACCEPT_TIMEOUT,
-               status);
-
-       /*  Return parameters starts from here */
-       pRetPar = &PPacketIrpEvent->Data[len];
-       pRetPar[0] = status;
-
-       len += 1;
-       PPacketIrpEvent->Length = len;
-
-       bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-       return status;
-}
-
-static enum hci_status
-bthci_CmdSetEventMask(
-       struct rtw_adapter *padapter,
-       struct packet_irp_hcicmd_data *pHciCmd
-       )
-{
-       enum hci_status         status = HCI_STATUS_SUCCESS;
-/*PMGNT_INFO           pMgntInfo = &padapter->MgntInfo; */
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_hci_info *pBtHciInfo = &pBTInfo->BtHciInfo;
-       u8 *pu8Temp;
-       u8 localBuf[6] = "";
-       u8 *pRetPar;
-       u8 len = 0;
-       struct packet_irp_hcievent_data *PPacketIrpEvent;
-
-       pu8Temp = (u8 *)&pHciCmd->Data[0];
-       pBtHciInfo->BTEventMask = *pu8Temp;
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD_DETAIL, ("BTEventMask = 0x%"i64fmt"x\n",
-               pBtHciInfo->BTEventMask));
-
-       /* send command complete event here when all data are received. */
-       PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-       len += bthci_CommandCompleteHeader(&localBuf[0],
-               OGF_SET_EVENT_MASK_COMMAND,
-               HCI_SET_EVENT_MASK,
-               status);
-
-       /*  Return parameters starts from here */
-       pRetPar = &PPacketIrpEvent->Data[len];
-       pRetPar[0] = status;            /* status */
-       len += 1;
-       PPacketIrpEvent->Length = len;
-
-       bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-
-       return status;
-}
-
-/*  7.3.69 */
-static enum hci_status
-bthci_CmdSetEventMaskPage2(
-       struct rtw_adapter *padapter,
-       struct packet_irp_hcicmd_data *pHciCmd
-       )
-{
-       enum hci_status         status = HCI_STATUS_SUCCESS;
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_hci_info *pBtHciInfo = &pBTInfo->BtHciInfo;
-       u8 *pu8Temp;
-       u8 localBuf[6] = "";
-       u8 *pRetPar;
-       u8 len = 0;
-       struct packet_irp_hcievent_data *PPacketIrpEvent;
-
-       pu8Temp = (u8 *)&pHciCmd->Data[0];
-       pBtHciInfo->BTEventMaskPage2 = *pu8Temp;
-       RTPRINT(FIOCTL, (IOCTL_BT_HCICMD_DETAIL|IOCTL_BT_LOGO), ("BTEventMaskPage2 = 0x%"i64fmt"x\n",
-               pBtHciInfo->BTEventMaskPage2));
-
-       /* send command complete event here when all data are received. */
-       PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-       len += bthci_CommandCompleteHeader(&localBuf[0],
-               OGF_SET_EVENT_MASK_COMMAND,
-               HCI_SET_EVENT_MASK_PAGE_2,
-               status);
-
-       /*  Return parameters starts from here */
-       pRetPar = &PPacketIrpEvent->Data[len];
-       pRetPar[0] = status;            /* status */
-       len += 1;
-       PPacketIrpEvent->Length = len;
-
-       bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-
-       return status;
-}
-
-static enum hci_status
-bthci_CmdReadLocationData(
-       struct rtw_adapter *padapter,
-       struct packet_irp_hcicmd_data *pHciCmd
-       )
-{
-       enum hci_status         status = HCI_STATUS_SUCCESS;
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_hci_info *pBtHciInfo = &pBTInfo->BtHciInfo;
-       u8 localBuf[12] = "";
-       u8 *pRetPar;
-       u8 len = 0;
-       struct packet_irp_hcievent_data *PPacketIrpEvent;
-       u16 *pu2Temp;
-
-       PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-       len += bthci_CommandCompleteHeader(&localBuf[0],
-               OGF_SET_EVENT_MASK_COMMAND,
-               HCI_READ_LOCATION_DATA,
-               status);
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("DomainAware = 0x%x\n", pBtHciInfo->LocationDomainAware));
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("Domain = 0x%x\n", pBtHciInfo->LocationDomain));
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("DomainOptions = 0x%x\n", pBtHciInfo->LocationDomainOptions));
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("Options = 0x%x\n", pBtHciInfo->LocationOptions));
-
-       /*  Return parameters starts from here */
-       pRetPar = &PPacketIrpEvent->Data[len];
-       pRetPar[0] = status;
-
-       pRetPar[1] = pBtHciInfo->LocationDomainAware;   /* 0x0;  Location_Domain_Aware */
-       pu2Temp = (u16 *)&pRetPar[2];                                   /*  Location_Domain */
-       *pu2Temp = pBtHciInfo->LocationDomain;          /* 0x5858; */
-       pRetPar[4] = pBtHciInfo->LocationDomainOptions; /* 0x58;        Location_Domain_Options */
-       pRetPar[5] = pBtHciInfo->LocationOptions;               /* 0x0; Location_Options */
-       len += 6;
-       PPacketIrpEvent->Length = len;
-
-       bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-       return status;
-}
-
-static enum hci_status
-bthci_CmdWriteLocationData(
-       struct rtw_adapter *padapter,
-       struct packet_irp_hcicmd_data *pHciCmd
-       )
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_hci_info *pBtHciInfo = &pBTInfo->BtHciInfo;
-       u16     *pu2Temp;
-       u8 localBuf[6] = "";
-       u8 *pRetPar;
-       u8 len = 0;
-       struct packet_irp_hcievent_data *PPacketIrpEvent;
-
-       pBtHciInfo->LocationDomainAware = pHciCmd->Data[0];
-       pu2Temp = (u16 *)&pHciCmd->Data[1];
-       pBtHciInfo->LocationDomain = *pu2Temp;
-       pBtHciInfo->LocationDomainOptions = pHciCmd->Data[3];
-       pBtHciInfo->LocationOptions = pHciCmd->Data[4];
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("DomainAware = 0x%x\n", pBtHciInfo->LocationDomainAware));
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("Domain = 0x%x\n", pBtHciInfo->LocationDomain));
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("DomainOptions = 0x%x\n", pBtHciInfo->LocationDomainOptions));
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("Options = 0x%x\n", pBtHciInfo->LocationOptions));
-
-       /* send command complete event here when all data are received. */
-       PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-       len += bthci_CommandCompleteHeader(&localBuf[0],
-               OGF_SET_EVENT_MASK_COMMAND,
-               HCI_WRITE_LOCATION_DATA,
-               status);
-
-       /*  Return parameters starts from here */
-       pRetPar = &PPacketIrpEvent->Data[len];
-       pRetPar[0] = status;            /* status */
-       len += 1;
-       PPacketIrpEvent->Length = len;
-
-       bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-
-       return status;
-}
-
-static enum hci_status
-bthci_CmdReadFlowControlMode(
-       struct rtw_adapter *padapter,
-       struct packet_irp_hcicmd_data *pHciCmd
-       )
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_hci_info *pBtHciInfo = &pBTInfo->BtHciInfo;
-       u8 localBuf[7] = "";
-       u8 *pRetPar;
-       u8 len = 0;
-       struct packet_irp_hcievent_data *PPacketIrpEvent;
-
-       PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-       len += bthci_CommandCompleteHeader(&localBuf[0],
-               OGF_SET_EVENT_MASK_COMMAND,
-               HCI_READ_FLOW_CONTROL_MODE,
-               status);
-
-       /*  Return parameters starts from here */
-       pRetPar = &PPacketIrpEvent->Data[len];
-       pRetPar[0] = status;
-       pRetPar[1] = pBtHciInfo->FlowControlMode;       /*  Flow Control Mode */
-       len += 2;
-       PPacketIrpEvent->Length = len;
-
-       bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-       return status;
-}
-
-static enum hci_status
-bthci_CmdWriteFlowControlMode(
-       struct rtw_adapter *padapter,
-       struct packet_irp_hcicmd_data *pHciCmd
-       )
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_hci_info *pBtHciInfo = &pBTInfo->BtHciInfo;
-       u8 localBuf[6] = "";
-       u8 *pRetPar;
-       u8 len = 0;
-       struct packet_irp_hcievent_data *PPacketIrpEvent;
-
-       pBtHciInfo->FlowControlMode = pHciCmd->Data[0];
-
-       /* send command complete event here when all data are received. */
-       PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-       len += bthci_CommandCompleteHeader(&localBuf[0],
-               OGF_SET_EVENT_MASK_COMMAND,
-               HCI_WRITE_FLOW_CONTROL_MODE,
-               status);
-
-       /*  Return parameters starts from here */
-       pRetPar = &PPacketIrpEvent->Data[len];
-       pRetPar[0] = status;            /* status */
-       len += 1;
-       PPacketIrpEvent->Length = len;
-
-       bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-
-       return status;
-}
-
-static enum hci_status
-bthci_CmdReadBestEffortFlushTimeout(
-       struct rtw_adapter *padapter,
-       struct packet_irp_hcicmd_data *pHciCmd
-       )
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-       struct bt_30info *pBTinfo = GET_BT_INFO(padapter);
-       u16 i, j, logicHandle;
-       u32 BestEffortFlushTimeout = 0xffffffff;
-       u8 find = 0;
-
-       logicHandle = *((u16 *)pHciCmd->Data);
-       /*  find an matched logical link index and copy the data */
-       for (j = 0; j < MAX_BT_ASOC_ENTRY_NUM; j++) {
-               for (i = 0; i < MAX_LOGICAL_LINK_NUM; i++) {
-                       if (pBTinfo->BtAsocEntry[j].LogLinkCmdData[i].BtLogLinkhandle == logicHandle) {
-                               BestEffortFlushTimeout = pBTinfo->BtAsocEntry[j].LogLinkCmdData[i].BestEffortFlushTimeout;
-                               find = 1;
-                               break;
-                       }
-               }
-       }
-
-       if (!find)
-               status = HCI_STATUS_UNKNOW_CONNECT_ID;
-
-       {
-               u8 localBuf[10] = "";
-               u8 *pRetPar;
-               u8 len = 0;
-               struct packet_irp_hcievent_data *PPacketIrpEvent;
-               u32 *pu4Temp;
-
-               PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-               len += bthci_CommandCompleteHeader(&localBuf[0],
-                       OGF_SET_EVENT_MASK_COMMAND,
-                       HCI_READ_BEST_EFFORT_FLUSH_TIMEOUT,
-                       status);
-
-               /*  Return parameters starts from here */
-               pRetPar = &PPacketIrpEvent->Data[len];
-               pRetPar[0] = status;
-               pu4Temp = (u32 *)&pRetPar[1];   /*  Best_Effort_Flush_Timeout */
-               *pu4Temp = BestEffortFlushTimeout;
-               len += 5;
-               PPacketIrpEvent->Length = len;
-
-               bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-       }
-       return status;
-}
-
-static enum hci_status
-bthci_CmdWriteBestEffortFlushTimeout(
-       struct rtw_adapter *padapter,
-       struct packet_irp_hcicmd_data *pHciCmd
-       )
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-       struct bt_30info *pBTinfo = GET_BT_INFO(padapter);
-       u16 i, j, logicHandle;
-       u32 BestEffortFlushTimeout = 0xffffffff;
-       u8 find = 0;
-
-       logicHandle = *((u16 *)pHciCmd->Data);
-       BestEffortFlushTimeout = *((u32 *)(pHciCmd->Data+1));
-
-       /*  find an matched logical link index and copy the data */
-       for (j = 0; j < MAX_BT_ASOC_ENTRY_NUM; j++) {
-               for (i = 0; i < MAX_LOGICAL_LINK_NUM; i++) {
-                       if (pBTinfo->BtAsocEntry[j].LogLinkCmdData[i].BtLogLinkhandle == logicHandle) {
-                               pBTinfo->BtAsocEntry[j].LogLinkCmdData[i].BestEffortFlushTimeout = BestEffortFlushTimeout;
-                               find = 1;
-                               break;
-                       }
-               }
-       }
-
-       if (!find)
-               status = HCI_STATUS_UNKNOW_CONNECT_ID;
-
-       {
-               u8 localBuf[6] = "";
-               u8 *pRetPar;
-               u8 len = 0;
-               struct packet_irp_hcievent_data *PPacketIrpEvent;
-
-               PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-               len += bthci_CommandCompleteHeader(&localBuf[0],
-                       OGF_SET_EVENT_MASK_COMMAND,
-                       HCI_WRITE_BEST_EFFORT_FLUSH_TIMEOUT,
-                       status);
-
-               /*  Return parameters starts from here */
-               pRetPar = &PPacketIrpEvent->Data[len];
-               pRetPar[0] = status;
-               len += 1;
-               PPacketIrpEvent->Length = len;
-
-               bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-       }
-       return status;
-}
-
-static enum hci_status
-bthci_CmdShortRangeMode(
-       struct rtw_adapter *padapter,
-       struct packet_irp_hcicmd_data *pHciCmd
-       )
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       u8 PhyLinkHandle, EntryNum, ShortRangeMode;
-
-       PhyLinkHandle = pHciCmd->Data[0];
-       ShortRangeMode = pHciCmd->Data[1];
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("PLH = 0x%x, Short_Range_Mode = 0x%x\n", PhyLinkHandle, ShortRangeMode));
-
-       EntryNum = bthci_GetCurrentEntryNum(padapter, PhyLinkHandle);
-       if (EntryNum != 0xff) {
-               pBTInfo->BtAsocEntry[EntryNum].ShortRangeMode = ShortRangeMode;
-       } else {
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("No such PLH(0x%x)\n", PhyLinkHandle));
-               status = HCI_STATUS_UNKNOW_CONNECT_ID;
-       }
-
-       bthci_EventCommandStatus(padapter,
-                       OGF_SET_EVENT_MASK_COMMAND,
-                       HCI_SHORT_RANGE_MODE,
-                       status);
-
-       bthci_EventShortRangeModeChangeComplete(padapter, status, ShortRangeMode, EntryNum);
-
-       return status;
-}
-
-static enum hci_status bthci_CmdReadLocalSupportedCommands(struct rtw_adapter *padapter)
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-       u8 localBuf[TmpLocalBufSize] = "";
-       u8 *pRetPar, *pSupportedCmds;
-       u8 len = 0;
-       struct packet_irp_hcievent_data *PPacketIrpEvent;
-
-       /*  send command complete event here when all data are received. */
-       PlatformZeroMemory(&localBuf[0], TmpLocalBufSize);
-       PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-       len += bthci_CommandCompleteHeader(&localBuf[0],
-               OGF_INFORMATIONAL_PARAMETERS,
-               HCI_READ_LOCAL_SUPPORTED_COMMANDS,
-               status);
-
-       /*  Return parameters starts from here */
-       pRetPar = &PPacketIrpEvent->Data[len];
-       pRetPar[0] = status;            /* status */
-       len += 1;
-       pSupportedCmds = &pRetPar[1];
-       RTPRINT(FIOCTL, (IOCTL_BT_HCICMD|IOCTL_BT_LOGO), ("Octet[5]= 0xc0\nBit [6]= Set Event Mask, [7]= Reset\n"));
-       pSupportedCmds[5] = 0xc0;
-       RTPRINT(FIOCTL, (IOCTL_BT_HCICMD|IOCTL_BT_LOGO), ("Octet[6]= 0x01\nBit [0]= Set Event Filter\n"));
-       pSupportedCmds[6] = 0x01;
-       RTPRINT(FIOCTL, (IOCTL_BT_HCICMD|IOCTL_BT_LOGO), ("Octet[7]= 0x0c\nBit [2]= Read Connection Accept Timeout, [3]= Write Connection Accept Timeout\n"));
-       pSupportedCmds[7] = 0x0c;
-       RTPRINT(FIOCTL, (IOCTL_BT_HCICMD|IOCTL_BT_LOGO), ("Octet[10]= 0x80\nBit [7]= Host Number Of Completed Packets\n"));
-       pSupportedCmds[10] = 0x80;
-       RTPRINT(FIOCTL, (IOCTL_BT_HCICMD|IOCTL_BT_LOGO), ("Octet[11]= 0x03\nBit [0]= Read Link Supervision Timeout, [1]= Write Link Supervision Timeout\n"));
-       pSupportedCmds[11] = 0x03;
-       RTPRINT(FIOCTL, (IOCTL_BT_HCICMD|IOCTL_BT_LOGO), ("Octet[14]= 0xa8\nBit [3]= Read Local Version Information, [5]= Read Local Supported Features, [7]= Read Buffer Size\n"));
-       pSupportedCmds[14] = 0xa8;
-       RTPRINT(FIOCTL, (IOCTL_BT_HCICMD|IOCTL_BT_LOGO), ("Octet[15]= 0x1c\nBit [2]= Read Failed Contact Count, [3]= Reset Failed Contact Count, [4]= Get Link Quality\n"));
-       pSupportedCmds[15] = 0x1c;
-       /* pSupportedCmds[16] = 0x04; */
-       RTPRINT(FIOCTL, (IOCTL_BT_HCICMD|IOCTL_BT_LOGO), ("Octet[19]= 0x40\nBit [6]= Enhanced Flush\n"));
-       pSupportedCmds[19] = 0x40;
-       RTPRINT(FIOCTL, (IOCTL_BT_HCICMD|IOCTL_BT_LOGO), ("Octet[21]= 0xff\nBit [0]= Create Physical Link, [1]= Accept Physical Link, [2]= Disconnect Physical Link, [3]= Create Logical Link\n"));
-       RTPRINT(FIOCTL, (IOCTL_BT_HCICMD|IOCTL_BT_LOGO), ("     [4]= Accept Logical Link, [5]= Disconnect Logical Link, [6]= Logical Link Cancel, [7]= Flow Spec Modify\n"));
-       pSupportedCmds[21] = 0xff;
-       RTPRINT(FIOCTL, (IOCTL_BT_HCICMD|IOCTL_BT_LOGO), ("Octet[22]= 0xff\nBit [0]= Read Logical Link Accept Timeout, [1]= Write Logical Link Accept Timeout, [2]= Set Event Mask Page 2, [3]= Read Location Data\n"));
-       RTPRINT(FIOCTL, (IOCTL_BT_HCICMD|IOCTL_BT_LOGO), ("     [4]= Write Location Data, [5]= Read Local AMP Info, [6]= Read Local AMP_ASSOC, [7]= Write Remote AMP_ASSOC\n"));
-       pSupportedCmds[22] = 0xff;
-       RTPRINT(FIOCTL, (IOCTL_BT_HCICMD|IOCTL_BT_LOGO), ("Octet[23]= 0x07\nBit [0]= Read Flow Control Mode, [1]= Write Flow Control Mode, [2]= Read Data Block Size\n"));
-       pSupportedCmds[23] = 0x07;
-       RTPRINT(FIOCTL, (IOCTL_BT_HCICMD|IOCTL_BT_LOGO), ("Octet[24]= 0x1c\nBit [2]= Read Best Effort Flush Timeout, [3]= Write Best Effort Flush Timeout, [4]= Short Range Mode\n"));
-       pSupportedCmds[24] = 0x1c;
-       len += 64;
-       PPacketIrpEvent->Length = len;
-
-       bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-
-       return status;
-}
-
-static enum hci_status bthci_CmdReadLocalSupportedFeatures(struct rtw_adapter *padapter)
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-       u8 localBuf[TmpLocalBufSize] = "";
-       u8 *pRetPar;
-       u8 len = 0;
-       struct packet_irp_hcievent_data *PPacketIrpEvent;
-
-       /* send command complete event here when all data are received. */
-       PlatformZeroMemory(&localBuf[0], TmpLocalBufSize);
-       PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-       len += bthci_CommandCompleteHeader(&localBuf[0],
-               OGF_INFORMATIONAL_PARAMETERS,
-               HCI_READ_LOCAL_SUPPORTED_FEATURES,
-               status);
-
-       /*  Return parameters starts from here */
-       pRetPar = &PPacketIrpEvent->Data[len];
-       pRetPar[0] = status;            /* status */
-       len += 9;
-       PPacketIrpEvent->Length = len;
-
-       bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-       return status;
-}
-
-static enum hci_status bthci_CmdReadLocalAMPAssoc(struct rtw_adapter *padapter,
-       struct packet_irp_hcicmd_data *pHciCmd)
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-       struct bt_dgb *pBtDbg = &pBTInfo->BtDbg;
-       u8 PhyLinkHandle, EntryNum;
-
-       pBtDbg->dbgHciInfo.hciCmdCntReadLocalAmpAssoc++;
-       PhyLinkHandle = *((u8 *)pHciCmd->Data);
-       EntryNum = bthci_GetCurrentEntryNum(padapter, PhyLinkHandle);
-
-       if ((EntryNum == 0xff) && PhyLinkHandle != 0) {
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("ReadLocalAMPAssoc, EntryNum = %d  !!!!!, physical link handle = 0x%x\n",
-               EntryNum, PhyLinkHandle));
-               status = HCI_STATUS_UNKNOW_CONNECT_ID;
-       } else if (pBtMgnt->bPhyLinkInProgressStartLL) {
-               status = HCI_STATUS_UNKNOW_CONNECT_ID;
-               pBtMgnt->bPhyLinkInProgressStartLL = false;
-       } else {
-               pBTInfo->BtAsocEntry[EntryNum].AmpAsocCmdData.BtPhyLinkhandle = *((u8 *)pHciCmd->Data);
-               pBTInfo->BtAsocEntry[EntryNum].AmpAsocCmdData.LenSoFar = *((u16 *)((u8 *)pHciCmd->Data+1));
-               pBTInfo->BtAsocEntry[EntryNum].AmpAsocCmdData.MaxRemoteASSOCLen = *((u16 *)((u8 *)pHciCmd->Data+3));
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD_DETAIL, ("ReadLocalAMPAssoc, LenSoFar =%d, MaxRemoteASSOCLen =%d\n",
-                       pBTInfo->BtAsocEntry[EntryNum].AmpAsocCmdData.LenSoFar,
-                       pBTInfo->BtAsocEntry[EntryNum].AmpAsocCmdData.MaxRemoteASSOCLen));
-       }
-
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("ReadLocalAMPAssoc, EntryNum = %d  !!!!!, physical link handle = 0x%x, LengthSoFar = %x  \n",
-               EntryNum, PhyLinkHandle, pBTInfo->BtAsocEntry[EntryNum].AmpAsocCmdData.LenSoFar));
-
-       /* send command complete event here when all data are received. */
-       {
-               struct packet_irp_hcievent_data *PPacketIrpEvent;
-
-               /* PVOID buffer = padapter->IrpHCILocalbuf.Ptr; */
-               u8 localBuf[TmpLocalBufSize] = "";
-               u16     *pRemainLen;
-               u32     totalLen = 0;
-               u16     typeLen = 0, remainLen = 0, ret_index = 0;
-               u8 *pRetPar;
-
-               PlatformZeroMemory(&localBuf[0], TmpLocalBufSize);
-               /* PPacketIrpEvent = (struct packet_irp_hcievent_data *)(buffer); */
-               PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-               totalLen += bthci_CommandCompleteHeader(&localBuf[0],
-                       OGF_STATUS_PARAMETERS,
-                       HCI_READ_LOCAL_AMP_ASSOC,
-                       status);
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("ReadLocalAMPAssoc, Remaining_Len =%d  \n", remainLen));
-               /*  Return parameters starts from here */
-               pRetPar = &PPacketIrpEvent->Data[totalLen];
-               pRetPar[0] = status;            /* status */
-               pRetPar[1] = *((u8 *)pHciCmd->Data);
-               pRemainLen = (u16 *)&pRetPar[2];        /* AMP_ASSOC_Remaining_Length */
-               totalLen += 4;  /* 0]~[3] */
-               ret_index = 4;
-
-               typeLen = bthci_AssocMACAddr(padapter, &pRetPar[ret_index]);
-               totalLen += typeLen;
-               remainLen += typeLen;
-               ret_index += typeLen;
-               typeLen = bthci_AssocPreferredChannelList(padapter, &pRetPar[ret_index], EntryNum);
-               totalLen += typeLen;
-               remainLen += typeLen;
-               ret_index += typeLen;
-               typeLen = bthci_PALCapabilities(padapter, &pRetPar[ret_index]);
-               totalLen += typeLen;
-               remainLen += typeLen;
-               ret_index += typeLen;
-               typeLen = bthci_AssocPALVer(padapter, &pRetPar[ret_index]);
-               totalLen += typeLen;
-               remainLen += typeLen;
-               PPacketIrpEvent->Length = (u8)totalLen;
-               *pRemainLen = remainLen;        /*  AMP_ASSOC_Remaining_Length */
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("ReadLocalAMPAssoc, Remaining_Len =%d  \n", remainLen));
-               RTPRINT_DATA(FIOCTL, (IOCTL_BT_HCICMD_DETAIL|IOCTL_BT_LOGO), ("AMP_ASSOC_fragment : \n"), PPacketIrpEvent->Data, totalLen);
-
-               bthci_IndicateEvent(padapter, PPacketIrpEvent, totalLen+2);
-       }
-
-       return status;
-}
-
-static enum hci_status bthci_CmdReadFailedContactCounter(struct rtw_adapter *padapter,
-                      struct packet_irp_hcicmd_data *pHciCmd)
-{
-
-       enum hci_status         status = HCI_STATUS_SUCCESS;
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_hci_info *pBtHciInfo = &pBTInfo->BtHciInfo;
-       u8 localBuf[TmpLocalBufSize] = "";
-       u8 *pRetPar;
-       u8 len = 0;
-       struct packet_irp_hcievent_data *PPacketIrpEvent;
-       u16 handle;
-
-       handle = *((u16 *)pHciCmd->Data);
-       /* send command complete event here when all data are received. */
-       PlatformZeroMemory(&localBuf[0], TmpLocalBufSize);
-       PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-       len += bthci_CommandCompleteHeader(&localBuf[0],
-               OGF_STATUS_PARAMETERS,
-               HCI_READ_FAILED_CONTACT_COUNTER,
-               status);
-
-       /*  Return parameters starts from here */
-       pRetPar = &PPacketIrpEvent->Data[len];
-       pRetPar[0] = status;            /* status */
-       pRetPar[1] = TWOBYTE_LOWBYTE(handle);
-       pRetPar[2] = TWOBYTE_HIGHTBYTE(handle);
-       pRetPar[3] = TWOBYTE_LOWBYTE(pBtHciInfo->FailContactCount);
-       pRetPar[4] = TWOBYTE_HIGHTBYTE(pBtHciInfo->FailContactCount);
-       len += 5;
-       PPacketIrpEvent->Length = len;
-
-       bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-
-       return status;
-}
-
-static enum hci_status
-bthci_CmdResetFailedContactCounter(
-       struct rtw_adapter *padapter,
-       struct packet_irp_hcicmd_data *pHciCmd
-       )
-{
-       enum hci_status         status = HCI_STATUS_SUCCESS;
-/*PMGNT_INFO           pMgntInfo = &padapter->MgntInfo; */
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_hci_info *pBtHciInfo = &pBTInfo->BtHciInfo;
-       u16             handle;
-       u8 localBuf[TmpLocalBufSize] = "";
-       u8 *pRetPar;
-       u8 len = 0;
-       struct packet_irp_hcievent_data *PPacketIrpEvent;
-
-       handle = *((u16 *)pHciCmd->Data);
-       pBtHciInfo->FailContactCount = 0;
-
-       /* send command complete event here when all data are received. */
-       PlatformZeroMemory(&localBuf[0], TmpLocalBufSize);
-       /* PPacketIrpEvent = (struct packet_irp_hcievent_data *)(buffer); */
-       PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-       len += bthci_CommandCompleteHeader(&localBuf[0],
-               OGF_STATUS_PARAMETERS,
-               HCI_RESET_FAILED_CONTACT_COUNTER,
-               status);
-
-       /*  Return parameters starts from here */
-       pRetPar = &PPacketIrpEvent->Data[len];
-       pRetPar[0] = status;            /* status */
-       pRetPar[1] = TWOBYTE_LOWBYTE(handle);
-       pRetPar[2] = TWOBYTE_HIGHTBYTE(handle);
-       len += 3;
-       PPacketIrpEvent->Length = len;
-
-       bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-       return status;
-}
-
-/*  */
-/*  BT 3.0+HS [Vol 2] 7.4.1 */
-/*  */
-static enum hci_status
-bthci_CmdReadLocalVersionInformation(
-       struct rtw_adapter *padapter
-       )
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-       /* send command complete event here when all data are received. */
-       u8 localBuf[TmpLocalBufSize] = "";
-       u8 *pRetPar;
-       u8 len = 0;
-       struct packet_irp_hcievent_data *PPacketIrpEvent;
-       u16 *pu2Temp;
-
-       PlatformZeroMemory(&localBuf[0], TmpLocalBufSize);
-       PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-       len += bthci_CommandCompleteHeader(&localBuf[0],
-               OGF_INFORMATIONAL_PARAMETERS,
-               HCI_READ_LOCAL_VERSION_INFORMATION,
-               status);
-
-       /*  Return parameters starts from here */
-       pRetPar = &PPacketIrpEvent->Data[len];
-       pRetPar[0] = status;            /* status */
-       pRetPar[1] = 0x05;                      /*  HCI_Version */
-       pu2Temp = (u16 *)&pRetPar[2];           /*  HCI_Revision */
-       *pu2Temp = 0x0001;
-       pRetPar[4] = 0x05;                      /*  LMP/PAL_Version */
-       pu2Temp = (u16 *)&pRetPar[5];           /*  Manufacturer_Name */
-       *pu2Temp = 0x005d;
-       pu2Temp = (u16 *)&pRetPar[7];           /*  LMP/PAL_Subversion */
-       *pu2Temp = 0x0001;
-       len += 9;
-       PPacketIrpEvent->Length = len;
-
-       RTPRINT(FIOCTL, (IOCTL_BT_HCICMD_DETAIL|IOCTL_BT_LOGO), ("LOCAL_VERSION_INFORMATION\n"));
-       RTPRINT(FIOCTL, (IOCTL_BT_HCICMD_DETAIL|IOCTL_BT_LOGO), ("Status  %x\n", status));
-       RTPRINT(FIOCTL, (IOCTL_BT_HCICMD_DETAIL|IOCTL_BT_LOGO), ("HCI_Version = 0x05\n"));
-       RTPRINT(FIOCTL, (IOCTL_BT_HCICMD_DETAIL|IOCTL_BT_LOGO), ("HCI_Revision = 0x0001\n"));
-       RTPRINT(FIOCTL, (IOCTL_BT_HCICMD_DETAIL|IOCTL_BT_LOGO), ("LMP/PAL_Version = 0x05\n"));
-       RTPRINT(FIOCTL, (IOCTL_BT_HCICMD_DETAIL|IOCTL_BT_LOGO), ("Manufacturer_Name = 0x0001\n"));
-       RTPRINT(FIOCTL, (IOCTL_BT_HCICMD_DETAIL|IOCTL_BT_LOGO), ("LMP/PAL_Subversion = 0x0001\n"));
-
-       bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-
-       return status;
-}
-
-/* 7.4.7 */
-static enum hci_status bthci_CmdReadDataBlockSize(struct rtw_adapter *padapter)
-{
-       enum hci_status                 status = HCI_STATUS_SUCCESS;
-       u8 localBuf[TmpLocalBufSize] = "";
-       u8 *pRetPar;
-       u8 len = 0;
-       struct packet_irp_hcievent_data *PPacketIrpEvent;
-       u16 *pu2Temp;
-
-       PlatformZeroMemory(&localBuf[0], TmpLocalBufSize);
-       PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-       len += bthci_CommandCompleteHeader(&localBuf[0],
-               OGF_INFORMATIONAL_PARAMETERS,
-               HCI_READ_DATA_BLOCK_SIZE,
-               status);
-
-       /*  Return parameters starts from here */
-       pRetPar = &PPacketIrpEvent->Data[len];
-       pRetPar[0] = HCI_STATUS_SUCCESS;        /* status */
-       pu2Temp = (u16 *)&pRetPar[1];           /*  Max_ACL_Data_Packet_Length */
-       *pu2Temp = Max80211PALPDUSize;
-
-       pu2Temp = (u16 *)&pRetPar[3];           /*  Data_Block_Length */
-       *pu2Temp = Max80211PALPDUSize;
-       pu2Temp = (u16 *)&pRetPar[5];           /*  Total_Num_Data_Blocks */
-       *pu2Temp = BTTotalDataBlockNum;
-       len += 7;
-       PPacketIrpEvent->Length = len;
-
-       bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-
-       return status;
-}
-
-/*  7.4.5 */
-static enum hci_status bthci_CmdReadBufferSize(struct rtw_adapter *padapter)
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-       u8 localBuf[TmpLocalBufSize] = "";
-       u8 *pRetPar;
-       u8 len = 0;
-       struct packet_irp_hcievent_data *PPacketIrpEvent;
-       u16 *pu2Temp;
-
-       PlatformZeroMemory(&localBuf[0], TmpLocalBufSize);
-       /* PPacketIrpEvent = (struct packet_irp_hcievent_data *)(buffer); */
-       PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-       len += bthci_CommandCompleteHeader(&localBuf[0],
-               OGF_INFORMATIONAL_PARAMETERS,
-               HCI_READ_BUFFER_SIZE,
-               status);
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("Synchronous_Data_Packet_Length = 0x%x\n", BTSynDataPacketLength));
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("Total_Num_ACL_Data_Packets = 0x%x\n", BTTotalDataBlockNum));
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("Total_Num_Synchronous_Data_Packets = 0x%x\n", BTTotalDataBlockNum));
-       /*  Return parameters starts from here */
-       pRetPar = &PPacketIrpEvent->Data[len];
-       pRetPar[0] = status;            /* status */
-       pu2Temp = (u16 *)&pRetPar[1];           /*  HC_ACL_Data_Packet_Length */
-       *pu2Temp = Max80211PALPDUSize;
-
-       pRetPar[3] = BTSynDataPacketLength;     /*  HC_Synchronous_Data_Packet_Length */
-       pu2Temp = (u16 *)&pRetPar[4];           /*  HC_Total_Num_ACL_Data_Packets */
-       *pu2Temp = BTTotalDataBlockNum;
-       pu2Temp = (u16 *)&pRetPar[6];           /*  HC_Total_Num_Synchronous_Data_Packets */
-       *pu2Temp = BTTotalDataBlockNum;
-       len += 8;
-       PPacketIrpEvent->Length = len;
-
-       bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-
-       return status;
-}
-
-static enum hci_status bthci_CmdReadLocalAMPInfo(struct rtw_adapter *padapter)
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-       struct pwrctrl_priv *ppwrctrl = &padapter->pwrctrlpriv;
-       u8 localBuf[TmpLocalBufSize] = "";
-       u8 *pRetPar;
-       u8 len = 0;
-       struct packet_irp_hcievent_data *PPacketIrpEvent;
-       u16 *pu2Temp;
-       u32 *pu4Temp;
-       u32     TotalBandwidth = BTTOTALBANDWIDTH, MaxBandGUBandwidth = BTMAXBANDGUBANDWIDTH;
-       u8 ControlType = 0x01, AmpStatus = 0x01;
-       u32     MaxFlushTimeout = 10000, BestEffortFlushTimeout = 5000;
-       u16 MaxPDUSize = Max80211PALPDUSize, PalCap = 0x1, AmpAssocLen = Max80211AMPASSOCLen, MinLatency = 20;
-
-       if ((ppwrctrl->rfoff_reason & RF_CHANGE_BY_HW) ||
-           (ppwrctrl->rfoff_reason & RF_CHANGE_BY_SW)) {
-               AmpStatus = AMP_STATUS_NO_CAPACITY_FOR_BT;
-       }
-
-       PlatformZeroMemory(&localBuf[0], TmpLocalBufSize);
-       /* PPacketIrpEvent = (struct packet_irp_hcievent_data *)(buffer); */
-       PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-       len += bthci_CommandCompleteHeader(&localBuf[0],
-               OGF_STATUS_PARAMETERS,
-               HCI_READ_LOCAL_AMP_INFO,
-               status);
-
-       /*  Return parameters starts from here */
-       pRetPar = &PPacketIrpEvent->Data[len];
-       pRetPar[0] = status;                    /* status */
-       pRetPar[1] = AmpStatus;                 /*  AMP_Status */
-       pu4Temp = (u32 *)&pRetPar[2];           /*  Total_Bandwidth */
-       *pu4Temp = TotalBandwidth;              /* 0x19bfcc00;0x7530; */
-       pu4Temp = (u32 *)&pRetPar[6];           /*  Max_Guaranteed_Bandwidth */
-       *pu4Temp = MaxBandGUBandwidth;          /* 0x19bfcc00;0x4e20; */
-       pu4Temp = (u32 *)&pRetPar[10];          /*  Min_Latency */
-       *pu4Temp = MinLatency;                  /* 150; */
-       pu4Temp = (u32 *)&pRetPar[14];          /*  Max_PDU_Size */
-       *pu4Temp = MaxPDUSize;
-       pRetPar[18] = ControlType;              /*  Controller_Type */
-       pu2Temp = (u16 *)&pRetPar[19];          /*  PAL_Capabilities */
-       *pu2Temp = PalCap;
-       pu2Temp = (u16 *)&pRetPar[21];          /*  AMP_ASSOC_Length */
-       *pu2Temp = AmpAssocLen;
-       pu4Temp = (u32 *)&pRetPar[23];          /*  Max_Flush_Timeout */
-       *pu4Temp = MaxFlushTimeout;
-       pu4Temp = (u32 *)&pRetPar[27];          /*  Best_Effort_Flush_Timeout */
-       *pu4Temp = BestEffortFlushTimeout;
-       len += 31;
-       PPacketIrpEvent->Length = len;
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("AmpStatus = 0x%x\n",
-               AmpStatus));
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("TotalBandwidth = 0x%x, MaxBandGUBandwidth = 0x%x, MinLatency = 0x%x, \n MaxPDUSize = 0x%x, ControlType = 0x%x\n",
-               TotalBandwidth, MaxBandGUBandwidth, MinLatency, MaxPDUSize, ControlType));
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("PalCap = 0x%x, AmpAssocLen = 0x%x, MaxFlushTimeout = 0x%x, BestEffortFlushTimeout = 0x%x\n",
-               PalCap, AmpAssocLen, MaxFlushTimeout, BestEffortFlushTimeout));
-       bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-       return status;
-}
-
-static enum hci_status
-bthci_CmdCreatePhysicalLink(
-       struct rtw_adapter *padapter,
-       struct packet_irp_hcicmd_data *pHciCmd
-       )
-{
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_dgb *pBtDbg = &pBTInfo->BtDbg;
-
-       pBtDbg->dbgHciInfo.hciCmdCntCreatePhyLink++;
-
-       return bthci_BuildPhysicalLink(padapter,
-               pHciCmd, HCI_CREATE_PHYSICAL_LINK);
-}
-
-static enum hci_status
-bthci_CmdReadLinkQuality(
-       struct rtw_adapter *padapter,
-       struct packet_irp_hcicmd_data *pHciCmd
-       )
-{
-       enum hci_status                 status = HCI_STATUS_SUCCESS;
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       u16                             PLH;
-       u8      EntryNum, LinkQuality = 0x55;
-
-       PLH = *((u16 *)&pHciCmd->Data[0]);
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("PLH = 0x%x\n", PLH));
-
-       EntryNum = bthci_GetCurrentEntryNum(padapter, (u8)PLH);
-       if (EntryNum == 0xff) {
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("No such PLH(0x%x)\n", PLH));
-               status = HCI_STATUS_UNKNOW_CONNECT_ID;
-       }
-
-       {
-               u8 localBuf[11] = "";
-               u8 *pRetPar;
-               u8 len = 0;
-               struct packet_irp_hcievent_data *PPacketIrpEvent;
-
-               PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-               len += bthci_CommandCompleteHeader(&localBuf[0],
-                       OGF_STATUS_PARAMETERS,
-                       HCI_READ_LINK_QUALITY,
-                       status);
-
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, (" PLH = 0x%x\n Link Quality = 0x%x\n", PLH, LinkQuality));
-
-               /*  Return parameters starts from here */
-               pRetPar = &PPacketIrpEvent->Data[len];
-               pRetPar[0] = status;                    /* status */
-               *((u16 *)&pRetPar[1]) = pBTInfo->BtAsocEntry[EntryNum].PhyLinkCmdData.BtPhyLinkhandle;  /*  Handle */
-               pRetPar[3] = 0x55;      /* Link Quailty */
-               len += 4;
-               PPacketIrpEvent->Length = len;
-
-               bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-       }
-
-       return status;
-}
-
-static enum hci_status
-bthci_CmdCreateLogicalLink(
-       struct rtw_adapter *padapter,
-       struct packet_irp_hcicmd_data *pHciCmd
-       )
-{
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_dgb *pBtDbg = &pBTInfo->BtDbg;
-
-       pBtDbg->dbgHciInfo.hciCmdCntCreateLogLink++;
-
-       bthci_BuildLogicalLink(padapter, pHciCmd,
-               HCI_CREATE_LOGICAL_LINK);
-
-       return HCI_STATUS_SUCCESS;
-}
-
-static enum hci_status
-bthci_CmdAcceptLogicalLink(
-       struct rtw_adapter *padapter,
-       struct packet_irp_hcicmd_data *pHciCmd
-       )
-{
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_dgb *pBtDbg = &pBTInfo->BtDbg;
-
-       pBtDbg->dbgHciInfo.hciCmdCntAcceptLogLink++;
-
-       bthci_BuildLogicalLink(padapter, pHciCmd,
-               HCI_ACCEPT_LOGICAL_LINK);
-
-       return HCI_STATUS_SUCCESS;
-}
-
-static enum hci_status
-bthci_CmdDisconnectLogicalLink(
-       struct rtw_adapter *padapter,
-       struct packet_irp_hcicmd_data *pHciCmd
-       )
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-/*PMGNT_INFO pMgntInfo = &padapter->MgntInfo; */
-       struct bt_30info *pBTinfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTinfo->BtMgnt;
-       struct bt_dgb *pBtDbg = &pBTinfo->BtDbg;
-       u16     logicHandle;
-       u8 i, j, find = 0, LogLinkCount = 0;
-
-       pBtDbg->dbgHciInfo.hciCmdCntDisconnectLogLink++;
-
-       logicHandle = *((u16 *)pHciCmd->Data);
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("DisconnectLogicalLink, logicHandle = 0x%x\n", logicHandle));
-
-       /*  find an created logical link index and clear the data */
-       for (j = 0; j < MAX_BT_ASOC_ENTRY_NUM; j++) {
-               for (i = 0; i < MAX_LOGICAL_LINK_NUM; i++) {
-                       if (pBTinfo->BtAsocEntry[j].LogLinkCmdData[i].BtLogLinkhandle == logicHandle) {
-                               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("DisconnectLogicalLink, logicHandle is matched  0x%x\n", logicHandle));
-                               bthci_ResetFlowSpec(padapter, j, i);
-                               find = 1;
-                               pBtMgnt->DisconnectEntryNum = j;
-                               break;
-                       }
-               }
-       }
-
-       if (!find)
-               status = HCI_STATUS_UNKNOW_CONNECT_ID;
-
-       /*  To check each */
-       for (i = 0; i < MAX_LOGICAL_LINK_NUM; i++) {
-               if (pBTinfo->BtAsocEntry[pBtMgnt->DisconnectEntryNum].LogLinkCmdData[i].BtLogLinkhandle != 0)
-                       LogLinkCount++;
-       }
-
-       /* When we receive Create logical link command, we should send command status event first. */
-       bthci_EventCommandStatus(padapter,
-                       LINK_CONTROL_COMMANDS,
-                       HCI_DISCONNECT_LOGICAL_LINK,
-                       status);
-       /*  */
-       /* When we determines the logical link is established, we should send command complete event. */
-       /*  */
-       if (status == HCI_STATUS_SUCCESS) {
-               bthci_EventDisconnectLogicalLinkComplete(padapter, status,
-                       logicHandle, HCI_STATUS_CONNECT_TERMINATE_LOCAL_HOST);
-       }
-
-       if (LogLinkCount == 0)
-               mod_timer(&pBTinfo->BTDisconnectPhyLinkTimer,
-                         jiffies + msecs_to_jiffies(100));
-
-       return status;
-}
-
-static enum hci_status
-bthci_CmdLogicalLinkCancel(struct rtw_adapter *padapter,
-                          struct packet_irp_hcicmd_data *pHciCmd)
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-       struct bt_30info *pBTinfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTinfo->BtMgnt;
-       u8 CurrentEntryNum, CurrentLogEntryNum;
-
-       u8 physicalLinkHandle, TxFlowSpecID, i;
-       u16     CurrentLogicalHandle;
-
-       physicalLinkHandle = *((u8 *)pHciCmd->Data);
-       TxFlowSpecID = *(((u8 *)pHciCmd->Data)+1);
-
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("LogicalLinkCancel, physicalLinkHandle = 0x%x, TxFlowSpecID = 0x%x\n",
-               physicalLinkHandle, TxFlowSpecID));
-
-       CurrentEntryNum = pBtMgnt->CurrentConnectEntryNum;
-       CurrentLogicalHandle = pBtMgnt->BtCurrentLogLinkhandle;
-
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("CurrentEntryNum = 0x%x, CurrentLogicalHandle = 0x%x\n",
-               CurrentEntryNum, CurrentLogicalHandle));
-
-       CurrentLogEntryNum = 0xff;
-       for (i = 0; i < MAX_LOGICAL_LINK_NUM; i++) {
-               if ((CurrentLogicalHandle == pBTinfo->BtAsocEntry[CurrentEntryNum].LogLinkCmdData[i].BtLogLinkhandle) &&
-                       (physicalLinkHandle == pBTinfo->BtAsocEntry[CurrentEntryNum].LogLinkCmdData[i].BtPhyLinkhandle)) {
-                       CurrentLogEntryNum = i;
-                       break;
-               }
-       }
-
-       if (CurrentLogEntryNum == 0xff) {
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("LogicalLinkCancel, CurrentLogEntryNum == 0xff !!!!\n"));
-               status = HCI_STATUS_UNKNOW_CONNECT_ID;
-               return status;
-       } else {
-               if (pBTinfo->BtAsocEntry[CurrentEntryNum].LogLinkCmdData[CurrentLogEntryNum].bLLCompleteEventIsSet) {
-                       RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("LogicalLinkCancel, LLCompleteEventIsSet!!!!\n"));
-                       status = HCI_STATUS_ACL_CONNECT_EXISTS;
-               }
-       }
-
-       {
-               u8 localBuf[8] = "";
-               u8 *pRetPar;
-               u8 len = 0;
-               struct packet_irp_hcievent_data *PPacketIrpEvent;
-
-               PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-               len += bthci_CommandCompleteHeader(&localBuf[0],
-                       LINK_CONTROL_COMMANDS,
-                       HCI_LOGICAL_LINK_CANCEL,
-                       status);
-
-               /*  Return parameters starts from here */
-               pRetPar = &PPacketIrpEvent->Data[len];
-               pRetPar[0] = status;            /* status */
-               pRetPar[1] = pBTinfo->BtAsocEntry[CurrentEntryNum].LogLinkCmdData[CurrentLogEntryNum].BtPhyLinkhandle;
-               pRetPar[2] = pBTinfo->BtAsocEntry[CurrentEntryNum].LogLinkCmdData[CurrentLogEntryNum].BtTxFlowSpecID;
-               len += 3;
-               PPacketIrpEvent->Length = len;
-
-               bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-       }
-
-       pBTinfo->BtAsocEntry[CurrentEntryNum].LogLinkCmdData[CurrentLogEntryNum].bLLCancelCMDIsSetandComplete = true;
-
-       return status;
-}
-
-static enum hci_status
-bthci_CmdFlowSpecModify(struct rtw_adapter *padapter,
-                       struct packet_irp_hcicmd_data *pHciCmd)
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-/*PMGNT_INFO pMgntInfo = &padapter->MgntInfo; */
-       struct bt_30info *pBTinfo = GET_BT_INFO(padapter);
-       u8 i, j, find = 0;
-       u16 logicHandle;
-
-       logicHandle = *((u16 *)pHciCmd->Data);
-       /*  find an matched logical link index and copy the data */
-       for (j = 0; j < MAX_BT_ASOC_ENTRY_NUM; j++) {
-               for (i = 0; i < MAX_LOGICAL_LINK_NUM; i++) {
-                       if (pBTinfo->BtAsocEntry[j].LogLinkCmdData[i].BtLogLinkhandle == logicHandle) {
-                               memcpy(&pBTinfo->BtAsocEntry[j].LogLinkCmdData[i].Tx_Flow_Spec,
-                                       &pHciCmd->Data[2], sizeof(struct hci_flow_spec));
-                               memcpy(&pBTinfo->BtAsocEntry[j].LogLinkCmdData[i].Rx_Flow_Spec,
-                                       &pHciCmd->Data[18], sizeof(struct hci_flow_spec));
-
-                               bthci_CheckLogLinkBehavior(padapter, pBTinfo->BtAsocEntry[j].LogLinkCmdData[i].Tx_Flow_Spec);
-                               find = 1;
-                               break;
-                       }
-               }
-       }
-       RTPRINT(FIOCTL, IOCTL_BT_LOGO, ("FlowSpecModify, LLH = 0x%x, \n", logicHandle));
-
-       /* When we receive Flow Spec Modify command, we should send command status event first. */
-       bthci_EventCommandStatus(padapter,
-               LINK_CONTROL_COMMANDS,
-               HCI_FLOW_SPEC_MODIFY,
-               HCI_STATUS_SUCCESS);
-
-       if (!find)
-               status = HCI_STATUS_UNKNOW_CONNECT_ID;
-
-       bthci_EventSendFlowSpecModifyComplete(padapter, status, logicHandle);
-
-       return status;
-}
-
-static enum hci_status
-bthci_CmdAcceptPhysicalLink(struct rtw_adapter *padapter,
-                           struct packet_irp_hcicmd_data *pHciCmd)
-{
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_dgb *pBtDbg = &pBTInfo->BtDbg;
-
-       pBtDbg->dbgHciInfo.hciCmdCntAcceptPhyLink++;
-
-       return bthci_BuildPhysicalLink(padapter,
-               pHciCmd, HCI_ACCEPT_PHYSICAL_LINK);
-}
-
-static enum hci_status
-bthci_CmdDisconnectPhysicalLink(struct rtw_adapter *padapter,
-                               struct packet_irp_hcicmd_data *pHciCmd)
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_dgb *pBtDbg = &pBTInfo->BtDbg;
-       u8 PLH, CurrentEntryNum, PhysLinkDisconnectReason;
-
-       pBtDbg->dbgHciInfo.hciCmdCntDisconnectPhyLink++;
-
-       PLH = *((u8 *)pHciCmd->Data);
-       PhysLinkDisconnectReason = *((u8 *)pHciCmd->Data+1);
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_DISCONNECT_PHYSICAL_LINK  PhyHandle = 0x%x, Reason = 0x%x\n",
-               PLH, PhysLinkDisconnectReason));
-
-       CurrentEntryNum = bthci_GetCurrentEntryNum(padapter, PLH);
-
-       if (CurrentEntryNum == 0xff) {
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD,
-                       ("DisconnectPhysicalLink, No such Handle in the Entry\n"));
-               status = HCI_STATUS_UNKNOW_CONNECT_ID;
-       } else {
-               pBTInfo->BtAsocEntry[CurrentEntryNum].PhyLinkDisconnectReason =
-                       (enum hci_status)PhysLinkDisconnectReason;
-       }
-       /* Send HCI Command status event to AMP. */
-       bthci_EventCommandStatus(padapter, LINK_CONTROL_COMMANDS,
-                                HCI_DISCONNECT_PHYSICAL_LINK, status);
-
-       if (status != HCI_STATUS_SUCCESS)
-               return status;
-
-       /* The macros below require { and } in the if statement */
-       if (pBTInfo->BtAsocEntry[CurrentEntryNum].BtCurrentState == HCI_STATE_DISCONNECTED) {
-               BTHCI_SM_WITH_INFO(padapter, HCI_STATE_DISCONNECTED, STATE_CMD_DISCONNECT_PHY_LINK, CurrentEntryNum);
-       } else {
-               BTHCI_SM_WITH_INFO(padapter, HCI_STATE_DISCONNECTING, STATE_CMD_DISCONNECT_PHY_LINK, CurrentEntryNum);
-       }
-       return status;
-}
-
-static enum hci_status
-bthci_CmdSetACLLinkDataFlowMode(struct rtw_adapter *padapter,
-                               struct packet_irp_hcicmd_data *pHciCmd)
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-       u8 localBuf[8] = "";
-       u8 *pRetPar;
-       u8 len = 0;
-       struct packet_irp_hcievent_data *PPacketIrpEvent;
-       u16 *pu2Temp;
-
-       pBtMgnt->ExtConfig.CurrentConnectHandle = *((u16 *)pHciCmd->Data);
-       pBtMgnt->ExtConfig.CurrentIncomingTrafficMode = *((u8 *)pHciCmd->Data)+2;
-       pBtMgnt->ExtConfig.CurrentOutgoingTrafficMode = *((u8 *)pHciCmd->Data)+3;
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD_EXT, ("Connection Handle = 0x%x, Incoming Traffic mode = 0x%x, Outgoing Traffic mode = 0x%x",
-               pBtMgnt->ExtConfig.CurrentConnectHandle,
-               pBtMgnt->ExtConfig.CurrentIncomingTrafficMode,
-               pBtMgnt->ExtConfig.CurrentOutgoingTrafficMode));
-
-
-       PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-       len += bthci_CommandCompleteHeader(&localBuf[0],
-               OGF_EXTENSION,
-               HCI_SET_ACL_LINK_DATA_FLOW_MODE,
-               status);
-
-       /*  Return parameters starts from here */
-       pRetPar = &PPacketIrpEvent->Data[len];
-       pRetPar[0] = status;            /* status */
-
-       pu2Temp = (u16 *)&pRetPar[1];
-       *pu2Temp = pBtMgnt->ExtConfig.CurrentConnectHandle;
-       len += 3;
-       PPacketIrpEvent->Length = len;
-
-       bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-       return status;
-}
-
-static enum hci_status
-bthci_CmdSetACLLinkStatus(struct rtw_adapter *padapter,
-                         struct packet_irp_hcicmd_data *pHciCmd)
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-       struct bt_dgb *pBtDbg = &pBTInfo->BtDbg;
-       u8 i;
-       u8 *pTriple;
-
-       pBtDbg->dbgHciInfo.hciCmdCntSetAclLinkStatus++;
-       RTPRINT_DATA(FIOCTL, IOCTL_BT_HCICMD_EXT, "SetACLLinkStatus, Hex Data :\n",
-                       &pHciCmd->Data[0], pHciCmd->Length);
-
-       /*  Only Core Stack v251 and later version support this command. */
-       pBtMgnt->bSupportProfile = true;
-
-       pBtMgnt->ExtConfig.NumberOfHandle = *((u8 *)pHciCmd->Data);
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD_EXT, ("NumberOfHandle = 0x%x\n", pBtMgnt->ExtConfig.NumberOfHandle));
-
-       pTriple = &pHciCmd->Data[1];
-       for (i = 0; i < pBtMgnt->ExtConfig.NumberOfHandle; i++) {
-               pBtMgnt->ExtConfig.linkInfo[i].ConnectHandle = *((u16 *)&pTriple[0]);
-               pBtMgnt->ExtConfig.linkInfo[i].IncomingTrafficMode = pTriple[2];
-               pBtMgnt->ExtConfig.linkInfo[i].OutgoingTrafficMode = pTriple[3];
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD_EXT,
-                       ("Connection_Handle = 0x%x, Incoming Traffic mode = 0x%x, Outgoing Traffic Mode = 0x%x\n",
-                       pBtMgnt->ExtConfig.linkInfo[i].ConnectHandle,
-                       pBtMgnt->ExtConfig.linkInfo[i].IncomingTrafficMode,
-                       pBtMgnt->ExtConfig.linkInfo[i].OutgoingTrafficMode));
-               pTriple += 4;
-       }
-
-       {
-               u8 localBuf[6] = "";
-               u8 *pRetPar;
-               u8 len = 0;
-               struct packet_irp_hcievent_data *PPacketIrpEvent;
-
-               PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-               len += bthci_CommandCompleteHeader(&localBuf[0],
-                       OGF_EXTENSION,
-                       HCI_SET_ACL_LINK_STATUS,
-                       status);
-
-               /*  Return parameters starts from here */
-               pRetPar = &PPacketIrpEvent->Data[len];
-               pRetPar[0] = status;            /* status */
-
-               len += 1;
-               PPacketIrpEvent->Length = len;
-
-               bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-       }
-
-       return status;
-}
-
-static enum hci_status
-bthci_CmdSetSCOLinkStatus(
-       struct rtw_adapter *padapter,
-       struct packet_irp_hcicmd_data *pHciCmd
-       )
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-       struct bt_dgb *pBtDbg = &pBTInfo->BtDbg;
-
-       pBtDbg->dbgHciInfo.hciCmdCntSetScoLinkStatus++;
-       pBtMgnt->ExtConfig.NumberOfSCO = *((u8 *)pHciCmd->Data);
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD_EXT, ("NumberOfSCO = 0x%x\n",
-               pBtMgnt->ExtConfig.NumberOfSCO));
-
-       {
-               u8 localBuf[6] = "";
-               u8 *pRetPar;
-               u8 len = 0;
-               struct packet_irp_hcievent_data *PPacketIrpEvent;
-
-               PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-               len += bthci_CommandCompleteHeader(&localBuf[0],
-                       OGF_EXTENSION,
-                       HCI_SET_SCO_LINK_STATUS,
-                       status);
-
-               /*  Return parameters starts from here */
-               pRetPar = &PPacketIrpEvent->Data[len];
-               pRetPar[0] = status;            /* status */
-
-               len += 1;
-               PPacketIrpEvent->Length = len;
-
-               bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-       }
-
-       return status;
-}
-
-static enum hci_status
-bthci_CmdSetRSSIValue(
-       struct rtw_adapter *padapter,
-       struct packet_irp_hcicmd_data *pHciCmd
-       )
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-       s8              min_bt_rssi = 0;
-       u8 i;
-       for (i = 0; i < pBtMgnt->ExtConfig.NumberOfHandle; i++) {
-               if (pBtMgnt->ExtConfig.linkInfo[i].ConnectHandle == *((u16 *)&pHciCmd->Data[0])) {
-                       pBtMgnt->ExtConfig.linkInfo[i].BT_RSSI = (s8)(pHciCmd->Data[2]);
-                       RTPRINT(FIOCTL, IOCTL_BT_EVENT_PERIODICAL,
-                       ("Connection_Handle = 0x%x, RSSI = %d \n",
-                       pBtMgnt->ExtConfig.linkInfo[i].ConnectHandle,
-                       pBtMgnt->ExtConfig.linkInfo[i].BT_RSSI));
-               }
-               /*  get the minimum bt rssi value */
-               if (pBtMgnt->ExtConfig.linkInfo[i].BT_RSSI <= min_bt_rssi)
-                       min_bt_rssi = pBtMgnt->ExtConfig.linkInfo[i].BT_RSSI;
-       }
-
-       pBtMgnt->ExtConfig.MIN_BT_RSSI = min_bt_rssi;
-       RTPRINT(FBT, BT_TRACE, ("[bt rssi], the min rssi is %d\n", min_bt_rssi));
-
-       {
-               u8 localBuf[6] = "";
-               u8 *pRetPar;
-               u8 len = 0;
-               struct packet_irp_hcievent_data *PPacketIrpEvent;
-
-               PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-               len += bthci_CommandCompleteHeader(&localBuf[0],
-                       OGF_EXTENSION,
-                       HCI_SET_RSSI_VALUE,
-                       status);
-
-               /*  Return parameters starts from here */
-               pRetPar = &PPacketIrpEvent->Data[len];
-               pRetPar[0] = status;            /* status */
-
-               len += 1;
-               PPacketIrpEvent->Length = len;
-
-               bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-       }
-
-       return status;
-}
-
-static enum hci_status
-bthci_CmdSetCurrentBluetoothStatus(
-       struct rtw_adapter *padapter,
-       struct packet_irp_hcicmd_data *pHciCmd
-       )
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-/*PMGNT_INFO   pMgntInfo = &padapter->MgntInfo; */
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-
-       pBtMgnt->ExtConfig.CurrentBTStatus = *((u8 *)&pHciCmd->Data[0]);
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD_EXT, ("SetCurrentBluetoothStatus, CurrentBTStatus = 0x%x\n",
-               pBtMgnt->ExtConfig.CurrentBTStatus));
-
-       {
-               u8 localBuf[6] = "";
-               u8 *pRetPar;
-               u8 len = 0;
-               struct packet_irp_hcievent_data *PPacketIrpEvent;
-
-               PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-               len += bthci_CommandCompleteHeader(&localBuf[0],
-                       OGF_EXTENSION,
-                       HCI_SET_CURRENT_BLUETOOTH_STATUS,
-                       status);
-
-               /*  Return parameters starts from here */
-               pRetPar = &PPacketIrpEvent->Data[len];
-               pRetPar[0] = status;            /* status */
-               len += 1;
-
-               PPacketIrpEvent->Length = len;
-
-               bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-       }
-
-       return status;
-}
-
-static enum hci_status
-bthci_CmdExtensionVersionNotify(
-       struct rtw_adapter *padapter,
-       struct packet_irp_hcicmd_data *pHciCmd
-       )
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-       struct bt_dgb *pBtDbg = &pBTInfo->BtDbg;
-
-       pBtDbg->dbgHciInfo.hciCmdCntExtensionVersionNotify++;
-       RTPRINT_DATA(FIOCTL, IOCTL_BT_HCICMD_EXT, "ExtensionVersionNotify, Hex Data :\n",
-                       &pHciCmd->Data[0], pHciCmd->Length);
-
-       pBtMgnt->ExtConfig.HCIExtensionVer = *((u16 *)&pHciCmd->Data[0]);
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD_EXT, ("HCIExtensionVer = 0x%x\n", pBtMgnt->ExtConfig.HCIExtensionVer));
-
-       {
-               u8 localBuf[6] = "";
-               u8 *pRetPar;
-               u8 len = 0;
-               struct packet_irp_hcievent_data *PPacketIrpEvent;
-
-               PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-               len += bthci_CommandCompleteHeader(&localBuf[0],
-                       OGF_EXTENSION,
-                       HCI_EXTENSION_VERSION_NOTIFY,
-                       status);
-
-               /*  Return parameters starts from here */
-               pRetPar = &PPacketIrpEvent->Data[len];
-               pRetPar[0] = status;            /* status */
-
-               len += 1;
-               PPacketIrpEvent->Length = len;
-
-               bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-       }
-
-       return status;
-}
-
-static enum hci_status
-bthci_CmdLinkStatusNotify(
-       struct rtw_adapter *padapter,
-       struct packet_irp_hcicmd_data *pHciCmd
-       )
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-       struct bt_dgb *pBtDbg = &pBTInfo->BtDbg;
-       u8 i;
-       u8 *pTriple;
-
-       pBtDbg->dbgHciInfo.hciCmdCntLinkStatusNotify++;
-       RTPRINT_DATA(FIOCTL, IOCTL_BT_HCICMD_EXT, "LinkStatusNotify, Hex Data :\n",
-                       &pHciCmd->Data[0], pHciCmd->Length);
-
-       /*  Current only RTL8723 support this command. */
-       pBtMgnt->bSupportProfile = true;
-
-       pBtMgnt->ExtConfig.NumberOfHandle = *((u8 *)pHciCmd->Data);
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD_EXT, ("NumberOfHandle = 0x%x\n", pBtMgnt->ExtConfig.NumberOfHandle));
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD_EXT, ("HCIExtensionVer = %d\n", pBtMgnt->ExtConfig.HCIExtensionVer));
-
-       pTriple = &pHciCmd->Data[1];
-       for (i = 0; i < pBtMgnt->ExtConfig.NumberOfHandle; i++) {
-               if (pBtMgnt->ExtConfig.HCIExtensionVer < 1) {
-                       pBtMgnt->ExtConfig.linkInfo[i].ConnectHandle = *((u16 *)&pTriple[0]);
-                       pBtMgnt->ExtConfig.linkInfo[i].BTProfile = pTriple[2];
-                       pBtMgnt->ExtConfig.linkInfo[i].BTCoreSpec = pTriple[3];
-                       RTPRINT(FIOCTL, IOCTL_BT_HCICMD_EXT,
-                               ("Connection_Handle = 0x%x, BTProfile =%d, BTSpec =%d\n",
-                               pBtMgnt->ExtConfig.linkInfo[i].ConnectHandle,
-                               pBtMgnt->ExtConfig.linkInfo[i].BTProfile,
-                               pBtMgnt->ExtConfig.linkInfo[i].BTCoreSpec));
-                       pTriple += 4;
-               } else {
-                       pBtMgnt->ExtConfig.linkInfo[i].ConnectHandle = *((u16 *)&pTriple[0]);
-                       pBtMgnt->ExtConfig.linkInfo[i].BTProfile = pTriple[2];
-                       pBtMgnt->ExtConfig.linkInfo[i].BTCoreSpec = pTriple[3];
-                       pBtMgnt->ExtConfig.linkInfo[i].linkRole = pTriple[4];
-                       RTPRINT(FIOCTL, IOCTL_BT_HCICMD_EXT,
-                               ("Connection_Handle = 0x%x, BTProfile =%d, BTSpec =%d, LinkRole =%d\n",
-                               pBtMgnt->ExtConfig.linkInfo[i].ConnectHandle,
-                               pBtMgnt->ExtConfig.linkInfo[i].BTProfile,
-                               pBtMgnt->ExtConfig.linkInfo[i].BTCoreSpec,
-                               pBtMgnt->ExtConfig.linkInfo[i].linkRole));
-                       pTriple += 5;
-               }
-
-       }
-       BTHCI_UpdateBTProfileRTKToMoto(padapter);
-       {
-               u8 localBuf[6] = "";
-               u8 *pRetPar;
-               u8 len = 0;
-               struct packet_irp_hcievent_data *PPacketIrpEvent;
-
-               PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-               len += bthci_CommandCompleteHeader(&localBuf[0],
-                       OGF_EXTENSION,
-                       HCI_LINK_STATUS_NOTIFY,
-                       status);
-
-               /*  Return parameters starts from here */
-               pRetPar = &PPacketIrpEvent->Data[len];
-               pRetPar[0] = status;            /* status */
-
-               len += 1;
-               PPacketIrpEvent->Length = len;
-
-               bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-       }
-
-       return status;
-}
-
-static enum hci_status
-bthci_CmdBtOperationNotify(
-       struct rtw_adapter *padapter,
-       struct packet_irp_hcicmd_data *pHciCmd
-       )
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-
-       RTPRINT_DATA(FIOCTL, IOCTL_BT_HCICMD_EXT, "Bt Operation notify, Hex Data :\n",
-                       &pHciCmd->Data[0], pHciCmd->Length);
-
-       pBtMgnt->ExtConfig.btOperationCode = *((u8 *)pHciCmd->Data);
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD_EXT, ("btOperationCode = 0x%x\n", pBtMgnt->ExtConfig.btOperationCode));
-       switch (pBtMgnt->ExtConfig.btOperationCode) {
-       case HCI_BT_OP_NONE:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD_EXT, ("[bt operation] : Operation None!!\n"));
-               break;
-       case HCI_BT_OP_INQUIRY_START:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD_EXT, ("[bt operation] : Inquire start!!\n"));
-               break;
-       case HCI_BT_OP_INQUIRY_FINISH:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD_EXT, ("[bt operation] : Inquire finished!!\n"));
-               break;
-       case HCI_BT_OP_PAGING_START:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD_EXT, ("[bt operation] : Paging is started!!\n"));
-               break;
-       case HCI_BT_OP_PAGING_SUCCESS:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD_EXT, ("[bt operation] : Paging complete successfully!!\n"));
-               break;
-       case HCI_BT_OP_PAGING_UNSUCCESS:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD_EXT, ("[bt operation] : Paging complete unsuccessfully!!\n"));
-               break;
-       case HCI_BT_OP_PAIRING_START:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD_EXT, ("[bt operation] : Pairing start!!\n"));
-               break;
-       case HCI_BT_OP_PAIRING_FINISH:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD_EXT, ("[bt operation] : Pairing finished!!\n"));
-               break;
-       case HCI_BT_OP_BT_DEV_ENABLE:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD_EXT, ("[bt operation] : BT Device is enabled!!\n"));
-               break;
-       case HCI_BT_OP_BT_DEV_DISABLE:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD_EXT, ("[bt operation] : BT Device is disabled!!\n"));
-               break;
-       default:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD_EXT, ("[bt operation] : Unknown, error!!\n"));
-               break;
-       }
-       BTDM_AdjustForBtOperation(padapter);
-       {
-               u8 localBuf[6] = "";
-               u8 *pRetPar;
-               u8 len = 0;
-               struct packet_irp_hcievent_data *PPacketIrpEvent;
-
-               PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-               len += bthci_CommandCompleteHeader(&localBuf[0],
-                       OGF_EXTENSION,
-                       HCI_BT_OPERATION_NOTIFY,
-                       status);
-
-               /*  Return parameters starts from here */
-               pRetPar = &PPacketIrpEvent->Data[len];
-               pRetPar[0] = status;            /* status */
-
-               len += 1;
-               PPacketIrpEvent->Length = len;
-
-               bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-       }
-
-       return status;
-}
-
-static enum hci_status
-bthci_CmdEnableWifiScanNotify(struct rtw_adapter *padapter,
-                             struct packet_irp_hcicmd_data *pHciCmd)
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-
-       RTPRINT_DATA(FIOCTL, IOCTL_BT_HCICMD_EXT, "Enable Wifi scan notify, Hex Data :\n",
-                       &pHciCmd->Data[0], pHciCmd->Length);
-
-       pBtMgnt->ExtConfig.bEnableWifiScanNotify = *((u8 *)pHciCmd->Data);
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD_EXT, ("bEnableWifiScanNotify = %d\n", pBtMgnt->ExtConfig.bEnableWifiScanNotify));
-
-       {
-               u8 localBuf[6] = "";
-               u8 *pRetPar;
-               u8 len = 0;
-               struct packet_irp_hcievent_data *PPacketIrpEvent;
-
-               PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-               len += bthci_CommandCompleteHeader(&localBuf[0],
-                       OGF_EXTENSION,
-                       HCI_ENABLE_WIFI_SCAN_NOTIFY,
-                       status);
-
-               /*  Return parameters starts from here */
-               pRetPar = &PPacketIrpEvent->Data[len];
-               pRetPar[0] = status;            /* status */
-
-               len += 1;
-               PPacketIrpEvent->Length = len;
-
-               bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-       }
-
-       return status;
-}
-
-static enum hci_status
-bthci_CmdWIFICurrentChannel(struct rtw_adapter *padapter,
-                           struct packet_irp_hcicmd_data *pHciCmd)
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       u8 chnl = pmlmeext->cur_channel;
-
-       if (pmlmeext->cur_bwmode == HT_CHANNEL_WIDTH_40) {
-               if (pmlmeext->cur_ch_offset == HAL_PRIME_CHNL_OFFSET_UPPER)
-                       chnl += 2;
-               else if (pmlmeext->cur_ch_offset == HAL_PRIME_CHNL_OFFSET_LOWER)
-                       chnl -= 2;
-       }
-
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD_EXT, ("Current Channel  = 0x%x\n", chnl));
-
-       {
-               u8 localBuf[8] = "";
-               u8 *pRetPar;
-               u8 len = 0;
-               struct packet_irp_hcievent_data *PPacketIrpEvent;
-
-               PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-               len += bthci_CommandCompleteHeader(&localBuf[0],
-                       OGF_EXTENSION,
-                       HCI_WIFI_CURRENT_CHANNEL,
-                       status);
-
-               /*  Return parameters starts from here */
-               pRetPar = &PPacketIrpEvent->Data[len];
-               pRetPar[0] = status;            /* status */
-               pRetPar[1] = chnl;                      /* current channel */
-               len += 2;
-               PPacketIrpEvent->Length = len;
-
-               bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-       }
-
-       return status;
-}
-
-static enum hci_status
-bthci_CmdWIFICurrentBandwidth(struct rtw_adapter *padapter,
-                             struct packet_irp_hcicmd_data *pHciCmd)
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-       enum ht_channel_width bw;
-       u8 CurrentBW = 0;
-
-       bw = padapter->mlmeextpriv.cur_bwmode;
-
-       if (bw == HT_CHANNEL_WIDTH_20)
-               CurrentBW = 0;
-       else if (bw == HT_CHANNEL_WIDTH_40)
-               CurrentBW = 1;
-
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD_EXT, ("Current BW = 0x%x\n",
-               CurrentBW));
-
-       {
-               u8 localBuf[8] = "";
-               u8 *pRetPar;
-               u8 len = 0;
-               struct packet_irp_hcievent_data *PPacketIrpEvent;
-
-               PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-               len += bthci_CommandCompleteHeader(&localBuf[0],
-                       OGF_EXTENSION,
-                       HCI_WIFI_CURRENT_BANDWIDTH,
-                       status);
-
-               /*  Return parameters starts from here */
-               pRetPar = &PPacketIrpEvent->Data[len];
-               pRetPar[0] = status;            /* status */
-               pRetPar[1] = CurrentBW;         /* current BW */
-               len += 2;
-               PPacketIrpEvent->Length = len;
-
-               bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-       }
-
-       return status;
-}
-
-static enum hci_status
-bthci_CmdWIFIConnectionStatus(
-       struct rtw_adapter *padapter,
-       struct packet_irp_hcicmd_data *pHciCmd
-       )
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-       u8 connectStatus = HCI_WIFI_NOT_CONNECTED;
-
-       if (check_fwstate(&padapter->mlmepriv, WIFI_AP_STATE)) {
-               if (padapter->stapriv.asoc_sta_count >= 3)
-                       connectStatus = HCI_WIFI_CONNECTED;
-               else
-                       connectStatus = HCI_WIFI_NOT_CONNECTED;
-       } else if (check_fwstate(&padapter->mlmepriv, WIFI_ADHOC_STATE|WIFI_ADHOC_MASTER_STATE|WIFI_ASOC_STATE)) {
-               connectStatus = HCI_WIFI_CONNECTED;
-       } else if (check_fwstate(&padapter->mlmepriv, WIFI_UNDER_LINKING)) {
-               connectStatus = HCI_WIFI_CONNECT_IN_PROGRESS;
-       } else {
-               connectStatus = HCI_WIFI_NOT_CONNECTED;
-       }
-
-       {
-               u8 localBuf[8] = "";
-               u8 *pRetPar;
-               u8 len = 0;
-               struct packet_irp_hcievent_data *PPacketIrpEvent;
-
-               PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-               len += bthci_CommandCompleteHeader(&localBuf[0],
-                       OGF_EXTENSION,
-                       HCI_WIFI_CONNECTION_STATUS,
-                       status);
-
-               /*  Return parameters starts from here */
-               pRetPar = &PPacketIrpEvent->Data[len];
-               pRetPar[0] = status;                    /* status */
-               pRetPar[1] = connectStatus;     /* connect status */
-               len += 2;
-               PPacketIrpEvent->Length = len;
-
-               bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-       }
-
-       return status;
-}
-
-static enum hci_status
-bthci_CmdEnableDeviceUnderTestMode(
-       struct rtw_adapter *padapter,
-       struct packet_irp_hcicmd_data *pHciCmd
-       )
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_hci_info *pBtHciInfo = &pBTInfo->BtHciInfo;
-
-       pBtHciInfo->bInTestMode = true;
-       pBtHciInfo->bTestIsEnd = false;
-
-       /* send command complete event here when all data are received. */
-       {
-               u8 localBuf[6] = "";
-               u8 *pRetPar;
-               u8 len = 0;
-               struct packet_irp_hcievent_data *PPacketIrpEvent;
-
-               PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-               len += bthci_CommandCompleteHeader(&localBuf[0],
-                       OGF_TESTING_COMMANDS,
-                       HCI_ENABLE_DEVICE_UNDER_TEST_MODE,
-                       status);
-
-               /*  Return parameters starts from here */
-               pRetPar = &PPacketIrpEvent->Data[len];
-               pRetPar[0] = status;            /* status */
-               len += 1;
-               PPacketIrpEvent->Length = len;
-
-               bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-       }
-
-       return status;
-}
-
-static enum hci_status
-bthci_CmdAMPTestEnd(struct rtw_adapter *padapter,
-                   struct packet_irp_hcicmd_data *pHciCmd)
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_hci_info *pBtHciInfo = &pBTInfo->BtHciInfo;
-
-       if (!pBtHciInfo->bInTestMode) {
-               RTPRINT(FIOCTL, (IOCTL_BT_EVENT|IOCTL_BT_LOGO), ("Not in Test mode, return status = HCI_STATUS_CMD_DISALLOW\n"));
-               status = HCI_STATUS_CMD_DISALLOW;
-               return status;
-       }
-
-       pBtHciInfo->bTestIsEnd = true;
-
-       del_timer_sync(&pBTInfo->BTTestSendPacketTimer);
-
-       rtl8723a_check_bssid(padapter, true);
-
-       /* send command complete event here when all data are received. */
-       {
-               u8 localBuf[4] = "";
-               struct packet_irp_hcievent_data *PPacketIrpEvent;
-
-               RTPRINT(FIOCTL, (IOCTL_BT_EVENT|IOCTL_BT_LOGO), ("AMP Test End Event \n"));
-               PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-               PPacketIrpEvent->EventCode = HCI_EVENT_AMP_TEST_END;
-               PPacketIrpEvent->Length = 2;
-
-               PPacketIrpEvent->Data[0] = status;
-               PPacketIrpEvent->Data[1] = pBtHciInfo->TestScenario;
-
-               bthci_IndicateEvent(padapter, PPacketIrpEvent, 4);
-       }
-
-       bthci_EventAMPReceiverReport(padapter, 0x01);
-
-       return status;
-}
-
-static enum hci_status
-bthci_CmdAMPTestCommand(struct rtw_adapter *padapter,
-                       struct packet_irp_hcicmd_data *pHciCmd)
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_hci_info *pBtHciInfo = &pBTInfo->BtHciInfo;
-
-       if (!pBtHciInfo->bInTestMode) {
-               RTPRINT(FIOCTL, (IOCTL_BT_EVENT|IOCTL_BT_LOGO), ("Not in Test mode, return status = HCI_STATUS_CMD_DISALLOW\n"));
-               status = HCI_STATUS_CMD_DISALLOW;
-               return status;
-       }
-
-       pBtHciInfo->TestScenario = *((u8 *)pHciCmd->Data);
-
-       if (pBtHciInfo->TestScenario == 0x01)
-               RTPRINT(FIOCTL, (IOCTL_BT_EVENT|IOCTL_BT_LOGO), ("TX Single Test \n"));
-       else if (pBtHciInfo->TestScenario == 0x02)
-               RTPRINT(FIOCTL, (IOCTL_BT_EVENT|IOCTL_BT_LOGO), ("Receive Frame Test \n"));
-       else
-               RTPRINT(FIOCTL, (IOCTL_BT_EVENT|IOCTL_BT_LOGO), ("No Such Test !!!!!!!!!!!!!!!!!! \n"));
-
-       if (pBtHciInfo->bTestIsEnd) {
-               u8 localBuf[5] = "";
-               struct packet_irp_hcievent_data *PPacketIrpEvent;
-
-               RTPRINT(FIOCTL, (IOCTL_BT_EVENT|IOCTL_BT_LOGO), ("AMP Test End Event \n"));
-               PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-               PPacketIrpEvent->EventCode = HCI_EVENT_AMP_TEST_END;
-               PPacketIrpEvent->Length = 2;
-
-               PPacketIrpEvent->Data[0] = status;
-               PPacketIrpEvent->Data[1] = pBtHciInfo->TestScenario ;
-
-               bthci_IndicateEvent(padapter, PPacketIrpEvent, 4);
-
-               /* Return to Idel state with RX and TX off. */
-
-               return status;
-       }
-
-       /*  should send command status event */
-       bthci_EventCommandStatus(padapter,
-                       OGF_TESTING_COMMANDS,
-                       HCI_AMP_TEST_COMMAND,
-                       status);
-
-       /* The HCI_AMP_Start Test Event shall be generated when the */
-       /* HCI_AMP_Test_Command has completed and the first data is ready to be sent */
-       /* or received. */
-
-       {
-               u8 localBuf[5] = "";
-               struct packet_irp_hcievent_data *PPacketIrpEvent;
-
-               RTPRINT(FIOCTL, (IOCTL_BT_EVENT|IOCTL_BT_LOGO), (" HCI_AMP_Start Test Event \n"));
-               PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-               PPacketIrpEvent->EventCode = HCI_EVENT_AMP_START_TEST;
-               PPacketIrpEvent->Length = 2;
-
-               PPacketIrpEvent->Data[0] = status;
-               PPacketIrpEvent->Data[1] = pBtHciInfo->TestScenario ;
-
-               bthci_IndicateEvent(padapter, PPacketIrpEvent, 4);
-
-               /* Return to Idel state with RX and TX off. */
-       }
-
-       if (pBtHciInfo->TestScenario == 0x01) {
-               /*
-                       When in a transmitter test scenario and the frames/bursts count have been
-                       transmitted the HCI_AMP_Test_End event shall be sent.
-               */
-               mod_timer(&pBTInfo->BTTestSendPacketTimer,
-                         jiffies + msecs_to_jiffies(50));
-               RTPRINT(FIOCTL, (IOCTL_BT_EVENT|IOCTL_BT_LOGO), ("TX Single Test \n"));
-       } else if (pBtHciInfo->TestScenario == 0x02) {
-               rtl8723a_check_bssid(padapter, false);
-               RTPRINT(FIOCTL, (IOCTL_BT_EVENT|IOCTL_BT_LOGO), ("Receive Frame Test \n"));
-       }
-
-       return status;
-}
-
-static enum hci_status
-bthci_CmdEnableAMPReceiverReports(struct rtw_adapter *padapter,
-                                 struct packet_irp_hcicmd_data *pHciCmd)
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_hci_info *pBtHciInfo = &pBTInfo->BtHciInfo;
-
-       if (!pBtHciInfo->bInTestMode) {
-               status = HCI_STATUS_CMD_DISALLOW;
-               /* send command complete event here when all data are received. */
-               {
-                       u8 localBuf[6] = "";
-                       u8 *pRetPar;
-                       u8 len = 0;
-                       struct packet_irp_hcievent_data *PPacketIrpEvent;
-
-                       PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-                       len += bthci_CommandCompleteHeader(&localBuf[0],
-                               OGF_TESTING_COMMANDS,
-                               HCI_ENABLE_AMP_RECEIVER_REPORTS,
-                               status);
-
-                       /*  Return parameters starts from here */
-                       pRetPar = &PPacketIrpEvent->Data[len];
-                       pRetPar[0] = status;            /* status */
-                       len += 1;
-                       PPacketIrpEvent->Length = len;
-
-                       bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-               }
-               return status;
-       }
-
-       pBtHciInfo->bTestNeedReport = *((u8 *)pHciCmd->Data);
-       pBtHciInfo->TestReportInterval = (*((u8 *)pHciCmd->Data+2));
-
-       bthci_EventAMPReceiverReport(padapter, 0x00);
-
-       /* send command complete event here when all data are received. */
-       {
-               u8 localBuf[6] = "";
-               u8 *pRetPar;
-               u8 len = 0;
-               struct packet_irp_hcievent_data *PPacketIrpEvent;
-
-               PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-               len += bthci_CommandCompleteHeader(&localBuf[0],
-                       OGF_TESTING_COMMANDS,
-                       HCI_ENABLE_AMP_RECEIVER_REPORTS,
-                       status);
-
-               /*  Return parameters starts from here */
-               pRetPar = &PPacketIrpEvent->Data[len];
-               pRetPar[0] = status;            /* status */
-               len += 1;
-               PPacketIrpEvent->Length = len;
-
-               bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-       }
-
-       return status;
-}
-
-static enum hci_status
-bthci_CmdHostBufferSize(struct rtw_adapter *padapter,
-                       struct packet_irp_hcicmd_data *pHciCmd)
-{
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-       struct packet_irp_hcievent_data *PPacketIrpEvent;
-       enum hci_status status = HCI_STATUS_SUCCESS;
-       u8 localBuf[6] = "";
-       u8 *pRetPar;
-       u8 len = 0;
-
-       pBTInfo->BtAsocEntry[pBtMgnt->CurrentConnectEntryNum].ACLPacketsData.ACLDataPacketLen = *((u16 *)pHciCmd->Data);
-       pBTInfo->BtAsocEntry[pBtMgnt->CurrentConnectEntryNum].SyncDataPacketLen = *((u8 *)(pHciCmd->Data+2));
-       pBTInfo->BtAsocEntry[pBtMgnt->CurrentConnectEntryNum].TotalNumACLDataPackets = *((u16 *)(pHciCmd->Data+3));
-       pBTInfo->BtAsocEntry[pBtMgnt->CurrentConnectEntryNum].TotalSyncNumDataPackets = *((u16 *)(pHciCmd->Data+5));
-
-       /* send command complete event here when all data are received. */
-       PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-       len += bthci_CommandCompleteHeader(&localBuf[0],
-               OGF_SET_EVENT_MASK_COMMAND,
-               HCI_HOST_BUFFER_SIZE,
-               status);
-
-       /*  Return parameters starts from here */
-       pRetPar = &PPacketIrpEvent->Data[len];
-       pRetPar[0] = status;            /* status */
-       len += 1;
-       PPacketIrpEvent->Length = len;
-
-       bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-
-       return status;
-}
-
-static enum hci_status
-bthci_UnknownCMD(struct rtw_adapter *padapter, struct packet_irp_hcicmd_data *pHciCmd)
-{
-       enum hci_status status = HCI_STATUS_UNKNOW_HCI_CMD;
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_dgb *pBtDbg = &pBTInfo->BtDbg;
-
-       pBtDbg->dbgHciInfo.hciCmdCntUnknown++;
-       bthci_EventCommandStatus(padapter,
-                       (u8)pHciCmd->OGF,
-                       pHciCmd->OCF,
-                       status);
-
-       return status;
-}
-
-static enum hci_status
-bthci_HandleOGFInformationalParameters(struct rtw_adapter *padapter,
-                                      struct packet_irp_hcicmd_data *pHciCmd)
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-
-       switch (pHciCmd->OCF) {
-       case HCI_READ_LOCAL_VERSION_INFORMATION:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_READ_LOCAL_VERSION_INFORMATION\n"));
-               status = bthci_CmdReadLocalVersionInformation(padapter);
-               break;
-       case HCI_READ_LOCAL_SUPPORTED_COMMANDS:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_READ_LOCAL_SUPPORTED_COMMANDS\n"));
-               status = bthci_CmdReadLocalSupportedCommands(padapter);
-               break;
-       case HCI_READ_LOCAL_SUPPORTED_FEATURES:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_READ_LOCAL_SUPPORTED_FEATURES\n"));
-               status = bthci_CmdReadLocalSupportedFeatures(padapter);
-               break;
-       case HCI_READ_BUFFER_SIZE:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_READ_BUFFER_SIZE\n"));
-               status = bthci_CmdReadBufferSize(padapter);
-               break;
-       case HCI_READ_DATA_BLOCK_SIZE:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_READ_DATA_BLOCK_SIZE\n"));
-               status = bthci_CmdReadDataBlockSize(padapter);
-               break;
-       default:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("bthci_HandleOGFInformationalParameters(), Unknown case = 0x%x\n", pHciCmd->OCF));
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_UNKNOWN_COMMAND\n"));
-               status = bthci_UnknownCMD(padapter, pHciCmd);
-               break;
-       }
-       return status;
-}
-
-static enum hci_status
-bthci_HandleOGFSetEventMaskCMD(struct rtw_adapter *padapter,
-                              struct packet_irp_hcicmd_data *pHciCmd)
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-
-       switch (pHciCmd->OCF) {
-       case HCI_SET_EVENT_MASK:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_SET_EVENT_MASK\n"));
-               status = bthci_CmdSetEventMask(padapter, pHciCmd);
-               break;
-       case HCI_RESET:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_RESET\n"));
-               status = bthci_CmdReset(padapter, true);
-               break;
-       case HCI_READ_CONNECTION_ACCEPT_TIMEOUT:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_READ_CONNECTION_ACCEPT_TIMEOUT\n"));
-               status = bthci_CmdReadConnectionAcceptTimeout(padapter);
-               break;
-       case HCI_SET_EVENT_FILTER:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_SET_EVENT_FILTER\n"));
-               break;
-       case HCI_WRITE_CONNECTION_ACCEPT_TIMEOUT:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_WRITE_CONNECTION_ACCEPT_TIMEOUT\n"));
-               status = bthci_CmdWriteConnectionAcceptTimeout(padapter, pHciCmd);
-               break;
-       case HCI_READ_PAGE_TIMEOUT:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_READ_PAGE_TIMEOUT\n"));
-               status = bthci_CmdReadPageTimeout(padapter, pHciCmd);
-               break;
-       case HCI_WRITE_PAGE_TIMEOUT:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_WRITE_PAGE_TIMEOUT\n"));
-               status = bthci_CmdWritePageTimeout(padapter, pHciCmd);
-               break;
-       case HCI_HOST_NUMBER_OF_COMPLETED_PACKETS:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_HOST_NUMBER_OF_COMPLETED_PACKETS\n"));
-               break;
-       case HCI_READ_LINK_SUPERVISION_TIMEOUT:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_READ_LINK_SUPERVISION_TIMEOUT\n"));
-               status = bthci_CmdReadLinkSupervisionTimeout(padapter, pHciCmd);
-               break;
-       case HCI_WRITE_LINK_SUPERVISION_TIMEOUT:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_WRITE_LINK_SUPERVISION_TIMEOUT\n"));
-               status = bthci_CmdWriteLinkSupervisionTimeout(padapter, pHciCmd);
-               break;
-       case HCI_ENHANCED_FLUSH:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_ENHANCED_FLUSH\n"));
-               status = bthci_CmdEnhancedFlush(padapter, pHciCmd);
-               break;
-       case HCI_READ_LOGICAL_LINK_ACCEPT_TIMEOUT:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_READ_LOGICAL_LINK_ACCEPT_TIMEOUT\n"));
-               status = bthci_CmdReadLogicalLinkAcceptTimeout(padapter, pHciCmd);
-               break;
-       case HCI_WRITE_LOGICAL_LINK_ACCEPT_TIMEOUT:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_WRITE_LOGICAL_LINK_ACCEPT_TIMEOUT\n"));
-               status = bthci_CmdWriteLogicalLinkAcceptTimeout(padapter, pHciCmd);
-               break;
-       case HCI_SET_EVENT_MASK_PAGE_2:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_SET_EVENT_MASK_PAGE_2\n"));
-               status = bthci_CmdSetEventMaskPage2(padapter, pHciCmd);
-               break;
-       case HCI_READ_LOCATION_DATA:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_READ_LOCATION_DATA\n"));
-               status = bthci_CmdReadLocationData(padapter, pHciCmd);
-               break;
-       case HCI_WRITE_LOCATION_DATA:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_WRITE_LOCATION_DATA\n"));
-               status = bthci_CmdWriteLocationData(padapter, pHciCmd);
-               break;
-       case HCI_READ_FLOW_CONTROL_MODE:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_READ_FLOW_CONTROL_MODE\n"));
-               status = bthci_CmdReadFlowControlMode(padapter, pHciCmd);
-               break;
-       case HCI_WRITE_FLOW_CONTROL_MODE:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_WRITE_FLOW_CONTROL_MODE\n"));
-               status = bthci_CmdWriteFlowControlMode(padapter, pHciCmd);
-               break;
-       case HCI_READ_BEST_EFFORT_FLUSH_TIMEOUT:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_READ_BEST_EFFORT_FLUSH_TIMEOUT\n"));
-               status = bthci_CmdReadBestEffortFlushTimeout(padapter, pHciCmd);
-               break;
-       case HCI_WRITE_BEST_EFFORT_FLUSH_TIMEOUT:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_WRITE_BEST_EFFORT_FLUSH_TIMEOUT\n"));
-               status = bthci_CmdWriteBestEffortFlushTimeout(padapter, pHciCmd);
-               break;
-       case HCI_SHORT_RANGE_MODE:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_SHORT_RANGE_MODE\n"));
-               status = bthci_CmdShortRangeMode(padapter, pHciCmd);
-               break;
-       case HCI_HOST_BUFFER_SIZE:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_HOST_BUFFER_SIZE\n"));
-               status = bthci_CmdHostBufferSize(padapter, pHciCmd);
-               break;
-       default:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("bthci_HandleOGFSetEventMaskCMD(), Unknown case = 0x%x\n", pHciCmd->OCF));
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_UNKNOWN_COMMAND\n"));
-               status = bthci_UnknownCMD(padapter, pHciCmd);
-               break;
-       }
-       return status;
-}
-
-static enum hci_status
-bthci_HandleOGFStatusParameters(struct rtw_adapter *padapter,
-                               struct packet_irp_hcicmd_data *pHciCmd)
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-
-       switch (pHciCmd->OCF) {
-       case HCI_READ_FAILED_CONTACT_COUNTER:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_READ_FAILED_CONTACT_COUNTER\n"));
-               status = bthci_CmdReadFailedContactCounter(padapter, pHciCmd);
-               break;
-       case HCI_RESET_FAILED_CONTACT_COUNTER:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_RESET_FAILED_CONTACT_COUNTER\n"));
-               status = bthci_CmdResetFailedContactCounter(padapter, pHciCmd);
-               break;
-       case HCI_READ_LINK_QUALITY:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_READ_LINK_QUALITY\n"));
-               status = bthci_CmdReadLinkQuality(padapter, pHciCmd);
-               break;
-       case HCI_READ_RSSI:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_READ_RSSI\n"));
-               break;
-       case HCI_READ_LOCAL_AMP_INFO:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_READ_LOCAL_AMP_INFO\n"));
-               status = bthci_CmdReadLocalAMPInfo(padapter);
-               break;
-       case HCI_READ_LOCAL_AMP_ASSOC:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_READ_LOCAL_AMP_ASSOC\n"));
-               status = bthci_CmdReadLocalAMPAssoc(padapter, pHciCmd);
-               break;
-       case HCI_WRITE_REMOTE_AMP_ASSOC:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_WRITE_REMOTE_AMP_ASSOC\n"));
-               status = bthci_CmdWriteRemoteAMPAssoc(padapter, pHciCmd);
-               break;
-       default:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("bthci_HandleOGFStatusParameters(), Unknown case = 0x%x\n", pHciCmd->OCF));
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_UNKNOWN_COMMAND\n"));
-               status = bthci_UnknownCMD(padapter, pHciCmd);
-               break;
-       }
-       return status;
-}
-
-static enum hci_status
-bthci_HandleOGFLinkControlCMD(struct rtw_adapter *padapter,
-                             struct packet_irp_hcicmd_data *pHciCmd)
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-
-       switch (pHciCmd->OCF) {
-       case HCI_CREATE_PHYSICAL_LINK:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_CREATE_PHYSICAL_LINK\n"));
-               status = bthci_CmdCreatePhysicalLink(padapter, pHciCmd);
-               break;
-       case HCI_ACCEPT_PHYSICAL_LINK:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_ACCEPT_PHYSICAL_LINK\n"));
-               status = bthci_CmdAcceptPhysicalLink(padapter, pHciCmd);
-               break;
-       case HCI_DISCONNECT_PHYSICAL_LINK:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_DISCONNECT_PHYSICAL_LINK\n"));
-               status = bthci_CmdDisconnectPhysicalLink(padapter, pHciCmd);
-               break;
-       case HCI_CREATE_LOGICAL_LINK:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_CREATE_LOGICAL_LINK\n"));
-               status = bthci_CmdCreateLogicalLink(padapter, pHciCmd);
-               break;
-       case HCI_ACCEPT_LOGICAL_LINK:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_ACCEPT_LOGICAL_LINK\n"));
-               status = bthci_CmdAcceptLogicalLink(padapter, pHciCmd);
-               break;
-       case HCI_DISCONNECT_LOGICAL_LINK:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_DISCONNECT_LOGICAL_LINK\n"));
-               status = bthci_CmdDisconnectLogicalLink(padapter, pHciCmd);
-               break;
-       case HCI_LOGICAL_LINK_CANCEL:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_LOGICAL_LINK_CANCEL\n"));
-               status = bthci_CmdLogicalLinkCancel(padapter, pHciCmd);
-               break;
-       case HCI_FLOW_SPEC_MODIFY:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_FLOW_SPEC_MODIFY\n"));
-               status = bthci_CmdFlowSpecModify(padapter, pHciCmd);
-               break;
-       default:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("bthci_HandleOGFLinkControlCMD(), Unknown case = 0x%x\n", pHciCmd->OCF));
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_UNKNOWN_COMMAND\n"));
-               status = bthci_UnknownCMD(padapter, pHciCmd);
-               break;
-       }
-       return status;
-}
-
-static enum hci_status
-bthci_HandleOGFTestingCMD(struct rtw_adapter *padapter,
-                         struct packet_irp_hcicmd_data *pHciCmd)
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-       switch (pHciCmd->OCF) {
-       case HCI_ENABLE_DEVICE_UNDER_TEST_MODE:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_ENABLE_DEVICE_UNDER_TEST_MODE\n"));
-               bthci_CmdEnableDeviceUnderTestMode(padapter, pHciCmd);
-               break;
-       case HCI_AMP_TEST_END:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_AMP_TEST_END\n"));
-               bthci_CmdAMPTestEnd(padapter, pHciCmd);
-               break;
-       case HCI_AMP_TEST_COMMAND:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_AMP_TEST_COMMAND\n"));
-               bthci_CmdAMPTestCommand(padapter, pHciCmd);
-               break;
-       case HCI_ENABLE_AMP_RECEIVER_REPORTS:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_ENABLE_AMP_RECEIVER_REPORTS\n"));
-               bthci_CmdEnableAMPReceiverReports(padapter, pHciCmd);
-               break;
-       default:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_UNKNOWN_COMMAND\n"));
-               status = bthci_UnknownCMD(padapter, pHciCmd);
-               break;
-       }
-       return status;
-}
-
-static enum hci_status
-bthci_HandleOGFExtension(struct rtw_adapter *padapter,
-                        struct packet_irp_hcicmd_data *pHciCmd)
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-       switch (pHciCmd->OCF) {
-       case HCI_SET_ACL_LINK_DATA_FLOW_MODE:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD_EXT, ("HCI_SET_ACL_LINK_DATA_FLOW_MODE\n"));
-               status = bthci_CmdSetACLLinkDataFlowMode(padapter, pHciCmd);
-               break;
-       case HCI_SET_ACL_LINK_STATUS:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD_EXT, ("HCI_SET_ACL_LINK_STATUS\n"));
-               status = bthci_CmdSetACLLinkStatus(padapter, pHciCmd);
-               break;
-       case HCI_SET_SCO_LINK_STATUS:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD_EXT, ("HCI_SET_SCO_LINK_STATUS\n"));
-               status = bthci_CmdSetSCOLinkStatus(padapter, pHciCmd);
-               break;
-       case HCI_SET_RSSI_VALUE:
-               RTPRINT(FIOCTL, IOCTL_BT_EVENT_PERIODICAL, ("HCI_SET_RSSI_VALUE\n"));
-               status = bthci_CmdSetRSSIValue(padapter, pHciCmd);
-               break;
-       case HCI_SET_CURRENT_BLUETOOTH_STATUS:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD_EXT, ("HCI_SET_CURRENT_BLUETOOTH_STATUS\n"));
-               status = bthci_CmdSetCurrentBluetoothStatus(padapter, pHciCmd);
-               break;
-       /* The following is for RTK8723 */
-
-       case HCI_EXTENSION_VERSION_NOTIFY:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD_EXT, ("HCI_EXTENSION_VERSION_NOTIFY\n"));
-               status = bthci_CmdExtensionVersionNotify(padapter, pHciCmd);
-               break;
-       case HCI_LINK_STATUS_NOTIFY:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD_EXT, ("HCI_LINK_STATUS_NOTIFY\n"));
-               status = bthci_CmdLinkStatusNotify(padapter, pHciCmd);
-               break;
-       case HCI_BT_OPERATION_NOTIFY:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD_EXT, ("HCI_BT_OPERATION_NOTIFY\n"));
-               status = bthci_CmdBtOperationNotify(padapter, pHciCmd);
-               break;
-       case HCI_ENABLE_WIFI_SCAN_NOTIFY:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD_EXT, ("HCI_ENABLE_WIFI_SCAN_NOTIFY\n"));
-               status = bthci_CmdEnableWifiScanNotify(padapter, pHciCmd);
-               break;
-
-       /* The following is for IVT */
-       case HCI_WIFI_CURRENT_CHANNEL:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD_EXT, ("HCI_WIFI_CURRENT_CHANNEL\n"));
-               status = bthci_CmdWIFICurrentChannel(padapter, pHciCmd);
-               break;
-       case HCI_WIFI_CURRENT_BANDWIDTH:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD_EXT, ("HCI_WIFI_CURRENT_BANDWIDTH\n"));
-               status = bthci_CmdWIFICurrentBandwidth(padapter, pHciCmd);
-               break;
-       case HCI_WIFI_CONNECTION_STATUS:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD_EXT, ("HCI_WIFI_CONNECTION_STATUS\n"));
-               status = bthci_CmdWIFIConnectionStatus(padapter, pHciCmd);
-               break;
-
-       default:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD_EXT, ("HCI_UNKNOWN_COMMAND\n"));
-               status = bthci_UnknownCMD(padapter, pHciCmd);
-               break;
-       }
-       return status;
-}
-
-static void
-bthci_StateStarting(struct rtw_adapter *padapter,
-                   enum hci_state_with_cmd StateCmd, u8 EntryNum)
-{
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-
-       RTPRINT(FIOCTL, IOCTL_STATE, ("[BT state], [Starting], "));
-       switch (StateCmd) {
-       case STATE_CMD_CONNECT_ACCEPT_TIMEOUT:
-               RTPRINT(FIOCTL, IOCTL_STATE, ("STATE_CMD_CONNECT_ACCEPT_TIMEOUT\n"));
-               pBTInfo->BtAsocEntry[EntryNum].PhysLinkCompleteStatus = HCI_STATUS_CONNECT_ACCEPT_TIMEOUT;
-               pBtMgnt->bNeedNotifyAMPNoCap = true;
-               BTHCI_DisconnectPeer(padapter, EntryNum);
-               break;
-       case STATE_CMD_DISCONNECT_PHY_LINK:
-               RTPRINT(FIOCTL, IOCTL_STATE, ("STATE_CMD_DISCONNECT_PHY_LINK\n"));
-
-               bthci_EventDisconnectPhyLinkComplete(padapter,
-               HCI_STATUS_SUCCESS,
-               pBTInfo->BtAsocEntry[EntryNum].PhyLinkDisconnectReason,
-               EntryNum);
-
-               del_timer_sync(&pBTInfo->BTHCIJoinTimeoutTimer);
-
-               pBTInfo->BtAsocEntry[EntryNum].PhysLinkCompleteStatus = HCI_STATUS_UNKNOW_CONNECT_ID;
-
-               BTHCI_DisconnectPeer(padapter, EntryNum);
-               break;
-       case STATE_CMD_MAC_START_COMPLETE:
-               RTPRINT(FIOCTL, IOCTL_STATE, ("STATE_CMD_MAC_START_COMPLETE\n"));
-               if (pBTInfo->BtAsocEntry[EntryNum].AMPRole == AMP_BTAP_CREATOR)
-                       bthci_EventChannelSelected(padapter, EntryNum);
-               break;
-       default:
-               RTPRINT(FIOCTL, IOCTL_STATE, ("State command(%d) is Wrong !!!\n", StateCmd));
-               break;
-       }
-}
-
-static void
-bthci_StateConnecting(struct rtw_adapter *padapter,
-                     enum hci_state_with_cmd StateCmd, u8 EntryNum)
-{
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-
-       RTPRINT(FIOCTL, IOCTL_STATE, ("[BT state], [Connecting], "));
-       switch (StateCmd) {
-       case STATE_CMD_CONNECT_ACCEPT_TIMEOUT:
-               RTPRINT(FIOCTL, IOCTL_STATE, ("STATE_CMD_CONNECT_ACCEPT_TIMEOUT\n"));
-               pBTInfo->BtAsocEntry[EntryNum].PhysLinkCompleteStatus = HCI_STATUS_CONNECT_ACCEPT_TIMEOUT;
-               pBtMgnt->bNeedNotifyAMPNoCap = true;
-               BTHCI_DisconnectPeer(padapter, EntryNum);
-               break;
-       case STATE_CMD_MAC_CONNECT_COMPLETE:
-               RTPRINT(FIOCTL, IOCTL_STATE, ("STATE_CMD_MAC_CONNECT_COMPLETE\n"));
-
-               if (pBTInfo->BtAsocEntry[EntryNum].AMPRole == AMP_BTAP_JOINER) {
-                       RT_TRACE(_module_rtl871x_security_c_, _drv_info_,
-                                "StateConnecting\n");
-               }
-               break;
-       case STATE_CMD_DISCONNECT_PHY_LINK:
-               RTPRINT(FIOCTL, IOCTL_STATE, ("STATE_CMD_DISCONNECT_PHY_LINK\n"));
-
-               bthci_EventDisconnectPhyLinkComplete(padapter,
-               HCI_STATUS_SUCCESS,
-               pBTInfo->BtAsocEntry[EntryNum].PhyLinkDisconnectReason,
-               EntryNum);
-
-               pBTInfo->BtAsocEntry[EntryNum].PhysLinkCompleteStatus = HCI_STATUS_UNKNOW_CONNECT_ID;
-
-               del_timer_sync(&pBTInfo->BTHCIJoinTimeoutTimer);
-
-               BTHCI_DisconnectPeer(padapter, EntryNum);
-
-               break;
-       case STATE_CMD_MAC_CONNECT_CANCEL_INDICATE:
-               RTPRINT(FIOCTL, IOCTL_STATE, ("STATE_CMD_MAC_CONNECT_CANCEL_INDICATE\n"));
-               pBTInfo->BtAsocEntry[EntryNum].PhysLinkCompleteStatus = HCI_STATUS_CONTROLLER_BUSY;
-               /*  Because this state cmd is caused by the BTHCI_EventAMPStatusChange(), */
-               /*  we don't need to send event in the following BTHCI_DisconnectPeer() again. */
-               pBtMgnt->bNeedNotifyAMPNoCap = false;
-               BTHCI_DisconnectPeer(padapter, EntryNum);
-               break;
-       default:
-               RTPRINT(FIOCTL, IOCTL_STATE, ("State command(%d) is Wrong !!!\n", StateCmd));
-               break;
-       }
-}
-
-static void
-bthci_StateConnected(struct rtw_adapter *padapter,
-                    enum hci_state_with_cmd StateCmd, u8 EntryNum)
-{
-/*PMGNT_INFO pMgntInfo = &padapter->MgntInfo; */
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-       u8 i;
-       u16 logicHandle = 0;
-
-       RTPRINT(FIOCTL, IOCTL_STATE, ("[BT state], [Connected], "));
-       switch (StateCmd) {
-       case STATE_CMD_DISCONNECT_PHY_LINK:
-               RTPRINT(FIOCTL, IOCTL_STATE, ("STATE_CMD_DISCONNECT_PHY_LINK\n"));
-
-               /* When we are trying to disconnect the phy link, we should disconnect log link first, */
-               for (i = 0; i < MAX_LOGICAL_LINK_NUM; i++) {
-                       if (pBTInfo->BtAsocEntry[EntryNum].LogLinkCmdData->BtLogLinkhandle != 0) {
-                               logicHandle = pBTInfo->BtAsocEntry[EntryNum].LogLinkCmdData->BtLogLinkhandle;
-
-                               bthci_EventDisconnectLogicalLinkComplete(padapter, HCI_STATUS_SUCCESS,
-                                       logicHandle, pBTInfo->BtAsocEntry[EntryNum].PhyLinkDisconnectReason);
-
-                               pBTInfo->BtAsocEntry[EntryNum].LogLinkCmdData->BtLogLinkhandle = 0;
-                       }
-               }
-
-               bthci_EventDisconnectPhyLinkComplete(padapter,
-               HCI_STATUS_SUCCESS,
-               pBTInfo->BtAsocEntry[EntryNum].PhyLinkDisconnectReason,
-               EntryNum);
-
-               del_timer_sync(&pBTInfo->BTHCIJoinTimeoutTimer);
-
-               BTHCI_DisconnectPeer(padapter, EntryNum);
-               break;
-
-       case STATE_CMD_MAC_DISCONNECT_INDICATE:
-               RTPRINT(FIOCTL, IOCTL_STATE, ("STATE_CMD_MAC_DISCONNECT_INDICATE\n"));
-
-               bthci_EventDisconnectPhyLinkComplete(padapter,
-               HCI_STATUS_SUCCESS,
-               /*  TODO: Remote Host not local host */
-               HCI_STATUS_CONNECT_TERMINATE_LOCAL_HOST,
-               EntryNum);
-               BTHCI_DisconnectPeer(padapter, EntryNum);
-
-               break;
-       case STATE_CMD_ENTER_STATE:
-               RTPRINT(FIOCTL, IOCTL_STATE, ("STATE_CMD_ENTER_STATE\n"));
-
-               if (pBtMgnt->bBTConnectInProgress) {
-                       pBtMgnt->bBTConnectInProgress = false;
-                       RTPRINT(FIOCTL, IOCTL_STATE, ("[BT Flag], BT Connect in progress OFF!!\n"));
-               }
-               pBTInfo->BtAsocEntry[EntryNum].BtCurrentState = HCI_STATE_CONNECTED;
-               pBTInfo->BtAsocEntry[EntryNum].b4waySuccess = true;
-               pBtMgnt->bStartSendSupervisionPkt = true;
-
-               /*  for rate adaptive */
-
-               rtl8723a_update_ramask(padapter,
-                                      MAX_FW_SUPPORT_MACID_NUM-1-EntryNum, 0);
-
-               HalSetBrateCfg23a(padapter, padapter->mlmepriv.cur_network.network.SupportedRates);
-               BTDM_SetFwChnlInfo(padapter, RT_MEDIA_CONNECT);
-               break;
-       default:
-               RTPRINT(FIOCTL, IOCTL_STATE, ("State command(%d) is Wrong !!!\n", StateCmd));
-               break;
-       }
-}
-
-static void
-bthci_StateAuth(struct rtw_adapter *padapter, enum hci_state_with_cmd StateCmd,
-               u8 EntryNum)
-{
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-
-       RTPRINT(FIOCTL, IOCTL_STATE, ("[BT state], [Authenticating], "));
-       switch (StateCmd) {
-       case STATE_CMD_CONNECT_ACCEPT_TIMEOUT:
-               RTPRINT(FIOCTL, IOCTL_STATE, ("STATE_CMD_CONNECT_ACCEPT_TIMEOUT\n"));
-               pBTInfo->BtAsocEntry[EntryNum].PhysLinkCompleteStatus = HCI_STATUS_CONNECT_ACCEPT_TIMEOUT;
-               pBtMgnt->bNeedNotifyAMPNoCap = true;
-               BTHCI_DisconnectPeer(padapter, EntryNum);
-               break;
-       case STATE_CMD_DISCONNECT_PHY_LINK:
-               RTPRINT(FIOCTL, IOCTL_STATE, ("STATE_CMD_DISCONNECT_PHY_LINK\n"));
-               bthci_EventDisconnectPhyLinkComplete(padapter,
-               HCI_STATUS_SUCCESS,
-               pBTInfo->BtAsocEntry[EntryNum].PhyLinkDisconnectReason,
-               EntryNum);
-
-               pBTInfo->BtAsocEntry[EntryNum].PhysLinkCompleteStatus = HCI_STATUS_UNKNOW_CONNECT_ID;
-
-               del_timer_sync(&pBTInfo->BTHCIJoinTimeoutTimer);
-
-               BTHCI_DisconnectPeer(padapter, EntryNum);
-               break;
-       case STATE_CMD_4WAY_FAILED:
-               RTPRINT(FIOCTL, IOCTL_STATE, ("STATE_CMD_4WAY_FAILED\n"));
-
-               pBTInfo->BtAsocEntry[EntryNum].PhysLinkCompleteStatus = HCI_STATUS_AUTH_FAIL;
-               pBtMgnt->bNeedNotifyAMPNoCap = true;
-
-               BTHCI_DisconnectPeer(padapter, EntryNum);
-
-               del_timer_sync(&pBTInfo->BTHCIJoinTimeoutTimer);
-               break;
-       case STATE_CMD_4WAY_SUCCESSED:
-               RTPRINT(FIOCTL, IOCTL_STATE, ("STATE_CMD_4WAY_SUCCESSED\n"));
-
-               bthci_EventPhysicalLinkComplete(padapter, HCI_STATUS_SUCCESS, EntryNum, INVALID_PL_HANDLE);
-
-               del_timer_sync(&pBTInfo->BTHCIJoinTimeoutTimer);
-
-               BTHCI_SM_WITH_INFO(padapter, HCI_STATE_CONNECTED, STATE_CMD_ENTER_STATE, EntryNum);
-               break;
-       default:
-               RTPRINT(FIOCTL, IOCTL_STATE, ("State command(%d) is Wrong !!!\n", StateCmd));
-               break;
-       }
-}
-
-static void
-bthci_StateDisconnecting(struct rtw_adapter *padapter,
-                        enum hci_state_with_cmd StateCmd, u8 EntryNum)
-{
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-
-       RTPRINT(FIOCTL, IOCTL_STATE, ("[BT state], [Disconnecting], "));
-       switch (StateCmd) {
-       case STATE_CMD_MAC_CONNECT_CANCEL_INDICATE:
-               RTPRINT(FIOCTL, IOCTL_STATE, ("STATE_CMD_MAC_CONNECT_CANCEL_INDICATE\n"));
-               if (pBTInfo->BtAsocEntry[EntryNum].bNeedPhysLinkCompleteEvent) {
-                       bthci_EventPhysicalLinkComplete(padapter,
-                               pBTInfo->BtAsocEntry[EntryNum].PhysLinkCompleteStatus,
-                               EntryNum, INVALID_PL_HANDLE);
-               }
-
-               if (pBtMgnt->bBTConnectInProgress) {
-                       pBtMgnt->bBTConnectInProgress = false;
-                       RTPRINT(FIOCTL, IOCTL_STATE, ("[BT Flag], BT Connect in progress OFF!!\n"));
-               }
-
-               BTHCI_SM_WITH_INFO(padapter, HCI_STATE_DISCONNECTED, STATE_CMD_ENTER_STATE, EntryNum);
-               break;
-       case STATE_CMD_DISCONNECT_PHY_LINK:
-               RTPRINT(FIOCTL, IOCTL_STATE, ("STATE_CMD_DISCONNECT_PHY_LINK\n"));
-
-               bthci_EventDisconnectPhyLinkComplete(padapter,
-               HCI_STATUS_SUCCESS,
-               pBTInfo->BtAsocEntry[EntryNum].PhyLinkDisconnectReason,
-               EntryNum);
-
-               del_timer_sync(&pBTInfo->BTHCIJoinTimeoutTimer);
-
-               BTHCI_DisconnectPeer(padapter, EntryNum);
-               break;
-       default:
-               RTPRINT(FIOCTL, IOCTL_STATE, ("State command(%d) is Wrong !!!\n", StateCmd));
-               break;
-       }
-}
-
-static void
-bthci_StateDisconnected(struct rtw_adapter *padapter,
-                       enum hci_state_with_cmd StateCmd, u8 EntryNum)
-{
-/*PMGNT_INFO pMgntInfo = &padapter->MgntInfo; */
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_hci_info *pBtHciInfo = &pBTInfo->BtHciInfo;
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-
-       RTPRINT(FIOCTL, IOCTL_STATE, ("[BT state], [Disconnected], "));
-       switch (StateCmd) {
-       case STATE_CMD_CREATE_PHY_LINK:
-       case STATE_CMD_ACCEPT_PHY_LINK:
-               if (StateCmd == STATE_CMD_CREATE_PHY_LINK)
-                       RTPRINT(FIOCTL, IOCTL_STATE, ("STATE_CMD_CREATE_PHY_LINK\n"));
-               else
-                       RTPRINT(FIOCTL, IOCTL_STATE, ("STATE_CMD_ACCEPT_PHY_LINK\n"));
-
-               RTPRINT(FIOCTL, IOCTL_STATE, ("[BT PS], Disable IPS and LPS\n"));
-               ips_leave23a(padapter);
-               LPS_Leave23a(padapter);
-
-               pBtMgnt->bPhyLinkInProgress = true;
-               pBtMgnt->BTCurrentConnectType = BT_DISCONNECT;
-               pBtMgnt->CurrentBTConnectionCnt++;
-               RTPRINT(FIOCTL, IOCTL_STATE, ("[BT Flag], CurrentBTConnectionCnt = %d\n",
-                       pBtMgnt->CurrentBTConnectionCnt));
-               pBtMgnt->BtOperationOn = true;
-               RTPRINT(FIOCTL, IOCTL_STATE, ("[BT Flag], Bt Operation ON!! CurrentConnectEntryNum = %d\n",
-                       pBtMgnt->CurrentConnectEntryNum));
-
-               if (pBtMgnt->bBTConnectInProgress) {
-                       bthci_EventPhysicalLinkComplete(padapter, HCI_STATUS_CONTROLLER_BUSY, INVALID_ENTRY_NUM, pBtMgnt->BtCurrentPhyLinkhandle);
-                       bthci_RemoveEntryByEntryNum(padapter, EntryNum);
-                       return;
-               }
-
-               if (StateCmd == STATE_CMD_CREATE_PHY_LINK)
-                       pBTInfo->BtAsocEntry[EntryNum].AMPRole = AMP_BTAP_CREATOR;
-               else
-                       pBTInfo->BtAsocEntry[EntryNum].AMPRole = AMP_BTAP_JOINER;
-
-               /*  1. MAC not yet in selected channel */
-               while (check_fwstate(&padapter->mlmepriv, WIFI_ASOC_STATE|WIFI_SITE_MONITOR)) {
-                       RTPRINT(FIOCTL, IOCTL_STATE, ("Scan/Roaming/Wifi Link is in Progress, wait 200 ms\n"));
-                       mdelay(200);
-               }
-               /*  2. MAC already in selected channel */
-               RTPRINT(FIOCTL, IOCTL_STATE, ("Channel is Ready\n"));
-               mod_timer(&pBTInfo->BTHCIJoinTimeoutTimer,
-                         jiffies + msecs_to_jiffies(pBtHciInfo->ConnAcceptTimeout));
-
-               pBTInfo->BtAsocEntry[EntryNum].bNeedPhysLinkCompleteEvent = true;
-               break;
-       case STATE_CMD_DISCONNECT_PHY_LINK:
-               RTPRINT(FIOCTL, IOCTL_STATE, ("STATE_CMD_DISCONNECT_PHY_LINK\n"));
-
-               del_timer_sync(&pBTInfo->BTHCIJoinTimeoutTimer);
-
-               bthci_EventDisconnectPhyLinkComplete(padapter,
-               HCI_STATUS_SUCCESS,
-               pBTInfo->BtAsocEntry[EntryNum].PhyLinkDisconnectReason,
-               EntryNum);
-
-               if (pBTInfo->BtAsocEntry[EntryNum].bNeedPhysLinkCompleteEvent) {
-                       bthci_EventPhysicalLinkComplete(padapter,
-                               HCI_STATUS_UNKNOW_CONNECT_ID,
-                               EntryNum, INVALID_PL_HANDLE);
-               }
-
-               if (pBtMgnt->bBTConnectInProgress) {
-                       pBtMgnt->bBTConnectInProgress = false;
-                       RTPRINT(FIOCTL, IOCTL_STATE, ("[BT Flag], BT Connect in progress OFF!!\n"));
-               }
-               BTHCI_SM_WITH_INFO(padapter, HCI_STATE_DISCONNECTED, STATE_CMD_ENTER_STATE, EntryNum);
-               bthci_RemoveEntryByEntryNum(padapter, EntryNum);
-               break;
-       case STATE_CMD_ENTER_STATE:
-               RTPRINT(FIOCTL, IOCTL_STATE, ("STATE_CMD_ENTER_STATE\n"));
-               break;
-       default:
-               RTPRINT(FIOCTL, IOCTL_STATE, ("State command(%d) is Wrong !!!\n", StateCmd));
-               break;
-       }
-}
-
-void BTHCI_EventParse(struct rtw_adapter *padapter, void *pEvntData, u32 dataLen)
-{
-}
-
-u8 BTHCI_HsConnectionEstablished(struct rtw_adapter *padapter)
-{
-       u8 bBtConnectionExist = false;
-       struct bt_30info *pBtinfo = GET_BT_INFO(padapter);
-       u8 i;
-
-       for (i = 0; i < MAX_BT_ASOC_ENTRY_NUM; i++) {
-               if (pBtinfo->BtAsocEntry[i].b4waySuccess) {
-                       bBtConnectionExist = true;
-                       break;
-               }
-       }
-
-/*RTPRINT(FIOCTL, IOCTL_STATE, (" BTHCI_HsConnectionEstablished(), connection exist = %d\n", bBtConnectionExist)); */
-
-       return bBtConnectionExist;
-}
-
-static u8
-BTHCI_CheckProfileExist(struct rtw_adapter *padapter,
-                       enum bt_traffic_mode_profile Profile)
-{
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-       u8 IsPRofile = false;
-       u8 i = 0;
-
-       for (i = 0; i < pBtMgnt->ExtConfig.NumberOfHandle; i++) {
-               if (pBtMgnt->ExtConfig.linkInfo[i].TrafficProfile == Profile) {
-                       IsPRofile = true;
-                       break;
-               }
-       }
-
-       return IsPRofile;
-}
-
-void BTHCI_UpdateBTProfileRTKToMoto(struct rtw_adapter *padapter)
-{
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-       u8 i = 0;
-
-       pBtMgnt->ExtConfig.NumberOfSCO = 0;
-
-       for (i = 0; i < pBtMgnt->ExtConfig.NumberOfHandle; i++) {
-               pBtMgnt->ExtConfig.linkInfo[i].TrafficProfile = BT_PROFILE_NONE;
-
-               if (pBtMgnt->ExtConfig.linkInfo[i].BTProfile == BT_PROFILE_SCO)
-                       pBtMgnt->ExtConfig.NumberOfSCO++;
-
-               pBtMgnt->ExtConfig.linkInfo[i].TrafficProfile = pBtMgnt->ExtConfig.linkInfo[i].BTProfile;
-               switch (pBtMgnt->ExtConfig.linkInfo[i].TrafficProfile) {
-               case BT_PROFILE_SCO:
-                       break;
-               case BT_PROFILE_PAN:
-                       pBtMgnt->ExtConfig.linkInfo[i].IncomingTrafficMode = BT_MOTOR_EXT_BE;
-                       pBtMgnt->ExtConfig.linkInfo[i].OutgoingTrafficMode = BT_MOTOR_EXT_BE;
-                       break;
-               case BT_PROFILE_A2DP:
-                       pBtMgnt->ExtConfig.linkInfo[i].IncomingTrafficMode = BT_MOTOR_EXT_GULB;
-                       pBtMgnt->ExtConfig.linkInfo[i].OutgoingTrafficMode = BT_MOTOR_EXT_GULB;
-                       break;
-               case BT_PROFILE_HID:
-                       pBtMgnt->ExtConfig.linkInfo[i].IncomingTrafficMode = BT_MOTOR_EXT_GUL;
-                       pBtMgnt->ExtConfig.linkInfo[i].OutgoingTrafficMode = BT_MOTOR_EXT_BE;
-                       break;
-               default:
-                       break;
-               }
-       }
-
-       RTPRINT(FBT, BT_TRACE, ("[DM][BT], RTK, NumberOfHandle = %d, NumberOfSCO = %d\n",
-               pBtMgnt->ExtConfig.NumberOfHandle, pBtMgnt->ExtConfig.NumberOfSCO));
-}
-
-void BTHCI_WifiScanNotify(struct rtw_adapter *padapter, u8 scanType)
-{
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-
-       if (pBtMgnt->ExtConfig.bEnableWifiScanNotify)
-               bthci_EventExtWifiScanNotify(padapter, scanType);
-}
-
-void
-BTHCI_StateMachine(
-       struct rtw_adapter *padapter,
-       u8              StateToEnter,
-       enum hci_state_with_cmd         StateCmd,
-       u8              EntryNum
-       )
-{
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-
-       if (EntryNum == 0xff) {
-               RTPRINT(FIOCTL, IOCTL_STATE, (" StateMachine, error EntryNum = 0x%x \n", EntryNum));
-               return;
-       }
-       RTPRINT(FIOCTL, IOCTL_STATE, (" StateMachine, EntryNum = 0x%x, CurrentState = 0x%x, BtNextState = 0x%x,  StateCmd = 0x%x , StateToEnter = 0x%x\n",
-               EntryNum, pBTInfo->BtAsocEntry[EntryNum].BtCurrentState, pBTInfo->BtAsocEntry[EntryNum].BtNextState, StateCmd, StateToEnter));
-
-       if (pBTInfo->BtAsocEntry[EntryNum].BtNextState & StateToEnter) {
-               pBTInfo->BtAsocEntry[EntryNum].BtCurrentState = StateToEnter;
-
-               switch (StateToEnter) {
-               case HCI_STATE_STARTING:
-                       pBTInfo->BtAsocEntry[EntryNum].BtNextState = HCI_STATE_DISCONNECTING | HCI_STATE_CONNECTING;
-                       bthci_StateStarting(padapter, StateCmd, EntryNum);
-                       break;
-               case HCI_STATE_CONNECTING:
-                       pBTInfo->BtAsocEntry[EntryNum].BtNextState = HCI_STATE_CONNECTING | HCI_STATE_DISCONNECTING | HCI_STATE_AUTHENTICATING;
-                       bthci_StateConnecting(padapter, StateCmd, EntryNum);
-                       break;
-               case HCI_STATE_AUTHENTICATING:
-                       pBTInfo->BtAsocEntry[EntryNum].BtNextState = HCI_STATE_DISCONNECTING | HCI_STATE_CONNECTED;
-                       bthci_StateAuth(padapter, StateCmd, EntryNum);
-                       break;
-               case HCI_STATE_CONNECTED:
-                       pBTInfo->BtAsocEntry[EntryNum].BtNextState = HCI_STATE_CONNECTED | HCI_STATE_DISCONNECTING;
-                       bthci_StateConnected(padapter, StateCmd, EntryNum);
-                       break;
-               case HCI_STATE_DISCONNECTING:
-                       pBTInfo->BtAsocEntry[EntryNum].BtNextState = HCI_STATE_DISCONNECTED | HCI_STATE_DISCONNECTING;
-                       bthci_StateDisconnecting(padapter, StateCmd, EntryNum);
-                       break;
-               case HCI_STATE_DISCONNECTED:
-                       pBTInfo->BtAsocEntry[EntryNum].BtNextState = HCI_STATE_DISCONNECTED | HCI_STATE_STARTING | HCI_STATE_CONNECTING;
-                       bthci_StateDisconnected(padapter, StateCmd, EntryNum);
-                       break;
-               default:
-                       RTPRINT(FIOCTL, IOCTL_STATE, (" StateMachine, Unknown state to enter!!!\n"));
-                       break;
-               }
-       } else {
-               RTPRINT(FIOCTL, IOCTL_STATE, (" StateMachine, Wrong state to enter\n"));
-       }
-
-       /*  20100325 Joseph: Disable/Enable IPS/LPS according to BT status. */
-       if (!pBtMgnt->bBTConnectInProgress && !pBtMgnt->BtOperationOn) {
-               RTPRINT(FIOCTL, IOCTL_STATE, ("[BT PS], ips_enter23a()\n"));
-               ips_enter23a(padapter);
-       }
-}
-
-void BTHCI_DisconnectPeer(struct rtw_adapter *padapter, u8 EntryNum)
-{
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD, (" BTHCI_DisconnectPeer()\n"));
-
-       BTHCI_SM_WITH_INFO(padapter, HCI_STATE_DISCONNECTING, STATE_CMD_MAC_CONNECT_CANCEL_INDICATE, EntryNum);
-
-       if (pBTInfo->BtAsocEntry[EntryNum].bUsed) {
-/*BTPKT_SendDeauthentication(padapter, pBTInfo->BtAsocEntry[EntryNum].BTRemoteMACAddr, unspec_reason); not porting yet */
-       }
-
-       if (pBtMgnt->bBTConnectInProgress) {
-               pBtMgnt->bBTConnectInProgress = false;
-               RTPRINT(FIOCTL, IOCTL_STATE, ("[BT Flag], BT Connect in progress OFF!!\n"));
-       }
-
-       bthci_RemoveEntryByEntryNum(padapter, EntryNum);
-
-       if (pBtMgnt->bNeedNotifyAMPNoCap) {
-               RTPRINT(FIOCTL, IOCTL_STATE, ("[BT AMPStatus], set to invalid in BTHCI_DisconnectPeer()\n"));
-               BTHCI_EventAMPStatusChange(padapter, AMP_STATUS_NO_CAPACITY_FOR_BT);
-       }
-}
-
-void BTHCI_EventNumOfCompletedDataBlocks(struct rtw_adapter *padapter)
-{
-/*PMGNT_INFO pMgntInfo = &padapter->MgntInfo; */
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_hci_info *pBtHciInfo = &pBTInfo->BtHciInfo;
-       u8 localBuf[TmpLocalBufSize] = "";
-       u8 *pRetPar, *pTriple;
-       u8 len = 0, i, j, handleNum = 0;
-       struct packet_irp_hcievent_data *PPacketIrpEvent;
-       u16 *pu2Temp, *pPackets, *pHandle, *pDblocks;
-       u8 sent = 0;
-
-       PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-
-       if (!(pBtHciInfo->BTEventMaskPage2 & EMP2_HCI_EVENT_NUM_OF_COMPLETE_DATA_BLOCKS)) {
-               RTPRINT(FIOCTL, IOCTL_BT_EVENT, ("[BT event], Num Of Completed DataBlocks, Ignore to send NumOfCompletedDataBlocksEvent due to event mask page 2\n"));
-               return;
-       }
-
-       /*  Return parameters starts from here */
-       pRetPar = &PPacketIrpEvent->Data[0];
-       pTriple = &pRetPar[3];
-       for (j = 0; j < MAX_BT_ASOC_ENTRY_NUM; j++) {
-
-               for (i = 0; i < MAX_LOGICAL_LINK_NUM; i++) {
-                       if (pBTInfo->BtAsocEntry[j].LogLinkCmdData[i].BtLogLinkhandle) {
-                               handleNum++;
-                               pHandle = (u16 *)&pTriple[0];   /*  Handle[i] */
-                               pPackets = (u16 *)&pTriple[2];  /*  Num_Of_Completed_Packets[i] */
-                               pDblocks = (u16 *)&pTriple[4];  /*  Num_Of_Completed_Blocks[i] */
-                               *pHandle = pBTInfo->BtAsocEntry[j].LogLinkCmdData[i].BtLogLinkhandle;
-                               *pPackets = (u16)pBTInfo->BtAsocEntry[j].LogLinkCmdData[i].TxPacketCount;
-                               *pDblocks = (u16)pBTInfo->BtAsocEntry[j].LogLinkCmdData[i].TxPacketCount;
-                               if (pBTInfo->BtAsocEntry[j].LogLinkCmdData[i].TxPacketCount) {
-                                       sent = 1;
-                                       RTPRINT(FIOCTL, IOCTL_BT_EVENT_DETAIL,
-                                               ("[BT event], Num Of Completed DataBlocks, Handle = 0x%x, Num_Of_Completed_Packets = 0x%x, Num_Of_Completed_Blocks = 0x%x\n",
-                                       *pHandle, *pPackets, *pDblocks));
-                               }
-                               pBTInfo->BtAsocEntry[j].LogLinkCmdData[i].TxPacketCount = 0;
-                               len += 6;
-                               pTriple += len;
-                       }
-               }
-       }
-
-       pRetPar[2] = handleNum;                         /*  Number_of_Handles */
-       len += 1;
-       pu2Temp = (u16 *)&pRetPar[0];
-       *pu2Temp = BTTotalDataBlockNum;
-       len += 2;
-
-       PPacketIrpEvent->EventCode = HCI_EVENT_NUM_OF_COMPLETE_DATA_BLOCKS;
-       PPacketIrpEvent->Length = len;
-       if (handleNum && sent)
-               bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2);
-}
-
-void BTHCI_EventAMPStatusChange(struct rtw_adapter *padapter, u8 AMP_Status)
-{
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-       struct packet_irp_hcievent_data *PPacketIrpEvent;
-       u8 len = 0;
-       u8 localBuf[7] = "";
-       u8 *pRetPar;
-
-       if (AMP_Status == AMP_STATUS_NO_CAPACITY_FOR_BT) {
-               pBtMgnt->BTNeedAMPStatusChg = true;
-               pBtMgnt->bNeedNotifyAMPNoCap = false;
-
-               BTHCI_DisconnectAll(padapter);
-       } else if (AMP_Status == AMP_STATUS_FULL_CAPACITY_FOR_BT) {
-               pBtMgnt->BTNeedAMPStatusChg = false;
-       }
-
-       PPacketIrpEvent = (struct packet_irp_hcievent_data *)(&localBuf[0]);
-       /*  Return parameters starts from here */
-       pRetPar = &PPacketIrpEvent->Data[0];
-
-       pRetPar[0] = 0; /*  Status */
-       len += 1;
-       pRetPar[1] = AMP_Status;        /*  AMP_Status */
-       len += 1;
-
-       PPacketIrpEvent->EventCode = HCI_EVENT_AMP_STATUS_CHANGE;
-       PPacketIrpEvent->Length = len;
-       if (bthci_IndicateEvent(padapter, PPacketIrpEvent, len+2) == RT_STATUS_SUCCESS)
-               RTPRINT(FIOCTL, (IOCTL_BT_EVENT|IOCTL_STATE), ("[BT event], AMP Status Change, AMP_Status = %d\n", AMP_Status));
-}
-
-void BTHCI_DisconnectAll(struct rtw_adapter *padapter)
-{
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       u8 i;
-
-       RTPRINT(FIOCTL, IOCTL_STATE, (" DisconnectALL()\n"));
-
-       for (i = 0; i < MAX_BT_ASOC_ENTRY_NUM; i++) {
-               if (pBTInfo->BtAsocEntry[i].b4waySuccess) {
-                       BTHCI_SM_WITH_INFO(padapter, HCI_STATE_CONNECTED, STATE_CMD_DISCONNECT_PHY_LINK, i);
-               } else if (pBTInfo->BtAsocEntry[i].bUsed) {
-                       if (pBTInfo->BtAsocEntry[i].BtCurrentState == HCI_STATE_CONNECTING) {
-                               BTHCI_SM_WITH_INFO(padapter, HCI_STATE_CONNECTING, STATE_CMD_MAC_CONNECT_CANCEL_INDICATE, i);
-                       } else if (pBTInfo->BtAsocEntry[i].BtCurrentState == HCI_STATE_DISCONNECTING) {
-                               BTHCI_SM_WITH_INFO(padapter, HCI_STATE_DISCONNECTING, STATE_CMD_MAC_CONNECT_CANCEL_INDICATE, i);
-                       }
-               }
-       }
-}
-
-enum hci_status
-BTHCI_HandleHCICMD(
-       struct rtw_adapter *padapter,
-       struct packet_irp_hcicmd_data *pHciCmd
-       )
-{
-       enum hci_status status = HCI_STATUS_SUCCESS;
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_dgb *pBtDbg = &pBTInfo->BtDbg;
-
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("\n"));
-       RTPRINT(FIOCTL, (IOCTL_BT_HCICMD_DETAIL|IOCTL_BT_LOGO), ("HCI Command start, OGF = 0x%x, OCF = 0x%x, Length = 0x%x\n",
-               pHciCmd->OGF, pHciCmd->OCF, pHciCmd->Length));
-       if (pHciCmd->Length) {
-               RTPRINT_DATA(FIOCTL, (IOCTL_BT_HCICMD_DETAIL|IOCTL_BT_LOGO), "HCI Command, Hex Data :\n",
-                       &pHciCmd->Data[0], pHciCmd->Length);
-       }
-       if (pHciCmd->OGF == OGF_EXTENSION) {
-               if (pHciCmd->OCF == HCI_SET_RSSI_VALUE)
-                       RTPRINT(FIOCTL, IOCTL_BT_EVENT_PERIODICAL, ("[BT cmd], "));
-               else
-                       RTPRINT(FIOCTL, IOCTL_BT_HCICMD_EXT, ("[BT cmd], "));
-       } else {
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("[BT cmd], "));
-       }
-
-       pBtDbg->dbgHciInfo.hciCmdCnt++;
-
-       switch (pHciCmd->OGF) {
-       case LINK_CONTROL_COMMANDS:
-               status = bthci_HandleOGFLinkControlCMD(padapter, pHciCmd);
-               break;
-       case HOLD_MODE_COMMAND:
-               break;
-       case OGF_SET_EVENT_MASK_COMMAND:
-               status = bthci_HandleOGFSetEventMaskCMD(padapter, pHciCmd);
-               break;
-       case OGF_INFORMATIONAL_PARAMETERS:
-               status = bthci_HandleOGFInformationalParameters(padapter, pHciCmd);
-               break;
-       case OGF_STATUS_PARAMETERS:
-               status = bthci_HandleOGFStatusParameters(padapter, pHciCmd);
-               break;
-       case OGF_TESTING_COMMANDS:
-               status = bthci_HandleOGFTestingCMD(padapter, pHciCmd);
-               break;
-       case OGF_EXTENSION:
-               status = bthci_HandleOGFExtension(padapter, pHciCmd);
-               break;
-       default:
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI Command(), Unknown OGF = 0x%x\n", pHciCmd->OGF));
-               RTPRINT(FIOCTL, IOCTL_BT_HCICMD, ("HCI_UNKNOWN_COMMAND\n"));
-               status = bthci_UnknownCMD(padapter, pHciCmd);
-               break;
-       }
-       RTPRINT(FIOCTL, IOCTL_BT_HCICMD_DETAIL, ("HCI Command execution end!!\n"));
-
-       return status;
-}
-
-/*  ===== End of sync from SD7 driver COMMOM/bt_hci.c ===== */
-
-static const char *const BtStateString[] = {
-       "BT_DISABLED",
-       "BT_NO_CONNECTION",
-       "BT_CONNECT_IDLE",
-       "BT_INQ_OR_PAG",
-       "BT_ACL_ONLY_BUSY",
-       "BT_SCO_ONLY_BUSY",
-       "BT_ACL_SCO_BUSY",
-       "BT_ACL_INQ_OR_PAG",
-       "BT_STATE_NOT_DEFINED"
-};
-
-/*  ===== Below this line is sync from SD7 driver HAL/BTCoexist/HalBtc87231Ant.c ===== */
-
-static void btdm_SetFwIgnoreWlanAct(struct rtw_adapter *padapter, u8 bEnable)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       u8 H2C_Parameter[1] = {0};
-
-       if (bEnable) {
-               RTPRINT(FBT, BT_TRACE, ("[BTCoex], BT Ignore Wlan_Act !!\n"));
-               H2C_Parameter[0] |= BIT(0);             /*  function enable */
-               pHalData->bt_coexist.bFWCoexistAllOff = false;
-       } else {
-               RTPRINT(FBT, BT_TRACE, ("[BTCoex], BT don't ignore Wlan_Act !!\n"));
-       }
-
-       RTPRINT(FBT, BT_TRACE, ("[BTCoex], set FW for BT Ignore Wlan_Act, write 0x25 = 0x%02x\n",
-               H2C_Parameter[0]));
-
-       FillH2CCmd(padapter, BT_IGNORE_WLAN_ACT_EID, 1, H2C_Parameter);
-}
-
-static void btdm_NotifyFwScan(struct rtw_adapter *padapter, u8 scanType)
-{
-       u8 H2C_Parameter[1] = {0};
-
-       if (scanType == true)
-               H2C_Parameter[0] = 0x1;
-
-       RTPRINT(FBT, BT_TRACE, ("[BTCoex], Notify FW for wifi scan, write 0x3b = 0x%02x\n",
-               H2C_Parameter[0]));
-
-       FillH2CCmd(padapter, 0x3b, 1, H2C_Parameter);
-}
-
-static void btdm_1AntSetPSMode(struct rtw_adapter *padapter,
-                              u8 enable, u8 smartps, u8 mode)
-{
-       struct pwrctrl_priv *pwrctrl;
-
-       RTPRINT(FBT, BT_TRACE, ("[BTCoex], Current LPS(%s, %d), smartps =%d\n", enable == true?"ON":"OFF", mode, smartps));
-
-       pwrctrl = &padapter->pwrctrlpriv;
-
-       if (enable == true) {
-               rtw_set_ps_mode23a(padapter, PS_MODE_MIN, smartps, mode);
-       } else {
-               rtw_set_ps_mode23a(padapter, PS_MODE_ACTIVE, 0, 0);
-               LPS_RF_ON_check23a(padapter, 100);
-       }
-}
-
-static void btdm_1AntTSFSwitch(struct rtw_adapter *padapter, u8 enable)
-{
-       u8 oldVal, newVal;
-
-       oldVal = rtl8723au_read8(padapter, 0x550);
-
-       if (enable)
-               newVal = oldVal | EN_BCN_FUNCTION;
-       else
-               newVal = oldVal & ~EN_BCN_FUNCTION;
-
-       if (oldVal != newVal)
-               rtl8723au_write8(padapter, 0x550, newVal);
-}
-
-static u8 btdm_Is1AntPsTdmaStateChange(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       struct btdm_8723a_1ant *pBtdm8723 = &pHalData->bt_coexist.halCoex8723.btdm1Ant;
-
-       if ((pBtdm8723->bPrePsTdmaOn != pBtdm8723->bCurPsTdmaOn) ||
-               (pBtdm8723->prePsTdma != pBtdm8723->curPsTdma))
-               return true;
-       else
-               return false;
-}
-
-/*  Before enter TDMA, make sure Power Saving is enable! */
-static void
-btdm_1AntPsTdma(
-       struct rtw_adapter *padapter,
-       u8 bTurnOn,
-       u8 type
-       )
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       struct btdm_8723a_1ant *pBtdm8723 = &pHalData->bt_coexist.halCoex8723.btdm1Ant;
-
-       pBtdm8723->bCurPsTdmaOn = bTurnOn;
-       pBtdm8723->curPsTdma = type;
-       if (bTurnOn) {
-               switch (type) {
-               case 1: /*  A2DP Level-1 or FTP/OPP */
-               default:
-                       if (btdm_Is1AntPsTdmaStateChange(padapter)) {
-                               /*  wide duration for WiFi */
-                               BTDM_SetFw3a(padapter, 0xd3, 0x1a, 0x1a, 0x0, 0x58);
-                       }
-                       break;
-               case 2: /*  A2DP Level-2 */
-                       if (btdm_Is1AntPsTdmaStateChange(padapter)) {
-                               /*  normal duration for WiFi */
-                               BTDM_SetFw3a(padapter, 0xd3, 0x12, 0x12, 0x0, 0x58);
-                       }
-                       break;
-               case 3: /*  BT FTP/OPP */
-                       if (btdm_Is1AntPsTdmaStateChange(padapter)) {
-                               /*  normal duration for WiFi */
-                               BTDM_SetFw3a(padapter, 0xd3, 0x30, 0x03, 0x10, 0x58);
-
-                       }
-                       break;
-               case 4: /*  for wifi scan & BT is connected */
-                       if (btdm_Is1AntPsTdmaStateChange(padapter)) {
-                               /*  protect 3 beacons in 3-beacon period & no Tx pause at BT slot */
-                               BTDM_SetFw3a(padapter, 0x93, 0x15, 0x03, 0x14, 0x0);
-                       }
-                       break;
-               case 5: /*  for WiFi connected-busy & BT is Non-Connected-Idle */
-                       if (btdm_Is1AntPsTdmaStateChange(padapter)) {
-                               /*  SCO mode, Ant fixed at WiFi, WLAN_Act toggle */
-                               BTDM_SetFw3a(padapter, 0x61, 0x15, 0x03, 0x31, 0x00);
-                       }
-                       break;
-               case 9: /*  ACL high-retry type - 2 */
-                       if (btdm_Is1AntPsTdmaStateChange(padapter)) {
-                               /*  narrow duration for WiFi */
-                               BTDM_SetFw3a(padapter, 0xd3, 0xa, 0xa, 0x0, 0x58); /* narrow duration for WiFi */
-                       }
-                       break;
-               case 10: /*  for WiFi connect idle & BT ACL busy or WiFi Connected-Busy & BT is Inquiry */
-                       if (btdm_Is1AntPsTdmaStateChange(padapter))
-                               BTDM_SetFw3a(padapter, 0x13, 0xa, 0xa, 0x0, 0x40);
-                       break;
-               case 11: /*  ACL high-retry type - 3 */
-                       if (btdm_Is1AntPsTdmaStateChange(padapter)) {
-                               /*  narrow duration for WiFi */
-                               BTDM_SetFw3a(padapter, 0xd3, 0x05, 0x05, 0x00, 0x58);
-                       }
-                       break;
-               case 12: /*  for WiFi Connected-Busy & BT is Connected-Idle */
-                       if (btdm_Is1AntPsTdmaStateChange(padapter)) {
-                               /*  Allow High-Pri BT */
-                               BTDM_SetFw3a(padapter, 0xeb, 0x0a, 0x03, 0x31, 0x18);
-                       }
-                       break;
-               case 20: /*  WiFi only busy , TDMA mode for power saving */
-                       if (btdm_Is1AntPsTdmaStateChange(padapter))
-                               BTDM_SetFw3a(padapter, 0x13, 0x25, 0x25, 0x00, 0x00);
-                       break;
-               case 27: /*  WiFi DHCP/Site Survey & BT SCO busy */
-                       if (btdm_Is1AntPsTdmaStateChange(padapter))
-                               BTDM_SetFw3a(padapter, 0xa3, 0x25, 0x03, 0x31, 0x98);
-                       break;
-               case 28: /*  WiFi DHCP/Site Survey & BT idle */
-                       if (btdm_Is1AntPsTdmaStateChange(padapter))
-                               BTDM_SetFw3a(padapter, 0x69, 0x25, 0x03, 0x31, 0x00);
-                       break;
-               case 29: /*  WiFi DHCP/Site Survey & BT ACL busy */
-                       if (btdm_Is1AntPsTdmaStateChange(padapter)) {
-                               BTDM_SetFw3a(padapter, 0xeb, 0x1a, 0x1a, 0x01, 0x18);
-                               rtl8723au_write32(padapter, 0x6c0, 0x5afa5afa);
-                               rtl8723au_write32(padapter, 0x6c4, 0x5afa5afa);
-                       }
-                       break;
-               case 30: /*  WiFi idle & BT Inquiry */
-                       if (btdm_Is1AntPsTdmaStateChange(padapter))
-                               BTDM_SetFw3a(padapter, 0x93, 0x15, 0x03, 0x14, 0x00);
-                       break;
-               case 31:  /*  BT HID */
-                       if (btdm_Is1AntPsTdmaStateChange(padapter))
-                               BTDM_SetFw3a(padapter, 0xd3, 0x1a, 0x1a, 0x00, 0x58);
-                       break;
-               case 32:  /*  BT SCO & Inquiry */
-                       if (btdm_Is1AntPsTdmaStateChange(padapter))
-                               BTDM_SetFw3a(padapter, 0xab, 0x0a, 0x03, 0x11, 0x98);
-                       break;
-               case 33:  /*  BT SCO & WiFi site survey */
-                       if (btdm_Is1AntPsTdmaStateChange(padapter))
-                               BTDM_SetFw3a(padapter, 0xa3, 0x25, 0x03, 0x30, 0x98);
-                       break;
-               case 34:  /*  BT HID & WiFi site survey */
-                       if (btdm_Is1AntPsTdmaStateChange(padapter))
-                               BTDM_SetFw3a(padapter, 0xd3, 0x1a, 0x1a, 0x00, 0x18);
-                       break;
-               case 35:  /*  BT HID & WiFi Connecting */
-                       if (btdm_Is1AntPsTdmaStateChange(padapter))
-                               BTDM_SetFw3a(padapter, 0xe3, 0x1a, 0x1a, 0x00, 0x18);
-                       break;
-               }
-       } else {
-               /*  disable PS-TDMA */
-               switch (type) {
-               case 8:
-                       if (btdm_Is1AntPsTdmaStateChange(padapter)) {
-                               /*  Antenna control by PTA, 0x870 = 0x310 */
-                               BTDM_SetFw3a(padapter, 0x8, 0x0, 0x0, 0x0, 0x0);
-                       }
-                       break;
-               case 0:
-               default:
-                       if (btdm_Is1AntPsTdmaStateChange(padapter)) {
-                               /*  Antenna control by PTA, 0x870 = 0x310 */
-                               BTDM_SetFw3a(padapter, 0x0, 0x0, 0x0, 0x8, 0x0);
-                       }
-                       /*  Switch Antenna to BT */
-                       rtl8723au_write16(padapter, 0x860, 0x210);
-                       RTPRINT(FBT, BT_TRACE, ("[BTCoex], 0x860 = 0x210, Switch Antenna to BT\n"));
-                       break;
-               case 9:
-                       if (btdm_Is1AntPsTdmaStateChange(padapter)) {
-                               /*  Antenna control by PTA, 0x870 = 0x310 */
-                               BTDM_SetFw3a(padapter, 0x0, 0x0, 0x0, 0x8, 0x0);
-                       }
-                       /*  Switch Antenna to WiFi */
-                       rtl8723au_write16(padapter, 0x860, 0x110);
-                       RTPRINT(FBT, BT_TRACE, ("[BTCoex], 0x860 = 0x110, Switch Antenna to WiFi\n"));
-                       break;
-               }
-       }
-
-       RTPRINT(FBT, BT_TRACE, ("[BTCoex], Current TDMA(%s, %d)\n",
-               pBtdm8723->bCurPsTdmaOn?"ON":"OFF", pBtdm8723->curPsTdma));
-
-       /*  update pre state */
-       pBtdm8723->bPrePsTdmaOn = pBtdm8723->bCurPsTdmaOn;
-       pBtdm8723->prePsTdma = pBtdm8723->curPsTdma;
-}
-
-static void
-_btdm_1AntSetPSTDMA(struct rtw_adapter *padapter, u8 bPSEn, u8 smartps,
-                   u8 psOption, u8 bTDMAOn, u8 tdmaType)
-{
-       struct pwrctrl_priv *pwrctrl;
-       struct hal_data_8723a *pHalData;
-       struct btdm_8723a_1ant *pBtdm8723;
-       u8 psMode;
-       u8 bSwitchPS;
-
-       if (!check_fwstate(&padapter->mlmepriv, WIFI_STATION_STATE) &&
-           (get_fwstate(&padapter->mlmepriv) != WIFI_NULL_STATE)) {
-               btdm_1AntPsTdma(padapter, bTDMAOn, tdmaType);
-               return;
-       }
-       psOption &= ~BIT(0);
-
-       RTPRINT(FBT, BT_TRACE,
-               ("[BTCoex], Set LPS(%s, %d) TDMA(%s, %d)\n",
-               bPSEn == true?"ON":"OFF", psOption,
-               bTDMAOn == true?"ON":"OFF", tdmaType));
-
-       pwrctrl = &padapter->pwrctrlpriv;
-       pHalData = GET_HAL_DATA(padapter);
-       pBtdm8723 = &pHalData->bt_coexist.halCoex8723.btdm1Ant;
-
-       if (bPSEn) {
-               if (pBtdm8723->bWiFiHalt) {
-                       RTPRINT(FBT, BT_TRACE, ("[BTCoex], Enable PS Fail, WiFi in Halt!!\n"));
-                       return;
-               }
-
-               if (pwrctrl->bInSuspend) {
-                       RTPRINT(FBT, BT_TRACE, ("[BTCoex], Enable PS Fail, WiFi in Suspend!!\n"));
-                       return;
-               }
-
-               if (padapter->bDriverStopped) {
-                       RTPRINT(FBT, BT_TRACE, ("[BTCoex], Enable PS Fail, WiFi driver stopped!!\n"));
-                       return;
-               }
-
-               if (padapter->bSurpriseRemoved) {
-                       RTPRINT(FBT, BT_TRACE, ("[BTCoex], Enable PS Fail, WiFi Surprise Removed!!\n"));
-                       return;
-               }
-
-               psMode = PS_MODE_MIN;
-       } else {
-               psMode = PS_MODE_ACTIVE;
-               psOption = 0;
-       }
-
-       if (psMode != pwrctrl->pwr_mode) {
-               bSwitchPS = true;
-       } else if (psMode != PS_MODE_ACTIVE) {
-               if (psOption != pwrctrl->bcn_ant_mode)
-                       bSwitchPS = true;
-               else if (smartps != pwrctrl->smart_ps)
-                       bSwitchPS = true;
-               else
-                       bSwitchPS = false;
-       } else {
-               bSwitchPS = false;
-       }
-
-       if (bSwitchPS) {
-               /*  disable TDMA */
-               if (pBtdm8723->bCurPsTdmaOn) {
-                       if (!bTDMAOn) {
-                               btdm_1AntPsTdma(padapter, false, tdmaType);
-                       } else {
-                               if (!rtl8723a_BT_enabled(padapter) ||
-                                   (pHalData->bt_coexist.halCoex8723.c2hBtInfo == BT_INFO_STATE_NO_CONNECTION) ||
-                                   (pHalData->bt_coexist.halCoex8723.c2hBtInfo == BT_INFO_STATE_CONNECT_IDLE) ||
-                                   (tdmaType == 29))
-                                       btdm_1AntPsTdma(padapter, false, 9);
-                               else
-                                       btdm_1AntPsTdma(padapter, false, 0);
-                       }
-               }
-
-               /*  change Power Save State */
-               btdm_1AntSetPSMode(padapter, bPSEn, smartps, psOption);
-       }
-
-       btdm_1AntPsTdma(padapter, bTDMAOn, tdmaType);
-}
-
-static void
-btdm_1AntSetPSTDMA(struct rtw_adapter *padapter, u8 bPSEn,
-                  u8 psOption, u8 bTDMAOn, u8 tdmaType)
-{
-       _btdm_1AntSetPSTDMA(padapter, bPSEn, 0, psOption, bTDMAOn, tdmaType);
-}
-
-static void btdm_1AntWifiParaAdjust(struct rtw_adapter *padapter, u8 bEnable)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       struct btdm_8723a_1ant *pBtdm8723 = &pHalData->bt_coexist.halCoex8723.btdm1Ant;
-
-       if (bEnable) {
-               pBtdm8723->curWifiPara = 1;
-               if (pBtdm8723->preWifiPara != pBtdm8723->curWifiPara)
-                       BTDM_SetSwPenaltyTxRateAdaptive(padapter, BT_TX_RATE_ADAPTIVE_LOW_PENALTY);
-       } else {
-               pBtdm8723->curWifiPara = 2;
-               if (pBtdm8723->preWifiPara != pBtdm8723->curWifiPara)
-                       BTDM_SetSwPenaltyTxRateAdaptive(padapter, BT_TX_RATE_ADAPTIVE_NORMAL);
-       }
-
-}
-
-static void btdm_1AntPtaParaReload(struct rtw_adapter *padapter)
-{
-       /*  PTA parameter */
-       rtl8723au_write8(padapter, 0x6cc, 0x0);         /*  1-Ant coex */
-       rtl8723au_write32(padapter, 0x6c8, 0xffff);     /*  wifi break table */
-       rtl8723au_write32(padapter, 0x6c4, 0x55555555); /*  coex table */
-
-       /*  Antenna switch control parameter */
-       rtl8723au_write32(padapter, 0x858, 0xaaaaaaaa);
-       if (IS_8723A_A_CUT(GET_HAL_DATA(padapter)->VersionID)) {
-               /*  SPDT(connected with TRSW) control by hardware PTA */
-               rtl8723au_write32(padapter, 0x870, 0x0);
-               rtl8723au_write8(padapter, 0x40, 0x24);
-       } else {
-               rtl8723au_write8(padapter, 0x40, 0x20);
-               /*  set antenna at bt side if ANTSW is software control */
-               rtl8723au_write16(padapter, 0x860, 0x210);
-               /*  SPDT(connected with TRSW) control by hardware PTA */
-               rtl8723au_write32(padapter, 0x870, 0x300);
-               /*  ANTSW keep by GNT_BT */
-               rtl8723au_write32(padapter, 0x874, 0x22804000);
-       }
-
-       /*  coexistence parameters */
-       rtl8723au_write8(padapter, 0x778, 0x1); /*  enable RTK mode PTA */
-
-       /*  BT don't ignore WLAN_Act */
-       btdm_SetFwIgnoreWlanAct(padapter, false);
-}
-
-/*
- * Return
- *1: upgrade (add WiFi duration time)
- *0: keep
- *-1: downgrade (add BT duration time)
- */
-static s8 btdm_1AntTdmaJudgement(struct rtw_adapter *padapter, u8 retry)
-{
-       struct hal_data_8723a *pHalData;
-       struct btdm_8723a_1ant *pBtdm8723;
-       static s8 up, dn, m = 1, WaitCount;
-       s8 ret;
-
-       pHalData = GET_HAL_DATA(padapter);
-       pBtdm8723 = &pHalData->bt_coexist.halCoex8723.btdm1Ant;
-       ret = 0;
-
-       if (pBtdm8723->psTdmaMonitorCnt == 0) {
-               up = 0;
-               dn = 0;
-               m = 1;
-               WaitCount = 0;
-       } else {
-               WaitCount++;
-       }
-
-       if (retry == 0) {
-       /*  no retry in the last 2-second duration */
-               up++;
-               dn--;
-               if (dn < 0)
-                       dn = 0;
-               if (up >= 3*m) {
-                       /*  retry = 0 in consecutive 3m*(2s), add WiFi duration */
-                       ret = 1;
-                       up = 0;
-                       dn = 0;
-                       WaitCount = 0;
-               }
-       } else if (retry <= 3) {
-               /*  retry<= 3 in the last 2-second duration */
-               up--;
-               dn++;
-               if (up < 0)
-                       up = 0;
-
-               if (dn == 2) {
-                       /*  retry<= 3 in consecutive 2*(2s), minus WiFi duration (add BT duration) */
-                       ret = -1;
-
-                       /*  record how many time downgrad WiFi duration */
-                       if (WaitCount <= 2)
-                               m++;
-                       else
-                               m = 1;
-                       /*  the max number of m is 20 */
-                       /*  the longest time of upgrade WiFi duration is 20*3*2s = 120s */
-                       if (m >= 20)
-                               m = 20;
-                       up = 0;
-                       dn = 0;
-                       WaitCount = 0;
-               }
-       } else {
-               /*  retry count > 3 */
-               /*  retry>3, minus WiFi duration (add BT duration) */
-               ret = -1;
-
-               /*  record how many time downgrad WiFi duration */
-               if (WaitCount == 1)
-                       m++;
-               else
-                       m = 1;
-               if (m >= 20)
-                       m = 20;
-
-               up = 0;
-               dn = 0;
-               WaitCount = 0;
-       }
-       return ret;
-}
-
-static void btdm_1AntTdmaDurationAdjustForACL(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       struct btdm_8723a_1ant *pBtdm8723 = &pHalData->bt_coexist.halCoex8723.btdm1Ant;
-
-       if (pBtdm8723->psTdmaGlobalCnt != pBtdm8723->psTdmaMonitorCnt) {
-               pBtdm8723->psTdmaMonitorCnt = 0;
-               pBtdm8723->psTdmaGlobalCnt = 0;
-       }
-       if (pBtdm8723->psTdmaMonitorCnt == 0) {
-               btdm_1AntSetPSTDMA(padapter, true, 0, true, 2);
-               pBtdm8723->psTdmaDuAdjType = 2;
-       } else {
-               /*  Now we only have 4 level Ps Tdma, */
-               /*  if that's not the following 4 level(will changed by wifi scan, dhcp...), */
-               /*  then we have to adjust it back to the previous record one. */
-               if ((pBtdm8723->curPsTdma != 1) &&
-                   (pBtdm8723->curPsTdma != 2) &&
-                   (pBtdm8723->curPsTdma != 9) &&
-                   (pBtdm8723->curPsTdma != 11)) {
-                       btdm_1AntSetPSTDMA(padapter, true, 0, true, pBtdm8723->psTdmaDuAdjType);
-               } else {
-                       s32 judge;
-
-                       judge = btdm_1AntTdmaJudgement(padapter, pHalData->bt_coexist.halCoex8723.btRetryCnt);
-                       if (judge == -1) {
-                               if (pBtdm8723->curPsTdma == 1) {
-                                       /*  Decrease WiFi duration for high BT retry */
-                                       if (pHalData->bt_coexist.halCoex8723.btInfoExt)
-                                               pBtdm8723->psTdmaDuAdjType = 9;
-                                       else
-                                               pBtdm8723->psTdmaDuAdjType = 2;
-                                       btdm_1AntSetPSTDMA(padapter, true, 0, true, pBtdm8723->psTdmaDuAdjType);
-                               } else if (pBtdm8723->curPsTdma == 2) {
-                                       btdm_1AntSetPSTDMA(padapter, true, 0, true, 9);
-                                       pBtdm8723->psTdmaDuAdjType = 9;
-                               } else if (pBtdm8723->curPsTdma == 9) {
-                                       btdm_1AntSetPSTDMA(padapter, true, 0, true, 11);
-                                       pBtdm8723->psTdmaDuAdjType = 11;
-                               }
-                       } else if (judge == 1) {
-                               if (pBtdm8723->curPsTdma == 11) {
-                                       btdm_1AntSetPSTDMA(padapter, true, 0, true, 9);
-                                       pBtdm8723->psTdmaDuAdjType = 9;
-                               } else if (pBtdm8723->curPsTdma == 9) {
-                                       if (pHalData->bt_coexist.halCoex8723.btInfoExt)
-                                               pBtdm8723->psTdmaDuAdjType = 9;
-                                       else
-                                               pBtdm8723->psTdmaDuAdjType = 2;
-                                       btdm_1AntSetPSTDMA(padapter, true, 0, true, pBtdm8723->psTdmaDuAdjType);
-                               } else if (pBtdm8723->curPsTdma == 2) {
-                                       if (pHalData->bt_coexist.halCoex8723.btInfoExt)
-                                               pBtdm8723->psTdmaDuAdjType = 9;
-                                       else
-                                               pBtdm8723->psTdmaDuAdjType = 1;
-                                       btdm_1AntSetPSTDMA(padapter, true, 0, true, pBtdm8723->psTdmaDuAdjType);
-                               }
-                       }
-               }
-               RTPRINT(FBT, BT_TRACE,
-                       ("[BTCoex], ACL current TDMA(%s, %d)\n",
-                       (pBtdm8723->bCurPsTdmaOn ? "ON" : "OFF"), pBtdm8723->curPsTdma));
-       }
-       pBtdm8723->psTdmaMonitorCnt++;
-}
-
-static void btdm_1AntCoexProcessForWifiConnect(struct rtw_adapter *padapter)
-{
-       struct mlme_priv *pmlmepriv;
-       struct hal_data_8723a *pHalData;
-       struct bt_coexist_8723a *pBtCoex;
-       struct btdm_8723a_1ant *pBtdm8723;
-       u8 BtState;
-
-       pmlmepriv = &padapter->mlmepriv;
-       pHalData = GET_HAL_DATA(padapter);
-       pBtCoex = &pHalData->bt_coexist.halCoex8723;
-       pBtdm8723 = &pBtCoex->btdm1Ant;
-       BtState = pBtCoex->c2hBtInfo;
-
-       RTPRINT(FBT, BT_TRACE, ("[BTCoex], WiFi is %s\n",
-                               BTDM_IsWifiBusy(padapter)?"Busy":"IDLE"));
-       RTPRINT(FBT, BT_TRACE, ("[BTCoex], BT is %s\n",
-                               BtStateString[BtState]));
-
-       padapter->pwrctrlpriv.btcoex_rfon = false;
-
-       if (!BTDM_IsWifiBusy(padapter) &&
-           !check_fwstate(&padapter->mlmepriv, WIFI_AP_STATE) &&
-           (BtState == BT_INFO_STATE_NO_CONNECTION ||
-            BtState == BT_INFO_STATE_CONNECT_IDLE)) {
-               switch (BtState) {
-               case BT_INFO_STATE_NO_CONNECTION:
-                       _btdm_1AntSetPSTDMA(padapter, true, 2, 0x26, false, 9);
-                       break;
-               case BT_INFO_STATE_CONNECT_IDLE:
-                       _btdm_1AntSetPSTDMA(padapter, true, 2, 0x26, false, 0);
-                       break;
-               }
-       } else {
-               switch (BtState) {
-               case BT_INFO_STATE_NO_CONNECTION:
-               case BT_INFO_STATE_CONNECT_IDLE:
-                       /*  WiFi is Busy */
-                       btdm_1AntSetPSTDMA(padapter, false, 0, true, 5);
-                       rtl8723au_write32(padapter, 0x6c0, 0x5a5a5a5a);
-                       rtl8723au_write32(padapter, 0x6c4, 0x5a5a5a5a);
-                       break;
-               case BT_INFO_STATE_ACL_INQ_OR_PAG:
-                       RTPRINT(FBT, BT_TRACE,
-                               ("[BTCoex], BT PROFILE is "
-                                "BT_INFO_STATE_ACL_INQ_OR_PAG\n"));
-               case BT_INFO_STATE_INQ_OR_PAG:
-                       padapter->pwrctrlpriv.btcoex_rfon = true;
-                       btdm_1AntSetPSTDMA(padapter, true, 0, true, 30);
-                       break;
-               case BT_INFO_STATE_SCO_ONLY_BUSY:
-               case BT_INFO_STATE_ACL_SCO_BUSY:
-                       if (true == pBtCoex->bC2hBtInquiryPage)
-                               btdm_1AntSetPSTDMA(padapter, false, 0,
-                                                  true, 32);
-                       else {
-#ifdef BTCOEX_CMCC_TEST
-                               btdm_1AntSetPSTDMA(padapter, false, 0,
-                                                  true, 23);
-#else /*  !BTCOEX_CMCC_TEST */
-                               btdm_1AntSetPSTDMA(padapter, false, 0,
-                                                  false, 8);
-                               rtl8723au_write32(padapter, 0x6c0, 0x5a5a5a5a);
-                               rtl8723au_write32(padapter, 0x6c4, 0x5a5a5a5a);
-#endif /*  !BTCOEX_CMCC_TEST */
-                       }
-                       break;
-               case BT_INFO_STATE_ACL_ONLY_BUSY:
-                       padapter->pwrctrlpriv.btcoex_rfon = true;
-                       if (pBtCoex->c2hBtProfile == BT_INFO_HID) {
-                               RTPRINT(FBT, BT_TRACE,
-                                       ("[BTCoex], BT PROFILE is HID\n"));
-                               btdm_1AntSetPSTDMA(padapter, true, 0, true, 31);
-                       } else if (pBtCoex->c2hBtProfile == BT_INFO_FTP) {
-                               RTPRINT(FBT, BT_TRACE,
-                                       ("[BTCoex], BT PROFILE is FTP/OPP\n"));
-                               btdm_1AntSetPSTDMA(padapter, true, 0, true, 3);
-                       } else if (pBtCoex->c2hBtProfile == (BT_INFO_A2DP|BT_INFO_FTP)) {
-                               RTPRINT(FBT, BT_TRACE,
-                                       ("[BTCoex], BT PROFILE is A2DP_FTP\n"));
-                               btdm_1AntSetPSTDMA(padapter, true, 0, true, 11);
-                       } else {
-                               if (pBtCoex->c2hBtProfile == BT_INFO_A2DP)
-                                       RTPRINT(FBT, BT_TRACE,
-                                               ("[BTCoex], BT PROFILE is "
-                                                "A2DP\n"));
-                               else
-                                       RTPRINT(FBT, BT_TRACE,
-                                               ("[BTCoex], BT PROFILE is "
-                                                "UNKNOWN(0x%02X)! Use A2DP "
-                                                "Profile\n",
-                                                pBtCoex->c2hBtProfile));
-                               btdm_1AntTdmaDurationAdjustForACL(padapter);
-                       }
-                       break;
-               }
-       }
-
-       pBtdm8723->psTdmaGlobalCnt++;
-}
-
-static void
-btdm_1AntUpdateHalRAMask(struct rtw_adapter *padapter, u32 mac_id, u32 filter)
-{
-       u8 init_rate = 0;
-       u8 raid, arg;
-       u32 mask;
-       u8 shortGIrate = false;
-       int supportRateNum = 0;
-       struct sta_info *psta;
-       struct hal_data_8723a *pHalData;
-       struct dm_priv *pdmpriv;
-       struct mlme_ext_priv *pmlmeext;
-       struct mlme_ext_info *pmlmeinfo;
-       struct wlan_bssid_ex *cur_network;
-
-       RTPRINT(FBT, BT_TRACE, ("[BTCoex], %s, MACID =%d, filter = 0x%08x!!\n",
-                               __func__, mac_id, filter));
-
-       pHalData = GET_HAL_DATA(padapter);
-       pdmpriv = &pHalData->dmpriv;
-       pmlmeext = &padapter->mlmeextpriv;
-       pmlmeinfo = &pmlmeext->mlmext_info;
-       cur_network = &pmlmeinfo->network;
-
-       if (mac_id >= NUM_STA) { /* CAM_SIZE */
-               RTPRINT(FBT, BT_TRACE, ("[BTCoex], %s, MACID =%d illegal!!\n",
-                                       __func__, mac_id));
-               return;
-       }
-
-       psta = pmlmeinfo->FW_sta_info[mac_id].psta;
-       if (!psta) {
-               RTPRINT(FBT, BT_TRACE, ("[BTCoex], %s, Can't find station!!\n",
-                                       __func__));
-               return;
-       }
-
-       raid = psta->raid;
-
-       switch (mac_id) {
-       case 0:/*  for infra mode */
-               supportRateNum =
-                       rtw_get_rateset_len23a(cur_network->SupportedRates);
-               mask = update_supported_rate23a(cur_network->SupportedRates,
-                                               supportRateNum);
-               mask |= (pmlmeinfo->HT_enable) ?
-                       update_MSC_rate23a(&pmlmeinfo->ht_cap):0;
-               if (support_short_GI23a(padapter, &pmlmeinfo->ht_cap))
-                       shortGIrate = true;
-               break;
-       case 1:/* for broadcast/multicast */
-               supportRateNum = rtw_get_rateset_len23a(
-                       pmlmeinfo->FW_sta_info[mac_id].SupportedRates);
-               mask = update_basic_rate23a(cur_network->SupportedRates,
-                                           supportRateNum);
-               break;
-       default: /* for each sta in IBSS */
-               supportRateNum = rtw_get_rateset_len23a(
-                       pmlmeinfo->FW_sta_info[mac_id].SupportedRates);
-               mask = update_supported_rate23a(cur_network->SupportedRates,
-                                               supportRateNum);
-               break;
-       }
-       mask |= ((raid<<28)&0xf0000000);
-       mask &= 0xffffffff;
-       mask &= ~filter;
-       init_rate = get_highest_rate_idx23a(mask)&0x3f;
-
-       arg = mac_id&0x1f;/* MACID */
-       arg |= BIT(7);
-       if (true == shortGIrate)
-               arg |= BIT(5);
-
-       RTPRINT(FBT, BT_TRACE,
-               ("[BTCoex], Update FW RAID entry, MASK = 0x%08x, "
-                "arg = 0x%02x\n", mask, arg));
-
-       rtl8723a_set_raid_cmd(padapter, mask, arg);
-
-       psta->init_rate = init_rate;
-       pdmpriv->INIDATA_RATE[mac_id] = init_rate;
-}
-
-static void
-btdm_1AntUpdateHalRAMaskForSCO(struct rtw_adapter *padapter, u8 forceUpdate)
-{
-       struct btdm_8723a_1ant *pBtdm8723;
-       struct sta_priv *pstapriv;
-       struct wlan_bssid_ex *cur_network;
-       struct sta_info *psta;
-       u32 macid;
-       u32 filter = 0;
-
-       pBtdm8723 = &GET_HAL_DATA(padapter)->bt_coexist.halCoex8723.btdm1Ant;
-
-       if (pBtdm8723->bRAChanged == true && forceUpdate == false)
-               return;
-
-       pstapriv = &padapter->stapriv;
-       cur_network = &padapter->mlmeextpriv.mlmext_info.network;
-       psta = rtw_get_stainfo23a(pstapriv, cur_network->MacAddress);
-       macid = psta->mac_id;
-
-       filter |= BIT(_1M_RATE_);
-       filter |= BIT(_2M_RATE_);
-       filter |= BIT(_5M_RATE_);
-       filter |= BIT(_11M_RATE_);
-       filter |= BIT(_6M_RATE_);
-       filter |= BIT(_9M_RATE_);
-
-       btdm_1AntUpdateHalRAMask(padapter, macid, filter);
-
-       pBtdm8723->bRAChanged = true;
-}
-
-static void btdm_1AntRecoverHalRAMask(struct rtw_adapter *padapter)
-{
-       struct btdm_8723a_1ant *pBtdm8723;
-       struct sta_priv *pstapriv;
-       struct wlan_bssid_ex *cur_network;
-       struct sta_info *psta;
-
-       pBtdm8723 = &GET_HAL_DATA(padapter)->bt_coexist.halCoex8723.btdm1Ant;
-
-       if (pBtdm8723->bRAChanged == false)
-               return;
-
-       pstapriv = &padapter->stapriv;
-       cur_network = &padapter->mlmeextpriv.mlmext_info.network;
-       psta = rtw_get_stainfo23a(pstapriv, cur_network->MacAddress);
-
-       Update_RA_Entry23a(padapter, psta);
-
-       pBtdm8723->bRAChanged = false;
-}
-
-static void
-btdm_1AntBTStateChangeHandler(struct rtw_adapter *padapter,
-                             enum bt_state_1ant oldState,
-                             enum bt_state_1ant newState)
-{
-       struct hal_data_8723a *phaldata;
-       RTPRINT(FBT, BT_TRACE, ("[BTCoex], BT state change, %s => %s\n",
-                               BtStateString[oldState],
-                               BtStateString[newState]));
-
-       /*  BT default ignore wlan active, */
-       /*  WiFi MUST disable this when BT is enable */
-       if (newState > BT_INFO_STATE_DISABLED)
-               btdm_SetFwIgnoreWlanAct(padapter, false);
-
-       if ((check_fwstate(&padapter->mlmepriv, WIFI_STATION_STATE)) &&
-           (BTDM_IsWifiConnectionExist(padapter))) {
-               if ((newState == BT_INFO_STATE_SCO_ONLY_BUSY) ||
-                   (newState == BT_INFO_STATE_ACL_SCO_BUSY)) {
-                       btdm_1AntUpdateHalRAMaskForSCO(padapter, false);
-               } else {
-                       /*  Recover original RA setting */
-                       btdm_1AntRecoverHalRAMask(padapter);
-               }
-       } else {
-               phaldata = GET_HAL_DATA(padapter);
-               phaldata->bt_coexist.halCoex8723.btdm1Ant.bRAChanged = false;
-       }
-
-       if (oldState == newState)
-               return;
-
-       if (oldState == BT_INFO_STATE_ACL_ONLY_BUSY) {
-               struct hal_data_8723a *Hal = GET_HAL_DATA(padapter);
-               Hal->bt_coexist.halCoex8723.btdm1Ant.psTdmaMonitorCnt = 0;
-               Hal->bt_coexist.halCoex8723.btdm1Ant.psTdmaMonitorCntForSCO = 0;
-       }
-
-       if ((oldState == BT_INFO_STATE_SCO_ONLY_BUSY) ||
-           (oldState == BT_INFO_STATE_ACL_SCO_BUSY)) {
-               struct hal_data_8723a *Hal = GET_HAL_DATA(padapter);
-               Hal->bt_coexist.halCoex8723.btdm1Ant.psTdmaMonitorCntForSCO = 0;
-       }
-
-       /*  Active 2Ant mechanism when BT Connected */
-       if ((oldState == BT_INFO_STATE_DISABLED) ||
-           (oldState == BT_INFO_STATE_NO_CONNECTION)) {
-               if ((newState != BT_INFO_STATE_DISABLED) &&
-                   (newState != BT_INFO_STATE_NO_CONNECTION)) {
-                       BTDM_SetSwRfRxLpfCorner(padapter,
-                                               BT_RF_RX_LPF_CORNER_SHRINK);
-                       BTDM_AGCTable(padapter, BT_AGCTABLE_ON);
-                       BTDM_BBBackOffLevel(padapter, BT_BB_BACKOFF_ON);
-               }
-       } else {
-               if ((newState == BT_INFO_STATE_DISABLED) ||
-                   (newState == BT_INFO_STATE_NO_CONNECTION)) {
-                       BTDM_SetSwRfRxLpfCorner(padapter,
-                                               BT_RF_RX_LPF_CORNER_RESUME);
-                       BTDM_AGCTable(padapter, BT_AGCTABLE_OFF);
-                       BTDM_BBBackOffLevel(padapter, BT_BB_BACKOFF_OFF);
-               }
-       }
-}
-
-static void btdm_1AntBtCoexistHandler(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData;
-       struct bt_coexist_8723a *pBtCoex8723;
-       struct btdm_8723a_1ant *pBtdm8723;
-
-       pHalData = GET_HAL_DATA(padapter);
-       pBtCoex8723 = &pHalData->bt_coexist.halCoex8723;
-       pBtdm8723 = &pBtCoex8723->btdm1Ant;
-       padapter->pwrctrlpriv.btcoex_rfon = false;
-       if (!rtl8723a_BT_enabled(padapter)) {
-               RTPRINT(FBT, BT_TRACE, ("[BTCoex], BT is disabled\n"));
-
-               if (BTDM_IsWifiConnectionExist(padapter)) {
-                       RTPRINT(FBT, BT_TRACE,
-                               ("[BTCoex], wifi is connected\n"));
-
-                       if (BTDM_IsWifiBusy(padapter)) {
-                               RTPRINT(FBT, BT_TRACE,
-                                       ("[BTCoex], Wifi is busy\n"));
-                               btdm_1AntSetPSTDMA(padapter, false, 0,
-                                                  false, 9);
-                       } else {
-                               RTPRINT(FBT, BT_TRACE,
-                                       ("[BTCoex], Wifi is idle\n"));
-                               _btdm_1AntSetPSTDMA(padapter, true, 2, 1,
-                                                   false, 9);
-                       }
-               } else {
-                       RTPRINT(FBT, BT_TRACE,
-                               ("[BTCoex], wifi is disconnected\n"));
-
-                       btdm_1AntSetPSTDMA(padapter, false, 0, false, 9);
-               }
-       } else {
-               RTPRINT(FBT, BT_TRACE, ("[BTCoex], BT is enabled\n"));
-
-               if (BTDM_IsWifiConnectionExist(padapter)) {
-                       RTPRINT(FBT, BT_TRACE,
-                               ("[BTCoex], wifi is connected\n"));
-
-                       btdm_1AntWifiParaAdjust(padapter, true);
-                       btdm_1AntCoexProcessForWifiConnect(padapter);
-               } else {
-                       RTPRINT(FBT, BT_TRACE,
-                               ("[BTCoex], wifi is disconnected\n"));
-
-                       /*  Antenna switch at BT side(0x870 = 0x300,
-                           0x860 = 0x210) after PSTDMA off */
-                       btdm_1AntWifiParaAdjust(padapter, false);
-                       btdm_1AntSetPSTDMA(padapter, false, 0, false, 0);
-               }
-       }
-
-       btdm_1AntBTStateChangeHandler(padapter, pBtCoex8723->prec2hBtInfo,
-                                     pBtCoex8723->c2hBtInfo);
-       pBtCoex8723->prec2hBtInfo = pBtCoex8723->c2hBtInfo;
-}
-
-void BTDM_1AntSignalCompensation(struct rtw_adapter *padapter,
-                                u8 *rssi_wifi, u8 *rssi_bt)
-{
-       struct hal_data_8723a *pHalData;
-       struct btdm_8723a_1ant *pBtdm8723;
-       u8 RSSI_WiFi_Cmpnstn, RSSI_BT_Cmpnstn;
-
-       pHalData = GET_HAL_DATA(padapter);
-       pBtdm8723 = &pHalData->bt_coexist.halCoex8723.btdm1Ant;
-       RSSI_WiFi_Cmpnstn = 0;
-       RSSI_BT_Cmpnstn = 0;
-
-       switch (pBtdm8723->curPsTdma) {
-       case 1: /*  WiFi 52ms */
-               RSSI_WiFi_Cmpnstn = 11; /*  22*0.48 */
-               break;
-       case 2: /*  WiFi 36ms */
-               RSSI_WiFi_Cmpnstn = 14; /*  22*0.64 */
-               break;
-       case 9: /*  WiFi 20ms */
-               RSSI_WiFi_Cmpnstn = 18; /*  22*0.80 */
-               break;
-       case 11: /*  WiFi 10ms */
-               RSSI_WiFi_Cmpnstn = 20; /*  22*0.90 */
-               break;
-       case 4: /*  WiFi 21ms */
-               RSSI_WiFi_Cmpnstn = 17; /*  22*0.79 */
-               break;
-       case 16: /*  WiFi 24ms */
-               RSSI_WiFi_Cmpnstn = 18; /*  22*0.76 */
-               break;
-       case 18: /*  WiFi 37ms */
-               RSSI_WiFi_Cmpnstn = 14; /*  22*0.64 */
-               break;
-       case 23: /* Level-1, Antenna switch to BT at all time */
-       case 24: /* Level-2, Antenna switch to BT at all time */
-       case 25: /* Level-3a, Antenna switch to BT at all time */
-       case 26: /* Level-3b, Antenna switch to BT at all time */
-       case 27: /* Level-3b, Antenna switch to BT at all time */
-       case 33: /* BT SCO & WiFi site survey */
-               RSSI_WiFi_Cmpnstn = 22;
-               break;
-       default:
-               break;
-       }
-
-       if (rssi_wifi && RSSI_WiFi_Cmpnstn) {
-               RTPRINT(FBT, BT_TRACE,
-                       ("[BTCoex], 1AntSgnlCmpnstn, case %d, WiFiCmpnstn "
-                        "=%d(%d => %d)\n", pBtdm8723->curPsTdma,
-                        RSSI_WiFi_Cmpnstn, *rssi_wifi,
-                        *rssi_wifi+RSSI_WiFi_Cmpnstn));
-               *rssi_wifi += RSSI_WiFi_Cmpnstn;
-       }
-
-       if (rssi_bt && RSSI_BT_Cmpnstn) {
-               RTPRINT(FBT, BT_TRACE,
-                       ("[BTCoex], 1AntSgnlCmpnstn, case %d, BTCmpnstn "
-                        "=%d(%d => %d)\n", pBtdm8723->curPsTdma,
-                        RSSI_BT_Cmpnstn, *rssi_bt, *rssi_bt+RSSI_BT_Cmpnstn));
-               *rssi_bt += RSSI_BT_Cmpnstn;
-       }
-}
-
-static void BTDM_1AntParaInit(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData;
-       struct bt_coexist_8723a *pBtCoex;
-       struct btdm_8723a_1ant *pBtdm8723;
-
-       pHalData = GET_HAL_DATA(padapter);
-       pBtCoex = &pHalData->bt_coexist.halCoex8723;
-       pBtdm8723 = &pBtCoex->btdm1Ant;
-
-       /*  Enable counter statistics */
-       rtl8723au_write8(padapter, 0x76e, 0x4);
-       btdm_1AntPtaParaReload(padapter);
-
-       pBtdm8723->wifiRssiThresh = 48;
-
-       pBtdm8723->bWiFiHalt = false;
-       pBtdm8723->bRAChanged = false;
-
-       if ((pBtCoex->c2hBtInfo != BT_INFO_STATE_DISABLED) &&
-           (pBtCoex->c2hBtInfo != BT_INFO_STATE_NO_CONNECTION)) {
-               BTDM_SetSwRfRxLpfCorner(padapter, BT_RF_RX_LPF_CORNER_SHRINK);
-               BTDM_AGCTable(padapter, BT_AGCTABLE_ON);
-               BTDM_BBBackOffLevel(padapter, BT_BB_BACKOFF_ON);
-       }
-}
-
-static void BTDM_1AntForHalt(struct rtw_adapter *padapter)
-{
-       RTPRINT(FBT, BT_TRACE, ("\n[BTCoex], 1Ant for halt\n"));
-
-       GET_HAL_DATA(padapter)->bt_coexist.halCoex8723.btdm1Ant.bWiFiHalt =
-               true;
-
-       btdm_1AntWifiParaAdjust(padapter, false);
-
-       /*  don't use btdm_1AntSetPSTDMA() here */
-       /*  it will call rtw_set_ps_mode23a() and request pwrpriv->lock. */
-       /*  This will lead to deadlock, if this function is called in IPS */
-       /*  Lucas@20130205 */
-       btdm_1AntPsTdma(padapter, false, 0);
-
-       btdm_SetFwIgnoreWlanAct(padapter, true);
-}
-
-static void BTDM_1AntLpsLeave(struct rtw_adapter *padapter)
-{
-       RTPRINT(FBT, BT_TRACE, ("\n[BTCoex], 1Ant for LPS Leave\n"));
-
-       /*  Prevent from entering LPS again */
-       GET_HAL_DATA(padapter)->bt_coexist.halCoex8723.btdm1Ant.bWiFiHalt =
-               true;
-
-       btdm_1AntSetPSTDMA(padapter, false, 0, false, 8);
-/*btdm_1AntPsTdma(padapter, false, 8); */
-}
-
-static void BTDM_1AntWifiAssociateNotify(struct rtw_adapter *padapter, u8 type)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-
-       RTPRINT(FBT, BT_TRACE,
-               ("\n[BTCoex], 1Ant for associate, type =%d\n", type));
-
-       if (type) {
-               rtl8723a_CheckAntenna_Selection(padapter);
-               if (!rtl8723a_BT_enabled(padapter))
-                       btdm_1AntSetPSTDMA(padapter, false, 0, false, 9);
-               else {
-                       struct bt_coexist_8723a *pBtCoex;
-                       u8 BtState;
-
-                       pBtCoex = &pHalData->bt_coexist.halCoex8723;
-                       BtState = pBtCoex->c2hBtInfo;
-
-                       btdm_1AntTSFSwitch(padapter, true);
-
-                       if (BtState == BT_INFO_STATE_NO_CONNECTION ||
-                           BtState == BT_INFO_STATE_CONNECT_IDLE) {
-                               btdm_1AntSetPSTDMA(padapter, false, 0,
-                                                  true, 28);
-                       } else if (BtState == BT_INFO_STATE_SCO_ONLY_BUSY ||
-                                  BtState == BT_INFO_STATE_ACL_SCO_BUSY) {
-                               btdm_1AntSetPSTDMA(padapter, false, 0,
-                                                  false, 8);
-                               rtl8723au_write32(padapter, 0x6c0, 0x5a5a5a5a);
-                               rtl8723au_write32(padapter, 0x6c4, 0x5a5a5a5a);
-                       } else if (BtState == BT_INFO_STATE_ACL_ONLY_BUSY ||
-                                  BtState == BT_INFO_STATE_ACL_INQ_OR_PAG) {
-                               if (pBtCoex->c2hBtProfile == BT_INFO_HID)
-                                       btdm_1AntSetPSTDMA(padapter, false, 0,
-                                                          true, 35);
-                               else
-                                       btdm_1AntSetPSTDMA(padapter, false, 0,
-                                                          true, 29);
-                       }
-               }
-       } else {
-               if (!rtl8723a_BT_enabled(padapter)) {
-                       if (!BTDM_IsWifiConnectionExist(padapter)) {
-                               btdm_1AntPsTdma(padapter, false, 0);
-                               btdm_1AntTSFSwitch(padapter, false);
-                       }
-               }
-
-               btdm_1AntBtCoexistHandler(padapter);
-       }
-}
-
-static void
-BTDM_1AntMediaStatusNotify(struct rtw_adapter *padapter,
-                          enum rt_media_status mstatus)
-{
-       struct bt_coexist_8723a *pBtCoex;
-
-       pBtCoex = &GET_HAL_DATA(padapter)->bt_coexist.halCoex8723;
-
-       RTPRINT(FBT, BT_TRACE,
-               ("\n\n[BTCoex]******************************\n"));
-       RTPRINT(FBT, BT_TRACE, ("[BTCoex], MediaStatus, WiFi %s !!\n",
-                       mstatus == RT_MEDIA_CONNECT?"CONNECT":"DISCONNECT"));
-       RTPRINT(FBT, BT_TRACE, ("[BTCoex]******************************\n"));
-
-       if (RT_MEDIA_CONNECT == mstatus) {
-               if (check_fwstate(&padapter->mlmepriv, WIFI_STATION_STATE)) {
-                       if (pBtCoex->c2hBtInfo == BT_INFO_STATE_SCO_ONLY_BUSY ||
-                           pBtCoex->c2hBtInfo == BT_INFO_STATE_ACL_SCO_BUSY)
-                               btdm_1AntUpdateHalRAMaskForSCO(padapter, true);
-               }
-
-               padapter->pwrctrlpriv.DelayLPSLastTimeStamp = jiffies;
-               BTDM_1AntForDhcp(padapter);
-       } else {
-               /* DBG_8723A("%s rtl8723a_DeinitAntenna_Selection\n",
-                  __func__); */
-               rtl8723a_DeinitAntenna_Selection(padapter);
-               btdm_1AntBtCoexistHandler(padapter);
-               pBtCoex->btdm1Ant.bRAChanged = false;
-       }
-}
-
-void BTDM_1AntForDhcp(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData;
-       u8 BtState;
-       struct bt_coexist_8723a *pBtCoex;
-       struct btdm_8723a_1ant *pBtdm8723;
-
-       pHalData = GET_HAL_DATA(padapter);
-       pBtCoex = &pHalData->bt_coexist.halCoex8723;
-       BtState = pBtCoex->c2hBtInfo;
-       pBtdm8723 = &pBtCoex->btdm1Ant;
-
-       RTPRINT(FBT, BT_TRACE, ("\n[BTCoex], 1Ant for DHCP\n"));
-       RTPRINT(FBT, BT_TRACE, ("[BTCoex], 1Ant for DHCP, WiFi is %s\n",
-                               BTDM_IsWifiBusy(padapter)?"Busy":"IDLE"));
-       RTPRINT(FBT, BT_TRACE, ("[BTCoex], 1Ant for DHCP, %s\n",
-                               BtStateString[BtState]));
-
-       BTDM_1AntWifiAssociateNotify(padapter, true);
-}
-
-static void BTDM_1AntWifiScanNotify(struct rtw_adapter *padapter, u8 scanType)
-{
-       struct hal_data_8723a *pHalData;
-       u8 BtState;
-       struct bt_coexist_8723a *pBtCoex;
-       struct btdm_8723a_1ant *pBtdm8723;
-
-       pHalData = GET_HAL_DATA(padapter);
-       BtState = pHalData->bt_coexist.halCoex8723.c2hBtInfo;
-       pBtCoex = &pHalData->bt_coexist.halCoex8723;
-       pBtdm8723 = &pBtCoex->btdm1Ant;
-
-       RTPRINT(FBT, BT_TRACE, ("\n[BTCoex], 1Ant for wifi scan =%d!!\n",
-                               scanType));
-       RTPRINT(FBT, BT_TRACE, ("[BTCoex], 1Ant for wifi scan, WiFi is %s\n",
-                               BTDM_IsWifiBusy(padapter)?"Busy":"IDLE"));
-       RTPRINT(FBT, BT_TRACE, ("[BTCoex], 1Ant for wifi scan, %s\n",
-                               BtStateString[BtState]));
-
-       if (scanType) {
-               rtl8723a_CheckAntenna_Selection(padapter);
-               if (!rtl8723a_BT_enabled(padapter)) {
-                       btdm_1AntSetPSTDMA(padapter, false, 0, false, 9);
-               } else if (BTDM_IsWifiConnectionExist(padapter) == false) {
-                       BTDM_1AntWifiAssociateNotify(padapter, true);
-               } else {
-                       if ((BtState == BT_INFO_STATE_SCO_ONLY_BUSY) ||
-                           (BtState == BT_INFO_STATE_ACL_SCO_BUSY)) {
-                               if (pBtCoex->bC2hBtInquiryPage) {
-                                       btdm_1AntSetPSTDMA(padapter, false, 0,
-                                                          true, 32);
-                               } else {
-                                       padapter->pwrctrlpriv.btcoex_rfon =
-                                               true;
-                                       btdm_1AntSetPSTDMA(padapter, true, 0,
-                                                          true, 33);
-                               }
-                       } else if (true == pBtCoex->bC2hBtInquiryPage) {
-                               padapter->pwrctrlpriv.btcoex_rfon = true;
-                               btdm_1AntSetPSTDMA(padapter, true, 0, true, 30);
-                       } else if (BtState == BT_INFO_STATE_ACL_ONLY_BUSY) {
-                               padapter->pwrctrlpriv.btcoex_rfon = true;
-                               if (pBtCoex->c2hBtProfile == BT_INFO_HID)
-                                       btdm_1AntSetPSTDMA(padapter, true, 0,
-                                                          true, 34);
-                               else
-                                       btdm_1AntSetPSTDMA(padapter, true, 0,
-                                                          true, 4);
-                       } else {
-                               padapter->pwrctrlpriv.btcoex_rfon = true;
-                               btdm_1AntSetPSTDMA(padapter, true, 0, true, 5);
-                       }
-               }
-
-               btdm_NotifyFwScan(padapter, 1);
-       } else {
-               /*  WiFi_Finish_Scan */
-               btdm_NotifyFwScan(padapter, 0);
-               btdm_1AntBtCoexistHandler(padapter);
-       }
-}
-
-static void BTDM_1AntFwC2hBtInfo8723A(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData;
-       struct bt_30info *pBTInfo;
-       struct bt_mgnt *pBtMgnt;
-       struct bt_coexist_8723a *pBtCoex;
-       u8 u1tmp, btState;
-
-       pHalData = GET_HAL_DATA(padapter);
-       pBTInfo = GET_BT_INFO(padapter);
-       pBtMgnt = &pBTInfo->BtMgnt;
-       pBtCoex = &pHalData->bt_coexist.halCoex8723;
-
-       u1tmp = pBtCoex->c2hBtInfoOriginal;
-       /*  sco BUSY bit is not used on voice over PCM platform */
-       btState = u1tmp & 0xF;
-       pBtCoex->c2hBtProfile = u1tmp & 0xE0;
-
-       /*  default set bt to idle state. */
-       pBtMgnt->ExtConfig.bBTBusy = false;
-       pHalData->bt_coexist.CurrentState |= BT_COEX_STATE_BT_IDLE;
-
-       /*  check BIT2 first ==> check if bt is under inquiry or page scan */
-       if (btState & BIT(2))
-               pBtCoex->bC2hBtInquiryPage = true;
-       else
-               pBtCoex->bC2hBtInquiryPage = false;
-       btState &= ~BIT(2);
-
-       if (!(btState & BIT(0)))
-               pBtCoex->c2hBtInfo = BT_INFO_STATE_NO_CONNECTION;
-       else {
-               if (btState == 0x1)
-                       pBtCoex->c2hBtInfo = BT_INFO_STATE_CONNECT_IDLE;
-               else if (btState == 0x9) {
-                       if (pBtCoex->bC2hBtInquiryPage == true)
-                               pBtCoex->c2hBtInfo =
-                                       BT_INFO_STATE_ACL_INQ_OR_PAG;
-                       else
-                               pBtCoex->c2hBtInfo =
-                                       BT_INFO_STATE_ACL_ONLY_BUSY;
-                       pBtMgnt->ExtConfig.bBTBusy = true;
-               } else if (btState == 0x3) {
-                       pBtCoex->c2hBtInfo = BT_INFO_STATE_SCO_ONLY_BUSY;
-                       pBtMgnt->ExtConfig.bBTBusy = true;
-               } else if (btState == 0xb) {
-                       pBtCoex->c2hBtInfo = BT_INFO_STATE_ACL_SCO_BUSY;
-                       pBtMgnt->ExtConfig.bBTBusy = true;
-               } else
-                       pBtCoex->c2hBtInfo = BT_INFO_STATE_MAX;
-               if (pBtMgnt->ExtConfig.bBTBusy)
-                       pHalData->bt_coexist.CurrentState &=
-                               ~BT_COEX_STATE_BT_IDLE;
-       }
-
-       if (BT_INFO_STATE_NO_CONNECTION == pBtCoex->c2hBtInfo ||
-           BT_INFO_STATE_CONNECT_IDLE == pBtCoex->c2hBtInfo) {
-               if (pBtCoex->bC2hBtInquiryPage)
-                       pBtCoex->c2hBtInfo = BT_INFO_STATE_INQ_OR_PAG;
-       }
-
-       RTPRINT(FBT, BT_TRACE, ("[BTC2H], %s(%d)\n",
-                       BtStateString[pBtCoex->c2hBtInfo], pBtCoex->c2hBtInfo));
-
-       if (pBtCoex->c2hBtProfile != BT_INFO_HID)
-               pBtCoex->c2hBtProfile &= ~BT_INFO_HID;
-}
-
-void BTDM_1AntBtCoexist8723A(struct rtw_adapter *padapter)
-{
-       struct mlme_priv *pmlmepriv;
-       struct hal_data_8723a *pHalData;
-       unsigned long delta_time;
-
-       pmlmepriv = &padapter->mlmepriv;
-       pHalData = GET_HAL_DATA(padapter);
-
-       if (check_fwstate(pmlmepriv, WIFI_SITE_MONITOR)) {
-               /*  already done in BTDM_1AntForScan() */
-               RTPRINT(FBT, BT_TRACE,
-                       ("[BTCoex], wifi is under scan progress!!\n"));
-               return;
-       }
-
-       if (check_fwstate(pmlmepriv, WIFI_UNDER_LINKING)) {
-               RTPRINT(FBT, BT_TRACE,
-                       ("[BTCoex], wifi is under link progress!!\n"));
-               return;
-       }
-
-       /*  under DHCP(Special packet) */
-       delta_time = jiffies - padapter->pwrctrlpriv.DelayLPSLastTimeStamp;
-       delta_time = jiffies_to_msecs(delta_time);
-       if (delta_time < 500) {
-               RTPRINT(FBT, BT_TRACE, ("[BTCoex], wifi is under DHCP "
-                                       "progress(%li ms)!!\n", delta_time));
-               return;
-       }
-
-       BTDM_CheckWiFiState(padapter);
-
-       btdm_1AntBtCoexistHandler(padapter);
-}
-
-/*  ===== End of sync from SD7 driver HAL/BTCoexist/HalBtc87231Ant.c ===== */
-
-/*  ===== Below this line is sync from SD7 driver HAL/BTCoexist/HalBtc87232Ant.c ===== */
-
-/*  local function start with btdm_ */
-static u8 btdm_ActionAlgorithm(struct rtw_adapter *padapter)
-{
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       struct btdm_8723a_2ant *pBtdm8723 = &pHalData->bt_coexist.halCoex8723.btdm2Ant;
-       u8 bScoExist = false, bBtLinkExist = false, bBtHsModeExist = false;
-       u8 algorithm = BT_2ANT_COEX_ALGO_UNDEFINED;
-
-       if (pBtMgnt->ExtConfig.NumberOfHandle)
-               bBtLinkExist = true;
-       if (pBtMgnt->ExtConfig.NumberOfSCO)
-               bScoExist = true;
-       if (BT_HsConnectionEstablished(padapter))
-               bBtHsModeExist = true;
-
-       /*  here we get BT status first */
-       /*  1) initialize */
-       pBtdm8723->btStatus = BT_2ANT_BT_STATUS_IDLE;
-
-       if ((bScoExist) || (bBtHsModeExist) ||
-           (BTHCI_CheckProfileExist(padapter, BT_PROFILE_HID))) {
-               RTPRINT(FBT, BT_TRACE, ("[BTCoex], SCO or HID or HS exists, set BT non-idle !!!\n"));
-               pBtdm8723->btStatus = BT_2ANT_BT_STATUS_NON_IDLE;
-       } else {
-               /*  A2dp profile */
-               if ((pBtMgnt->ExtConfig.NumberOfHandle == 1) &&
-                   (BTHCI_CheckProfileExist(padapter, BT_PROFILE_A2DP))) {
-                       if (BTDM_BtTxRxCounterL(padapter) < 100) {
-                               RTPRINT(FBT, BT_TRACE, ("[BTCoex], A2DP, low priority tx+rx < 100, set BT connected-idle!!!\n"));
-                               pBtdm8723->btStatus = BT_2ANT_BT_STATUS_CONNECTED_IDLE;
-                       } else {
-                               RTPRINT(FBT, BT_TRACE, ("[BTCoex], A2DP, low priority tx+rx >= 100, set BT non-idle!!!\n"));
-                               pBtdm8723->btStatus = BT_2ANT_BT_STATUS_NON_IDLE;
-                       }
-               }
-               /*  Pan profile */
-               if ((pBtMgnt->ExtConfig.NumberOfHandle == 1) &&
-                   (BTHCI_CheckProfileExist(padapter, BT_PROFILE_PAN))) {
-                       if (BTDM_BtTxRxCounterL(padapter) < 600) {
-                               RTPRINT(FBT, BT_TRACE, ("[BTCoex], PAN, low priority tx+rx < 600, set BT connected-idle!!!\n"));
-                               pBtdm8723->btStatus = BT_2ANT_BT_STATUS_CONNECTED_IDLE;
-                       } else {
-                               if (pHalData->bt_coexist.halCoex8723.lowPriorityTx) {
-                                       if ((pHalData->bt_coexist.halCoex8723.lowPriorityRx /
-                                           pHalData->bt_coexist.halCoex8723.lowPriorityTx) > 9) {
-                                               RTPRINT(FBT, BT_TRACE, ("[BTCoex], PAN, low priority rx/tx > 9, set BT connected-idle!!!\n"));
-                                               pBtdm8723->btStatus = BT_2ANT_BT_STATUS_CONNECTED_IDLE;
-                                       }
-                               }
-                       }
-                       if (BT_2ANT_BT_STATUS_CONNECTED_IDLE != pBtdm8723->btStatus) {
-                               RTPRINT(FBT, BT_TRACE, ("[BTCoex], PAN, set BT non-idle!!!\n"));
-                               pBtdm8723->btStatus = BT_2ANT_BT_STATUS_NON_IDLE;
-                       }
-               }
-               /*  Pan+A2dp profile */
-               if ((pBtMgnt->ExtConfig.NumberOfHandle == 2) &&
-                   (BTHCI_CheckProfileExist(padapter, BT_PROFILE_A2DP)) &&
-                   (BTHCI_CheckProfileExist(padapter, BT_PROFILE_PAN))) {
-                       if (BTDM_BtTxRxCounterL(padapter) < 600) {
-                               RTPRINT(FBT, BT_TRACE, ("[BTCoex], PAN+A2DP, low priority tx+rx < 600, set BT connected-idle!!!\n"));
-                               pBtdm8723->btStatus = BT_2ANT_BT_STATUS_CONNECTED_IDLE;
-                       } else {
-                               if (pHalData->bt_coexist.halCoex8723.lowPriorityTx) {
-                                       if ((pHalData->bt_coexist.halCoex8723.lowPriorityRx /
-                                           pHalData->bt_coexist.halCoex8723.lowPriorityTx) > 9) {
-                                               RTPRINT(FBT, BT_TRACE, ("[BTCoex], PAN+A2DP, low priority rx/tx > 9, set BT connected-idle!!!\n"));
-                                               pBtdm8723->btStatus = BT_2ANT_BT_STATUS_CONNECTED_IDLE;
-                                       }
-                               }
-                       }
-                       if (BT_2ANT_BT_STATUS_CONNECTED_IDLE != pBtdm8723->btStatus) {
-                               RTPRINT(FBT, BT_TRACE, ("[BTCoex], PAN+A2DP, set BT non-idle!!!\n"));
-                               pBtdm8723->btStatus = BT_2ANT_BT_STATUS_NON_IDLE;
-                       }
-               }
-       }
-       if (BT_2ANT_BT_STATUS_IDLE != pBtdm8723->btStatus)
-               pBtMgnt->ExtConfig.bBTBusy = true;
-       else
-               pBtMgnt->ExtConfig.bBTBusy = false;
-
-       if (!bBtLinkExist) {
-               RTPRINT(FBT, BT_TRACE, ("[BTCoex], No profile exists!!!\n"));
-               return algorithm;
-       }
-
-       if (pBtMgnt->ExtConfig.NumberOfHandle == 1) {
-               if (bScoExist) {
-                       RTPRINT(FBT, BT_TRACE, ("[BTCoex], SCO only\n"));
-                       algorithm = BT_2ANT_COEX_ALGO_SCO;
-               } else {
-                       if (BTHCI_CheckProfileExist(padapter, BT_PROFILE_HID)) {
-                               RTPRINT(FBT, BT_TRACE, ("[BTCoex], HID only\n"));
-                               algorithm = BT_2ANT_COEX_ALGO_HID;
-                       } else if (BTHCI_CheckProfileExist(padapter, BT_PROFILE_A2DP)) {
-                               RTPRINT(FBT, BT_TRACE, ("[BTCoex], A2DP only\n"));
-                               algorithm = BT_2ANT_COEX_ALGO_A2DP;
-                       } else if (BTHCI_CheckProfileExist(padapter, BT_PROFILE_PAN)) {
-                               if (bBtHsModeExist) {
-                                       RTPRINT(FBT, BT_TRACE, ("[BTCoex], PAN(HS) only\n"));
-                                       algorithm = BT_2ANT_COEX_ALGO_PANHS;
-                               } else {
-                                       RTPRINT(FBT, BT_TRACE, ("[BTCoex], PAN(EDR) only\n"));
-                                       algorithm = BT_2ANT_COEX_ALGO_PANEDR;
-                               }
-                       } else {
-                               RTPRINT(FBT, BT_TRACE, ("[BTCoex], Error!!! NO matched profile for NumberOfHandle =%d \n",
-                               pBtMgnt->ExtConfig.NumberOfHandle));
-                       }
-               }
-       } else if (pBtMgnt->ExtConfig.NumberOfHandle == 2) {
-               if (bScoExist) {
-                       if (BTHCI_CheckProfileExist(padapter, BT_PROFILE_HID)) {
-                               RTPRINT(FBT, BT_TRACE, ("[BTCoex], SCO + HID\n"));
-                               algorithm = BT_2ANT_COEX_ALGO_HID;
-                       } else if (BTHCI_CheckProfileExist(padapter, BT_PROFILE_A2DP)) {
-                               RTPRINT(FBT, BT_TRACE, ("[BTCoex], Error!!! SCO + A2DP\n"));
-                       } else if (BTHCI_CheckProfileExist(padapter, BT_PROFILE_PAN)) {
-                               if (bBtHsModeExist) {
-                                       RTPRINT(FBT, BT_TRACE, ("[BTCoex], SCO + PAN(HS)\n"));
-                                       algorithm = BT_2ANT_COEX_ALGO_SCO;
-                               } else {
-                                       RTPRINT(FBT, BT_TRACE, ("[BTCoex], SCO + PAN(EDR)\n"));
-                                       algorithm = BT_2ANT_COEX_ALGO_PANEDR_HID;
-                               }
-                       } else {
-                               RTPRINT(FBT, BT_TRACE, ("[BTCoex], Error!!! SCO exists but why NO matched ACL profile for NumberOfHandle =%d\n",
-                               pBtMgnt->ExtConfig.NumberOfHandle));
-                       }
-               } else {
-                       if (BTHCI_CheckProfileExist(padapter, BT_PROFILE_HID) &&
-                           BTHCI_CheckProfileExist(padapter, BT_PROFILE_A2DP)) {
-                               RTPRINT(FBT, BT_TRACE, ("[BTCoex], HID + A2DP\n"));
-                               algorithm = BT_2ANT_COEX_ALGO_HID_A2DP;
-               } else if (BTHCI_CheckProfileExist(padapter, BT_PROFILE_HID) &&
-                          BTHCI_CheckProfileExist(padapter, BT_PROFILE_PAN)) {
-                               if (bBtHsModeExist) {
-                                       RTPRINT(FBT, BT_TRACE, ("[BTCoex], HID + PAN(HS)\n"));
-                                       algorithm = BT_2ANT_COEX_ALGO_HID_A2DP;
-                               } else {
-                                       RTPRINT(FBT, BT_TRACE, ("[BTCoex], HID + PAN(EDR)\n"));
-                                       algorithm = BT_2ANT_COEX_ALGO_PANEDR_HID;
-                               }
-                       } else if (BTHCI_CheckProfileExist(padapter, BT_PROFILE_PAN) &&
-                                  BTHCI_CheckProfileExist(padapter, BT_PROFILE_A2DP)) {
-                               if (bBtHsModeExist) {
-                                       RTPRINT(FBT, BT_TRACE, ("[BTCoex], A2DP + PAN(HS)\n"));
-                                       algorithm = BT_2ANT_COEX_ALGO_A2DP;
-                               } else {
-                                       RTPRINT(FBT, BT_TRACE, ("[BTCoex], A2DP + PAN(EDR)\n"));
-                                       algorithm = BT_2ANT_COEX_ALGO_PANEDR_A2DP;
-                               }
-                       } else {
-                               RTPRINT(FBT, BT_TRACE, ("[BTCoex], Error!!! NO matched profile for NumberOfHandle =%d\n",
-                                       pBtMgnt->ExtConfig.NumberOfHandle));
-                       }
-               }
-       } else if (pBtMgnt->ExtConfig.NumberOfHandle == 3) {
-               if (bScoExist) {
-                       if (BTHCI_CheckProfileExist(padapter, BT_PROFILE_HID) &&
-                           BTHCI_CheckProfileExist(padapter, BT_PROFILE_A2DP)) {
-                               RTPRINT(FBT, BT_TRACE, ("[BTCoex], Error!!! SCO + HID + A2DP\n"));
-                       } else if (BTHCI_CheckProfileExist(padapter, BT_PROFILE_HID) &&
-                                  BTHCI_CheckProfileExist(padapter, BT_PROFILE_PAN)) {
-                               if (bBtHsModeExist) {
-                                       RTPRINT(FBT, BT_TRACE, ("[BTCoex], SCO + HID + PAN(HS)\n"));
-                                       algorithm = BT_2ANT_COEX_ALGO_HID_A2DP;
-                               } else {
-                                       RTPRINT(FBT, BT_TRACE, ("[BTCoex], SCO + HID + PAN(EDR)\n"));
-                                       algorithm = BT_2ANT_COEX_ALGO_PANEDR_HID;
-                               }
-                       } else if (BTHCI_CheckProfileExist(padapter, BT_PROFILE_PAN) &&
-                                  BTHCI_CheckProfileExist(padapter, BT_PROFILE_A2DP)) {
-                               if (bBtHsModeExist) {
-                                       RTPRINT(FBT, BT_TRACE, ("[BTCoex], Error!!! SCO + A2DP + PAN(HS)\n"));
-                                       algorithm = BT_2ANT_COEX_ALGO_SCO;
-                               } else {
-                                       RTPRINT(FBT, BT_TRACE, ("[BTCoex], Error!!! SCO + A2DP + PAN(EDR)\n"));
-                               }
-                       } else {
-                               RTPRINT(FBT, BT_TRACE, ("[BTCoex], Error!!! SCO exists but why NO matched profile for NumberOfHandle =%d\n",
-                                       pBtMgnt->ExtConfig.NumberOfHandle));
-                       }
-               } else {
-                       if (BTHCI_CheckProfileExist(padapter, BT_PROFILE_HID) &&
-                           BTHCI_CheckProfileExist(padapter, BT_PROFILE_PAN) &&
-                           BTHCI_CheckProfileExist(padapter, BT_PROFILE_A2DP)) {
-                               if (bBtHsModeExist) {
-                                       RTPRINT(FBT, BT_TRACE, ("[BTCoex], HID + A2DP + PAN(HS)\n"));
-                                       algorithm = BT_2ANT_COEX_ALGO_HID_A2DP_PANHS;
-                               } else {
-                                       RTPRINT(FBT, BT_TRACE, ("[BTCoex], HID + A2DP + PAN(EDR)\n"));
-                                       algorithm = BT_2ANT_COEX_ALGO_HID_A2DP_PANEDR;
-                               }
-                       } else {
-                               RTPRINT(FBT, BT_TRACE, ("[BTCoex], Error!!! NO matched profile for NumberOfHandle =%d\n",
-                                       pBtMgnt->ExtConfig.NumberOfHandle));
-                       }
-               }
-       } else if (pBtMgnt->ExtConfig.NumberOfHandle >= 3) {
-               if (bScoExist) {
-                       if (BTHCI_CheckProfileExist(padapter, BT_PROFILE_HID) &&
-                           BTHCI_CheckProfileExist(padapter, BT_PROFILE_PAN) &&
-                           BTHCI_CheckProfileExist(padapter, BT_PROFILE_A2DP)) {
-                               if (bBtHsModeExist)
-                                       RTPRINT(FBT, BT_TRACE, ("[BTCoex], Error!!! SCO + HID + A2DP + PAN(HS)\n"));
-                               else
-                                       RTPRINT(FBT, BT_TRACE, ("[BTCoex], Error!!! SCO + HID + A2DP + PAN(EDR)\n"));
-                       } else {
-                               RTPRINT(FBT, BT_TRACE, ("[BTCoex], Error!!! SCO exists but why NO matched profile for NumberOfHandle =%d\n",
-                                       pBtMgnt->ExtConfig.NumberOfHandle));
-                       }
-               } else {
-                       RTPRINT(FBT, BT_TRACE, ("[BTCoex], Error!!! NO matched profile for NumberOfHandle =%d\n",
-                               pBtMgnt->ExtConfig.NumberOfHandle));
-               }
-       }
-       return algorithm;
-}
-
-static u8 btdm_NeedToDecBtPwr(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       u8 bRet = false;
-
-       if (BT_Operation(padapter)) {
-               if (pHalData->dmpriv.EntryMinUndecoratedSmoothedPWDB > 47) {
-                       RTPRINT(FBT, BT_TRACE, ("Need to decrease bt power for HS mode!!\n"));
-                       bRet = true;
-               } else {
-                       RTPRINT(FBT, BT_TRACE, ("NO Need to decrease bt power for HS mode!!\n"));
-               }
-       } else {
-               if (BTDM_IsWifiConnectionExist(padapter)) {
-                       RTPRINT(FBT, BT_TRACE, ("Need to decrease bt power for Wifi is connected!!\n"));
-                       bRet = true;
-               }
-       }
-       return bRet;
-}
-
-static void
-btdm_SetCoexTable(struct rtw_adapter *padapter, u32 val0x6c0,
-                 u32 val0x6c8, u8 val0x6cc)
-{
-       RTPRINT(FBT, BT_TRACE, ("set coex table, set 0x6c0 = 0x%x\n", val0x6c0));
-       rtl8723au_write32(padapter, 0x6c0, val0x6c0);
-
-       RTPRINT(FBT, BT_TRACE, ("set coex table, set 0x6c8 = 0x%x\n", val0x6c8));
-       rtl8723au_write32(padapter, 0x6c8, val0x6c8);
-
-       RTPRINT(FBT, BT_TRACE, ("set coex table, set 0x6cc = 0x%x\n", val0x6cc));
-       rtl8723au_write8(padapter, 0x6cc, val0x6cc);
-}
-
-static void
-btdm_SetSwFullTimeDacSwing(struct rtw_adapter *padapter, u8 bSwDacSwingOn,
-                          u32 swDacSwingLvl)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-
-       if (bSwDacSwingOn) {
-               RTPRINT(FBT, BT_TRACE, ("[BTCoex], SwDacSwing = 0x%x\n", swDacSwingLvl));
-               PHY_SetBBReg(padapter, 0x880, 0xff000000, swDacSwingLvl);
-               pHalData->bt_coexist.bSWCoexistAllOff = false;
-       } else {
-               RTPRINT(FBT, BT_TRACE, ("[BTCoex], SwDacSwing Off!\n"));
-               PHY_SetBBReg(padapter, 0x880, 0xff000000, 0xc0);
-       }
-}
-
-static void
-btdm_SetFwDacSwingLevel(struct rtw_adapter *padapter, u8 dacSwingLvl)
-{
-       u8 H2C_Parameter[1] = {0};
-
-       H2C_Parameter[0] = dacSwingLvl;
-
-       RTPRINT(FBT, BT_TRACE, ("[BTCoex], Set Dac Swing Level = 0x%x\n", dacSwingLvl));
-       RTPRINT(FBT, BT_TRACE, ("[BTCoex], write 0x29 = 0x%x\n", H2C_Parameter[0]));
-
-       FillH2CCmd(padapter, 0x29, 1, H2C_Parameter);
-}
-
-static void btdm_2AntDecBtPwr(struct rtw_adapter *padapter, u8 bDecBtPwr)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       struct btdm_8723a_2ant *pBtdm8723 = &pHalData->bt_coexist.halCoex8723.btdm2Ant;
-
-       RTPRINT(FBT, BT_TRACE,
-               ("[BTCoex], Dec BT power = %s\n",
-               ((bDecBtPwr) ? "ON" : "OFF")));
-       pBtdm8723->bCurDecBtPwr = bDecBtPwr;
-
-       if (pBtdm8723->bPreDecBtPwr == pBtdm8723->bCurDecBtPwr)
-               return;
-
-       BTDM_SetFwDecBtPwr(padapter, pBtdm8723->bCurDecBtPwr);
-
-       pBtdm8723->bPreDecBtPwr = pBtdm8723->bCurDecBtPwr;
-}
-
-static void
-btdm_2AntFwDacSwingLvl(struct rtw_adapter *padapter, u8 fwDacSwingLvl)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       struct btdm_8723a_2ant *pBtdm8723 = &pHalData->bt_coexist.halCoex8723.btdm2Ant;
-
-       RTPRINT(FBT, BT_TRACE, ("[BTCoex], set FW Dac Swing level = %d\n",  fwDacSwingLvl));
-       pBtdm8723->curFwDacSwingLvl = fwDacSwingLvl;
-
-       /* RTPRINT(FBT, BT_TRACE, ("[BTCoex], preFwDacSwingLvl =%d, curFwDacSwingLvl =%d\n", */
-       /*pBtdm8723->preFwDacSwingLvl, pBtdm8723->curFwDacSwingLvl)); */
-
-       if (pBtdm8723->preFwDacSwingLvl == pBtdm8723->curFwDacSwingLvl)
-               return;
-
-       btdm_SetFwDacSwingLevel(padapter, pBtdm8723->curFwDacSwingLvl);
-
-       pBtdm8723->preFwDacSwingLvl = pBtdm8723->curFwDacSwingLvl;
-}
-
-static void
-btdm_2AntRfShrink(struct rtw_adapter *padapter, u8 bRxRfShrinkOn)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       struct btdm_8723a_2ant *pBtdm8723 = &pHalData->bt_coexist.halCoex8723.btdm2Ant;
-
-       RTPRINT(FBT, BT_TRACE,
-               ("[BTCoex], turn Rx RF Shrink = %s\n",
-               ((bRxRfShrinkOn) ? "ON" : "OFF")));
-       pBtdm8723->bCurRfRxLpfShrink = bRxRfShrinkOn;
-
-       /* RTPRINT(FBT, BT_TRACE, ("[BTCoex], bPreRfRxLpfShrink =%d, bCurRfRxLpfShrink =%d\n", */
-       /*pBtdm8723->bPreRfRxLpfShrink, pBtdm8723->bCurRfRxLpfShrink)); */
-
-       if (pBtdm8723->bPreRfRxLpfShrink == pBtdm8723->bCurRfRxLpfShrink)
-               return;
-
-       BTDM_SetSwRfRxLpfCorner(padapter, (u8)pBtdm8723->bCurRfRxLpfShrink);
-
-       pBtdm8723->bPreRfRxLpfShrink = pBtdm8723->bCurRfRxLpfShrink;
-}
-
-static void
-btdm_2AntLowPenaltyRa(struct rtw_adapter *padapter, u8 bLowPenaltyRa)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       struct btdm_8723a_2ant *pBtdm8723 = &pHalData->bt_coexist.halCoex8723.btdm2Ant;
-
-       RTPRINT(FBT, BT_TRACE,
-               ("[BTCoex], turn LowPenaltyRA = %s\n",
-               ((bLowPenaltyRa) ? "ON" : "OFF")));
-       pBtdm8723->bCurLowPenaltyRa = bLowPenaltyRa;
-
-       /* RTPRINT(FBT, BT_TRACE, ("[BTCoex], bPreLowPenaltyRa =%d, bCurLowPenaltyRa =%d\n", */
-       /*pBtdm8723->bPreLowPenaltyRa, pBtdm8723->bCurLowPenaltyRa)); */
-
-       if (pBtdm8723->bPreLowPenaltyRa == pBtdm8723->bCurLowPenaltyRa)
-               return;
-
-       BTDM_SetSwPenaltyTxRateAdaptive(padapter, (u8)pBtdm8723->bCurLowPenaltyRa);
-
-       pBtdm8723->bPreLowPenaltyRa = pBtdm8723->bCurLowPenaltyRa;
-}
-
-static void
-btdm_2AntDacSwing(struct rtw_adapter *padapter,
-                 u8 bDacSwingOn, u32 dacSwingLvl)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       struct btdm_8723a_2ant *pBtdm8723 = &pHalData->bt_coexist.halCoex8723.btdm2Ant;
-
-       RTPRINT(FBT, BT_TRACE,
-               ("[BTCoex], turn DacSwing =%s, dacSwingLvl = 0x%x\n",
-               (bDacSwingOn ? "ON" : "OFF"), dacSwingLvl));
-       pBtdm8723->bCurDacSwingOn = bDacSwingOn;
-       pBtdm8723->curDacSwingLvl = dacSwingLvl;
-
-       if ((pBtdm8723->bPreDacSwingOn == pBtdm8723->bCurDacSwingOn) &&
-           (pBtdm8723->preDacSwingLvl == pBtdm8723->curDacSwingLvl))
-               return;
-
-       mdelay(30);
-       btdm_SetSwFullTimeDacSwing(padapter, bDacSwingOn, dacSwingLvl);
-
-       pBtdm8723->bPreDacSwingOn = pBtdm8723->bCurDacSwingOn;
-       pBtdm8723->preDacSwingLvl = pBtdm8723->curDacSwingLvl;
-}
-
-static void btdm_2AntAdcBackOff(struct rtw_adapter *padapter, u8 bAdcBackOff)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       struct btdm_8723a_2ant *pBtdm8723 = &pHalData->bt_coexist.halCoex8723.btdm2Ant;
-
-       RTPRINT(FBT, BT_TRACE,
-               ("[BTCoex], turn AdcBackOff = %s\n",
-               ((bAdcBackOff) ? "ON" : "OFF")));
-       pBtdm8723->bCurAdcBackOff = bAdcBackOff;
-
-       if (pBtdm8723->bPreAdcBackOff == pBtdm8723->bCurAdcBackOff)
-               return;
-
-       BTDM_BBBackOffLevel(padapter, (u8)pBtdm8723->bCurAdcBackOff);
-
-       pBtdm8723->bPreAdcBackOff = pBtdm8723->bCurAdcBackOff;
-}
-
-static void btdm_2AntAgcTable(struct rtw_adapter *padapter, u8 bAgcTableEn)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       struct btdm_8723a_2ant *pBtdm8723 = &pHalData->bt_coexist.halCoex8723.btdm2Ant;
-
-       RTPRINT(FBT, BT_TRACE,
-               ("[BTCoex], %s Agc Table\n", ((bAgcTableEn) ? "Enable" : "Disable")));
-       pBtdm8723->bCurAgcTableEn = bAgcTableEn;
-
-       /* RTPRINT(FBT, BT_TRACE, ("[BTCoex], bPreAgcTableEn =%d, bCurAgcTableEn =%d\n", */
-       /*pBtdm8723->bPreAgcTableEn, pBtdm8723->bCurAgcTableEn)); */
-
-       if (pBtdm8723->bPreAgcTableEn == pBtdm8723->bCurAgcTableEn)
-               return;
-
-       BTDM_AGCTable(padapter, (u8)bAgcTableEn);
-
-       pBtdm8723->bPreAgcTableEn = pBtdm8723->bCurAgcTableEn;
-}
-
-static void
-btdm_2AntCoexTable(struct rtw_adapter *padapter,
-                  u32 val0x6c0, u32 val0x6c8, u8 val0x6cc)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       struct btdm_8723a_2ant *pBtdm8723 = &pHalData->bt_coexist.halCoex8723.btdm2Ant;
-
-       RTPRINT(FBT, BT_TRACE, ("[BTCoex], write Coex Table 0x6c0 = 0x%x, 0x6c8 = 0x%x, 0x6cc = 0x%x\n",
-               val0x6c0, val0x6c8, val0x6cc));
-       pBtdm8723->curVal0x6c0 = val0x6c0;
-       pBtdm8723->curVal0x6c8 = val0x6c8;
-       pBtdm8723->curVal0x6cc = val0x6cc;
-
-       /* RTPRINT(FBT, BT_TRACE, ("[BTCoex], preVal0x6c0 = 0x%x, preVal0x6c8 = 0x%x, preVal0x6cc = 0x%x !!\n", */
-       /*pBtdm8723->preVal0x6c0, pBtdm8723->preVal0x6c8, pBtdm8723->preVal0x6cc)); */
-       /* RTPRINT(FBT, BT_TRACE, ("[BTCoex], curVal0x6c0 = 0x%x, curVal0x6c8 = 0x%x, curVal0x6cc = 0x%x !!\n", */
-       /*pBtdm8723->curVal0x6c0, pBtdm8723->curVal0x6c8, pBtdm8723->curVal0x6cc)); */
-
-       if ((pBtdm8723->preVal0x6c0 == pBtdm8723->curVal0x6c0) &&
-           (pBtdm8723->preVal0x6c8 == pBtdm8723->curVal0x6c8) &&
-           (pBtdm8723->preVal0x6cc == pBtdm8723->curVal0x6cc))
-               return;
-
-       btdm_SetCoexTable(padapter, val0x6c0, val0x6c8, val0x6cc);
-
-       pBtdm8723->preVal0x6c0 = pBtdm8723->curVal0x6c0;
-       pBtdm8723->preVal0x6c8 = pBtdm8723->curVal0x6c8;
-       pBtdm8723->preVal0x6cc = pBtdm8723->curVal0x6cc;
-}
-
-static void btdm_2AntIgnoreWlanAct(struct rtw_adapter *padapter, u8 bEnable)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       struct btdm_8723a_2ant *pBtdm8723 = &pHalData->bt_coexist.halCoex8723.btdm2Ant;
-
-       RTPRINT(FBT, BT_TRACE,
-               ("[BTCoex], turn Ignore WlanAct %s\n", (bEnable ? "ON" : "OFF")));
-       pBtdm8723->bCurIgnoreWlanAct = bEnable;
-
-
-       if (pBtdm8723->bPreIgnoreWlanAct == pBtdm8723->bCurIgnoreWlanAct)
-               return;
-
-       btdm_SetFwIgnoreWlanAct(padapter, bEnable);
-       pBtdm8723->bPreIgnoreWlanAct = pBtdm8723->bCurIgnoreWlanAct;
-}
-
-static void
-btdm_2AntSetFw3a(struct rtw_adapter *padapter, u8 byte1, u8 byte2,
-                u8 byte3, u8 byte4, u8 byte5)
-{
-       u8 H2C_Parameter[5] = {0};
-
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-
-       /*  byte1[1:0] != 0 means enable pstdma */
-       /*  for 2Ant bt coexist, if byte1 != 0 means enable pstdma */
-       if (byte1)
-               pHalData->bt_coexist.bFWCoexistAllOff = false;
-       H2C_Parameter[0] = byte1;
-       H2C_Parameter[1] = byte2;
-       H2C_Parameter[2] = byte3;
-       H2C_Parameter[3] = byte4;
-       H2C_Parameter[4] = byte5;
-
-       pHalData->bt_coexist.fw3aVal[0] = byte1;
-       pHalData->bt_coexist.fw3aVal[1] = byte2;
-       pHalData->bt_coexist.fw3aVal[2] = byte3;
-       pHalData->bt_coexist.fw3aVal[3] = byte4;
-       pHalData->bt_coexist.fw3aVal[4] = byte5;
-
-       RTPRINT(FBT, BT_TRACE, ("[BTCoex], FW write 0x3a(5bytes) = 0x%x%08x\n",
-               H2C_Parameter[0],
-               H2C_Parameter[1]<<24|H2C_Parameter[2]<<16|H2C_Parameter[3]<<8|H2C_Parameter[4]));
-
-       FillH2CCmd(padapter, 0x3a, 5, H2C_Parameter);
-       }
-
-static void btdm_2AntPsTdma(struct rtw_adapter *padapter, u8 bTurnOn, u8 type)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       struct btdm_8723a_2ant *pBtdm8723 = &pHalData->bt_coexist.halCoex8723.btdm2Ant;
-       u32                     btTxRxCnt = 0;
-       u8 bTurnOnByCnt = false;
-       u8 psTdmaTypeByCnt = 0;
-
-       btTxRxCnt = BTDM_BtTxRxCounterH(padapter)+BTDM_BtTxRxCounterL(padapter);
-       RTPRINT(FBT, BT_TRACE, ("[BTCoex], BT TxRx Counters = %d\n", btTxRxCnt));
-       if (btTxRxCnt > 3000) {
-               bTurnOnByCnt = true;
-               psTdmaTypeByCnt = 8;
-
-               RTPRINT(FBT, BT_TRACE,
-                       ("[BTCoex], For BTTxRxCounters, turn %s PS TDMA, type =%d\n",
-                       (bTurnOnByCnt ? "ON" : "OFF"), psTdmaTypeByCnt));
-               pBtdm8723->bCurPsTdmaOn = bTurnOnByCnt;
-               pBtdm8723->curPsTdma = psTdmaTypeByCnt;
-       } else {
-               RTPRINT(FBT, BT_TRACE,
-                       ("[BTCoex], turn %s PS TDMA, type =%d\n",
-                       (bTurnOn ? "ON" : "OFF"), type));
-               pBtdm8723->bCurPsTdmaOn = bTurnOn;
-               pBtdm8723->curPsTdma = type;
-       }
-
-       if ((pBtdm8723->bPrePsTdmaOn == pBtdm8723->bCurPsTdmaOn) &&
-           (pBtdm8723->prePsTdma == pBtdm8723->curPsTdma))
-               return;
-
-       if (bTurnOn) {
-               switch (type) {
-               case 1:
-               default:
-                       btdm_2AntSetFw3a(padapter, 0xe3, 0x1a, 0x1a, 0xa1, 0x98);
-                       break;
-               case 2:
-                       btdm_2AntSetFw3a(padapter, 0xe3, 0x12, 0x12, 0xa1, 0x98);
-                       break;
-               case 3:
-                       btdm_2AntSetFw3a(padapter, 0xe3, 0xa, 0xa, 0xa1, 0x98);
-                       break;
-               case 4:
-                       btdm_2AntSetFw3a(padapter, 0xa3, 0x5, 0x5, 0xa1, 0x80);
-                       break;
-               case 5:
-                       btdm_2AntSetFw3a(padapter, 0xe3, 0x1a, 0x1a, 0x20, 0x98);
-                       break;
-               case 6:
-                       btdm_2AntSetFw3a(padapter, 0xe3, 0x12, 0x12, 0x20, 0x98);
-                       break;
-               case 7:
-                       btdm_2AntSetFw3a(padapter, 0xe3, 0xa, 0xa, 0x20, 0x98);
-                       break;
-               case 8:
-                       btdm_2AntSetFw3a(padapter, 0xa3, 0x5, 0x5, 0x20, 0x80);
-                       break;
-               case 9:
-                       btdm_2AntSetFw3a(padapter, 0xe3, 0x1a, 0x1a, 0xa1, 0x98);
-                       break;
-               case 10:
-                       btdm_2AntSetFw3a(padapter, 0xe3, 0x12, 0x12, 0xa1, 0x98);
-                       break;
-               case 11:
-                       btdm_2AntSetFw3a(padapter, 0xe3, 0xa, 0xa, 0xa1, 0x98);
-                       break;
-               case 12:
-                       btdm_2AntSetFw3a(padapter, 0xe3, 0x5, 0x5, 0xa1, 0x98);
-                       break;
-               case 13:
-                       btdm_2AntSetFw3a(padapter, 0xe3, 0x1a, 0x1a, 0x20, 0x98);
-                       break;
-               case 14:
-                       btdm_2AntSetFw3a(padapter, 0xe3, 0x12, 0x12, 0x20, 0x98);
-                       break;
-               case 15:
-                       btdm_2AntSetFw3a(padapter, 0xe3, 0xa, 0xa, 0x20, 0x98);
-                       break;
-               case 16:
-                       btdm_2AntSetFw3a(padapter, 0xe3, 0x5, 0x5, 0x20, 0x98);
-                       break;
-               case 17:
-                       btdm_2AntSetFw3a(padapter, 0xa3, 0x2f, 0x2f, 0x20, 0x80);
-                       break;
-               case 18:
-                       btdm_2AntSetFw3a(padapter, 0xe3, 0x5, 0x5, 0xa1, 0x98);
-                       break;
-               case 19:
-                       btdm_2AntSetFw3a(padapter, 0xe3, 0x25, 0x25, 0xa1, 0x98);
-                       break;
-               case 20:
-                       btdm_2AntSetFw3a(padapter, 0xe3, 0x25, 0x25, 0x20, 0x98);
-                       break;
-               }
-       } else {
-               /*  disable PS tdma */
-               switch (type) {
-               case 0:
-                       btdm_2AntSetFw3a(padapter, 0x0, 0x0, 0x0, 0x8, 0x0);
-                       break;
-               case 1:
-                       btdm_2AntSetFw3a(padapter, 0x0, 0x0, 0x0, 0x0, 0x0);
-                       break;
-               default:
-                       btdm_2AntSetFw3a(padapter, 0x0, 0x0, 0x0, 0x8, 0x0);
-                       break;
-               }
-       }
-
-       /*  update pre state */
-       pBtdm8723->bPrePsTdmaOn =  pBtdm8723->bCurPsTdmaOn;
-       pBtdm8723->prePsTdma = pBtdm8723->curPsTdma;
-}
-
-static void btdm_2AntBtInquiryPage(struct rtw_adapter *padapter)
-{
-       btdm_2AntCoexTable(padapter, 0x55555555, 0xffff, 0x3);
-       btdm_2AntIgnoreWlanAct(padapter, false);
-       btdm_2AntPsTdma(padapter, true, 8);
-}
-
-static u8 btdm_HoldForBtInqPage(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       u32 curTime = jiffies;
-
-       if (pHalData->bt_coexist.halCoex8723.bC2hBtInquiryPage) {
-               /*  bt inquiry or page is started. */
-               if (pHalData->bt_coexist.halCoex8723.btInqPageStartTime == 0) {
-                       pHalData->bt_coexist.halCoex8723.btInqPageStartTime = curTime;
-                       RTPRINT(FBT, BT_TRACE, ("[BTCoex], BT Inquiry/page is started at time : 0x%lx \n",
-                       pHalData->bt_coexist.halCoex8723.btInqPageStartTime));
-               }
-       }
-       RTPRINT(FBT, BT_TRACE, ("[BTCoex], BT Inquiry/page started time : 0x%lx, curTime : 0x%x \n",
-               pHalData->bt_coexist.halCoex8723.btInqPageStartTime, curTime));
-
-       if (pHalData->bt_coexist.halCoex8723.btInqPageStartTime) {
-               if (((curTime - pHalData->bt_coexist.halCoex8723.btInqPageStartTime)/1000000) >= 10) {
-                       RTPRINT(FBT, BT_TRACE, ("[BTCoex], BT Inquiry/page >= 10sec!!!"));
-                       pHalData->bt_coexist.halCoex8723.btInqPageStartTime = 0;
-               }
-       }
-
-       if (pHalData->bt_coexist.halCoex8723.btInqPageStartTime) {
-               btdm_2AntCoexTable(padapter, 0x55555555, 0xffff, 0x3);
-               btdm_2AntIgnoreWlanAct(padapter, false);
-               btdm_2AntPsTdma(padapter, true, 8);
-               return true;
-       } else {
-               return false;
-       }
-}
-
-static u8 btdm_Is2Ant8723ACommonAction(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       struct btdm_8723a_2ant *pBtdm8723 = &pHalData->bt_coexist.halCoex8723.btdm2Ant;
-       u8 bCommon = false;
-
-       RTPRINT(FBT, BT_TRACE, ("%s :BTDM_IsWifiConnectionExist =%x check_fwstate =%x pmlmepriv->fw_state = 0x%x\n", __func__, BTDM_IsWifiConnectionExist(padapter), check_fwstate(&padapter->mlmepriv, (_FW_UNDER_SURVEY|_FW_UNDER_LINKING)), padapter->mlmepriv.fw_state));
-
-       if ((!BTDM_IsWifiConnectionExist(padapter)) &&
-           (!check_fwstate(&padapter->mlmepriv, (_FW_UNDER_SURVEY|_FW_UNDER_LINKING))) &&
-           (BT_2ANT_BT_STATUS_IDLE == pBtdm8723->btStatus)) {
-               RTPRINT(FBT, BT_TRACE, ("Wifi idle + Bt idle!!\n"));
-
-               btdm_2AntLowPenaltyRa(padapter, false);
-               btdm_2AntRfShrink(padapter, false);
-               btdm_2AntCoexTable(padapter, 0x55555555, 0xffff, 0x3);
-
-               btdm_2AntIgnoreWlanAct(padapter, false);
-               btdm_2AntPsTdma(padapter, false, 0);
-               btdm_2AntFwDacSwingLvl(padapter, 0x20);
-               btdm_2AntDecBtPwr(padapter, false);
-
-               btdm_2AntAgcTable(padapter, false);
-               btdm_2AntAdcBackOff(padapter, false);
-               btdm_2AntDacSwing(padapter, false, 0xc0);
-
-               bCommon = true;
-       } else if (((BTDM_IsWifiConnectionExist(padapter)) ||
-                  (check_fwstate(&padapter->mlmepriv, (_FW_UNDER_SURVEY|_FW_UNDER_LINKING)))) &&
-                  (BT_2ANT_BT_STATUS_IDLE == pBtdm8723->btStatus)) {
-               RTPRINT(FBT, BT_TRACE, ("Wifi non-idle + BT idle!!\n"));
-
-               btdm_2AntLowPenaltyRa(padapter, true);
-               btdm_2AntRfShrink(padapter, false);
-               btdm_2AntCoexTable(padapter, 0x55555555, 0xffff, 0x3);
-
-               btdm_2AntIgnoreWlanAct(padapter, false);
-               btdm_2AntPsTdma(padapter, false, 0);
-               btdm_2AntFwDacSwingLvl(padapter, 0x20);
-               btdm_2AntDecBtPwr(padapter, true);
-
-               btdm_2AntAgcTable(padapter, false);
-               btdm_2AntAdcBackOff(padapter, false);
-               btdm_2AntDacSwing(padapter, false, 0xc0);
-
-               bCommon = true;
-       } else if ((!BTDM_IsWifiConnectionExist(padapter)) &&
-                  (!check_fwstate(&padapter->mlmepriv, (_FW_UNDER_SURVEY|_FW_UNDER_LINKING))) &&
-                  (BT_2ANT_BT_STATUS_CONNECTED_IDLE == pBtdm8723->btStatus)) {
-               RTPRINT(FBT, BT_TRACE, ("Wifi idle + Bt connected idle!!\n"));
-
-               btdm_2AntLowPenaltyRa(padapter, true);
-               btdm_2AntRfShrink(padapter, true);
-               btdm_2AntCoexTable(padapter, 0x55555555, 0xffff, 0x3);
-
-               btdm_2AntIgnoreWlanAct(padapter, false);
-               btdm_2AntPsTdma(padapter, false, 0);
-               btdm_2AntFwDacSwingLvl(padapter, 0x20);
-               btdm_2AntDecBtPwr(padapter, false);
-
-               btdm_2AntAgcTable(padapter, false);
-               btdm_2AntAdcBackOff(padapter, false);
-               btdm_2AntDacSwing(padapter, false, 0xc0);
-
-               bCommon = true;
-       } else if (((BTDM_IsWifiConnectionExist(padapter)) ||
-                  (check_fwstate(&padapter->mlmepriv, (_FW_UNDER_SURVEY|_FW_UNDER_LINKING)))) &&
-                  (BT_2ANT_BT_STATUS_CONNECTED_IDLE == pBtdm8723->btStatus)) {
-               RTPRINT(FBT, BT_TRACE, ("Wifi non-idle + Bt connected idle!!\n"));
-
-               btdm_2AntLowPenaltyRa(padapter, true);
-               btdm_2AntRfShrink(padapter, true);
-               btdm_2AntCoexTable(padapter, 0x55555555, 0xffff, 0x3);
-
-               btdm_2AntIgnoreWlanAct(padapter, false);
-               btdm_2AntPsTdma(padapter, false, 0);
-               btdm_2AntFwDacSwingLvl(padapter, 0x20);
-               btdm_2AntDecBtPwr(padapter, true);
-
-               btdm_2AntAgcTable(padapter, false);
-               btdm_2AntAdcBackOff(padapter, false);
-               btdm_2AntDacSwing(padapter, false, 0xc0);
-
-               bCommon = true;
-       } else if ((!BTDM_IsWifiConnectionExist(padapter)) &&
-                  (!check_fwstate(&padapter->mlmepriv, (_FW_UNDER_SURVEY|_FW_UNDER_LINKING))) &&
-                  (BT_2ANT_BT_STATUS_NON_IDLE == pBtdm8723->btStatus)) {
-               RTPRINT(FBT, BT_TRACE, ("Wifi idle + BT non-idle!!\n"));
-
-               btdm_2AntLowPenaltyRa(padapter, true);
-               btdm_2AntRfShrink(padapter, true);
-               btdm_2AntCoexTable(padapter, 0x55555555, 0xffff, 0x3);
-
-               btdm_2AntIgnoreWlanAct(padapter, false);
-               btdm_2AntPsTdma(padapter, false, 0);
-               btdm_2AntFwDacSwingLvl(padapter, 0x20);
-               btdm_2AntDecBtPwr(padapter, false);
-
-               btdm_2AntAgcTable(padapter, false);
-               btdm_2AntAdcBackOff(padapter, false);
-               btdm_2AntDacSwing(padapter, false, 0xc0);
-
-               bCommon = true;
-       } else {
-               RTPRINT(FBT, BT_TRACE, ("Wifi non-idle + BT non-idle!!\n"));
-               btdm_2AntLowPenaltyRa(padapter, true);
-               btdm_2AntRfShrink(padapter, true);
-               btdm_2AntCoexTable(padapter, 0x55555555, 0xffff, 0x3);
-               btdm_2AntIgnoreWlanAct(padapter, false);
-               btdm_2AntFwDacSwingLvl(padapter, 0x20);
-
-               bCommon = false;
-       }
-       return bCommon;
-}
-
-static void
-btdm_2AntTdmaDurationAdjust(struct rtw_adapter *padapter, u8 bScoHid,
-                           u8 bTxPause, u8 maxInterval)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       struct btdm_8723a_2ant *pBtdm8723 = &pHalData->bt_coexist.halCoex8723.btdm2Ant;
-       static s32              up, dn, m, n, WaitCount;
-       s32                     result;   /* 0: no change, +1: increase WiFi duration, -1: decrease WiFi duration */
-       u8 retryCount = 0;
-
-       RTPRINT(FBT, BT_TRACE, ("[BTCoex], TdmaDurationAdjust()\n"));
-
-       if (pBtdm8723->bResetTdmaAdjust) {
-               pBtdm8723->bResetTdmaAdjust = false;
-               RTPRINT(FBT, BT_TRACE, ("[BTCoex], first run TdmaDurationAdjust()!!\n"));
-               if (bScoHid) {
-                       if (bTxPause) {
-                               btdm_2AntPsTdma(padapter, true, 15);
-                               pBtdm8723->psTdmaDuAdjType = 15;
-                       } else {
-                               btdm_2AntPsTdma(padapter, true, 11);
-                               pBtdm8723->psTdmaDuAdjType = 11;
-                       }
-               } else {
-                       if (bTxPause) {
-                               btdm_2AntPsTdma(padapter, true, 7);
-                               pBtdm8723->psTdmaDuAdjType = 7;
-                       } else {
-                               btdm_2AntPsTdma(padapter, true, 3);
-                               pBtdm8723->psTdmaDuAdjType = 3;
-                       }
-               }
-               up = 0;
-               dn = 0;
-               m = 1;
-               n = 3;
-               result = 0;
-               WaitCount = 0;
-       } else {
-               /* accquire the BT TRx retry count from BT_Info byte2 */
-               retryCount = pHalData->bt_coexist.halCoex8723.btRetryCnt;
-               RTPRINT(FBT, BT_TRACE, ("[BTCoex], retryCount = %d\n", retryCount));
-               result = 0;
-               WaitCount++;
-
-               if (retryCount == 0) {  /*  no retry in the last 2-second duration */
-                       up++;
-                       dn--;
-
-                       if (dn <= 0)
-                               dn = 0;
-
-                       if (up >= n) {  /*  if ³sÄò n ­Ó2¬í retry count¬°0, «h½Õ¼eWiFi duration */
-                               WaitCount = 0;
-                               n = 3;
-                               up = 0;
-                               dn = 0;
-                               result = 1;
-                               RTPRINT(FBT, BT_TRACE, ("[BTCoex], Increase wifi duration!!\n"));
-                       }
-               } else if (retryCount <= 3) {   /*  <= 3 retry in the last 2-second duration */
-                       up--;
-                       dn++;
-
-                       if (up <= 0)
-                               up = 0;
-
-                       if (dn == 2) {  /*  if ³sÄò 2 ­Ó2¬í retry count< 3, «h½Õ¯¶WiFi duration */
-                               if (WaitCount <= 2)
-                                       m++; /*  ÁקK¤@ª½¦b¨â­Ólevel¤¤¨Ó¦^ */
-                               else
-                                       m = 1;
-
-                               if (m >= 20) /* m ³Ì¤j­È = 20 ' ³Ì¤j120¬í recheck¬O§_½Õ¾ã WiFi duration. */
-                                       m = 20;
-
-                               n = 3*m;
-                               up = 0;
-                               dn = 0;
-                               WaitCount = 0;
-                               result = -1;
-                               RTPRINT(FBT, BT_TRACE, ("[BTCoex], Decrease wifi duration for retryCounter<3!!\n"));
-                       }
-               } else {  /* retry count > 3, ¥u­n1¦¸ retry count > 3, «h½Õ¯¶WiFi duration */
-                       if (WaitCount == 1)
-                               m++; /*  ÁקK¤@ª½¦b¨â­Ólevel¤¤¨Ó¦^ */
-                       else
-                               m = 1;
-
-                       if (m >= 20) /* m ³Ì¤j­È = 20 ' ³Ì¤j120¬í recheck¬O§_½Õ¾ã WiFi duration. */
-                               m = 20;
-                       n = 3*m;
-                       up = 0;
-                       dn = 0;
-                       WaitCount = 0;
-                       result = -1;
-                       RTPRINT(FBT, BT_TRACE, ("[BTCoex], Decrease wifi duration for retryCounter>3!!\n"));
-               }
-
-               RTPRINT(FBT, BT_TRACE, ("[BTCoex], max Interval = %d\n", maxInterval));
-               if (maxInterval == 1) {
-                       if (bTxPause) {
-                               RTPRINT(FBT, BT_TRACE, ("[BTCoex], TxPause = 1\n"));
-                               if (pBtdm8723->curPsTdma == 1) {
-                                       btdm_2AntPsTdma(padapter, true, 5);
-                                       pBtdm8723->psTdmaDuAdjType = 5;
-                               } else if (pBtdm8723->curPsTdma == 2) {
-                                       btdm_2AntPsTdma(padapter, true, 6);
-                                       pBtdm8723->psTdmaDuAdjType = 6;
-                               } else if (pBtdm8723->curPsTdma == 3) {
-                                       btdm_2AntPsTdma(padapter, true, 7);
-                                       pBtdm8723->psTdmaDuAdjType = 7;
-                               } else if (pBtdm8723->curPsTdma == 4) {
-                                       btdm_2AntPsTdma(padapter, true, 8);
-                                       pBtdm8723->psTdmaDuAdjType = 8;
-                               }
-                               if (pBtdm8723->curPsTdma == 9) {
-                                       btdm_2AntPsTdma(padapter, true, 13);
-                                       pBtdm8723->psTdmaDuAdjType = 13;
-                               } else if (pBtdm8723->curPsTdma == 10) {
-                                       btdm_2AntPsTdma(padapter, true, 14);
-                                       pBtdm8723->psTdmaDuAdjType = 14;
-                               } else if (pBtdm8723->curPsTdma == 11) {
-                                       btdm_2AntPsTdma(padapter, true, 15);
-                                       pBtdm8723->psTdmaDuAdjType = 15;
-                               } else if (pBtdm8723->curPsTdma == 12) {
-                                       btdm_2AntPsTdma(padapter, true, 16);
-                                       pBtdm8723->psTdmaDuAdjType = 16;
-                               }
-
-                               if (result == -1) {
-                                       if (pBtdm8723->curPsTdma == 5) {
-                                               btdm_2AntPsTdma(padapter, true, 6);
-                                               pBtdm8723->psTdmaDuAdjType = 6;
-                                       } else if (pBtdm8723->curPsTdma == 6) {
-                                               btdm_2AntPsTdma(padapter, true, 7);
-                                               pBtdm8723->psTdmaDuAdjType = 7;
-                                       } else if (pBtdm8723->curPsTdma == 7) {
-                                               btdm_2AntPsTdma(padapter, true, 8);
-                                               pBtdm8723->psTdmaDuAdjType = 8;
-                                       } else if (pBtdm8723->curPsTdma == 13) {
-                                               btdm_2AntPsTdma(padapter, true, 14);
-                                               pBtdm8723->psTdmaDuAdjType = 14;
-                                       } else if (pBtdm8723->curPsTdma == 14) {
-                                               btdm_2AntPsTdma(padapter, true, 15);
-                                               pBtdm8723->psTdmaDuAdjType = 15;
-                                       } else if (pBtdm8723->curPsTdma == 15) {
-                                               btdm_2AntPsTdma(padapter, true, 16);
-                                               pBtdm8723->psTdmaDuAdjType = 16;
-                                       }
-                               } else if (result == 1) {
-                                       if (pBtdm8723->curPsTdma == 8) {
-                                               btdm_2AntPsTdma(padapter, true, 7);
-                                               pBtdm8723->psTdmaDuAdjType = 7;
-                                       } else if (pBtdm8723->curPsTdma == 7) {
-                                               btdm_2AntPsTdma(padapter, true, 6);
-                                               pBtdm8723->psTdmaDuAdjType = 6;
-                                       } else if (pBtdm8723->curPsTdma == 6) {
-                                               btdm_2AntPsTdma(padapter, true, 5);
-                                               pBtdm8723->psTdmaDuAdjType = 5;
-                                       } else if (pBtdm8723->curPsTdma == 16) {
-                                               btdm_2AntPsTdma(padapter, true, 15);
-                                               pBtdm8723->psTdmaDuAdjType = 15;
-                                       } else if (pBtdm8723->curPsTdma == 15) {
-                                               btdm_2AntPsTdma(padapter, true, 14);
-                                               pBtdm8723->psTdmaDuAdjType = 14;
-                                       } else if (pBtdm8723->curPsTdma == 14) {
-                                               btdm_2AntPsTdma(padapter, true, 13);
-                                               pBtdm8723->psTdmaDuAdjType = 13;
-                                       }
-                               }
-                       } else {
-                               RTPRINT(FBT, BT_TRACE, ("[BTCoex], TxPause = 0\n"));
-                               if (pBtdm8723->curPsTdma == 5) {
-                                       btdm_2AntPsTdma(padapter, true, 1);
-                                       pBtdm8723->psTdmaDuAdjType = 1;
-                               } else if (pBtdm8723->curPsTdma == 6) {
-                                       btdm_2AntPsTdma(padapter, true, 2);
-                                       pBtdm8723->psTdmaDuAdjType = 2;
-                               } else if (pBtdm8723->curPsTdma == 7) {
-                                       btdm_2AntPsTdma(padapter, true, 3);
-                                       pBtdm8723->psTdmaDuAdjType = 3;
-                               } else if (pBtdm8723->curPsTdma == 8) {
-                                       btdm_2AntPsTdma(padapter, true, 4);
-                                       pBtdm8723->psTdmaDuAdjType = 4;
-                               }
-                               if (pBtdm8723->curPsTdma == 13) {
-                                       btdm_2AntPsTdma(padapter, true, 9);
-                                       pBtdm8723->psTdmaDuAdjType = 9;
-                               } else if (pBtdm8723->curPsTdma == 14) {
-                                       btdm_2AntPsTdma(padapter, true, 10);
-                                       pBtdm8723->psTdmaDuAdjType = 10;
-                               } else if (pBtdm8723->curPsTdma == 15) {
-                                       btdm_2AntPsTdma(padapter, true, 11);
-                                       pBtdm8723->psTdmaDuAdjType = 11;
-                               } else if (pBtdm8723->curPsTdma == 16) {
-                                       btdm_2AntPsTdma(padapter, true, 12);
-                                       pBtdm8723->psTdmaDuAdjType = 12;
-                               }
-
-                               if (result == -1) {
-                                       if (pBtdm8723->curPsTdma == 1) {
-                                               btdm_2AntPsTdma(padapter, true, 2);
-                                               pBtdm8723->psTdmaDuAdjType = 2;
-                                       } else if (pBtdm8723->curPsTdma == 2) {
-                                               btdm_2AntPsTdma(padapter, true, 3);
-                                               pBtdm8723->psTdmaDuAdjType = 3;
-                                       } else if (pBtdm8723->curPsTdma == 3) {
-                                               btdm_2AntPsTdma(padapter, true, 4);
-                                               pBtdm8723->psTdmaDuAdjType = 4;
-                                       } else if (pBtdm8723->curPsTdma == 9) {
-                                               btdm_2AntPsTdma(padapter, true, 10);
-                                               pBtdm8723->psTdmaDuAdjType = 10;
-                                       } else if (pBtdm8723->curPsTdma == 10) {
-                                               btdm_2AntPsTdma(padapter, true, 11);
-                                               pBtdm8723->psTdmaDuAdjType = 11;
-                                       } else if (pBtdm8723->curPsTdma == 11) {
-                                               btdm_2AntPsTdma(padapter, true, 12);
-                                               pBtdm8723->psTdmaDuAdjType = 12;
-                                       }
-                               } else if (result == 1) {
-                                       if (pBtdm8723->curPsTdma == 4) {
-                                               btdm_2AntPsTdma(padapter, true, 3);
-                                               pBtdm8723->psTdmaDuAdjType = 3;
-                                       } else if (pBtdm8723->curPsTdma == 3) {
-                                               btdm_2AntPsTdma(padapter, true, 2);
-                                               pBtdm8723->psTdmaDuAdjType = 2;
-                                       } else if (pBtdm8723->curPsTdma == 2) {
-                                               btdm_2AntPsTdma(padapter, true, 1);
-                                               pBtdm8723->psTdmaDuAdjType = 1;
-                                       } else if (pBtdm8723->curPsTdma == 12) {
-                                               btdm_2AntPsTdma(padapter, true, 11);
-                                               pBtdm8723->psTdmaDuAdjType = 11;
-                                       } else if (pBtdm8723->curPsTdma == 11) {
-                                               btdm_2AntPsTdma(padapter, true, 10);
-                                               pBtdm8723->psTdmaDuAdjType = 10;
-                                       } else if (pBtdm8723->curPsTdma == 10) {
-                                               btdm_2AntPsTdma(padapter, true, 9);
-                                               pBtdm8723->psTdmaDuAdjType = 9;
-                                       }
-                               }
-                       }
-               } else if (maxInterval == 2) {
-                       if (bTxPause) {
-                               RTPRINT(FBT, BT_TRACE, ("[BTCoex], TxPause = 1\n"));
-                               if (pBtdm8723->curPsTdma == 1) {
-                                       btdm_2AntPsTdma(padapter, true, 6);
-                                       pBtdm8723->psTdmaDuAdjType = 6;
-                               } else if (pBtdm8723->curPsTdma == 2) {
-                                       btdm_2AntPsTdma(padapter, true, 6);
-                                       pBtdm8723->psTdmaDuAdjType = 6;
-                               } else if (pBtdm8723->curPsTdma == 3) {
-                                       btdm_2AntPsTdma(padapter, true, 7);
-                                       pBtdm8723->psTdmaDuAdjType = 7;
-                               } else if (pBtdm8723->curPsTdma == 4) {
-                                       btdm_2AntPsTdma(padapter, true, 8);
-                                       pBtdm8723->psTdmaDuAdjType = 8;
-                               }
-                               if (pBtdm8723->curPsTdma == 9) {
-                                       btdm_2AntPsTdma(padapter, true, 14);
-                                       pBtdm8723->psTdmaDuAdjType = 14;
-                               } else if (pBtdm8723->curPsTdma == 10) {
-                                       btdm_2AntPsTdma(padapter, true, 14);
-                                       pBtdm8723->psTdmaDuAdjType = 14;
-                               } else if (pBtdm8723->curPsTdma == 11) {
-                                       btdm_2AntPsTdma(padapter, true, 15);
-                                       pBtdm8723->psTdmaDuAdjType = 15;
-                               } else if (pBtdm8723->curPsTdma == 12) {
-                                       btdm_2AntPsTdma(padapter, true, 16);
-                                       pBtdm8723->psTdmaDuAdjType = 16;
-                               }
-                               if (result == -1) {
-                                       if (pBtdm8723->curPsTdma == 5) {
-                                               btdm_2AntPsTdma(padapter, true, 6);
-                                               pBtdm8723->psTdmaDuAdjType = 6;
-                                       } else if (pBtdm8723->curPsTdma == 6) {
-                                               btdm_2AntPsTdma(padapter, true, 7);
-                                               pBtdm8723->psTdmaDuAdjType = 7;
-                                       } else if (pBtdm8723->curPsTdma == 7) {
-                                               btdm_2AntPsTdma(padapter, true, 8);
-                                               pBtdm8723->psTdmaDuAdjType = 8;
-                                       } else if (pBtdm8723->curPsTdma == 13) {
-                                               btdm_2AntPsTdma(padapter, true, 14);
-                                               pBtdm8723->psTdmaDuAdjType = 14;
-                                       } else if (pBtdm8723->curPsTdma == 14) {
-                                               btdm_2AntPsTdma(padapter, true, 15);
-                                               pBtdm8723->psTdmaDuAdjType = 15;
-                                       } else if (pBtdm8723->curPsTdma == 15) {
-                                               btdm_2AntPsTdma(padapter, true, 16);
-                                               pBtdm8723->psTdmaDuAdjType = 16;
-                                       }
-                               } else if (result == 1) {
-                                       if (pBtdm8723->curPsTdma == 8) {
-                                               btdm_2AntPsTdma(padapter, true, 7);
-                                               pBtdm8723->psTdmaDuAdjType = 7;
-                                       } else if (pBtdm8723->curPsTdma == 7) {
-                                               btdm_2AntPsTdma(padapter, true, 6);
-                                               pBtdm8723->psTdmaDuAdjType = 6;
-                                       } else if (pBtdm8723->curPsTdma == 6) {
-                                               btdm_2AntPsTdma(padapter, true, 6);
-                                               pBtdm8723->psTdmaDuAdjType = 6;
-                                       } else if (pBtdm8723->curPsTdma == 16) {
-                                               btdm_2AntPsTdma(padapter, true, 15);
-                                               pBtdm8723->psTdmaDuAdjType = 15;
-                                       } else if (pBtdm8723->curPsTdma == 15) {
-                                               btdm_2AntPsTdma(padapter, true, 14);
-                                               pBtdm8723->psTdmaDuAdjType = 14;
-                                       } else if (pBtdm8723->curPsTdma == 14) {
-                                               btdm_2AntPsTdma(padapter, true, 14);
-                                               pBtdm8723->psTdmaDuAdjType = 14;
-                                       }
-                               }
-                       } else {
-                               RTPRINT(FBT, BT_TRACE, ("[BTCoex], TxPause = 0\n"));
-                               if (pBtdm8723->curPsTdma == 5) {
-                                       btdm_2AntPsTdma(padapter, true, 2);
-                                       pBtdm8723->psTdmaDuAdjType = 2;
-                               } else if (pBtdm8723->curPsTdma == 6) {
-                                       btdm_2AntPsTdma(padapter, true, 2);
-                                       pBtdm8723->psTdmaDuAdjType = 2;
-                               } else if (pBtdm8723->curPsTdma == 7) {
-                                       btdm_2AntPsTdma(padapter, true, 3);
-                                       pBtdm8723->psTdmaDuAdjType = 3;
-                               } else if (pBtdm8723->curPsTdma == 8) {
-                                       btdm_2AntPsTdma(padapter, true, 4);
-                                       pBtdm8723->psTdmaDuAdjType = 4;
-                               }
-                               if (pBtdm8723->curPsTdma == 13) {
-                                       btdm_2AntPsTdma(padapter, true, 10);
-                                       pBtdm8723->psTdmaDuAdjType = 10;
-                               } else if (pBtdm8723->curPsTdma == 14) {
-                                       btdm_2AntPsTdma(padapter, true, 10);
-                                       pBtdm8723->psTdmaDuAdjType = 10;
-                               } else if (pBtdm8723->curPsTdma == 15) {
-                                       btdm_2AntPsTdma(padapter, true, 11);
-                                       pBtdm8723->psTdmaDuAdjType = 11;
-                               } else if (pBtdm8723->curPsTdma == 16) {
-                                       btdm_2AntPsTdma(padapter, true, 12);
-                                       pBtdm8723->psTdmaDuAdjType = 12;
-                               }
-                               if (result == -1) {
-                                       if (pBtdm8723->curPsTdma == 1) {
-                                               btdm_2AntPsTdma(padapter, true, 2);
-                                               pBtdm8723->psTdmaDuAdjType = 2;
-                                       } else if (pBtdm8723->curPsTdma == 2) {
-                                               btdm_2AntPsTdma(padapter, true, 3);
-                                               pBtdm8723->psTdmaDuAdjType = 3;
-                                       } else if (pBtdm8723->curPsTdma == 3) {
-                                               btdm_2AntPsTdma(padapter, true, 4);
-                                               pBtdm8723->psTdmaDuAdjType = 4;
-                                       } else if (pBtdm8723->curPsTdma == 9) {
-                                               btdm_2AntPsTdma(padapter, true, 10);
-                                               pBtdm8723->psTdmaDuAdjType = 10;
-                                       } else if (pBtdm8723->curPsTdma == 10) {
-                                               btdm_2AntPsTdma(padapter, true, 11);
-                                               pBtdm8723->psTdmaDuAdjType = 11;
-                                       } else if (pBtdm8723->curPsTdma == 11) {
-                                               btdm_2AntPsTdma(padapter, true, 12);
-                                               pBtdm8723->psTdmaDuAdjType = 12;
-                                       }
-                               } else if (result == 1) {
-                                       if (pBtdm8723->curPsTdma == 4) {
-                                               btdm_2AntPsTdma(padapter, true, 3);
-                                               pBtdm8723->psTdmaDuAdjType = 3;
-                                       } else if (pBtdm8723->curPsTdma == 3) {
-                                               btdm_2AntPsTdma(padapter, true, 2);
-                                               pBtdm8723->psTdmaDuAdjType = 2;
-                                       } else if (pBtdm8723->curPsTdma == 2) {
-                                               btdm_2AntPsTdma(padapter, true, 2);
-                                               pBtdm8723->psTdmaDuAdjType = 2;
-                                       } else if (pBtdm8723->curPsTdma == 12) {
-                                               btdm_2AntPsTdma(padapter, true, 11);
-                                               pBtdm8723->psTdmaDuAdjType = 11;
-                                       } else if (pBtdm8723->curPsTdma == 11) {
-                                               btdm_2AntPsTdma(padapter, true, 10);
-                                               pBtdm8723->psTdmaDuAdjType = 10;
-                                       } else if (pBtdm8723->curPsTdma == 10) {
-                                               btdm_2AntPsTdma(padapter, true, 10);
-                                               pBtdm8723->psTdmaDuAdjType = 10;
-                                       }
-                               }
-                       }
-               } else if (maxInterval == 3) {
-                       if (bTxPause) {
-                               RTPRINT(FBT, BT_TRACE, ("[BTCoex], TxPause = 1\n"));
-                               if (pBtdm8723->curPsTdma == 1) {
-                                       btdm_2AntPsTdma(padapter, true, 7);
-                                       pBtdm8723->psTdmaDuAdjType = 7;
-                               } else if (pBtdm8723->curPsTdma == 2) {
-                                       btdm_2AntPsTdma(padapter, true, 7);
-                                       pBtdm8723->psTdmaDuAdjType = 7;
-                               } else if (pBtdm8723->curPsTdma == 3) {
-                                       btdm_2AntPsTdma(padapter, true, 7);
-                                       pBtdm8723->psTdmaDuAdjType = 7;
-                               } else if (pBtdm8723->curPsTdma == 4) {
-                                       btdm_2AntPsTdma(padapter, true, 8);
-                                       pBtdm8723->psTdmaDuAdjType = 8;
-                               }
-                               if (pBtdm8723->curPsTdma == 9) {
-                                       btdm_2AntPsTdma(padapter, true, 15);
-                                       pBtdm8723->psTdmaDuAdjType = 15;
-                               } else if (pBtdm8723->curPsTdma == 10) {
-                                       btdm_2AntPsTdma(padapter, true, 15);
-                                       pBtdm8723->psTdmaDuAdjType = 15;
-                               } else if (pBtdm8723->curPsTdma == 11) {
-                                       btdm_2AntPsTdma(padapter, true, 15);
-                                       pBtdm8723->psTdmaDuAdjType = 15;
-                               } else if (pBtdm8723->curPsTdma == 12) {
-                                       btdm_2AntPsTdma(padapter, true, 16);
-                                       pBtdm8723->psTdmaDuAdjType = 16;
-                               }
-                               if (result == -1) {
-                                       if (pBtdm8723->curPsTdma == 5) {
-                                               btdm_2AntPsTdma(padapter, true, 7);
-                                               pBtdm8723->psTdmaDuAdjType = 7;
-                                       } else if (pBtdm8723->curPsTdma == 6) {
-                                               btdm_2AntPsTdma(padapter, true, 7);
-                                               pBtdm8723->psTdmaDuAdjType = 7;
-                                       } else if (pBtdm8723->curPsTdma == 7) {
-                                               btdm_2AntPsTdma(padapter, true, 8);
-                                               pBtdm8723->psTdmaDuAdjType = 8;
-                                       } else if (pBtdm8723->curPsTdma == 13) {
-                                               btdm_2AntPsTdma(padapter, true, 15);
-                                               pBtdm8723->psTdmaDuAdjType = 15;
-                                       } else if (pBtdm8723->curPsTdma == 14) {
-                                               btdm_2AntPsTdma(padapter, true, 15);
-                                               pBtdm8723->psTdmaDuAdjType = 15;
-                                       } else if (pBtdm8723->curPsTdma == 15) {
-                                               btdm_2AntPsTdma(padapter, true, 16);
-                                               pBtdm8723->psTdmaDuAdjType = 16;
-                                       }
-                               } else if (result == 1) {
-                                       if (pBtdm8723->curPsTdma == 8) {
-                                               btdm_2AntPsTdma(padapter, true, 7);
-                                               pBtdm8723->psTdmaDuAdjType = 7;
-                                       } else if (pBtdm8723->curPsTdma == 7) {
-                                               btdm_2AntPsTdma(padapter, true, 7);
-                                               pBtdm8723->psTdmaDuAdjType = 7;
-                                       } else if (pBtdm8723->curPsTdma == 6) {
-                                               btdm_2AntPsTdma(padapter, true, 7);
-                                               pBtdm8723->psTdmaDuAdjType = 7;
-                                       } else if (pBtdm8723->curPsTdma == 16) {
-                                               btdm_2AntPsTdma(padapter, true, 15);
-                                               pBtdm8723->psTdmaDuAdjType = 15;
-                                       } else if (pBtdm8723->curPsTdma == 15) {
-                                               btdm_2AntPsTdma(padapter, true, 15);
-                                               pBtdm8723->psTdmaDuAdjType = 15;
-                                       } else if (pBtdm8723->curPsTdma == 14) {
-                                               btdm_2AntPsTdma(padapter, true, 15);
-                                               pBtdm8723->psTdmaDuAdjType = 15;
-                                       }
-                               }
-                       } else {
-                               RTPRINT(FBT, BT_TRACE, ("[BTCoex], TxPause = 0\n"));
-                               if (pBtdm8723->curPsTdma == 5) {
-                                       btdm_2AntPsTdma(padapter, true, 3);
-                                       pBtdm8723->psTdmaDuAdjType = 3;
-                               } else if (pBtdm8723->curPsTdma == 6) {
-                                       btdm_2AntPsTdma(padapter, true, 3);
-                                       pBtdm8723->psTdmaDuAdjType = 3;
-                               } else if (pBtdm8723->curPsTdma == 7) {
-                                       btdm_2AntPsTdma(padapter, true, 3);
-                                       pBtdm8723->psTdmaDuAdjType = 3;
-                               } else if (pBtdm8723->curPsTdma == 8) {
-                                       btdm_2AntPsTdma(padapter, true, 4);
-                                       pBtdm8723->psTdmaDuAdjType = 4;
-                               }
-                               if (pBtdm8723->curPsTdma == 13) {
-                                       btdm_2AntPsTdma(padapter, true, 11);
-                                       pBtdm8723->psTdmaDuAdjType = 11;
-                               } else if (pBtdm8723->curPsTdma == 14) {
-                                       btdm_2AntPsTdma(padapter, true, 11);
-                                       pBtdm8723->psTdmaDuAdjType = 11;
-                               } else if (pBtdm8723->curPsTdma == 15) {
-                                       btdm_2AntPsTdma(padapter, true, 11);
-                                       pBtdm8723->psTdmaDuAdjType = 11;
-                               } else if (pBtdm8723->curPsTdma == 16) {
-                                       btdm_2AntPsTdma(padapter, true, 12);
-                                       pBtdm8723->psTdmaDuAdjType = 12;
-                               }
-                               if (result == -1) {
-                                       if (pBtdm8723->curPsTdma == 1) {
-                                               btdm_2AntPsTdma(padapter, true, 3);
-                                               pBtdm8723->psTdmaDuAdjType = 3;
-                                       } else if (pBtdm8723->curPsTdma == 2) {
-                                               btdm_2AntPsTdma(padapter, true, 3);
-                                               pBtdm8723->psTdmaDuAdjType = 3;
-                                       } else if (pBtdm8723->curPsTdma == 3) {
-                                               btdm_2AntPsTdma(padapter, true, 4);
-                                               pBtdm8723->psTdmaDuAdjType = 4;
-                                       } else if (pBtdm8723->curPsTdma == 9) {
-                                               btdm_2AntPsTdma(padapter, true, 11);
-                                               pBtdm8723->psTdmaDuAdjType = 11;
-                                       } else if (pBtdm8723->curPsTdma == 10) {
-                                               btdm_2AntPsTdma(padapter, true, 11);
-                                               pBtdm8723->psTdmaDuAdjType = 11;
-                                       } else if (pBtdm8723->curPsTdma == 11) {
-                                               btdm_2AntPsTdma(padapter, true, 12);
-                                               pBtdm8723->psTdmaDuAdjType = 12;
-                                       }
-                               } else if (result == 1) {
-                                       if (pBtdm8723->curPsTdma == 4) {
-                                               btdm_2AntPsTdma(padapter, true, 3);
-                                               pBtdm8723->psTdmaDuAdjType = 3;
-                                       } else if (pBtdm8723->curPsTdma == 3) {
-                                               btdm_2AntPsTdma(padapter, true, 3);
-                                               pBtdm8723->psTdmaDuAdjType = 3;
-                                       } else if (pBtdm8723->curPsTdma == 2) {
-                                               btdm_2AntPsTdma(padapter, true, 3);
-                                               pBtdm8723->psTdmaDuAdjType = 3;
-                                       } else if (pBtdm8723->curPsTdma == 12) {
-                                               btdm_2AntPsTdma(padapter, true, 11);
-                                               pBtdm8723->psTdmaDuAdjType = 11;
-                                       } else if (pBtdm8723->curPsTdma == 11) {
-                                               btdm_2AntPsTdma(padapter, true, 11);
-                                               pBtdm8723->psTdmaDuAdjType = 11;
-                                       } else if (pBtdm8723->curPsTdma == 10) {
-                                               btdm_2AntPsTdma(padapter, true, 11);
-                                               pBtdm8723->psTdmaDuAdjType = 11;
-                                       }
-                               }
-                       }
-               }
-       }
-       RTPRINT(FBT, BT_TRACE, ("[BTCoex], PsTdma type : recordPsTdma =%d\n", pBtdm8723->psTdmaDuAdjType));
-       /*  if current PsTdma not match with the recorded one (when scan, dhcp...), */
-       /*  then we have to adjust it back to the previous record one. */
-       if (pBtdm8723->curPsTdma != pBtdm8723->psTdmaDuAdjType) {
-               RTPRINT(FBT, BT_TRACE, ("[BTCoex], PsTdma type dismatch!!!, curPsTdma =%d, recordPsTdma =%d\n",
-                       pBtdm8723->curPsTdma, pBtdm8723->psTdmaDuAdjType));
-
-               if (!check_fwstate(&padapter->mlmepriv, _FW_UNDER_SURVEY|_FW_UNDER_LINKING))
-                       btdm_2AntPsTdma(padapter, true, pBtdm8723->psTdmaDuAdjType);
-               else
-                       RTPRINT(FBT, BT_TRACE, ("[BTCoex], roaming/link/scan is under progress, will adjust next time!!!\n"));
-       }
-}
-
-/*  default Action */
-/*  SCO only or SCO+PAN(HS) */
-static void btdm_2Ant8723ASCOAction(struct rtw_adapter *padapter)
-{
-       u8 btRssiState, btRssiState1;
-
-       if (btdm_NeedToDecBtPwr(padapter))
-               btdm_2AntDecBtPwr(padapter, true);
-       else
-               btdm_2AntDecBtPwr(padapter, false);
-
-       if (BTDM_IsHT40(padapter)) {
-               RTPRINT(FBT, BT_TRACE, ("HT40\n"));
-               btRssiState = BTDM_CheckCoexRSSIState(padapter, 2, 37, 0);
-               /*  fw mechanism */
-               if ((btRssiState == BT_RSSI_STATE_HIGH) ||
-                   (btRssiState == BT_RSSI_STATE_STAY_HIGH)) {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi-1 high \n"));
-                       PlatformEFIOWrite1Byte(padapter, 0x883, 0x40);
-                       btdm_2AntPsTdma(padapter, true, 11);
-               } else {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi-1 low \n"));
-                       btdm_2AntPsTdma(padapter, true, 15);
-               }
-
-               /*  sw mechanism */
-               btdm_2AntAgcTable(padapter, false);
-               btdm_2AntAdcBackOff(padapter, true);
-               btdm_2AntDacSwing(padapter, false, 0xc0);
-       } else {
-               RTPRINT(FBT, BT_TRACE, ("HT20 or Legacy\n"));
-               btRssiState = BTDM_CheckCoexRSSIState(padapter, 2, 37, 0);
-               btRssiState1 = BTDM_CheckCoexRSSIState1(padapter, 2, 27, 0);
-
-               /*  fw mechanism */
-               if ((btRssiState1 == BT_RSSI_STATE_HIGH) ||
-                   (btRssiState1 == BT_RSSI_STATE_STAY_HIGH)) {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi-1 high \n"));
-                       PlatformEFIOWrite1Byte(padapter, 0x883, 0x40);
-                       btdm_2AntPsTdma(padapter, true, 11);
-               } else {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi-1 low \n"));
-                       btdm_2AntPsTdma(padapter, true, 15);
-               }
-
-               /*  sw mechanism */
-               if ((btRssiState == BT_RSSI_STATE_HIGH) ||
-                   (btRssiState == BT_RSSI_STATE_STAY_HIGH)) {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi high \n"));
-                       btdm_2AntAgcTable(padapter, true);
-                       btdm_2AntAdcBackOff(padapter, true);
-                       btdm_2AntDacSwing(padapter, false, 0xc0);
-               } else {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi low \n"));
-                       btdm_2AntAgcTable(padapter, false);
-                       btdm_2AntAdcBackOff(padapter, false);
-                       btdm_2AntDacSwing(padapter, false, 0xc0);
-               }
-       }
-}
-
-static void btdm_2Ant8723AHIDAction(struct rtw_adapter *padapter)
-{
-       u8 btRssiState, btRssiState1;
-
-       if (btdm_NeedToDecBtPwr(padapter))
-               btdm_2AntDecBtPwr(padapter, true);
-       else
-               btdm_2AntDecBtPwr(padapter, false);
-
-       if (BTDM_IsHT40(padapter)) {
-               RTPRINT(FBT, BT_TRACE, ("HT40\n"));
-               btRssiState = BTDM_CheckCoexRSSIState(padapter, 2, 37, 0);
-                       /*  fw mechanism */
-               if ((btRssiState == BT_RSSI_STATE_HIGH) ||
-                   (btRssiState == BT_RSSI_STATE_STAY_HIGH)) {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi-1 high \n"));
-                       PlatformEFIOWrite1Byte(padapter, 0x883, 0x40);
-                       btdm_2AntPsTdma(padapter, true, 9);
-               } else {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi-1 low \n"));
-                       btdm_2AntPsTdma(padapter, true, 13);
-               }
-
-               /*  sw mechanism */
-               btdm_2AntAgcTable(padapter, false);
-               btdm_2AntAdcBackOff(padapter, false);
-               btdm_2AntDacSwing(padapter, false, 0xc0);
-       } else {
-               RTPRINT(FBT, BT_TRACE, ("HT20 or Legacy\n"));
-               btRssiState = BTDM_CheckCoexRSSIState(padapter, 2, 37, 0);
-               btRssiState1 = BTDM_CheckCoexRSSIState1(padapter, 2, 27, 0);
-
-               /*  fw mechanism */
-               if ((btRssiState1 == BT_RSSI_STATE_HIGH) ||
-                   (btRssiState1 == BT_RSSI_STATE_STAY_HIGH)) {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi-1 high \n"));
-                       PlatformEFIOWrite1Byte(padapter, 0x883, 0x40);
-                       btdm_2AntPsTdma(padapter, true, 9);
-               } else {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi-1 low \n"));
-                       btdm_2AntPsTdma(padapter, true, 13);
-               }
-
-               /*  sw mechanism */
-               if ((btRssiState == BT_RSSI_STATE_HIGH) ||
-                   (btRssiState == BT_RSSI_STATE_STAY_HIGH)) {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi high \n"));
-                       btdm_2AntAgcTable(padapter, true);
-                       btdm_2AntAdcBackOff(padapter, true);
-                       btdm_2AntDacSwing(padapter, false, 0xc0);
-               } else {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi low \n"));
-                       btdm_2AntAgcTable(padapter, false);
-                       btdm_2AntAdcBackOff(padapter, false);
-                       btdm_2AntDacSwing(padapter, false, 0xc0);
-               }
-       }
-}
-
-/* A2DP only / PAN(EDR) only/ A2DP+PAN(HS) */
-static void btdm_2Ant8723AA2DPAction(struct rtw_adapter *padapter)
-{
-       u8 btRssiState, btRssiState1;
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       u8 btInfoExt = pHalData->bt_coexist.halCoex8723.btInfoExt;
-
-       if (btdm_NeedToDecBtPwr(padapter))
-               btdm_2AntDecBtPwr(padapter, true);
-       else
-               btdm_2AntDecBtPwr(padapter, false);
-
-       if (BTDM_IsHT40(padapter)) {
-               RTPRINT(FBT, BT_TRACE, ("HT40\n"));
-               btRssiState = BTDM_CheckCoexRSSIState(padapter, 2, 37, 0);
-
-               /*  fw mechanism */
-               if ((btRssiState == BT_RSSI_STATE_HIGH) ||
-                   (btRssiState == BT_RSSI_STATE_STAY_HIGH)) {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi high \n"));
-                       PlatformEFIOWrite1Byte(padapter, 0x883, 0x40);
-
-                       if (btInfoExt&BIT(0)) { /* a2dp rate, 1:basic /0:edr */
-                               RTPRINT(FBT, BT_TRACE, ("a2dp basic rate \n"));
-                               btdm_2AntTdmaDurationAdjust(padapter, false, false, 3);
-                       } else {
-                               RTPRINT(FBT, BT_TRACE, ("a2dp edr rate \n"));
-                               btdm_2AntTdmaDurationAdjust(padapter, false, false, 1);
-                       }
-               } else {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi low \n"));
-                       if (btInfoExt&BIT(0)) { /* a2dp rate, 1:basic /0:edr */
-                               RTPRINT(FBT, BT_TRACE, ("a2dp basic rate \n"));
-                               btdm_2AntTdmaDurationAdjust(padapter, false, true, 3);
-                       } else {
-                               RTPRINT(FBT, BT_TRACE, ("a2dp edr rate \n"));
-                       btdm_2AntTdmaDurationAdjust(padapter, false, true, 1);
-                       }
-               }
-
-               /*  sw mechanism */
-               btdm_2AntAgcTable(padapter, false);
-               btdm_2AntAdcBackOff(padapter, true);
-               btdm_2AntDacSwing(padapter, false, 0xc0);
-       } else {
-               RTPRINT(FBT, BT_TRACE, ("HT20 or Legacy\n"));
-               btRssiState = BTDM_CheckCoexRSSIState(padapter, 2, 37, 0);
-               btRssiState1 = BTDM_CheckCoexRSSIState1(padapter, 2, 27, 0);
-
-               /*  fw mechanism */
-               if ((btRssiState1 == BT_RSSI_STATE_HIGH) ||
-                   (btRssiState1 == BT_RSSI_STATE_STAY_HIGH)) {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi-1 high \n"));
-                       PlatformEFIOWrite1Byte(padapter, 0x883, 0x40);
-                       if (btInfoExt&BIT(0)) { /* a2dp rate, 1:basic /0:edr */
-                               RTPRINT(FBT, BT_TRACE, ("a2dp basic rate \n"));
-                               btdm_2AntTdmaDurationAdjust(padapter, false, false, 3);
-                       } else {
-                               RTPRINT(FBT, BT_TRACE, ("a2dp edr rate \n"));
-                               btdm_2AntTdmaDurationAdjust(padapter, false, false, 1);
-                       }
-               } else {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi-1 low \n"));
-                       if (btInfoExt&BIT(0)) { /* a2dp rate, 1:basic /0:edr */
-                               RTPRINT(FBT, BT_TRACE, ("a2dp basic rate \n"));
-                               btdm_2AntTdmaDurationAdjust(padapter, false, true, 3);
-                       } else {
-                               RTPRINT(FBT, BT_TRACE, ("a2dp edr rate \n"));
-                               btdm_2AntTdmaDurationAdjust(padapter, false, true, 1);
-                       }
-               }
-
-               /*  sw mechanism */
-               if ((btRssiState == BT_RSSI_STATE_HIGH) ||
-                   (btRssiState == BT_RSSI_STATE_STAY_HIGH)) {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi high \n"));
-                       btdm_2AntAgcTable(padapter, true);
-                       btdm_2AntAdcBackOff(padapter, true);
-                       btdm_2AntDacSwing(padapter, false, 0xc0);
-               } else {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi low \n"));
-                       btdm_2AntAgcTable(padapter, false);
-                       btdm_2AntAdcBackOff(padapter, false);
-                       btdm_2AntDacSwing(padapter, false, 0xc0);
-               }
-       }
-}
-
-static void btdm_2Ant8723APANEDRAction(struct rtw_adapter *padapter)
-{
-       u8 btRssiState, btRssiState1;
-
-       if (btdm_NeedToDecBtPwr(padapter))
-               btdm_2AntDecBtPwr(padapter, true);
-       else
-               btdm_2AntDecBtPwr(padapter, false);
-
-       if (BTDM_IsHT40(padapter)) {
-               RTPRINT(FBT, BT_TRACE, ("HT40\n"));
-               btRssiState = BTDM_CheckCoexRSSIState(padapter, 2, 37, 0);
-
-               /*  fw mechanism */
-               if ((btRssiState == BT_RSSI_STATE_HIGH) ||
-                   (btRssiState == BT_RSSI_STATE_STAY_HIGH)) {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi high \n"));
-                       PlatformEFIOWrite1Byte(padapter, 0x883, 0x40);
-                       btdm_2AntPsTdma(padapter, true, 2);
-               } else {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi low \n"));
-                       btdm_2AntPsTdma(padapter, true, 6);
-               }
-
-               /*  sw mechanism */
-               btdm_2AntAgcTable(padapter, false);
-               btdm_2AntAdcBackOff(padapter, true);
-               btdm_2AntDacSwing(padapter, false, 0xc0);
-       } else {
-               RTPRINT(FBT, BT_TRACE, ("HT20 or Legacy\n"));
-               btRssiState = BTDM_CheckCoexRSSIState(padapter, 2, 37, 0);
-               btRssiState1 = BTDM_CheckCoexRSSIState1(padapter, 2, 27, 0);
-
-               /*  fw mechanism */
-               if ((btRssiState1 == BT_RSSI_STATE_HIGH) ||
-                   (btRssiState1 == BT_RSSI_STATE_STAY_HIGH)) {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi-1 high \n"));
-                       PlatformEFIOWrite1Byte(padapter, 0x883, 0x40);
-                       btdm_2AntPsTdma(padapter, true, 2);
-               } else {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi-1 low \n"));
-                       btdm_2AntPsTdma(padapter, true, 6);
-               }
-
-               /*  sw mechanism */
-               if ((btRssiState == BT_RSSI_STATE_HIGH) ||
-                   (btRssiState == BT_RSSI_STATE_STAY_HIGH)) {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi high \n"));
-                       btdm_2AntAgcTable(padapter, true);
-                       btdm_2AntAdcBackOff(padapter, true);
-                       btdm_2AntDacSwing(padapter, false, 0xc0);
-               } else {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi low \n"));
-                       btdm_2AntAgcTable(padapter, false);
-                       btdm_2AntAdcBackOff(padapter, false);
-                       btdm_2AntDacSwing(padapter, false, 0xc0);
-               }
-       }
-}
-
-/* PAN(HS) only */
-static void btdm_2Ant8723APANHSAction(struct rtw_adapter *padapter)
-{
-       u8 btRssiState;
-
-       if (BTDM_IsHT40(padapter)) {
-               RTPRINT(FBT, BT_TRACE, ("HT40\n"));
-               btRssiState = BTDM_CheckCoexRSSIState(padapter, 2, 47, 0);
-               /*  fw mechanism */
-               if ((btRssiState == BT_RSSI_STATE_HIGH) ||
-                   (btRssiState == BT_RSSI_STATE_STAY_HIGH)) {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi high \n"));
-                       btdm_2AntDecBtPwr(padapter, true);
-               } else {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi low \n"));
-                       btdm_2AntDecBtPwr(padapter, false);
-               }
-               btdm_2AntPsTdma(padapter, false, 0);
-
-               /*  sw mechanism */
-               btdm_2AntAgcTable(padapter, false);
-               btdm_2AntAdcBackOff(padapter, true);
-               btdm_2AntDacSwing(padapter, false, 0xc0);
-       } else {
-               RTPRINT(FBT, BT_TRACE, ("HT20 or Legacy\n"));
-               btRssiState = BTDM_CheckCoexRSSIState(padapter, 2, 47, 0);
-
-               if ((btRssiState == BT_RSSI_STATE_HIGH) ||
-                   (btRssiState == BT_RSSI_STATE_STAY_HIGH)) {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi high\n"));
-                       /*  fw mechanism */
-                       btdm_2AntDecBtPwr(padapter, true);
-                       btdm_2AntPsTdma(padapter, false, 0);
-
-                       /*  sw mechanism */
-                       btdm_2AntAgcTable(padapter, true);
-                       btdm_2AntAdcBackOff(padapter, true);
-                       btdm_2AntDacSwing(padapter, false, 0xc0);
-               } else {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi low\n"));
-                       /*  fw mechanism */
-                       btdm_2AntDecBtPwr(padapter, false);
-                       btdm_2AntPsTdma(padapter, false, 0);
-
-                       /*  sw mechanism */
-                       btdm_2AntAgcTable(padapter, false);
-                       btdm_2AntAdcBackOff(padapter, false);
-                       btdm_2AntDacSwing(padapter, false, 0xc0);
-               }
-       }
-}
-
-/* PAN(EDR)+A2DP */
-static void btdm_2Ant8723APANEDRA2DPAction(struct rtw_adapter *padapter)
-{
-       u8 btRssiState, btRssiState1, btInfoExt;
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-
-       btInfoExt = pHalData->bt_coexist.halCoex8723.btInfoExt;
-
-       if (btdm_NeedToDecBtPwr(padapter))
-               btdm_2AntDecBtPwr(padapter, true);
-       else
-               btdm_2AntDecBtPwr(padapter, false);
-
-       if (BTDM_IsHT40(padapter)) {
-               RTPRINT(FBT, BT_TRACE, ("HT40\n"));
-               btRssiState = BTDM_CheckCoexRSSIState(padapter, 2, 37, 0);
-
-               if ((btRssiState == BT_RSSI_STATE_HIGH) ||
-                   (btRssiState == BT_RSSI_STATE_STAY_HIGH)) {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi high \n"));
-                       /*  fw mechanism */
-                       PlatformEFIOWrite1Byte(padapter, 0x883, 0x40);
-
-                       if (btInfoExt&BIT(0)) { /* a2dp rate, 1:basic /0:edr */
-                               RTPRINT(FBT, BT_TRACE, ("a2dp basic rate \n"));
-                               btdm_2AntPsTdma(padapter, true, 4);
-                       } else {
-                               RTPRINT(FBT, BT_TRACE, ("a2dp edr rate \n"));
-                               btdm_2AntPsTdma(padapter, true, 2);
-                       }
-               } else {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi low \n"));
-                       /*  fw mechanism */
-                       if (btInfoExt&BIT(0)) { /* a2dp rate, 1:basic /0:edr */
-                               RTPRINT(FBT, BT_TRACE, ("a2dp basic rate \n"));
-                               btdm_2AntPsTdma(padapter, true, 8);
-                       } else {
-                               RTPRINT(FBT, BT_TRACE, ("a2dp edr rate \n"));
-                               btdm_2AntPsTdma(padapter, true, 6);
-                       }
-               }
-
-               /*  sw mechanism */
-               btdm_2AntAgcTable(padapter, false);
-               btdm_2AntAdcBackOff(padapter, true);
-               btdm_2AntDacSwing(padapter, false, 0xc0);
-       } else {
-               RTPRINT(FBT, BT_TRACE, ("HT20 or Legacy\n"));
-               btRssiState = BTDM_CheckCoexRSSIState(padapter, 2, 37, 0);
-               btRssiState1 = BTDM_CheckCoexRSSIState1(padapter, 2, 27, 0);
-
-               if ((btRssiState1 == BT_RSSI_STATE_HIGH) ||
-                   (btRssiState1 == BT_RSSI_STATE_STAY_HIGH)) {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi-1 high \n"));
-                       PlatformEFIOWrite1Byte(padapter, 0x883, 0x40);
-                       /*  fw mechanism */
-                       if (btInfoExt&BIT(0)) { /* a2dp rate, 1:basic /0:edr */
-                               RTPRINT(FBT, BT_TRACE, ("a2dp basic rate \n"));
-                               btdm_2AntPsTdma(padapter, true, 4);
-                       } else {
-                               RTPRINT(FBT, BT_TRACE, ("a2dp edr rate \n"));
-                               btdm_2AntPsTdma(padapter, true, 2);
-                       }
-               } else {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi-1 low \n"));
-                       /*  fw mechanism */
-                       if (btInfoExt&BIT(0)) { /* a2dp rate, 1:basic /0:edr */
-                               RTPRINT(FBT, BT_TRACE, ("a2dp basic rate \n"));
-                               btdm_2AntPsTdma(padapter, true, 8);
-                       } else {
-                               RTPRINT(FBT, BT_TRACE, ("a2dp edr rate \n"));
-                               btdm_2AntPsTdma(padapter, true, 6);
-                       }
-               }
-
-               /*  sw mechanism */
-               if ((btRssiState == BT_RSSI_STATE_HIGH) ||
-                   (btRssiState == BT_RSSI_STATE_STAY_HIGH)) {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi high \n"));
-                       btdm_2AntAgcTable(padapter, true);
-                       btdm_2AntAdcBackOff(padapter, true);
-                       btdm_2AntDacSwing(padapter, false, 0xc0);
-               } else {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi low \n"));
-                       btdm_2AntAgcTable(padapter, false);
-                       btdm_2AntAdcBackOff(padapter, false);
-                       btdm_2AntDacSwing(padapter, false, 0xc0);
-               }
-       }
-}
-
-static void btdm_2Ant8723APANEDRHIDAction(struct rtw_adapter *padapter)
-{
-       u8 btRssiState, btRssiState1;
-
-       if (btdm_NeedToDecBtPwr(padapter))
-               btdm_2AntDecBtPwr(padapter, true);
-       else
-               btdm_2AntDecBtPwr(padapter, false);
-
-       if (BTDM_IsHT40(padapter)) {
-               RTPRINT(FBT, BT_TRACE, ("HT40\n"));
-               btRssiState = BTDM_CheckCoexRSSIState(padapter, 2, 37, 0);
-               /*  fw mechanism */
-               if ((btRssiState == BT_RSSI_STATE_HIGH) ||
-                   (btRssiState == BT_RSSI_STATE_STAY_HIGH)) {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi high \n"));
-                       PlatformEFIOWrite1Byte(padapter, 0x883, 0x40);
-                       btdm_2AntPsTdma(padapter, true, 10);
-               } else {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi low \n"));
-                       btdm_2AntPsTdma(padapter, true, 14);
-               }
-
-               /*  sw mechanism */
-               btdm_2AntAgcTable(padapter, false);
-               btdm_2AntAdcBackOff(padapter, true);
-               btdm_2AntDacSwing(padapter, false, 0xc0);
-       } else {
-               RTPRINT(FBT, BT_TRACE, ("HT20 or Legacy\n"));
-               btRssiState = BTDM_CheckCoexRSSIState(padapter, 2, 37, 0);
-               btRssiState1 = BTDM_CheckCoexRSSIState1(padapter, 2, 27, 0);
-
-               /*  fw mechanism */
-               if ((btRssiState1 == BT_RSSI_STATE_HIGH) ||
-                   (btRssiState1 == BT_RSSI_STATE_STAY_HIGH)) {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi-1 high \n"));
-                       PlatformEFIOWrite1Byte(padapter, 0x883, 0x40);
-                       btdm_2AntPsTdma(padapter, true, 10);
-               } else {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi-1 low \n"));
-                       btdm_2AntPsTdma(padapter, true, 14);
-               }
-
-               /*  sw mechanism */
-               if ((btRssiState == BT_RSSI_STATE_HIGH) ||
-                   (btRssiState == BT_RSSI_STATE_STAY_HIGH)) {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi high \n"));
-                       btdm_2AntAgcTable(padapter, true);
-                       btdm_2AntAdcBackOff(padapter, true);
-                       btdm_2AntDacSwing(padapter, false, 0xc0);
-               } else {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi low \n"));
-                       btdm_2AntAgcTable(padapter, false);
-                       btdm_2AntAdcBackOff(padapter, false);
-                       btdm_2AntDacSwing(padapter, false, 0xc0);
-               }
-       }
-}
-
-/*  HID+A2DP+PAN(EDR) */
-static void btdm_2Ant8723AHIDA2DPPANEDRAction(struct rtw_adapter *padapter)
-{
-       u8 btRssiState, btRssiState1, btInfoExt;
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-
-       btInfoExt = pHalData->bt_coexist.halCoex8723.btInfoExt;
-
-       if (btdm_NeedToDecBtPwr(padapter))
-               btdm_2AntDecBtPwr(padapter, true);
-       else
-               btdm_2AntDecBtPwr(padapter, false);
-
-       if (BTDM_IsHT40(padapter)) {
-               RTPRINT(FBT, BT_TRACE, ("HT40\n"));
-               btRssiState = BTDM_CheckCoexRSSIState(padapter, 2, 37, 0);
-               if ((btRssiState == BT_RSSI_STATE_HIGH) ||
-                   (btRssiState == BT_RSSI_STATE_STAY_HIGH)) {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi high \n"));
-                       PlatformEFIOWrite1Byte(padapter, 0x883, 0x40);
-
-                       if (btInfoExt&BIT(0)) { /* a2dp rate, 1:basic /0:edr */
-                               RTPRINT(FBT, BT_TRACE, ("a2dp basic rate \n"));
-                               btdm_2AntPsTdma(padapter, true, 12);
-                       } else {
-                               RTPRINT(FBT, BT_TRACE, ("a2dp edr rate \n"));
-                               btdm_2AntPsTdma(padapter, true, 10);
-                       }
-               } else {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi low \n"));
-                       if (btInfoExt&BIT(0)) { /* a2dp rate, 1:basic /0:edr */
-                               RTPRINT(FBT, BT_TRACE, ("a2dp basic rate \n"));
-                               btdm_2AntPsTdma(padapter, true, 16);
-                       } else {
-                               RTPRINT(FBT, BT_TRACE, ("a2dp edr rate \n"));
-                               btdm_2AntPsTdma(padapter, true, 14);
-                       }
-               }
-
-               /*  sw mechanism */
-               btdm_2AntAgcTable(padapter, false);
-               btdm_2AntAdcBackOff(padapter, true);
-               btdm_2AntDacSwing(padapter, false, 0xc0);
-       } else {
-               RTPRINT(FBT, BT_TRACE, ("HT20 or Legacy\n"));
-               btRssiState1 = BTDM_CheckCoexRSSIState1(padapter, 2, 37, 0);
-               btRssiState = BTDM_CheckCoexRSSIState(padapter, 2, 27, 0);
-               if ((btRssiState == BT_RSSI_STATE_HIGH) ||
-                   (btRssiState == BT_RSSI_STATE_STAY_HIGH)) {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi high \n"));
-                       PlatformEFIOWrite1Byte(padapter, 0x883, 0x40);
-
-                       if (btInfoExt&BIT(0)) { /* a2dp rate, 1:basic /0:edr */
-                               RTPRINT(FBT, BT_TRACE, ("a2dp basic rate \n"));
-                               btdm_2AntPsTdma(padapter, true, 12);
-                       } else {
-                               RTPRINT(FBT, BT_TRACE, ("a2dp edr rate \n"));
-                               btdm_2AntPsTdma(padapter, true, 10);
-                       }
-               } else {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi low \n"));
-                       if (btInfoExt&BIT(0)) { /* a2dp rate, 1:basic /0:edr */
-                               RTPRINT(FBT, BT_TRACE, ("a2dp basic rate \n"));
-                               btdm_2AntPsTdma(padapter, true, 16);
-                       } else {
-                               RTPRINT(FBT, BT_TRACE, ("a2dp edr rate \n"));
-                               btdm_2AntPsTdma(padapter, true, 14);
-                       }
-               }
-
-               /*  sw mechanism */
-               if ((btRssiState1 == BT_RSSI_STATE_HIGH) ||
-                   (btRssiState1 == BT_RSSI_STATE_STAY_HIGH)) {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi-1 high \n"));
-                       btdm_2AntAgcTable(padapter, true);
-                       btdm_2AntAdcBackOff(padapter, true);
-                       btdm_2AntDacSwing(padapter, false, 0xc0);
-               } else {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi-1 high \n"));
-                       btdm_2AntAgcTable(padapter, false);
-                       btdm_2AntAdcBackOff(padapter, false);
-                       btdm_2AntDacSwing(padapter, false, 0xc0);
-               }
-       }
-}
-
-static void btdm_2Ant8723AHIDA2DPAction(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       u8 btRssiState, btRssiState1, btInfoExt;
-
-       btInfoExt = pHalData->bt_coexist.halCoex8723.btInfoExt;
-
-       if (btdm_NeedToDecBtPwr(padapter))
-               btdm_2AntDecBtPwr(padapter, true);
-       else
-               btdm_2AntDecBtPwr(padapter, false);
-
-       if (BTDM_IsHT40(padapter)) {
-               RTPRINT(FBT, BT_TRACE, ("HT40\n"));
-               btRssiState = BTDM_CheckCoexRSSIState(padapter, 2, 37, 0);
-               if ((btRssiState == BT_RSSI_STATE_HIGH) ||
-                   (btRssiState == BT_RSSI_STATE_STAY_HIGH)) {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi high \n"));
-                       PlatformEFIOWrite1Byte(padapter, 0x883, 0x40);
-
-                       if (btInfoExt&BIT(0)) { /* a2dp rate, 1:basic /0:edr */
-                               RTPRINT(FBT, BT_TRACE, ("a2dp basic rate \n"));
-                               btdm_2AntTdmaDurationAdjust(padapter, true, false, 3);
-                       } else {
-                               RTPRINT(FBT, BT_TRACE, ("a2dp edr rate \n"));
-                               btdm_2AntTdmaDurationAdjust(padapter, true, false, 1);
-                       }
-               } else {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi low \n"));
-                       if (btInfoExt&BIT(0)) { /* a2dp rate, 1:basic /0:edr */
-                               RTPRINT(FBT, BT_TRACE, ("a2dp basic rate \n"));
-                               btdm_2AntTdmaDurationAdjust(padapter, true, true, 3);
-                       } else {
-                               RTPRINT(FBT, BT_TRACE, ("a2dp edr rate \n"));
-                               btdm_2AntTdmaDurationAdjust(padapter, true, true, 1);
-                       }
-               }
-               /*  sw mechanism */
-               btdm_2AntAgcTable(padapter, false);
-               btdm_2AntAdcBackOff(padapter, true);
-               btdm_2AntDacSwing(padapter, false, 0xc0);
-       } else {
-               RTPRINT(FBT, BT_TRACE, ("HT20 or Legacy\n"));
-               btRssiState = BTDM_CheckCoexRSSIState(padapter, 2, 37, 0);
-               btRssiState1 = BTDM_CheckCoexRSSIState(padapter, 2, 27, 0);
-
-               if ((btRssiState == BT_RSSI_STATE_HIGH) ||
-                   (btRssiState == BT_RSSI_STATE_STAY_HIGH)) {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi high \n"));
-                       PlatformEFIOWrite1Byte(padapter, 0x883, 0x40);
-
-                       if (btInfoExt&BIT(0)) { /* a2dp rate, 1:basic /0:edr */
-                               RTPRINT(FBT, BT_TRACE, ("a2dp basic rate \n"));
-                               btdm_2AntTdmaDurationAdjust(padapter, true, false, 3);
-                       } else {
-                               RTPRINT(FBT, BT_TRACE, ("a2dp edr rate \n"));
-                               btdm_2AntTdmaDurationAdjust(padapter, true, false, 1);
-                       }
-               } else {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi low \n"));
-                       if (btInfoExt&BIT(0)) { /* a2dp rate, 1:basic /0:edr */
-                               RTPRINT(FBT, BT_TRACE, ("a2dp basic rate \n"));
-                               btdm_2AntTdmaDurationAdjust(padapter, true, true, 3);
-                       } else {
-                               RTPRINT(FBT, BT_TRACE, ("a2dp edr rate \n"));
-                               btdm_2AntTdmaDurationAdjust(padapter, true, true, 1);
-                       }
-               }
-               if ((btRssiState1 == BT_RSSI_STATE_HIGH) ||
-                   (btRssiState1 == BT_RSSI_STATE_STAY_HIGH)) {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi-1 high \n"));
-                       /*  sw mechanism */
-                       btdm_2AntAgcTable(padapter, true);
-                       btdm_2AntAdcBackOff(padapter, true);
-                       btdm_2AntDacSwing(padapter, false, 0xc0);
-               } else {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi-1 low \n"));
-                       /*  sw mechanism */
-                       btdm_2AntAgcTable(padapter, false);
-                       btdm_2AntAdcBackOff(padapter, false);
-                       btdm_2AntDacSwing(padapter, false, 0xc0);
-               }
-       }
-}
-
-static void btdm_2Ant8723AA2dp(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       u8 btRssiState, btRssiState1, btInfoExt;
-
-       btInfoExt = pHalData->bt_coexist.halCoex8723.btInfoExt;
-
-       if (btdm_NeedToDecBtPwr(padapter))
-               btdm_2AntDecBtPwr(padapter, true);
-       else
-               btdm_2AntDecBtPwr(padapter, false);
-       /*  coex table */
-       btdm_2AntCoexTable(padapter, 0x55555555, 0xffff, 0x3);
-       btdm_2AntIgnoreWlanAct(padapter, false);
-
-       if (BTDM_IsHT40(padapter)) {
-               RTPRINT(FBT, BT_TRACE, ("HT40\n"));
-               btRssiState = BTDM_CheckCoexRSSIState(padapter, 2, 37, 0);
-               /*  fw mechanism */
-               if ((btRssiState == BT_RSSI_STATE_HIGH) ||
-                   (btRssiState == BT_RSSI_STATE_STAY_HIGH)) {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi-1 high \n"));
-                       PlatformEFIOWrite1Byte(padapter, 0x883, 0x40);
-                       btdm_2AntTdmaDurationAdjust(padapter, false, false, 1);
-               } else {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi-1 low \n"));
-                       btdm_2AntTdmaDurationAdjust(padapter, false, true, 1);
-               }
-
-               /*  sw mechanism */
-               btdm_2AntAgcTable(padapter, false);
-               btdm_2AntAdcBackOff(padapter, true);
-               btdm_2AntDacSwing(padapter, false, 0xc0);
-       } else {
-               RTPRINT(FBT, BT_TRACE, ("HT20 or Legacy\n"));
-               btRssiState = BTDM_CheckCoexRSSIState(padapter, 2, 47, 0);
-               btRssiState1 = BTDM_CheckCoexRSSIState1(padapter, 2, 27, 0);
-
-               /*  fw mechanism */
-               if ((btRssiState1 == BT_RSSI_STATE_HIGH) ||
-                   (btRssiState1 == BT_RSSI_STATE_STAY_HIGH)) {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi-1 high \n"));
-                       PlatformEFIOWrite1Byte(padapter, 0x883, 0x40);
-                       btdm_2AntTdmaDurationAdjust(padapter, false, false, 1);
-               } else {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi-1 low \n"));
-                       btdm_2AntTdmaDurationAdjust(padapter, false, true, 1);
-               }
-
-               /*  sw mechanism */
-               if ((btRssiState == BT_RSSI_STATE_HIGH) ||
-                   (btRssiState == BT_RSSI_STATE_STAY_HIGH)) {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi high \n"));
-                       btdm_2AntAgcTable(padapter, true);
-                       btdm_2AntAdcBackOff(padapter, true);
-                       btdm_2AntDacSwing(padapter, false, 0xc0);
-               } else {
-                       RTPRINT(FBT, BT_TRACE, ("Wifi rssi low \n"));
-                       btdm_2AntAgcTable(padapter, false);
-                       btdm_2AntAdcBackOff(padapter, false);
-                       btdm_2AntDacSwing(padapter, false, 0xc0);
-               }
-       }
-}
-
-/*  extern function start with BTDM_ */
-static void BTDM_2AntParaInit(struct rtw_adapter *padapter)
-{
-
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       struct btdm_8723a_2ant *pBtdm8723 = &pHalData->bt_coexist.halCoex8723.btdm2Ant;
-
-       RTPRINT(FBT, BT_TRACE, ("[BTCoex], 2Ant Parameter Init!!\n"));
-
-       /*  Enable counter statistics */
-       rtl8723au_write8(padapter, 0x76e, 0x4);
-       rtl8723au_write8(padapter, 0x778, 0x3);
-       rtl8723au_write8(padapter, 0x40, 0x20);
-
-       /*  force to reset coex mechanism */
-       pBtdm8723->preVal0x6c0 = 0x0;
-       btdm_2AntCoexTable(padapter, 0x55555555, 0xffff, 0x3);
-
-       pBtdm8723->bPrePsTdmaOn = true;
-       btdm_2AntPsTdma(padapter, false, 0);
-
-       pBtdm8723->preFwDacSwingLvl = 0x10;
-       btdm_2AntFwDacSwingLvl(padapter, 0x20);
-
-       pBtdm8723->bPreDecBtPwr = true;
-       btdm_2AntDecBtPwr(padapter, false);
-
-       pBtdm8723->bPreAgcTableEn = true;
-       btdm_2AntAgcTable(padapter, false);
-
-       pBtdm8723->bPreAdcBackOff = true;
-       btdm_2AntAdcBackOff(padapter, false);
-
-       pBtdm8723->bPreLowPenaltyRa = true;
-       btdm_2AntLowPenaltyRa(padapter, false);
-
-       pBtdm8723->bPreRfRxLpfShrink = true;
-       btdm_2AntRfShrink(padapter, false);
-
-       pBtdm8723->bPreDacSwingOn = true;
-       btdm_2AntDacSwing(padapter, false, 0xc0);
-
-       pBtdm8723->bPreIgnoreWlanAct = true;
-       btdm_2AntIgnoreWlanAct(padapter, false);
-}
-
-static void BTDM_2AntHwCoexAllOff8723A(struct rtw_adapter *padapter)
-{
-       btdm_2AntCoexTable(padapter, 0x55555555, 0xffff, 0x3);
-}
-
-static void BTDM_2AntFwCoexAllOff8723A(struct rtw_adapter *padapter)
-{
-       btdm_2AntIgnoreWlanAct(padapter, false);
-       btdm_2AntPsTdma(padapter, false, 0);
-       btdm_2AntFwDacSwingLvl(padapter, 0x20);
-       btdm_2AntDecBtPwr(padapter, false);
-}
-
-static void BTDM_2AntSwCoexAllOff8723A(struct rtw_adapter *padapter)
-{
-       btdm_2AntAgcTable(padapter, false);
-       btdm_2AntAdcBackOff(padapter, false);
-       btdm_2AntLowPenaltyRa(padapter, false);
-       btdm_2AntRfShrink(padapter, false);
-       btdm_2AntDacSwing(padapter, false, 0xc0);
-}
-
-static void BTDM_2AntFwC2hBtInfo8723A(struct rtw_adapter *padapter)
-{
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       struct btdm_8723a_2ant *pBtdm8723 = &pHalData->bt_coexist.halCoex8723.btdm2Ant;
-       u8 btInfo = 0;
-       u8 algorithm = BT_2ANT_COEX_ALGO_UNDEFINED;
-       u8 bBtLinkExist = false, bBtHsModeExist = false;
-
-       btInfo = pHalData->bt_coexist.halCoex8723.c2hBtInfoOriginal;
-       pBtdm8723->btStatus = BT_2ANT_BT_STATUS_IDLE;
-
-       /*  check BIT2 first ==> check if bt is under inquiry or page scan */
-       if (btInfo & BIT(2)) {
-               if (!pHalData->bt_coexist.halCoex8723.bC2hBtInquiryPage) {
-                       pBtMgnt->ExtConfig.bHoldForBtOperation = true;
-                       pBtMgnt->ExtConfig.bHoldPeriodCnt = 1;
-                       btdm_2AntBtInquiryPage(padapter);
-               } else {
-                       pBtMgnt->ExtConfig.bHoldPeriodCnt++;
-                       btdm_HoldForBtInqPage(padapter);
-               }
-               pHalData->bt_coexist.halCoex8723.bC2hBtInquiryPage = true;
-
-       } else {
-               pHalData->bt_coexist.halCoex8723.bC2hBtInquiryPage = false;
-               pBtMgnt->ExtConfig.bHoldForBtOperation = false;
-               pBtMgnt->ExtConfig.bHoldPeriodCnt = 0;
-
-       }
-       RTPRINT(FBT, BT_TRACE,
-               ("[BTC2H], pHalData->bt_coexist.halCoex8723.bC2hBtInquiryPage =%x pBtMgnt->ExtConfig.bHoldPeriodCnt =%x pBtMgnt->ExtConfig.bHoldForBtOperation =%x\n",
-               pHalData->bt_coexist.halCoex8723.bC2hBtInquiryPage,
-               pBtMgnt->ExtConfig.bHoldPeriodCnt,
-               pBtMgnt->ExtConfig.bHoldForBtOperation));
-
-       RTPRINT(FBT, BT_TRACE,
-               ("[BTC2H],   btInfo =%x   pHalData->bt_coexist.halCoex8723.c2hBtInfoOriginal =%x\n",
-               btInfo, pHalData->bt_coexist.halCoex8723.c2hBtInfoOriginal));
-       if (btInfo&BT_INFO_ACL) {
-               RTPRINT(FBT, BT_TRACE, ("[BTC2H], BTInfo: bConnect = true   btInfo =%x\n", btInfo));
-               bBtLinkExist = true;
-               if (((btInfo&(BT_INFO_FTP|BT_INFO_A2DP|BT_INFO_HID|BT_INFO_SCO_BUSY)) != 0) ||
-                   pHalData->bt_coexist.halCoex8723.btRetryCnt > 0) {
-                       pBtdm8723->btStatus = BT_2ANT_BT_STATUS_NON_IDLE;
-               } else {
-                       pBtdm8723->btStatus = BT_2ANT_BT_STATUS_CONNECTED_IDLE;
-               }
-
-               if (btInfo&BT_INFO_SCO || btInfo&BT_INFO_SCO_BUSY) {
-                       if (btInfo&BT_INFO_FTP || btInfo&BT_INFO_A2DP || btInfo&BT_INFO_HID) {
-                               switch (btInfo&0xe0) {
-                               case BT_INFO_HID:
-                                       RTPRINT(FBT, BT_TRACE, ("[BTCoex], SCO + HID\n"));
-                                       algorithm = BT_2ANT_COEX_ALGO_HID;
-                                       break;
-                               case BT_INFO_A2DP:
-                                       RTPRINT(FBT, BT_TRACE, ("[BTCoex], Error!!! SCO + A2DP\n"));
-                                       break;
-                               case BT_INFO_FTP:
-                                       if (bBtHsModeExist) {
-                                               RTPRINT(FBT, BT_TRACE, ("[BTCoex], SCO + PAN(HS)\n"));
-                                               algorithm = BT_2ANT_COEX_ALGO_SCO;
-                                       } else {
-                                               RTPRINT(FBT, BT_TRACE, ("[BTCoex], SCO + PAN(EDR)\n"));
-                                               algorithm = BT_2ANT_COEX_ALGO_PANEDR_HID;
-                                       }
-                                       break;
-                               case (BT_INFO_HID | BT_INFO_A2DP):
-                                       RTPRINT(FBT, BT_TRACE, ("[BTCoex], HID + A2DP\n"));
-                                       algorithm = BT_2ANT_COEX_ALGO_HID_A2DP;
-                                       break;
-                               case (BT_INFO_HID | BT_INFO_FTP):
-                                       if (bBtHsModeExist) {
-                                               RTPRINT(FBT, BT_TRACE, ("[BTCoex], HID + PAN(HS)\n"));
-                                               algorithm = BT_2ANT_COEX_ALGO_HID_A2DP;
-                                       } else {
-                                               RTPRINT(FBT, BT_TRACE, ("[BTCoex], HID + PAN(EDR)\n"));
-                                               algorithm = BT_2ANT_COEX_ALGO_PANEDR_HID;
-                                       }
-                                       break;
-                               case (BT_INFO_A2DP | BT_INFO_FTP):
-                                       if (bBtHsModeExist) {
-                                               RTPRINT(FBT, BT_TRACE, ("[BTCoex], A2DP + PAN(HS)\n"));
-                                               algorithm = BT_2ANT_COEX_ALGO_A2DP;
-                                       } else {
-                                               RTPRINT(FBT, BT_TRACE, ("[BTCoex], A2DP + PAN(EDR)\n"));
-                                               algorithm = BT_2ANT_COEX_ALGO_PANEDR_A2DP;
-                                       }
-                                       break;
-                               case (BT_INFO_HID | BT_INFO_A2DP | BT_INFO_FTP):
-                                       if (bBtHsModeExist) {
-                                               RTPRINT(FBT, BT_TRACE, ("[BTCoex], HID + A2DP + PAN(HS)\n"));
-                                               algorithm = BT_2ANT_COEX_ALGO_HID_A2DP;
-                                       } else {
-                                               RTPRINT(FBT, BT_TRACE, ("[BTCoex], HID + A2DP + PAN(EDR)\n"));
-                                               algorithm = BT_2ANT_COEX_ALGO_HID_A2DP_PANEDR;
-                                       }
-                                       break;
-                               }
-                       } else {
-                               RTPRINT(FBT, BT_TRACE, ("[BTCoex], SCO only\n"));
-                               algorithm = BT_2ANT_COEX_ALGO_SCO;
-                       }
-               } else {
-                       RTPRINT(FBT, BT_TRACE, ("[BTCoex], non SCO\n"));
-                       switch (btInfo&0xe0) {
-                       case BT_INFO_HID:
-                               RTPRINT(FBT, BT_TRACE, ("[BTCoex], HID\n"));
-                               algorithm = BT_2ANT_COEX_ALGO_HID;
-                               break;
-                       case BT_INFO_A2DP:
-                               RTPRINT(FBT, BT_TRACE, ("[BTCoex],  A2DP\n"));
-                               algorithm = BT_2ANT_COEX_ALGO_A2DP;
-                               break;
-                       case BT_INFO_FTP:
-                               RTPRINT(FBT, BT_TRACE, ("[BTCoex], PAN(EDR)\n"));
-                               algorithm = BT_2ANT_COEX_ALGO_PANEDR_HID;
-                               break;
-                       case (BT_INFO_HID | BT_INFO_A2DP):
-                               RTPRINT(FBT, BT_TRACE, ("[BTCoex], HID + A2DP\n"));
-                               algorithm = BT_2ANT_COEX_ALGO_HID_A2DP;
-                               break;
-                       case (BT_INFO_HID|BT_INFO_FTP):
-                               if (bBtHsModeExist) {
-                                       RTPRINT(FBT, BT_TRACE, ("[BTCoex], HID + PAN(HS)\n"));
-                                       algorithm = BT_2ANT_COEX_ALGO_HID_A2DP;
-                               } else {
-                                       RTPRINT(FBT, BT_TRACE, ("[BTCoex], HID + PAN(EDR)\n"));
-                                       algorithm = BT_2ANT_COEX_ALGO_PANEDR_HID;
-                               }
-                               break;
-                       case (BT_INFO_A2DP|BT_INFO_FTP):
-                               if (bBtHsModeExist) {
-                                       RTPRINT(FBT, BT_TRACE, ("[BTCoex], A2DP + PAN(HS)\n"));
-                                       algorithm = BT_2ANT_COEX_ALGO_A2DP;
-                               } else {
-                                       RTPRINT(FBT, BT_TRACE, ("[BTCoex], A2DP + PAN(EDR)\n"));
-                                       algorithm = BT_2ANT_COEX_ALGO_PANEDR_A2DP;
-                               }
-                               break;
-                       case (BT_INFO_HID|BT_INFO_A2DP|BT_INFO_FTP):
-                               if (bBtHsModeExist) {
-                                       RTPRINT(FBT, BT_TRACE, ("[BTCoex], HID + A2DP + PAN(HS)\n"));
-                                       algorithm = BT_2ANT_COEX_ALGO_HID_A2DP;
-                               } else {
-                                       RTPRINT(FBT, BT_TRACE, ("[BTCoex], HID + A2DP + PAN(EDR)\n"));
-                                       algorithm = BT_2ANT_COEX_ALGO_HID_A2DP_PANEDR;
-                               }
-                               break;
-                       }
-
-               }
-       } else {
-               RTPRINT(FBT, BT_TRACE, ("[BTC2H], BTInfo: bConnect = false\n"));
-               pBtdm8723->btStatus = BT_2ANT_BT_STATUS_IDLE;
-       }
-
-       pBtdm8723->curAlgorithm = algorithm;
-       RTPRINT(FBT, BT_TRACE, ("[BTCoex], Algorithm = %d \n", pBtdm8723->curAlgorithm));
-
-/* From */
-       BTDM_CheckWiFiState(padapter);
-       if (pBtMgnt->ExtConfig.bManualControl) {
-               RTPRINT(FBT, BT_TRACE, ("Action Manual control, won't execute bt coexist mechanism!!\n"));
-               return;
-       }
-}
-
-void BTDM_2AntBtCoexist8723A(struct rtw_adapter *padapter)
-{
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-       struct bt_dgb *pBtDbg = &pBTInfo->BtDbg;
-       u8 btInfoOriginal = 0;
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       struct btdm_8723a_2ant *pBtdm8723 = &pHalData->bt_coexist.halCoex8723.btdm2Ant;
-
-       if (BTDM_BtProfileSupport(padapter)) {
-               if (pBtMgnt->ExtConfig.bHoldForBtOperation) {
-                       RTPRINT(FBT, BT_TRACE, ("Action for BT Operation adjust!!\n"));
-                       return;
-               }
-               if (pBtMgnt->ExtConfig.bHoldPeriodCnt) {
-                       RTPRINT(FBT, BT_TRACE, ("Hold BT inquiry/page scan setting (cnt = %d)!!\n",
-                               pBtMgnt->ExtConfig.bHoldPeriodCnt));
-                       if (pBtMgnt->ExtConfig.bHoldPeriodCnt >= 11) {
-                               pBtMgnt->ExtConfig.bHoldPeriodCnt = 0;
-                               /*  next time the coexist parameters should be reset again. */
-                       } else {
-                               pBtMgnt->ExtConfig.bHoldPeriodCnt++;
-                       }
-                       return;
-               }
-
-               if (pBtDbg->dbgCtrl)
-                       RTPRINT(FBT, BT_TRACE, ("[Dbg control], "));
-
-               pBtdm8723->curAlgorithm = btdm_ActionAlgorithm(padapter);
-               RTPRINT(FBT, BT_TRACE, ("[BTCoex], Algorithm = %d \n", pBtdm8723->curAlgorithm));
-
-               if (btdm_Is2Ant8723ACommonAction(padapter)) {
-                       RTPRINT(FBT, BT_TRACE, ("Action 2-Ant common.\n"));
-                       pBtdm8723->bResetTdmaAdjust = true;
-               } else {
-                       if (pBtdm8723->curAlgorithm != pBtdm8723->preAlgorithm) {
-                               RTPRINT(FBT, BT_TRACE, ("[BTCoex], preAlgorithm =%d, curAlgorithm =%d\n",
-                               pBtdm8723->preAlgorithm, pBtdm8723->curAlgorithm));
-                               pBtdm8723->bResetTdmaAdjust = true;
-                       }
-                       switch (pBtdm8723->curAlgorithm) {
-                       case BT_2ANT_COEX_ALGO_SCO:
-                               RTPRINT(FBT, BT_TRACE, ("Action 2-Ant, algorithm = SCO.\n"));
-                               btdm_2Ant8723ASCOAction(padapter);
-                               break;
-                       case BT_2ANT_COEX_ALGO_HID:
-                               RTPRINT(FBT, BT_TRACE, ("Action 2-Ant, algorithm = HID.\n"));
-                               btdm_2Ant8723AHIDAction(padapter);
-                               break;
-                       case BT_2ANT_COEX_ALGO_A2DP:
-                               RTPRINT(FBT, BT_TRACE, ("Action 2-Ant, algorithm = A2DP.\n"));
-                               btdm_2Ant8723AA2DPAction(padapter);
-                               break;
-                       case BT_2ANT_COEX_ALGO_PANEDR:
-                               RTPRINT(FBT, BT_TRACE, ("Action 2-Ant, algorithm = PAN(EDR).\n"));
-                               btdm_2Ant8723APANEDRAction(padapter);
-                               break;
-                       case BT_2ANT_COEX_ALGO_PANHS:
-                               RTPRINT(FBT, BT_TRACE, ("Action 2-Ant, algorithm = HS mode.\n"));
-                               btdm_2Ant8723APANHSAction(padapter);
-                               break;
-                       case BT_2ANT_COEX_ALGO_PANEDR_A2DP:
-                               RTPRINT(FBT, BT_TRACE, ("Action 2-Ant, algorithm = PAN+A2DP.\n"));
-                               btdm_2Ant8723APANEDRA2DPAction(padapter);
-                               break;
-                       case BT_2ANT_COEX_ALGO_PANEDR_HID:
-                               RTPRINT(FBT, BT_TRACE, ("Action 2-Ant, algorithm = PAN(EDR)+HID.\n"));
-                               btdm_2Ant8723APANEDRHIDAction(padapter);
-                               break;
-                       case BT_2ANT_COEX_ALGO_HID_A2DP_PANEDR:
-                               RTPRINT(FBT, BT_TRACE, ("Action 2-Ant, algorithm = HID+A2DP+PAN.\n"));
-                               btdm_2Ant8723AHIDA2DPPANEDRAction(padapter);
-                               break;
-                       case BT_2ANT_COEX_ALGO_HID_A2DP:
-                               RTPRINT(FBT, BT_TRACE, ("Action 2-Ant, algorithm = HID+A2DP.\n"));
-                               btdm_2Ant8723AHIDA2DPAction(padapter);
-                               break;
-                       default:
-                               RTPRINT(FBT, BT_TRACE, ("Action 2-Ant, algorithm = 0.\n"));
-                               btdm_2Ant8723AA2DPAction(padapter);
-                               break;
-                       }
-                       pBtdm8723->preAlgorithm = pBtdm8723->curAlgorithm;
-               }
-       } else {
-               RTPRINT(FBT, BT_TRACE, ("[BTCoex] Get bt info by fw!!\n"));
-               /* msg shows c2h rsp for bt_info is received or not. */
-               if (pHalData->bt_coexist.halCoex8723.bC2hBtInfoReqSent)
-                       RTPRINT(FBT, BT_TRACE, ("[BTCoex] c2h for btInfo not rcvd yet!!\n"));
-
-               btInfoOriginal = pHalData->bt_coexist.halCoex8723.c2hBtInfoOriginal;
-
-               if (pBtMgnt->ExtConfig.bHoldForBtOperation) {
-                       RTPRINT(FBT, BT_TRACE, ("Action for BT Operation adjust!!\n"));
-                       return;
-               }
-               if (pBtMgnt->ExtConfig.bHoldPeriodCnt) {
-                       RTPRINT(FBT, BT_TRACE,
-                               ("Hold BT inquiry/page scan setting (cnt = %d)!!\n",
-                               pBtMgnt->ExtConfig.bHoldPeriodCnt));
-                       if (pBtMgnt->ExtConfig.bHoldPeriodCnt >= 11) {
-                               pBtMgnt->ExtConfig.bHoldPeriodCnt = 0;
-                               /*  next time the coexist parameters should be reset again. */
-                       } else {
-                                pBtMgnt->ExtConfig.bHoldPeriodCnt++;
-                       }
-                       return;
-               }
-
-               if (pBtDbg->dbgCtrl)
-                       RTPRINT(FBT, BT_TRACE, ("[Dbg control], "));
-               if (btdm_Is2Ant8723ACommonAction(padapter)) {
-                       RTPRINT(FBT, BT_TRACE, ("Action 2-Ant common.\n"));
-                       pBtdm8723->bResetTdmaAdjust = true;
-               } else {
-                       if (pBtdm8723->curAlgorithm != pBtdm8723->preAlgorithm) {
-                               RTPRINT(FBT, BT_TRACE,
-                                       ("[BTCoex], preAlgorithm =%d, curAlgorithm =%d\n",
-                                       pBtdm8723->preAlgorithm,
-                                       pBtdm8723->curAlgorithm));
-                               pBtdm8723->bResetTdmaAdjust = true;
-                       }
-                       switch (pBtdm8723->curAlgorithm) {
-                       case BT_2ANT_COEX_ALGO_SCO:
-                               RTPRINT(FBT, BT_TRACE, ("Action 2-Ant, algorithm = SCO.\n"));
-                               btdm_2Ant8723ASCOAction(padapter);
-                               break;
-                       case BT_2ANT_COEX_ALGO_HID:
-                               RTPRINT(FBT, BT_TRACE, ("Action 2-Ant, algorithm = HID.\n"));
-                               btdm_2Ant8723AHIDAction(padapter);
-                               break;
-                       case BT_2ANT_COEX_ALGO_A2DP:
-                               RTPRINT(FBT, BT_TRACE, ("Action 2-Ant, algorithm = A2DP.\n"));
-                               btdm_2Ant8723AA2dp(padapter);
-                               break;
-                       case BT_2ANT_COEX_ALGO_PANEDR:
-                               RTPRINT(FBT, BT_TRACE, ("Action 2-Ant, algorithm = PAN(EDR).\n"));
-                               btdm_2Ant8723APANEDRAction(padapter);
-                               break;
-                       case BT_2ANT_COEX_ALGO_PANHS:
-                               RTPRINT(FBT, BT_TRACE, ("Action 2-Ant, algorithm = HS mode.\n"));
-                               btdm_2Ant8723APANHSAction(padapter);
-                               break;
-                       case BT_2ANT_COEX_ALGO_PANEDR_A2DP:
-                               RTPRINT(FBT, BT_TRACE, ("Action 2-Ant, algorithm = PAN+A2DP.\n"));
-                               btdm_2Ant8723APANEDRA2DPAction(padapter);
-                               break;
-                       case BT_2ANT_COEX_ALGO_PANEDR_HID:
-                               RTPRINT(FBT, BT_TRACE, ("Action 2-Ant, algorithm = PAN(EDR)+HID.\n"));
-                               btdm_2Ant8723APANEDRHIDAction(padapter);
-                               break;
-                       case BT_2ANT_COEX_ALGO_HID_A2DP_PANEDR:
-                               RTPRINT(FBT, BT_TRACE, ("Action 2-Ant, algorithm = HID+A2DP+PAN.\n"));
-                               btdm_2Ant8723AHIDA2DPPANEDRAction(padapter);
-                               break;
-                       case BT_2ANT_COEX_ALGO_HID_A2DP:
-                               RTPRINT(FBT, BT_TRACE, ("Action 2-Ant, algorithm = HID+A2DP.\n"));
-                               btdm_2Ant8723AHIDA2DPAction(padapter);
-                               break;
-                       default:
-                               RTPRINT(FBT, BT_TRACE, ("Action 2-Ant, algorithm = 0.\n"));
-                               btdm_2Ant8723AA2DPAction(padapter);
-                               break;
-                       }
-                       pBtdm8723->preAlgorithm = pBtdm8723->curAlgorithm;
-               }
-       }
-}
-
-/*  ===== End of sync from SD7 driver HAL/BTCoexist/HalBtc87232Ant.c ===== */
-
-/*  ===== Below this line is sync from SD7 driver HAL/BTCoexist/HalBtc8723.c ===== */
-
-static u8 btCoexDbgBuf[BT_TMP_BUF_SIZE];
-
-static const char *const BtProfileString[] = {
-       "NONE",
-       "A2DP",
-       "PAN",
-       "HID",
-       "SCO",
-};
-
-static const char *const BtSpecString[] = {
-       "1.0b",
-       "1.1",
-       "1.2",
-       "2.0+EDR",
-       "2.1+EDR",
-       "3.0+HS",
-       "4.0",
-};
-
-static const char *const BtLinkRoleString[] = {
-       "Master",
-       "Slave",
-};
-
-static u8 btdm_BtWifiAntNum(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       struct bt_coexist_8723a *pBtCoex = &pHalData->bt_coexist.halCoex8723;
-
-       if (Ant_x2 == pHalData->bt_coexist.BT_Ant_Num) {
-               if (Ant_x2 == pBtCoex->TotalAntNum)
-                       return Ant_x2;
-               else
-                       return Ant_x1;
-       } else {
-               return Ant_x1;
-       }
-       return Ant_x2;
-}
-
-static void btdm_BtHwCountersMonitor(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       u32     regHPTxRx, regLPTxRx, u4Tmp;
-       u32     regHPTx = 0, regHPRx = 0, regLPTx = 0, regLPRx = 0;
-
-       regHPTxRx = REG_HIGH_PRIORITY_TXRX;
-       regLPTxRx = REG_LOW_PRIORITY_TXRX;
-
-       u4Tmp = rtl8723au_read32(padapter, regHPTxRx);
-       regHPTx = u4Tmp & bMaskLWord;
-       regHPRx = (u4Tmp & bMaskHWord)>>16;
-
-       u4Tmp = rtl8723au_read32(padapter, regLPTxRx);
-       regLPTx = u4Tmp & bMaskLWord;
-       regLPRx = (u4Tmp & bMaskHWord)>>16;
-
-       pHalData->bt_coexist.halCoex8723.highPriorityTx = regHPTx;
-       pHalData->bt_coexist.halCoex8723.highPriorityRx = regHPRx;
-       pHalData->bt_coexist.halCoex8723.lowPriorityTx = regLPTx;
-       pHalData->bt_coexist.halCoex8723.lowPriorityRx = regLPRx;
-
-       RTPRINT(FBT, BT_TRACE, ("High Priority Tx/Rx = %d / %d\n", regHPTx, regHPRx));
-       RTPRINT(FBT, BT_TRACE, ("Low Priority Tx/Rx = %d / %d\n", regLPTx, regLPRx));
-
-       /*  reset counter */
-       rtl8723au_write8(padapter, 0x76e, 0xc);
-}
-
-/*  This function check if 8723 bt is disabled */
-static void btdm_BtEnableDisableCheck8723A(struct rtw_adapter *padapter)
-{
-       u8 btAlife = true;
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-
-#ifdef CHECK_BT_EXIST_FROM_REG
-       u8 val8;
-
-       /*  ox68[28]= 1 => BT enable; otherwise disable */
-       val8 = rtl8723au_read8(padapter, 0x6B);
-       if (!(val8 & BIT(4)))
-               btAlife = false;
-
-       if (btAlife)
-               pHalData->bt_coexist.bCurBtDisabled = false;
-       else
-               pHalData->bt_coexist.bCurBtDisabled = true;
-#else
-       if (pHalData->bt_coexist.halCoex8723.highPriorityTx == 0 &&
-           pHalData->bt_coexist.halCoex8723.highPriorityRx == 0 &&
-           pHalData->bt_coexist.halCoex8723.lowPriorityTx == 0 &&
-           pHalData->bt_coexist.halCoex8723.lowPriorityRx == 0)
-               btAlife = false;
-       if (pHalData->bt_coexist.halCoex8723.highPriorityTx == 0xeaea &&
-           pHalData->bt_coexist.halCoex8723.highPriorityRx == 0xeaea &&
-           pHalData->bt_coexist.halCoex8723.lowPriorityTx == 0xeaea &&
-           pHalData->bt_coexist.halCoex8723.lowPriorityRx == 0xeaea)
-               btAlife = false;
-       if (pHalData->bt_coexist.halCoex8723.highPriorityTx == 0xffff &&
-           pHalData->bt_coexist.halCoex8723.highPriorityRx == 0xffff &&
-           pHalData->bt_coexist.halCoex8723.lowPriorityTx == 0xffff &&
-           pHalData->bt_coexist.halCoex8723.lowPriorityRx == 0xffff)
-               btAlife = false;
-       if (btAlife) {
-               pHalData->bt_coexist.btActiveZeroCnt = 0;
-               pHalData->bt_coexist.bCurBtDisabled = false;
-               RTPRINT(FBT, BT_TRACE, ("8723A BT is enabled !!\n"));
-       } else {
-               pHalData->bt_coexist.btActiveZeroCnt++;
-               RTPRINT(FBT, BT_TRACE, ("8723A bt all counters = 0, %d times!!\n",
-                               pHalData->bt_coexist.btActiveZeroCnt));
-               if (pHalData->bt_coexist.btActiveZeroCnt >= 2) {
-                       pHalData->bt_coexist.bCurBtDisabled = true;
-                       RTPRINT(FBT, BT_TRACE, ("8723A BT is disabled !!\n"));
-               }
-       }
-#endif
-
-       if (!pHalData->bt_coexist.bCurBtDisabled) {
-               if (BTDM_IsWifiConnectionExist(padapter))
-                       BTDM_SetFwChnlInfo(padapter, RT_MEDIA_CONNECT);
-               else
-                       BTDM_SetFwChnlInfo(padapter, RT_MEDIA_DISCONNECT);
-       }
-
-       if (pHalData->bt_coexist.bPreBtDisabled !=
-           pHalData->bt_coexist.bCurBtDisabled) {
-               RTPRINT(FBT, BT_TRACE, ("8723A BT is from %s to %s!!\n",
-                       (pHalData->bt_coexist.bPreBtDisabled ? "disabled":"enabled"),
-                       (pHalData->bt_coexist.bCurBtDisabled ? "disabled":"enabled")));
-               pHalData->bt_coexist.bPreBtDisabled = pHalData->bt_coexist.bCurBtDisabled;
-       }
-}
-
-static void btdm_BTCoexist8723AHandler(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData;
-
-       pHalData = GET_HAL_DATA(padapter);
-
-       if (btdm_BtWifiAntNum(padapter) == Ant_x2) {
-               RTPRINT(FBT, BT_TRACE, ("[BTCoex], 2 Ant mechanism\n"));
-               BTDM_2AntBtCoexist8723A(padapter);
-       } else {
-               RTPRINT(FBT, BT_TRACE, ("[BTCoex], 1 Ant mechanism\n"));
-               BTDM_1AntBtCoexist8723A(padapter);
-       }
-
-       if (!BTDM_IsSameCoexistState(padapter)) {
-               RTPRINT(FBT, BT_TRACE, ("[BTCoex], Coexist State[bitMap] change from 0x%"i64fmt"x to 0x%"i64fmt"x\n",
-                       pHalData->bt_coexist.PreviousState,
-                       pHalData->bt_coexist.CurrentState));
-               pHalData->bt_coexist.PreviousState = pHalData->bt_coexist.CurrentState;
-
-               RTPRINT(FBT, BT_TRACE, ("["));
-               if (pHalData->bt_coexist.CurrentState & BT_COEX_STATE_BT30)
-                       RTPRINT(FBT, BT_TRACE, ("BT 3.0, "));
-               if (pHalData->bt_coexist.CurrentState & BT_COEX_STATE_WIFI_HT20)
-                       RTPRINT(FBT, BT_TRACE, ("HT20, "));
-               if (pHalData->bt_coexist.CurrentState & BT_COEX_STATE_WIFI_HT40)
-                       RTPRINT(FBT, BT_TRACE, ("HT40, "));
-               if (pHalData->bt_coexist.CurrentState & BT_COEX_STATE_WIFI_LEGACY)
-                       RTPRINT(FBT, BT_TRACE, ("Legacy, "));
-               if (pHalData->bt_coexist.CurrentState & BT_COEX_STATE_WIFI_RSSI_LOW)
-                       RTPRINT(FBT, BT_TRACE, ("Rssi_Low, "));
-               if (pHalData->bt_coexist.CurrentState & BT_COEX_STATE_WIFI_RSSI_MEDIUM)
-                       RTPRINT(FBT, BT_TRACE, ("Rssi_Mid, "));
-               if (pHalData->bt_coexist.CurrentState & BT_COEX_STATE_WIFI_RSSI_HIGH)
-                       RTPRINT(FBT, BT_TRACE, ("Rssi_High, "));
-               if (pHalData->bt_coexist.CurrentState & BT_COEX_STATE_WIFI_IDLE)
-                       RTPRINT(FBT, BT_TRACE, ("Wifi_Idle, "));
-               if (pHalData->bt_coexist.CurrentState & BT_COEX_STATE_WIFI_UPLINK)
-                       RTPRINT(FBT, BT_TRACE, ("Wifi_Uplink, "));
-               if (pHalData->bt_coexist.CurrentState & BT_COEX_STATE_WIFI_DOWNLINK)
-                       RTPRINT(FBT, BT_TRACE, ("Wifi_Downlink, "));
-               if (pHalData->bt_coexist.CurrentState & BT_COEX_STATE_BT_IDLE)
-                       RTPRINT(FBT, BT_TRACE, ("BT_idle, "));
-               if (pHalData->bt_coexist.CurrentState & BT_COEX_STATE_PROFILE_HID)
-                       RTPRINT(FBT, BT_TRACE, ("PRO_HID, "));
-               if (pHalData->bt_coexist.CurrentState & BT_COEX_STATE_PROFILE_A2DP)
-                       RTPRINT(FBT, BT_TRACE, ("PRO_A2DP, "));
-               if (pHalData->bt_coexist.CurrentState & BT_COEX_STATE_PROFILE_PAN)
-                       RTPRINT(FBT, BT_TRACE, ("PRO_PAN, "));
-               if (pHalData->bt_coexist.CurrentState & BT_COEX_STATE_PROFILE_SCO)
-                       RTPRINT(FBT, BT_TRACE, ("PRO_SCO, "));
-               RTPRINT(FBT, BT_TRACE, ("]\n"));
-       }
-}
-
-/*  extern function start with BTDM_ */
-u32 BTDM_BtTxRxCounterH(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       u32     counters;
-
-       counters = pHalData->bt_coexist.halCoex8723.highPriorityTx+
-               pHalData->bt_coexist.halCoex8723.highPriorityRx;
-       return counters;
-}
-
-u32 BTDM_BtTxRxCounterL(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       u32     counters;
-
-       counters = pHalData->bt_coexist.halCoex8723.lowPriorityTx+
-               pHalData->bt_coexist.halCoex8723.lowPriorityRx;
-       return counters;
-}
-
-void BTDM_SetFwChnlInfo(struct rtw_adapter *padapter, enum rt_media_status mstatus)
-{
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-       u8 H2C_Parameter[3] = {0};
-       u8 chnl;
-
-       /*  opMode */
-       if (RT_MEDIA_CONNECT == mstatus)
-               H2C_Parameter[0] = 0x1; /*  0: disconnected, 1:connected */
-
-       if (check_fwstate(&padapter->mlmepriv, WIFI_ASOC_STATE)) {
-               /*  channel */
-               chnl = pmlmeext->cur_channel;
-               if (BTDM_IsHT40(padapter)) {
-                       if (pmlmeext->cur_ch_offset == HAL_PRIME_CHNL_OFFSET_UPPER)
-                               chnl -= 2;
-                       else if (pmlmeext->cur_ch_offset == HAL_PRIME_CHNL_OFFSET_LOWER)
-                               chnl += 2;
-               }
-               H2C_Parameter[1] = chnl;
-       } else {        /*  check if HS link is exists */
-               /*  channel */
-               if (BT_Operation(padapter))
-                       H2C_Parameter[1] = pBtMgnt->BTChannel;
-               else
-                       H2C_Parameter[1] = pmlmeext->cur_channel;
-       }
-
-       if (BTDM_IsHT40(padapter))
-               H2C_Parameter[2] = 0x30;
-       else
-               H2C_Parameter[2] = 0x20;
-
-       FillH2CCmd(padapter, 0x19, 3, H2C_Parameter);
-}
-
-u8 BTDM_IsWifiConnectionExist(struct rtw_adapter *padapter)
-{
-       u8 bRet = false;
-
-       if (BTHCI_HsConnectionEstablished(padapter))
-               bRet = true;
-
-       if (check_fwstate(&padapter->mlmepriv, WIFI_ASOC_STATE) == true)
-               bRet = true;
-
-       return bRet;
-}
-
-void BTDM_SetFw3a(
-       struct rtw_adapter *padapter,
-       u8 byte1,
-       u8 byte2,
-       u8 byte3,
-       u8 byte4,
-       u8 byte5
-       )
-{
-       u8 H2C_Parameter[5] = {0};
-
-       if (rtl8723a_BT_using_antenna_1(padapter)) {
-               if ((!check_fwstate(&padapter->mlmepriv, WIFI_STATION_STATE)) &&
-                   (get_fwstate(&padapter->mlmepriv) != WIFI_NULL_STATE)) {
-                       /*  for softap mode */
-                       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-                       struct bt_coexist_8723a *pBtCoex = &pHalData->bt_coexist.halCoex8723;
-                       u8 BtState = pBtCoex->c2hBtInfo;
-
-                       if ((BtState != BT_INFO_STATE_NO_CONNECTION) &&
-                           (BtState != BT_INFO_STATE_CONNECT_IDLE)) {
-                               if (byte1 & BIT(4)) {
-                                       byte1 &= ~BIT(4);
-                                       byte1 |= BIT(5);
-                               }
-
-                               byte5 |= BIT(5);
-                               if (byte5 & BIT(6))
-                                       byte5 &= ~BIT(6);
-                       }
-               }
-       }
-
-       H2C_Parameter[0] = byte1;
-       H2C_Parameter[1] = byte2;
-       H2C_Parameter[2] = byte3;
-       H2C_Parameter[3] = byte4;
-       H2C_Parameter[4] = byte5;
-
-       RTPRINT(FBT, BT_TRACE, ("[BTCoex], FW write 0x3a(5bytes) = 0x%02x%08x\n",
-               H2C_Parameter[0],
-               H2C_Parameter[1]<<24|H2C_Parameter[2]<<16|H2C_Parameter[3]<<8|H2C_Parameter[4]));
-
-       FillH2CCmd(padapter, 0x3a, 5, H2C_Parameter);
-}
-
-void BTDM_QueryBtInformation(struct rtw_adapter *padapter)
-{
-       u8 H2C_Parameter[1] = {0};
-       struct hal_data_8723a *pHalData;
-       struct bt_coexist_8723a *pBtCoex;
-
-       pHalData = GET_HAL_DATA(padapter);
-       pBtCoex = &pHalData->bt_coexist.halCoex8723;
-
-       if (!rtl8723a_BT_enabled(padapter)) {
-               pBtCoex->c2hBtInfo = BT_INFO_STATE_DISABLED;
-               pBtCoex->bC2hBtInfoReqSent = false;
-               return;
-       }
-
-       if (pBtCoex->c2hBtInfo == BT_INFO_STATE_DISABLED)
-               pBtCoex->c2hBtInfo = BT_INFO_STATE_NO_CONNECTION;
-
-       if (pBtCoex->bC2hBtInfoReqSent == true)
-               RTPRINT(FBT, BT_TRACE, ("[BTCoex], didn't recv previous BtInfo report!\n"));
-       else
-               pBtCoex->bC2hBtInfoReqSent = true;
-
-       H2C_Parameter[0] |= BIT(0);     /*  trigger */
-
-/*RTPRINT(FBT, BT_TRACE, ("[BTCoex], Query Bt information, write 0x38 = 0x%x\n", */
-/*H2C_Parameter[0])); */
-
-       FillH2CCmd(padapter, 0x38, 1, H2C_Parameter);
-}
-
-void BTDM_SetSwRfRxLpfCorner(struct rtw_adapter *padapter, u8 type)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-
-       if (BT_RF_RX_LPF_CORNER_SHRINK == type) {
-               /* Shrink RF Rx LPF corner */
-               RTPRINT(FBT, BT_TRACE, ("Shrink RF Rx LPF corner!!\n"));
-               PHY_SetRFReg(padapter, PathA, 0x1e, bRFRegOffsetMask, 0xf0ff7);
-               pHalData->bt_coexist.bSWCoexistAllOff = false;
-       } else if (BT_RF_RX_LPF_CORNER_RESUME == type) {
-               /* Resume RF Rx LPF corner */
-               RTPRINT(FBT, BT_TRACE, ("Resume RF Rx LPF corner!!\n"));
-               PHY_SetRFReg(padapter, PathA, 0x1e, bRFRegOffsetMask, pHalData->bt_coexist.BtRfRegOrigin1E);
-       }
-}
-
-void
-BTDM_SetSwPenaltyTxRateAdaptive(
-       struct rtw_adapter *padapter,
-       u8 raType
-       )
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       u8 tmpU1;
-
-       tmpU1 = rtl8723au_read8(padapter, 0x4fd);
-       tmpU1 |= BIT(0);
-       if (BT_TX_RATE_ADAPTIVE_LOW_PENALTY == raType) {
-               tmpU1 &= ~BIT(2);
-               pHalData->bt_coexist.bSWCoexistAllOff = false;
-       } else if (BT_TX_RATE_ADAPTIVE_NORMAL == raType) {
-               tmpU1 |= BIT(2);
-       }
-
-       rtl8723au_write8(padapter, 0x4fd, tmpU1);
-}
-
-void BTDM_SetFwDecBtPwr(struct rtw_adapter *padapter, u8 bDecBtPwr)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       u8 H2C_Parameter[1] = {0};
-
-       H2C_Parameter[0] = 0;
-
-       if (bDecBtPwr) {
-               H2C_Parameter[0] |= BIT(1);
-               pHalData->bt_coexist.bFWCoexistAllOff = false;
-       }
-
-       RTPRINT(FBT, BT_TRACE, ("[BTCoex], decrease Bt Power : %s, write 0x21 = 0x%x\n",
-               (bDecBtPwr ? "Yes!!" : "No!!"), H2C_Parameter[0]));
-
-       FillH2CCmd(padapter, 0x21, 1, H2C_Parameter);
-}
-
-u8 BTDM_BtProfileSupport(struct rtw_adapter *padapter)
-{
-       u8 bRet = false;
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-
-       if (pBtMgnt->bSupportProfile &&
-           !pHalData->bt_coexist.halCoex8723.bForceFwBtInfo)
-               bRet = true;
-
-       return bRet;
-}
-
-static void BTDM_AdjustForBtOperation8723A(struct rtw_adapter *padapter)
-{
-       /* BTDM_2AntAdjustForBtOperation8723(padapter); */
-}
-
-static void BTDM_FwC2hBtRssi8723A(struct rtw_adapter *padapter, u8 *tmpBuf)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       u8 percent, u1tmp;
-
-       u1tmp = tmpBuf[0];
-       percent = u1tmp*2+10;
-
-       pHalData->bt_coexist.halCoex8723.btRssi = percent;
-/*RTPRINT(FBT, BT_TRACE, ("[BTC2H], BT RSSI =%d\n", percent)); */
-}
-
-void
-rtl8723a_fw_c2h_BT_info(struct rtw_adapter *padapter, u8 *tmpBuf, u8 length)
-{
-       struct hal_data_8723a *pHalData;
-       struct bt_30info *pBTInfo;
-       struct bt_mgnt *pBtMgnt;
-       struct bt_coexist_8723a *pBtCoex;
-       u8 i;
-
-       pHalData = GET_HAL_DATA(padapter);
-       pBTInfo = GET_BT_INFO(padapter);
-       pBtMgnt = &pBTInfo->BtMgnt;
-       pBtCoex = &pHalData->bt_coexist.halCoex8723;
-
-       pBtCoex->bC2hBtInfoReqSent = false;
-
-       RTPRINT(FBT, BT_TRACE, ("[BTC2H], BT info[%d]=[", length));
-
-       pBtCoex->btRetryCnt = 0;
-       for (i = 0; i < length; i++) {
-               switch (i) {
-               case 0:
-                       pBtCoex->c2hBtInfoOriginal = tmpBuf[i];
-                       break;
-               case 1:
-                       pBtCoex->btRetryCnt = tmpBuf[i];
-                       break;
-               case 2:
-                       BTDM_FwC2hBtRssi8723A(padapter, &tmpBuf[i]);
-                       break;
-               case 3:
-                       pBtCoex->btInfoExt = tmpBuf[i]&BIT(0);
-                       break;
-               }
-
-               if (i == length-1)
-                       RTPRINT(FBT, BT_TRACE, ("0x%02x]\n", tmpBuf[i]));
-               else
-                       RTPRINT(FBT, BT_TRACE, ("0x%02x, ", tmpBuf[i]));
-       }
-       RTPRINT(FBT, BT_TRACE, ("[BTC2H], BT RSSI =%d\n", pBtCoex->btRssi));
-       if (pBtCoex->btInfoExt)
-               RTPRINT(FBT, BT_TRACE, ("[BTC2H], pBtCoex->btInfoExt =%x\n", pBtCoex->btInfoExt));
-
-       if (btdm_BtWifiAntNum(padapter) == Ant_x1)
-               BTDM_1AntFwC2hBtInfo8723A(padapter);
-       else
-               BTDM_2AntFwC2hBtInfo8723A(padapter);
-
-       if (pBtMgnt->ExtConfig.bManualControl) {
-               RTPRINT(FBT, BT_TRACE, ("%s: Action Manual control!!\n", __func__));
-               return;
-       }
-
-       btdm_BTCoexist8723AHandler(padapter);
-}
-
-static void BTDM_Display8723ABtCoexInfo(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       struct bt_coexist_8723a *pBtCoex = &pHalData->bt_coexist.halCoex8723;
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-       u8 u1Tmp, u1Tmp1, u1Tmp2, i, btInfoExt, psTdmaCase = 0;
-       u32 u4Tmp[4];
-       u8 antNum = Ant_x2;
-
-       snprintf(btCoexDbgBuf, BT_TMP_BUF_SIZE, "\r\n ============[BT Coexist info]============");
-       DCMD_Printf(btCoexDbgBuf);
-
-       if (!rtl8723a_BT_coexist(padapter)) {
-               snprintf(btCoexDbgBuf, BT_TMP_BUF_SIZE, "\r\n BT not exists !!!");
-               DCMD_Printf(btCoexDbgBuf);
-               return;
-       }
-
-       antNum = btdm_BtWifiAntNum(padapter);
-       snprintf(btCoexDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d/%d ", "Ant mechanism PG/Now run :", \
-               ((pHalData->bt_coexist.BT_Ant_Num == Ant_x2) ? 2 : 1), ((antNum == Ant_x2) ? 2 : 1));
-       DCMD_Printf(btCoexDbgBuf);
-
-       if (pBtMgnt->ExtConfig.bManualControl) {
-               snprintf(btCoexDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "[Action Manual control]!!");
-               DCMD_Printf(btCoexDbgBuf);
-       } else {
-               snprintf(btCoexDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s / %d", "BT stack/ hci ext ver", \
-                       ((pBtMgnt->bSupportProfile) ? "Yes" : "No"), pBtMgnt->ExtConfig.HCIExtensionVer);
-               DCMD_Printf(btCoexDbgBuf);
-       }
-
-       snprintf(btCoexDbgBuf, BT_TMP_BUF_SIZE, "\n %-35s = / %d", "Dot11 channel / BT channel", \
-               pBtMgnt->BTChannel);
-               DCMD_Printf(btCoexDbgBuf);
-
-       snprintf(btCoexDbgBuf, BT_TMP_BUF_SIZE, "\n %-35s = %d / %d / %d", "Wifi/BT/HS rssi", \
-               BTDM_GetRxSS(padapter),
-               pHalData->bt_coexist.halCoex8723.btRssi,
-               pHalData->dmpriv.EntryMinUndecoratedSmoothedPWDB);
-                       DCMD_Printf(btCoexDbgBuf);
-
-       if (!pBtMgnt->ExtConfig.bManualControl) {
-               snprintf(btCoexDbgBuf, BT_TMP_BUF_SIZE, "\n %-35s = %s / %s ", "WIfi status",
-                       ((BTDM_Legacy(padapter)) ? "Legacy" : (((BTDM_IsHT40(padapter)) ? "HT40" : "HT20"))),
-                       ((!BTDM_IsWifiBusy(padapter)) ? "idle" : ((BTDM_IsWifiUplink(padapter)) ? "uplink" : "downlink")));
-               DCMD_Printf(btCoexDbgBuf);
-
-               if (pBtMgnt->bSupportProfile) {
-                       snprintf(btCoexDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d / %d / %d / %d", "SCO/HID/PAN/A2DP",
-                               ((BTHCI_CheckProfileExist(padapter, BT_PROFILE_SCO)) ? 1 : 0),
-                               ((BTHCI_CheckProfileExist(padapter, BT_PROFILE_HID)) ? 1 : 0),
-                               ((BTHCI_CheckProfileExist(padapter, BT_PROFILE_PAN)) ? 1 : 0),
-                               ((BTHCI_CheckProfileExist(padapter, BT_PROFILE_A2DP)) ? 1 : 0));
-               DCMD_Printf(btCoexDbgBuf);
-
-                       for (i = 0; i < pBtMgnt->ExtConfig.NumberOfHandle; i++) {
-                               if (pBtMgnt->ExtConfig.HCIExtensionVer >= 1) {
-                                       snprintf(btCoexDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %s/ %s", "Bt link type/spec/role",
-                                               BtProfileString[pBtMgnt->ExtConfig.linkInfo[i].BTProfile],
-                                               BtSpecString[pBtMgnt->ExtConfig.linkInfo[i].BTCoreSpec],
-                                               BtLinkRoleString[pBtMgnt->ExtConfig.linkInfo[i].linkRole]);
-                                       DCMD_Printf(btCoexDbgBuf);
-
-                                       btInfoExt = pHalData->bt_coexist.halCoex8723.btInfoExt;
-                                       snprintf(btCoexDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s", "A2DP rate", \
-                                                (btInfoExt & BIT(0)) ?
-                                                "Basic rate" : "EDR rate");
-                                       DCMD_Printf(btCoexDbgBuf);
-                               } else {
-                                       snprintf(btCoexDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %s/ %s", "Bt link type/spec", \
-                                               BtProfileString[pBtMgnt->ExtConfig.linkInfo[i].BTProfile],
-                                               BtSpecString[pBtMgnt->ExtConfig.linkInfo[i].BTCoreSpec]);
-                                       DCMD_Printf(btCoexDbgBuf);
-                               }
-                       }
-               }
-       }
-
-       /*  Sw mechanism */
-       if (!pBtMgnt->ExtConfig.bManualControl) {
-               snprintf(btCoexDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Sw BT Coex mechanism]============");
-               DCMD_Printf(btCoexDbgBuf);
-               snprintf(btCoexDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d ", "AGC Table", \
-                       pBtCoex->btdm2Ant.bCurAgcTableEn);
-               DCMD_Printf(btCoexDbgBuf);
-               snprintf(btCoexDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d ", "ADC Backoff", \
-                       pBtCoex->btdm2Ant.bCurAdcBackOff);
-               DCMD_Printf(btCoexDbgBuf);
-               snprintf(btCoexDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d ", "Low penalty RA", \
-                       pBtCoex->btdm2Ant.bCurLowPenaltyRa);
-               DCMD_Printf(btCoexDbgBuf);
-               snprintf(btCoexDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d ", "RF Rx LPF Shrink", \
-                       pBtCoex->btdm2Ant.bCurRfRxLpfShrink);
-               DCMD_Printf(btCoexDbgBuf);
-       }
-       u4Tmp[0] = PHY_QueryRFReg(padapter, PathA, 0x1e, 0xff0);
-       snprintf(btCoexDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x", "RF-A, 0x1e[11:4]/original val", \
-               u4Tmp[0], pHalData->bt_coexist.BtRfRegOrigin1E);
-       DCMD_Printf(btCoexDbgBuf);
-
-       /*  Fw mechanism */
-       if (!pBtMgnt->ExtConfig.bManualControl) {
-               snprintf(btCoexDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Fw BT Coex mechanism]============");
-               DCMD_Printf(btCoexDbgBuf);
-       }
-       if (!pBtMgnt->ExtConfig.bManualControl) {
-               if (btdm_BtWifiAntNum(padapter) == Ant_x1)
-                       psTdmaCase = pHalData->bt_coexist.halCoex8723.btdm1Ant.curPsTdma;
-               else
-                       psTdmaCase = pHalData->bt_coexist.halCoex8723.btdm2Ant.curPsTdma;
-               snprintf(btCoexDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %*ph case-%d",
-                        "PS TDMA(0x3a)", 5, pHalData->bt_coexist.fw3aVal, psTdmaCase);
-               DCMD_Printf(btCoexDbgBuf);
-
-               snprintf(btCoexDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d ", "Decrease Bt Power", \
-                       pBtCoex->btdm2Ant.bCurDecBtPwr);
-               DCMD_Printf(btCoexDbgBuf);
-       }
-       u1Tmp = rtl8723au_read8(padapter, 0x778);
-       u1Tmp1 = rtl8723au_read8(padapter, 0x783);
-       u1Tmp2 = rtl8723au_read8(padapter, 0x796);
-       snprintf(btCoexDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x", "0x778/ 0x783/ 0x796", \
-               u1Tmp, u1Tmp1, u1Tmp2);
-       DCMD_Printf(btCoexDbgBuf);
-
-       if (!pBtMgnt->ExtConfig.bManualControl) {
-               snprintf(btCoexDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x / 0x%x", "Sw DacSwing Ctrl/Val", \
-                       pBtCoex->btdm2Ant.bCurDacSwingOn, pBtCoex->btdm2Ant.curDacSwingLvl);
-               DCMD_Printf(btCoexDbgBuf);
-       }
-       u4Tmp[0] =  rtl8723au_read32(padapter, 0x880);
-       snprintf(btCoexDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0x880", \
-               u4Tmp[0]);
-       DCMD_Printf(btCoexDbgBuf);
-
-       /*  Hw mechanism */
-       if (!pBtMgnt->ExtConfig.bManualControl) {
-               snprintf(btCoexDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s", "============[Hw BT Coex mechanism]============");
-               DCMD_Printf(btCoexDbgBuf);
-       }
-
-       u1Tmp = rtl8723au_read8(padapter, 0x40);
-       snprintf(btCoexDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0x40", \
-               u1Tmp);
-       DCMD_Printf(btCoexDbgBuf);
-
-       u4Tmp[0] = rtl8723au_read32(padapter, 0x550);
-       u1Tmp = rtl8723au_read8(padapter, 0x522);
-       snprintf(btCoexDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/0x%x", "0x550(bcn contrl)/0x522", \
-               u4Tmp[0], u1Tmp);
-       DCMD_Printf(btCoexDbgBuf);
-
-       u4Tmp[0] = rtl8723au_read32(padapter, 0x484);
-       snprintf(btCoexDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0x484(rate adaptive)", \
-               u4Tmp[0]);
-       DCMD_Printf(btCoexDbgBuf);
-
-       u4Tmp[0] = rtl8723au_read32(padapter, 0x50);
-       snprintf(btCoexDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0xc50(dig)", \
-               u4Tmp[0]);
-       DCMD_Printf(btCoexDbgBuf);
-
-       u4Tmp[0] = rtl8723au_read32(padapter, 0xda0);
-       u4Tmp[1] = rtl8723au_read32(padapter, 0xda4);
-       u4Tmp[2] = rtl8723au_read32(padapter, 0xda8);
-       u4Tmp[3] = rtl8723au_read32(padapter, 0xdac);
-       snprintf(btCoexDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x", "0xda0/0xda4/0xda8/0xdac(FA cnt)", \
-               u4Tmp[0], u4Tmp[1], u4Tmp[2], u4Tmp[3]);
-       DCMD_Printf(btCoexDbgBuf);
-
-       u4Tmp[0] = rtl8723au_read32(padapter, 0x6c0);
-       u4Tmp[1] = rtl8723au_read32(padapter, 0x6c4);
-       u4Tmp[2] = rtl8723au_read32(padapter, 0x6c8);
-       u1Tmp = rtl8723au_read8(padapter, 0x6cc);
-       snprintf(btCoexDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x", "0x6c0/0x6c4/0x6c8/0x6cc(coexTable)", \
-               u4Tmp[0], u4Tmp[1], u4Tmp[2], u1Tmp);
-       DCMD_Printf(btCoexDbgBuf);
-
-       /* u4Tmp = rtl8723au_read32(padapter, 0x770); */
-       snprintf(btCoexDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d / %d", "0x770(Hi pri Rx[31:16]/Tx[15:0])", \
-               pHalData->bt_coexist.halCoex8723.highPriorityRx,
-               pHalData->bt_coexist.halCoex8723.highPriorityTx);
-       DCMD_Printf(btCoexDbgBuf);
-       /* u4Tmp = rtl8723au_read32(padapter, 0x774); */
-       snprintf(btCoexDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = %d / %d", "0x774(Lo pri Rx[31:16]/Tx[15:0])", \
-               pHalData->bt_coexist.halCoex8723.lowPriorityRx,
-               pHalData->bt_coexist.halCoex8723.lowPriorityTx);
-       DCMD_Printf(btCoexDbgBuf);
-
-       /*  Tx mgnt queue hang or not, 0x41b should = 0xf, ex: 0xd ==>hang */
-       u1Tmp = rtl8723au_read8(padapter, 0x41b);
-       snprintf(btCoexDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "0x41b (hang chk == 0xf)", \
-               u1Tmp);
-       DCMD_Printf(btCoexDbgBuf);
-       snprintf(btCoexDbgBuf, BT_TMP_BUF_SIZE, "\r\n %-35s = 0x%x", "lastHMEBoxNum", \
-               pHalData->LastHMEBoxNum);
-       DCMD_Printf(btCoexDbgBuf);
-}
-
-static void
-BTDM_8723ASignalCompensation(struct rtw_adapter *padapter,
-                            u8 *rssi_wifi, u8 *rssi_bt)
-{
-       if (btdm_BtWifiAntNum(padapter) == Ant_x1)
-               BTDM_1AntSignalCompensation(padapter, rssi_wifi, rssi_bt);
-}
-
-static void BTDM_8723AInit(struct rtw_adapter *padapter)
-{
-       if (btdm_BtWifiAntNum(padapter) == Ant_x2)
-               BTDM_2AntParaInit(padapter);
-       else
-               BTDM_1AntParaInit(padapter);
-}
-
-static void BTDM_HWCoexAllOff8723A(struct rtw_adapter *padapter)
-{
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-
-       if (pBtMgnt->ExtConfig.bManualControl)
-               return;
-
-       if (btdm_BtWifiAntNum(padapter) == Ant_x2)
-               BTDM_2AntHwCoexAllOff8723A(padapter);
-}
-
-static void BTDM_FWCoexAllOff8723A(struct rtw_adapter *padapter)
-{
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-
-       if (pBtMgnt->ExtConfig.bManualControl)
-               return;
-
-       if (btdm_BtWifiAntNum(padapter) == Ant_x2)
-               BTDM_2AntFwCoexAllOff8723A(padapter);
-}
-
-static void BTDM_SWCoexAllOff8723A(struct rtw_adapter *padapter)
-{
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-
-       if (pBtMgnt->ExtConfig.bManualControl)
-               return;
-
-       if (btdm_BtWifiAntNum(padapter) == Ant_x2)
-               BTDM_2AntSwCoexAllOff8723A(padapter);
-}
-
-static void
-BTDM_Set8723ABtCoexCurrAntNum(struct rtw_adapter *padapter, u8 antNum)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       struct bt_coexist_8723a *pBtCoex = &pHalData->bt_coexist.halCoex8723;
-
-       if (antNum == 1)
-               pBtCoex->TotalAntNum = Ant_x1;
-       else if (antNum == 2)
-               pBtCoex->TotalAntNum = Ant_x2;
-}
-
-void rtl8723a_BT_lps_leave(struct rtw_adapter *padapter)
-{
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-
-       if (pBtMgnt->ExtConfig.bManualControl)
-               return;
-
-       if (btdm_BtWifiAntNum(padapter) == Ant_x1)
-               BTDM_1AntLpsLeave(padapter);
-}
-
-static void BTDM_ForHalt8723A(struct rtw_adapter *padapter)
-{
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-
-       if (pBtMgnt->ExtConfig.bManualControl)
-               return;
-
-       if (btdm_BtWifiAntNum(padapter) == Ant_x1)
-               BTDM_1AntForHalt(padapter);
-}
-
-static void BTDM_WifiScanNotify8723A(struct rtw_adapter *padapter, u8 scanType)
-{
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-
-       if (pBtMgnt->ExtConfig.bManualControl)
-               return;
-
-       if (btdm_BtWifiAntNum(padapter) == Ant_x1)
-               BTDM_1AntWifiScanNotify(padapter, scanType);
-}
-
-static void
-BTDM_WifiAssociateNotify8723A(struct rtw_adapter *padapter, u8 action)
-{
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-
-       if (pBtMgnt->ExtConfig.bManualControl)
-               return;
-
-       if (btdm_BtWifiAntNum(padapter) == Ant_x1)
-               BTDM_1AntWifiAssociateNotify(padapter, action);
-}
-
-static void
-BTDM_MediaStatusNotify8723A(struct rtw_adapter *padapter,
-                           enum rt_media_status mstatus)
-{
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-
-       RTPRINT(FBT, BT_TRACE, ("[BTCoex], MediaStatusNotify, %s\n",
-               mstatus?"connect":"disconnect"));
-
-       BTDM_SetFwChnlInfo(padapter, mstatus);
-
-       if (pBtMgnt->ExtConfig.bManualControl)
-               return;
-
-       if (btdm_BtWifiAntNum(padapter) == Ant_x1)
-               BTDM_1AntMediaStatusNotify(padapter, mstatus);
-}
-
-static void BTDM_ForDhcp8723A(struct rtw_adapter *padapter)
-{
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-
-       if (pBtMgnt->ExtConfig.bManualControl)
-               return;
-
-       if (btdm_BtWifiAntNum(padapter) == Ant_x1)
-               BTDM_1AntForDhcp(padapter);
-}
-
-bool rtl8723a_BT_using_antenna_1(struct rtw_adapter *padapter)
-{
-       if (btdm_BtWifiAntNum(padapter) == Ant_x1)
-               return true;
-       else
-               return false;
-}
-
-static void BTDM_BTCoexist8723A(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData;
-       struct bt_30info *pBTInfo;
-       struct bt_mgnt *pBtMgnt;
-       struct bt_coexist_8723a *pBtCoex;
-
-       pHalData = GET_HAL_DATA(padapter);
-       pBTInfo = GET_BT_INFO(padapter);
-       pBtMgnt = &pBTInfo->BtMgnt;
-       pBtCoex = &pHalData->bt_coexist.halCoex8723;
-
-       RTPRINT(FBT, BT_TRACE, ("[BTCoex], beacon RSSI = 0x%x(%d)\n",
-               pHalData->dmpriv.EntryMinUndecoratedSmoothedPWDB,
-               pHalData->dmpriv.EntryMinUndecoratedSmoothedPWDB));
-
-       btdm_BtHwCountersMonitor(padapter);
-       btdm_BtEnableDisableCheck8723A(padapter);
-
-       if (pBtMgnt->ExtConfig.bManualControl) {
-               RTPRINT(FBT, BT_TRACE, ("%s: Action Manual control!!\n", __func__));
-               return;
-       }
-
-       if (pBtCoex->bC2hBtInfoReqSent) {
-               if (!rtl8723a_BT_enabled(padapter)) {
-                       pBtCoex->c2hBtInfo = BT_INFO_STATE_DISABLED;
-               } else {
-                       if (pBtCoex->c2hBtInfo == BT_INFO_STATE_DISABLED)
-                               pBtCoex->c2hBtInfo = BT_INFO_STATE_NO_CONNECTION;
-               }
-
-               btdm_BTCoexist8723AHandler(padapter);
-       } else if (!rtl8723a_BT_enabled(padapter)) {
-               pBtCoex->c2hBtInfo = BT_INFO_STATE_DISABLED;
-               btdm_BTCoexist8723AHandler(padapter);
-       }
-
-       BTDM_QueryBtInformation(padapter);
-}
-
-/*  ===== End of sync from SD7 driver HAL/BTCoexist/HalBtc8723.c ===== */
-
-/*  ===== Below this line is sync from SD7 driver HAL/BTCoexist/HalBtcCsr1Ant.c ===== */
-
-/*  local function start with btdm_ */
-/*  extern function start with BTDM_ */
-
-static void BTDM_SetAntenna(struct rtw_adapter *padapter, u8 who)
-{
-}
-
-void
-BTDM_SingleAnt(
-       struct rtw_adapter *padapter,
-       u8 bSingleAntOn,
-       u8 bInterruptOn,
-       u8 bMultiNAVOn
-       )
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       u8 H2C_Parameter[3] = {0};
-
-       if (pHalData->bt_coexist.BT_Ant_Num != Ant_x1)
-               return;
-
-       H2C_Parameter[2] = 0;
-       H2C_Parameter[1] = 0;
-       H2C_Parameter[0] = 0;
-
-       if (bInterruptOn) {
-               H2C_Parameter[2] |= 0x02;       /* BIT1 */
-               pHalData->bt_coexist.bFWCoexistAllOff = false;
-       }
-       pHalData->bt_coexist.bInterruptOn = bInterruptOn;
-
-       if (bSingleAntOn) {
-               H2C_Parameter[2] |= 0x10;       /* BIT4 */
-               pHalData->bt_coexist.bFWCoexistAllOff = false;
-       }
-       pHalData->bt_coexist.bSingleAntOn = bSingleAntOn;
-
-       if (bMultiNAVOn) {
-               H2C_Parameter[2] |= 0x20;       /* BIT5 */
-               pHalData->bt_coexist.bFWCoexistAllOff = false;
-       }
-       pHalData->bt_coexist.bMultiNAVOn = bMultiNAVOn;
-
-       RTPRINT(FBT, BT_TRACE, ("[DM][BT], SingleAntenna =[%s:%s:%s], write 0xe = 0x%x\n",
-               bSingleAntOn?"ON":"OFF", bInterruptOn?"ON":"OFF", bMultiNAVOn?"ON":"OFF",
-               H2C_Parameter[0]<<16|H2C_Parameter[1]<<8|H2C_Parameter[2]));
-}
-
-void BTDM_CheckBTIdleChange1Ant(struct rtw_adapter *padapter)
-{
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-/*PMGNT_INFO           pMgntInfo = &padapter->MgntInfo; */
-       u8      stateChange = false;
-       u32                     BT_Polling, Ratio_Act, Ratio_STA;
-       u32                             BT_Active, BT_State;
-       u32                             regBTActive = 0, regBTState = 0, regBTPolling = 0;
-
-       if (!rtl8723a_BT_coexist(padapter))
-               return;
-       if (pBtMgnt->ExtConfig.bManualControl)
-               return;
-       if (pHalData->bt_coexist.BT_CoexistType != BT_CSR_BC8)
-               return;
-       if (pHalData->bt_coexist.BT_Ant_Num != Ant_x1)
-               return;
-
-       /*  The following we only consider CSR BC8 and fw version should be >= 62 */
-       RTPRINT(FBT, BT_TRACE, ("[DM][BT], FirmwareVersion = 0x%x(%d)\n",
-       pHalData->FirmwareVersion, pHalData->FirmwareVersion));
-       regBTActive = REG_BT_ACTIVE;
-       regBTState = REG_BT_STATE;
-       if (pHalData->FirmwareVersion >= FW_VER_BT_REG1)
-               regBTPolling = REG_BT_POLLING1;
-       else
-               regBTPolling = REG_BT_POLLING;
-
-       BT_Active = rtl8723au_read32(padapter, regBTActive);
-       RTPRINT(FBT, BT_TRACE, ("[DM][BT], BT_Active(0x%x) =%x\n", regBTActive, BT_Active));
-       BT_Active = BT_Active & 0x00ffffff;
-
-       BT_State = rtl8723au_read32(padapter, regBTState);
-       RTPRINT(FBT, BT_TRACE, ("[DM][BT], BT_State(0x%x) =%x\n", regBTState, BT_State));
-       BT_State = BT_State & 0x00ffffff;
-
-       BT_Polling = rtl8723au_read32(padapter, regBTPolling);
-       RTPRINT(FBT, BT_TRACE, ("[DM][BT], BT_Polling(0x%x) =%x\n", regBTPolling, BT_Polling));
-
-       if (BT_Active == 0x00ffffff && BT_State == 0x00ffffff && BT_Polling == 0xffffffff)
-               return;
-       if (BT_Polling == 0)
-               return;
-
-       Ratio_Act = BT_Active*1000/BT_Polling;
-       Ratio_STA = BT_State*1000/BT_Polling;
-
-       pHalData->bt_coexist.Ratio_Tx = Ratio_Act;
-       pHalData->bt_coexist.Ratio_PRI = Ratio_STA;
-
-       RTPRINT(FBT, BT_TRACE, ("[DM][BT], Ratio_Act =%d\n", Ratio_Act));
-       RTPRINT(FBT, BT_TRACE, ("[DM][BT], Ratio_STA =%d\n", Ratio_STA));
-
-       if (Ratio_STA < 60 && Ratio_Act < 500) {        /*  BT PAN idle */
-               pHalData->bt_coexist.CurrentState |= BT_COEX_STATE_BT_PAN_IDLE;
-               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_BT_PAN_DOWNLINK;
-               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_BT_PAN_UPLINK;
-       } else {
-               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_BT_PAN_IDLE;
-
-               if (Ratio_STA) {
-                       /*  Check if BT PAN (under BT 2.1) is uplink or downlink */
-                       if ((Ratio_Act/Ratio_STA) < 2) {
-                               /*  BT PAN Uplink */
-                               pHalData->bt_coexist.BT21TrafficStatistics.bTxBusyTraffic = true;
-                               pHalData->bt_coexist.CurrentState |= BT_COEX_STATE_BT_PAN_UPLINK;
-                               pHalData->bt_coexist.BT21TrafficStatistics.bRxBusyTraffic = false;
-                               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_BT_PAN_DOWNLINK;
-                       } else {
-                               /*  BT PAN downlink */
-                               pHalData->bt_coexist.BT21TrafficStatistics.bTxBusyTraffic = false;
-                               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_BT_PAN_UPLINK;
-                               pHalData->bt_coexist.BT21TrafficStatistics.bRxBusyTraffic = true;
-                               pHalData->bt_coexist.CurrentState |= BT_COEX_STATE_BT_PAN_DOWNLINK;
-                       }
-               } else {
-                       /*  BT PAN downlink */
-                       pHalData->bt_coexist.BT21TrafficStatistics.bTxBusyTraffic = false;
-                       pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_BT_PAN_UPLINK;
-                       pHalData->bt_coexist.BT21TrafficStatistics.bRxBusyTraffic = true;
-                       pHalData->bt_coexist.CurrentState |= BT_COEX_STATE_BT_PAN_DOWNLINK;
-               }
-       }
-
-       /*  Check BT is idle or not */
-       if (pBtMgnt->ExtConfig.NumberOfHandle == 0 &&
-           pBtMgnt->ExtConfig.NumberOfSCO == 0) {
-               pBtMgnt->ExtConfig.bBTBusy = false;
-               pHalData->bt_coexist.CurrentState |= BT_COEX_STATE_BT_IDLE;
-       } else {
-               if (Ratio_STA < 60) {
-                       pBtMgnt->ExtConfig.bBTBusy = false;
-                       pHalData->bt_coexist.CurrentState |= BT_COEX_STATE_BT_IDLE;
-               } else {
-                       pBtMgnt->ExtConfig.bBTBusy = true;
-                       pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_BT_IDLE;
-               }
-       }
-
-       if (pBtMgnt->ExtConfig.NumberOfHandle == 0 &&
-           pBtMgnt->ExtConfig.NumberOfSCO == 0) {
-               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_BT_RSSI_LOW;
-               pBtMgnt->ExtConfig.MIN_BT_RSSI = 0;
-               BTDM_SetAntenna(padapter, BTDM_ANT_BT_IDLE);
-       } else {
-               if (pBtMgnt->ExtConfig.MIN_BT_RSSI <= -5) {
-                       pHalData->bt_coexist.CurrentState |= BT_COEX_STATE_BT_RSSI_LOW;
-                       RTPRINT(FBT, BT_TRACE, ("[DM][BT], core stack notify bt rssi Low\n"));
-               } else {
-                       pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_BT_RSSI_LOW;
-                       RTPRINT(FBT, BT_TRACE, ("[DM][BT], core stack notify bt rssi Normal\n"));
-               }
-       }
-
-       if (pHalData->bt_coexist.bBTBusyTraffic != pBtMgnt->ExtConfig.bBTBusy) {
-               /*  BT idle or BT non-idle */
-               pHalData->bt_coexist.bBTBusyTraffic = pBtMgnt->ExtConfig.bBTBusy;
-               stateChange = true;
-       }
-
-       if (stateChange) {
-               if (!pBtMgnt->ExtConfig.bBTBusy)
-                       RTPRINT(FBT, BT_TRACE, ("[DM][BT], BT is idle or disable\n"));
-               else
-                       RTPRINT(FBT, BT_TRACE, ("[DM][BT], BT is non-idle\n"));
-       }
-       if (!pBtMgnt->ExtConfig.bBTBusy) {
-               RTPRINT(FBT, BT_TRACE, ("[DM][BT], BT is idle or disable\n"));
-               if (check_fwstate(&padapter->mlmepriv, WIFI_UNDER_LINKING|WIFI_SITE_MONITOR) == true)
-                       BTDM_SetAntenna(padapter, BTDM_ANT_WIFI);
-       }
-}
-
-/*  ===== End of sync from SD7 driver HAL/BTCoexist/HalBtcCsr1Ant.c ===== */
-
-/*  ===== Below this line is sync from SD7 driver HAL/BTCoexist/HalBtcCsr2Ant.c ===== */
-
-/*  local function start with btdm_ */
-
-/*  Note: */
-/*  In the following, FW should be done before SW mechanism. */
-/*  BTDM_Balance(), BTDM_DiminishWiFi(), BT_NAV() should be done */
-/*  before BTDM_AGCTable(), BTDM_BBBackOffLevel(), btdm_DacSwing(). */
-
-/*  extern function start with BTDM_ */
-
-void
-BTDM_DiminishWiFi(
-       struct rtw_adapter *padapter,
-       u8 bDACOn,
-       u8 bInterruptOn,
-       u8 DACSwingLevel,
-       u8 bNAVOn
-       )
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       u8 H2C_Parameter[3] = {0};
-
-       if (pHalData->bt_coexist.BT_Ant_Num != Ant_x2)
-               return;
-
-       if ((pHalData->bt_coexist.CurrentState & BT_COEX_STATE_BT_RSSI_LOW) &&
-           (DACSwingLevel == 0x20)) {
-               RTPRINT(FBT, BT_TRACE, ("[BT]DiminishWiFi 0x20 original, but set 0x18 for Low RSSI!\n"));
-               DACSwingLevel = 0x18;
-       }
-
-       H2C_Parameter[2] = 0;
-       H2C_Parameter[1] = DACSwingLevel;
-       H2C_Parameter[0] = 0;
-       if (bDACOn) {
-               H2C_Parameter[2] |= 0x01;       /* BIT0 */
-               if (bInterruptOn)
-                       H2C_Parameter[2] |= 0x02;       /* BIT1 */
-               pHalData->bt_coexist.bFWCoexistAllOff = false;
-       }
-       if (bNAVOn) {
-               H2C_Parameter[2] |= 0x08;       /* BIT3 */
-               pHalData->bt_coexist.bFWCoexistAllOff = false;
-       }
-
-       RTPRINT(FBT, BT_TRACE, ("[DM][BT], bDACOn = %s, bInterruptOn = %s, write 0xe = 0x%x\n",
-               bDACOn?"ON":"OFF", bInterruptOn?"ON":"OFF",
-               H2C_Parameter[0]<<16|H2C_Parameter[1]<<8|H2C_Parameter[2]));
-       RTPRINT(FBT, BT_TRACE, ("[DM][BT], bNAVOn = %s\n",
-               bNAVOn?"ON":"OFF"));
-}
-
-/*  ===== End of sync from SD7 driver HAL/BTCoexist/HalBtcCsr2Ant.c ===== */
-
-/*  ===== Below this line is sync from SD7 driver HAL/BTCoexist/HalBtCoexist.c ===== */
-
-/*  local function */
-static void btdm_ResetFWCoexState(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-
-       pHalData->bt_coexist.CurrentState = 0;
-       pHalData->bt_coexist.PreviousState = 0;
-}
-
-static void btdm_InitBtCoexistDM(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-
-       /*  20100415 Joseph: Restore RF register 0x1E and 0x1F value for further usage. */
-       pHalData->bt_coexist.BtRfRegOrigin1E = PHY_QueryRFReg(padapter, PathA, RF_RCK1, bRFRegOffsetMask);
-       pHalData->bt_coexist.BtRfRegOrigin1F = PHY_QueryRFReg(padapter, PathA, RF_RCK2, 0xf0);
-
-       pHalData->bt_coexist.CurrentState = 0;
-       pHalData->bt_coexist.PreviousState = 0;
-
-       BTDM_8723AInit(padapter);
-       pHalData->bt_coexist.bInitlized = true;
-}
-
-/*  */
-/*  extern function */
-/*  */
-void BTDM_CheckAntSelMode(struct rtw_adapter *padapter)
-{
-}
-
-void BTDM_FwC2hBtRssi(struct rtw_adapter *padapter, u8 *tmpBuf)
-{
-       BTDM_FwC2hBtRssi8723A(padapter, tmpBuf);
-}
-
-void BTDM_DisplayBtCoexInfo(struct rtw_adapter *padapter)
-{
-       BTDM_Display8723ABtCoexInfo(padapter);
-}
-
-void BTDM_RejectAPAggregatedPacket(struct rtw_adapter *padapter, u8 bReject)
-{
-}
-
-u8 BTDM_IsHT40(struct rtw_adapter *padapter)
-{
-       u8 isht40 = true;
-       enum ht_channel_width bw;
-
-       bw = padapter->mlmeextpriv.cur_bwmode;
-
-       if (bw == HT_CHANNEL_WIDTH_20)
-               isht40 = false;
-       else if (bw == HT_CHANNEL_WIDTH_40)
-               isht40 = true;
-
-       return isht40;
-}
-
-u8 BTDM_Legacy(struct rtw_adapter *padapter)
-{
-       struct mlme_ext_priv *pmlmeext;
-       u8 isLegacy = false;
-
-       pmlmeext = &padapter->mlmeextpriv;
-       if ((pmlmeext->cur_wireless_mode == WIRELESS_11B) ||
-               (pmlmeext->cur_wireless_mode == WIRELESS_11G) ||
-               (pmlmeext->cur_wireless_mode == WIRELESS_11BG))
-               isLegacy = true;
-
-       return isLegacy;
-}
-
-void BTDM_CheckWiFiState(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData;
-       struct mlme_priv *pmlmepriv;
-       struct bt_30info *pBTInfo;
-       struct bt_mgnt *pBtMgnt;
-
-       pHalData = GET_HAL_DATA(padapter);
-       pmlmepriv = &padapter->mlmepriv;
-       pBTInfo = GET_BT_INFO(padapter);
-       pBtMgnt = &pBTInfo->BtMgnt;
-
-       if (pmlmepriv->LinkDetectInfo.bBusyTraffic) {
-               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_WIFI_IDLE;
-
-               if (pmlmepriv->LinkDetectInfo.bTxBusyTraffic)
-                       pHalData->bt_coexist.CurrentState |= BT_COEX_STATE_WIFI_UPLINK;
-               else
-                       pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_WIFI_UPLINK;
-
-               if (pmlmepriv->LinkDetectInfo.bRxBusyTraffic)
-                       pHalData->bt_coexist.CurrentState |= BT_COEX_STATE_WIFI_DOWNLINK;
-               else
-                       pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_WIFI_DOWNLINK;
-       } else {
-               pHalData->bt_coexist.CurrentState |= BT_COEX_STATE_WIFI_IDLE;
-               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_WIFI_UPLINK;
-               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_WIFI_DOWNLINK;
-       }
-
-       if (BTDM_Legacy(padapter)) {
-               pHalData->bt_coexist.CurrentState |= BT_COEX_STATE_WIFI_LEGACY;
-               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_WIFI_HT20;
-               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_WIFI_HT40;
-       } else {
-               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_WIFI_LEGACY;
-               if (BTDM_IsHT40(padapter)) {
-                       pHalData->bt_coexist.CurrentState |= BT_COEX_STATE_WIFI_HT40;
-                       pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_WIFI_HT20;
-               } else {
-                       pHalData->bt_coexist.CurrentState |= BT_COEX_STATE_WIFI_HT20;
-                       pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_WIFI_HT40;
-               }
-       }
-
-       if (pBtMgnt->BtOperationOn)
-               pHalData->bt_coexist.CurrentState |= BT_COEX_STATE_BT30;
-       else
-               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_BT30;
-}
-
-s32 BTDM_GetRxSS(struct rtw_adapter *padapter)
-{
-/*PMGNT_INFO           pMgntInfo = &padapter->MgntInfo; */
-       struct mlme_priv *pmlmepriv;
-       struct hal_data_8723a *pHalData;
-       s32                     UndecoratedSmoothedPWDB = 0;
-
-       pmlmepriv = &padapter->mlmepriv;
-       pHalData = GET_HAL_DATA(padapter);
-
-       if (check_fwstate(pmlmepriv, _FW_LINKED)) {
-               UndecoratedSmoothedPWDB = GET_UNDECORATED_AVERAGE_RSSI(padapter);
-       } else { /*  associated entry pwdb */
-               UndecoratedSmoothedPWDB = pHalData->dmpriv.EntryMinUndecoratedSmoothedPWDB;
-               /* pHalData->BT_EntryMinUndecoratedSmoothedPWDB */
-       }
-       RTPRINT(FBT, BT_TRACE, ("BTDM_GetRxSS() = %d\n", UndecoratedSmoothedPWDB));
-       return UndecoratedSmoothedPWDB;
-}
-
-static s32 BTDM_GetRxBeaconSS(struct rtw_adapter *padapter)
-{
-/*PMGNT_INFO           pMgntInfo = &padapter->MgntInfo; */
-       struct mlme_priv *pmlmepriv;
-       struct hal_data_8723a *pHalData;
-       s32                     pwdbBeacon = 0;
-
-       pmlmepriv = &padapter->mlmepriv;
-       pHalData = GET_HAL_DATA(padapter);
-
-       if (check_fwstate(pmlmepriv, _FW_LINKED)) {
-               /* pwdbBeacon = pHalData->dmpriv.UndecoratedSmoothedBeacon; */
-               pwdbBeacon = pHalData->dmpriv.EntryMinUndecoratedSmoothedPWDB;
-       }
-       RTPRINT(FBT, BT_TRACE, ("BTDM_GetRxBeaconSS() = %d\n", pwdbBeacon));
-       return pwdbBeacon;
-}
-
-/*  Get beacon rssi state */
-u8 BTDM_CheckCoexBcnRssiState(struct rtw_adapter *padapter, u8 levelNum,
-                             u8 RssiThresh, u8 RssiThresh1)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       s32 pwdbBeacon = 0;
-       u8 bcnRssiState = 0;
-
-       pwdbBeacon = BTDM_GetRxBeaconSS(padapter);
-
-       if (levelNum == 2) {
-               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_WIFI_RSSI_BEACON_MEDIUM;
-
-               if ((pHalData->bt_coexist.preRssiStateBeacon == BT_RSSI_STATE_LOW) ||
-                   (pHalData->bt_coexist.preRssiStateBeacon == BT_RSSI_STATE_STAY_LOW)) {
-                       if (pwdbBeacon >= (RssiThresh+BT_FW_COEX_THRESH_TOL)) {
-                               bcnRssiState = BT_RSSI_STATE_HIGH;
-                               pHalData->bt_coexist.CurrentState |= BT_COEX_STATE_WIFI_RSSI_BEACON_HIGH;
-                               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_WIFI_RSSI_BEACON_LOW;
-                               RTPRINT(FBT, BT_TRACE, ("[DM][BT], RSSI_BEACON state switch to High\n"));
-                       } else {
-                               bcnRssiState = BT_RSSI_STATE_STAY_LOW;
-                               RTPRINT(FBT, BT_TRACE, ("[DM][BT], RSSI_BEACON state stay at Low\n"));
-                       }
-               } else {
-                       if (pwdbBeacon < RssiThresh) {
-                               bcnRssiState = BT_RSSI_STATE_LOW;
-                               pHalData->bt_coexist.CurrentState |= BT_COEX_STATE_WIFI_RSSI_BEACON_LOW;
-                               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_WIFI_RSSI_BEACON_HIGH;
-                               RTPRINT(FBT, BT_TRACE, ("[DM][BT], RSSI_BEACON state switch to Low\n"));
-                       } else {
-                               bcnRssiState = BT_RSSI_STATE_STAY_HIGH;
-                               RTPRINT(FBT, BT_TRACE, ("[DM][BT], RSSI_BEACON state stay at High\n"));
-                       }
-               }
-       } else if (levelNum == 3) {
-               if (RssiThresh > RssiThresh1) {
-                       RTPRINT(FBT, BT_TRACE, ("[DM][BT], RSSI_BEACON thresh error!!\n"));
-                       return pHalData->bt_coexist.preRssiStateBeacon;
-               }
-
-               if ((pHalData->bt_coexist.preRssiStateBeacon == BT_RSSI_STATE_LOW) ||
-                   (pHalData->bt_coexist.preRssiStateBeacon == BT_RSSI_STATE_STAY_LOW)) {
-                       if (pwdbBeacon >= (RssiThresh+BT_FW_COEX_THRESH_TOL)) {
-                               bcnRssiState = BT_RSSI_STATE_MEDIUM;
-                               pHalData->bt_coexist.CurrentState |= BT_COEX_STATE_WIFI_RSSI_BEACON_MEDIUM;
-                               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_WIFI_RSSI_BEACON_LOW;
-                               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_WIFI_RSSI_BEACON_HIGH;
-                               RTPRINT(FBT, BT_TRACE, ("[DM][BT], RSSI_BEACON state switch to Medium\n"));
-                       } else {
-                               bcnRssiState = BT_RSSI_STATE_STAY_LOW;
-                               RTPRINT(FBT, BT_TRACE, ("[DM][BT], RSSI_BEACON state stay at Low\n"));
-                       }
-               } else if ((pHalData->bt_coexist.preRssiStateBeacon == BT_RSSI_STATE_MEDIUM) ||
-                          (pHalData->bt_coexist.preRssiStateBeacon == BT_RSSI_STATE_STAY_MEDIUM)) {
-                       if (pwdbBeacon >= (RssiThresh1+BT_FW_COEX_THRESH_TOL)) {
-                               bcnRssiState = BT_RSSI_STATE_HIGH;
-                               pHalData->bt_coexist.CurrentState |= BT_COEX_STATE_WIFI_RSSI_BEACON_HIGH;
-                               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_WIFI_RSSI_BEACON_LOW;
-                               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_WIFI_RSSI_BEACON_MEDIUM;
-                               RTPRINT(FBT, BT_TRACE, ("[DM][BT], RSSI_BEACON state switch to High\n"));
-                       } else if (pwdbBeacon < RssiThresh) {
-                               bcnRssiState = BT_RSSI_STATE_LOW;
-                               pHalData->bt_coexist.CurrentState |= BT_COEX_STATE_WIFI_RSSI_BEACON_LOW;
-                               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_WIFI_RSSI_BEACON_HIGH;
-                               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_WIFI_RSSI_BEACON_MEDIUM;
-                               RTPRINT(FBT, BT_TRACE, ("[DM][BT], RSSI_BEACON state switch to Low\n"));
-                       } else {
-                               bcnRssiState = BT_RSSI_STATE_STAY_MEDIUM;
-                               RTPRINT(FBT, BT_TRACE, ("[DM][BT], RSSI_BEACON state stay at Medium\n"));
-                       }
-               } else {
-                       if (pwdbBeacon < RssiThresh1) {
-                               bcnRssiState = BT_RSSI_STATE_MEDIUM;
-                               pHalData->bt_coexist.CurrentState |= BT_COEX_STATE_WIFI_RSSI_BEACON_MEDIUM;
-                               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_WIFI_RSSI_BEACON_HIGH;
-                               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_WIFI_RSSI_BEACON_LOW;
-                               RTPRINT(FBT, BT_TRACE, ("[DM][BT], RSSI_BEACON state switch to Medium\n"));
-                       } else {
-                               bcnRssiState = BT_RSSI_STATE_STAY_HIGH;
-                               RTPRINT(FBT, BT_TRACE, ("[DM][BT], RSSI_BEACON state stay at High\n"));
-                       }
-               }
-       }
-
-       pHalData->bt_coexist.preRssiStateBeacon = bcnRssiState;
-
-       return bcnRssiState;
-}
-
-u8 BTDM_CheckCoexRSSIState1(struct rtw_adapter *padapter, u8 levelNum,
-                           u8 RssiThresh, u8 RssiThresh1)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       s32 UndecoratedSmoothedPWDB = 0;
-       u8 btRssiState = 0;
-
-       UndecoratedSmoothedPWDB = BTDM_GetRxSS(padapter);
-
-       if (levelNum == 2) {
-               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_WIFI_RSSI_1_MEDIUM;
-
-               if ((pHalData->bt_coexist.preRssiState1 == BT_RSSI_STATE_LOW) ||
-                   (pHalData->bt_coexist.preRssiState1 == BT_RSSI_STATE_STAY_LOW)) {
-                       if (UndecoratedSmoothedPWDB >= (RssiThresh+BT_FW_COEX_THRESH_TOL)) {
-                               btRssiState = BT_RSSI_STATE_HIGH;
-                               pHalData->bt_coexist.CurrentState |= BT_COEX_STATE_WIFI_RSSI_1_HIGH;
-                               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_WIFI_RSSI_1_LOW;
-                               RTPRINT(FBT, BT_TRACE, ("[DM][BT], RSSI_1 state switch to High\n"));
-                       } else {
-                               btRssiState = BT_RSSI_STATE_STAY_LOW;
-                               RTPRINT(FBT, BT_TRACE, ("[DM][BT], RSSI_1 state stay at Low\n"));
-                       }
-               } else {
-                       if (UndecoratedSmoothedPWDB < RssiThresh) {
-                               btRssiState = BT_RSSI_STATE_LOW;
-                               pHalData->bt_coexist.CurrentState |= BT_COEX_STATE_WIFI_RSSI_1_LOW;
-                               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_WIFI_RSSI_1_HIGH;
-                               RTPRINT(FBT, BT_TRACE, ("[DM][BT], RSSI_1 state switch to Low\n"));
-                       } else {
-                               btRssiState = BT_RSSI_STATE_STAY_HIGH;
-                               RTPRINT(FBT, BT_TRACE, ("[DM][BT], RSSI_1 state stay at High\n"));
-                       }
-               }
-       } else if (levelNum == 3) {
-               if (RssiThresh > RssiThresh1) {
-                       RTPRINT(FBT, BT_TRACE, ("[DM][BT], RSSI_1 thresh error!!\n"));
-                       return pHalData->bt_coexist.preRssiState1;
-               }
-
-               if ((pHalData->bt_coexist.preRssiState1 == BT_RSSI_STATE_LOW) ||
-                   (pHalData->bt_coexist.preRssiState1 == BT_RSSI_STATE_STAY_LOW)) {
-                       if (UndecoratedSmoothedPWDB >= (RssiThresh+BT_FW_COEX_THRESH_TOL)) {
-                               btRssiState = BT_RSSI_STATE_MEDIUM;
-                               pHalData->bt_coexist.CurrentState |= BT_COEX_STATE_WIFI_RSSI_1_MEDIUM;
-                               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_WIFI_RSSI_1_LOW;
-                               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_WIFI_RSSI_1_HIGH;
-                               RTPRINT(FBT, BT_TRACE, ("[DM][BT], RSSI_1 state switch to Medium\n"));
-                       } else {
-                               btRssiState = BT_RSSI_STATE_STAY_LOW;
-                               RTPRINT(FBT, BT_TRACE, ("[DM][BT], RSSI_1 state stay at Low\n"));
-                       }
-               } else if ((pHalData->bt_coexist.preRssiState1 == BT_RSSI_STATE_MEDIUM) ||
-                          (pHalData->bt_coexist.preRssiState1 == BT_RSSI_STATE_STAY_MEDIUM)) {
-                       if (UndecoratedSmoothedPWDB >= (RssiThresh1+BT_FW_COEX_THRESH_TOL)) {
-                               btRssiState = BT_RSSI_STATE_HIGH;
-                               pHalData->bt_coexist.CurrentState |= BT_COEX_STATE_WIFI_RSSI_1_HIGH;
-                               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_WIFI_RSSI_1_LOW;
-                               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_WIFI_RSSI_1_MEDIUM;
-                               RTPRINT(FBT, BT_TRACE, ("[DM][BT], RSSI_1 state switch to High\n"));
-                       } else if (UndecoratedSmoothedPWDB < RssiThresh) {
-                               btRssiState = BT_RSSI_STATE_LOW;
-                               pHalData->bt_coexist.CurrentState |= BT_COEX_STATE_WIFI_RSSI_1_LOW;
-                               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_WIFI_RSSI_1_HIGH;
-                               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_WIFI_RSSI_1_MEDIUM;
-                               RTPRINT(FBT, BT_TRACE, ("[DM][BT], RSSI_1 state switch to Low\n"));
-                       } else {
-                               btRssiState = BT_RSSI_STATE_STAY_MEDIUM;
-                               RTPRINT(FBT, BT_TRACE, ("[DM][BT], RSSI_1 state stay at Medium\n"));
-                       }
-               } else {
-                       if (UndecoratedSmoothedPWDB < RssiThresh1) {
-                               btRssiState = BT_RSSI_STATE_MEDIUM;
-                               pHalData->bt_coexist.CurrentState |= BT_COEX_STATE_WIFI_RSSI_1_MEDIUM;
-                               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_WIFI_RSSI_1_HIGH;
-                               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_WIFI_RSSI_1_LOW;
-                               RTPRINT(FBT, BT_TRACE, ("[DM][BT], RSSI_1 state switch to Medium\n"));
-                       } else {
-                               btRssiState = BT_RSSI_STATE_STAY_HIGH;
-                               RTPRINT(FBT, BT_TRACE, ("[DM][BT], RSSI_1 state stay at High\n"));
-                       }
-               }
-       }
-
-       pHalData->bt_coexist.preRssiState1 = btRssiState;
-
-       return btRssiState;
-}
-
-u8 BTDM_CheckCoexRSSIState(struct rtw_adapter *padapter, u8 levelNum,
-                          u8 RssiThresh, u8 RssiThresh1)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       s32 UndecoratedSmoothedPWDB = 0;
-       u8 btRssiState = 0;
-
-       UndecoratedSmoothedPWDB = BTDM_GetRxSS(padapter);
-
-       if (levelNum == 2) {
-               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_WIFI_RSSI_MEDIUM;
-
-               if ((pHalData->bt_coexist.preRssiState == BT_RSSI_STATE_LOW) ||
-                   (pHalData->bt_coexist.preRssiState == BT_RSSI_STATE_STAY_LOW)) {
-                       if (UndecoratedSmoothedPWDB >= (RssiThresh+BT_FW_COEX_THRESH_TOL)) {
-                               btRssiState = BT_RSSI_STATE_HIGH;
-                               pHalData->bt_coexist.CurrentState |= BT_COEX_STATE_WIFI_RSSI_HIGH;
-                               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_WIFI_RSSI_LOW;
-                               RTPRINT(FBT, BT_TRACE, ("[DM][BT], RSSI state switch to High\n"));
-                       } else {
-                               btRssiState = BT_RSSI_STATE_STAY_LOW;
-                               RTPRINT(FBT, BT_TRACE, ("[DM][BT], RSSI state stay at Low\n"));
-                       }
-               } else {
-                       if (UndecoratedSmoothedPWDB < RssiThresh) {
-                               btRssiState = BT_RSSI_STATE_LOW;
-                               pHalData->bt_coexist.CurrentState |= BT_COEX_STATE_WIFI_RSSI_LOW;
-                               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_WIFI_RSSI_HIGH;
-                               RTPRINT(FBT, BT_TRACE, ("[DM][BT], RSSI state switch to Low\n"));
-                       } else {
-                               btRssiState = BT_RSSI_STATE_STAY_HIGH;
-                               RTPRINT(FBT, BT_TRACE, ("[DM][BT], RSSI state stay at High\n"));
-                       }
-               }
-       } else if (levelNum == 3) {
-               if (RssiThresh > RssiThresh1) {
-                       RTPRINT(FBT, BT_TRACE, ("[DM][BT], RSSI thresh error!!\n"));
-                       return pHalData->bt_coexist.preRssiState;
-               }
-
-               if ((pHalData->bt_coexist.preRssiState == BT_RSSI_STATE_LOW) ||
-                   (pHalData->bt_coexist.preRssiState == BT_RSSI_STATE_STAY_LOW)) {
-                       if (UndecoratedSmoothedPWDB >= (RssiThresh+BT_FW_COEX_THRESH_TOL)) {
-                               btRssiState = BT_RSSI_STATE_MEDIUM;
-                               pHalData->bt_coexist.CurrentState |= BT_COEX_STATE_WIFI_RSSI_MEDIUM;
-                               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_WIFI_RSSI_LOW;
-                               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_WIFI_RSSI_HIGH;
-                               RTPRINT(FBT, BT_TRACE, ("[DM][BT], RSSI state switch to Medium\n"));
-                       } else {
-                               btRssiState = BT_RSSI_STATE_STAY_LOW;
-                               RTPRINT(FBT, BT_TRACE, ("[DM][BT], RSSI state stay at Low\n"));
-                       }
-               } else if ((pHalData->bt_coexist.preRssiState == BT_RSSI_STATE_MEDIUM) ||
-                          (pHalData->bt_coexist.preRssiState == BT_RSSI_STATE_STAY_MEDIUM)) {
-                       if (UndecoratedSmoothedPWDB >= (RssiThresh1+BT_FW_COEX_THRESH_TOL)) {
-                               btRssiState = BT_RSSI_STATE_HIGH;
-                               pHalData->bt_coexist.CurrentState |= BT_COEX_STATE_WIFI_RSSI_HIGH;
-                               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_WIFI_RSSI_LOW;
-                               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_WIFI_RSSI_MEDIUM;
-                               RTPRINT(FBT, BT_TRACE, ("[DM][BT], RSSI state switch to High\n"));
-                       } else if (UndecoratedSmoothedPWDB < RssiThresh) {
-                               btRssiState = BT_RSSI_STATE_LOW;
-                               pHalData->bt_coexist.CurrentState |= BT_COEX_STATE_WIFI_RSSI_LOW;
-                               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_WIFI_RSSI_HIGH;
-                               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_WIFI_RSSI_MEDIUM;
-                               RTPRINT(FBT, BT_TRACE, ("[DM][BT], RSSI state switch to Low\n"));
-                       } else {
-                               btRssiState = BT_RSSI_STATE_STAY_MEDIUM;
-                               RTPRINT(FBT, BT_TRACE, ("[DM][BT], RSSI state stay at Medium\n"));
-                       }
-               } else {
-                       if (UndecoratedSmoothedPWDB < RssiThresh1) {
-                               btRssiState = BT_RSSI_STATE_MEDIUM;
-                               pHalData->bt_coexist.CurrentState |= BT_COEX_STATE_WIFI_RSSI_MEDIUM;
-                               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_WIFI_RSSI_HIGH;
-                               pHalData->bt_coexist.CurrentState &= ~BT_COEX_STATE_WIFI_RSSI_LOW;
-                               RTPRINT(FBT, BT_TRACE, ("[DM][BT], RSSI state switch to Medium\n"));
-                       } else {
-                               btRssiState = BT_RSSI_STATE_STAY_HIGH;
-                               RTPRINT(FBT, BT_TRACE, ("[DM][BT], RSSI state stay at High\n"));
-                       }
-               }
-       }
-
-       pHalData->bt_coexist.preRssiState = btRssiState;
-
-       return btRssiState;
-}
-
-bool rtl8723a_BT_disable_EDCA_turbo(struct rtw_adapter *padapter)
-{
-       struct bt_mgnt *pBtMgnt;
-       struct hal_data_8723a *pHalData;
-       u8 bBtChangeEDCA = false;
-       u32 EDCA_BT_BE = 0x5ea42b, cur_EDCA_reg;
-       bool bRet = false;
-
-       pHalData = GET_HAL_DATA(padapter);
-       pBtMgnt = &pHalData->BtInfo.BtMgnt;
-
-       if (!rtl8723a_BT_coexist(padapter)) {
-               bRet = false;
-               pHalData->bt_coexist.lastBtEdca = 0;
-               return bRet;
-       }
-       if (!((pBtMgnt->bSupportProfile) ||
-           (pHalData->bt_coexist.BT_CoexistType == BT_CSR_BC8))) {
-               bRet = false;
-               pHalData->bt_coexist.lastBtEdca = 0;
-               return bRet;
-       }
-
-       if (rtl8723a_BT_using_antenna_1(padapter)) {
-               bRet = false;
-               pHalData->bt_coexist.lastBtEdca = 0;
-               return bRet;
-       }
-
-       if (pHalData->bt_coexist.exec_cnt < 3)
-               pHalData->bt_coexist.exec_cnt++;
-       else
-               pHalData->bt_coexist.bEDCAInitialized = true;
-
-       /*  When BT is non idle */
-       if (!(pHalData->bt_coexist.CurrentState & BT_COEX_STATE_BT_IDLE)) {
-               RTPRINT(FBT, BT_TRACE, ("BT state non idle, set bt EDCA\n"));
-
-               /* aggr_num = 0x0909; */
-               if (pHalData->odmpriv.DM_EDCA_Table.bCurrentTurboEDCA) {
-                       bBtChangeEDCA = true;
-                       pHalData->odmpriv.DM_EDCA_Table.bCurrentTurboEDCA = false;
-                       pHalData->dmpriv.prv_traffic_idx = 3;
-               }
-               cur_EDCA_reg = rtl8723au_read32(padapter, REG_EDCA_BE_PARAM);
-
-               if (cur_EDCA_reg != EDCA_BT_BE)
-                       bBtChangeEDCA = true;
-               if (bBtChangeEDCA || !pHalData->bt_coexist.bEDCAInitialized) {
-                       rtl8723au_write32(padapter, REG_EDCA_BE_PARAM,
-                                         EDCA_BT_BE);
-                       pHalData->bt_coexist.lastBtEdca = EDCA_BT_BE;
-               }
-               bRet = true;
-       } else {
-               RTPRINT(FBT, BT_TRACE, ("BT state idle, set original EDCA\n"));
-               pHalData->bt_coexist.lastBtEdca = 0;
-               bRet = false;
-       }
-       return bRet;
-}
-
-void
-BTDM_Balance(
-       struct rtw_adapter *padapter,
-       u8 bBalanceOn,
-       u8 ms0,
-       u8 ms1
-       )
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       u8 H2C_Parameter[3] = {0};
-
-       if (bBalanceOn) {
-               H2C_Parameter[2] = 1;
-               H2C_Parameter[1] = ms1;
-               H2C_Parameter[0] = ms0;
-               pHalData->bt_coexist.bFWCoexistAllOff = false;
-       } else {
-               H2C_Parameter[2] = 0;
-               H2C_Parameter[1] = 0;
-               H2C_Parameter[0] = 0;
-       }
-       pHalData->bt_coexist.bBalanceOn = bBalanceOn;
-
-       RTPRINT(FBT, BT_TRACE, ("[DM][BT], Balance =[%s:%dms:%dms], write 0xc = 0x%x\n",
-               bBalanceOn?"ON":"OFF", ms0, ms1,
-               H2C_Parameter[0]<<16|H2C_Parameter[1]<<8|H2C_Parameter[2]));
-
-       FillH2CCmd(padapter, 0xc, 3, H2C_Parameter);
-}
-
-void BTDM_AGCTable(struct rtw_adapter *padapter, u8 type)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       if (type == BT_AGCTABLE_OFF) {
-               RTPRINT(FBT, BT_TRACE, ("[BT]AGCTable Off!\n"));
-               rtl8723au_write32(padapter, 0xc78, 0x641c0001);
-               rtl8723au_write32(padapter, 0xc78, 0x631d0001);
-               rtl8723au_write32(padapter, 0xc78, 0x621e0001);
-               rtl8723au_write32(padapter, 0xc78, 0x611f0001);
-               rtl8723au_write32(padapter, 0xc78, 0x60200001);
-
-               PHY_SetRFReg(padapter, PathA, RF_RX_AGC_HP, bRFRegOffsetMask, 0x32000);
-               PHY_SetRFReg(padapter, PathA, RF_RX_AGC_HP, bRFRegOffsetMask, 0x71000);
-               PHY_SetRFReg(padapter, PathA, RF_RX_AGC_HP, bRFRegOffsetMask, 0xb0000);
-               PHY_SetRFReg(padapter, PathA, RF_RX_AGC_HP, bRFRegOffsetMask, 0xfc000);
-               PHY_SetRFReg(padapter, PathA, RF_RX_G1, bRFRegOffsetMask, 0x30355);
-
-               pHalData->bt_coexist.b8723aAgcTableOn = false;
-       } else if (type == BT_AGCTABLE_ON) {
-               RTPRINT(FBT, BT_TRACE, ("[BT]AGCTable On!\n"));
-               rtl8723au_write32(padapter, 0xc78, 0x4e1c0001);
-               rtl8723au_write32(padapter, 0xc78, 0x4d1d0001);
-               rtl8723au_write32(padapter, 0xc78, 0x4c1e0001);
-               rtl8723au_write32(padapter, 0xc78, 0x4b1f0001);
-               rtl8723au_write32(padapter, 0xc78, 0x4a200001);
-
-               PHY_SetRFReg(padapter, PathA, RF_RX_AGC_HP, bRFRegOffsetMask, 0xdc000);
-               PHY_SetRFReg(padapter, PathA, RF_RX_AGC_HP, bRFRegOffsetMask, 0x90000);
-               PHY_SetRFReg(padapter, PathA, RF_RX_AGC_HP, bRFRegOffsetMask, 0x51000);
-               PHY_SetRFReg(padapter, PathA, RF_RX_AGC_HP, bRFRegOffsetMask, 0x12000);
-               PHY_SetRFReg(padapter, PathA, RF_RX_G1, bRFRegOffsetMask, 0x00355);
-
-               pHalData->bt_coexist.b8723aAgcTableOn = true;
-
-               pHalData->bt_coexist.bSWCoexistAllOff = false;
-       }
-}
-
-void BTDM_BBBackOffLevel(struct rtw_adapter *padapter, u8 type)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-
-       if (type == BT_BB_BACKOFF_OFF) {
-               RTPRINT(FBT, BT_TRACE, ("[BT]BBBackOffLevel Off!\n"));
-               rtl8723au_write32(padapter, 0xc04, 0x3a05611);
-       } else if (type == BT_BB_BACKOFF_ON) {
-               RTPRINT(FBT, BT_TRACE, ("[BT]BBBackOffLevel On!\n"));
-               rtl8723au_write32(padapter, 0xc04, 0x3a07611);
-               pHalData->bt_coexist.bSWCoexistAllOff = false;
-       }
-}
-
-void BTDM_FWCoexAllOff(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-
-       RTPRINT(FBT, BT_TRACE, ("BTDM_FWCoexAllOff()\n"));
-       if (pHalData->bt_coexist.bFWCoexistAllOff)
-               return;
-       RTPRINT(FBT, BT_TRACE, ("BTDM_FWCoexAllOff(), real Do\n"));
-
-       BTDM_FWCoexAllOff8723A(padapter);
-
-       pHalData->bt_coexist.bFWCoexistAllOff = true;
-}
-
-void BTDM_SWCoexAllOff(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-
-       RTPRINT(FBT, BT_TRACE, ("BTDM_SWCoexAllOff()\n"));
-       if (pHalData->bt_coexist.bSWCoexistAllOff)
-               return;
-       RTPRINT(FBT, BT_TRACE, ("BTDM_SWCoexAllOff(), real Do\n"));
-       BTDM_SWCoexAllOff8723A(padapter);
-
-       pHalData->bt_coexist.bSWCoexistAllOff = true;
-}
-
-void BTDM_HWCoexAllOff(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-
-       RTPRINT(FBT, BT_TRACE, ("BTDM_HWCoexAllOff()\n"));
-       if (pHalData->bt_coexist.bHWCoexistAllOff)
-               return;
-       RTPRINT(FBT, BT_TRACE, ("BTDM_HWCoexAllOff(), real Do\n"));
-
-       BTDM_HWCoexAllOff8723A(padapter);
-
-       pHalData->bt_coexist.bHWCoexistAllOff = true;
-}
-
-void BTDM_CoexAllOff(struct rtw_adapter *padapter)
-{
-       BTDM_FWCoexAllOff(padapter);
-       BTDM_SWCoexAllOff(padapter);
-       BTDM_HWCoexAllOff(padapter);
-}
-
-void rtl8723a_BT_disable_coexist(struct rtw_adapter *padapter)
-{
-       struct pwrctrl_priv *ppwrctrl = &padapter->pwrctrlpriv;
-
-       if (!rtl8723a_BT_coexist(padapter))
-               return;
-
-       /*  8723 1Ant doesn't need to turn off bt coexist mechanism. */
-       if (rtl8723a_BT_using_antenna_1(padapter))
-               return;
-
-       /*  Before enter IPS, turn off FW BT Co-exist mechanism */
-       if (ppwrctrl->reg_rfoff == rf_on) {
-               RTPRINT(FBT, BT_TRACE, ("[BT][DM], Before enter IPS, turn off all Coexist DM\n"));
-               btdm_ResetFWCoexState(padapter);
-               BTDM_CoexAllOff(padapter);
-               BTDM_SetAntenna(padapter, BTDM_ANT_BT);
-       }
-}
-
-void BTDM_SignalCompensation(struct rtw_adapter *padapter, u8 *rssi_wifi, u8 *rssi_bt)
-{
-       BTDM_8723ASignalCompensation(padapter, rssi_wifi, rssi_bt);
-}
-
-void rtl8723a_BT_do_coexist(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-
-       if (!rtl8723a_BT_coexist(padapter)) {
-               RTPRINT(FBT, BT_TRACE, ("[DM][BT], BT not exists!!\n"));
-               return;
-       }
-
-       if (!pHalData->bt_coexist.bInitlized) {
-               RTPRINT(FBT, BT_TRACE, ("[DM][BT], btdm_InitBtCoexistDM()\n"));
-               btdm_InitBtCoexistDM(padapter);
-       }
-
-       RTPRINT(FBT, BT_TRACE, ("\n\n[DM][BT], BTDM start!!\n"));
-
-       BTDM_PWDBMonitor(padapter);
-
-       RTPRINT(FBT, BT_TRACE, ("[DM][BT], HW type is 8723\n"));
-       BTDM_BTCoexist8723A(padapter);
-       RTPRINT(FBT, BT_TRACE, ("[DM][BT], BTDM end!!\n\n"));
-}
-
-void BTDM_UpdateCoexState(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-
-       if (!BTDM_IsSameCoexistState(padapter)) {
-               RTPRINT(FBT, BT_TRACE, ("[BTCoex], Coexist State[bitMap] change from 0x%"i64fmt"x to 0x%"i64fmt"x,  changeBits = 0x%"i64fmt"x\n",
-                       pHalData->bt_coexist.PreviousState,
-                       pHalData->bt_coexist.CurrentState,
-                       (pHalData->bt_coexist.PreviousState^pHalData->bt_coexist.CurrentState)));
-               pHalData->bt_coexist.PreviousState = pHalData->bt_coexist.CurrentState;
-       }
-}
-
-u8 BTDM_IsSameCoexistState(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-
-       if (pHalData->bt_coexist.PreviousState == pHalData->bt_coexist.CurrentState) {
-               return true;
-       } else {
-               RTPRINT(FBT, BT_TRACE, ("[DM][BT], Coexist state changed!!\n"));
-               return false;
-       }
-}
-
-void BTDM_PWDBMonitor(struct rtw_adapter *padapter)
-{
-       struct bt_30info *pBTInfo = GET_BT_INFO(GetDefaultAdapter(padapter));
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       u8 H2C_Parameter[3] = {0};
-       s32 tmpBTEntryMaxPWDB = 0, tmpBTEntryMinPWDB = 0xff;
-       u8 i;
-
-       if (pBtMgnt->BtOperationOn) {
-               for (i = 0; i < MAX_BT_ASOC_ENTRY_NUM; i++) {
-                       if (pBTInfo->BtAsocEntry[i].bUsed) {
-                               if (pBTInfo->BtAsocEntry[i].UndecoratedSmoothedPWDB < tmpBTEntryMinPWDB)
-                                       tmpBTEntryMinPWDB = pBTInfo->BtAsocEntry[i].UndecoratedSmoothedPWDB;
-                               if (pBTInfo->BtAsocEntry[i].UndecoratedSmoothedPWDB > tmpBTEntryMaxPWDB)
-                                       tmpBTEntryMaxPWDB = pBTInfo->BtAsocEntry[i].UndecoratedSmoothedPWDB;
-                               /*  Report every BT connection (HS mode) RSSI to FW */
-                               H2C_Parameter[2] = (u8)(pBTInfo->BtAsocEntry[i].UndecoratedSmoothedPWDB & 0xFF);
-                               H2C_Parameter[0] = (MAX_FW_SUPPORT_MACID_NUM-1-i);
-                               RTPRINT(FDM, DM_BT30, ("RSSI report for BT[%d], H2C_Par = 0x%x\n", i, H2C_Parameter[0]));
-                               FillH2CCmd(padapter, RSSI_SETTING_EID, 3, H2C_Parameter);
-                               RTPRINT_ADDR(FDM, (DM_PWDB|DM_BT30), ("BT_Entry Mac :"),
-                                            pBTInfo->BtAsocEntry[i].BTRemoteMACAddr)
-                               RTPRINT(FDM, (DM_PWDB|DM_BT30),
-                                       ("BT rx pwdb[%d] = 0x%x(%d)\n", i,
-                                       pBTInfo->BtAsocEntry[i].UndecoratedSmoothedPWDB,
-                                       pBTInfo->BtAsocEntry[i].UndecoratedSmoothedPWDB));
-                       }
-               }
-               if (tmpBTEntryMaxPWDB != 0) {   /*  If associated entry is found */
-                       pHalData->dmpriv.BT_EntryMaxUndecoratedSmoothedPWDB = tmpBTEntryMaxPWDB;
-                       RTPRINT(FDM, (DM_PWDB|DM_BT30), ("BT_EntryMaxPWDB = 0x%x(%d)\n",
-                               tmpBTEntryMaxPWDB, tmpBTEntryMaxPWDB));
-               } else {
-                       pHalData->dmpriv.BT_EntryMaxUndecoratedSmoothedPWDB = 0;
-               }
-               if (tmpBTEntryMinPWDB != 0xff) { /*  If associated entry is found */
-                       pHalData->dmpriv.BT_EntryMinUndecoratedSmoothedPWDB = tmpBTEntryMinPWDB;
-                       RTPRINT(FDM, (DM_PWDB|DM_BT30), ("BT_EntryMinPWDB = 0x%x(%d)\n",
-                               tmpBTEntryMinPWDB, tmpBTEntryMinPWDB));
-               } else {
-                       pHalData->dmpriv.BT_EntryMinUndecoratedSmoothedPWDB = 0;
-               }
-       }
-}
-
-u8 BTDM_IsBTBusy(struct rtw_adapter *padapter)
-{
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_mgnt *pBtMgnt = &pBTInfo->BtMgnt;
-
-       if (pBtMgnt->ExtConfig.bBTBusy)
-               return true;
-       else
-               return false;
-}
-
-u8 BTDM_IsWifiBusy(struct rtw_adapter *padapter)
-{
-/*PMGNT_INFO           pMgntInfo = &GetDefaultAdapter(padapter)->MgntInfo; */
-       struct mlme_priv *pmlmepriv = &GetDefaultAdapter(padapter)->mlmepriv;
-       struct bt_30info *pBTInfo = GET_BT_INFO(padapter);
-       struct bt_traffic *pBtTraffic = &pBTInfo->BtTraffic;
-
-       if (pmlmepriv->LinkDetectInfo.bBusyTraffic ||
-               pBtTraffic->Bt30TrafficStatistics.bTxBusyTraffic ||
-               pBtTraffic->Bt30TrafficStatistics.bRxBusyTraffic)
-               return true;
-       else
-               return false;
-}
-
-u8 BTDM_IsCoexistStateChanged(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-
-       if (pHalData->bt_coexist.PreviousState == pHalData->bt_coexist.CurrentState)
-               return false;
-       else
-               return true;
-}
-
-u8 BTDM_IsWifiUplink(struct rtw_adapter *padapter)
-{
-/*PMGNT_INFO           pMgntInfo = &GetDefaultAdapter(padapter)->MgntInfo; */
-       struct mlme_priv *pmlmepriv;
-       struct bt_30info *pBTInfo;
-       struct bt_traffic *pBtTraffic;
-
-       pmlmepriv = &padapter->mlmepriv;
-       pBTInfo = GET_BT_INFO(padapter);
-       pBtTraffic = &pBTInfo->BtTraffic;
-
-       if ((pmlmepriv->LinkDetectInfo.bTxBusyTraffic) ||
-               (pBtTraffic->Bt30TrafficStatistics.bTxBusyTraffic))
-               return true;
-       else
-               return false;
-}
-
-u8 BTDM_IsWifiDownlink(struct rtw_adapter *padapter)
-{
-/*PMGNT_INFO           pMgntInfo = &GetDefaultAdapter(padapter)->MgntInfo; */
-       struct mlme_priv *pmlmepriv;
-       struct bt_30info *pBTInfo;
-       struct bt_traffic *pBtTraffic;
-
-       pmlmepriv = &padapter->mlmepriv;
-       pBTInfo = GET_BT_INFO(padapter);
-       pBtTraffic = &pBTInfo->BtTraffic;
-
-       if ((pmlmepriv->LinkDetectInfo.bRxBusyTraffic) ||
-               (pBtTraffic->Bt30TrafficStatistics.bRxBusyTraffic))
-               return true;
-       else
-               return false;
-}
-
-u8 BTDM_IsBTHSMode(struct rtw_adapter *padapter)
-{
-/*PMGNT_INFO           pMgntInfo = &GetDefaultAdapter(padapter)->MgntInfo; */
-       struct hal_data_8723a *pHalData;
-       struct bt_mgnt *pBtMgnt;
-
-       pHalData = GET_HAL_DATA(padapter);
-       pBtMgnt = &pHalData->BtInfo.BtMgnt;
-
-       if (pBtMgnt->BtOperationOn)
-               return true;
-       else
-               return false;
-}
-
-u8 BTDM_IsBTUplink(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-
-       if (pHalData->bt_coexist.BT21TrafficStatistics.bTxBusyTraffic)
-               return true;
-       else
-               return false;
-}
-
-u8 BTDM_IsBTDownlink(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-
-       if (pHalData->bt_coexist.BT21TrafficStatistics.bRxBusyTraffic)
-               return true;
-       else
-               return false;
-}
-
-void BTDM_AdjustForBtOperation(struct rtw_adapter *padapter)
-{
-       RTPRINT(FBT, BT_TRACE, ("[BT][DM], BTDM_AdjustForBtOperation()\n"));
-       BTDM_AdjustForBtOperation8723A(padapter);
-}
-
-void BTDM_SetBtCoexCurrAntNum(struct rtw_adapter *padapter, u8 antNum)
-{
-       BTDM_Set8723ABtCoexCurrAntNum(padapter, antNum);
-}
-
-void BTDM_ForHalt(struct rtw_adapter *padapter)
-{
-       if (!rtl8723a_BT_coexist(padapter))
-               return;
-
-       BTDM_ForHalt8723A(padapter);
-       GET_HAL_DATA(padapter)->bt_coexist.bInitlized = false;
-}
-
-void BTDM_WifiScanNotify(struct rtw_adapter *padapter, u8 scanType)
-{
-       if (!rtl8723a_BT_coexist(padapter))
-               return;
-
-       BTDM_WifiScanNotify8723A(padapter, scanType);
-}
-
-void BTDM_WifiAssociateNotify(struct rtw_adapter *padapter, u8 action)
-{
-       if (!rtl8723a_BT_coexist(padapter))
-               return;
-
-       BTDM_WifiAssociateNotify8723A(padapter, action);
-}
-
-void rtl8723a_BT_mediastatus_notify(struct rtw_adapter *padapter,
-                                   enum rt_media_status mstatus)
-{
-       if (!rtl8723a_BT_coexist(padapter))
-               return;
-
-       BTDM_MediaStatusNotify8723A(padapter, mstatus);
-}
-
-void rtl8723a_BT_specialpacket_notify(struct rtw_adapter *padapter)
-{
-       if (!rtl8723a_BT_coexist(padapter))
-               return;
-
-       BTDM_ForDhcp8723A(padapter);
-}
-
-void BTDM_ResetActionProfileState(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-
-       pHalData->bt_coexist.CurrentState &= ~\
-               (BT_COEX_STATE_PROFILE_HID|BT_COEX_STATE_PROFILE_A2DP|
-               BT_COEX_STATE_PROFILE_PAN|BT_COEX_STATE_PROFILE_SCO);
-}
-
-u8 BTDM_IsActionSCO(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData;
-       struct bt_30info *pBTInfo;
-       struct bt_mgnt *pBtMgnt;
-       struct bt_dgb *pBtDbg;
-       u8 bRet;
-
-       pHalData = GET_HAL_DATA(padapter);
-       pBTInfo = GET_BT_INFO(padapter);
-       pBtMgnt = &pBTInfo->BtMgnt;
-       pBtDbg = &pBTInfo->BtDbg;
-       bRet = false;
-
-       if (pBtDbg->dbgCtrl) {
-               if (pBtDbg->dbgProfile == BT_DBG_PROFILE_SCO) {
-                       pHalData->bt_coexist.CurrentState |= BT_COEX_STATE_PROFILE_SCO;
-                       bRet = true;
-               }
-       } else {
-               if (pBtMgnt->ExtConfig.NumberOfSCO > 0) {
-                       pHalData->bt_coexist.CurrentState |= BT_COEX_STATE_PROFILE_SCO;
-                       bRet = true;
-               }
-       }
-       return bRet;
-}
-
-u8 BTDM_IsActionHID(struct rtw_adapter *padapter)
-{
-       struct bt_30info *pBTInfo;
-       struct hal_data_8723a *pHalData;
-       struct bt_mgnt *pBtMgnt;
-       struct bt_dgb *pBtDbg;
-       u8 bRet;
-
-       pHalData = GET_HAL_DATA(padapter);
-       pBTInfo = GET_BT_INFO(padapter);
-       pBtMgnt = &pBTInfo->BtMgnt;
-       pBtDbg = &pBTInfo->BtDbg;
-       bRet = false;
-
-       if (pBtDbg->dbgCtrl) {
-               if (pBtDbg->dbgProfile == BT_DBG_PROFILE_HID) {
-                       pHalData->bt_coexist.CurrentState |= BT_COEX_STATE_PROFILE_HID;
-                       bRet = true;
-               }
-       } else {
-               if (BTHCI_CheckProfileExist(padapter, BT_PROFILE_HID) &&
-                   pBtMgnt->ExtConfig.NumberOfHandle == 1) {
-                       pHalData->bt_coexist.CurrentState |= BT_COEX_STATE_PROFILE_HID;
-                       bRet = true;
-               }
-       }
-       return bRet;
-}
-
-u8 BTDM_IsActionA2DP(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData;
-       struct bt_30info *pBTInfo;
-       struct bt_mgnt *pBtMgnt;
-       struct bt_dgb *pBtDbg;
-       u8 bRet;
-
-       pHalData = GET_HAL_DATA(padapter);
-       pBTInfo = GET_BT_INFO(padapter);
-       pBtMgnt = &pBTInfo->BtMgnt;
-       pBtDbg = &pBTInfo->BtDbg;
-       bRet = false;
-
-       if (pBtDbg->dbgCtrl) {
-               if (pBtDbg->dbgProfile == BT_DBG_PROFILE_A2DP) {
-                       pHalData->bt_coexist.CurrentState |= BT_COEX_STATE_PROFILE_A2DP;
-                       bRet = true;
-               }
-       } else {
-               if (BTHCI_CheckProfileExist(padapter, BT_PROFILE_A2DP) &&
-                   pBtMgnt->ExtConfig.NumberOfHandle == 1) {
-                       pHalData->bt_coexist.CurrentState |= BT_COEX_STATE_PROFILE_A2DP;
-                       bRet = true;
-               }
-       }
-       return bRet;
-}
-
-u8 BTDM_IsActionPAN(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData;
-       struct bt_30info *pBTInfo;
-       struct bt_mgnt *pBtMgnt;
-       struct bt_dgb *pBtDbg;
-       u8 bRet;
-
-       pHalData = GET_HAL_DATA(padapter);
-       pBTInfo = GET_BT_INFO(padapter);
-       pBtMgnt = &pBTInfo->BtMgnt;
-       pBtDbg = &pBTInfo->BtDbg;
-       bRet = false;
-
-       if (pBtDbg->dbgCtrl) {
-               if (pBtDbg->dbgProfile == BT_DBG_PROFILE_PAN) {
-                       pHalData->bt_coexist.CurrentState |= BT_COEX_STATE_PROFILE_PAN;
-                       bRet = true;
-               }
-       } else {
-               if (BTHCI_CheckProfileExist(padapter, BT_PROFILE_PAN) &&
-                   pBtMgnt->ExtConfig.NumberOfHandle == 1) {
-                       pHalData->bt_coexist.CurrentState |= BT_COEX_STATE_PROFILE_PAN;
-                       bRet = true;
-               }
-       }
-       return bRet;
-}
-
-u8 BTDM_IsActionHIDA2DP(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData;
-       struct bt_30info *pBTInfo;
-       struct bt_mgnt *pBtMgnt;
-       struct bt_dgb *pBtDbg;
-       u8 bRet;
-
-       pHalData = GET_HAL_DATA(padapter);
-       pBTInfo = GET_BT_INFO(padapter);
-       pBtMgnt = &pBTInfo->BtMgnt;
-       pBtDbg = &pBTInfo->BtDbg;
-       bRet = false;
-
-       if (pBtDbg->dbgCtrl) {
-               if (pBtDbg->dbgProfile == BT_DBG_PROFILE_HID_A2DP) {
-                       pHalData->bt_coexist.CurrentState |= (BT_COEX_STATE_PROFILE_HID|BT_COEX_STATE_PROFILE_A2DP);
-                       bRet = true;
-               }
-       } else {
-               if (BTHCI_CheckProfileExist(padapter, BT_PROFILE_HID) &&
-                   BTHCI_CheckProfileExist(padapter, BT_PROFILE_A2DP)) {
-                       pHalData->bt_coexist.CurrentState |= (BT_COEX_STATE_PROFILE_HID|BT_COEX_STATE_PROFILE_A2DP);
-                       bRet = true;
-               }
-       }
-       return bRet;
-}
-
-u8 BTDM_IsActionHIDPAN(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData;
-       struct bt_30info *pBTInfo;
-       struct bt_dgb *pBtDbg;
-       u8 bRet;
-
-       pHalData = GET_HAL_DATA(padapter);
-       pBTInfo = GET_BT_INFO(padapter);
-       pBtDbg = &pBTInfo->BtDbg;
-       bRet = false;
-
-       if (pBtDbg->dbgCtrl) {
-               if (pBtDbg->dbgProfile == BT_DBG_PROFILE_HID_PAN) {
-                       pHalData->bt_coexist.CurrentState |= (BT_COEX_STATE_PROFILE_HID|BT_COEX_STATE_PROFILE_PAN);
-                       bRet = true;
-               }
-       } else {
-               if (BTHCI_CheckProfileExist(padapter, BT_PROFILE_HID) &&
-                   BTHCI_CheckProfileExist(padapter, BT_PROFILE_PAN)) {
-                       pHalData->bt_coexist.CurrentState |= (BT_COEX_STATE_PROFILE_HID|BT_COEX_STATE_PROFILE_PAN);
-                       bRet = true;
-               }
-       }
-       return bRet;
-}
-
-u8 BTDM_IsActionPANA2DP(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData;
-       struct bt_30info *pBTInfo;
-       struct bt_dgb *pBtDbg;
-       u8 bRet;
-
-       pHalData = GET_HAL_DATA(padapter);
-       pBTInfo = GET_BT_INFO(padapter);
-       pBtDbg = &pBTInfo->BtDbg;
-       bRet = false;
-
-       if (pBtDbg->dbgCtrl) {
-               if (pBtDbg->dbgProfile == BT_DBG_PROFILE_PAN_A2DP) {
-                       pHalData->bt_coexist.CurrentState |= (BT_COEX_STATE_PROFILE_PAN|BT_COEX_STATE_PROFILE_A2DP);
-                       bRet = true;
-               }
-       } else {
-               if (BTHCI_CheckProfileExist(padapter, BT_PROFILE_PAN) && BTHCI_CheckProfileExist(padapter, BT_PROFILE_A2DP)) {
-                       pHalData->bt_coexist.CurrentState |= (BT_COEX_STATE_PROFILE_PAN|BT_COEX_STATE_PROFILE_A2DP);
-                       bRet = true;
-               }
-       }
-       return bRet;
-}
-
-bool rtl8723a_BT_enabled(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-
-       if (pHalData->bt_coexist.bCurBtDisabled)
-               return false;
-       else
-               return true;
-}
-
-/*  ===== End of sync from SD7 driver HAL/BTCoexist/HalBtCoexist.c ===== */
-
-/*  ===== Below this line is sync from SD7 driver HAL/HalBT.c ===== */
-
-/*  */
-/*local function */
-/*  */
-
-static void halbt_InitHwConfig8723A(struct rtw_adapter *padapter)
-{
-}
-
-/*  */
-/*extern function */
-/*  */
-u8 HALBT_GetPGAntNum(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-
-       return pHalData->bt_coexist.BT_Ant_Num;
-}
-
-void HALBT_SetKey(struct rtw_adapter *padapter, u8 EntryNum)
-{
-       struct bt_30info *pBTinfo;
-       struct bt_asoc_entry *pBtAssocEntry;
-       u16                             usConfig = 0;
-
-       pBTinfo = GET_BT_INFO(padapter);
-       pBtAssocEntry = &pBTinfo->BtAsocEntry[EntryNum];
-
-       pBtAssocEntry->HwCAMIndex = BT_HWCAM_STAR + EntryNum;
-
-       usConfig = CAM_VALID | (CAM_AES << 2);
-       rtl8723a_cam_write(padapter, pBtAssocEntry->HwCAMIndex, usConfig,
-                          pBtAssocEntry->BTRemoteMACAddr,
-                          pBtAssocEntry->PTK + TKIP_ENC_KEY_POS);
-}
-
-void HALBT_RemoveKey(struct rtw_adapter *padapter, u8 EntryNum)
-{
-       struct bt_30info *pBTinfo;
-       struct bt_asoc_entry *pBtAssocEntry;
-
-       pBTinfo = GET_BT_INFO(padapter);
-       pBtAssocEntry = &pBTinfo->BtAsocEntry[EntryNum];
-
-       if (pBTinfo->BtAsocEntry[EntryNum].HwCAMIndex != 0) {
-               /*  ToDo : add New HALBT_RemoveKey function !! */
-               if (pBtAssocEntry->HwCAMIndex >= BT_HWCAM_STAR &&
-                   pBtAssocEntry->HwCAMIndex < HALF_CAM_ENTRY)
-                       rtl8723a_cam_empty_entry(padapter,
-                                                pBtAssocEntry->HwCAMIndex);
-               pBTinfo->BtAsocEntry[EntryNum].HwCAMIndex = 0;
-       }
-}
-
-void rtl8723a_BT_init_hal_vars(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData;
-
-       pHalData = GET_HAL_DATA(padapter);
-
-       pHalData->bt_coexist.BluetoothCoexist = pHalData->EEPROMBluetoothCoexist;
-       pHalData->bt_coexist.BT_Ant_Num = pHalData->EEPROMBluetoothAntNum;
-       pHalData->bt_coexist.BT_CoexistType = pHalData->EEPROMBluetoothType;
-       pHalData->bt_coexist.BT_Ant_isolation = pHalData->EEPROMBluetoothAntIsolation;
-       pHalData->bt_coexist.bt_radiosharedtype = pHalData->EEPROMBluetoothRadioShared;
-
-       RT_TRACE(_module_hal_init_c_, _drv_info_,
-                "BT Coexistance = 0x%x\n", rtl8723a_BT_coexist(padapter));
-
-       if (rtl8723a_BT_coexist(padapter)) {
-               if (pHalData->bt_coexist.BT_Ant_Num == Ant_x2) {
-                       BTDM_SetBtCoexCurrAntNum(padapter, 2);
-                       RT_TRACE(_module_hal_init_c_, _drv_info_,
-                                "BlueTooth BT_Ant_Num = Antx2\n");
-               } else if (pHalData->bt_coexist.BT_Ant_Num == Ant_x1) {
-                       BTDM_SetBtCoexCurrAntNum(padapter, 1);
-                       RT_TRACE(_module_hal_init_c_, _drv_info_,
-                                "BlueTooth BT_Ant_Num = Antx1\n");
-               }
-               pHalData->bt_coexist.bBTBusyTraffic = false;
-               pHalData->bt_coexist.bBTTrafficModeSet = false;
-               pHalData->bt_coexist.bBTNonTrafficModeSet = false;
-               pHalData->bt_coexist.CurrentState = 0;
-               pHalData->bt_coexist.PreviousState = 0;
-
-               RT_TRACE(_module_hal_init_c_, _drv_info_,
-                        "bt_radiosharedType = 0x%x\n",
-                        pHalData->bt_coexist.bt_radiosharedtype);
-       }
-}
-
-bool rtl8723a_BT_coexist(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-
-       if (pHalData->bt_coexist.BluetoothCoexist)
-               return true;
-       else
-               return false;
-}
-
-u8 HALBT_BTChipType(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-
-       return pHalData->bt_coexist.BT_CoexistType;
-}
-
-void rtl8723a_BT_init_hwconfig(struct rtw_adapter *padapter)
-{
-       halbt_InitHwConfig8723A(padapter);
-       rtl8723a_BT_do_coexist(padapter);
-}
-
-void HALBT_SetRtsCtsNoLenLimit(struct rtw_adapter *padapter)
-{
-}
-
-/*  ===== End of sync from SD7 driver HAL/HalBT.c ===== */
-
-void rtl8723a_dual_antenna_detection(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData;
-       struct dm_odm_t *pDM_Odm;
-       struct sw_ant_sw *pDM_SWAT_Table;
-       u8 i;
-
-       pHalData = GET_HAL_DATA(padapter);
-       pDM_Odm = &pHalData->odmpriv;
-       pDM_SWAT_Table = &pDM_Odm->DM_SWAT_Table;
-
-       /*  */
-       /*  <Roger_Notes> RTL8723A Single and Dual antenna dynamic detection
-           mechanism when RF power state is on. */
-       /*  We should take power tracking, IQK, LCK, RCK RF read/write
-           operation into consideration. */
-       /*  2011.12.15. */
-       /*  */
-       if (!pHalData->bAntennaDetected) {
-               u8 btAntNum = BT_GetPGAntNum(padapter);
-
-               /*  Set default antenna B status */
-               if (btAntNum == Ant_x2)
-                       pDM_SWAT_Table->ANTB_ON = true;
-               else if (btAntNum == Ant_x1)
-                       pDM_SWAT_Table->ANTB_ON = false;
-               else
-                       pDM_SWAT_Table->ANTB_ON = true;
-
-               if (pHalData->CustomerID != RT_CID_TOSHIBA) {
-                       for (i = 0; i < MAX_ANTENNA_DETECTION_CNT; i++) {
-                               if (ODM_SingleDualAntennaDetection
-                                   (&pHalData->odmpriv, ANTTESTALL) == true)
-                                       break;
-                       }
-
-                       /*  Set default antenna number for BT coexistence */
-                       if (btAntNum == Ant_x2)
-                               BT_SetBtCoexCurrAntNum(padapter,
-                                                      pDM_SWAT_Table->
-                                                      ANTB_ON ? 2 : 1);
-               }
-               pHalData->bAntennaDetected = true;
-       }
-}
diff --git a/drivers/staging/rtl8723au/hal/rtl8723a_cmd.c b/drivers/staging/rtl8723au/hal/rtl8723a_cmd.c
deleted file mode 100644 (file)
index 2230f4c..0000000
+++ /dev/null
@@ -1,755 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#define _RTL8723A_CMD_C_
-
-#include <osdep_service.h>
-#include <drv_types.h>
-#include <recv_osdep.h>
-#include <mlme_osdep.h>
-#include <rtl8723a_hal.h>
-#include <usb_ops_linux.h>
-
-#define RTL92C_MAX_H2C_BOX_NUMS                4
-#define RTL92C_MAX_CMD_LEN             5
-#define MESSAGE_BOX_SIZE               4
-#define EX_MESSAGE_BOX_SIZE            2
-
-static u8 _is_fw_read_cmd_down(struct rtw_adapter *padapter, u8 msgbox_num)
-{
-       u8 read_down = false;
-       int     retry_cnts = 100;
-       u8 valid;
-
-       do {
-               valid = rtl8723au_read8(padapter, REG_HMETFR) & BIT(msgbox_num);
-               if (0 == valid)
-                       read_down = true;
-       } while ((!read_down) && (retry_cnts--));
-
-       return read_down;
-}
-
-/*****************************************
-* H2C Msg format :
-*| 31 - 8              |7              | 6 - 0 |
-*| h2c_msg     |Ext_bit        |CMD_ID |
-*
-******************************************/
-int FillH2CCmd(struct rtw_adapter *padapter, u8 ElementID, u32 CmdLen,
-              u8 *pCmdBuffer)
-{
-       u8 bcmd_down = false;
-       s32 retry_cnts = 100;
-       u8 h2c_box_num;
-       u32 msgbox_addr;
-       u32 msgbox_ex_addr;
-       struct hal_data_8723a *pHalData;
-       u32 h2c_cmd = 0;
-       u16 h2c_cmd_ex = 0;
-       int ret = _FAIL;
-
-       padapter = GET_PRIMARY_ADAPTER(padapter);
-       pHalData = GET_HAL_DATA(padapter);
-
-       mutex_lock(&adapter_to_dvobj(padapter)->h2c_fwcmd_mutex);
-
-       if (!pCmdBuffer)
-               goto exit;
-       if (CmdLen > RTL92C_MAX_CMD_LEN)
-               goto exit;
-       if (padapter->bSurpriseRemoved == true)
-               goto exit;
-
-       /* pay attention to if  race condition happened in  H2C cmd setting. */
-       do {
-               h2c_box_num = pHalData->LastHMEBoxNum;
-
-               if (!_is_fw_read_cmd_down(padapter, h2c_box_num)) {
-                       DBG_8723A(" fw read cmd failed...\n");
-                       goto exit;
-               }
-
-               if (CmdLen <= 3) {
-                       memcpy((u8 *)(&h2c_cmd)+1, pCmdBuffer, CmdLen);
-               } else {
-                       memcpy((u8 *)(&h2c_cmd_ex), pCmdBuffer, EX_MESSAGE_BOX_SIZE);
-                       memcpy((u8 *)(&h2c_cmd)+1, pCmdBuffer+2, (CmdLen-EX_MESSAGE_BOX_SIZE));
-                       *(u8 *)(&h2c_cmd) |= BIT(7);
-               }
-
-               *(u8 *)(&h2c_cmd) |= ElementID;
-
-               if (h2c_cmd & BIT(7)) {
-                       msgbox_ex_addr = REG_HMEBOX_EXT_0 + (h2c_box_num * EX_MESSAGE_BOX_SIZE);
-                       h2c_cmd_ex = le16_to_cpu(h2c_cmd_ex);
-                       rtl8723au_write16(padapter, msgbox_ex_addr, h2c_cmd_ex);
-               }
-               msgbox_addr = REG_HMEBOX_0 + (h2c_box_num * MESSAGE_BOX_SIZE);
-               h2c_cmd = le32_to_cpu(h2c_cmd);
-               rtl8723au_write32(padapter, msgbox_addr, h2c_cmd);
-
-               bcmd_down = true;
-
-               pHalData->LastHMEBoxNum = (h2c_box_num+1) % RTL92C_MAX_H2C_BOX_NUMS;
-
-       } while ((!bcmd_down) && (retry_cnts--));
-
-       ret = _SUCCESS;
-
-exit:
-       mutex_unlock(&adapter_to_dvobj(padapter)->h2c_fwcmd_mutex);
-       return ret;
-}
-
-int rtl8723a_set_rssi_cmd(struct rtw_adapter *padapter, u32 param)
-{
-       __le32 cmd = cpu_to_le32(param);
-
-       FillH2CCmd(padapter, RSSI_SETTING_EID, 3, (void *)&cmd);
-
-       return _SUCCESS;
-}
-
-int rtl8723a_set_raid_cmd(struct rtw_adapter *padapter, u32 mask, u8 arg)
-{
-       u8 buf[5];
-
-       memset(buf, 0, 5);
-       put_unaligned_le32(mask, buf);
-       buf[4]  = arg;
-
-       FillH2CCmd(padapter, MACID_CONFIG_EID, 5, buf);
-
-       return _SUCCESS;
-}
-
-/* bitmap[0:27] = tx_rate_bitmap */
-/* bitmap[28:31]= Rate Adaptive id */
-/* arg[0:4] = macid */
-/* arg[5] = Short GI */
-void rtl8723a_add_rateatid(struct rtw_adapter *pAdapter, u32 bitmap, u8 arg, u8 rssi_level)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(pAdapter);
-       u8 macid = arg & 0x1f;
-       u32 raid = bitmap & 0xf0000000;
-
-       bitmap &= 0x0fffffff;
-       if (rssi_level != DM_RATR_STA_INIT)
-               bitmap = ODM_Get_Rate_Bitmap23a(pHalData, macid, bitmap,
-                                               rssi_level);
-
-       bitmap |= raid;
-
-       rtl8723a_set_raid_cmd(pAdapter, bitmap, arg);
-}
-
-void rtl8723a_set_FwPwrMode_cmd(struct rtw_adapter *padapter, u8 Mode)
-{
-       struct setpwrmode_parm H2CSetPwrMode;
-       struct pwrctrl_priv *pwrpriv = &padapter->pwrctrlpriv;
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-
-       DBG_8723A("%s: Mode =%d SmartPS =%d UAPSD =%d BcnMode = 0x%02x\n", __func__,
-                       Mode, pwrpriv->smart_ps, padapter->registrypriv.uapsd_enable, pwrpriv->bcn_ant_mode);
-
-       /*  Forece leave RF low power mode for 1T1R to
-           prevent conficting setting in Fw power */
-       /*  saving sequence. 2010.06.07. Added by tynli.
-           Suggested by SD3 yschang. */
-       if (Mode != PS_MODE_ACTIVE && pHalData->rf_type != RF_2T2R)
-               ODM_RF_Saving23a(&pHalData->odmpriv, true);
-
-       H2CSetPwrMode.Mode = Mode;
-       H2CSetPwrMode.SmartPS = pwrpriv->smart_ps;
-       H2CSetPwrMode.AwakeInterval = 1;
-       H2CSetPwrMode.bAllQueueUAPSD = padapter->registrypriv.uapsd_enable;
-       H2CSetPwrMode.BcnAntMode = pwrpriv->bcn_ant_mode;
-
-       FillH2CCmd(padapter, SET_PWRMODE_EID, sizeof(H2CSetPwrMode), (u8 *)&H2CSetPwrMode);
-
-}
-
-static void
-ConstructBeacon(struct rtw_adapter *padapter, u8 *pframe, u32 *pLength)
-{
-       struct ieee80211_mgmt *mgmt;
-       u32 rate_len, pktlen;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       struct wlan_bssid_ex *cur_network = &pmlmeinfo->network;
-       u8 bc_addr[] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
-
-       /* DBG_8723A("%s\n", __func__); */
-
-       mgmt = (struct ieee80211_mgmt *)pframe;
-
-       mgmt->frame_control =
-               cpu_to_le16(IEEE80211_FTYPE_MGMT | IEEE80211_STYPE_BEACON);
-
-       ether_addr_copy(mgmt->da, bc_addr);
-       ether_addr_copy(mgmt->sa, myid(&padapter->eeprompriv));
-       ether_addr_copy(mgmt->bssid, get_my_bssid23a(cur_network));
-
-       /* A Beacon frame shouldn't have fragment bits set */
-       mgmt->seq_ctrl = 0;
-
-       /* timestamp will be inserted by hardware */
-
-       put_unaligned_le16(cur_network->beacon_interval,
-                          &mgmt->u.beacon.beacon_int);
-
-       put_unaligned_le16(cur_network->capability,
-                          &mgmt->u.beacon.capab_info);
-
-       pframe = mgmt->u.beacon.variable;
-       pktlen = offsetof(struct ieee80211_mgmt, u.beacon.variable);
-
-       if ((pmlmeinfo->state&0x03) == MSR_AP) {
-               /* DBG_8723A("ie len =%d\n", cur_network->IELength); */
-               pktlen += cur_network->IELength;
-               memcpy(pframe, cur_network->IEs, pktlen);
-
-               goto _ConstructBeacon;
-       }
-
-       /* below for ad-hoc mode */
-
-       /*  SSID */
-       pframe = rtw_set_ie23a(pframe, WLAN_EID_SSID,
-                              cur_network->Ssid.ssid_len,
-                              cur_network->Ssid.ssid, &pktlen);
-
-       /*  supported rates... */
-       rate_len = rtw_get_rateset_len23a(cur_network->SupportedRates);
-       pframe = rtw_set_ie23a(pframe, WLAN_EID_SUPP_RATES, ((rate_len > 8) ?
-                              8 : rate_len), cur_network->SupportedRates, &pktlen);
-
-       /*  DS parameter set */
-       pframe = rtw_set_ie23a(pframe, WLAN_EID_DS_PARAMS, 1, (unsigned char *)
-                              &cur_network->DSConfig, &pktlen);
-
-       if ((pmlmeinfo->state&0x03) == MSR_ADHOC) {
-               u32 ATIMWindow;
-               /*  IBSS Parameter Set... */
-               /* ATIMWindow = cur->ATIMWindow; */
-               ATIMWindow = 0;
-               pframe = rtw_set_ie23a(pframe, WLAN_EID_IBSS_PARAMS, 2,
-                                      (unsigned char *)&ATIMWindow, &pktlen);
-       }
-
-       /* todo: ERP IE */
-
-       /*  EXTERNDED SUPPORTED RATE */
-       if (rate_len > 8)
-               pframe = rtw_set_ie23a(pframe, WLAN_EID_EXT_SUPP_RATES,
-                                      (rate_len - 8),
-                                      (cur_network->SupportedRates + 8),
-                                      &pktlen);
-
-       /* todo:HT for adhoc */
-
-_ConstructBeacon:
-
-       if ((pktlen + TXDESC_SIZE) > 512) {
-               DBG_8723A("beacon frame too large\n");
-               return;
-       }
-
-       *pLength = pktlen;
-
-       /* DBG_8723A("%s bcn_sz =%d\n", __func__, pktlen); */
-
-}
-
-static void ConstructPSPoll(struct rtw_adapter *padapter,
-                           u8 *pframe, u32 *pLength)
-{
-       struct ieee80211_hdr *pwlanhdr;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-
-       pwlanhdr = (struct ieee80211_hdr *)pframe;
-
-       /*  Frame control. */
-       pwlanhdr->frame_control =
-               cpu_to_le16(IEEE80211_FTYPE_CTL | IEEE80211_STYPE_PSPOLL);
-       pwlanhdr->frame_control |= cpu_to_le16(IEEE80211_FCTL_PM);
-
-       /*  AID. */
-       pwlanhdr->duration_id = cpu_to_le16(pmlmeinfo->aid | 0xc000);
-
-       /*  BSSID. */
-       memcpy(pwlanhdr->addr1, get_my_bssid23a(&pmlmeinfo->network), ETH_ALEN);
-
-       /*  TA. */
-       memcpy(pwlanhdr->addr2, myid(&padapter->eeprompriv), ETH_ALEN);
-
-       *pLength = 16;
-}
-
-static void
-ConstructNullFunctionData(struct rtw_adapter *padapter, u8 *pframe,
-                         u32 *pLength, u8 *StaAddr, u8 bQoS, u8 AC,
-                         u8 bEosp, u8 bForcePowerSave)
-{
-       struct ieee80211_hdr *pwlanhdr;
-       u32 pktlen;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct wlan_network *cur_network = &pmlmepriv->cur_network;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-
-       pwlanhdr = (struct ieee80211_hdr *)pframe;
-
-       pwlanhdr->frame_control = 0;
-       pwlanhdr->seq_ctrl = 0;
-
-       if (bForcePowerSave)
-               pwlanhdr->frame_control |= cpu_to_le16(IEEE80211_FCTL_PM);
-
-       switch (cur_network->network.ifmode) {
-       case NL80211_IFTYPE_P2P_CLIENT:
-       case NL80211_IFTYPE_STATION:
-               pwlanhdr->frame_control |= cpu_to_le16(IEEE80211_FCTL_TODS);
-               memcpy(pwlanhdr->addr1,
-                      get_my_bssid23a(&pmlmeinfo->network), ETH_ALEN);
-               memcpy(pwlanhdr->addr2, myid(&padapter->eeprompriv),
-                      ETH_ALEN);
-               memcpy(pwlanhdr->addr3, StaAddr, ETH_ALEN);
-               break;
-       case NL80211_IFTYPE_P2P_GO:
-       case NL80211_IFTYPE_AP:
-               pwlanhdr->frame_control |= cpu_to_le16(IEEE80211_FCTL_FROMDS);
-               memcpy(pwlanhdr->addr1, StaAddr, ETH_ALEN);
-               memcpy(pwlanhdr->addr2,
-                      get_my_bssid23a(&pmlmeinfo->network), ETH_ALEN);
-               memcpy(pwlanhdr->addr3, myid(&padapter->eeprompriv),
-                      ETH_ALEN);
-               break;
-       case NL80211_IFTYPE_ADHOC:
-       default:
-               memcpy(pwlanhdr->addr1, StaAddr, ETH_ALEN);
-               memcpy(pwlanhdr->addr2, myid(&padapter->eeprompriv), ETH_ALEN);
-               memcpy(pwlanhdr->addr3,
-                      get_my_bssid23a(&pmlmeinfo->network), ETH_ALEN);
-               break;
-       }
-
-       if (bQoS == true) {
-               struct ieee80211_qos_hdr *qoshdr;
-               qoshdr = (struct ieee80211_qos_hdr *)pframe;
-
-               qoshdr->frame_control |=
-                       cpu_to_le16(IEEE80211_FTYPE_DATA |
-                                   IEEE80211_STYPE_QOS_NULLFUNC);
-
-               qoshdr->qos_ctrl = cpu_to_le16(AC & IEEE80211_QOS_CTL_TID_MASK);
-               if (bEosp)
-                       qoshdr->qos_ctrl |= cpu_to_le16(IEEE80211_QOS_CTL_EOSP);
-
-               pktlen = sizeof(struct ieee80211_qos_hdr);
-       } else {
-               pwlanhdr->frame_control |=
-                       cpu_to_le16(IEEE80211_FTYPE_DATA |
-                                   IEEE80211_STYPE_NULLFUNC);
-
-               pktlen = sizeof(struct ieee80211_hdr_3addr);
-       }
-
-       *pLength = pktlen;
-}
-
-static void ConstructProbeRsp(struct rtw_adapter *padapter, u8 *pframe,
-                             u32 *pLength, u8 *StaAddr, bool bHideSSID)
-{
-       struct ieee80211_mgmt *mgmt;
-       u8 *mac, *bssid;
-       u32 pktlen;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       struct wlan_bssid_ex *cur_network = &pmlmeinfo->network;
-
-       /* DBG_8723A("%s\n", __func__); */
-
-       mgmt = (struct ieee80211_mgmt *)pframe;
-
-       mac = myid(&padapter->eeprompriv);
-       bssid = cur_network->MacAddress;
-
-       mgmt->frame_control =
-               cpu_to_le16(IEEE80211_FTYPE_MGMT | IEEE80211_STYPE_PROBE_RESP);
-
-       mgmt->seq_ctrl = 0;
-
-       memcpy(mgmt->da, StaAddr, ETH_ALEN);
-       memcpy(mgmt->sa, mac, ETH_ALEN);
-       memcpy(mgmt->bssid, bssid, ETH_ALEN);
-
-       put_unaligned_le64(cur_network->tsf,
-                          &mgmt->u.probe_resp.timestamp);
-       put_unaligned_le16(cur_network->beacon_interval,
-                          &mgmt->u.probe_resp.beacon_int);
-       put_unaligned_le16(cur_network->capability,
-                          &mgmt->u.probe_resp.capab_info);
-
-       pktlen = offsetof(struct ieee80211_mgmt, u.probe_resp.variable);
-
-       if (cur_network->IELength > MAX_IE_SZ)
-               return;
-
-       memcpy(mgmt->u.probe_resp.variable, cur_network->IEs,
-              cur_network->IELength);
-       pktlen += (cur_network->IELength);
-
-       *pLength = pktlen;
-}
-
-/*  */
-/*  Description: Fill the reserved packets that FW will use to RSVD page. */
-/*                     Now we just send 4 types packet to rsvd page. */
-/*                     (1)Beacon, (2)Ps-poll, (3)Null data, (4)ProbeRsp. */
-/*     Input: */
-/*         bDLFinished - false: At the first time we will send all the packets as a large packet to Hw, */
-/*                                             so we need to set the packet length to total lengh. */
-/*                           true: At the second time, we should send the first packet (default:beacon) */
-/*                                             to Hw again and set the lengh in descriptor to the real beacon lengh. */
-/*  2009.10.15 by tynli. */
-static void SetFwRsvdPagePkt(struct rtw_adapter *padapter, bool bDLFinished)
-{
-       struct hal_data_8723a *pHalData;
-       struct xmit_frame *pmgntframe;
-       struct pkt_attrib *pattrib;
-       struct xmit_priv *pxmitpriv;
-       struct mlme_ext_priv *pmlmeext;
-       struct mlme_ext_info *pmlmeinfo;
-       u32 BeaconLength = 0, ProbeRspLength = 0, PSPollLength;
-       u32 NullDataLength, QosNullLength, BTQosNullLength;
-       u8 *ReservedPagePacket;
-       u8 PageNum, PageNeed, TxDescLen;
-       u16 BufIndex;
-       u32 TotalPacketLen;
-       struct rsvdpage_loc     RsvdPageLoc;
-
-       DBG_8723A("%s\n", __func__);
-
-       ReservedPagePacket = kzalloc(1000, GFP_KERNEL);
-       if (ReservedPagePacket == NULL) {
-               DBG_8723A("%s: alloc ReservedPagePacket fail!\n", __func__);
-               return;
-       }
-
-       pHalData = GET_HAL_DATA(padapter);
-       pxmitpriv = &padapter->xmitpriv;
-       pmlmeext = &padapter->mlmeextpriv;
-       pmlmeinfo = &pmlmeext->mlmext_info;
-
-       TxDescLen = TXDESC_SIZE;
-       PageNum = 0;
-
-       /* 3 (1) beacon */
-       BufIndex = TXDESC_OFFSET;
-       ConstructBeacon(padapter, &ReservedPagePacket[BufIndex], &BeaconLength);
-
-       /*  When we count the first page size, we need to reserve description size for the RSVD */
-       /*  packet, it will be filled in front of the packet in TXPKTBUF. */
-       PageNeed = (u8)PageNum_128(TxDescLen + BeaconLength);
-       /*  To reserved 2 pages for beacon buffer. 2010.06.24. */
-       if (PageNeed == 1)
-               PageNeed += 1;
-       PageNum += PageNeed;
-       pHalData->FwRsvdPageStartOffset = PageNum;
-
-       BufIndex += PageNeed*128;
-
-       /* 3 (2) ps-poll */
-       RsvdPageLoc.LocPsPoll = PageNum;
-       ConstructPSPoll(padapter, &ReservedPagePacket[BufIndex], &PSPollLength);
-       rtl8723a_fill_fake_txdesc(padapter, &ReservedPagePacket[BufIndex-TxDescLen], PSPollLength, true, false);
-
-       PageNeed = (u8)PageNum_128(TxDescLen + PSPollLength);
-       PageNum += PageNeed;
-
-       BufIndex += PageNeed*128;
-
-       /* 3 (3) null data */
-       RsvdPageLoc.LocNullData = PageNum;
-       ConstructNullFunctionData(padapter, &ReservedPagePacket[BufIndex],
-                                 &NullDataLength,
-                                 get_my_bssid23a(&pmlmeinfo->network),
-                                 false, 0, 0, false);
-       rtl8723a_fill_fake_txdesc(padapter,
-                                 &ReservedPagePacket[BufIndex-TxDescLen],
-                                 NullDataLength, false, false);
-
-       PageNeed = (u8)PageNum_128(TxDescLen + NullDataLength);
-       PageNum += PageNeed;
-
-       BufIndex += PageNeed*128;
-
-       /* 3 (4) probe response */
-       RsvdPageLoc.LocProbeRsp = PageNum;
-       ConstructProbeRsp(
-               padapter,
-               &ReservedPagePacket[BufIndex],
-               &ProbeRspLength,
-               get_my_bssid23a(&pmlmeinfo->network),
-               false);
-       rtl8723a_fill_fake_txdesc(padapter, &ReservedPagePacket[BufIndex-TxDescLen], ProbeRspLength, false, false);
-
-       PageNeed = (u8)PageNum_128(TxDescLen + ProbeRspLength);
-       PageNum += PageNeed;
-
-       BufIndex += PageNeed*128;
-
-       /* 3 (5) Qos null data */
-       RsvdPageLoc.LocQosNull = PageNum;
-       ConstructNullFunctionData(
-               padapter,
-               &ReservedPagePacket[BufIndex],
-               &QosNullLength,
-               get_my_bssid23a(&pmlmeinfo->network),
-               true, 0, 0, false);
-       rtl8723a_fill_fake_txdesc(padapter, &ReservedPagePacket[BufIndex-TxDescLen], QosNullLength, false, false);
-
-       PageNeed = (u8)PageNum_128(TxDescLen + QosNullLength);
-       PageNum += PageNeed;
-
-       BufIndex += PageNeed*128;
-
-       /* 3 (6) BT Qos null data */
-       RsvdPageLoc.LocBTQosNull = PageNum;
-       ConstructNullFunctionData(
-               padapter,
-               &ReservedPagePacket[BufIndex],
-               &BTQosNullLength,
-               get_my_bssid23a(&pmlmeinfo->network),
-               true, 0, 0, false);
-       rtl8723a_fill_fake_txdesc(padapter, &ReservedPagePacket[BufIndex-TxDescLen], BTQosNullLength, false, true);
-
-       TotalPacketLen = BufIndex + BTQosNullLength;
-
-       pmgntframe = alloc_mgtxmitframe23a(pxmitpriv);
-       if (pmgntframe == NULL)
-               goto exit;
-
-       /*  update attribute */
-       pattrib = &pmgntframe->attrib;
-       update_mgntframe_attrib23a(padapter, pattrib);
-       pattrib->qsel = 0x10;
-       pattrib->pktlen = pattrib->last_txcmdsz = TotalPacketLen - TXDESC_OFFSET;
-       memcpy(pmgntframe->buf_addr, ReservedPagePacket, TotalPacketLen);
-
-       rtl8723au_mgnt_xmit(padapter, pmgntframe);
-
-       DBG_8723A("%s: Set RSVD page location to Fw\n", __func__);
-       FillH2CCmd(padapter, RSVD_PAGE_EID, sizeof(RsvdPageLoc), (u8 *)&RsvdPageLoc);
-
-exit:
-       kfree(ReservedPagePacket);
-}
-
-void rtl8723a_set_FwJoinBssReport_cmd(struct rtw_adapter *padapter, u8 mstatus)
-{
-       struct joinbssrpt_parm  JoinBssRptParm;
-       struct hal_data_8723a   *pHalData = GET_HAL_DATA(padapter);
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-
-       DBG_8723A("%s mstatus(%x)\n", __func__, mstatus);
-
-       if (mstatus == 1) {
-               bool bRecover = false;
-               u8 v8;
-
-               /*  We should set AID, correct TSF, HW seq enable before set JoinBssReport to Fw in 88/92C. */
-               /*  Suggested by filen. Added by tynli. */
-               rtl8723au_write16(padapter, REG_BCN_PSR_RPT,
-                                 0xC000|pmlmeinfo->aid);
-               /*  Do not set TSF again here or vWiFi beacon DMA INT will not work. */
-               /* correct_TSF23a(padapter, pmlmeext); */
-               /*  Hw sequende enable by dedault. 2010.06.23. by tynli. */
-               /* rtl8723au_write16(padapter, REG_NQOS_SEQ, ((pmlmeext->mgnt_seq+100)&0xFFF)); */
-               /* rtl8723au_write8(padapter, REG_HWSEQ_CTRL, 0xFF); */
-
-               /*  set REG_CR bit 8 */
-               v8 = rtl8723au_read8(padapter, REG_CR+1);
-               v8 |= BIT(0); /*  ENSWBCN */
-               rtl8723au_write8(padapter,  REG_CR+1, v8);
-
-               /*  Disable Hw protection for a time which revserd for Hw sending beacon. */
-               /*  Fix download reserved page packet fail that access collision with the protection time. */
-               /*  2010.05.11. Added by tynli. */
-/*                     SetBcnCtrlReg23a(padapter, 0, BIT(3)); */
-/*                     SetBcnCtrlReg23a(padapter, BIT(4), 0); */
-               SetBcnCtrlReg23a(padapter, BIT(4), BIT(3));
-
-               /*  Set FWHW_TXQ_CTRL 0x422[6]= 0 to tell Hw the packet is not a real beacon frame. */
-               if (pHalData->RegFwHwTxQCtrl & BIT(6))
-                       bRecover = true;
-
-               /*  To tell Hw the packet is not a real beacon frame. */
-               /* U1bTmp = rtl8723au_read8(padapter, REG_FWHW_TXQ_CTRL+2); */
-               rtl8723au_write8(padapter, REG_FWHW_TXQ_CTRL + 2,
-                                pHalData->RegFwHwTxQCtrl & ~BIT(6));
-               pHalData->RegFwHwTxQCtrl &= ~BIT(6);
-               SetFwRsvdPagePkt(padapter, 0);
-
-               /*  2010.05.11. Added by tynli. */
-               SetBcnCtrlReg23a(padapter, BIT(3), BIT(4));
-
-               /*  To make sure that if there exists an adapter which would like to send beacon. */
-               /*  If exists, the origianl value of 0x422[6] will be 1, we should check this to */
-               /*  prevent from setting 0x422[6] to 0 after download reserved page, or it will cause */
-               /*  the beacon cannot be sent by HW. */
-               /*  2010.06.23. Added by tynli. */
-               if (bRecover) {
-                       rtl8723au_write8(padapter, REG_FWHW_TXQ_CTRL + 2,
-                                        pHalData->RegFwHwTxQCtrl | BIT(6));
-                       pHalData->RegFwHwTxQCtrl |= BIT(6);
-               }
-
-               /*  Clear CR[8] or beacon packet will not be send to TxBuf anymore. */
-               v8 = rtl8723au_read8(padapter, REG_CR+1);
-               v8 &= ~BIT(0); /*  ~ENSWBCN */
-               rtl8723au_write8(padapter, REG_CR+1, v8);
-       }
-
-       JoinBssRptParm.OpMode = mstatus;
-
-       FillH2CCmd(padapter, JOINBSS_RPT_EID, sizeof(JoinBssRptParm), (u8 *)&JoinBssRptParm);
-
-}
-
-#ifdef CONFIG_8723AU_BT_COEXIST
-static void SetFwRsvdPagePkt_BTCoex(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData;
-       struct xmit_frame *pmgntframe;
-       struct pkt_attrib *pattrib;
-       struct xmit_priv *pxmitpriv;
-       struct mlme_ext_priv *pmlmeext;
-       struct mlme_ext_info *pmlmeinfo;
-       u8 fakemac[6] = {0x00, 0xe0, 0x4c, 0x00, 0x00, 0x00};
-       u32 NullDataLength, BTQosNullLength;
-       u8 *ReservedPagePacket;
-       u8 PageNum, PageNeed, TxDescLen;
-       u16 BufIndex;
-       u32 TotalPacketLen;
-       struct rsvdpage_loc     RsvdPageLoc;
-
-       DBG_8723A("+%s\n", __func__);
-
-       ReservedPagePacket = kzalloc(1024, GFP_KERNEL);
-       if (ReservedPagePacket == NULL) {
-               DBG_8723A("%s: alloc ReservedPagePacket fail!\n", __func__);
-               return;
-       }
-
-       pHalData = GET_HAL_DATA(padapter);
-       pxmitpriv = &padapter->xmitpriv;
-       pmlmeext = &padapter->mlmeextpriv;
-       pmlmeinfo = &pmlmeext->mlmext_info;
-
-       TxDescLen = TXDESC_SIZE;
-       PageNum = 0;
-
-       /* 3 (1) beacon */
-       BufIndex = TXDESC_OFFSET;
-       /*  skip Beacon Packet */
-       PageNeed = 3;
-
-       PageNum += PageNeed;
-       pHalData->FwRsvdPageStartOffset = PageNum;
-
-       BufIndex += PageNeed*128;
-
-       /* 3 (3) null data */
-       RsvdPageLoc.LocNullData = PageNum;
-       ConstructNullFunctionData(
-               padapter,
-               &ReservedPagePacket[BufIndex],
-               &NullDataLength,
-               fakemac,
-               false, 0, 0, false);
-       rtl8723a_fill_fake_txdesc(padapter, &ReservedPagePacket[BufIndex-TxDescLen], NullDataLength, false, false);
-
-       PageNeed = (u8)PageNum_128(TxDescLen + NullDataLength);
-       PageNum += PageNeed;
-
-       BufIndex += PageNeed*128;
-
-       /* 3 (6) BT Qos null data */
-       RsvdPageLoc.LocBTQosNull = PageNum;
-       ConstructNullFunctionData(
-               padapter,
-               &ReservedPagePacket[BufIndex],
-               &BTQosNullLength,
-               fakemac,
-               true, 0, 0, false);
-       rtl8723a_fill_fake_txdesc(padapter, &ReservedPagePacket[BufIndex-TxDescLen], BTQosNullLength, false, true);
-
-       TotalPacketLen = BufIndex + BTQosNullLength;
-
-       pmgntframe = alloc_mgtxmitframe23a(pxmitpriv);
-       if (pmgntframe == NULL)
-               goto exit;
-
-       /*  update attribute */
-       pattrib = &pmgntframe->attrib;
-       update_mgntframe_attrib23a(padapter, pattrib);
-       pattrib->qsel = 0x10;
-       pattrib->pktlen = pattrib->last_txcmdsz = TotalPacketLen - TXDESC_OFFSET;
-       memcpy(pmgntframe->buf_addr, ReservedPagePacket, TotalPacketLen);
-
-       rtl8723au_mgnt_xmit(padapter, pmgntframe);
-
-       DBG_8723A("%s: Set RSVD page location to Fw\n", __func__);
-       FillH2CCmd(padapter, RSVD_PAGE_EID, sizeof(RsvdPageLoc), (u8 *)&RsvdPageLoc);
-
-exit:
-       kfree(ReservedPagePacket);
-}
-
-void rtl8723a_set_BTCoex_AP_mode_FwRsvdPkt_cmd(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData;
-       u8 bRecover = false;
-
-       DBG_8723A("+%s\n", __func__);
-
-       pHalData = GET_HAL_DATA(padapter);
-
-       /*  Set FWHW_TXQ_CTRL 0x422[6]= 0 to tell Hw the packet is not a real beacon frame. */
-       if (pHalData->RegFwHwTxQCtrl & BIT(6))
-               bRecover = true;
-
-       /*  To tell Hw the packet is not a real beacon frame. */
-       pHalData->RegFwHwTxQCtrl &= ~BIT(6);
-       rtl8723au_write8(padapter, REG_FWHW_TXQ_CTRL + 2,
-                        pHalData->RegFwHwTxQCtrl);
-       SetFwRsvdPagePkt_BTCoex(padapter);
-
-       /*  To make sure that if there exists an adapter which would like to send beacon. */
-       /*  If exists, the origianl value of 0x422[6] will be 1, we should check this to */
-       /*  prevent from setting 0x422[6] to 0 after download reserved page, or it will cause */
-       /*  the beacon cannot be sent by HW. */
-       /*  2010.06.23. Added by tynli. */
-       if (bRecover) {
-               pHalData->RegFwHwTxQCtrl |= BIT(6);
-               rtl8723au_write8(padapter, REG_FWHW_TXQ_CTRL + 2,
-                                pHalData->RegFwHwTxQCtrl);
-       }
-}
-#endif
diff --git a/drivers/staging/rtl8723au/hal/rtl8723a_dm.c b/drivers/staging/rtl8723au/hal/rtl8723a_dm.c
deleted file mode 100644 (file)
index 1e831f2..0000000
+++ /dev/null
@@ -1,194 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-/*  */
-/*  Description: */
-/*  */
-/*  This file is for 92CE/92CU dynamic mechanism only */
-/*  */
-/*  */
-/*  */
-#define _RTL8723A_DM_C_
-
-/*  */
-/*  include files */
-/*  */
-#include <osdep_service.h>
-#include <drv_types.h>
-
-#include <rtl8723a_hal.h>
-#include <usb_ops_linux.h>
-
-/*  */
-/*  Global var */
-/*  */
-
-static void dm_CheckPbcGPIO(struct rtw_adapter *padapter)
-{
-       u8      tmp1byte;
-       u8      bPbcPressed = false;
-
-       if (!padapter->registrypriv.hw_wps_pbc)
-               return;
-
-       tmp1byte = rtl8723au_read8(padapter, GPIO_IO_SEL);
-       tmp1byte |= (HAL_8192C_HW_GPIO_WPS_BIT);
-       /* enable GPIO[2] as output mode */
-       rtl8723au_write8(padapter, GPIO_IO_SEL, tmp1byte);
-
-       tmp1byte &= ~(HAL_8192C_HW_GPIO_WPS_BIT);
-       /* reset the floating voltage level */
-       rtl8723au_write8(padapter,  GPIO_IN, tmp1byte);
-
-       tmp1byte = rtl8723au_read8(padapter, GPIO_IO_SEL);
-       tmp1byte &= ~(HAL_8192C_HW_GPIO_WPS_BIT);
-       /* enable GPIO[2] as input mode */
-       rtl8723au_write8(padapter, GPIO_IO_SEL, tmp1byte);
-
-       tmp1byte = rtl8723au_read8(padapter, GPIO_IN);
-
-       if (tmp1byte == 0xff)
-               return;
-
-       if (tmp1byte&HAL_8192C_HW_GPIO_WPS_BIT)
-               bPbcPressed = true;
-
-       if (bPbcPressed) {
-               /*  Here we only set bPbcPressed to true */
-               /*  After trigger PBC, the variable will be set to false */
-               DBG_8723A("CheckPbcGPIO - PBC is pressed\n");
-
-               if (padapter->pid[0] == 0) {
-                       /* 0 is the default value and it means the application
-                        * monitors the HW PBC doesn't privde its pid to driver.
-                        */
-                       return;
-               }
-
-               kill_pid(find_vpid(padapter->pid[0]), SIGUSR1, 1);
-       }
-}
-
-/*  Initialize GPIO setting registers */
-/*  functions */
-
-void rtl8723a_init_dm_priv(struct rtw_adapter *Adapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(Adapter);
-       struct dm_priv  *pdmpriv = &pHalData->dmpriv;
-       struct dm_odm_t *pDM_Odm = &pHalData->odmpriv;
-       u8 cut_ver, fab_ver;
-
-       memset(pdmpriv, 0, sizeof(struct dm_priv));
-       memset(pDM_Odm, 0, sizeof(*pDM_Odm));
-
-       pDM_Odm->Adapter = Adapter;
-
-       ODM_CmnInfoInit23a(pDM_Odm, ODM_CMNINFO_IC_TYPE, ODM_RTL8723A);
-
-       if (IS_8723A_A_CUT(pHalData->VersionID)) {
-               fab_ver = ODM_UMC;
-               cut_ver = ODM_CUT_A;
-       } else if (IS_8723A_B_CUT(pHalData->VersionID)) {
-               fab_ver = ODM_UMC;
-               cut_ver = ODM_CUT_B;
-       } else {
-               fab_ver = ODM_TSMC;
-               cut_ver = ODM_CUT_A;
-       }
-       ODM_CmnInfoInit23a(pDM_Odm, ODM_CMNINFO_FAB_VER, fab_ver);
-       ODM_CmnInfoInit23a(pDM_Odm, ODM_CMNINFO_CUT_VER, cut_ver);
-       ODM_CmnInfoInit23a(pDM_Odm, ODM_CMNINFO_MP_TEST_CHIP, IS_NORMAL_CHIP(pHalData->VersionID));
-
-       ODM_CmnInfoInit23a(pDM_Odm, ODM_CMNINFO_BOARD_TYPE, pHalData->BoardType);
-
-       if (pHalData->BoardType == BOARD_USB_High_PA) {
-               ODM_CmnInfoInit23a(pDM_Odm, ODM_CMNINFO_EXT_LNA, true);
-               ODM_CmnInfoInit23a(pDM_Odm, ODM_CMNINFO_EXT_PA, true);
-       }
-       ODM_CmnInfoInit23a(pDM_Odm, ODM_CMNINFO_BWIFI_TEST, Adapter->registrypriv.wifi_spec);
-}
-
-static void Update_ODM_ComInfo_8723a(struct rtw_adapter *Adapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(Adapter);
-       struct dm_odm_t *pDM_Odm = &pHalData->odmpriv;
-       struct dm_priv  *pdmpriv = &pHalData->dmpriv;
-       int i;
-       pdmpriv->InitODMFlag = 0;
-       /*  Pointer reference */
-       rtl8723a_odm_support_ability_set(Adapter, DYNAMIC_ALL_FUNC_ENABLE);
-
-       for (i = 0; i < NUM_STA; i++)
-               ODM_CmnInfoPtrArrayHook23a(pDM_Odm, ODM_CMNINFO_STA_STATUS, i, NULL);
-}
-
-void rtl8723a_InitHalDm(struct rtw_adapter *Adapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(Adapter);
-       struct dm_priv  *pdmpriv = &pHalData->dmpriv;
-       struct dm_odm_t *pDM_Odm = &pHalData->odmpriv;
-       u8      i;
-
-       Update_ODM_ComInfo_8723a(Adapter);
-       ODM23a_DMInit(pDM_Odm);
-       /*  Save REG_INIDATA_RATE_SEL value for TXDESC. */
-       for (i = 0; i < 32; i++)
-               pdmpriv->INIDATA_RATE[i] = rtl8723au_read8(Adapter, REG_INIDATA_RATE_SEL+i) & 0x3f;
-}
-
-void
-rtl8723a_HalDmWatchDog(
-       struct rtw_adapter *Adapter
-       )
-{
-       bool            bFwCurrentInPSMode = false;
-       bool            bFwPSAwake = true;
-       u8 bLinked = false;
-       u8 hw_init_completed = false;
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(Adapter);
-       struct dm_priv  *pdmpriv = &pHalData->dmpriv;
-
-       hw_init_completed = Adapter->hw_init_completed;
-
-       if (hw_init_completed == false)
-               goto skip_dm;
-
-       bFwCurrentInPSMode = Adapter->pwrctrlpriv.bFwCurrentInPSMode;
-       bFwPSAwake = rtl8723a_get_fwlps_rf_on(Adapter);
-
-       if (!bFwCurrentInPSMode && bFwPSAwake) {
-               /*  Read REG_INIDATA_RATE_SEL value for TXDESC. */
-               if (check_fwstate(&Adapter->mlmepriv, WIFI_STATION_STATE)) {
-                       pdmpriv->INIDATA_RATE[0] = rtl8723au_read8(Adapter, REG_INIDATA_RATE_SEL) & 0x3f;
-               } else {
-                       u8      i;
-                       for (i = 1 ; i < (Adapter->stapriv.asoc_sta_count + 1); i++)
-                               pdmpriv->INIDATA_RATE[i] = rtl8723au_read8(Adapter, (REG_INIDATA_RATE_SEL+i)) & 0x3f;
-               }
-       }
-
-       /* ODM */
-       if (rtw_linked_check(Adapter))
-               bLinked = true;
-
-       ODM_CmnInfoUpdate23a(&pHalData->odmpriv, ODM_CMNINFO_LINK, bLinked);
-       ODM_DMWatchdog23a(Adapter);
-
-skip_dm:
-
-       /*  Check GPIO to determine current RF on/off and Pbc status. */
-       /*  Check Hardware Radio ON/OFF or not */
-       dm_CheckPbcGPIO(Adapter);
-}
diff --git a/drivers/staging/rtl8723au/hal/rtl8723a_hal_init.c b/drivers/staging/rtl8723au/hal/rtl8723a_hal_init.c
deleted file mode 100644 (file)
index 1ea0af4..0000000
+++ /dev/null
@@ -1,2076 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#define _HAL_INIT_C_
-
-#include <linux/firmware.h>
-#include <drv_types.h>
-#include <rtw_efuse.h>
-
-#include <rtl8723a_hal.h>
-#include <usb_ops_linux.h>
-
-static void _FWDownloadEnable(struct rtw_adapter *padapter, bool enable)
-{
-       u8 tmp;
-
-       if (enable) {
-               /*  8051 enable */
-               tmp = rtl8723au_read8(padapter, REG_SYS_FUNC_EN + 1);
-               rtl8723au_write8(padapter, REG_SYS_FUNC_EN + 1, tmp | 0x04);
-
-               /*  MCU firmware download enable. */
-               tmp = rtl8723au_read8(padapter, REG_MCUFWDL);
-               rtl8723au_write8(padapter, REG_MCUFWDL, tmp | 0x01);
-
-               /*  8051 reset */
-               tmp = rtl8723au_read8(padapter, REG_MCUFWDL + 2);
-               rtl8723au_write8(padapter, REG_MCUFWDL + 2, tmp & 0xf7);
-       } else {
-               /*  MCU firmware download disable. */
-               tmp = rtl8723au_read8(padapter, REG_MCUFWDL);
-               rtl8723au_write8(padapter, REG_MCUFWDL, tmp & 0xfe);
-
-               /*  Reserved for fw extension. */
-               rtl8723au_write8(padapter, REG_MCUFWDL + 1, 0x00);
-       }
-}
-
-static int
-_PageWrite(struct rtw_adapter *padapter, u32 page, void *buffer, u32 size)
-{
-       u8 value8;
-       u8 u8Page = (u8) (page & 0x07);
-
-       if (size > MAX_PAGE_SIZE)
-               return _FAIL;
-
-       value8 = (rtl8723au_read8(padapter, REG_MCUFWDL + 2) & 0xF8) | u8Page;
-       rtl8723au_write8(padapter, REG_MCUFWDL + 2, value8);
-
-       return rtl8723au_writeN(padapter, FW_8723A_START_ADDRESS, size, buffer);
-}
-
-static int _WriteFW(struct rtw_adapter *padapter, void *buffer, u32 size)
-{
-       /*  Since we need dynamic decide method of dwonload fw, so we
-           call this function to get chip version. */
-       /*  We can remove _ReadChipVersion from ReadpadapterInfo8192C later. */
-       int ret = _SUCCESS;
-       u32 pageNums, remainSize;
-       u32 page, offset;
-       u8 *bufferPtr = (u8 *) buffer;
-
-       pageNums = size / MAX_PAGE_SIZE;
-       /* RT_ASSERT((pageNums <= 4),
-          ("Page numbers should not greater then 4 \n")); */
-       remainSize = size % MAX_PAGE_SIZE;
-
-       for (page = 0; page < pageNums; page++) {
-               offset = page * MAX_PAGE_SIZE;
-               ret = _PageWrite(padapter, page, bufferPtr + offset,
-                                MAX_PAGE_SIZE);
-
-               if (ret == _FAIL)
-                       goto exit;
-       }
-       if (remainSize) {
-               offset = pageNums * MAX_PAGE_SIZE;
-               page = pageNums;
-               ret = _PageWrite(padapter, page, bufferPtr + offset,
-                                remainSize);
-
-               if (ret == _FAIL)
-                       goto exit;
-       }
-       RT_TRACE(_module_hal_init_c_, _drv_info_,
-                "_WriteFW Done- for Normal chip.\n");
-
-exit:
-       return ret;
-}
-
-static int _FWFreeToGo(struct rtw_adapter *padapter)
-{
-       u32 counter = 0;
-       u32 value32;
-
-       /*  polling CheckSum report */
-       do {
-               value32 = rtl8723au_read32(padapter, REG_MCUFWDL);
-               if (value32 & FWDL_ChkSum_rpt)
-                       break;
-       } while (counter++ < POLLING_READY_TIMEOUT_COUNT);
-
-       if (counter >= POLLING_READY_TIMEOUT_COUNT) {
-               RT_TRACE(_module_hal_init_c_, _drv_err_,
-                        "%s: chksum report fail! REG_MCUFWDL:0x%08x\n",
-                        __func__, value32);
-               return _FAIL;
-       }
-       RT_TRACE(_module_hal_init_c_, _drv_info_,
-                "%s: Checksum report OK! REG_MCUFWDL:0x%08x\n", __func__,
-                value32);
-
-       value32 = rtl8723au_read32(padapter, REG_MCUFWDL);
-       value32 |= MCUFWDL_RDY;
-       value32 &= ~WINTINI_RDY;
-       rtl8723au_write32(padapter, REG_MCUFWDL, value32);
-
-       /*  polling for FW ready */
-       counter = 0;
-       do {
-               value32 = rtl8723au_read32(padapter, REG_MCUFWDL);
-               if (value32 & WINTINI_RDY) {
-                       RT_TRACE(_module_hal_init_c_, _drv_info_,
-                                "%s: Polling FW ready success!! REG_MCUFWDL:0x%08x\n",
-                                __func__, value32);
-                       return _SUCCESS;
-               }
-               udelay(5);
-       } while (counter++ < POLLING_READY_TIMEOUT_COUNT);
-
-       RT_TRACE(_module_hal_init_c_, _drv_err_,
-                "%s: Polling FW ready fail!! REG_MCUFWDL:0x%08x\n",
-                __func__, value32);
-       return _FAIL;
-}
-
-#define IS_FW_81xxC(padapter)  (((GET_HAL_DATA(padapter))->FirmwareSignature & 0xFFF0) == 0x88C0)
-
-void rtl8723a_FirmwareSelfReset(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       u8 u1bTmp;
-       u8 Delay = 100;
-
-       if (!(IS_FW_81xxC(padapter) &&
-             ((pHalData->FirmwareVersion < 0x21) ||
-              (pHalData->FirmwareVersion == 0x21 &&
-               pHalData->FirmwareSubVersion < 0x01)))) {
-               /*  after 88C Fw v33.1 */
-               /* 0x1cf = 0x20. Inform 8051 to reset. 2009.12.25. tynli_test */
-               rtl8723au_write8(padapter, REG_HMETFR + 3, 0x20);
-
-               u1bTmp = rtl8723au_read8(padapter, REG_SYS_FUNC_EN + 1);
-               while (u1bTmp & BIT(2)) {
-                       Delay--;
-                       if (Delay == 0)
-                               break;
-                       udelay(50);
-                       u1bTmp = rtl8723au_read8(padapter, REG_SYS_FUNC_EN + 1);
-               }
-               RT_TRACE(_module_hal_init_c_, _drv_info_,
-                        "-%s: 8051 reset success (%d)\n", __func__,
-                        Delay);
-
-               if ((Delay == 0)) {
-                       /* force firmware reset */
-                       u1bTmp = rtl8723au_read8(padapter, REG_SYS_FUNC_EN + 1);
-                       rtl8723au_write8(padapter, REG_SYS_FUNC_EN + 1,
-                                        u1bTmp & ~BIT(2));
-               }
-       }
-}
-
-/*  */
-/*     Description: */
-/*             Download 8192C firmware code. */
-/*  */
-/*  */
-int rtl8723a_FirmwareDownload(struct rtw_adapter *padapter)
-{
-       int rtStatus = _SUCCESS;
-       u8 writeFW_retry = 0;
-       unsigned long fwdl_start_time;
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
-       struct device *device = dvobj_to_dev(dvobj);
-       struct rt_8723a_firmware_hdr *pFwHdr = NULL;
-       const struct firmware *fw;
-       char *fw_name;
-       u8 *firmware_buf = NULL;
-       u8 *buf;
-       int fw_size;
-       static int log_version;
-
-       RT_TRACE(_module_hal_init_c_, _drv_info_, "+%s\n", __func__);
-
-       if (IS_8723A_A_CUT(pHalData->VersionID)) {
-               fw_name = "rtlwifi/rtl8723aufw_A.bin";
-               RT_TRACE(_module_hal_init_c_, _drv_info_,
-                        "rtl8723a_FirmwareDownload: R8723FwImageArray_UMC for RTL8723A A CUT\n");
-       } else if (IS_8723A_B_CUT(pHalData->VersionID)) {
-               /*  WLAN Fw. */
-               if (padapter->registrypriv.wifi_spec == 1) {
-                       fw_name = "rtlwifi/rtl8723aufw_B_NoBT.bin";
-                       DBG_8723A(" Rtl8723_FwUMCBCutImageArrayWithoutBT for "
-                                 "RTL8723A B CUT\n");
-               } else {
-                       if (rtl8723a_BT_coexist(padapter)) {
-                               fw_name = "rtlwifi/rtl8723aufw_B.bin";
-                               DBG_8723A(" Rtl8723_FwUMCBCutImageArrayWithBT "
-                                         "for RTL8723A B CUT\n");
-                       } else {
-                               fw_name = "rtlwifi/rtl8723aufw_B_NoBT.bin";
-                               DBG_8723A(" Rtl8723_FwUMCBCutImageArrayWithout "
-                                         "BT for RTL8723A B CUT\n");
-                       }
-               }
-       } else {
-               /*  <Roger_TODO> We should download proper RAM Code here
-                   to match the ROM code. */
-               RT_TRACE(_module_hal_init_c_, _drv_err_,
-                        "%s: unknown version!\n", __func__);
-               rtStatus = _FAIL;
-               goto Exit;
-       }
-
-       pr_info("rtl8723au: Loading firmware %s\n", fw_name);
-       if (request_firmware(&fw, fw_name, device)) {
-               pr_err("rtl8723au: request_firmware load failed\n");
-               rtStatus = _FAIL;
-               goto Exit;
-       }
-       if (!fw) {
-               pr_err("rtl8723au: Firmware %s not available\n", fw_name);
-               rtStatus = _FAIL;
-               goto Exit;
-       }
-       firmware_buf = kmemdup(fw->data, fw->size, GFP_KERNEL);
-       fw_size = fw->size;
-       release_firmware(fw);
-       if (!firmware_buf) {
-               rtStatus = _FAIL;
-               goto Exit;
-       }
-       buf = firmware_buf;
-
-       /*  To Check Fw header. Added by tynli. 2009.12.04. */
-       pFwHdr = (struct rt_8723a_firmware_hdr *)firmware_buf;
-
-       pHalData->FirmwareVersion = le16_to_cpu(pFwHdr->Version);
-       pHalData->FirmwareSubVersion = pFwHdr->Subversion;
-       pHalData->FirmwareSignature = le16_to_cpu(pFwHdr->Signature);
-
-       DBG_8723A("%s: fw_ver =%d fw_subver =%d sig = 0x%x\n",
-                 __func__, pHalData->FirmwareVersion,
-                 pHalData->FirmwareSubVersion, pHalData->FirmwareSignature);
-
-       if (!log_version++)
-               pr_info("%sFirmware Version %d, SubVersion %d, Signature "
-                       "0x%x\n", DRIVER_PREFIX, pHalData->FirmwareVersion,
-                       pHalData->FirmwareSubVersion,
-                       pHalData->FirmwareSignature);
-
-       if (IS_FW_HEADER_EXIST(pFwHdr)) {
-               /*  Shift 32 bytes for FW header */
-               buf = buf + 32;
-               fw_size = fw_size - 32;
-       }
-
-       /*  Suggested by Filen. If 8051 is running in RAM code, driver should
-           inform Fw to reset by itself, */
-       /*  or it will cause download Fw fail. 2010.02.01. by tynli. */
-       if (rtl8723au_read8(padapter, REG_MCUFWDL) & RAM_DL_SEL) {
-               /* 8051 RAM code */
-               rtl8723a_FirmwareSelfReset(padapter);
-               rtl8723au_write8(padapter, REG_MCUFWDL, 0x00);
-       }
-
-       _FWDownloadEnable(padapter, true);
-       fwdl_start_time = jiffies;
-       while (1) {
-               /* reset the FWDL chksum */
-               rtl8723au_write8(padapter, REG_MCUFWDL,
-                                rtl8723au_read8(padapter, REG_MCUFWDL) |
-                                FWDL_ChkSum_rpt);
-
-               rtStatus = _WriteFW(padapter, buf, fw_size);
-
-               if (rtStatus == _SUCCESS ||
-                   (jiffies_to_msecs(jiffies - fwdl_start_time) > 500 &&
-                    writeFW_retry++ >= 3))
-                       break;
-
-               DBG_8723A("%s writeFW_retry:%u, time after fwdl_start_time:"
-                         "%ums\n", __func__, writeFW_retry,
-                         jiffies_to_msecs(jiffies - fwdl_start_time));
-       }
-       _FWDownloadEnable(padapter, false);
-       if (_SUCCESS != rtStatus) {
-               DBG_8723A("DL Firmware failed!\n");
-               goto Exit;
-       }
-
-       rtStatus = _FWFreeToGo(padapter);
-       if (_SUCCESS != rtStatus) {
-               RT_TRACE(_module_hal_init_c_, _drv_err_,
-                        "DL Firmware failed!\n");
-               goto Exit;
-       }
-       RT_TRACE(_module_hal_init_c_, _drv_info_,
-                "Firmware is ready to run!\n");
-
-Exit:
-       kfree(firmware_buf);
-       return rtStatus;
-}
-
-void rtl8723a_InitializeFirmwareVars(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-
-       /*  Init Fw LPS related. */
-       padapter->pwrctrlpriv.bFwCurrentInPSMode = false;
-
-       /*  Init H2C counter. by tynli. 2009.12.09. */
-       pHalData->LastHMEBoxNum = 0;
-}
-
-/*  */
-/*                             Efuse related code */
-/*  */
-static u8
-hal_EfuseSwitchToBank(struct rtw_adapter *padapter, u8 bank)
-{
-       u8 bRet = false;
-       u32 value32 = 0;
-
-       DBG_8723A("%s: Efuse switch bank to %d\n", __func__, bank);
-       value32 = rtl8723au_read32(padapter, EFUSE_TEST);
-       bRet = true;
-       switch (bank) {
-       case 0:
-               value32 = (value32 & ~EFUSE_SEL_MASK) |
-                       EFUSE_SEL(EFUSE_WIFI_SEL_0);
-               break;
-       case 1:
-               value32 = (value32 & ~EFUSE_SEL_MASK) |
-                       EFUSE_SEL(EFUSE_BT_SEL_0);
-               break;
-       case 2:
-               value32 = (value32 & ~EFUSE_SEL_MASK) |
-                       EFUSE_SEL(EFUSE_BT_SEL_1);
-               break;
-       case 3:
-               value32 = (value32 & ~EFUSE_SEL_MASK) |
-                       EFUSE_SEL(EFUSE_BT_SEL_2);
-               break;
-       default:
-               value32 = (value32 & ~EFUSE_SEL_MASK) |
-                       EFUSE_SEL(EFUSE_WIFI_SEL_0);
-               bRet = false;
-               break;
-       }
-       rtl8723au_write32(padapter, EFUSE_TEST, value32);
-
-       return bRet;
-}
-
-static void
-hal_ReadEFuse_WiFi(struct rtw_adapter *padapter,
-                  u16 _offset, u16 _size_byte, u8 *pbuf)
-{
-       u8 *efuseTbl = NULL;
-       u16 eFuse_Addr = 0;
-       u8 offset, wden;
-       u8 efuseHeader, efuseExtHdr, efuseData;
-       u16 i, total, used;
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-
-       /*  Do NOT excess total size of EFuse table.
-           Added by Roger, 2008.11.10. */
-       if ((_offset + _size_byte) > EFUSE_MAP_LEN_8723A) {
-               DBG_8723A("%s: Invalid offset(%#x) with read bytes(%#x)!!\n",
-                         __func__, _offset, _size_byte);
-               return;
-       }
-
-       efuseTbl = kmalloc(EFUSE_MAP_LEN_8723A, GFP_KERNEL);
-       if (!efuseTbl)
-               return;
-       /*  0xff will be efuse default value instead of 0x00. */
-       memset(efuseTbl, 0xFF, EFUSE_MAP_LEN_8723A);
-
-       /*  switch bank back to bank 0 for later BT and wifi use. */
-       hal_EfuseSwitchToBank(padapter, 0);
-
-       while (AVAILABLE_EFUSE_ADDR(eFuse_Addr)) {
-               ReadEFuseByte23a(padapter, eFuse_Addr++, &efuseHeader);
-               if (efuseHeader == 0xFF) {
-                       DBG_8723A("%s: data end at address =%#x\n", __func__,
-                                 eFuse_Addr);
-                       break;
-               }
-
-               /*  Check PG header for section num. */
-               if (EXT_HEADER(efuseHeader)) {  /* extended header */
-                       offset = GET_HDR_OFFSET_2_0(efuseHeader);
-
-                       ReadEFuseByte23a(padapter, eFuse_Addr++, &efuseExtHdr);
-                       if (ALL_WORDS_DISABLED(efuseExtHdr))
-                               continue;
-
-                       offset |= ((efuseExtHdr & 0xF0) >> 1);
-                       wden = efuseExtHdr & 0x0F;
-               } else {
-                       offset = (efuseHeader >> 4) & 0x0f;
-                       wden = efuseHeader & 0x0f;
-               }
-
-               if (offset < EFUSE_MAX_SECTION_8723A) {
-                       u16 addr;
-                       /*  Get word enable value from PG header */
-
-                       addr = offset * PGPKT_DATA_SIZE;
-                       for (i = 0; i < EFUSE_MAX_WORD_UNIT; i++) {
-                               /* Check word enable condition in the section */
-                               if (!(wden & (0x01 << i))) {
-                                       ReadEFuseByte23a(padapter, eFuse_Addr++,
-                                                     &efuseData);
-                                       efuseTbl[addr] = efuseData;
-
-                                       ReadEFuseByte23a(padapter, eFuse_Addr++,
-                                                     &efuseData);
-                                       efuseTbl[addr + 1] = efuseData;
-                               }
-                               addr += 2;
-                       }
-               } else {
-                       DBG_8723A(KERN_ERR "%s: offset(%d) is illegal!!\n",
-                                 __func__, offset);
-                       eFuse_Addr += Efuse_CalculateWordCnts23a(wden) * 2;
-               }
-       }
-
-       /*  Copy from Efuse map to output pointer memory!!! */
-       for (i = 0; i < _size_byte; i++)
-               pbuf[i] = efuseTbl[_offset + i];
-
-       /*  Calculate Efuse utilization */
-       EFUSE_GetEfuseDefinition23a(padapter, EFUSE_WIFI,
-                                TYPE_AVAILABLE_EFUSE_BYTES_TOTAL, &total);
-       used = eFuse_Addr - 1;
-       pHalData->EfuseUsedBytes = used;
-
-       kfree(efuseTbl);
-}
-
-static void
-hal_ReadEFuse_BT(struct rtw_adapter *padapter,
-                u16 _offset, u16 _size_byte, u8 *pbuf)
-{
-       u8 *efuseTbl;
-       u8 bank;
-       u16 eFuse_Addr;
-       u8 efuseHeader, efuseExtHdr, efuseData;
-       u8 offset, wden;
-       u16 i, total, used;
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-
-       /*  Do NOT excess total size of EFuse table.
-           Added by Roger, 2008.11.10. */
-       if ((_offset + _size_byte) > EFUSE_BT_MAP_LEN) {
-               DBG_8723A("%s: Invalid offset(%#x) with read bytes(%#x)!!\n",
-                         __func__, _offset, _size_byte);
-               return;
-       }
-
-       efuseTbl = kmalloc(EFUSE_BT_MAP_LEN, GFP_KERNEL);
-       if (!efuseTbl)
-               return;
-       /*  0xff will be efuse default value instead of 0x00. */
-       memset(efuseTbl, 0xFF, EFUSE_BT_MAP_LEN);
-
-       EFUSE_GetEfuseDefinition23a(padapter, EFUSE_BT,
-                                TYPE_AVAILABLE_EFUSE_BYTES_BANK, &total);
-
-       for (bank = 1; bank < EFUSE_MAX_BANK; bank++) {
-               if (hal_EfuseSwitchToBank(padapter, bank) == false) {
-                       DBG_8723A("%s: hal_EfuseSwitchToBank Fail!!\n",
-                                 __func__);
-                       goto exit;
-               }
-
-               eFuse_Addr = 0;
-
-               while (AVAILABLE_EFUSE_ADDR(eFuse_Addr)) {
-                       ReadEFuseByte23a(padapter, eFuse_Addr++, &efuseHeader);
-                       if (efuseHeader == 0xFF)
-                               break;
-
-                       /*  Check PG header for section num. */
-                       if (EXT_HEADER(efuseHeader)) {  /* extended header */
-                               offset = GET_HDR_OFFSET_2_0(efuseHeader);
-
-                               ReadEFuseByte23a(padapter, eFuse_Addr++,
-                                             &efuseExtHdr);
-                               if (ALL_WORDS_DISABLED(efuseExtHdr))
-                                       continue;
-
-                               offset |= ((efuseExtHdr & 0xF0) >> 1);
-                               wden = efuseExtHdr & 0x0F;
-                       } else {
-                               offset = (efuseHeader >> 4) & 0x0f;
-                               wden = efuseHeader & 0x0f;
-                       }
-
-                       if (offset < EFUSE_BT_MAX_SECTION) {
-                               u16 addr;
-
-                               /*  Get word enable value from PG header */
-
-                               addr = offset * PGPKT_DATA_SIZE;
-                               for (i = 0; i < EFUSE_MAX_WORD_UNIT; i++) {
-                                       /*  Check word enable condition in
-                                           the section */
-                                       if (!(wden & (0x01 << i))) {
-                                               ReadEFuseByte23a(padapter,
-                                                             eFuse_Addr++,
-                                                             &efuseData);
-                                               efuseTbl[addr] = efuseData;
-
-                                               ReadEFuseByte23a(padapter,
-                                                             eFuse_Addr++,
-                                                             &efuseData);
-                                               efuseTbl[addr + 1] = efuseData;
-                                       }
-                                       addr += 2;
-                               }
-                       } else {
-                               DBG_8723A(KERN_ERR
-                                         "%s: offset(%d) is illegal!!\n",
-                                         __func__, offset);
-                               eFuse_Addr += Efuse_CalculateWordCnts23a(wden) * 2;
-                       }
-               }
-
-               if ((eFuse_Addr - 1) < total) {
-                       DBG_8723A("%s: bank(%d) data end at %#x\n",
-                                 __func__, bank, eFuse_Addr - 1);
-                       break;
-               }
-       }
-
-       /*  switch bank back to bank 0 for later BT and wifi use. */
-       hal_EfuseSwitchToBank(padapter, 0);
-
-       /*  Copy from Efuse map to output pointer memory!!! */
-       for (i = 0; i < _size_byte; i++)
-               pbuf[i] = efuseTbl[_offset + i];
-
-       /*  */
-       /*  Calculate Efuse utilization. */
-       /*  */
-       EFUSE_GetEfuseDefinition23a(padapter, EFUSE_BT,
-                                TYPE_AVAILABLE_EFUSE_BYTES_TOTAL, &total);
-       used = (EFUSE_BT_REAL_BANK_CONTENT_LEN * (bank - 1)) + eFuse_Addr - 1;
-       pHalData->BTEfuseUsedBytes = used;
-
-exit:
-       kfree(efuseTbl);
-}
-
-void
-rtl8723a_readefuse(struct rtw_adapter *padapter,
-                  u8 efuseType, u16 _offset, u16 _size_byte, u8 *pbuf)
-{
-       if (efuseType == EFUSE_WIFI)
-               hal_ReadEFuse_WiFi(padapter, _offset, _size_byte, pbuf);
-       else
-               hal_ReadEFuse_BT(padapter, _offset, _size_byte, pbuf);
-}
-
-u16 rtl8723a_EfuseGetCurrentSize_WiFi(struct rtw_adapter *padapter)
-{
-       u16 efuse_addr = 0;
-       u8 hoffset = 0, hworden = 0;
-       u8 efuse_data, word_cnts = 0;
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-
-       efuse_addr = pHalData->EfuseUsedBytes;
-
-       DBG_8723A("%s: start_efuse_addr = 0x%X\n", __func__, efuse_addr);
-
-       /*  switch bank back to bank 0 for later BT and wifi use. */
-       hal_EfuseSwitchToBank(padapter, 0);
-
-       while (AVAILABLE_EFUSE_ADDR(efuse_addr)) {
-               if (efuse_OneByteRead23a(padapter, efuse_addr, &efuse_data) ==
-                   _FAIL) {
-                       DBG_8723A(KERN_ERR "%s: efuse_OneByteRead23a Fail! "
-                                 "addr = 0x%X !!\n", __func__, efuse_addr);
-                       break;
-               }
-
-               if (efuse_data == 0xFF)
-                       break;
-
-               if (EXT_HEADER(efuse_data)) {
-                       hoffset = GET_HDR_OFFSET_2_0(efuse_data);
-                       efuse_addr++;
-                       efuse_OneByteRead23a(padapter, efuse_addr, &efuse_data);
-                       if (ALL_WORDS_DISABLED(efuse_data))
-                               continue;
-
-                       hoffset |= ((efuse_data & 0xF0) >> 1);
-                       hworden = efuse_data & 0x0F;
-               } else {
-                       hoffset = (efuse_data >> 4) & 0x0F;
-                       hworden = efuse_data & 0x0F;
-               }
-
-               word_cnts = Efuse_CalculateWordCnts23a(hworden);
-               efuse_addr += (word_cnts * 2) + 1;
-       }
-
-       pHalData->EfuseUsedBytes = efuse_addr;
-
-       DBG_8723A("%s: CurrentSize =%d\n", __func__, efuse_addr);
-
-       return efuse_addr;
-}
-
-u16 rtl8723a_EfuseGetCurrentSize_BT(struct rtw_adapter *padapter)
-{
-       u16 btusedbytes;
-       u16 efuse_addr;
-       u8 bank, startBank;
-       u8 hoffset = 0, hworden = 0;
-       u8 efuse_data, word_cnts = 0;
-       u16 retU2 = 0;
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-
-       btusedbytes = pHalData->BTEfuseUsedBytes;
-
-       efuse_addr = (u16) ((btusedbytes % EFUSE_BT_REAL_BANK_CONTENT_LEN));
-       startBank = (u8) (1 + (btusedbytes / EFUSE_BT_REAL_BANK_CONTENT_LEN));
-
-       DBG_8723A("%s: start from bank =%d addr = 0x%X\n", __func__, startBank,
-                 efuse_addr);
-
-       EFUSE_GetEfuseDefinition23a(padapter, EFUSE_BT,
-                                TYPE_AVAILABLE_EFUSE_BYTES_BANK, &retU2);
-
-       for (bank = startBank; bank < EFUSE_MAX_BANK; bank++) {
-               if (hal_EfuseSwitchToBank(padapter, bank) == false) {
-                       DBG_8723A(KERN_ERR "%s: switch bank(%d) Fail!!\n",
-                                 __func__, bank);
-                       bank = EFUSE_MAX_BANK;
-                       break;
-               }
-
-               /*  only when bank is switched we have to reset
-                   the efuse_addr. */
-               if (bank != startBank)
-                       efuse_addr = 0;
-
-               while (AVAILABLE_EFUSE_ADDR(efuse_addr)) {
-                       if (efuse_OneByteRead23a(padapter, efuse_addr,
-                                             &efuse_data) == _FAIL) {
-                               DBG_8723A(KERN_ERR "%s: efuse_OneByteRead23a Fail!"
-                                         " addr = 0x%X !!\n",
-                                         __func__, efuse_addr);
-                               bank = EFUSE_MAX_BANK;
-                               break;
-                       }
-
-                       if (efuse_data == 0xFF)
-                               break;
-
-                       if (EXT_HEADER(efuse_data)) {
-                               hoffset = GET_HDR_OFFSET_2_0(efuse_data);
-                               efuse_addr++;
-                               efuse_OneByteRead23a(padapter, efuse_addr,
-                                                 &efuse_data);
-                               if (ALL_WORDS_DISABLED(efuse_data)) {
-                                       efuse_addr++;
-                                       continue;
-                               }
-
-                               hoffset |= ((efuse_data & 0xF0) >> 1);
-                               hworden = efuse_data & 0x0F;
-                       } else {
-                               hoffset = (efuse_data >> 4) & 0x0F;
-                               hworden = efuse_data & 0x0F;
-                       }
-                       word_cnts = Efuse_CalculateWordCnts23a(hworden);
-                       /* read next header */
-                       efuse_addr += (word_cnts * 2) + 1;
-               }
-
-               /*  Check if we need to check next bank efuse */
-               if (efuse_addr < retU2)
-                       break;  /*  don't need to check next bank. */
-       }
-
-       retU2 = ((bank - 1) * EFUSE_BT_REAL_BANK_CONTENT_LEN) + efuse_addr;
-       pHalData->BTEfuseUsedBytes = retU2;
-
-       DBG_8723A("%s: CurrentSize =%d\n", __func__, retU2);
-       return retU2;
-}
-
-void rtl8723a_read_chip_version(struct rtw_adapter *padapter)
-{
-       u32 value32;
-       struct hal_version ChipVersion;
-       struct hal_data_8723a *pHalData;
-
-       pHalData = GET_HAL_DATA(padapter);
-
-       value32 = rtl8723au_read32(padapter, REG_SYS_CFG);
-       ChipVersion.ICType = CHIP_8723A;
-       ChipVersion.ChipType = ((value32 & RTL_ID) ? TEST_CHIP : NORMAL_CHIP);
-       pHalData->rf_type = RF_1T1R;
-       ChipVersion.VendorType =
-               ((value32 & VENDOR_ID) ? CHIP_VENDOR_UMC : CHIP_VENDOR_TSMC);
-       ChipVersion.CUTVersion = (value32 & CHIP_VER_RTL_MASK) >> CHIP_VER_RTL_SHIFT;   /*  IC version (CUT) */
-
-       /*  For regulator mode. by tynli. 2011.01.14 */
-       pHalData->RegulatorMode = ((value32 & SPS_SEL) ?
-                                  RT_LDO_REGULATOR : RT_SWITCHING_REGULATOR);
-
-       value32 = rtl8723au_read32(padapter, REG_GPIO_OUTSTS);
-       /*  ROM code version. */
-       ChipVersion.ROMVer = (value32 & RF_RL_ID) >> 20;
-
-       /*  For multi-function consideration. Added by Roger, 2010.10.06. */
-       pHalData->MultiFunc = RT_MULTI_FUNC_NONE;
-       value32 = rtl8723au_read32(padapter, REG_MULTI_FUNC_CTRL);
-       pHalData->MultiFunc |=
-               ((value32 & WL_FUNC_EN) ? RT_MULTI_FUNC_WIFI : 0);
-       pHalData->MultiFunc |= ((value32 & BT_FUNC_EN) ? RT_MULTI_FUNC_BT : 0);
-       pHalData->MultiFunc |=
-               ((value32 & GPS_FUNC_EN) ? RT_MULTI_FUNC_GPS : 0);
-       pHalData->PolarityCtl =
-               ((value32 & WL_HWPDN_SL) ? RT_POLARITY_HIGH_ACT :
-                RT_POLARITY_LOW_ACT);
-       pHalData->VersionID = ChipVersion;
-
-       MSG_8723A("RF_Type is %x!!\n", pHalData->rf_type);
-}
-
-/*  */
-/*  */
-/*  20100209 Joseph: */
-/*  This function is used only for 92C to set REG_BCN_CTRL(0x550) register. */
-/*  We just reserve the value of the register in variable
-    pHalData->RegBcnCtrlVal and then operate */
-/*  the value of the register via atomic operation. */
-/*  This prevents from race condition when setting this register. */
-/*  The value of pHalData->RegBcnCtrlVal is initialized in
-    HwConfigureRTL8192CE() function. */
-/*  */
-void SetBcnCtrlReg23a(struct rtw_adapter *padapter, u8 SetBits, u8 ClearBits)
-{
-       u8 val8;
-
-       val8 = rtl8723au_read8(padapter, REG_BCN_CTRL);
-       val8 |= SetBits;
-       val8 &= ~ClearBits;
-
-       rtl8723au_write8(padapter, REG_BCN_CTRL, val8);
-}
-
-void rtl8723a_InitBeaconParameters(struct rtw_adapter *padapter)
-{
-       rtl8723au_write16(padapter, REG_BCN_CTRL, 0x1010);
-
-       /*  TODO: Remove these magic number */
-       rtl8723au_write16(padapter, REG_TBTT_PROHIBIT, 0x6404); /*  ms */
-       /*  Firmware will control REG_DRVERLYINT when power saving is enable, */
-       /*  so don't set this register on STA mode. */
-       if (check_fwstate(&padapter->mlmepriv, WIFI_STATION_STATE) == false)
-               rtl8723au_write8(padapter, REG_DRVERLYINT,
-                                DRIVER_EARLY_INT_TIME);
-       /*  2ms */
-       rtl8723au_write8(padapter, REG_BCNDMATIM, BCN_DMA_ATIME_INT_TIME);
-
-       /*  Suggested by designer timchen. Change beacon AIFS to the
-           largest number beacause test chip does not contension before
-           sending beacon. by tynli. 2009.11.03 */
-       rtl8723au_write16(padapter, REG_BCNTCFG, 0x660F);
-}
-
-static void ResumeTxBeacon(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-
-       /*  2010.03.01. Marked by tynli. No need to call workitem beacause
-           we record the value */
-       /*  which should be read from register to a global variable. */
-
-       RT_TRACE(_module_hci_hal_init_c_, _drv_info_, "+ResumeTxBeacon\n");
-
-       pHalData->RegFwHwTxQCtrl |= BIT(6);
-       rtl8723au_write8(padapter, REG_FWHW_TXQ_CTRL + 2,
-                        pHalData->RegFwHwTxQCtrl);
-       rtl8723au_write8(padapter, REG_TBTT_PROHIBIT + 1, 0xff);
-       pHalData->RegReg542 |= BIT(0);
-       rtl8723au_write8(padapter, REG_TBTT_PROHIBIT + 2, pHalData->RegReg542);
-}
-
-static void StopTxBeacon(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-
-       /*  2010.03.01. Marked by tynli. No need to call workitem beacause
-           we record the value */
-       /*  which should be read from register to a global variable. */
-
-       RT_TRACE(_module_hci_hal_init_c_, _drv_info_, "+StopTxBeacon\n");
-
-       pHalData->RegFwHwTxQCtrl &= ~BIT(6);
-       rtl8723au_write8(padapter, REG_FWHW_TXQ_CTRL + 2,
-                        pHalData->RegFwHwTxQCtrl);
-       rtl8723au_write8(padapter, REG_TBTT_PROHIBIT + 1, 0x64);
-       pHalData->RegReg542 &= ~BIT(0);
-       rtl8723au_write8(padapter, REG_TBTT_PROHIBIT + 2, pHalData->RegReg542);
-}
-
-static void _BeaconFunctionEnable(struct rtw_adapter *padapter, u8 Enable,
-                                 u8 Linked)
-{
-       SetBcnCtrlReg23a(padapter, DIS_TSF_UDT | EN_BCN_FUNCTION | DIS_BCNQ_SUB,
-                     0);
-       rtl8723au_write8(padapter, REG_RD_CTRL + 1, 0x6F);
-}
-
-void rtl8723a_SetBeaconRelatedRegisters(struct rtw_adapter *padapter)
-{
-       u32 value32;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-
-       /* reset TSF, enable update TSF, correcting TSF On Beacon */
-
-       /* REG_BCN_INTERVAL */
-       /* REG_BCNDMATIM */
-       /* REG_ATIMWND */
-       /* REG_TBTT_PROHIBIT */
-       /* REG_DRVERLYINT */
-       /* REG_BCN_MAX_ERR */
-       /* REG_BCNTCFG (0x510) */
-       /* REG_DUAL_TSF_RST */
-       /* REG_BCN_CTRL (0x550) */
-
-       /*  */
-       /*  ATIM window */
-       /*  */
-       rtl8723au_write16(padapter, REG_ATIMWND, 2);
-
-       /*  */
-       /*  Beacon interval (in unit of TU). */
-       /*  */
-       rtl8723au_write16(padapter, REG_BCN_INTERVAL, pmlmeinfo->bcn_interval);
-
-       rtl8723a_InitBeaconParameters(padapter);
-
-       rtl8723au_write8(padapter, REG_SLOT, 0x09);
-
-       /*  */
-       /*  Reset TSF Timer to zero, added by Roger. 2008.06.24 */
-       /*  */
-       value32 = rtl8723au_read32(padapter, REG_TCR);
-       value32 &= ~TSFRST;
-       rtl8723au_write32(padapter, REG_TCR, value32);
-
-       value32 |= TSFRST;
-       rtl8723au_write32(padapter, REG_TCR, value32);
-
-       /*  NOTE: Fix test chip's bug (about contention windows's randomness) */
-       if (check_fwstate(&padapter->mlmepriv, WIFI_ADHOC_STATE |
-                         WIFI_ADHOC_MASTER_STATE | WIFI_AP_STATE) == true) {
-               rtl8723au_write8(padapter, REG_RXTSF_OFFSET_CCK, 0x50);
-               rtl8723au_write8(padapter, REG_RXTSF_OFFSET_OFDM, 0x50);
-       }
-
-       _BeaconFunctionEnable(padapter, true, true);
-
-       ResumeTxBeacon(padapter);
-       SetBcnCtrlReg23a(padapter, DIS_BCNQ_SUB, 0);
-}
-
-void rtl8723a_SetHalODMVar(struct rtw_adapter *Adapter,
-                          enum hal_odm_variable eVariable,
-                          void *pValue1, bool bSet)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(Adapter);
-       struct dm_odm_t *podmpriv = &pHalData->odmpriv;
-       switch (eVariable) {
-       case HAL_ODM_STA_INFO:
-       {
-               struct sta_info *psta = (struct sta_info *)pValue1;
-
-               if (bSet) {
-                       DBG_8723A("Set STA_(%d) info\n", psta->mac_id);
-                       ODM_CmnInfoPtrArrayHook23a(podmpriv,
-                                               ODM_CMNINFO_STA_STATUS,
-                                               psta->mac_id, psta);
-               } else {
-                       DBG_8723A("Clean STA_(%d) info\n", psta->mac_id);
-                               ODM_CmnInfoPtrArrayHook23a(podmpriv,
-                                                       ODM_CMNINFO_STA_STATUS,
-                                                       psta->mac_id, NULL);
-               }
-       }
-               break;
-       case HAL_ODM_P2P_STATE:
-               ODM_CmnInfoUpdate23a(podmpriv, ODM_CMNINFO_WIFI_DIRECT, bSet);
-               break;
-       case HAL_ODM_WIFI_DISPLAY_STATE:
-               ODM_CmnInfoUpdate23a(podmpriv, ODM_CMNINFO_WIFI_DISPLAY, bSet);
-               break;
-       default:
-               break;
-       }
-}
-
-void rtl8723a_notch_filter(struct rtw_adapter *adapter, bool enable)
-{
-       if (enable) {
-               DBG_8723A("Enable notch filter\n");
-               rtl8723au_write8(adapter, rOFDM0_RxDSP + 1,
-                                rtl8723au_read8(adapter, rOFDM0_RxDSP + 1) |
-                                BIT(1));
-       } else {
-               DBG_8723A("Disable notch filter\n");
-               rtl8723au_write8(adapter, rOFDM0_RxDSP + 1,
-                          rtl8723au_read8(adapter, rOFDM0_RxDSP + 1) &
-                                ~BIT(1));
-       }
-}
-
-bool c2h_id_filter_ccx_8723a(u8 id)
-{
-       bool ret = false;
-       if (id == C2H_CCX_TX_RPT)
-               ret = true;
-
-       return ret;
-}
-
-int c2h_handler_8723a(struct rtw_adapter *padapter, struct c2h_evt_hdr *c2h_evt)
-{
-       int ret = _SUCCESS;
-       u8 i = 0;
-
-       if (c2h_evt == NULL) {
-               DBG_8723A("%s c2h_evt is NULL\n", __func__);
-               ret = _FAIL;
-               goto exit;
-       }
-
-       switch (c2h_evt->id) {
-       case C2H_DBG:
-               RT_TRACE(_module_hal_init_c_, _drv_info_,
-                        "C2HCommandHandler: %s\n", c2h_evt->payload);
-               break;
-
-       case C2H_CCX_TX_RPT:
-               handle_txrpt_ccx_8723a(padapter, c2h_evt->payload);
-               break;
-       case C2H_EXT_RA_RPT:
-               break;
-       case C2H_HW_INFO_EXCH:
-               RT_TRACE(_module_hal_init_c_, _drv_info_,
-                        "[BT], C2H_HW_INFO_EXCH\n");
-               for (i = 0; i < c2h_evt->plen; i++) {
-                       RT_TRACE(_module_hal_init_c_, _drv_info_,
-                                "[BT], tmpBuf[%d]= 0x%x\n", i,
-                                c2h_evt->payload[i]);
-               }
-               break;
-
-       case C2H_C2H_H2C_TEST:
-               RT_TRACE(_module_hal_init_c_, _drv_info_,
-                        "[BT], C2H_H2C_TEST\n");
-               RT_TRACE(_module_hal_init_c_, _drv_info_,
-                        "[BT], tmpBuf[0]/[1]/[2]/[3]/[4]= 0x%x/ 0x%x/ 0x%x/ 0x%x/ 0x%x\n",
-                        c2h_evt->payload[0],
-                        c2h_evt->payload[1], c2h_evt->payload[2],
-                        c2h_evt->payload[3], c2h_evt->payload[4]);
-               break;
-
-       case C2H_BT_INFO:
-               DBG_8723A("%s ,  Got  C2H_BT_INFO \n", __func__);
-               rtl8723a_fw_c2h_BT_info(padapter,
-                                       c2h_evt->payload, c2h_evt->plen);
-               break;
-
-       default:
-               ret = _FAIL;
-               break;
-       }
-
-exit:
-       return ret;
-}
-
-void handle_txrpt_ccx_8723a(struct rtw_adapter *adapter, void *buf)
-{
-       struct txrpt_ccx_8723a *txrpt_ccx = buf;
-       struct submit_ctx *pack_tx_ops = &adapter->xmitpriv.ack_tx_ops;
-
-       if (txrpt_ccx->int_ccx && adapter->xmitpriv.ack_tx) {
-               if (txrpt_ccx->pkt_ok)
-                       rtw23a_sctx_done_err(&pack_tx_ops,
-                                            RTW_SCTX_DONE_SUCCESS);
-               else
-                       rtw23a_sctx_done_err(&pack_tx_ops,
-                                            RTW_SCTX_DONE_CCX_PKT_FAIL);
-       }
-}
-
-void rtl8723a_InitAntenna_Selection(struct rtw_adapter *padapter)
-{
-       u8 val;
-
-       val = rtl8723au_read8(padapter, REG_LEDCFG2);
-       /*  Let 8051 take control antenna setting */
-       val |= BIT(7);          /*  DPDT_SEL_EN, 0x4C[23] */
-       rtl8723au_write8(padapter, REG_LEDCFG2, val);
-}
-
-void rtl8723a_CheckAntenna_Selection(struct rtw_adapter *padapter)
-{
-       u8 val;
-
-       val = rtl8723au_read8(padapter, REG_LEDCFG2);
-       /*  Let 8051 take control antenna setting */
-       if (!(val & BIT(7))) {
-               val |= BIT(7);  /*  DPDT_SEL_EN, 0x4C[23] */
-               rtl8723au_write8(padapter, REG_LEDCFG2, val);
-       }
-}
-
-void rtl8723a_DeinitAntenna_Selection(struct rtw_adapter *padapter)
-{
-       u8 val;
-
-       val = rtl8723au_read8(padapter, REG_LEDCFG2);
-       /*  Let 8051 take control antenna setting */
-       val &= ~BIT(7);         /*  DPDT_SEL_EN, clear 0x4C[23] */
-       rtl8723au_write8(padapter, REG_LEDCFG2, val);
-}
-
-void rtl8723a_init_default_value(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData;
-       struct dm_priv *pdmpriv;
-       u8 i;
-
-       pHalData = GET_HAL_DATA(padapter);
-       pdmpriv = &pHalData->dmpriv;
-
-       /*  init default value */
-       pHalData->bIQKInitialized = false;
-       if (!padapter->pwrctrlpriv.bkeepfwalive)
-               pHalData->LastHMEBoxNum = 0;
-
-       pHalData->bIQKInitialized = false;
-
-       /*  init dm default value */
-       pdmpriv->TM_Trigger = 0;        /* for IQK */
-/*     pdmpriv->binitialized = false; */
-/*     pdmpriv->prv_traffic_idx = 3; */
-/*     pdmpriv->initialize = 0; */
-
-       pdmpriv->ThermalValue_HP_index = 0;
-       for (i = 0; i < HP_THERMAL_NUM; i++)
-               pdmpriv->ThermalValue_HP[i] = 0;
-
-       /*  init Efuse variables */
-       pHalData->EfuseUsedBytes = 0;
-       pHalData->BTEfuseUsedBytes = 0;
-}
-
-u8 GetEEPROMSize8723A(struct rtw_adapter *padapter)
-{
-       u8 size = 0;
-       u32 cr;
-
-       cr = rtl8723au_read16(padapter, REG_9346CR);
-       /*  6: EEPROM used is 93C46, 4: boot from E-Fuse. */
-       size = (cr & BOOT_FROM_EEPROM) ? 6 : 4;
-
-       MSG_8723A("EEPROM type is %s\n", size == 4 ? "E-FUSE" : "93C46");
-
-       return size;
-}
-
-/*  */
-/*  */
-/*  LLT R/W/Init function */
-/*  */
-/*  */
-static int _LLTWrite(struct rtw_adapter *padapter, u32 address, u32 data)
-{
-       int status = _SUCCESS;
-       s32 count = 0;
-       u32 value = _LLT_INIT_ADDR(address) | _LLT_INIT_DATA(data) |
-                   _LLT_OP(_LLT_WRITE_ACCESS);
-       u16 LLTReg = REG_LLT_INIT;
-
-       rtl8723au_write32(padapter, LLTReg, value);
-
-       /* polling */
-       do {
-               value = rtl8723au_read32(padapter, LLTReg);
-               if (_LLT_NO_ACTIVE == _LLT_OP_VALUE(value))
-                       break;
-
-               if (count > POLLING_LLT_THRESHOLD) {
-                       RT_TRACE(_module_hal_init_c_, _drv_err_,
-                                "Failed to polling write LLT done at address %d!\n",
-                                address);
-                       status = _FAIL;
-                       break;
-               }
-       } while (count++);
-
-       return status;
-}
-
-int InitLLTTable23a(struct rtw_adapter *padapter, u32 boundary)
-{
-       int status = _SUCCESS;
-       u32 i;
-       u32 txpktbuf_bndy = boundary;
-       u32 Last_Entry_Of_TxPktBuf = LAST_ENTRY_OF_TX_PKT_BUFFER;
-
-       for (i = 0; i < (txpktbuf_bndy - 1); i++) {
-               status = _LLTWrite(padapter, i, i + 1);
-               if (status != _SUCCESS)
-                       return status;
-       }
-
-       /*  end of list */
-       status = _LLTWrite(padapter, (txpktbuf_bndy - 1), 0xFF);
-       if (status != _SUCCESS)
-               return status;
-
-       /*  Make the other pages as ring buffer */
-       /*  This ring buffer is used as beacon buffer if we config this
-           MAC as two MAC transfer. */
-       /*  Otherwise used as local loopback buffer. */
-       for (i = txpktbuf_bndy; i < Last_Entry_Of_TxPktBuf; i++) {
-               status = _LLTWrite(padapter, i, (i + 1));
-               if (_SUCCESS != status)
-                       return status;
-       }
-
-       /*  Let last entry point to the start entry of ring buffer */
-       status = _LLTWrite(padapter, Last_Entry_Of_TxPktBuf, txpktbuf_bndy);
-
-       return status;
-}
-
-static void _DisableGPIO(struct rtw_adapter *padapter)
-{
-/***************************************
-j. GPIO_PIN_CTRL 0x44[31:0]= 0x000
-k.Value = GPIO_PIN_CTRL[7:0]
-l. GPIO_PIN_CTRL 0x44[31:0] = 0x00FF0000 | (value <<8); write external PIN level
-m. GPIO_MUXCFG 0x42 [15:0] = 0x0780
-n. LEDCFG 0x4C[15:0] = 0x8080
-***************************************/
-       u32 value32;
-       u32 u4bTmp;
-
-       /* 1. Disable GPIO[7:0] */
-       rtl8723au_write16(padapter, REG_GPIO_PIN_CTRL + 2, 0x0000);
-       value32 = rtl8723au_read32(padapter, REG_GPIO_PIN_CTRL) & 0xFFFF00FF;
-       u4bTmp = value32 & 0x000000FF;
-       value32 |= ((u4bTmp << 8) | 0x00FF0000);
-       rtl8723au_write32(padapter, REG_GPIO_PIN_CTRL, value32);
-
-       /*  */
-       /*  <Roger_Notes> For RTL8723u multi-function configuration which
-           was autoload from Efuse offset 0x0a and 0x0b, */
-       /*  WLAN HW GPIO[9], GPS HW GPIO[10] and BT HW GPIO[11]. */
-       /*  Added by Roger, 2010.10.07. */
-       /*  */
-       /* 2. Disable GPIO[8] and GPIO[12] */
-
-       /*  Configure all pins as input mode. */
-       rtl8723au_write16(padapter, REG_GPIO_IO_SEL_2, 0x0000);
-       value32 = rtl8723au_read32(padapter, REG_GPIO_PIN_CTRL_2) & 0xFFFF001F;
-       u4bTmp = value32 & 0x0000001F;
-       /*  Set pin 8, 10, 11 and pin 12 to output mode. */
-       value32 |= ((u4bTmp << 8) | 0x001D0000);
-       rtl8723au_write32(padapter, REG_GPIO_PIN_CTRL_2, value32);
-
-       /* 3. Disable LED0 & 1 */
-       rtl8723au_write16(padapter, REG_LEDCFG0, 0x8080);
-}                              /* end of _DisableGPIO() */
-
-static void _DisableRFAFEAndResetBB8192C(struct rtw_adapter *padapter)
-{
-/**************************************
-a.     TXPAUSE 0x522[7:0] = 0xFF               Pause MAC TX queue
-b.     RF path 0 offset 0x00 = 0x00            disable RF
-c.     APSD_CTRL 0x600[7:0] = 0x40
-d.     SYS_FUNC_EN 0x02[7:0] = 0x16            reset BB state machine
-e.     SYS_FUNC_EN 0x02[7:0] = 0x14            reset BB state machine
-***************************************/
-       u8 value8;
-
-       rtl8723au_write8(padapter, REG_TXPAUSE, 0xFF);
-
-       PHY_SetRFReg(padapter, RF_PATH_A, 0x0, bMaskByte0, 0x0);
-
-       value8 = APSDOFF;
-       rtl8723au_write8(padapter, REG_APSD_CTRL, value8);      /* 0x40 */
-
-       /*  Set BB reset at first */
-       value8 = FEN_USBD | FEN_USBA | FEN_BB_GLB_RSTn;
-       rtl8723au_write8(padapter, REG_SYS_FUNC_EN, value8);    /* 0x16 */
-
-       /*  Set global reset. */
-       value8 &= ~FEN_BB_GLB_RSTn;
-       rtl8723au_write8(padapter, REG_SYS_FUNC_EN, value8);    /* 0x14 */
-
-       /*  2010/08/12 MH We need to set BB/GLBAL reset to save power
-           for SS mode. */
-}
-
-static void _ResetDigitalProcedure1_92C(struct rtw_adapter *padapter,
-                                       bool bWithoutHWSM)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-
-       if (IS_FW_81xxC(padapter) && (pHalData->FirmwareVersion <= 0x20)) {
-       /*****************************
-       f.      MCUFWDL 0x80[7:0]= 0            reset MCU ready status
-       g.      SYS_FUNC_EN 0x02[10]= 0         reset MCU register, (8051 reset)
-       h.      SYS_FUNC_EN 0x02[15-12]= 5      reset MAC register, DCORE
-       i.     SYS_FUNC_EN 0x02[10]= 1          enable MCU register,
-                                               (8051 enable)
-       ******************************/
-               u16 valu16;
-               rtl8723au_write8(padapter, REG_MCUFWDL, 0);
-
-               valu16 = rtl8723au_read16(padapter, REG_SYS_FUNC_EN);
-               /* reset MCU , 8051 */
-               rtl8723au_write16(padapter, REG_SYS_FUNC_EN,
-                                 valu16 & ~FEN_CPUEN);
-
-               valu16 = rtl8723au_read16(padapter, REG_SYS_FUNC_EN) & 0x0FFF;
-               /* reset MAC */
-               rtl8723au_write16(padapter, REG_SYS_FUNC_EN,
-                                 valu16 | FEN_HWPDN | FEN_ELDR);
-
-               valu16 = rtl8723au_read16(padapter, REG_SYS_FUNC_EN);
-               /* enable MCU , 8051 */
-               rtl8723au_write16(padapter, REG_SYS_FUNC_EN,
-                                 valu16 | FEN_CPUEN);
-       } else {
-               u8 retry_cnts = 0;
-               u8 val8;
-
-               val8 = rtl8723au_read8(padapter, REG_MCUFWDL);
-
-               /*  2010/08/12 MH For USB SS, we can not stop 8051 when we
-                   are trying to enter IPS/HW&SW radio off. For
-                   S3/S4/S5/Disable, we can stop 8051 because */
-               /*  we will init FW when power on again. */
-               /*  If we want to SS mode, we can not reset 8051. */
-               if ((val8 & BIT(1)) && padapter->bFWReady) {
-                       /* IF fw in RAM code, do reset */
-                       /*  2010/08/25 MH According to RD alfred's
-                           suggestion, we need to disable other */
-                       /*  HRCV INT to influence 8051 reset. */
-                       rtl8723au_write8(padapter, REG_FWIMR, 0x20);
-                       /*  2011/02/15 MH According to Alex's
-                           suggestion, close mask to prevent
-                           incorrect FW write operation. */
-                       rtl8723au_write8(padapter, REG_FTIMR, 0x00);
-                       rtl8723au_write8(padapter, REG_FSIMR, 0x00);
-
-                       /* 8051 reset by self */
-                       rtl8723au_write8(padapter, REG_HMETFR + 3, 0x20);
-
-                       while ((retry_cnts++ < 100) &&
-                              (rtl8723au_read16(padapter, REG_SYS_FUNC_EN) &
-                               FEN_CPUEN)) {
-                               udelay(50);     /* us */
-                       }
-
-                       if (retry_cnts >= 100) {
-                               /* Reset MAC and Enable 8051 */
-                               rtl8723au_write8(padapter,
-                                                REG_SYS_FUNC_EN + 1, 0x50);
-                               mdelay(10);
-                       }
-               }
-               /* Reset MAC and Enable 8051 */
-               rtl8723au_write8(padapter, REG_SYS_FUNC_EN + 1, 0x54);
-               rtl8723au_write8(padapter, REG_MCUFWDL, 0);
-       }
-
-       if (bWithoutHWSM) {
-       /*****************************
-               Without HW auto state machine
-       g.      SYS_CLKR 0x08[15:0] = 0x30A3            disable MAC clock
-       h.      AFE_PLL_CTRL 0x28[7:0] = 0x80           disable AFE PLL
-       i.      AFE_XTAL_CTRL 0x24[15:0] = 0x880F       gated AFE DIG_CLOCK
-       j.      SYS_ISO_CTRL 0x00[7:0] = 0xF9           isolated digital to PON
-       ******************************/
-               /* modify to 0x70A3 by Scott. */
-               rtl8723au_write16(padapter, REG_SYS_CLKR, 0x70A3);
-               rtl8723au_write8(padapter, REG_AFE_PLL_CTRL, 0x80);
-               rtl8723au_write16(padapter, REG_AFE_XTAL_CTRL, 0x880F);
-               rtl8723au_write8(padapter, REG_SYS_ISO_CTRL, 0xF9);
-       } else {
-               /*  Disable all RF/BB power */
-               rtl8723au_write8(padapter, REG_RF_CTRL, 0x00);
-       }
-}
-
-static void _ResetDigitalProcedure2(struct rtw_adapter *padapter)
-{
-/*****************************
-k.     SYS_FUNC_EN 0x03[7:0] = 0x44            disable ELDR runction
-l.     SYS_CLKR 0x08[15:0] = 0x3083            disable ELDR clock
-m.     SYS_ISO_CTRL 0x01[7:0] = 0x83           isolated ELDR to PON
-******************************/
-       /* modify to 0x70a3 by Scott. */
-       rtl8723au_write16(padapter, REG_SYS_CLKR, 0x70a3);
-       /* modify to 0x82 by Scott. */
-       rtl8723au_write8(padapter, REG_SYS_ISO_CTRL + 1, 0x82);
-}
-
-static void _DisableAnalog(struct rtw_adapter *padapter, bool bWithoutHWSM)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       u16 value16;
-       u8 value8;
-
-       if (bWithoutHWSM) {
-       /*****************************
-       n.      LDOA15_CTRL 0x20[7:0] = 0x04    disable A15 power
-       o.      LDOV12D_CTRL 0x21[7:0] = 0x54   disable digital core power
-       r.      When driver call disable, the ASIC will turn off remaining
-               clock automatically
-       ******************************/
-
-               rtl8723au_write8(padapter, REG_LDOA15_CTRL, 0x04);
-               /* rtl8723au_write8(padapter, REG_LDOV12D_CTRL, 0x54); */
-
-               value8 = rtl8723au_read8(padapter, REG_LDOV12D_CTRL);
-               value8 &= ~LDV12_EN;
-               rtl8723au_write8(padapter, REG_LDOV12D_CTRL, value8);
-       }
-
-       /*****************************
-       h.      SPS0_CTRL 0x11[7:0] = 0x23              enter PFM mode
-       i.      APS_FSMCO 0x04[15:0] = 0x4802           set USB suspend
-       ******************************/
-       value8 = 0x23;
-       if (IS_81xxC_VENDOR_UMC_B_CUT(pHalData->VersionID))
-               value8 |= BIT(3);
-
-       rtl8723au_write8(padapter, REG_SPS0_CTRL, value8);
-
-       if (bWithoutHWSM) {
-               /* value16 |= (APDM_HOST | FSM_HSUS |/PFM_ALDN); */
-               /*  2010/08/31 According to Filen description, we need to
-                   use HW to shut down 8051 automatically. */
-               /*  Because suspend operation need the asistance of 8051
-                   to wait for 3ms. */
-               value16 = APDM_HOST | AFSM_HSUS | PFM_ALDN;
-       } else {
-               value16 = APDM_HOST | AFSM_HSUS | PFM_ALDN;
-       }
-
-       rtl8723au_write16(padapter, REG_APS_FSMCO, value16);    /* 0x4802 */
-
-       rtl8723au_write8(padapter, REG_RSV_CTRL, 0x0e);
-}
-
-/*  HW Auto state machine */
-int CardDisableHWSM(struct rtw_adapter *padapter, u8 resetMCU)
-{
-       if (padapter->bSurpriseRemoved)
-               return _SUCCESS;
-
-       /*  RF Off Sequence ==== */
-       _DisableRFAFEAndResetBB8192C(padapter);
-
-       /*   ==== Reset digital sequence   ====== */
-       _ResetDigitalProcedure1_92C(padapter, false);
-
-       /*   ==== Pull GPIO PIN to balance level and LED control ====== */
-       _DisableGPIO(padapter);
-
-       /*   ==== Disable analog sequence === */
-       _DisableAnalog(padapter, false);
-
-       RT_TRACE(_module_hci_hal_init_c_, _drv_info_,
-                "======> Card disable finished.\n");
-
-       return _SUCCESS;
-}
-
-/*  without HW Auto state machine */
-int CardDisableWithoutHWSM(struct rtw_adapter *padapter)
-{
-       if (padapter->bSurpriseRemoved)
-               return _SUCCESS;
-
-       /*  RF Off Sequence ==== */
-       _DisableRFAFEAndResetBB8192C(padapter);
-
-       /*   ==== Reset digital sequence   ====== */
-       _ResetDigitalProcedure1_92C(padapter, true);
-
-       /*   ==== Pull GPIO PIN to balance level and LED control ====== */
-       _DisableGPIO(padapter);
-
-       /*   ==== Reset digital sequence   ====== */
-       _ResetDigitalProcedure2(padapter);
-
-       /*   ==== Disable analog sequence === */
-       _DisableAnalog(padapter, true);
-
-       return _SUCCESS;
-}
-
-void Hal_InitPGData(struct rtw_adapter *padapter, u8 *PROMContent)
-{
-       struct eeprom_priv *pEEPROM = GET_EEPROM_EFUSE_PRIV(padapter);
-
-       if (!pEEPROM->bautoload_fail_flag) {    /*  autoload OK. */
-               if (!pEEPROM->EepromOrEfuse) {
-                       /*  Read EFUSE real map to shadow. */
-                       EFUSE_ShadowMapUpdate23a(padapter, EFUSE_WIFI);
-                       memcpy(PROMContent, pEEPROM->efuse_eeprom_data,
-                              HWSET_MAX_SIZE);
-               }
-       } else {
-               RT_TRACE(_module_hci_hal_init_c_, _drv_notice_,
-                        "AutoLoad Fail reported from CR9346!!\n");
-               /* update to default value 0xFF */
-               if (!pEEPROM->EepromOrEfuse)
-                       EFUSE_ShadowMapUpdate23a(padapter, EFUSE_WIFI);
-               memcpy(PROMContent, pEEPROM->efuse_eeprom_data,
-                      HWSET_MAX_SIZE);
-       }
-}
-
-void Hal_EfuseParseIDCode(struct rtw_adapter *padapter, u8 *hwinfo)
-{
-       struct eeprom_priv *pEEPROM = GET_EEPROM_EFUSE_PRIV(padapter);
-/*     struct hal_data_8723a   *pHalData = GET_HAL_DATA(padapter); */
-       u16 EEPROMId;
-
-       /*  Checl 0x8129 again for making sure autoload status!! */
-       EEPROMId = le16_to_cpu(*((__le16 *) hwinfo));
-       if (EEPROMId != RTL_EEPROM_ID) {
-               DBG_8723A("EEPROM ID(%#x) is invalid!!\n", EEPROMId);
-               pEEPROM->bautoload_fail_flag = true;
-       } else {
-               pEEPROM->bautoload_fail_flag = false;
-       }
-
-       RT_TRACE(_module_hal_init_c_, _drv_info_,
-                "EEPROM ID = 0x%04x\n", EEPROMId);
-}
-
-static void
-Hal_ReadPowerValueFromPROM_8723A(struct txpowerinfo *pwrInfo,
-                                u8 *PROMContent, bool AutoLoadFail)
-{
-       u32 rfPath, eeAddr, group, rfPathMax = 1;
-
-       memset(pwrInfo, 0, sizeof(*pwrInfo));
-
-       if (AutoLoadFail) {
-               for (group = 0; group < MAX_CHNL_GROUP; group++) {
-                       for (rfPath = 0; rfPath < rfPathMax; rfPath++) {
-                               pwrInfo->CCKIndex[rfPath][group] =
-                                       EEPROM_Default_TxPowerLevel;
-                               pwrInfo->HT40_1SIndex[rfPath][group] =
-                                       EEPROM_Default_TxPowerLevel;
-                               pwrInfo->HT40_2SIndexDiff[rfPath][group] =
-                                       EEPROM_Default_HT40_2SDiff;
-                               pwrInfo->HT20IndexDiff[rfPath][group] =
-                                       EEPROM_Default_HT20_Diff;
-                               pwrInfo->OFDMIndexDiff[rfPath][group] =
-                                       EEPROM_Default_LegacyHTTxPowerDiff;
-                               pwrInfo->HT40MaxOffset[rfPath][group] =
-                                       EEPROM_Default_HT40_PwrMaxOffset;
-                               pwrInfo->HT20MaxOffset[rfPath][group] =
-                                       EEPROM_Default_HT20_PwrMaxOffset;
-                       }
-               }
-               pwrInfo->TSSI_A[0] = EEPROM_Default_TSSI;
-               return;
-       }
-
-       for (rfPath = 0; rfPath < rfPathMax; rfPath++) {
-               for (group = 0; group < MAX_CHNL_GROUP; group++) {
-                       eeAddr =
-                           EEPROM_CCK_TX_PWR_INX_8723A + (rfPath * 3) + group;
-
-                       pwrInfo->CCKIndex[rfPath][group] = PROMContent[eeAddr];
-                       if (pwrInfo->CCKIndex[rfPath][group] > 63)
-                               pwrInfo->CCKIndex[rfPath][group] =
-                                       EEPROM_Default_TxPowerLevel;
-
-                       eeAddr = EEPROM_HT40_1S_TX_PWR_INX_8723A +
-                               (rfPath * 3) + group;
-                       pwrInfo->HT40_1SIndex[rfPath][group] =
-                               PROMContent[eeAddr];
-                       if (pwrInfo->HT40_1SIndex[rfPath][group] > 63)
-                               pwrInfo->HT40_1SIndex[rfPath][group] =
-                                       EEPROM_Default_TxPowerLevel;
-               }
-       }
-
-       for (group = 0; group < MAX_CHNL_GROUP; group++) {
-               for (rfPath = 0; rfPath < rfPathMax; rfPath++) {
-                       pwrInfo->HT40_2SIndexDiff[rfPath][group] = 0;
-                       pwrInfo->HT20IndexDiff[rfPath][group] =
-                               (PROMContent
-                                [EEPROM_HT20_TX_PWR_INX_DIFF_8723A +
-                                 group] >> (rfPath * 4)) & 0xF;
-                       /* 4bit sign number to 8 bit sign number */
-                       if (pwrInfo->HT20IndexDiff[rfPath][group] & BIT(3))
-                               pwrInfo->HT20IndexDiff[rfPath][group] |= 0xF0;
-
-                       pwrInfo->OFDMIndexDiff[rfPath][group] =
-                               (PROMContent[EEPROM_OFDM_TX_PWR_INX_DIFF_8723A +
-                                            group] >> (rfPath * 4)) & 0xF;
-
-                       pwrInfo->HT40MaxOffset[rfPath][group] =
-                               (PROMContent[EEPROM_HT40_MAX_PWR_OFFSET_8723A +
-                                            group] >> (rfPath * 4)) & 0xF;
-
-                       pwrInfo->HT20MaxOffset[rfPath][group] =
-                               (PROMContent[EEPROM_HT20_MAX_PWR_OFFSET_8723A +
-                                            group] >> (rfPath * 4)) & 0xF;
-               }
-       }
-
-       pwrInfo->TSSI_A[0] = PROMContent[EEPROM_TSSI_A_8723A];
-}
-
-static u8 Hal_GetChnlGroup(u8 chnl)
-{
-       u8 group = 0;
-
-       if (chnl < 3)           /*  Cjanel 1-3 */
-               group = 0;
-       else if (chnl < 9)      /*  Channel 4-9 */
-               group = 1;
-       else                    /*  Channel 10-14 */
-               group = 2;
-
-       return group;
-}
-
-void
-Hal_EfuseParsetxpowerinfo_8723A(struct rtw_adapter *padapter,
-                               u8 *PROMContent, bool AutoLoadFail)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       struct txpowerinfo pwrInfo;
-       u8 rfPath, ch, group, rfPathMax = 1;
-       u8 pwr, diff;
-
-       Hal_ReadPowerValueFromPROM_8723A(&pwrInfo, PROMContent, AutoLoadFail);
-       for (rfPath = 0; rfPath < rfPathMax; rfPath++) {
-               for (ch = 0; ch < CHANNEL_MAX_NUMBER; ch++) {
-                       group = Hal_GetChnlGroup(ch);
-
-                       pHalData->TxPwrLevelCck[rfPath][ch] =
-                               pwrInfo.CCKIndex[rfPath][group];
-                       pHalData->TxPwrLevelHT40_1S[rfPath][ch] =
-                               pwrInfo.HT40_1SIndex[rfPath][group];
-
-                       pHalData->TxPwrHt20Diff[rfPath][ch] =
-                               pwrInfo.HT20IndexDiff[rfPath][group];
-                       pHalData->TxPwrLegacyHtDiff[rfPath][ch] =
-                               pwrInfo.OFDMIndexDiff[rfPath][group];
-                       pHalData->PwrGroupHT20[rfPath][ch] =
-                               pwrInfo.HT20MaxOffset[rfPath][group];
-                       pHalData->PwrGroupHT40[rfPath][ch] =
-                               pwrInfo.HT40MaxOffset[rfPath][group];
-
-                       pwr = pwrInfo.HT40_1SIndex[rfPath][group];
-                       diff = pwrInfo.HT40_2SIndexDiff[rfPath][group];
-
-                       pHalData->TxPwrLevelHT40_2S[rfPath][ch] =
-                           (pwr > diff) ? (pwr - diff) : 0;
-               }
-       }
-       for (rfPath = 0; rfPath < RF_PATH_MAX; rfPath++) {
-               for (ch = 0; ch < CHANNEL_MAX_NUMBER; ch++) {
-                       RT_TRACE(_module_hci_hal_init_c_, _drv_info_,
-                                "RF(%u)-Ch(%u) [CCK / HT40_1S / HT40_2S] = [0x%x / 0x%x / 0x%x]\n",
-                                rfPath, ch,
-                                pHalData->TxPwrLevelCck[rfPath][ch],
-                                pHalData->TxPwrLevelHT40_1S[rfPath][ch],
-                                pHalData->TxPwrLevelHT40_2S[rfPath][ch]);
-
-               }
-       }
-       for (ch = 0; ch < CHANNEL_MAX_NUMBER; ch++) {
-               RT_TRACE(_module_hci_hal_init_c_, _drv_info_,
-                        "RF-A Ht20 to HT40 Diff[%u] = 0x%x(%d)\n", ch,
-                        pHalData->TxPwrHt20Diff[RF_PATH_A][ch],
-                        pHalData->TxPwrHt20Diff[RF_PATH_A][ch]);
-       }
-       for (ch = 0; ch < CHANNEL_MAX_NUMBER; ch++)
-               RT_TRACE(_module_hci_hal_init_c_, _drv_info_,
-                        "RF-A Legacy to Ht40 Diff[%u] = 0x%x\n", ch,
-                        pHalData->TxPwrLegacyHtDiff[RF_PATH_A][ch]);
-       for (ch = 0; ch < CHANNEL_MAX_NUMBER; ch++) {
-               RT_TRACE(_module_hci_hal_init_c_, _drv_info_,
-                        "RF-B Ht20 to HT40 Diff[%u] = 0x%x(%d)\n", ch,
-                        pHalData->TxPwrHt20Diff[RF_PATH_B][ch],
-                        pHalData->TxPwrHt20Diff[RF_PATH_B][ch]);
-       }
-       for (ch = 0; ch < CHANNEL_MAX_NUMBER; ch++)
-               RT_TRACE(_module_hci_hal_init_c_, _drv_info_,
-                        "RF-B Legacy to HT40 Diff[%u] = 0x%x\n", ch,
-                        pHalData->TxPwrLegacyHtDiff[RF_PATH_B][ch]);
-       if (!AutoLoadFail) {
-               struct registry_priv *registry_par = &padapter->registrypriv;
-               if (registry_par->regulatory_tid == 0xff) {
-                       if (PROMContent[RF_OPTION1_8723A] == 0xff)
-                               pHalData->EEPROMRegulatory = 0;
-                       else
-                               pHalData->EEPROMRegulatory =
-                                       PROMContent[RF_OPTION1_8723A] & 0x7;
-               } else {
-                       pHalData->EEPROMRegulatory =
-                           registry_par->regulatory_tid;
-               }
-       } else {
-               pHalData->EEPROMRegulatory = 0;
-       }
-       RT_TRACE(_module_hci_hal_init_c_, _drv_info_,
-                "EEPROMRegulatory = 0x%x\n", pHalData->EEPROMRegulatory);
-
-       if (!AutoLoadFail)
-               pHalData->bTXPowerDataReadFromEEPORM = true;
-}
-
-void
-Hal_EfuseParseBTCoexistInfo_8723A(struct rtw_adapter *padapter,
-                                 u8 *hwinfo, bool AutoLoadFail)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       u8 tempval;
-       u32 tmpu4;
-
-       if (!AutoLoadFail) {
-               tmpu4 = rtl8723au_read32(padapter, REG_MULTI_FUNC_CTRL);
-               if (tmpu4 & BT_FUNC_EN)
-                       pHalData->EEPROMBluetoothCoexist = 1;
-               else
-                       pHalData->EEPROMBluetoothCoexist = 0;
-               pHalData->EEPROMBluetoothType = BT_RTL8723A;
-
-               /*  The following need to be checked with newer version of */
-               /*  eeprom spec */
-               tempval = hwinfo[RF_OPTION4_8723A];
-               pHalData->EEPROMBluetoothAntNum = (tempval & 0x1);
-               pHalData->EEPROMBluetoothAntIsolation = (tempval & 0x10) >> 4;
-               pHalData->EEPROMBluetoothRadioShared = (tempval & 0x20) >> 5;
-       } else {
-               pHalData->EEPROMBluetoothCoexist = 0;
-               pHalData->EEPROMBluetoothType = BT_RTL8723A;
-               pHalData->EEPROMBluetoothAntNum = Ant_x2;
-               pHalData->EEPROMBluetoothAntIsolation = 0;
-               pHalData->EEPROMBluetoothRadioShared = BT_Radio_Shared;
-       }
-
-       rtl8723a_BT_init_hal_vars(padapter);
-}
-
-void
-Hal_EfuseParseEEPROMVer(struct rtw_adapter *padapter,
-                       u8 *hwinfo, bool AutoLoadFail)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-
-       if (!AutoLoadFail)
-               pHalData->EEPROMVersion = hwinfo[EEPROM_VERSION_8723A];
-       else
-               pHalData->EEPROMVersion = 1;
-       RT_TRACE(_module_hci_hal_init_c_, _drv_info_,
-                "Hal_EfuseParseEEPROMVer(), EEVer = %d\n",
-                pHalData->EEPROMVersion);
-}
-
-void
-rtl8723a_EfuseParseChnlPlan(struct rtw_adapter *padapter,
-                           u8 *hwinfo, bool AutoLoadFail)
-{
-       padapter->mlmepriv.ChannelPlan =
-               hal_com_get_channel_plan23a(padapter, hwinfo ?
-                                        hwinfo[EEPROM_ChannelPlan_8723A]:0xFF,
-                                        padapter->registrypriv.channel_plan,
-                                        RT_CHANNEL_DOMAIN_WORLD_WIDE_13,
-                                        AutoLoadFail);
-
-       DBG_8723A("mlmepriv.ChannelPlan = 0x%02x\n",
-                 padapter->mlmepriv.ChannelPlan);
-}
-
-void
-Hal_EfuseParseCustomerID(struct rtw_adapter *padapter,
-                        u8 *hwinfo, bool AutoLoadFail)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-
-       if (!AutoLoadFail) {
-               pHalData->EEPROMCustomerID = hwinfo[EEPROM_CustomID_8723A];
-               pHalData->EEPROMSubCustomerID =
-                   hwinfo[EEPROM_SubCustomID_8723A];
-       } else {
-               pHalData->EEPROMCustomerID = 0;
-               pHalData->EEPROMSubCustomerID = 0;
-       }
-       RT_TRACE(_module_hci_hal_init_c_, _drv_info_,
-                "EEPROM Customer ID: 0x%2x\n", pHalData->EEPROMCustomerID);
-       RT_TRACE(_module_hci_hal_init_c_, _drv_info_,
-                "EEPROM SubCustomer ID: 0x%02x\n",
-                pHalData->EEPROMSubCustomerID);
-}
-
-void
-Hal_EfuseParseAntennaDiversity(struct rtw_adapter *padapter,
-                              u8 *hwinfo, bool AutoLoadFail)
-{
-}
-
-void
-Hal_EfuseParseRateIndicationOption(struct rtw_adapter *padapter,
-                                  u8 *hwinfo, bool AutoLoadFail)
-{
-}
-
-void
-Hal_EfuseParseXtal_8723A(struct rtw_adapter *pAdapter,
-                        u8 *hwinfo, u8 AutoLoadFail)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(pAdapter);
-
-       if (!AutoLoadFail) {
-               pHalData->CrystalCap = hwinfo[EEPROM_XTAL_K_8723A];
-               if (pHalData->CrystalCap == 0xFF)
-                       pHalData->CrystalCap = EEPROM_Default_CrystalCap_8723A;
-       } else {
-               pHalData->CrystalCap = EEPROM_Default_CrystalCap_8723A;
-       }
-       RT_TRACE(_module_hci_hal_init_c_, _drv_info_,
-                "%s: CrystalCap = 0x%2x\n", __func__,
-                pHalData->CrystalCap);
-}
-
-void
-Hal_EfuseParseThermalMeter_8723A(struct rtw_adapter *padapter,
-                                u8 *PROMContent, bool AutoloadFail)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-
-       /*  */
-       /*  ThermalMeter from EEPROM */
-       /*  */
-       if (!AutoloadFail)
-               pHalData->EEPROMThermalMeter =
-                   PROMContent[EEPROM_THERMAL_METER_8723A];
-       else
-               pHalData->EEPROMThermalMeter = EEPROM_Default_ThermalMeter;
-
-       if ((pHalData->EEPROMThermalMeter == 0xff) || AutoloadFail) {
-               pHalData->bAPKThermalMeterIgnore = true;
-               pHalData->EEPROMThermalMeter = EEPROM_Default_ThermalMeter;
-       }
-
-       DBG_8723A("%s: ThermalMeter = 0x%x\n", __func__,
-                 pHalData->EEPROMThermalMeter);
-}
-
-static void rtl8723a_cal_txdesc_chksum(struct tx_desc *ptxdesc)
-{
-       __le16 *usPtr = (__le16 *)ptxdesc;
-       u32 count = 16;         /*  (32 bytes / 2 bytes per XOR) => 16 times */
-       u32 index;
-       u16 checksum = 0;
-
-       /*  Clear first */
-       ptxdesc->txdw7 &= cpu_to_le32(0xffff0000);
-
-       for (index = 0; index < count; index++)
-               checksum ^= le16_to_cpu(usPtr[index]);
-
-       ptxdesc->txdw7 |= cpu_to_le32(checksum & 0x0000ffff);
-}
-
-/*
- *  Description: In normal chip, we should send some packet to Hw which
- *  will be used by Fw in FW LPS mode. The function is to fill the Tx
- * descriptor of this packets, then
- */
-/*                     Fw can tell Hw to send these packet derectly. */
-/*  Added by tynli. 2009.10.15. */
-/*  */
-void rtl8723a_fill_fake_txdesc(struct rtw_adapter *padapter, u8 *pDesc,
-                              u32 BufferLen, u8 IsPsPoll, u8 IsBTQosNull)
-{
-       struct tx_desc *ptxdesc;
-
-       /*  Clear all status */
-       ptxdesc = (struct tx_desc *)pDesc;
-       memset(pDesc, 0, TXDESC_SIZE);
-
-       /* offset 0 */
-       /* own, bFirstSeg, bLastSeg; */
-       ptxdesc->txdw0 |= cpu_to_le32(OWN | FSG | LSG);
-
-       /* 32 bytes for TX Desc */
-       ptxdesc->txdw0 |= cpu_to_le32(((TXDESC_SIZE + OFFSET_SZ) <<
-                                      OFFSET_SHT) & 0x00ff0000);
-
-       /*  Buffer size + command header */
-       ptxdesc->txdw0 |= cpu_to_le32(BufferLen & 0x0000ffff);
-
-       /* offset 4 */
-       /*  Fixed queue of Mgnt queue */
-       ptxdesc->txdw1 |= cpu_to_le32((QSLT_MGNT << QSEL_SHT) & 0x00001f00);
-
-       /* Set NAVUSEHDR to prevent Ps-poll AId filed to be changed
-          to error vlaue by Hw. */
-       if (IsPsPoll) {
-               ptxdesc->txdw1 |= cpu_to_le32(NAVUSEHDR);
-       } else {
-               /*  Hw set sequence number */
-               ptxdesc->txdw4 |= cpu_to_le32(BIT(7));
-               /* set bit3 to 1. Suugested by TimChen. 2009.12.29. */
-               ptxdesc->txdw3 |= cpu_to_le32((8 << 28));
-       }
-
-       if (true == IsBTQosNull)
-               ptxdesc->txdw2 |= cpu_to_le32(BIT(23)); /*  BT NULL */
-
-       /* offset 16 */
-       ptxdesc->txdw4 |= cpu_to_le32(BIT(8));  /* driver uses rate */
-
-       /*  USB interface drop packet if the checksum of descriptor isn't
-           correct. */
-       /*  Using this checksum can let hardware recovery from packet bulk
-           out error (e.g. Cancel URC, Bulk out error.). */
-       rtl8723a_cal_txdesc_chksum(ptxdesc);
-}
-
-void hw_var_set_opmode(struct rtw_adapter *padapter, u8 mode)
-{
-       u8 val8;
-
-       if (mode == MSR_INFRA || mode == MSR_NOLINK) {
-               StopTxBeacon(padapter);
-
-               /*  disable atim wnd */
-               val8 = DIS_TSF_UDT | EN_BCN_FUNCTION | DIS_ATIM;
-               SetBcnCtrlReg23a(padapter, val8, ~val8);
-       } else if (mode == MSR_ADHOC) {
-               ResumeTxBeacon(padapter);
-
-               val8 = DIS_TSF_UDT | EN_BCN_FUNCTION | DIS_BCNQ_SUB;
-               SetBcnCtrlReg23a(padapter, val8, ~val8);
-       } else if (mode == MSR_AP) {
-               /*  add NULL Data and BT NULL Data Packets to FW RSVD Page */
-               rtl8723a_set_BTCoex_AP_mode_FwRsvdPkt_cmd(padapter);
-
-               ResumeTxBeacon(padapter);
-
-               val8 = DIS_TSF_UDT | DIS_BCNQ_SUB;
-               SetBcnCtrlReg23a(padapter, val8, ~val8);
-
-               /*  Set RCR */
-               /* rtl8723au_write32(padapter, REG_RCR, 0x70002a8e);
-                  CBSSID_DATA must set to 0 */
-               /* CBSSID_DATA must set to 0 */
-               rtl8723au_write32(padapter, REG_RCR, 0x7000228e);
-               /*  enable to rx data frame */
-               rtl8723au_write16(padapter, REG_RXFLTMAP2, 0xFFFF);
-               /*  enable to rx ps-poll */
-               rtl8723au_write16(padapter, REG_RXFLTMAP1, 0x0400);
-
-               /*  Beacon Control related register for first time */
-               /*  2ms */
-               rtl8723au_write8(padapter, REG_BCNDMATIM, 0x02);
-               /*  5ms */
-               rtl8723au_write8(padapter, REG_DRVERLYINT, 0x05);
-               /*  10ms for port0 */
-               rtl8723au_write8(padapter, REG_ATIMWND, 0x0a);
-               rtl8723au_write16(padapter, REG_BCNTCFG, 0x00);
-               rtl8723au_write16(padapter, REG_TBTT_PROHIBIT, 0xff04);
-               /*  +32767 (~32ms) */
-               rtl8723au_write16(padapter, REG_TSFTR_SYN_OFFSET, 0x7fff);
-
-               /*  reset TSF */
-               rtl8723au_write8(padapter, REG_DUAL_TSF_RST, BIT(0));
-
-               /*  enable BCN Function */
-               /*  don't enable update TSF (due to TSF update when
-                   beacon/probe rsp are received) */
-               val8 = DIS_TSF_UDT | EN_BCN_FUNCTION |
-                      EN_TXBCN_RPT | DIS_BCNQ_SUB;
-               SetBcnCtrlReg23a(padapter, val8, ~val8);
-       }
-
-       val8 = rtl8723au_read8(padapter, MSR);
-       val8 = (val8 & 0xC) | mode;
-       rtl8723au_write8(padapter, MSR, val8);
-}
-
-void hw_var_set_macaddr(struct rtw_adapter *padapter, u8 *val)
-{
-       u8 idx = 0;
-       u32 reg_macid;
-
-       reg_macid = REG_MACID;
-
-       for (idx = 0; idx < 6; idx++)
-               rtl8723au_write8(padapter, (reg_macid + idx), val[idx]);
-}
-
-void hw_var_set_bssid(struct rtw_adapter *padapter, u8 *val)
-{
-       u8 idx = 0;
-       u32 reg_bssid;
-
-       reg_bssid = REG_BSSID;
-
-       for (idx = 0; idx < 6; idx++)
-               rtl8723au_write8(padapter, (reg_bssid + idx), val[idx]);
-}
-
-void hw_var_set_correct_tsf(struct rtw_adapter *padapter)
-{
-       u64 tsf;
-       u32 reg_tsftr;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-
-       /* tsf = pmlmeext->TSFValue - ((u32)pmlmeext->TSFValue %
-          (pmlmeinfo->bcn_interval*1024)) - 1024; us */
-       tsf = pmlmeext->TSFValue -
-               do_div(pmlmeext->TSFValue,
-                      (pmlmeinfo->bcn_interval * 1024)) - 1024;        /* us */
-
-       if (((pmlmeinfo->state & 0x03) == MSR_ADHOC) ||
-           ((pmlmeinfo->state & 0x03) == MSR_AP)) {
-               /* pHalData->RegTxPause |= STOP_BCNQ;BIT(6) */
-               /* rtl8723au_write8(padapter, REG_TXPAUSE,
-                  (rtl8723au_read8(Adapter, REG_TXPAUSE)|BIT(6))); */
-               StopTxBeacon(padapter);
-       }
-
-       reg_tsftr = REG_TSFTR;
-
-       /*  disable related TSF function */
-       SetBcnCtrlReg23a(padapter, 0, EN_BCN_FUNCTION);
-
-       rtl8723au_write32(padapter, reg_tsftr, tsf);
-       rtl8723au_write32(padapter, reg_tsftr + 4, tsf >> 32);
-
-       /* enable related TSF function */
-       SetBcnCtrlReg23a(padapter, EN_BCN_FUNCTION, 0);
-
-       if (((pmlmeinfo->state & 0x03) == MSR_ADHOC) ||
-           ((pmlmeinfo->state & 0x03) == MSR_AP))
-               ResumeTxBeacon(padapter);
-}
-
-void hw_var_set_mlme_disconnect(struct rtw_adapter *padapter)
-{
-       /*  reject all data frames */
-       rtl8723au_write16(padapter, REG_RXFLTMAP2, 0);
-
-       /*  reset TSF */
-       rtl8723au_write8(padapter, REG_DUAL_TSF_RST, BIT(0));
-
-       /*  disable update TSF */
-       SetBcnCtrlReg23a(padapter, DIS_TSF_UDT, 0);
-}
-
-void hw_var_set_mlme_join(struct rtw_adapter *padapter, u8 type)
-{
-       u8 RetryLimit = 0x30;
-
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-
-       if (type == 0) {        /*  prepare to join */
-               u32 v32;
-
-               /*  enable to rx data frame.Accept all data frame */
-               /* rtl8723au_write32(padapter, REG_RCR,
-                  rtl8723au_read32(padapter, REG_RCR)|RCR_ADF); */
-               rtl8723au_write16(padapter, REG_RXFLTMAP2, 0xFFFF);
-
-               v32 = rtl8723au_read32(padapter, REG_RCR);
-               v32 |= RCR_CBSSID_DATA | RCR_CBSSID_BCN;
-               rtl8723au_write32(padapter, REG_RCR, v32);
-
-               if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) == true)
-                       RetryLimit =
-                           (pHalData->CustomerID == RT_CID_CCX) ? 7 : 48;
-               else            /*  Ad-hoc Mode */
-                       RetryLimit = 0x7;
-       } else if (type == 1) { /*  joinbss_event callback when join res < 0 */
-               /*  config RCR to receive different BSSID & not to
-                   receive data frame during linking */
-               rtl8723au_write16(padapter, REG_RXFLTMAP2, 0);
-       } else if (type == 2) { /*  sta add event callback */
-               /*  enable update TSF */
-               SetBcnCtrlReg23a(padapter, 0, DIS_TSF_UDT);
-
-               if (check_fwstate(pmlmepriv,
-                                 WIFI_ADHOC_STATE | WIFI_ADHOC_MASTER_STATE)) {
-                       /*  fixed beacon issue for 8191su........... */
-                       rtl8723au_write8(padapter, 0x542, 0x02);
-                       RetryLimit = 0x7;
-               }
-       }
-
-       rtl8723au_write16(padapter, REG_RL,
-                         RetryLimit << RETRY_LIMIT_SHORT_SHIFT | RetryLimit <<
-                         RETRY_LIMIT_LONG_SHIFT);
-
-       switch (type) {
-       case 0:
-               /*  prepare to join */
-               rtl8723a_BT_wifiassociate_notify(padapter, true);
-               break;
-       case 1:
-               /*  joinbss_event callback when join res < 0 */
-               rtl8723a_BT_wifiassociate_notify(padapter, false);
-               break;
-       case 2:
-               /*  sta add event callback */
-/*             BT_WifiMediaStatusNotify(padapter, RT_MEDIA_CONNECT); */
-               break;
-       }
-}
diff --git a/drivers/staging/rtl8723au/hal/rtl8723a_phycfg.c b/drivers/staging/rtl8723au/hal/rtl8723a_phycfg.c
deleted file mode 100644 (file)
index 06a6c3e..0000000
+++ /dev/null
@@ -1,961 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#define _RTL8723A_PHYCFG_C_
-
-#include <osdep_service.h>
-#include <drv_types.h>
-
-#include <rtl8723a_hal.h>
-#include <usb_ops_linux.h>
-
-/*---------------------------Define Local Constant---------------------------*/
-/* Channel switch:The size of command tables for switch channel*/
-#define MAX_PRECMD_CNT 16
-#define MAX_RFDEPENDCMD_CNT 16
-#define MAX_POSTCMD_CNT 16
-
-#define MAX_DOZE_WAITING_TIMES_9x 64
-
-/*---------------------------Define Local Constant---------------------------*/
-
-/*------------------------Define global variable-----------------------------*/
-
-/*------------------------Define local variable------------------------------*/
-
-/*--------------------Define export function prototype-----------------------*/
-/*  Please refer to header file */
-/*--------------------Define export function prototype-----------------------*/
-
-/*----------------------------Function Body----------------------------------*/
-/*  */
-/*  1. BB register R/W API */
-/*  */
-
-/**
-* Function:    phy_CalculateBitShift
-*
-* OverView:    Get shifted position of the BitMask
-*
-* Input:
-*                      u32             BitMask,
-*
-* Output:      none
-* Return:              u32             Return the shift bit bit position of the mask
-*/
-static u32 phy_CalculateBitShift(u32 BitMask)
-{
-       u32 i;
-
-       for (i = 0; i <= 31; i++) {
-               if (((BitMask>>i) & 0x1) == 1)
-                       break;
-       }
-
-       return i;
-}
-
-/**
-* Function:    PHY_QueryBBReg
-*
-* OverView:    Read "sepcific bits" from BB register
-*
-* Input:
-*      struct rtw_adapter *    Adapter,
-*      u32                     RegAddr,        Target address to be readback
-*      u32                     BitMask         Target bit position in the
-*                                              target address to be readback
-* Output:
-*      None
-* Return:
-*      u32                     Data            The readback register value
-* Note:
-*      This function is equal to "GetRegSetting" in PHY programming guide
-*/
-u32
-PHY_QueryBBReg(struct rtw_adapter *Adapter, u32 RegAddr, u32 BitMask)
-{
-       u32     ReturnValue = 0, OriginalValue, BitShift;
-
-       OriginalValue = rtl8723au_read32(Adapter, RegAddr);
-       BitShift = phy_CalculateBitShift(BitMask);
-       ReturnValue = (OriginalValue & BitMask) >> BitShift;
-       return ReturnValue;
-}
-
-/**
-* Function:    PHY_SetBBReg
-*
-* OverView:    Write "Specific bits" to BB register (page 8~)
-*
-* Input:
-*      struct rtw_adapter *    Adapter,
-*      u32                     RegAddr,        Target address to be modified
-*      u32                     BitMask         Target bit position in the
-*                                              target address to be modified
-*      u32                     Data            The new register value in the
-*                                              target bit position of the
-*                                               target address
-*
-* Output:
-*      None
-* Return:
-*      None
-* Note:
-*      This function is equal to "PutRegSetting" in PHY programming guide
-*/
-
-void
-PHY_SetBBReg(struct rtw_adapter *Adapter, u32 RegAddr, u32 BitMask, u32        Data)
-{
-       u32 OriginalValue, BitShift;
-
-       if (BitMask != bMaskDWord) {/* if not "double word" write */
-               OriginalValue = rtl8723au_read32(Adapter, RegAddr);
-               BitShift = phy_CalculateBitShift(BitMask);
-               Data = (OriginalValue & (~BitMask)) | (Data << BitShift);
-       }
-
-       rtl8723au_write32(Adapter, RegAddr, Data);
-
-       /* RTPRINT(FPHY, PHY_BBW, ("BBW MASK = 0x%lx Addr[0x%lx]= 0x%lx\n", BitMask, RegAddr, Data)); */
-}
-
-/*  */
-/*  2. RF register R/W API */
-/*  */
-
-/**
-* Function:    phy_RFSerialRead
-*
-* OverView:    Read regster from RF chips
-*
-* Input:
-*              struct rtw_adapter *            Adapter,
-*              enum RF_RADIO_PATH      eRFPath,        Radio path of A/B/C/D
-*              u32 Offset,                     The target address to be read
-*
-* Output:      None
-* Return:      u32                     reback value
-* Note:                Threre are three types of serial operations:
-*              1. Software serial write
-*              2. Hardware LSSI-Low Speed Serial Interface
-*              3. Hardware HSSI-High speed
-*              serial write. Driver need to implement (1) and (2).
-*              This function is equal to the combination of RF_ReadReg() and
-*              RFLSSIRead()
-*/
-static u32
-phy_RFSerialRead(struct rtw_adapter *Adapter, enum RF_RADIO_PATH eRFPath,
-                u32 Offset)
-{
-       u32 retValue = 0;
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(Adapter);
-       struct bb_reg_define *pPhyReg = &pHalData->PHYRegDef[eRFPath];
-       u32 NewOffset;
-       u32 tmplong, tmplong2;
-       u8 RfPiEnable = 0;
-       /*  */
-       /*  Make sure RF register offset is correct */
-       /*  */
-       Offset &= 0x3f;
-
-       /*  */
-       /*  Switch page for 8256 RF IC */
-       /*  */
-       NewOffset = Offset;
-
-       /*  2009/06/17 MH We can not execute IO for power save or
-           other accident mode. */
-       /* if (RT_CANNOT_IO(Adapter)) */
-       /*  */
-       /*      RTPRINT(FPHY, PHY_RFR, ("phy_RFSerialRead return all one\n")); */
-       /*      return  0xFFFFFFFF; */
-       /*  */
-
-       /*  For 92S LSSI Read RFLSSIRead */
-       /*  For RF A/B write 0x824/82c(does not work in the future) */
-       /*  We must use 0x824 for RF A and B to execute read trigger */
-       tmplong = rtl8723au_read32(Adapter, rFPGA0_XA_HSSIParameter2);
-       if (eRFPath == RF_PATH_A)
-               tmplong2 = tmplong;
-       else
-               tmplong2 = rtl8723au_read32(Adapter, pPhyReg->rfHSSIPara2);
-
-       tmplong2 = (tmplong2 & ~bLSSIReadAddress) |
-               (NewOffset << 23) | bLSSIReadEdge;      /* T65 RF */
-
-       rtl8723au_write32(Adapter, rFPGA0_XA_HSSIParameter2,
-                         tmplong & (~bLSSIReadEdge));
-       udelay(10);/*  PlatformStallExecution(10); */
-
-       rtl8723au_write32(Adapter, pPhyReg->rfHSSIPara2, tmplong2);
-       udelay(100);/* PlatformStallExecution(100); */
-
-       rtl8723au_write32(Adapter, rFPGA0_XA_HSSIParameter2,
-                         tmplong | bLSSIReadEdge);
-       udelay(10);/* PlatformStallExecution(10); */
-
-       if (eRFPath == RF_PATH_A)
-               RfPiEnable = (u8)PHY_QueryBBReg(Adapter,
-                                               rFPGA0_XA_HSSIParameter1,
-                                               BIT(8));
-       else if (eRFPath == RF_PATH_B)
-               RfPiEnable = (u8)PHY_QueryBBReg(Adapter,
-                                               rFPGA0_XB_HSSIParameter1,
-                                               BIT(8));
-
-       if (RfPiEnable) {
-               /* Read from BBreg8b8, 12 bits for 8190, 20bits for T65 RF */
-               retValue = PHY_QueryBBReg(Adapter, pPhyReg->rfLSSIReadBackPi,
-                                         bLSSIReadBackData);
-               /* DBG_8723A("Readback from RF-PI : 0x%x\n", retValue); */
-       } else {
-               /* Read from BBreg8a0, 12 bits for 8190, 20 bits for T65 RF */
-               retValue = PHY_QueryBBReg(Adapter, pPhyReg->rfLSSIReadBack,
-                                         bLSSIReadBackData);
-               /* DBG_8723A("Readback from RF-SI : 0x%x\n", retValue); */
-       }
-       /* DBG_8723A("RFR-%d Addr[0x%x]= 0x%x\n", eRFPath, pPhyReg->rfLSSIReadBack, retValue); */
-
-       return retValue;
-}
-
-/**
-* Function:    phy_RFSerialWrite
-*
-* OverView:    Write data to RF register (page 8~)
-*
-* Input:
-*      struct rtw_adapter *            Adapter,
-*      enum RF_RADIO_PATH      eRFPath,        Radio path of A/B/C/D
-*      u32 Offset,                     The target address to be read
-*      u32 Data                        The new register Data in the target
-*                                      bit position of the target to be read
-*
-* Output:
-*      None
-* Return:
-*      None
-* Note:
-*      Threre are three types of serial operations:
-*              1. Software serial write
-*              2. Hardware LSSI-Low Speed Serial Interface
-*              3. Hardware HSSI-High speed
-*              serial write. Driver need to implement (1) and (2).
-*              This function is equal to the combination of RF_ReadReg() and
-*              RFLSSIRead()
-*
-* Note:          For RF8256 only
-* The total count of RTL8256(Zebra4) register is around 36 bit it only employs
-* 4-bit RF address. RTL8256 uses "register mode control bit"
-* (Reg00[12], Reg00[10]) to access register address bigger than 0xf.
-* See "Appendix-4 in PHY Configuration programming guide" for more details.
-* Thus, we define a sub-finction for RTL8526 register address conversion
-* ===========================================================
-* Register Mode:       RegCTL[1]       RegCTL[0]       Note
-*                      (Reg00[12])     (Reg00[10])
-* ===========================================================
-* Reg_Mode0            0               x               Reg 0 ~15(0x0 ~ 0xf)
-* ------------------------------------------------------------------
-* Reg_Mode1            1               0               Reg 16 ~30(0x1 ~ 0xf)
-* ------------------------------------------------------------------
-* Reg_Mode2            1               1               Reg 31 ~ 45(0x1 ~ 0xf)
-* ------------------------------------------------------------------
-*
-*      2008/09/02      MH      Add 92S RF definition
-*/
-static void
-phy_RFSerialWrite(struct rtw_adapter *Adapter, enum RF_RADIO_PATH eRFPath,
-                 u32 Offset, u32 Data)
-{
-       u32 DataAndAddr = 0;
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(Adapter);
-       struct bb_reg_define *pPhyReg = &pHalData->PHYRegDef[eRFPath];
-       u32 NewOffset;
-
-       /*  2009/06/17 MH We can not execute IO for power save or
-           other accident mode. */
-       /* if (RT_CANNOT_IO(Adapter)) */
-       /*  */
-       /*      RTPRINT(FPHY, PHY_RFW, ("phy_RFSerialWrite stop\n")); */
-       /*      return; */
-       /*  */
-
-       Offset &= 0x3f;
-
-       /*  */
-       /*  Shadow Update */
-       /*  */
-       /* PHY_RFShadowWrite(Adapter, eRFPath, Offset, Data); */
-
-       /*  */
-       /*  Switch page for 8256 RF IC */
-       /*  */
-       NewOffset = Offset;
-
-       /*  */
-       /*  Put write addr in [5:0]  and write data in [31:16] */
-       /*  */
-       /* DataAndAddr = (Data<<16) | (NewOffset&0x3f); */
-       /*  T65 RF */
-       DataAndAddr = ((NewOffset<<20) | (Data&0x000fffff)) & 0x0fffffff;
-
-       /*  */
-       /*  Write Operation */
-       /*  */
-       rtl8723au_write32(Adapter, pPhyReg->rf3wireOffset, DataAndAddr);
-}
-
-/**
-* Function:    PHY_QueryRFReg
-*
-* OverView:    Query "Specific bits" to RF register (page 8~)
-*
-* Input:
-*      struct rtw_adapter *            Adapter,
-*      enum RF_RADIO_PATH      eRFPath,        Radio path of A/B/C/D
-*      u32 RegAddr,                    The target address to be read
-*      u32BitMask                      The target bit position in the target
-*                                      address to be read
-*
-* Output:
-*      None
-* Return:
-*      u32                             Readback value
-* Note:
-*      This function is equal to "GetRFRegSetting" in PHY programming guide
-*/
-u32
-PHY_QueryRFReg(struct rtw_adapter *Adapter, enum RF_RADIO_PATH eRFPath,
-              u32 RegAddr, u32 BitMask)
-{
-       u32 Original_Value, Readback_Value, BitShift;
-       /* struct hal_data_8723a        *pHalData = GET_HAL_DATA(Adapter); */
-       /* u8   RFWaitCounter = 0; */
-       /* _irqL        irqL; */
-
-       Original_Value = phy_RFSerialRead(Adapter, eRFPath, RegAddr);
-
-       BitShift =  phy_CalculateBitShift(BitMask);
-       Readback_Value = (Original_Value & BitMask) >> BitShift;
-
-       return Readback_Value;
-}
-
-/**
-* Function:    PHY_SetRFReg
-*
-* OverView:    Write "Specific bits" to RF register (page 8~)
-*
-* Input:
-*      struct rtw_adapter *            Adapter,
-*      enum RF_RADIO_PATH      eRFPath,        Radio path of A/B/C/D
-*      u32 RegAddr,                    The target address to be modified
-*      u32 BitMask                     The target bit position in the target
-*                                      address to be modified
-*      u32 Data                        The new register Data in the target
-*                                      bit position of the target address
-*
-* Output:
-*      None
-* Return:
-*      None
-* Note:        This function is equal to "PutRFRegSetting" in PHY programming guide
-*/
-void
-PHY_SetRFReg(struct rtw_adapter *Adapter, enum RF_RADIO_PATH eRFPath,
-            u32 RegAddr, u32 BitMask, u32 Data)
-{
-       /* struct hal_data_8723a *pHalData = GET_HAL_DATA(Adapter); */
-       /* u8 RFWaitCounter     = 0; */
-       u32 Original_Value, BitShift;
-
-       /*  RF data is 12 bits only */
-       if (BitMask != bRFRegOffsetMask) {
-               Original_Value = phy_RFSerialRead(Adapter, eRFPath, RegAddr);
-               BitShift =  phy_CalculateBitShift(BitMask);
-               Data = (Original_Value & (~BitMask)) | (Data << BitShift);
-       }
-
-       phy_RFSerialWrite(Adapter, eRFPath, RegAddr, Data);
-}
-
-/*  3. Initial MAC/BB/RF config by reading MAC/BB/RF txt. */
-
-/*-----------------------------------------------------------------------------
- * Function:    PHY_MACConfig8723A
- *
- * Overview:   Condig MAC by header file or parameter file.
- *
- * Input:       NONE
- *
- * Output:      NONE
- *
- * Return:      NONE
- *
- * Revised History:
- *  When               Who             Remark
- *  08/12/2008 MHC             Create Version 0.
- *
- *---------------------------------------------------------------------------*/
-int PHY_MACConfig8723A(struct rtw_adapter *Adapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(Adapter);
-
-       /*  */
-       /*  Config MAC */
-       /*  */
-       ODM_ReadAndConfig_MAC_REG_8723A(&pHalData->odmpriv);
-
-       /*  2010.07.13 AMPDU aggregation number 9 */
-       rtl8723au_write8(Adapter, REG_MAX_AGGR_NUM, 0x0A);
-       if (pHalData->rf_type == RF_2T2R &&
-           BOARD_USB_DONGLE == pHalData->BoardType)
-               rtl8723au_write8(Adapter, 0x40, 0x04);
-
-       return _SUCCESS;
-}
-
-/**
-* Function:    phy_InitBBRFRegisterDefinition
-*
-* OverView:    Initialize Register definition offset for Radio Path A/B/C/D
-*
-* Input:
-*                      struct rtw_adapter *            Adapter,
-*
-* Output:      None
-* Return:              None
-* Note:
-*      The initialization value is constant and it should never be changes
-*/
-static void
-phy_InitBBRFRegisterDefinition(struct rtw_adapter *Adapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(Adapter);
-
-       /*  RF Interface Sowrtware Control */
-        /*  16 LSBs if read 32-bit from 0x870 */
-       pHalData->PHYRegDef[RF_PATH_A].rfintfs = rFPGA0_XAB_RFInterfaceSW;
-        /*  16 MSBs if read 32-bit from 0x870 (16-bit for 0x872) */
-       pHalData->PHYRegDef[RF_PATH_B].rfintfs = rFPGA0_XAB_RFInterfaceSW;
-
-       /*  RF Interface Readback Value */
-       /*  16 LSBs if read 32-bit from 0x8E0 */
-       pHalData->PHYRegDef[RF_PATH_A].rfintfi = rFPGA0_XAB_RFInterfaceRB;
-       /*  16 MSBs if read 32-bit from 0x8E0 (16-bit for 0x8E2) */
-       pHalData->PHYRegDef[RF_PATH_B].rfintfi = rFPGA0_XAB_RFInterfaceRB;
-
-       /*  RF Interface Output (and Enable) */
-       /*  16 LSBs if read 32-bit from 0x860 */
-       pHalData->PHYRegDef[RF_PATH_A].rfintfo = rFPGA0_XA_RFInterfaceOE;
-        /*  16 LSBs if read 32-bit from 0x864 */
-       pHalData->PHYRegDef[RF_PATH_B].rfintfo = rFPGA0_XB_RFInterfaceOE;
-
-       /*  RF Interface (Output and)  Enable */
-        /*  16 MSBs if read 32-bit from 0x860 (16-bit for 0x862) */
-       pHalData->PHYRegDef[RF_PATH_A].rfintfe = rFPGA0_XA_RFInterfaceOE;
-       /*  16 MSBs if read 32-bit from 0x864 (16-bit for 0x866) */
-       pHalData->PHYRegDef[RF_PATH_B].rfintfe = rFPGA0_XB_RFInterfaceOE;
-
-       /* Addr of LSSI. Wirte RF register by driver */
-       pHalData->PHYRegDef[RF_PATH_A].rf3wireOffset = rFPGA0_XA_LSSIParameter;
-       pHalData->PHYRegDef[RF_PATH_B].rf3wireOffset = rFPGA0_XB_LSSIParameter;
-
-       /*  RF parameter */
-       /* BB Band Select */
-       pHalData->PHYRegDef[RF_PATH_A].rfLSSI_Select = rFPGA0_XAB_RFParameter;
-       pHalData->PHYRegDef[RF_PATH_B].rfLSSI_Select = rFPGA0_XAB_RFParameter;
-
-       /*  Tx AGC Gain Stage (same for all path. Should we remove this?) */
-       pHalData->PHYRegDef[RF_PATH_A].rfTxGainStage = rFPGA0_TxGainStage;
-       pHalData->PHYRegDef[RF_PATH_B].rfTxGainStage = rFPGA0_TxGainStage;
-
-       /*  Tranceiver A~D HSSI Parameter-1 */
-       /* wire control parameter1 */
-       pHalData->PHYRegDef[RF_PATH_A].rfHSSIPara1 = rFPGA0_XA_HSSIParameter1;
-       /* wire control parameter1 */
-       pHalData->PHYRegDef[RF_PATH_B].rfHSSIPara1 = rFPGA0_XB_HSSIParameter1;
-
-       /*  Tranceiver A~D HSSI Parameter-2 */
-       /* wire control parameter2 */
-       pHalData->PHYRegDef[RF_PATH_A].rfHSSIPara2 = rFPGA0_XA_HSSIParameter2;
-       /* wire control parameter2 */
-       pHalData->PHYRegDef[RF_PATH_B].rfHSSIPara2 = rFPGA0_XB_HSSIParameter2;
-
-       /*  RF switch Control */
-       pHalData->PHYRegDef[RF_PATH_A].rfSwitchControl =
-               rFPGA0_XAB_SwitchControl; /* TR/Ant switch control */
-       pHalData->PHYRegDef[RF_PATH_B].rfSwitchControl =
-               rFPGA0_XAB_SwitchControl;
-
-       /*  AGC control 1 */
-       pHalData->PHYRegDef[RF_PATH_A].rfAGCControl1 = rOFDM0_XAAGCCore1;
-       pHalData->PHYRegDef[RF_PATH_B].rfAGCControl1 = rOFDM0_XBAGCCore1;
-
-       /*  AGC control 2 */
-       pHalData->PHYRegDef[RF_PATH_A].rfAGCControl2 = rOFDM0_XAAGCCore2;
-       pHalData->PHYRegDef[RF_PATH_B].rfAGCControl2 = rOFDM0_XBAGCCore2;
-
-       /*  RX AFE control 1 */
-       pHalData->PHYRegDef[RF_PATH_A].rfRxIQImbalance = rOFDM0_XARxIQImbalance;
-       pHalData->PHYRegDef[RF_PATH_B].rfRxIQImbalance = rOFDM0_XBRxIQImbalance;
-
-       /*  RX AFE control 1 */
-       pHalData->PHYRegDef[RF_PATH_A].rfRxAFE = rOFDM0_XARxAFE;
-       pHalData->PHYRegDef[RF_PATH_B].rfRxAFE = rOFDM0_XBRxAFE;
-
-       /*  Tx AFE control 1 */
-       pHalData->PHYRegDef[RF_PATH_A].rfTxIQImbalance = rOFDM0_XATxIQImbalance;
-       pHalData->PHYRegDef[RF_PATH_B].rfTxIQImbalance = rOFDM0_XBTxIQImbalance;
-
-       /*  Tx AFE control 2 */
-       pHalData->PHYRegDef[RF_PATH_A].rfTxAFE = rOFDM0_XATxAFE;
-       pHalData->PHYRegDef[RF_PATH_B].rfTxAFE = rOFDM0_XBTxAFE;
-
-       /*  Tranceiver LSSI Readback SI mode */
-       pHalData->PHYRegDef[RF_PATH_A].rfLSSIReadBack = rFPGA0_XA_LSSIReadBack;
-       pHalData->PHYRegDef[RF_PATH_B].rfLSSIReadBack = rFPGA0_XB_LSSIReadBack;
-
-       /*  Tranceiver LSSI Readback PI mode */
-       pHalData->PHYRegDef[RF_PATH_A].rfLSSIReadBackPi =
-               TransceiverA_HSPI_Readback;
-       pHalData->PHYRegDef[RF_PATH_B].rfLSSIReadBackPi =
-               TransceiverB_HSPI_Readback;
-}
-
-/*  The following is for High Power PA */
-static void
-storePwrIndexDiffRateOffset(struct rtw_adapter *Adapter, u32 RegAddr,
-                           u32 BitMask, u32 Data)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(Adapter);
-
-       if (RegAddr == rTxAGC_A_Rate18_06) {
-               pHalData->MCSTxPowerLevelOriginalOffset[pHalData->pwrGroupCnt][0] = Data;
-       }
-       if (RegAddr == rTxAGC_A_Rate54_24) {
-               pHalData->MCSTxPowerLevelOriginalOffset[pHalData->pwrGroupCnt][1] = Data;
-       }
-       if (RegAddr == rTxAGC_A_CCK1_Mcs32) {
-               pHalData->MCSTxPowerLevelOriginalOffset[pHalData->pwrGroupCnt][6] = Data;
-       }
-       if (RegAddr == rTxAGC_B_CCK11_A_CCK2_11 && BitMask == 0xffffff00) {
-               pHalData->MCSTxPowerLevelOriginalOffset[pHalData->pwrGroupCnt][7] = Data;
-       }
-       if (RegAddr == rTxAGC_A_Mcs03_Mcs00) {
-               pHalData->MCSTxPowerLevelOriginalOffset[pHalData->pwrGroupCnt][2] = Data;
-       }
-       if (RegAddr == rTxAGC_A_Mcs07_Mcs04) {
-               pHalData->MCSTxPowerLevelOriginalOffset[pHalData->pwrGroupCnt][3] = Data;
-       }
-       if (RegAddr == rTxAGC_A_Mcs11_Mcs08) {
-               pHalData->MCSTxPowerLevelOriginalOffset[pHalData->pwrGroupCnt][4] = Data;
-       }
-       if (RegAddr == rTxAGC_A_Mcs15_Mcs12) {
-               pHalData->MCSTxPowerLevelOriginalOffset[pHalData->pwrGroupCnt][5] = Data;
-       }
-       if (RegAddr == rTxAGC_B_Rate18_06) {
-               pHalData->MCSTxPowerLevelOriginalOffset[pHalData->pwrGroupCnt][8] = Data;
-       }
-       if (RegAddr == rTxAGC_B_Rate54_24) {
-               pHalData->MCSTxPowerLevelOriginalOffset[pHalData->pwrGroupCnt][9] = Data;
-       }
-       if (RegAddr == rTxAGC_B_CCK1_55_Mcs32) {
-               pHalData->MCSTxPowerLevelOriginalOffset[pHalData->pwrGroupCnt][14] = Data;
-       }
-       if (RegAddr == rTxAGC_B_CCK11_A_CCK2_11 && BitMask == 0x000000ff) {
-               pHalData->MCSTxPowerLevelOriginalOffset[pHalData->pwrGroupCnt][15] = Data;
-       }
-       if (RegAddr == rTxAGC_B_Mcs03_Mcs00) {
-               pHalData->MCSTxPowerLevelOriginalOffset[pHalData->pwrGroupCnt][10] = Data;
-       }
-       if (RegAddr == rTxAGC_B_Mcs07_Mcs04) {
-               pHalData->MCSTxPowerLevelOriginalOffset[pHalData->pwrGroupCnt][11] = Data;
-       }
-       if (RegAddr == rTxAGC_B_Mcs11_Mcs08) {
-               pHalData->MCSTxPowerLevelOriginalOffset[pHalData->pwrGroupCnt][12] = Data;
-       }
-       if (RegAddr == rTxAGC_B_Mcs15_Mcs12) {
-               pHalData->MCSTxPowerLevelOriginalOffset[pHalData->pwrGroupCnt][13] = Data;
-               pHalData->pwrGroupCnt++;
-       }
-}
-
-/*-----------------------------------------------------------------------------
- * Function:   phy_ConfigBBWithPgHeaderFile
- *
- * Overview:   Config PHY_REG_PG array
- *
- * Input:       NONE
- *
- * Output:      NONE
- *
- * Return:      NONE
- *
- * Revised History:
- * When                Who     Remark
- * 11/06/2008  MHC     Add later!!!!!!.. Please modify for new files!!!!
- * 11/10/2008  tynli   Modify to mew files.
- *---------------------------------------------------------------------------*/
-static int
-phy_ConfigBBWithPgHeaderFile(struct rtw_adapter *Adapter)
-{
-       int i;
-       u32 *Rtl819XPHY_REGArray_Table_PG;
-       u16 PHY_REGArrayPGLen;
-
-       PHY_REGArrayPGLen = Rtl8723_PHY_REG_Array_PGLength;
-       Rtl819XPHY_REGArray_Table_PG = (u32 *)Rtl8723_PHY_REG_Array_PG;
-
-       for (i = 0; i < PHY_REGArrayPGLen; i = i + 3) {
-               storePwrIndexDiffRateOffset(Adapter,
-                                           Rtl819XPHY_REGArray_Table_PG[i],
-                                           Rtl819XPHY_REGArray_Table_PG[i+1],
-                                           Rtl819XPHY_REGArray_Table_PG[i+2]);
-       }
-
-       return _SUCCESS;
-}
-
-static void
-phy_BB8192C_Config_1T(struct rtw_adapter *Adapter)
-{
-       /* for path - B */
-       PHY_SetBBReg(Adapter, rFPGA0_TxInfo, 0x3, 0x2);
-       PHY_SetBBReg(Adapter, rFPGA1_TxInfo, 0x300033, 0x200022);
-
-       /*  20100519 Joseph: Add for 1T2R config. Suggested by Kevin,
-           Jenyu and Yunan. */
-       PHY_SetBBReg(Adapter, rCCK0_AFESetting, bMaskByte3, 0x45);
-       PHY_SetBBReg(Adapter, rOFDM0_TRxPathEnable, bMaskByte0, 0x23);
-       /*  B path first AGC */
-       PHY_SetBBReg(Adapter, rOFDM0_AGCParameter1, 0x30, 0x1);
-
-       PHY_SetBBReg(Adapter, 0xe74, 0x0c000000, 0x2);
-       PHY_SetBBReg(Adapter, 0xe78, 0x0c000000, 0x2);
-       PHY_SetBBReg(Adapter, 0xe7c, 0x0c000000, 0x2);
-       PHY_SetBBReg(Adapter, 0xe80, 0x0c000000, 0x2);
-       PHY_SetBBReg(Adapter, 0xe88, 0x0c000000, 0x2);
-}
-
-static int
-phy_BB8723a_Config_ParaFile(struct rtw_adapter *Adapter)
-{
-       struct eeprom_priv *pEEPROM = GET_EEPROM_EFUSE_PRIV(Adapter);
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(Adapter);
-       int rtStatus = _SUCCESS;
-
-       /*  */
-       /*  1. Read PHY_REG.TXT BB INIT!! */
-       /*  We will separate as 88C / 92C according to chip version */
-       /*  */
-       ODM_ReadAndConfig_PHY_REG_1T_8723A(&pHalData->odmpriv);
-
-       /*  */
-       /*  20100318 Joseph: Config 2T2R to 1T2R if necessary. */
-       /*  */
-       if (pHalData->rf_type == RF_1T2R) {
-               phy_BB8192C_Config_1T(Adapter);
-               DBG_8723A("phy_BB8723a_Config_ParaFile():Config to 1T!!\n");
-       }
-
-       /*  */
-       /*  2. If EEPROM or EFUSE autoload OK, We must config by
-           PHY_REG_PG.txt */
-       /*  */
-       if (pEEPROM->bautoload_fail_flag == false) {
-               pHalData->pwrGroupCnt = 0;
-
-               rtStatus = phy_ConfigBBWithPgHeaderFile(Adapter);
-       }
-
-       if (rtStatus != _SUCCESS)
-               goto phy_BB8190_Config_ParaFile_Fail;
-
-       /*  */
-       /*  3. BB AGC table Initialization */
-       /*  */
-       ODM_ReadAndConfig_AGC_TAB_1T_8723A(&pHalData->odmpriv);
-
-phy_BB8190_Config_ParaFile_Fail:
-
-       return rtStatus;
-}
-
-int
-PHY_BBConfig8723A(struct rtw_adapter *Adapter)
-{
-       int rtStatus = _SUCCESS;
-       struct hal_data_8723a   *pHalData = GET_HAL_DATA(Adapter);
-       u8 TmpU1B = 0;
-       u8 CrystalCap;
-
-       phy_InitBBRFRegisterDefinition(Adapter);
-
-       /*  Suggested by Scott. tynli_test. 2010.12.30. */
-       /* 1. 0x28[1] = 1 */
-       TmpU1B = rtl8723au_read8(Adapter, REG_AFE_PLL_CTRL);
-       udelay(2);
-       rtl8723au_write8(Adapter, REG_AFE_PLL_CTRL, TmpU1B | BIT(1));
-       udelay(2);
-
-       /* 2. 0x29[7:0] = 0xFF */
-       rtl8723au_write8(Adapter, REG_AFE_PLL_CTRL+1, 0xff);
-       udelay(2);
-
-       /* 3. 0x02[1:0] = 2b'11 */
-       TmpU1B = rtl8723au_read8(Adapter, REG_SYS_FUNC_EN);
-       rtl8723au_write8(Adapter, REG_SYS_FUNC_EN,
-                        (TmpU1B | FEN_BB_GLB_RSTn | FEN_BBRSTB));
-
-       /* 4. 0x25[6] = 0 */
-       TmpU1B = rtl8723au_read8(Adapter, REG_AFE_XTAL_CTRL + 1);
-       rtl8723au_write8(Adapter, REG_AFE_XTAL_CTRL+1, TmpU1B & ~BIT(6));
-
-       /* 5. 0x24[20] = 0      Advised by SD3 Alex Wang. 2011.02.09. */
-       TmpU1B = rtl8723au_read8(Adapter, REG_AFE_XTAL_CTRL+2);
-       rtl8723au_write8(Adapter, REG_AFE_XTAL_CTRL+2, TmpU1B & ~BIT(4));
-
-       /* 6. 0x1f[7:0] = 0x07 */
-       rtl8723au_write8(Adapter, REG_RF_CTRL, 0x07);
-
-       /*  */
-       /*  Config BB and AGC */
-       /*  */
-       rtStatus = phy_BB8723a_Config_ParaFile(Adapter);
-
-/* only for B-cut */
-       if (pHalData->EEPROMVersion >= 0x01) {
-               CrystalCap = pHalData->CrystalCap & 0x3F;
-               PHY_SetBBReg(Adapter, REG_MAC_PHY_CTRL, 0xFFF000,
-                            (CrystalCap | (CrystalCap << 6)));
-       }
-
-       rtl8723au_write32(Adapter, REG_LDOA15_CTRL, 0x01572505);
-       return rtStatus;
-}
-
-/*-----------------------------------------------------------------------------
- * Function:    SetTxPowerLevel8723A()
- *
- * Overview:    This function is export to "HalCommon" moudule
- *                     We must consider RF path later!!!!!!!
- *
- * Input:       struct rtw_adapter *           Adapter
- *                     u8              channel
- *
- * Output:      NONE
- *
- * Return:      NONE
- *
- *---------------------------------------------------------------------------*/
-void PHY_SetTxPowerLevel8723A(struct rtw_adapter *Adapter, u8 channel)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(Adapter);
-       u8 cckpwr[2], ofdmpwr[2];       /*  [0]:RF-A, [1]:RF-B */
-       int i = channel - 1;
-
-       if (pHalData->bTXPowerDataReadFromEEPORM == false)
-               return;
-
-       /*  1. CCK */
-       cckpwr[RF_PATH_A] = pHalData->TxPwrLevelCck[RF_PATH_A][i];
-       cckpwr[RF_PATH_B] = pHalData->TxPwrLevelCck[RF_PATH_B][i];
-
-       /*  2. OFDM for 1S or 2S */
-       if (GET_RF_TYPE(Adapter) == RF_1T2R ||
-           GET_RF_TYPE(Adapter) == RF_1T1R) {
-               /*  Read HT 40 OFDM TX power */
-               ofdmpwr[RF_PATH_A] = pHalData->TxPwrLevelHT40_1S[RF_PATH_A][i];
-               ofdmpwr[RF_PATH_B] = pHalData->TxPwrLevelHT40_1S[RF_PATH_B][i];
-       } else if (GET_RF_TYPE(Adapter) == RF_2T2R) {
-               /*  Read HT 40 OFDM TX power */
-               ofdmpwr[RF_PATH_A] = pHalData->TxPwrLevelHT40_2S[RF_PATH_A][i];
-               ofdmpwr[RF_PATH_B] = pHalData->TxPwrLevelHT40_2S[RF_PATH_B][i];
-       }
-
-       rtl823a_phy_rf6052setccktxpower(Adapter, &cckpwr[0]);
-       rtl8723a_PHY_RF6052SetOFDMTxPower(Adapter, &ofdmpwr[0], channel);
-}
-
-/*-----------------------------------------------------------------------------
- * Function:    PHY_SetBWMode23aCallback8192C()
- *
- * Overview:    Timer callback function for SetSetBWMode23a
- *
- * Input:              PRT_TIMER               pTimer
- *
- * Output:      NONE
- *
- * Return:      NONE
- *
- * Note:
- *     (1) We do not take j mode into consideration now
- *     (2) Will two workitem of "switch channel" and
- *         "switch channel bandwidth" run concurrently?
- *---------------------------------------------------------------------------*/
-static void
-_PHY_SetBWMode23a92C(struct rtw_adapter *Adapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(Adapter);
-       u8 regBwOpMode;
-       u8 regRRSR_RSC;
-
-       if (Adapter->bDriverStopped)
-               return;
-
-       /* 3 */
-       /* 3<1>Set MAC register */
-       /* 3 */
-
-       regBwOpMode = rtl8723au_read8(Adapter, REG_BWOPMODE);
-       regRRSR_RSC = rtl8723au_read8(Adapter, REG_RRSR+2);
-
-       switch (pHalData->CurrentChannelBW) {
-       case HT_CHANNEL_WIDTH_20:
-               regBwOpMode |= BW_OPMODE_20MHZ;
-               rtl8723au_write8(Adapter, REG_BWOPMODE, regBwOpMode);
-               break;
-       case HT_CHANNEL_WIDTH_40:
-               regBwOpMode &= ~BW_OPMODE_20MHZ;
-               rtl8723au_write8(Adapter, REG_BWOPMODE, regBwOpMode);
-               regRRSR_RSC = (regRRSR_RSC & 0x90) |
-                       (pHalData->nCur40MhzPrimeSC << 5);
-               rtl8723au_write8(Adapter, REG_RRSR+2, regRRSR_RSC);
-               break;
-
-       default:
-               break;
-       }
-
-       /* 3 */
-       /* 3<2>Set PHY related register */
-       /* 3 */
-       switch (pHalData->CurrentChannelBW) {
-               /* 20 MHz channel*/
-       case HT_CHANNEL_WIDTH_20:
-               PHY_SetBBReg(Adapter, rFPGA0_RFMOD, bRFMOD, 0x0);
-               PHY_SetBBReg(Adapter, rFPGA1_RFMOD, bRFMOD, 0x0);
-               PHY_SetBBReg(Adapter, rFPGA0_AnalogParameter2, BIT(10), 1);
-
-               break;
-
-               /* 40 MHz channel*/
-       case HT_CHANNEL_WIDTH_40:
-               PHY_SetBBReg(Adapter, rFPGA0_RFMOD, bRFMOD, 0x1);
-               PHY_SetBBReg(Adapter, rFPGA1_RFMOD, bRFMOD, 0x1);
-
-               /*  Set Control channel to upper or lower. These settings
-                   are required only for 40MHz */
-               PHY_SetBBReg(Adapter, rCCK0_System, bCCKSideBand,
-                            (pHalData->nCur40MhzPrimeSC >> 1));
-               PHY_SetBBReg(Adapter, rOFDM1_LSTF, 0xC00,
-                            pHalData->nCur40MhzPrimeSC);
-               PHY_SetBBReg(Adapter, rFPGA0_AnalogParameter2, BIT(10), 0);
-
-               PHY_SetBBReg(Adapter, 0x818, BIT(26) | BIT(27),
-                            (pHalData->nCur40MhzPrimeSC ==
-                             HAL_PRIME_CHNL_OFFSET_LOWER) ? 2:1);
-               break;
-
-       default:
-               break;
-       }
-       /* Skip over setting of J-mode in BB register here. Default value
-          is "None J mode". Emily 20070315 */
-
-       /*  Added it for 20/40 mhz switch time evaluation by guangan 070531 */
-       /* NowL = PlatformEFIORead4Byte(Adapter, TSFR); */
-       /* NowH = PlatformEFIORead4Byte(Adapter, TSFR+4); */
-       /* EndTime = ((u64)NowH << 32) + NowL; */
-
-       rtl8723a_phy_rf6052set_bw(Adapter, pHalData->CurrentChannelBW);
-}
-
- /*-----------------------------------------------------------------------------
- * Function:   SetBWMode23a8190Pci()
- *
- * Overview:  This function is export to "HalCommon" moudule
- *
- * Input:              struct rtw_adapter *                    Adapter
- *                     enum ht_channel_width   Bandwidth       20M or 40M
- *
- * Output:      NONE
- *
- * Return:      NONE
- *
- * Note:               We do not take j mode into consideration now
- *---------------------------------------------------------------------------*/
-void
-PHY_SetBWMode23a8723A(struct rtw_adapter *Adapter,
-                  enum ht_channel_width Bandwidth, unsigned char Offset)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(Adapter);
-       enum ht_channel_width tmpBW = pHalData->CurrentChannelBW;
-
-       pHalData->CurrentChannelBW = Bandwidth;
-
-       pHalData->nCur40MhzPrimeSC = Offset;
-
-       if ((!Adapter->bDriverStopped) && (!Adapter->bSurpriseRemoved))
-               _PHY_SetBWMode23a92C(Adapter);
-       else
-               pHalData->CurrentChannelBW = tmpBW;
-}
-
-static void _PHY_SwChnl8723A(struct rtw_adapter *Adapter, u8 channel)
-{
-       enum RF_RADIO_PATH eRFPath;
-       u32 param1, param2;
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(Adapter);
-
-       /* s1. pre common command - CmdID_SetTxPowerLevel */
-       PHY_SetTxPowerLevel8723A(Adapter, channel);
-
-       /* s2. RF dependent command - CmdID_RF_WriteReg,
-          param1 = RF_CHNLBW, param2 = channel */
-       param1 = RF_CHNLBW;
-       param2 = channel;
-       for (eRFPath = 0; eRFPath < pHalData->NumTotalRFPath; eRFPath++) {
-               pHalData->RfRegChnlVal[eRFPath] =
-                       (pHalData->RfRegChnlVal[eRFPath] & 0xfffffc00) | param2;
-               PHY_SetRFReg(Adapter, eRFPath, param1,
-                            bRFRegOffsetMask, pHalData->RfRegChnlVal[eRFPath]);
-       }
-
-       /* s3. post common command - CmdID_End, None */
-}
-
-void PHY_SwChnl8723A(struct rtw_adapter *Adapter, u8 channel)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(Adapter);
-       u8 tmpchannel = pHalData->CurrentChannel;
-       bool  result = true;
-
-       if (channel == 0)
-               channel = 1;
-
-       pHalData->CurrentChannel = channel;
-
-       if ((!Adapter->bDriverStopped) && (!Adapter->bSurpriseRemoved)) {
-               _PHY_SwChnl8723A(Adapter, channel);
-
-               if (!result)
-                       pHalData->CurrentChannel = tmpchannel;
-       } else {
-               pHalData->CurrentChannel = tmpchannel;
-       }
-}
diff --git a/drivers/staging/rtl8723au/hal/rtl8723a_rf6052.c b/drivers/staging/rtl8723au/hal/rtl8723a_rf6052.c
deleted file mode 100644 (file)
index 24c0ff3..0000000
+++ /dev/null
@@ -1,503 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-/******************************************************************************
- *
- *
- * Module:     rtl8192c_rf6052.c       (Source C File)
- *
- * Note:       Provide RF 6052 series relative API.
- *
- * Function:
- *
- * Export:
- *
- * Abbrev:
- *
- * History:
- * Data                        Who             Remark
- *
- * 09/25/2008  MHC             Create initial version.
- * 11/05/2008  MHC             Add API for tw power setting.
- *
- *
-******************************************************************************/
-
-#define _RTL8723A_RF6052_C_
-
-#include <osdep_service.h>
-#include <drv_types.h>
-
-#include <rtl8723a_hal.h>
-#include <usb_ops_linux.h>
-
-/*-----------------------------------------------------------------------------
- * Function:    PHY_RF6052SetBandwidth()
- *
- * Overview:    This function is called by SetBWMode23aCallback8190Pci() only
- *
- * Input:       struct rtw_adapter *                           Adapter
- *                     WIRELESS_BANDWIDTH_E    Bandwidth       20M or 40M
- *
- * Output:      NONE
- *
- * Return:      NONE
- *
- * Note:               For RF type 0222D
- *---------------------------------------------------------------------------*/
-void rtl8723a_phy_rf6052set_bw(struct rtw_adapter *Adapter,
-                              enum ht_channel_width Bandwidth) /* 20M or 40M */
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(Adapter);
-
-       switch (Bandwidth) {
-       case HT_CHANNEL_WIDTH_20:
-               pHalData->RfRegChnlVal[0] =
-                       (pHalData->RfRegChnlVal[0] & 0xfffff3ff) | 0x0400;
-               PHY_SetRFReg(Adapter, RF_PATH_A, RF_CHNLBW, bRFRegOffsetMask,
-                            pHalData->RfRegChnlVal[0]);
-               break;
-       case HT_CHANNEL_WIDTH_40:
-               pHalData->RfRegChnlVal[0] =
-                       (pHalData->RfRegChnlVal[0] & 0xfffff3ff);
-               PHY_SetRFReg(Adapter, RF_PATH_A, RF_CHNLBW, bRFRegOffsetMask,
-                            pHalData->RfRegChnlVal[0]);
-               break;
-       default:
-               break;
-       }
-}
-
-/*-----------------------------------------------------------------------------
- * Function:   PHY_RF6052SetCckTxPower
- *
- * Overview:
- *
- * Input:       NONE
- *
- * Output:      NONE
- *
- * Return:      NONE
- *
- * Revised History:
- * When                        Who             Remark
- * 11/05/2008  MHC             Simulate 8192series..
- *
- *---------------------------------------------------------------------------*/
-
-void rtl823a_phy_rf6052setccktxpower(struct rtw_adapter *Adapter,
-                                    u8 *pPowerlevel)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(Adapter);
-       struct dm_priv *pdmpriv = &pHalData->dmpriv;
-       struct mlme_ext_priv *pmlmeext = &Adapter->mlmeextpriv;
-       u32 TxAGC[2] = {0, 0}, tmpval = 0;
-       u8 idx1, idx2;
-       u8 *ptr;
-
-       if (pmlmeext->sitesurvey_res.state == SCAN_PROCESS) {
-               TxAGC[RF_PATH_A] = 0x3f3f3f3f;
-               TxAGC[RF_PATH_B] = 0x3f3f3f3f;
-
-               for (idx1 = RF_PATH_A; idx1 <= RF_PATH_B; idx1++) {
-                       TxAGC[idx1] = pPowerlevel[idx1] |
-                               (pPowerlevel[idx1] << 8) |
-                               (pPowerlevel[idx1] << 16) |
-                               (pPowerlevel[idx1] << 24);
-                       /*
-                        * 2010/10/18 MH For external PA module. We need
-                        * to limit power index to be less than 0x20.
-                        */
-                       if (TxAGC[idx1] > 0x20 && pHalData->ExternalPA)
-                               TxAGC[idx1] = 0x20;
-               }
-       } else {
-/*  20100427 Joseph: Driver dynamic Tx power shall not affect Tx
- *  power. It shall be determined by power training mechanism. */
-/*  Currently, we cannot fully disable driver dynamic tx power
- *  mechanism because it is referenced by BT coexist mechanism. */
-/*  In the future, two mechanism shall be separated from each other
- *  and maintained independently. Thanks for Lanhsin's reminder. */
-               if (pdmpriv->DynamicTxHighPowerLvl == TxHighPwrLevel_Level1) {
-                       TxAGC[RF_PATH_A] = 0x10101010;
-                       TxAGC[RF_PATH_B] = 0x10101010;
-               } else if (pdmpriv->DynamicTxHighPowerLvl ==
-                          TxHighPwrLevel_Level2) {
-                       TxAGC[RF_PATH_A] = 0x00000000;
-                       TxAGC[RF_PATH_B] = 0x00000000;
-               } else {
-                       for (idx1 = RF_PATH_A; idx1 <= RF_PATH_B; idx1++) {
-                               TxAGC[idx1] = pPowerlevel[idx1] |
-                                       (pPowerlevel[idx1] << 8) |
-                                       (pPowerlevel[idx1] << 16) |
-                                       (pPowerlevel[idx1] << 24);
-                       }
-
-                       if (pHalData->EEPROMRegulatory == 0) {
-                               tmpval = (pHalData->MCSTxPowerLevelOriginalOffset[0][6]) +
-                                               (pHalData->MCSTxPowerLevelOriginalOffset[0][7]<<8);
-                               TxAGC[RF_PATH_A] += tmpval;
-
-                               tmpval = (pHalData->MCSTxPowerLevelOriginalOffset[0][14]) +
-                                               (pHalData->MCSTxPowerLevelOriginalOffset[0][15]<<24);
-                               TxAGC[RF_PATH_B] += tmpval;
-                       }
-               }
-       }
-
-       for (idx1 = RF_PATH_A; idx1 <= RF_PATH_B; idx1++) {
-               ptr = (u8 *)(&TxAGC[idx1]);
-               for (idx2 = 0; idx2 < 4; idx2++) {
-                       if (*ptr > RF6052_MAX_TX_PWR)
-                               *ptr = RF6052_MAX_TX_PWR;
-                       ptr++;
-               }
-       }
-
-       /*  rf-A cck tx power */
-       tmpval = TxAGC[RF_PATH_A] & 0xff;
-       PHY_SetBBReg(Adapter, rTxAGC_A_CCK1_Mcs32, bMaskByte1, tmpval);
-       tmpval = TxAGC[RF_PATH_A] >> 8;
-       PHY_SetBBReg(Adapter, rTxAGC_B_CCK11_A_CCK2_11, 0xffffff00, tmpval);
-
-       /*  rf-B cck tx power */
-       tmpval = TxAGC[RF_PATH_B] >> 24;
-       PHY_SetBBReg(Adapter, rTxAGC_B_CCK11_A_CCK2_11, bMaskByte0, tmpval);
-       tmpval = TxAGC[RF_PATH_B] & 0x00ffffff;
-       PHY_SetBBReg(Adapter, rTxAGC_B_CCK1_55_Mcs32, 0xffffff00, tmpval);
-}      /* PHY_RF6052SetCckTxPower */
-
-/*  powerbase0 for OFDM rates */
-/*  powerbase1 for HT MCS rates */
-static void getPowerBase(struct rtw_adapter *Adapter, u8 *pPowerLevel,
-                        u8 Channel, u32 *OfdmBase, u32 *MCSBase)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(Adapter);
-       u32 ofdm, mcs;
-       u8 Legacy_pwrdiff = 0;
-       s8 HT20_pwrdiff = 0;
-       u8 i, powerlevel[2];
-
-       for (i = 0; i < 2; i++) {
-               powerlevel[i] = pPowerLevel[i];
-               Legacy_pwrdiff = pHalData->TxPwrLegacyHtDiff[i][Channel-1];
-               ofdm = powerlevel[i] + Legacy_pwrdiff;
-
-               ofdm = ofdm << 24 | ofdm << 16 | ofdm << 8 | ofdm;
-               *(OfdmBase + i) = ofdm;
-       }
-
-       for (i = 0; i < 2; i++) {
-               /* Check HT20 to HT40 diff */
-               if (pHalData->CurrentChannelBW == HT_CHANNEL_WIDTH_20) {
-                       HT20_pwrdiff = pHalData->TxPwrHt20Diff[i][Channel-1];
-                       powerlevel[i] += HT20_pwrdiff;
-               }
-               mcs = powerlevel[i];
-               mcs = mcs << 24 | mcs << 16 | mcs << 8 | mcs;
-               *(MCSBase + i) = mcs;
-       }
-}
-
-static void
-getTxPowerWriteValByRegulatory(struct rtw_adapter *Adapter, u8 Channel,
-                              u8 index, u32 *powerBase0, u32 *powerBase1,
-                              u32 *pOutWriteVal)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(Adapter);
-       struct dm_priv  *pdmpriv = &pHalData->dmpriv;
-       u8 i, chnlGroup = 0, pwr_diff_limit[4];
-       u32 writeVal, customer_limit, rf;
-
-       /*  Index 0 & 1 = legacy OFDM, 2-5 = HT_MCS rate */
-       for (rf = 0; rf < 2; rf++) {
-               switch (pHalData->EEPROMRegulatory) {
-               case 0: /*  Realtek better performance */
-                       /*  increase power diff defined by Realtek for
-                        *  large power */
-                       chnlGroup = 0;
-                       writeVal = pHalData->MCSTxPowerLevelOriginalOffset[chnlGroup][index+(rf?8:0)] +
-                               ((index < 2) ? powerBase0[rf] : powerBase1[rf]);
-                       break;
-               case 1: /*  Realtek regulatory */
-                       /*  increase power diff defined by Realtek for
-                        *  regulatory */
-                       if (pHalData->pwrGroupCnt == 1)
-                               chnlGroup = 0;
-                       if (pHalData->pwrGroupCnt >= 3) {
-                               if (Channel <= 3)
-                                       chnlGroup = 0;
-                               else if (Channel >= 4 && Channel <= 9)
-                                       chnlGroup = 1;
-                               else if (Channel > 9)
-                                       chnlGroup = 2;
-
-                               if (pHalData->CurrentChannelBW ==
-                                   HT_CHANNEL_WIDTH_20)
-                                       chnlGroup++;
-                               else
-                                       chnlGroup += 4;
-                       }
-                       writeVal = pHalData->MCSTxPowerLevelOriginalOffset[chnlGroup][index+(rf?8:0)] +
-                                  ((index < 2) ? powerBase0[rf] :
-                                   powerBase1[rf]);
-                       break;
-               case 2: /*  Better regulatory */
-                       /*  don't increase any power diff */
-                       writeVal = (index < 2) ? powerBase0[rf] :
-                                   powerBase1[rf];
-                       break;
-               case 3: /*  Customer defined power diff. */
-                       chnlGroup = 0;
-
-                       for (i = 0; i < 4; i++) {
-                               pwr_diff_limit[i] = (u8)((pHalData->MCSTxPowerLevelOriginalOffset[chnlGroup][index +
-                                                   (rf ? 8 : 0)]&(0x7f << (i*8))) >> (i*8));
-                               if (pHalData->CurrentChannelBW == HT_CHANNEL_WIDTH_40) {
-                                       if (pwr_diff_limit[i] > pHalData->PwrGroupHT40[rf][Channel-1])
-                                               pwr_diff_limit[i] = pHalData->PwrGroupHT40[rf][Channel-1];
-                               } else {
-                                       if (pwr_diff_limit[i] > pHalData->PwrGroupHT20[rf][Channel-1])
-                                               pwr_diff_limit[i] = pHalData->PwrGroupHT20[rf][Channel-1];
-                               }
-                       }
-                       customer_limit = (pwr_diff_limit[3]<<24) | (pwr_diff_limit[2]<<16) |
-                                                       (pwr_diff_limit[1]<<8) | (pwr_diff_limit[0]);
-                       writeVal = customer_limit + ((index<2)?powerBase0[rf]:powerBase1[rf]);
-                       break;
-               default:
-                       chnlGroup = 0;
-                       writeVal = pHalData->MCSTxPowerLevelOriginalOffset[chnlGroup][index+(rf?8:0)] +
-                                       ((index < 2) ? powerBase0[rf] : powerBase1[rf]);
-                       break;
-               }
-
-/*  20100427 Joseph: Driver dynamic Tx power shall not affect Tx power.
-    It shall be determined by power training mechanism. */
-/*  Currently, we cannot fully disable driver dynamic tx power mechanism
-    because it is referenced by BT coexist mechanism. */
-/*  In the future, two mechanism shall be separated from each other and
-    maintained independently. Thanks for Lanhsin's reminder. */
-
-               if (pdmpriv->DynamicTxHighPowerLvl == TxHighPwrLevel_Level1)
-                       writeVal = 0x14141414;
-               else if (pdmpriv->DynamicTxHighPowerLvl ==
-                        TxHighPwrLevel_Level2)
-                       writeVal = 0x00000000;
-
-               /* 20100628 Joseph: High power mode for BT-Coexist mechanism. */
-               /* This mechanism is only applied when
-                  Driver-Highpower-Mechanism is OFF. */
-               if (pdmpriv->DynamicTxHighPowerLvl == TxHighPwrLevel_BT1)
-                       writeVal = writeVal - 0x06060606;
-               else if (pdmpriv->DynamicTxHighPowerLvl == TxHighPwrLevel_BT2)
-                       writeVal = writeVal;
-               *(pOutWriteVal + rf) = writeVal;
-       }
-}
-
-static void writeOFDMPowerReg(struct rtw_adapter *Adapter, u8 index,
-                             u32 *pValue)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(Adapter);
-       u16 RegOffset_A[6] = {
-               rTxAGC_A_Rate18_06, rTxAGC_A_Rate54_24,
-               rTxAGC_A_Mcs03_Mcs00, rTxAGC_A_Mcs07_Mcs04,
-               rTxAGC_A_Mcs11_Mcs08, rTxAGC_A_Mcs15_Mcs12
-       };
-       u16 RegOffset_B[6] = {
-               rTxAGC_B_Rate18_06, rTxAGC_B_Rate54_24,
-               rTxAGC_B_Mcs03_Mcs00, rTxAGC_B_Mcs07_Mcs04,
-               rTxAGC_B_Mcs11_Mcs08, rTxAGC_B_Mcs15_Mcs12
-       };
-       u8 i, rf, pwr_val[4];
-       u32 writeVal;
-       u16 RegOffset;
-
-       for (rf = 0; rf < 2; rf++) {
-               writeVal = pValue[rf];
-               for (i = 0; i < 4; i++) {
-                       pwr_val[i] = (u8)((writeVal &
-                                          (0x7f << (i * 8))) >> (i * 8));
-                       if (pwr_val[i] > RF6052_MAX_TX_PWR)
-                               pwr_val[i]  = RF6052_MAX_TX_PWR;
-               }
-               writeVal = pwr_val[3] << 24 | pwr_val[2] << 16 |
-                       pwr_val[1] << 8 | pwr_val[0];
-
-               if (rf == 0)
-                       RegOffset = RegOffset_A[index];
-               else
-                       RegOffset = RegOffset_B[index];
-
-               rtl8723au_write32(Adapter, RegOffset, writeVal);
-
-               /*  201005115 Joseph: Set Tx Power diff for Tx power
-                   training mechanism. */
-               if (((pHalData->rf_type == RF_2T2R) &&
-                   (RegOffset == rTxAGC_A_Mcs15_Mcs12 ||
-                    RegOffset == rTxAGC_B_Mcs15_Mcs12)) ||
-                   ((pHalData->rf_type != RF_2T2R) &&
-                    (RegOffset == rTxAGC_A_Mcs07_Mcs04 ||
-                     RegOffset == rTxAGC_B_Mcs07_Mcs04))) {
-                       writeVal = pwr_val[3];
-                       if (RegOffset == rTxAGC_A_Mcs15_Mcs12 ||
-                           RegOffset == rTxAGC_A_Mcs07_Mcs04)
-                               RegOffset = 0xc90;
-                       if (RegOffset == rTxAGC_B_Mcs15_Mcs12 ||
-                           RegOffset == rTxAGC_B_Mcs07_Mcs04)
-                               RegOffset = 0xc98;
-                       for (i = 0; i < 3; i++) {
-                               if (i != 2)
-                                       writeVal = (writeVal > 8) ?
-                                               (writeVal - 8) : 0;
-                               else
-                                       writeVal = (writeVal > 6) ?
-                                               (writeVal - 6) : 0;
-                               rtl8723au_write8(Adapter, RegOffset + i,
-                                                (u8)writeVal);
-                       }
-               }
-       }
-}
-/*-----------------------------------------------------------------------------
- * Function:   PHY_RF6052SetOFDMTxPower
- *
- * Overview:   For legacy and HY OFDM, we must read EEPROM TX power index for
- *             different channel and read original value in TX power
- *             register area from 0xe00. We increase offset and
- *             original value to be correct tx pwr.
- *
- * Input:       NONE
- *
- * Output:      NONE
- *
- * Return:      NONE
- *
- * Revised History:
- * When                        Remark
- * 11/05/2008  MHC     Simulate 8192 series method.
- * 01/06/2009  MHC     1. Prevent Path B tx power overflow or
- *                     underflow dure to A/B pwr difference or
- *                     legacy/HT pwr diff.
- *                     2. We concern with path B legacy/HT OFDM difference.
- * 01/22/2009  MHC     Support new EPRO format from SD3.
- *
- *---------------------------------------------------------------------------*/
-void rtl8723a_PHY_RF6052SetOFDMTxPower(struct rtw_adapter *Adapter,
-                                      u8 *pPowerLevel, u8 Channel)
-{
-       u32 writeVal[2], powerBase0[2], powerBase1[2];
-       u8 index = 0;
-
-       getPowerBase(Adapter, pPowerLevel, Channel,
-                    &powerBase0[0], &powerBase1[0]);
-
-       for (index = 0; index < 6; index++) {
-               getTxPowerWriteValByRegulatory(Adapter, Channel, index,
-                       &powerBase0[0], &powerBase1[0], &writeVal[0]);
-
-               writeOFDMPowerReg(Adapter, index, &writeVal[0]);
-       }
-}
-
-static int phy_RF6052_Config_ParaFile(struct rtw_adapter *Adapter)
-{
-       u32 u4RegValue = 0;
-       u8 eRFPath;
-       struct bb_reg_define *pPhyReg;
-       int rtStatus = _SUCCESS;
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(Adapter);
-
-       /* 3----------------------------------------------------------------- */
-       /* 3 <2> Initialize RF */
-       /* 3----------------------------------------------------------------- */
-       for (eRFPath = 0; eRFPath < pHalData->NumTotalRFPath; eRFPath++) {
-
-               pPhyReg = &pHalData->PHYRegDef[eRFPath];
-
-               /*----Store original RFENV control type----*/
-               switch (eRFPath) {
-               case RF_PATH_A:
-                       u4RegValue = PHY_QueryBBReg(Adapter, pPhyReg->rfintfs,
-                                                   bRFSI_RFENV);
-                       break;
-               case RF_PATH_B:
-                       u4RegValue = PHY_QueryBBReg(Adapter, pPhyReg->rfintfs,
-                                                   bRFSI_RFENV << 16);
-                       break;
-               }
-
-               /*----Set RF_ENV enable----*/
-               PHY_SetBBReg(Adapter, pPhyReg->rfintfe, bRFSI_RFENV << 16, 0x1);
-               udelay(1);/* PlatformStallExecution(1); */
-
-               /*----Set RF_ENV output high----*/
-               PHY_SetBBReg(Adapter, pPhyReg->rfintfo, bRFSI_RFENV, 0x1);
-               udelay(1);/* PlatformStallExecution(1); */
-
-               /* Set bit number of Address and Data for RF register */
-               PHY_SetBBReg(Adapter, pPhyReg->rfHSSIPara2, b3WireAddressLength,
-                            0x0);      /*  Set 1 to 4 bits for 8255 */
-               udelay(1);/* PlatformStallExecution(1); */
-
-               PHY_SetBBReg(Adapter, pPhyReg->rfHSSIPara2, b3WireDataLength,
-                            0x0);      /*  Set 0 to 12  bits for 8255 */
-               udelay(1);/* PlatformStallExecution(1); */
-
-               /*----Initialize RF fom connfiguration file----*/
-               switch (eRFPath) {
-               case RF_PATH_A:
-                       ODM_ReadAndConfig_RadioA_1T_8723A(&pHalData->odmpriv);
-                       break;
-               case RF_PATH_B:
-                       break;
-               }
-
-               /*----Restore RFENV control type----*/
-               switch (eRFPath) {
-               case RF_PATH_A:
-                       PHY_SetBBReg(Adapter, pPhyReg->rfintfs,
-                                    bRFSI_RFENV, u4RegValue);
-                       break;
-               case RF_PATH_B:
-                       PHY_SetBBReg(Adapter, pPhyReg->rfintfs,
-                                    bRFSI_RFENV << 16, u4RegValue);
-                       break;
-               }
-
-               if (rtStatus != _SUCCESS) {
-                       goto phy_RF6052_Config_ParaFile_Fail;
-               }
-       }
-phy_RF6052_Config_ParaFile_Fail:
-       return rtStatus;
-}
-
-int PHY_RF6052_Config8723A(struct rtw_adapter *Adapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(Adapter);
-
-       /*  Initialize general global value */
-       /*  TODO: Extend RF_PATH_C and RF_PATH_D in the future */
-       if (pHalData->rf_type == RF_1T1R)
-               pHalData->NumTotalRFPath = 1;
-       else
-               pHalData->NumTotalRFPath = 2;
-
-       /*  Config BB and RF */
-       return phy_RF6052_Config_ParaFile(Adapter);
-}
-
-/* End of HalRf6052.c */
diff --git a/drivers/staging/rtl8723au/hal/rtl8723a_rxdesc.c b/drivers/staging/rtl8723au/hal/rtl8723a_rxdesc.c
deleted file mode 100644 (file)
index 81b5efe..0000000
+++ /dev/null
@@ -1,69 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#define _RTL8723A_REDESC_C_
-
-#include <osdep_service.h>
-#include <drv_types.h>
-#include <rtl8723a_hal.h>
-
-static void process_rssi(struct rtw_adapter *padapter,
-                        struct recv_frame *prframe)
-{
-       struct rx_pkt_attrib *pattrib = &prframe->attrib;
-       struct signal_stat *signal_stat = &padapter->recvpriv.signal_strength_data;
-
-       if (signal_stat->update_req) {
-               signal_stat->total_num = 0;
-               signal_stat->total_val = 0;
-               signal_stat->update_req = 0;
-       }
-
-       signal_stat->total_num++;
-       signal_stat->total_val  += pattrib->phy_info.SignalStrength;
-       signal_stat->avg_val = signal_stat->total_val / signal_stat->total_num;
-}
-
-static void process_link_qual(struct rtw_adapter *padapter,
-                             struct recv_frame *prframe)
-{
-       struct rx_pkt_attrib *pattrib;
-       struct signal_stat *signal_stat;
-
-       if (prframe == NULL || padapter == NULL)
-               return;
-
-       pattrib = &prframe->attrib;
-       signal_stat = &padapter->recvpriv.signal_qual_data;
-
-       if (signal_stat->update_req) {
-               signal_stat->total_num = 0;
-               signal_stat->total_val = 0;
-               signal_stat->update_req = 0;
-       }
-
-       signal_stat->total_num++;
-       signal_stat->total_val  += pattrib->phy_info.SignalQuality;
-       signal_stat->avg_val = signal_stat->total_val / signal_stat->total_num;
-}
-
-/* void rtl8723a_process_phy_info(struct rtw_adapter *padapter, union recv_frame *prframe) */
-void rtl8723a_process_phy_info(struct rtw_adapter *padapter, void *prframe)
-{
-       struct recv_frame *precvframe = prframe;
-       /*  Check RSSI */
-       process_rssi(padapter, precvframe);
-       /*  Check EVM */
-       process_link_qual(padapter,  precvframe);
-}
diff --git a/drivers/staging/rtl8723au/hal/rtl8723a_sreset.c b/drivers/staging/rtl8723au/hal/rtl8723a_sreset.c
deleted file mode 100644 (file)
index 3c46294..0000000
+++ /dev/null
@@ -1,55 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#define _RTL8723A_SRESET_C_
-
-#include <rtl8723a_sreset.h>
-#include <rtl8723a_hal.h>
-#include <usb_ops_linux.h>
-
-void rtl8723a_sreset_xmit_status_check(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a   *pHalData = GET_HAL_DATA(padapter);
-       struct sreset_priv *psrtpriv = &pHalData->srestpriv;
-
-       unsigned long current_time;
-       struct xmit_priv        *pxmitpriv = &padapter->xmitpriv;
-       unsigned int diff_time;
-       u32 txdma_status;
-
-       txdma_status = rtl8723au_read32(padapter, REG_TXDMA_STATUS);
-       if (txdma_status != 0) {
-               DBG_8723A("%s REG_TXDMA_STATUS:0x%08x\n", __func__, txdma_status);
-               rtw_sreset_reset(padapter);
-       }
-
-       current_time = jiffies;
-
-       if (0 == pxmitpriv->free_xmitbuf_cnt || 0 == pxmitpriv->free_xmit_extbuf_cnt) {
-
-               diff_time = jiffies_to_msecs(jiffies - psrtpriv->last_tx_time);
-
-               if (diff_time > 2000) {
-                       if (psrtpriv->last_tx_complete_time == 0) {
-                               psrtpriv->last_tx_complete_time = current_time;
-                       } else {
-                               diff_time = jiffies_to_msecs(jiffies - psrtpriv->last_tx_complete_time);
-                               if (diff_time > 4000) {
-                                       DBG_8723A("%s tx hang\n", __func__);
-                                       rtw_sreset_reset(padapter);
-                               }
-                       }
-               }
-       }
-}
diff --git a/drivers/staging/rtl8723au/hal/rtl8723au_recv.c b/drivers/staging/rtl8723au/hal/rtl8723au_recv.c
deleted file mode 100644 (file)
index 0fec84b..0000000
+++ /dev/null
@@ -1,267 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#define _RTL8192CU_RECV_C_
-#include <osdep_service.h>
-#include <drv_types.h>
-#include <recv_osdep.h>
-#include <mlme_osdep.h>
-#include <linux/ip.h>
-#include <linux/if_ether.h>
-#include <usb_ops.h>
-#include <wifi.h>
-#include <rtl8723a_hal.h>
-
-int rtl8723au_init_recv_priv(struct rtw_adapter *padapter)
-{
-       struct recv_priv *precvpriv = &padapter->recvpriv;
-       int i, size, res = _SUCCESS;
-       struct recv_buf *precvbuf;
-       unsigned long tmpaddr;
-       unsigned long alignment;
-       struct sk_buff *pskb;
-
-       tasklet_init(&precvpriv->recv_tasklet,
-                    (void(*)(unsigned long))rtl8723au_recv_tasklet,
-                    (unsigned long)padapter);
-
-       precvpriv->int_in_urb = usb_alloc_urb(0, GFP_KERNEL);
-       if (!precvpriv->int_in_urb)
-               DBG_8723A("alloc_urb for interrupt in endpoint fail !!!!\n");
-       precvpriv->int_in_buf = kzalloc(USB_INTR_CONTENT_LENGTH, GFP_KERNEL);
-       if (!precvpriv->int_in_buf)
-               DBG_8723A("alloc_mem for interrupt in endpoint fail !!!!\n");
-
-       size = NR_RECVBUFF * sizeof(struct recv_buf);
-       precvpriv->precv_buf = kzalloc(size, GFP_KERNEL);
-       if (!precvpriv->precv_buf) {
-               res = _FAIL;
-               RT_TRACE(_module_rtl871x_recv_c_, _drv_err_,
-                        "alloc recv_buf fail!\n");
-               goto exit;
-       }
-
-       precvbuf = (struct recv_buf *)precvpriv->precv_buf;
-
-       for (i = 0; i < NR_RECVBUFF; i++) {
-               INIT_LIST_HEAD(&precvbuf->list);
-
-               precvbuf->purb = usb_alloc_urb(0, GFP_KERNEL);
-               if (!precvbuf->purb)
-                       break;
-
-               precvbuf->adapter = padapter;
-
-               precvbuf++;
-       }
-
-       skb_queue_head_init(&precvpriv->rx_skb_queue);
-       skb_queue_head_init(&precvpriv->free_recv_skb_queue);
-
-       for (i = 0; i < NR_PREALLOC_RECV_SKB; i++) {
-               size = MAX_RECVBUF_SZ + RECVBUFF_ALIGN_SZ;
-               pskb = __netdev_alloc_skb(padapter->pnetdev, size, GFP_KERNEL);
-
-               if (pskb) {
-                       pskb->dev = padapter->pnetdev;
-
-                       tmpaddr = (unsigned long)pskb->data;
-                       alignment = tmpaddr & (RECVBUFF_ALIGN_SZ-1);
-                       skb_reserve(pskb, (RECVBUFF_ALIGN_SZ - alignment));
-
-                       skb_queue_tail(&precvpriv->free_recv_skb_queue, pskb);
-               }
-
-               pskb = NULL;
-       }
-
-exit:
-       return res;
-}
-
-void rtl8723au_free_recv_priv(struct rtw_adapter *padapter)
-{
-       int     i;
-       struct recv_buf *precvbuf;
-       struct recv_priv *precvpriv = &padapter->recvpriv;
-
-       precvbuf = (struct recv_buf *)precvpriv->precv_buf;
-
-       for (i = 0; i < NR_RECVBUFF; i++) {
-               usb_free_urb(precvbuf->purb);
-
-               if (precvbuf->pskb)
-                       dev_kfree_skb_any(precvbuf->pskb);
-
-               precvbuf++;
-       }
-
-       kfree(precvpriv->precv_buf);
-
-       usb_free_urb(precvpriv->int_in_urb);
-       kfree(precvpriv->int_in_buf);
-
-       if (skb_queue_len(&precvpriv->rx_skb_queue))
-               DBG_8723A(KERN_WARNING "rx_skb_queue not empty\n");
-
-       skb_queue_purge(&precvpriv->rx_skb_queue);
-
-       if (skb_queue_len(&precvpriv->free_recv_skb_queue)) {
-               DBG_8723A(KERN_WARNING "free_recv_skb_queue not empty, %d\n",
-                         skb_queue_len(&precvpriv->free_recv_skb_queue));
-       }
-
-       skb_queue_purge(&precvpriv->free_recv_skb_queue);
-}
-
-struct recv_stat_cpu {
-       u32 rxdw0;
-       u32 rxdw1;
-       u32 rxdw2;
-       u32 rxdw3;
-       u32 rxdw4;
-       u32 rxdw5;
-};
-
-void update_recvframe_attrib(struct recv_frame *precvframe,
-                            struct recv_stat *prxstat)
-{
-       struct rx_pkt_attrib *pattrib;
-       struct recv_stat_cpu report;
-       struct rxreport_8723a *prxreport;
-
-       report.rxdw0 = le32_to_cpu(prxstat->rxdw0);
-       report.rxdw1 = le32_to_cpu(prxstat->rxdw1);
-       report.rxdw2 = le32_to_cpu(prxstat->rxdw2);
-       report.rxdw3 = le32_to_cpu(prxstat->rxdw3);
-       report.rxdw4 = le32_to_cpu(prxstat->rxdw4);
-       report.rxdw5 = le32_to_cpu(prxstat->rxdw5);
-
-       prxreport = (struct rxreport_8723a *)&report;
-
-       pattrib = &precvframe->attrib;
-       memset(pattrib, 0, sizeof(struct rx_pkt_attrib));
-
-       /*  update rx report to recv_frame attribute */
-       pattrib->pkt_len = (u16)prxreport->pktlen;
-       pattrib->drvinfo_sz = (u8)(prxreport->drvinfosize << 3);
-       pattrib->physt = (u8)prxreport->physt;
-
-       pattrib->crc_err = (u8)prxreport->crc32;
-       pattrib->icv_err = (u8)prxreport->icverr;
-
-       pattrib->bdecrypted = (u8)(prxreport->swdec ? 0 : 1);
-       pattrib->encrypt = (u8)prxreport->security;
-
-       pattrib->qos = (u8)prxreport->qos;
-       pattrib->priority = (u8)prxreport->tid;
-
-       pattrib->amsdu = (u8)prxreport->amsdu;
-
-       pattrib->seq_num = (u16)prxreport->seq;
-       pattrib->frag_num = (u8)prxreport->frag;
-       pattrib->mfrag = (u8)prxreport->mf;
-       pattrib->mdata = (u8)prxreport->md;
-
-       pattrib->mcs_rate = (u8)prxreport->rxmcs;
-       pattrib->rxht = (u8)prxreport->rxht;
-}
-
-void update_recvframe_phyinfo(struct recv_frame *precvframe,
-                             struct phy_stat *pphy_status)
-{
-       struct rtw_adapter *padapter = precvframe->adapter;
-       struct rx_pkt_attrib *pattrib = &precvframe->attrib;
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       struct phy_info *pPHYInfo = &pattrib->phy_info;
-       struct odm_packet_info pkt_info;
-       u8 *sa = NULL, *da;
-       struct sta_priv *pstapriv;
-       struct sta_info *psta;
-       struct sk_buff *skb = precvframe->pkt;
-       struct ieee80211_hdr *hdr = (struct ieee80211_hdr *) skb->data;
-       bool matchbssid = false;
-       u8 *bssid;
-
-       matchbssid = !ieee80211_is_ctl(hdr->frame_control) &&
-                     !pattrib->icv_err && !pattrib->crc_err;
-
-       if (matchbssid) {
-               switch (hdr->frame_control &
-                       cpu_to_le16(IEEE80211_FCTL_TODS |
-                                   IEEE80211_FCTL_FROMDS)) {
-               case cpu_to_le16(IEEE80211_FCTL_TODS):
-                       bssid = hdr->addr1;
-                       break;
-               case cpu_to_le16(IEEE80211_FCTL_FROMDS):
-                       bssid = hdr->addr2;
-                       break;
-               case cpu_to_le16(0):
-                       bssid = hdr->addr3;
-                       break;
-               default:
-                       bssid = NULL;
-                       matchbssid = false;
-               }
-
-               if (bssid)
-                       matchbssid = ether_addr_equal(
-                               get_bssid(&padapter->mlmepriv), bssid);
-       }
-
-       pkt_info.bPacketMatchBSSID = matchbssid;
-
-       da = ieee80211_get_DA(hdr);
-       pkt_info.bPacketToSelf = pkt_info.bPacketMatchBSSID &&
-               (!memcmp(da, myid(&padapter->eeprompriv), ETH_ALEN));
-
-       pkt_info.bPacketBeacon = pkt_info.bPacketMatchBSSID &&
-               ieee80211_is_beacon(hdr->frame_control);
-
-       pkt_info.StationID = 0xFF;
-       if (pkt_info.bPacketBeacon) {
-               if (check_fwstate(&padapter->mlmepriv, WIFI_STATION_STATE) == true)
-                       sa = padapter->mlmepriv.cur_network.network.MacAddress;
-               /* to do Ad-hoc */
-       } else {
-               sa = ieee80211_get_SA(hdr);
-       }
-
-       pstapriv = &padapter->stapriv;
-       psta = rtw_get_stainfo23a(pstapriv, sa);
-       if (psta) {
-               pkt_info.StationID = psta->mac_id;
-               /* printk("%s ==> StationID(%d)\n", __func__, pkt_info.StationID); */
-       }
-       pkt_info.Rate = pattrib->mcs_rate;
-
-       ODM_PhyStatusQuery23a(&pHalData->odmpriv, pPHYInfo,
-                             (u8 *)pphy_status, &pkt_info);
-       precvframe->psta = NULL;
-       if (pkt_info.bPacketMatchBSSID &&
-           (check_fwstate(&padapter->mlmepriv, WIFI_AP_STATE) == true)) {
-               if (psta) {
-                       precvframe->psta = psta;
-                       rtl8723a_process_phy_info(padapter, precvframe);
-               }
-       } else if (pkt_info.bPacketToSelf || pkt_info.bPacketBeacon) {
-               if (check_fwstate(&padapter->mlmepriv,
-                                 WIFI_ADHOC_STATE|WIFI_ADHOC_MASTER_STATE) ==
-                   true) {
-                       if (psta)
-                               precvframe->psta = psta;
-               }
-               rtl8723a_process_phy_info(padapter, precvframe);
-       }
-}
diff --git a/drivers/staging/rtl8723au/hal/rtl8723au_xmit.c b/drivers/staging/rtl8723au/hal/rtl8723au_xmit.c
deleted file mode 100644 (file)
index 14746dd..0000000
+++ /dev/null
@@ -1,520 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#define _RTL8192C_XMIT_C_
-#include <osdep_service.h>
-#include <drv_types.h>
-#include <wifi.h>
-#include <osdep_intf.h>
-#include <usb_ops.h>
-/* include <rtl8192c_hal.h> */
-#include <rtl8723a_hal.h>
-
-static int urb_zero_packet_chk(struct rtw_adapter *padapter, int sz)
-{
-       int blnSetTxDescOffset;
-       struct dvobj_priv       *pdvobj = adapter_to_dvobj(padapter);
-
-       if (pdvobj->ishighspeed) {
-               if (((sz + TXDESC_SIZE) % 512) == 0)
-                       blnSetTxDescOffset = 1;
-               else
-                       blnSetTxDescOffset = 0;
-       } else {
-               if (((sz + TXDESC_SIZE) % 64) == 0)
-                       blnSetTxDescOffset = 1;
-               else
-                       blnSetTxDescOffset = 0;
-       }
-       return blnSetTxDescOffset;
-}
-
-static void rtl8192cu_cal_txdesc_chksum(struct tx_desc *ptxdesc)
-{
-               __le16  *usPtr = (__le16 *)ptxdesc;
-               u32 count = 16;         /*  (32 bytes / 2 bytes per XOR) => 16 times */
-               u32 index;
-               u16 checksum = 0;
-
-               /* Clear first */
-               ptxdesc->txdw7 &= cpu_to_le32(0xffff0000);
-
-               for (index = 0 ; index < count ; index++)
-                       checksum = checksum ^ le16_to_cpu(*(usPtr + index));
-
-               ptxdesc->txdw7 |= cpu_to_le32(0x0000ffff&checksum);
-}
-
-static void fill_txdesc_sectype(struct pkt_attrib *pattrib, struct tx_desc *ptxdesc)
-{
-       if ((pattrib->encrypt > 0) && !pattrib->bswenc) {
-               switch (pattrib->encrypt) {
-               /* SEC_TYPE */
-               case WLAN_CIPHER_SUITE_WEP40:
-               case WLAN_CIPHER_SUITE_WEP104:
-                       ptxdesc->txdw1 |= cpu_to_le32((0x01<<22)&0x00c00000);
-                       break;
-               case WLAN_CIPHER_SUITE_TKIP:
-                       /* ptxdesc->txdw1 |= cpu_to_le32((0x02<<22)&0x00c00000); */
-                       ptxdesc->txdw1 |= cpu_to_le32((0x01<<22)&0x00c00000);
-                       break;
-               case WLAN_CIPHER_SUITE_CCMP:
-                       ptxdesc->txdw1 |= cpu_to_le32((0x03<<22)&0x00c00000);
-                       break;
-               case 0:
-               default:
-                       break;
-               }
-       }
-}
-
-static void fill_txdesc_vcs(struct pkt_attrib *pattrib, __le32 *pdw)
-{
-       /* DBG_8723A("cvs_mode =%d\n", pattrib->vcs_mode); */
-
-       switch (pattrib->vcs_mode) {
-       case RTS_CTS:
-               *pdw |= cpu_to_le32(BIT(12));
-               break;
-       case CTS_TO_SELF:
-               *pdw |= cpu_to_le32(BIT(11));
-               break;
-       case NONE_VCS:
-       default:
-               break;
-       }
-
-       if (pattrib->vcs_mode) {
-               *pdw |= cpu_to_le32(BIT(13));
-
-               /*  Set RTS BW */
-               if (pattrib->ht_en) {
-                       *pdw |= (pattrib->bwmode&HT_CHANNEL_WIDTH_40) ? cpu_to_le32(BIT(27)) : 0;
-
-                       if (pattrib->ch_offset == HAL_PRIME_CHNL_OFFSET_LOWER)
-                               *pdw |= cpu_to_le32((0x01<<28)&0x30000000);
-                       else if (pattrib->ch_offset == HAL_PRIME_CHNL_OFFSET_UPPER)
-                               *pdw |= cpu_to_le32((0x02<<28)&0x30000000);
-                       else if (pattrib->ch_offset == HAL_PRIME_CHNL_OFFSET_DONT_CARE)
-                               *pdw |= 0;
-                       else
-                               *pdw |= cpu_to_le32((0x03<<28)&0x30000000);
-               }
-       }
-}
-
-static void fill_txdesc_phy(struct pkt_attrib *pattrib, __le32 *pdw)
-{
-       if (pattrib->ht_en) {
-               *pdw |= (pattrib->bwmode&HT_CHANNEL_WIDTH_40) ? cpu_to_le32(BIT(25)) : 0;
-
-               if (pattrib->ch_offset == HAL_PRIME_CHNL_OFFSET_LOWER)
-                       *pdw |= cpu_to_le32((0x01<<20)&0x003f0000);
-               else if (pattrib->ch_offset == HAL_PRIME_CHNL_OFFSET_UPPER)
-                       *pdw |= cpu_to_le32((0x02<<20)&0x003f0000);
-               else if (pattrib->ch_offset == HAL_PRIME_CHNL_OFFSET_DONT_CARE)
-                       *pdw |= 0;
-               else
-                       *pdw |= cpu_to_le32((0x03<<20)&0x003f0000);
-       }
-}
-
-static s32 update_txdesc(struct xmit_frame *pxmitframe, u8 *pmem, s32 sz)
-{
-       int     pull = 0;
-       uint    qsel;
-       struct rtw_adapter      *padapter = pxmitframe->padapter;
-       struct pkt_attrib       *pattrib = &pxmitframe->attrib;
-       struct hal_data_8723a   *pHalData = GET_HAL_DATA(padapter);
-       struct dm_priv  *pdmpriv = &pHalData->dmpriv;
-       struct tx_desc  *ptxdesc = (struct tx_desc *)pmem;
-       struct mlme_ext_priv    *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info    *pmlmeinfo = &pmlmeext->mlmext_info;
-       int     bmcst = is_multicast_ether_addr(pattrib->ra);
-
-       if (urb_zero_packet_chk(padapter, sz) == 0) {
-               ptxdesc = (struct tx_desc *)(pmem+PACKET_OFFSET_SZ);
-               pull = 1;
-               pxmitframe->pkt_offset--;
-       }
-
-       memset(ptxdesc, 0, sizeof(struct tx_desc));
-
-       if (pxmitframe->frame_tag == DATA_FRAMETAG) {
-               /* offset 4 */
-               ptxdesc->txdw1 |= cpu_to_le32(pattrib->mac_id&0x1f);
-
-               qsel = (uint)(pattrib->qsel & 0x0000001f);
-               ptxdesc->txdw1 |= cpu_to_le32((qsel << QSEL_SHT) & 0x00001f00);
-
-               ptxdesc->txdw1 |= cpu_to_le32((pattrib->raid<<16) & 0x000f0000);
-
-               fill_txdesc_sectype(pattrib, ptxdesc);
-
-               if (pattrib->ampdu_en)
-                       ptxdesc->txdw1 |= cpu_to_le32(BIT(5));/* AGG EN */
-               else
-                       ptxdesc->txdw1 |= cpu_to_le32(BIT(6));/* AGG BK */
-
-               /* offset 8 */
-
-               /* offset 12 */
-               ptxdesc->txdw3 |= cpu_to_le32((pattrib->seqnum<<16)&0xffff0000);
-
-               /* offset 16 , offset 20 */
-               if (pattrib->qos_en)
-                       ptxdesc->txdw4 |= cpu_to_le32(BIT(6));/* QoS */
-
-               if ((pattrib->ether_type != 0x888e) &&
-                   (pattrib->ether_type != 0x0806) &&
-                   (pattrib->dhcp_pkt != 1)) {
-                       /* Non EAP & ARP & DHCP type data packet */
-
-                       fill_txdesc_vcs(pattrib, &ptxdesc->txdw4);
-                       fill_txdesc_phy(pattrib, &ptxdesc->txdw4);
-
-                       ptxdesc->txdw4 |= cpu_to_le32(0x00000008);/* RTS Rate = 24M */
-                       ptxdesc->txdw5 |= cpu_to_le32(0x0001ff00);/*  */
-
-                       /* use REG_INIDATA_RATE_SEL value */
-                       ptxdesc->txdw5 |= cpu_to_le32(pdmpriv->INIDATA_RATE[pattrib->mac_id]);
-               } else {
-                       /*  EAP data packet and ARP packet. */
-                       /*  Use the 1M data rate to send the EAP/ARP packet. */
-                       /*  This will maybe make the handshake smooth. */
-
-                       ptxdesc->txdw1 |= cpu_to_le32(BIT(6));/* AGG BK */
-
-                       ptxdesc->txdw4 |= cpu_to_le32(BIT(8));/* driver uses rate */
-
-                       if (pmlmeinfo->preamble_mode == PREAMBLE_SHORT)
-                               ptxdesc->txdw4 |= cpu_to_le32(BIT(24));/*  DATA_SHORT */
-
-                       ptxdesc->txdw5 |= cpu_to_le32(MRateToHwRate23a(pmlmeext->tx_rate));
-               }
-       } else if (pxmitframe->frame_tag == MGNT_FRAMETAG) {
-               /* offset 4 */
-               ptxdesc->txdw1 |= cpu_to_le32(pattrib->mac_id&0x1f);
-
-               qsel = (uint)(pattrib->qsel&0x0000001f);
-               ptxdesc->txdw1 |= cpu_to_le32((qsel<<QSEL_SHT)&0x00001f00);
-
-               ptxdesc->txdw1 |= cpu_to_le32((pattrib->raid<<16) & 0x000f0000);
-
-               /* offset 8 */
-               /* CCX-TXRPT ack for xmit mgmt frames. */
-               if (pxmitframe->ack_report)
-                       ptxdesc->txdw2 |= cpu_to_le32(BIT(19));
-
-               /* offset 12 */
-               ptxdesc->txdw3 |= cpu_to_le32((pattrib->seqnum<<16)&0xffff0000);
-
-               /* offset 16 */
-               ptxdesc->txdw4 |= cpu_to_le32(BIT(8));/* driver uses rate */
-
-               /* offset 20 */
-               ptxdesc->txdw5 |= cpu_to_le32(BIT(17));/* retry limit enable */
-               ptxdesc->txdw5 |= cpu_to_le32(0x00180000);/* retry limit = 6 */
-
-               ptxdesc->txdw5 |= cpu_to_le32(MRateToHwRate23a(pmlmeext->tx_rate));
-       } else if (pxmitframe->frame_tag == TXAGG_FRAMETAG) {
-               DBG_8723A("pxmitframe->frame_tag == TXAGG_FRAMETAG\n");
-       } else {
-               DBG_8723A("pxmitframe->frame_tag = %d\n",
-                         pxmitframe->frame_tag);
-
-               /* offset 4 */
-               ptxdesc->txdw1 |= cpu_to_le32((4)&0x1f);/* CAM_ID(MAC_ID) */
-
-               ptxdesc->txdw1 |= cpu_to_le32((6<<16) & 0x000f0000);/* raid */
-
-               /* offset 8 */
-
-               /* offset 12 */
-               ptxdesc->txdw3 |= cpu_to_le32((pattrib->seqnum<<16)&0xffff0000);
-
-               /* offset 16 */
-               ptxdesc->txdw4 |= cpu_to_le32(BIT(8));/* driver uses rate */
-
-               /* offset 20 */
-               ptxdesc->txdw5 |= cpu_to_le32(MRateToHwRate23a(pmlmeext->tx_rate));
-       }
-
-       /*  (1) The sequence number of each non-Qos frame / broadcast / multicast / */
-       /*  mgnt frame should be controlled by Hw because Fw will also send null data */
-       /*  which we cannot control when Fw LPS enable. */
-       /*  --> default enable non-Qos data sequense number. 2010.06.23. by tynli. */
-       /*  (2) Enable HW SEQ control for beacon packet, because we use Hw beacon. */
-       /*  (3) Use HW Qos SEQ to control the seq num of Ext port non-Qos packets. */
-       if (!pattrib->qos_en) {
-               /*  Hw set sequence number */
-               ptxdesc->txdw4 |= cpu_to_le32(BIT(7));
-               /* set bit3 to 1. */
-               ptxdesc->txdw3 |= cpu_to_le32((8 << 28));
-       }
-
-       /* offset 0 */
-       ptxdesc->txdw0 |= cpu_to_le32(sz&0x0000ffff);
-       ptxdesc->txdw0 |= cpu_to_le32(OWN | FSG | LSG);
-       ptxdesc->txdw0 |= cpu_to_le32(((TXDESC_SIZE+OFFSET_SZ)<<OFFSET_SHT)&0x00ff0000);/* 32 bytes for TX Desc */
-
-       if (bmcst)
-               ptxdesc->txdw0 |= cpu_to_le32(BIT(24));
-
-       RT_TRACE(_module_rtl871x_xmit_c_, _drv_info_,
-                "offset0-txdesc = 0x%x\n", ptxdesc->txdw0);
-
-       /* offset 4 */
-       /*  pkt_offset, unit:8 bytes padding */
-       if (pxmitframe->pkt_offset > 0)
-               ptxdesc->txdw1 |= cpu_to_le32((pxmitframe->pkt_offset << 26) & 0x7c000000);
-
-       rtl8192cu_cal_txdesc_chksum(ptxdesc);
-       return pull;
-}
-
-static int rtw_dump_xframe(struct rtw_adapter *padapter,
-                          struct xmit_frame *pxmitframe)
-{
-       int ret = _SUCCESS;
-       int inner_ret = _SUCCESS;
-       int t, sz, w_sz, pull = 0;
-       u8 *mem_addr;
-       u32 ff_hwaddr;
-       struct xmit_buf *pxmitbuf = pxmitframe->pxmitbuf;
-       struct pkt_attrib *pattrib = &pxmitframe->attrib;
-       struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-
-       if (pxmitframe->frame_tag == DATA_FRAMETAG &&
-           pxmitframe->attrib.ether_type != ETH_P_ARP &&
-           pxmitframe->attrib.ether_type != ETH_P_PAE &&
-           pxmitframe->attrib.dhcp_pkt != 1)
-               rtw_issue_addbareq_cmd23a(padapter, pxmitframe);
-
-       mem_addr = pxmitframe->buf_addr;
-
-       RT_TRACE(_module_rtl871x_xmit_c_, _drv_info_, "rtw_dump_xframe()\n");
-
-       for (t = 0; t < pattrib->nr_frags; t++) {
-               if (inner_ret != _SUCCESS && ret == _SUCCESS)
-                       ret = _FAIL;
-
-               if (t != (pattrib->nr_frags - 1)) {
-                       RT_TRACE(_module_rtl871x_xmit_c_, _drv_err_,
-                                "pattrib->nr_frags =%d\n", pattrib->nr_frags);
-
-                       sz = pxmitpriv->frag_len;
-                       sz = sz - 4 - pattrib->icv_len;
-               } else {
-                       /* no frag */
-                       sz = pattrib->last_txcmdsz;
-               }
-
-               pull = update_txdesc(pxmitframe, mem_addr, sz);
-
-               if (pull) {
-                       mem_addr += PACKET_OFFSET_SZ; /* pull txdesc head */
-
-                       pxmitframe->buf_addr = mem_addr;
-
-                       w_sz = sz + TXDESC_SIZE;
-               } else {
-                       w_sz = sz + TXDESC_SIZE + PACKET_OFFSET_SZ;
-               }
-
-               ff_hwaddr = rtw_get_ff_hwaddr23a(pxmitframe);
-               inner_ret = rtl8723au_write_port(padapter, ff_hwaddr,
-                                                w_sz, pxmitbuf);
-               rtw_count_tx_stats23a(padapter, pxmitframe, sz);
-
-               RT_TRACE(_module_rtl871x_xmit_c_, _drv_info_,
-                        "rtw_write_port, w_sz =%d\n", w_sz);
-
-               mem_addr += w_sz;
-
-               mem_addr = PTR_ALIGN(mem_addr, 4);
-       }
-
-       rtw_free_xmitframe23a(pxmitpriv, pxmitframe);
-
-       if  (ret != _SUCCESS)
-               rtw23a_sctx_done_err(&pxmitbuf->sctx, RTW_SCTX_DONE_UNKNOWN);
-
-       return ret;
-}
-
-bool rtl8723au_xmitframe_complete(struct rtw_adapter *padapter,
-                                 struct xmit_priv *pxmitpriv,
-                                 struct xmit_buf *pxmitbuf)
-{
-       struct hw_xmit *phwxmits;
-       struct xmit_frame *pxmitframe;
-       int hwentry;
-       int res = _SUCCESS, xcnt = 0;
-
-       phwxmits = pxmitpriv->hwxmits;
-       hwentry = pxmitpriv->hwxmit_entry;
-
-       RT_TRACE(_module_rtl871x_xmit_c_, _drv_info_, "xmitframe_complete()\n");
-
-       if (pxmitbuf == NULL) {
-               pxmitbuf = rtw_alloc_xmitbuf23a(pxmitpriv);
-               if (!pxmitbuf)
-                       return false;
-       }
-       pxmitframe =  rtw_dequeue_xframe23a(pxmitpriv, phwxmits, hwentry);
-
-       if (pxmitframe) {
-               pxmitframe->pxmitbuf = pxmitbuf;
-
-               pxmitframe->buf_addr = pxmitbuf->pbuf;
-
-               pxmitbuf->priv_data = pxmitframe;
-
-               if (pxmitframe->frame_tag == DATA_FRAMETAG) {
-                       if (pxmitframe->attrib.priority <= 15)/* TID0~15 */
-                               res = rtw_xmitframe_coalesce23a(padapter, pxmitframe->pkt, pxmitframe);
-
-                       rtw_os_xmit_complete23a(padapter, pxmitframe);/* always return ndis_packet after rtw_xmitframe_coalesce23a */
-               }
-
-               RT_TRACE(_module_rtl871x_xmit_c_, _drv_info_,
-                        "xmitframe_complete(): rtw_dump_xframe\n");
-
-               if (res == _SUCCESS) {
-                       rtw_dump_xframe(padapter, pxmitframe);
-               } else {
-                       rtw_free_xmitbuf23a(pxmitpriv, pxmitbuf);
-                       rtw_free_xmitframe23a(pxmitpriv, pxmitframe);
-               }
-               xcnt++;
-       } else {
-               rtw_free_xmitbuf23a(pxmitpriv, pxmitbuf);
-               return false;
-       }
-       return true;
-}
-
-static int xmitframe_direct(struct rtw_adapter *padapter,
-                           struct xmit_frame *pxmitframe)
-{
-       int res;
-
-       res = rtw_xmitframe_coalesce23a(padapter, pxmitframe->pkt, pxmitframe);
-       if (res == _SUCCESS)
-               rtw_dump_xframe(padapter, pxmitframe);
-       return res;
-}
-
-/*
- * Return
- *     true    dump packet directly
- *     false   enqueue packet
- */
-bool rtl8723au_hal_xmit(struct rtw_adapter *padapter,
-                       struct xmit_frame *pxmitframe)
-{
-       int res;
-       struct xmit_buf *pxmitbuf = NULL;
-       struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-       struct pkt_attrib *pattrib = &pxmitframe->attrib;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-
-       pattrib->qsel = pattrib->priority;
-       spin_lock_bh(&pxmitpriv->lock);
-
-#ifdef CONFIG_8723AU_AP_MODE
-       if (xmitframe_enqueue_for_sleeping_sta23a(padapter, pxmitframe)) {
-               struct sta_info *psta;
-               struct sta_priv *pstapriv = &padapter->stapriv;
-
-               spin_unlock_bh(&pxmitpriv->lock);
-
-               if (pattrib->psta)
-                       psta = pattrib->psta;
-               else
-                       psta = rtw_get_stainfo23a(pstapriv, pattrib->ra);
-
-               if (psta) {
-                       if (psta->sleepq_len > (NR_XMITFRAME>>3))
-                               wakeup_sta_to_xmit23a(padapter, psta);
-               }
-
-               return false;
-       }
-#endif
-
-       if (rtw_txframes_sta_ac_pending23a(padapter, pattrib) > 0)
-               goto enqueue;
-
-       if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY|_FW_UNDER_LINKING) == true)
-               goto enqueue;
-
-       pxmitbuf = rtw_alloc_xmitbuf23a(pxmitpriv);
-       if (pxmitbuf == NULL)
-               goto enqueue;
-
-       spin_unlock_bh(&pxmitpriv->lock);
-
-       pxmitframe->pxmitbuf = pxmitbuf;
-       pxmitframe->buf_addr = pxmitbuf->pbuf;
-       pxmitbuf->priv_data = pxmitframe;
-
-       if (xmitframe_direct(padapter, pxmitframe) != _SUCCESS) {
-               rtw_free_xmitbuf23a(pxmitpriv, pxmitbuf);
-               rtw_free_xmitframe23a(pxmitpriv, pxmitframe);
-       }
-       return true;
-
-enqueue:
-       res = rtw_xmitframe_enqueue23a(padapter, pxmitframe);
-       spin_unlock_bh(&pxmitpriv->lock);
-
-       if (res != _SUCCESS) {
-               RT_TRACE(_module_xmit_osdep_c_, _drv_err_,
-                        "pre_xmitframe: enqueue xmitframe fail\n");
-               rtw_free_xmitframe23a(pxmitpriv, pxmitframe);
-
-               /*  Trick, make the statistics correct */
-               pxmitpriv->tx_pkts--;
-               pxmitpriv->tx_drop++;
-               return true;
-       }
-       return false;
-}
-
-int rtl8723au_mgnt_xmit(struct rtw_adapter *padapter,
-                       struct xmit_frame *pmgntframe)
-{
-       return rtw_dump_xframe(padapter, pmgntframe);
-}
-
-int rtl8723au_hal_xmitframe_enqueue(struct rtw_adapter *padapter,
-                                   struct xmit_frame *pxmitframe)
-{
-       struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-       int err;
-
-       err = rtw_xmitframe_enqueue23a(padapter, pxmitframe);
-       if (err != _SUCCESS) {
-               rtw_free_xmitframe23a(pxmitpriv, pxmitframe);
-
-               /*  Trick, make the statistics correct */
-               pxmitpriv->tx_pkts--;
-               pxmitpriv->tx_drop++;
-       } else {
-               tasklet_hi_schedule(&pxmitpriv->xmit_tasklet);
-       }
-       return err;
-}
diff --git a/drivers/staging/rtl8723au/hal/usb_halinit.c b/drivers/staging/rtl8723au/hal/usb_halinit.c
deleted file mode 100644 (file)
index fa47aeb..0000000
+++ /dev/null
@@ -1,1269 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#define _HCI_HAL_INIT_C_
-
-#include <osdep_service.h>
-#include <drv_types.h>
-#include <rtw_efuse.h>
-
-#include <HalPwrSeqCmd.h>
-#include <Hal8723PwrSeq.h>
-#include <rtl8723a_hal.h>
-#include <linux/ieee80211.h>
-
-#include <usb_ops.h>
-
-static void phy_SsPwrSwitch92CU(struct rtw_adapter *Adapter,
-                               enum rt_rf_power_state eRFPowerState);
-
-static void
-_ConfigChipOutEP(struct rtw_adapter *pAdapter, u8 NumOutPipe)
-{
-       u8 value8;
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(pAdapter);
-
-       pHalData->OutEpQueueSel = 0;
-       pHalData->OutEpNumber = 0;
-
-       /*  Normal and High queue */
-       value8 = rtl8723au_read8(pAdapter, (REG_NORMAL_SIE_EP + 1));
-
-       if (value8 & USB_NORMAL_SIE_EP_MASK) {
-               pHalData->OutEpQueueSel |= TX_SELE_HQ;
-               pHalData->OutEpNumber++;
-       }
-
-       if ((value8 >> USB_NORMAL_SIE_EP_SHIFT) & USB_NORMAL_SIE_EP_MASK) {
-               pHalData->OutEpQueueSel |= TX_SELE_NQ;
-               pHalData->OutEpNumber++;
-       }
-
-       /*  Low queue */
-       value8 = rtl8723au_read8(pAdapter, (REG_NORMAL_SIE_EP + 2));
-       if (value8 & USB_NORMAL_SIE_EP_MASK) {
-               pHalData->OutEpQueueSel |= TX_SELE_LQ;
-               pHalData->OutEpNumber++;
-       }
-
-       /*  TODO: Error recovery for this case */
-       /* RT_ASSERT((NumOutPipe == pHalData->OutEpNumber),
-          ("Out EP number isn't match! %d(Descriptor) != %d (SIE reg)\n",
-          (u32)NumOutPipe, (u32)pHalData->OutEpNumber)); */
-}
-
-bool rtl8723au_chip_configure(struct rtw_adapter *padapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(padapter);
-       u8 NumInPipe = pdvobjpriv->RtNumInPipes;
-       u8 NumOutPipe = pdvobjpriv->RtNumOutPipes;
-
-       _ConfigChipOutEP(padapter, NumOutPipe);
-
-       /*  Normal chip with one IN and one OUT doesn't have interrupt IN EP. */
-       if (pHalData->OutEpNumber == 1) {
-               if (NumInPipe != 1)
-                       return false;
-       }
-
-       return Hal_MappingOutPipe23a(padapter, NumOutPipe);
-}
-
-static int _InitPowerOn(struct rtw_adapter *padapter)
-{
-       u16 value16;
-       u8 value8;
-
-       /*  RSV_CTRL 0x1C[7:0] = 0x00
-           unlock ISO/CLK/Power control register */
-       rtl8723au_write8(padapter, REG_RSV_CTRL, 0x0);
-
-       /*  HW Power on sequence */
-       if (!HalPwrSeqCmdParsing23a(padapter, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK,
-                                PWR_INTF_USB_MSK, rtl8723AU_card_enable_flow))
-               return _FAIL;
-
-       /*  0x04[19] = 1, suggest by Jackie 2011.05.09, reset 8051 */
-       value8 = rtl8723au_read8(padapter, REG_APS_FSMCO+2);
-       rtl8723au_write8(padapter, REG_APS_FSMCO + 2, value8 | BIT(3));
-
-       /*  Enable MAC DMA/WMAC/SCHEDULE/SEC block */
-       /*  Set CR bit10 to enable 32k calibration. Suggested by SD1 Gimmy.
-           Added by tynli. 2011.08.31. */
-       value16 = rtl8723au_read16(padapter, REG_CR);
-       value16 |= (HCI_TXDMA_EN | HCI_RXDMA_EN | TXDMA_EN | RXDMA_EN |
-                   PROTOCOL_EN | SCHEDULE_EN | MACTXEN | MACRXEN |
-                   ENSEC | CALTMR_EN);
-       rtl8723au_write16(padapter, REG_CR, value16);
-
-       /* for Efuse PG, suggest by Jackie 2011.11.23 */
-       PHY_SetBBReg(padapter, REG_EFUSE_CTRL, BIT(28)|BIT(29)|BIT(30), 0x06);
-
-       return _SUCCESS;
-}
-
-/*  Shall USB interface init this? */
-static void _InitInterrupt(struct rtw_adapter *Adapter)
-{
-       u32 value32;
-
-       /*  HISR - turn all on */
-       value32 = 0xFFFFFFFF;
-       rtl8723au_write32(Adapter, REG_HISR, value32);
-
-       /*  HIMR - turn all on */
-       rtl8723au_write32(Adapter, REG_HIMR, value32);
-}
-
-static void _InitQueueReservedPage(struct rtw_adapter *Adapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(Adapter);
-       struct registry_priv *pregistrypriv = &Adapter->registrypriv;
-       u32 numHQ = 0;
-       u32 numLQ = 0;
-       u32 numNQ = 0;
-       u32 numPubQ;
-       u32 value32;
-       u8 value8;
-       bool bWiFiConfig = pregistrypriv->wifi_spec;
-
-       /* RT_ASSERT((outEPNum>= 2), ("for WMM , number of out-ep "
-          "must more than or equal to 2!\n")); */
-
-       numPubQ = bWiFiConfig ? WMM_NORMAL_PAGE_NUM_PUBQ : NORMAL_PAGE_NUM_PUBQ;
-
-       if (pHalData->OutEpQueueSel & TX_SELE_HQ) {
-               numHQ = bWiFiConfig ?
-                       WMM_NORMAL_PAGE_NUM_HPQ : NORMAL_PAGE_NUM_HPQ;
-       }
-
-       if (pHalData->OutEpQueueSel & TX_SELE_LQ) {
-               numLQ = bWiFiConfig ?
-                       WMM_NORMAL_PAGE_NUM_LPQ : NORMAL_PAGE_NUM_LPQ;
-       }
-       /*  NOTE: This step shall be proceed before
-           writting REG_RQPN. */
-       if (pHalData->OutEpQueueSel & TX_SELE_NQ) {
-               numNQ = bWiFiConfig ?
-                       WMM_NORMAL_PAGE_NUM_NPQ : NORMAL_PAGE_NUM_NPQ;
-       }
-       value8 = (u8)_NPQ(numNQ);
-       rtl8723au_write8(Adapter, REG_RQPN_NPQ, value8);
-
-       /*  TX DMA */
-       value32 = _HPQ(numHQ) | _LPQ(numLQ) | _PUBQ(numPubQ) | LD_RQPN;
-       rtl8723au_write32(Adapter, REG_RQPN, value32);
-}
-
-static void _InitTxBufferBoundary(struct rtw_adapter *Adapter)
-{
-       struct registry_priv *pregistrypriv = &Adapter->registrypriv;
-
-       u8 txpktbuf_bndy;
-
-       if (!pregistrypriv->wifi_spec)
-               txpktbuf_bndy = TX_PAGE_BOUNDARY;
-       else /* for WMM */
-               txpktbuf_bndy = WMM_NORMAL_TX_PAGE_BOUNDARY;
-
-       rtl8723au_write8(Adapter, REG_TXPKTBUF_BCNQ_BDNY, txpktbuf_bndy);
-       rtl8723au_write8(Adapter, REG_TXPKTBUF_MGQ_BDNY, txpktbuf_bndy);
-       rtl8723au_write8(Adapter, REG_TXPKTBUF_WMAC_LBK_BF_HD, txpktbuf_bndy);
-       rtl8723au_write8(Adapter, REG_TRXFF_BNDY, txpktbuf_bndy);
-       rtl8723au_write8(Adapter, REG_TDECTRL+1, txpktbuf_bndy);
-}
-
-static void _InitPageBoundary(struct rtw_adapter *Adapter)
-{
-       /*  RX Page Boundary */
-       /* srand(static_cast<unsigned int>(time(NULL))); */
-       u16 rxff_bndy = 0x27FF;/* rand() % 1) ? 0x27FF : 0x23FF; */
-
-       rtl8723au_write16(Adapter, (REG_TRXFF_BNDY + 2), rxff_bndy);
-
-       /*  TODO: ?? shall we set tx boundary? */
-}
-
-static void
-_InitNormalChipRegPriority(struct rtw_adapter *Adapter, u16 beQ, u16 bkQ,
-                          u16 viQ, u16 voQ, u16 mgtQ, u16 hiQ)
-{
-       u16 value16 = rtl8723au_read16(Adapter, REG_TRXDMA_CTRL) & 0x7;
-
-       value16 |= _TXDMA_BEQ_MAP(beQ) | _TXDMA_BKQ_MAP(bkQ) |
-               _TXDMA_VIQ_MAP(viQ) | _TXDMA_VOQ_MAP(voQ) |
-               _TXDMA_MGQ_MAP(mgtQ) | _TXDMA_HIQ_MAP(hiQ);
-
-       rtl8723au_write16(Adapter, REG_TRXDMA_CTRL, value16);
-}
-
-static void _InitNormalChipOneOutEpPriority(struct rtw_adapter *Adapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(Adapter);
-       u16 value = 0;
-
-       switch (pHalData->OutEpQueueSel) {
-       case TX_SELE_HQ:
-               value = QUEUE_HIGH;
-               break;
-       case TX_SELE_LQ:
-               value = QUEUE_LOW;
-               break;
-       case TX_SELE_NQ:
-               value = QUEUE_NORMAL;
-               break;
-       default:
-               /* RT_ASSERT(false, ("Shall not reach here!\n")); */
-               break;
-       }
-
-       _InitNormalChipRegPriority(Adapter, value, value, value,
-                                  value, value, value);
-}
-
-static void _InitNormalChipTwoOutEpPriority(struct rtw_adapter *Adapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(Adapter);
-       struct registry_priv *pregistrypriv = &Adapter->registrypriv;
-       u16 beQ, bkQ, viQ, voQ, mgtQ, hiQ;
-       u16 valueHi = 0;
-       u16 valueLow = 0;
-
-       switch (pHalData->OutEpQueueSel) {
-       case (TX_SELE_HQ | TX_SELE_LQ):
-               valueHi = QUEUE_HIGH;
-               valueLow = QUEUE_LOW;
-               break;
-       case (TX_SELE_NQ | TX_SELE_LQ):
-               valueHi = QUEUE_NORMAL;
-               valueLow = QUEUE_LOW;
-               break;
-       case (TX_SELE_HQ | TX_SELE_NQ):
-               valueHi = QUEUE_HIGH;
-               valueLow = QUEUE_NORMAL;
-               break;
-       default:
-               /* RT_ASSERT(false, ("Shall not reach here!\n")); */
-               break;
-       }
-
-       if (!pregistrypriv->wifi_spec) {
-               beQ = valueLow;
-               bkQ = valueLow;
-               viQ = valueHi;
-               voQ = valueHi;
-               mgtQ = valueHi;
-               hiQ = valueHi;
-       } else {/* for WMM , CONFIG_OUT_EP_WIFI_MODE */
-               beQ = valueLow;
-               bkQ = valueHi;
-               viQ = valueHi;
-               voQ = valueLow;
-               mgtQ = valueHi;
-               hiQ = valueHi;
-       }
-
-       _InitNormalChipRegPriority(Adapter, beQ, bkQ, viQ, voQ, mgtQ, hiQ);
-}
-
-static void _InitNormalChipThreeOutEpPriority(struct rtw_adapter *Adapter)
-{
-       struct registry_priv *pregistrypriv = &Adapter->registrypriv;
-       u16 beQ, bkQ, viQ, voQ, mgtQ, hiQ;
-
-       if (!pregistrypriv->wifi_spec) {/*  typical setting */
-               beQ = QUEUE_LOW;
-               bkQ = QUEUE_LOW;
-               viQ = QUEUE_NORMAL;
-               voQ = QUEUE_HIGH;
-               mgtQ = QUEUE_HIGH;
-               hiQ = QUEUE_HIGH;
-       } else {/*  for WMM */
-               beQ = QUEUE_LOW;
-               bkQ = QUEUE_NORMAL;
-               viQ = QUEUE_NORMAL;
-               voQ = QUEUE_HIGH;
-               mgtQ = QUEUE_HIGH;
-               hiQ = QUEUE_HIGH;
-       }
-       _InitNormalChipRegPriority(Adapter, beQ, bkQ, viQ, voQ, mgtQ, hiQ);
-}
-
-static void _InitQueuePriority(struct rtw_adapter *Adapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(Adapter);
-
-       switch (pHalData->OutEpNumber) {
-       case 1:
-               _InitNormalChipOneOutEpPriority(Adapter);
-               break;
-       case 2:
-               _InitNormalChipTwoOutEpPriority(Adapter);
-               break;
-       case 3:
-               _InitNormalChipThreeOutEpPriority(Adapter);
-               break;
-       default:
-               /* RT_ASSERT(false, ("Shall not reach here!\n")); */
-               break;
-       }
-}
-
-static void _InitTransferPageSize(struct rtw_adapter *Adapter)
-{
-       /*  Tx page size is always 128. */
-
-       u8 value8;
-       value8 = _PSRX(PBP_128) | _PSTX(PBP_128);
-       rtl8723au_write8(Adapter, REG_PBP, value8);
-}
-
-static void _InitDriverInfoSize(struct rtw_adapter *Adapter, u8 drvInfoSize)
-{
-       rtl8723au_write8(Adapter, REG_RX_DRVINFO_SZ, drvInfoSize);
-}
-
-static void _InitWMACSetting(struct rtw_adapter *Adapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(Adapter);
-
-       /*  don't turn on AAP, it will allow all packets to driver */
-       pHalData->ReceiveConfig = RCR_APM | RCR_AM | RCR_AB | RCR_CBSSID_DATA |
-                                 RCR_CBSSID_BCN | RCR_APP_ICV | RCR_AMF |
-                                 RCR_HTC_LOC_CTRL | RCR_APP_MIC |
-                                 RCR_APP_PHYSTS;
-
-       /*  some REG_RCR will be modified later by
-           phy_ConfigMACWithHeaderFile() */
-       rtl8723au_write32(Adapter, REG_RCR, pHalData->ReceiveConfig);
-
-       /*  Accept all multicast address */
-       rtl8723au_write32(Adapter, REG_MAR, 0xFFFFFFFF);
-       rtl8723au_write32(Adapter, REG_MAR + 4, 0xFFFFFFFF);
-
-       /*  Accept all data frames */
-       /* value16 = 0xFFFF; */
-       /* rtl8723au_write16(Adapter, REG_RXFLTMAP2, value16); */
-
-       /*  2010.09.08 hpfan */
-       /*  Since ADF is removed from RCR, ps-poll will not be indicate
-           to driver, */
-       /*  RxFilterMap should mask ps-poll to guarantee AP mode can
-           rx ps-poll. */
-       /* value16 = 0x400; */
-       /* rtl8723au_write16(Adapter, REG_RXFLTMAP1, value16); */
-
-       /*  Accept all management frames */
-       /* value16 = 0xFFFF; */
-       /* rtl8723au_write16(Adapter, REG_RXFLTMAP0, value16); */
-
-       /* enable RX_SHIFT bits */
-       /* rtl8723au_write8(Adapter, REG_TRXDMA_CTRL, rtl8723au_read8(Adapter,
-          REG_TRXDMA_CTRL)|BIT(1)); */
-}
-
-static void _InitAdaptiveCtrl(struct rtw_adapter *Adapter)
-{
-       u16 value16;
-       u32 value32;
-
-       /*  Response Rate Set */
-       value32 = rtl8723au_read32(Adapter, REG_RRSR);
-       value32 &= ~RATE_BITMAP_ALL;
-       value32 |= RATE_RRSR_CCK_ONLY_1M;
-       rtl8723au_write32(Adapter, REG_RRSR, value32);
-
-       /*  CF-END Threshold */
-       /* m_spIoBase->rtl8723au_write8(REG_CFEND_TH, 0x1); */
-
-       /*  SIFS (used in NAV) */
-       value16 = _SPEC_SIFS_CCK(0x10) | _SPEC_SIFS_OFDM(0x10);
-       rtl8723au_write16(Adapter, REG_SPEC_SIFS, value16);
-
-       /*  Retry Limit */
-       value16 = _LRL(0x30) | _SRL(0x30);
-       rtl8723au_write16(Adapter, REG_RL, value16);
-}
-
-static void _InitRateFallback(struct rtw_adapter *Adapter)
-{
-       /*  Set Data Auto Rate Fallback Retry Count register. */
-       rtl8723au_write32(Adapter, REG_DARFRC, 0x00000000);
-       rtl8723au_write32(Adapter, REG_DARFRC+4, 0x10080404);
-       rtl8723au_write32(Adapter, REG_RARFRC, 0x04030201);
-       rtl8723au_write32(Adapter, REG_RARFRC+4, 0x08070605);
-}
-
-static void _InitEDCA(struct rtw_adapter *Adapter)
-{
-       /*  Set Spec SIFS (used in NAV) */
-       rtl8723au_write16(Adapter, REG_SPEC_SIFS, 0x100a);
-       rtl8723au_write16(Adapter, REG_MAC_SPEC_SIFS, 0x100a);
-
-       /*  Set SIFS for CCK */
-       rtl8723au_write16(Adapter, REG_SIFS_CTX, 0x100a);
-
-       /*  Set SIFS for OFDM */
-       rtl8723au_write16(Adapter, REG_SIFS_TRX, 0x100a);
-
-       /*  TXOP */
-       rtl8723au_write32(Adapter, REG_EDCA_BE_PARAM, 0x005EA42B);
-       rtl8723au_write32(Adapter, REG_EDCA_BK_PARAM, 0x0000A44F);
-       rtl8723au_write32(Adapter, REG_EDCA_VI_PARAM, 0x005EA324);
-       rtl8723au_write32(Adapter, REG_EDCA_VO_PARAM, 0x002FA226);
-}
-
-static void _InitRDGSetting(struct rtw_adapter *Adapter)
-{
-       rtl8723au_write8(Adapter, REG_RD_CTRL, 0xFF);
-       rtl8723au_write16(Adapter, REG_RD_NAV_NXT, 0x200);
-       rtl8723au_write8(Adapter, REG_RD_RESP_PKT_TH, 0x05);
-}
-
-static void _InitRetryFunction(struct rtw_adapter *Adapter)
-{
-       u8 value8;
-
-       value8 = rtl8723au_read8(Adapter, REG_FWHW_TXQ_CTRL);
-       value8 |= EN_AMPDU_RTY_NEW;
-       rtl8723au_write8(Adapter, REG_FWHW_TXQ_CTRL, value8);
-
-       /*  Set ACK timeout */
-       rtl8723au_write8(Adapter, REG_ACKTO, 0x40);
-}
-
-static void _InitRFType(struct rtw_adapter *Adapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(Adapter);
-
-       pHalData->rf_type = RF_1T1R;
-}
-
-/*  Set CCK and OFDM Block "ON" */
-static void _BBTurnOnBlock(struct rtw_adapter *Adapter)
-{
-       PHY_SetBBReg(Adapter, rFPGA0_RFMOD, bCCKEn, 0x1);
-       PHY_SetBBReg(Adapter, rFPGA0_RFMOD, bOFDMEn, 0x1);
-}
-
-#define MgntActSet_RF_State(...)
-static void _RfPowerSave(struct rtw_adapter *padapter)
-{
-}
-
-enum {
-       Antenna_Lfet = 1,
-       Antenna_Right = 2,
-};
-
-enum rt_rf_power_state RfOnOffDetect23a(struct rtw_adapter *pAdapter)
-{
-       /* struct hal_data_8723a *pHalData = GET_HAL_DATA(pAdapter); */
-       u8 val8;
-       enum rt_rf_power_state rfpowerstate = rf_off;
-
-       rtl8723au_write8(pAdapter, REG_MAC_PINMUX_CFG,
-                        rtl8723au_read8(pAdapter,
-                                        REG_MAC_PINMUX_CFG) & ~BIT(3));
-       val8 = rtl8723au_read8(pAdapter, REG_GPIO_IO_SEL);
-       DBG_8723A("GPIO_IN =%02x\n", val8);
-       rfpowerstate = (val8 & BIT(3)) ? rf_on : rf_off;
-
-       return rfpowerstate;
-}
-
-int rtl8723au_hal_init(struct rtw_adapter *Adapter)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(Adapter);
-       struct pwrctrl_priv *pwrctrlpriv = &Adapter->pwrctrlpriv;
-       struct registry_priv *pregistrypriv = &Adapter->registrypriv;
-       u8 val8 = 0;
-       u32 boundary;
-       int status = _SUCCESS;
-       bool mac_on;
-
-       unsigned long init_start_time = jiffies;
-
-       Adapter->hw_init_completed = false;
-
-       if (Adapter->pwrctrlpriv.bkeepfwalive) {
-               phy_SsPwrSwitch92CU(Adapter, rf_on);
-
-               if (pHalData->bIQKInitialized) {
-                       rtl8723a_phy_iq_calibrate(Adapter, true);
-               } else {
-                       rtl8723a_phy_iq_calibrate(Adapter, false);
-                       pHalData->bIQKInitialized = true;
-               }
-               rtl8723a_odm_check_tx_power_tracking(Adapter);
-               rtl8723a_phy_lc_calibrate(Adapter);
-
-               goto exit;
-       }
-
-       /*  Check if MAC has already power on. by tynli. 2011.05.27. */
-       val8 = rtl8723au_read8(Adapter, REG_CR);
-       RT_TRACE(_module_hci_hal_init_c_, _drv_info_,
-                "%s: REG_CR 0x100 = 0x%02x\n", __func__, val8);
-       /* Fix 92DU-VC S3 hang with the reason is that secondary mac is not
-          initialized. */
-       /* 0x100 value of first mac is 0xEA while 0x100 value of secondary
-          is 0x00 */
-       if (val8 == 0xEA) {
-               mac_on = false;
-       } else {
-               mac_on = true;
-               RT_TRACE(_module_hci_hal_init_c_, _drv_info_,
-                        "%s: MAC has already power on\n", __func__);
-       }
-
-       status = _InitPowerOn(Adapter);
-       if (status == _FAIL) {
-               RT_TRACE(_module_hci_hal_init_c_, _drv_err_,
-                        "Failed to init power on!\n");
-               goto exit;
-       }
-
-       if (!pregistrypriv->wifi_spec) {
-               boundary = TX_PAGE_BOUNDARY;
-       } else {
-               /*  for WMM */
-               boundary = WMM_NORMAL_TX_PAGE_BOUNDARY;
-       }
-
-       if (!mac_on) {
-               status =  InitLLTTable23a(Adapter, boundary);
-               if (status == _FAIL) {
-                       RT_TRACE(_module_hci_hal_init_c_, _drv_err_,
-                                "Failed to init LLT table\n");
-                       goto exit;
-               }
-       }
-
-       if (pHalData->bRDGEnable)
-               _InitRDGSetting(Adapter);
-
-       status = rtl8723a_FirmwareDownload(Adapter);
-       if (status != _SUCCESS) {
-               Adapter->bFWReady = false;
-               DBG_8723A("fw download fail!\n");
-               goto exit;
-       } else {
-               Adapter->bFWReady = true;
-               DBG_8723A("fw download ok!\n");
-       }
-
-       rtl8723a_InitializeFirmwareVars(Adapter);
-
-       if (pwrctrlpriv->reg_rfoff == true) {
-               pwrctrlpriv->rf_pwrstate = rf_off;
-       }
-
-       /*  2010/08/09 MH We need to check if we need to turnon or off RF after detecting */
-       /*  HW GPIO pin. Before PHY_RFConfig8192C. */
-       /* HalDetectPwrDownMode(Adapter); */
-       /*  2010/08/26 MH If Efuse does not support sective suspend then disable the function. */
-       /* HalDetectSelectiveSuspendMode(Adapter); */
-
-       /*  Set RF type for BB/RF configuration */
-       _InitRFType(Adapter);/* _ReadRFType() */
-
-       /*  Save target channel */
-       /*  <Roger_Notes> Current Channel will be updated again later. */
-       pHalData->CurrentChannel = 6;/* default set to 6 */
-
-       status = PHY_MACConfig8723A(Adapter);
-       if (status == _FAIL) {
-               DBG_8723A("PHY_MACConfig8723A fault !!\n");
-               goto exit;
-       }
-
-       /*  */
-       /* d. Initialize BB related configurations. */
-       /*  */
-       status = PHY_BBConfig8723A(Adapter);
-       if (status == _FAIL) {
-               DBG_8723A("PHY_BBConfig8723A fault !!\n");
-               goto exit;
-       }
-
-       /*  Add for tx power by rate fine tune. We need to call the function after BB config. */
-       /*  Because the tx power by rate table is inited in BB config. */
-
-       status = PHY_RF6052_Config8723A(Adapter);
-       if (status == _FAIL) {
-               DBG_8723A("PHY_RF6052_Config8723A failed!!\n");
-               goto exit;
-       }
-
-       /* reducing 80M spur */
-       rtl8723au_write32(Adapter, REG_AFE_XTAL_CTRL, 0x0381808d);
-       rtl8723au_write32(Adapter, REG_AFE_PLL_CTRL, 0xf0ffff83);
-       rtl8723au_write32(Adapter, REG_AFE_PLL_CTRL, 0xf0ffff82);
-       rtl8723au_write32(Adapter, REG_AFE_PLL_CTRL, 0xf0ffff83);
-
-       /* RFSW Control */
-       /* 0x804[14]= 0 */
-       rtl8723au_write32(Adapter, rFPGA0_TxInfo, 0x00000003);
-       /* 0x870[6:5]= b'11 */
-       rtl8723au_write32(Adapter, rFPGA0_XAB_RFInterfaceSW, 0x07000760);
-       /* 0x860[6:5]= b'00 */
-       rtl8723au_write32(Adapter, rFPGA0_XA_RFInterfaceOE, 0x66F60210);
-
-       RT_TRACE(_module_hci_hal_init_c_, _drv_info_,
-                "%s: 0x870 = value 0x%x\n", __func__,
-                rtl8723au_read32(Adapter, 0x870));
-
-       /*  */
-       /*  Joseph Note: Keep RfRegChnlVal for later use. */
-       /*  */
-       pHalData->RfRegChnlVal[0] = PHY_QueryRFReg(Adapter, RF_PATH_A,
-                                                  RF_CHNLBW, bRFRegOffsetMask);
-       pHalData->RfRegChnlVal[1] = PHY_QueryRFReg(Adapter, RF_PATH_B,
-                                                  RF_CHNLBW, bRFRegOffsetMask);
-
-       if (!mac_on) {
-               _InitQueueReservedPage(Adapter);
-               _InitTxBufferBoundary(Adapter);
-       }
-       _InitQueuePriority(Adapter);
-       _InitPageBoundary(Adapter);
-       _InitTransferPageSize(Adapter);
-
-       /*  Get Rx PHY status in order to report RSSI and others. */
-       _InitDriverInfoSize(Adapter, DRVINFO_SZ);
-
-       _InitInterrupt(Adapter);
-       hw_var_set_macaddr(Adapter, Adapter->eeprompriv.mac_addr);
-       rtl8723a_set_media_status(Adapter, MSR_INFRA);
-       _InitWMACSetting(Adapter);
-       _InitAdaptiveCtrl(Adapter);
-       _InitEDCA(Adapter);
-       _InitRateFallback(Adapter);
-       _InitRetryFunction(Adapter);
-       rtl8723a_InitBeaconParameters(Adapter);
-
-       _BBTurnOnBlock(Adapter);
-       /* NicIFSetMacAddress(padapter, padapter->PermanentAddress); */
-
-       rtl8723a_cam_invalidate_all(Adapter);
-
-       /*  2010/12/17 MH We need to set TX power according to EFUSE content at first. */
-       PHY_SetTxPowerLevel8723A(Adapter, pHalData->CurrentChannel);
-
-       rtl8723a_InitAntenna_Selection(Adapter);
-
-       /*  HW SEQ CTRL */
-       /* set 0x0 to 0xFF by tynli. Default enable HW SEQ NUM. */
-       rtl8723au_write8(Adapter, REG_HWSEQ_CTRL, 0xFF);
-
-       /*  */
-       /*  Disable BAR, suggested by Scott */
-       /*  2010.04.09 add by hpfan */
-       /*  */
-       rtl8723au_write32(Adapter, REG_BAR_MODE_CTRL, 0x0201ffff);
-
-       if (pregistrypriv->wifi_spec)
-               rtl8723au_write16(Adapter, REG_FAST_EDCA_CTRL, 0);
-
-       /*  Move by Neo for USB SS from above setp */
-       _RfPowerSave(Adapter);
-
-       /*  2010/08/26 MH Merge from 8192CE. */
-       /* sherry masked that it has been done in _RfPowerSave */
-       /* 20110927 */
-       /* recovery for 8192cu and 9723Au 20111017 */
-       if (pwrctrlpriv->rf_pwrstate == rf_on) {
-               if (pHalData->bIQKInitialized) {
-                       rtl8723a_phy_iq_calibrate(Adapter, true);
-               } else {
-                       rtl8723a_phy_iq_calibrate(Adapter, false);
-                       pHalData->bIQKInitialized = true;
-               }
-
-               rtl8723a_odm_check_tx_power_tracking(Adapter);
-
-               rtl8723a_phy_lc_calibrate(Adapter);
-
-               rtl8723a_dual_antenna_detection(Adapter);
-       }
-
-       /* fixed USB interface interference issue */
-       rtl8723au_write8(Adapter, 0xfe40, 0xe0);
-       rtl8723au_write8(Adapter, 0xfe41, 0x8d);
-       rtl8723au_write8(Adapter, 0xfe42, 0x80);
-       rtl8723au_write32(Adapter, 0x20c, 0xfd0320);
-       /* Solve too many protocol error on USB bus */
-       if (!IS_81xxC_VENDOR_UMC_A_CUT(pHalData->VersionID)) {
-               /*  0xE6 = 0x94 */
-               rtl8723au_write8(Adapter, 0xFE40, 0xE6);
-               rtl8723au_write8(Adapter, 0xFE41, 0x94);
-               rtl8723au_write8(Adapter, 0xFE42, 0x80);
-
-               /*  0xE0 = 0x19 */
-               rtl8723au_write8(Adapter, 0xFE40, 0xE0);
-               rtl8723au_write8(Adapter, 0xFE41, 0x19);
-               rtl8723au_write8(Adapter, 0xFE42, 0x80);
-
-               /*  0xE5 = 0x91 */
-               rtl8723au_write8(Adapter, 0xFE40, 0xE5);
-               rtl8723au_write8(Adapter, 0xFE41, 0x91);
-               rtl8723au_write8(Adapter, 0xFE42, 0x80);
-
-               /*  0xE2 = 0x81 */
-               rtl8723au_write8(Adapter, 0xFE40, 0xE2);
-               rtl8723au_write8(Adapter, 0xFE41, 0x81);
-               rtl8723au_write8(Adapter, 0xFE42, 0x80);
-
-       }
-
-/*     _InitPABias(Adapter); */
-
-       /*  Init BT hw config. */
-       rtl8723a_BT_init_hwconfig(Adapter);
-
-       rtl8723a_InitHalDm(Adapter);
-
-       val8 = DIV_ROUND_UP(WiFiNavUpperUs, HAL_8723A_NAV_UPPER_UNIT);
-       rtl8723au_write8(Adapter, REG_NAV_UPPER, val8);
-
-       /*  2011/03/09 MH debug only, UMC-B cut pass 2500 S5 test, but we need to fin root cause. */
-       if (((rtl8723au_read32(Adapter, rFPGA0_RFMOD) & 0xFF000000) !=
-            0x83000000)) {
-               PHY_SetBBReg(Adapter, rFPGA0_RFMOD, BIT(24), 1);
-               RT_TRACE(_module_hci_hal_init_c_, _drv_err_,
-                        "%s: IQK fail recover\n", __func__);
-       }
-
-       /* ack for xmit mgmt frames. */
-       rtl8723au_write32(Adapter, REG_FWHW_TXQ_CTRL,
-                         rtl8723au_read32(Adapter, REG_FWHW_TXQ_CTRL)|BIT(12));
-
-exit:
-       if (status == _SUCCESS) {
-               Adapter->hw_init_completed = true;
-
-               if (Adapter->registrypriv.notch_filter == 1)
-                       rtl8723a_notch_filter(Adapter, 1);
-       }
-
-       DBG_8723A("%s in %dms\n", __func__,
-                 jiffies_to_msecs(jiffies - init_start_time));
-       return status;
-}
-
-static void phy_SsPwrSwitch92CU(struct rtw_adapter *Adapter,
-                               enum rt_rf_power_state eRFPowerState)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(Adapter);
-       u8 sps0;
-
-       sps0 = rtl8723au_read8(Adapter, REG_SPS0_CTRL);
-
-       switch (eRFPowerState) {
-       case rf_on:
-               /*  1. Enable MAC Clock. Can not be enabled now. */
-               /* WriteXBYTE(REG_SYS_CLKR+1,
-                  ReadXBYTE(REG_SYS_CLKR+1) | BIT(3)); */
-
-               /*  2. Force PWM, Enable SPS18_LDO_Marco_Block */
-               rtl8723au_write8(Adapter, REG_SPS0_CTRL,
-                                sps0 | BIT(0) | BIT(3));
-
-               /*  3. restore BB, AFE control register. */
-               /* RF */
-               if (pHalData->rf_type ==  RF_2T2R)
-                       PHY_SetBBReg(Adapter, rFPGA0_XAB_RFParameter,
-                                    0x380038, 1);
-               else
-                       PHY_SetBBReg(Adapter, rFPGA0_XAB_RFParameter,
-                                    0x38, 1);
-               PHY_SetBBReg(Adapter, rOFDM0_TRxPathEnable, 0xf0, 1);
-               PHY_SetBBReg(Adapter, rFPGA0_RFMOD, BIT(1), 0);
-
-               /* AFE */
-               if (pHalData->rf_type ==  RF_2T2R)
-                       rtl8723au_write32(Adapter, rRx_Wait_CCA, 0x63DB25A0);
-               else if (pHalData->rf_type ==  RF_1T1R)
-                       rtl8723au_write32(Adapter, rRx_Wait_CCA, 0x631B25A0);
-
-               /*  4. issue 3-wire command that RF set to Rx idle
-                   mode. This is used to re-write the RX idle mode. */
-               /*  We can only prvide a usual value instead and then
-                   HW will modify the value by itself. */
-               PHY_SetRFReg(Adapter, RF_PATH_A, RF_AC,
-                            bRFRegOffsetMask, 0x32D95);
-               if (pHalData->rf_type ==  RF_2T2R) {
-                       PHY_SetRFReg(Adapter, RF_PATH_B, RF_AC,
-                                    bRFRegOffsetMask, 0x32D95);
-               }
-               break;
-       case rf_sleep:
-       case rf_off:
-               if (IS_81xxC_VENDOR_UMC_B_CUT(pHalData->VersionID))
-                       sps0 &= ~BIT(0);
-               else
-                       sps0 &= ~(BIT(0) | BIT(3));
-
-               RT_TRACE(_module_hal_init_c_, _drv_err_, "SS LVL1\n");
-               /*  Disable RF and BB only for SelectSuspend. */
-
-               /*  1. Set BB/RF to shutdown. */
-               /*      (1) Reg878[5:3]= 0      RF rx_code for
-                                               preamble power saving */
-               /*      (2)Reg878[21:19]= 0     Turn off RF-B */
-               /*      (3) RegC04[7:4]= 0      Turn off all paths
-                                               for packet detection */
-               /*      (4) Reg800[1] = 1       enable preamble power saving */
-               Adapter->pwrctrlpriv.PS_BBRegBackup[PSBBREG_RF0] =
-                       rtl8723au_read32(Adapter, rFPGA0_XAB_RFParameter);
-               Adapter->pwrctrlpriv.PS_BBRegBackup[PSBBREG_RF1] =
-                       rtl8723au_read32(Adapter, rOFDM0_TRxPathEnable);
-               Adapter->pwrctrlpriv.PS_BBRegBackup[PSBBREG_RF2] =
-                       rtl8723au_read32(Adapter, rFPGA0_RFMOD);
-               if (pHalData->rf_type ==  RF_2T2R)
-                       PHY_SetBBReg(Adapter, rFPGA0_XAB_RFParameter,
-                                    0x380038, 0);
-               else if (pHalData->rf_type ==  RF_1T1R)
-                       PHY_SetBBReg(Adapter, rFPGA0_XAB_RFParameter, 0x38, 0);
-               PHY_SetBBReg(Adapter, rOFDM0_TRxPathEnable, 0xf0, 0);
-               PHY_SetBBReg(Adapter, rFPGA0_RFMOD, BIT(1), 1);
-
-               /*  2 .AFE control register to power down. bit[30:22] */
-               Adapter->pwrctrlpriv.PS_BBRegBackup[PSBBREG_AFE0] =
-                       rtl8723au_read32(Adapter, rRx_Wait_CCA);
-               if (pHalData->rf_type ==  RF_2T2R)
-                       rtl8723au_write32(Adapter, rRx_Wait_CCA, 0x00DB25A0);
-               else if (pHalData->rf_type ==  RF_1T1R)
-                       rtl8723au_write32(Adapter, rRx_Wait_CCA, 0x001B25A0);
-
-               /*  3. issue 3-wire command that RF set to power down.*/
-               PHY_SetRFReg(Adapter, RF_PATH_A, RF_AC, bRFRegOffsetMask, 0);
-               if (pHalData->rf_type ==  RF_2T2R)
-                       PHY_SetRFReg(Adapter, RF_PATH_B, RF_AC,
-                                    bRFRegOffsetMask, 0);
-
-               /*  4. Force PFM , disable SPS18_LDO_Marco_Block */
-               rtl8723au_write8(Adapter, REG_SPS0_CTRL, sps0);
-               break;
-       default:
-               break;
-       }
-}
-
-static void CardDisableRTL8723U(struct rtw_adapter *Adapter)
-{
-       u8              u1bTmp;
-
-       DBG_8723A("CardDisableRTL8723U\n");
-       /*  USB-MF Card Disable Flow */
-       /*  1. Run LPS WL RFOFF flow */
-       HalPwrSeqCmdParsing23a(Adapter, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK,
-                           PWR_INTF_USB_MSK, rtl8723AU_enter_lps_flow);
-
-       /*  2. 0x1F[7:0] = 0            turn off RF */
-       rtl8723au_write8(Adapter, REG_RF_CTRL, 0x00);
-
-       /*      ==== Reset digital sequence   ====== */
-       if ((rtl8723au_read8(Adapter, REG_MCUFWDL) & BIT(7)) &&
-           Adapter->bFWReady) /* 8051 RAM code */
-               rtl8723a_FirmwareSelfReset(Adapter);
-
-       /*  Reset MCU. Suggested by Filen. 2011.01.26. by tynli. */
-       u1bTmp = rtl8723au_read8(Adapter, REG_SYS_FUNC_EN+1);
-       rtl8723au_write8(Adapter, REG_SYS_FUNC_EN+1, u1bTmp & ~BIT(2));
-
-       /*  g.  MCUFWDL 0x80[1:0]= 0            reset MCU ready status */
-       rtl8723au_write8(Adapter, REG_MCUFWDL, 0x00);
-
-       /*      ==== Reset digital sequence end ====== */
-       /*  Card disable power action flow */
-       HalPwrSeqCmdParsing23a(Adapter, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK,
-                              PWR_INTF_USB_MSK,
-                              rtl8723AU_card_disable_flow);
-
-       /*  Reset MCU IO Wrapper, added by Roger, 2011.08.30. */
-       u1bTmp = rtl8723au_read8(Adapter, REG_RSV_CTRL + 1);
-       rtl8723au_write8(Adapter, REG_RSV_CTRL+1, u1bTmp & ~BIT(0));
-       u1bTmp = rtl8723au_read8(Adapter, REG_RSV_CTRL + 1);
-       rtl8723au_write8(Adapter, REG_RSV_CTRL+1, u1bTmp | BIT(0));
-
-       /*  7. RSV_CTRL 0x1C[7:0] = 0x0E  lock ISO/CLK/Power control register */
-       rtl8723au_write8(Adapter, REG_RSV_CTRL, 0x0e);
-}
-
-int rtl8723au_hal_deinit(struct rtw_adapter *padapter)
-{
-       DBG_8723A("==> %s\n", __func__);
-
-#ifdef CONFIG_8723AU_BT_COEXIST
-       BT_HaltProcess(padapter);
-#endif
-       /*  2011/02/18 To Fix RU LNA  power leakage problem. We need to
-           execute below below in Adapter init and halt sequence.
-           According to EEchou's opinion, we can enable the ability for all */
-       /*  IC. Accord to johnny's opinion, only RU need the support. */
-       CardDisableRTL8723U(padapter);
-
-       padapter->hw_init_completed = false;
-
-       return _SUCCESS;
-}
-
-int rtl8723au_inirp_init(struct rtw_adapter *Adapter)
-{
-       u8 i;
-       struct recv_buf *precvbuf;
-       int status;
-       struct recv_priv *precvpriv = &Adapter->recvpriv;
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(Adapter);
-
-       status = _SUCCESS;
-
-       RT_TRACE(_module_hci_hal_init_c_, _drv_info_, "===> usb_inirp_init\n");
-
-       /* issue Rx irp to receive data */
-       precvbuf = (struct recv_buf *)precvpriv->precv_buf;
-       for (i = 0; i < NR_RECVBUFF; i++) {
-               if (rtl8723au_read_port(Adapter, 0, precvbuf) == _FAIL) {
-                       RT_TRACE(_module_hci_hal_init_c_, _drv_err_,
-                                "usb_rx_init: usb_read_port error\n");
-                       status = _FAIL;
-                       goto exit;
-               }
-               precvbuf++;
-       }
-       if (rtl8723au_read_interrupt(Adapter) == _FAIL) {
-               RT_TRACE(_module_hci_hal_init_c_, _drv_err_,
-                        "%s: usb_read_interrupt error\n", __func__);
-               status = _FAIL;
-       }
-       pHalData->IntrMask[0] = rtl8723au_read32(Adapter, REG_USB_HIMR);
-       MSG_8723A("pHalData->IntrMask = 0x%04x\n", pHalData->IntrMask[0]);
-       pHalData->IntrMask[0] |= UHIMR_C2HCMD|UHIMR_CPWM;
-       rtl8723au_write32(Adapter, REG_USB_HIMR, pHalData->IntrMask[0]);
-exit:
-       RT_TRACE(_module_hci_hal_init_c_, _drv_info_,
-                "<=== usb_inirp_init\n");
-       return status;
-}
-
-int rtl8723au_inirp_deinit(struct rtw_adapter *Adapter)
-{
-       struct hal_data_8723a   *pHalData = GET_HAL_DATA(Adapter);
-
-       RT_TRACE(_module_hci_hal_init_c_, _drv_info_,
-                "===> usb_rx_deinit\n");
-       rtl8723au_read_port_cancel(Adapter);
-       pHalData->IntrMask[0] = rtl8723au_read32(Adapter, REG_USB_HIMR);
-       MSG_8723A("%s pHalData->IntrMask = 0x%04x\n", __func__,
-                 pHalData->IntrMask[0]);
-       pHalData->IntrMask[0] = 0x0;
-       rtl8723au_write32(Adapter, REG_USB_HIMR, pHalData->IntrMask[0]);
-       RT_TRACE(_module_hci_hal_init_c_, _drv_info_,
-                "<=== usb_rx_deinit\n");
-       return _SUCCESS;
-}
-
-static void _ReadBoardType(struct rtw_adapter *Adapter, u8 *PROMContent,
-                          bool AutoloadFail)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(Adapter);
-       u8 boardType = BOARD_USB_DONGLE;
-
-       if (AutoloadFail) {
-               if (IS_8723_SERIES(pHalData->VersionID))
-                       pHalData->rf_type = RF_1T1R;
-               else
-                       pHalData->rf_type = RF_2T2R;
-               pHalData->BoardType = boardType;
-               return;
-       }
-
-       boardType = PROMContent[EEPROM_NORMAL_BoardType];
-       boardType &= BOARD_TYPE_NORMAL_MASK;/* bit[7:5] */
-       boardType >>= 5;
-
-       pHalData->BoardType = boardType;
-       MSG_8723A("_ReadBoardType(%x)\n", pHalData->BoardType);
-
-       if (boardType == BOARD_USB_High_PA)
-               pHalData->ExternalPA = 1;
-}
-
-static void Hal_EfuseParseMACAddr_8723AU(struct rtw_adapter *padapter,
-                                        u8 *hwinfo, bool AutoLoadFail)
-{
-       u16 i;
-       u8 sMacAddr[ETH_ALEN] = {0x00, 0xE0, 0x4C, 0x87, 0x23, 0x00};
-       struct eeprom_priv *pEEPROM = GET_EEPROM_EFUSE_PRIV(padapter);
-
-       if (AutoLoadFail) {
-               for (i = 0; i < 6; i++)
-                       pEEPROM->mac_addr[i] = sMacAddr[i];
-       } else {
-               /* Read Permanent MAC address */
-               memcpy(pEEPROM->mac_addr, &hwinfo[EEPROM_MAC_ADDR_8723AU],
-                      ETH_ALEN);
-       }
-
-       RT_TRACE(_module_hci_hal_init_c_, _drv_notice_,
-                "Hal_EfuseParseMACAddr_8723AU: Permanent Address =%pM\n",
-                pEEPROM->mac_addr);
-}
-
-static void readAdapterInfo(struct rtw_adapter *padapter)
-{
-       struct eeprom_priv *pEEPROM = GET_EEPROM_EFUSE_PRIV(padapter);
-       /* struct hal_data_8723a * pHalData = GET_HAL_DATA(padapter); */
-       u8 hwinfo[HWSET_MAX_SIZE];
-
-       Hal_InitPGData(padapter, hwinfo);
-       Hal_EfuseParseIDCode(padapter, hwinfo);
-       Hal_EfuseParseEEPROMVer(padapter, hwinfo,
-                               pEEPROM->bautoload_fail_flag);
-       Hal_EfuseParseMACAddr_8723AU(padapter, hwinfo,
-                                    pEEPROM->bautoload_fail_flag);
-       Hal_EfuseParsetxpowerinfo_8723A(padapter, hwinfo,
-                                       pEEPROM->bautoload_fail_flag);
-       _ReadBoardType(padapter, hwinfo, pEEPROM->bautoload_fail_flag);
-       Hal_EfuseParseBTCoexistInfo_8723A(padapter, hwinfo,
-                                         pEEPROM->bautoload_fail_flag);
-
-       rtl8723a_EfuseParseChnlPlan(padapter, hwinfo,
-                                   pEEPROM->bautoload_fail_flag);
-       Hal_EfuseParseThermalMeter_8723A(padapter, hwinfo,
-                                        pEEPROM->bautoload_fail_flag);
-/*     _ReadRFSetting(Adapter, PROMContent, pEEPROM->bautoload_fail_flag); */
-/*     _ReadPSSetting(Adapter, PROMContent, pEEPROM->bautoload_fail_flag); */
-       Hal_EfuseParseAntennaDiversity(padapter, hwinfo,
-                                      pEEPROM->bautoload_fail_flag);
-
-       Hal_EfuseParseEEPROMVer(padapter, hwinfo, pEEPROM->bautoload_fail_flag);
-       Hal_EfuseParseCustomerID(padapter, hwinfo,
-                                pEEPROM->bautoload_fail_flag);
-       Hal_EfuseParseRateIndicationOption(padapter, hwinfo,
-                                          pEEPROM->bautoload_fail_flag);
-       Hal_EfuseParseXtal_8723A(padapter, hwinfo,
-                                pEEPROM->bautoload_fail_flag);
-
-       /* hal_CustomizedBehavior_8723U(Adapter); */
-
-/*     Adapter->bDongle = (PROMContent[EEPROM_EASY_REPLACEMENT] == 1)? 0: 1; */
-       DBG_8723A("%s(): REPLACEMENT = %x\n", __func__, padapter->bDongle);
-}
-
-static void _ReadPROMContent(struct rtw_adapter *Adapter)
-{
-       struct eeprom_priv *pEEPROM = GET_EEPROM_EFUSE_PRIV(Adapter);
-       u8 eeValue;
-
-       eeValue = rtl8723au_read8(Adapter, REG_9346CR);
-       /*  To check system boot selection. */
-       pEEPROM->EepromOrEfuse = (eeValue & BOOT_FROM_EEPROM) ? true : false;
-       pEEPROM->bautoload_fail_flag = (eeValue & EEPROM_EN) ? false : true;
-
-       DBG_8723A("Boot from %s, Autoload %s !\n",
-                 (pEEPROM->EepromOrEfuse ? "EEPROM" : "EFUSE"),
-                 (pEEPROM->bautoload_fail_flag ? "Fail" : "OK"));
-
-       readAdapterInfo(Adapter);
-}
-
-/*  */
-/*     Description: */
-/*             We should set Efuse cell selection to WiFi cell in default. */
-/*  */
-/*     Assumption: */
-/*             PASSIVE_LEVEL */
-/*  */
-/*     Added by Roger, 2010.11.23. */
-/*  */
-static void hal_EfuseCellSel(struct rtw_adapter *Adapter)
-{
-       u32 value32;
-
-       value32 = rtl8723au_read32(Adapter, EFUSE_TEST);
-       value32 = (value32 & ~EFUSE_SEL_MASK) | EFUSE_SEL(EFUSE_WIFI_SEL_0);
-       rtl8723au_write32(Adapter, EFUSE_TEST, value32);
-}
-
-void rtl8723a_read_adapter_info(struct rtw_adapter *Adapter)
-{
-       unsigned long start = jiffies;
-
-       /*  Read EEPROM size before call any EEPROM function */
-       Adapter->EepromAddressSize = GetEEPROMSize8723A(Adapter);
-
-       MSG_8723A("====> _ReadAdapterInfo8723AU\n");
-
-       hal_EfuseCellSel(Adapter);
-
-       _ReadPROMContent(Adapter);
-
-       MSG_8723A("<==== _ReadAdapterInfo8723AU in %d ms\n",
-                 jiffies_to_msecs(jiffies - start));
-}
-
-/*  */
-/*     Description: */
-/*             Query setting of specified variable. */
-/*  */
-int GetHalDefVar8192CUsb(struct rtw_adapter *Adapter,
-                        enum hal_def_variable eVariable, void *pValue)
-{
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(Adapter);
-       int bResult = _SUCCESS;
-
-       switch (eVariable) {
-       case HAL_DEF_UNDERCORATEDSMOOTHEDPWDB:
-               *((int *)pValue) = pHalData->dmpriv.UndecoratedSmoothedPWDB;
-               break;
-       case HAL_DEF_IS_SUPPORT_ANT_DIV:
-               break;
-       case HAL_DEF_CURRENT_ANTENNA:
-               break;
-       case HAL_DEF_DRVINFO_SZ:
-               *((u32 *)pValue) = DRVINFO_SZ;
-               break;
-       case HAL_DEF_MAX_RECVBUF_SZ:
-               *((u32 *)pValue) = MAX_RECVBUF_SZ;
-               break;
-       case HAL_DEF_RX_PACKET_OFFSET:
-               *((u32 *)pValue) = RXDESC_SIZE + DRVINFO_SZ;
-               break;
-       case HAL_DEF_DBG_DUMP_RXPKT:
-               *((u8 *)pValue) = pHalData->bDumpRxPkt;
-               break;
-       case HAL_DEF_DBG_DM_FUNC:
-               *((u32 *)pValue) = pHalData->odmpriv.SupportAbility;
-               break;
-       case HW_VAR_MAX_RX_AMPDU_FACTOR:
-               *((u32 *)pValue) = IEEE80211_HT_MAX_AMPDU_64K;
-               break;
-       case HW_DEF_ODM_DBG_FLAG:
-       {
-               struct dm_odm_t *pDM_Odm = &pHalData->odmpriv;
-               printk("pDM_Odm->DebugComponents = 0x%llx\n",
-                      pDM_Odm->DebugComponents);
-       }
-               break;
-       default:
-               bResult = _FAIL;
-               break;
-       }
-
-       return bResult;
-}
-
-void rtl8723a_update_ramask(struct rtw_adapter *padapter,
-                           u32 mac_id, u8 rssi_level)
-{
-       struct sta_info *psta;
-       struct FW_Sta_Info *fw_sta;
-       struct hal_data_8723a *pHalData = GET_HAL_DATA(padapter);
-       struct dm_priv *pdmpriv = &pHalData->dmpriv;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       struct wlan_bssid_ex *cur_network = &pmlmeinfo->network;
-       u8 init_rate, networkType, raid, arg;
-       u32 mask, rate_bitmap;
-       u8 shortGIrate = false;
-       int supportRateNum;
-
-       if (mac_id >= NUM_STA) /* CAM_SIZE */
-               return;
-
-       psta = pmlmeinfo->FW_sta_info[mac_id].psta;
-       if (psta == NULL)
-               return;
-
-       switch (mac_id) {
-       case 0:/*  for infra mode */
-               supportRateNum =
-                       rtw_get_rateset_len23a(cur_network->SupportedRates);
-               networkType = judge_network_type23a(padapter,
-                                                cur_network->SupportedRates,
-                                                supportRateNum) & 0xf;
-               /* pmlmeext->cur_wireless_mode = networkType; */
-               raid = networktype_to_raid23a(networkType);
-
-               mask = update_supported_rate23a(cur_network->SupportedRates,
-                                            supportRateNum);
-               mask |= (pmlmeinfo->HT_enable) ?
-                       update_MSC_rate23a(&pmlmeinfo->ht_cap) : 0;
-
-               if (support_short_GI23a(padapter, &pmlmeinfo->ht_cap))
-                       shortGIrate = true;
-               break;
-
-       case 1:/* for broadcast/multicast */
-               fw_sta = &pmlmeinfo->FW_sta_info[mac_id]; 
-               supportRateNum = rtw_get_rateset_len23a(fw_sta->SupportedRates);
-               if (pmlmeext->cur_wireless_mode & WIRELESS_11B)
-                       networkType = WIRELESS_11B;
-               else
-                       networkType = WIRELESS_11G;
-               raid = networktype_to_raid23a(networkType);
-
-               mask = update_basic_rate23a(cur_network->SupportedRates,
-                                        supportRateNum);
-               break;
-
-       default: /* for each sta in IBSS */
-               fw_sta = &pmlmeinfo->FW_sta_info[mac_id]; 
-               supportRateNum = rtw_get_rateset_len23a(fw_sta->SupportedRates);
-               networkType = judge_network_type23a(padapter,
-                                                   fw_sta->SupportedRates,
-                                                   supportRateNum) & 0xf;
-               /* pmlmeext->cur_wireless_mode = networkType; */
-               raid = networktype_to_raid23a(networkType);
-
-               mask = update_supported_rate23a(cur_network->SupportedRates,
-                                               supportRateNum);
-
-               /* todo: support HT in IBSS */
-               break;
-       }
-
-       /* mask &= 0x0fffffff; */
-       rate_bitmap = ODM_Get_Rate_Bitmap23a(pHalData, mac_id, mask,
-                                            rssi_level);
-       DBG_8723A("%s => mac_id:%d, networkType:0x%02x, "
-                 "mask:0x%08x\n\t ==> rssi_level:%d, rate_bitmap:0x%08x\n",
-                 __func__, mac_id, networkType, mask, rssi_level, rate_bitmap);
-
-       mask &= rate_bitmap;
-       mask |= ((raid << 28) & 0xf0000000);
-
-       init_rate = get_highest_rate_idx23a(mask) & 0x3f;
-
-       arg = mac_id & 0x1f;/* MACID */
-       arg |= BIT(7);
-
-       if (shortGIrate == true)
-               arg |= BIT(5);
-
-       DBG_8723A("update raid entry, mask = 0x%x, arg = 0x%x\n", mask, arg);
-
-       rtl8723a_set_raid_cmd(padapter, mask, arg);
-
-       /* set ra_id */
-       psta->raid = raid;
-       psta->init_rate = init_rate;
-
-       /* set correct initial date rate for each mac_id */
-       pdmpriv->INIDATA_RATE[mac_id] = init_rate;
-}
diff --git a/drivers/staging/rtl8723au/hal/usb_ops_linux.c b/drivers/staging/rtl8723au/hal/usb_ops_linux.c
deleted file mode 100644 (file)
index 5c81ff4..0000000
+++ /dev/null
@@ -1,690 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#define _HCI_OPS_OS_C_
-
-#include <osdep_service.h>
-#include <drv_types.h>
-#include <osdep_intf.h>
-#include <usb_ops.h>
-#include <recv_osdep.h>
-#include <rtl8723a_hal.h>
-#include <rtl8723a_recv.h>
-
-u8 rtl8723au_read8(struct rtw_adapter *padapter, u16 addr)
-{
-       struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(padapter);
-       struct usb_device *udev = pdvobjpriv->pusbdev;
-       int len;
-       u8 data;
-
-       mutex_lock(&pdvobjpriv->usb_vendor_req_mutex);
-       len = usb_control_msg(udev, usb_rcvctrlpipe(udev, 0),
-                             REALTEK_USB_VENQT_CMD_REQ, REALTEK_USB_VENQT_READ,
-                             addr, 0, &pdvobjpriv->usb_buf.val8, sizeof(data),
-                             RTW_USB_CONTROL_MSG_TIMEOUT);
-
-       data = pdvobjpriv->usb_buf.val8;
-       mutex_unlock(&pdvobjpriv->usb_vendor_req_mutex);
-
-       return data;
-}
-
-u16 rtl8723au_read16(struct rtw_adapter *padapter, u16 addr)
-{
-       struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(padapter);
-       struct usb_device *udev = pdvobjpriv->pusbdev;
-       int len;
-       u16 data;
-
-       mutex_lock(&pdvobjpriv->usb_vendor_req_mutex);
-       len = usb_control_msg(udev, usb_rcvctrlpipe(udev, 0),
-                             REALTEK_USB_VENQT_CMD_REQ, REALTEK_USB_VENQT_READ,
-                             addr, 0, &pdvobjpriv->usb_buf.val16, sizeof(data),
-                             RTW_USB_CONTROL_MSG_TIMEOUT);
-
-       data = le16_to_cpu(pdvobjpriv->usb_buf.val16);
-       mutex_unlock(&pdvobjpriv->usb_vendor_req_mutex);
-
-       return data;
-}
-
-u32 rtl8723au_read32(struct rtw_adapter *padapter, u16 addr)
-{
-       struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(padapter);
-       struct usb_device *udev = pdvobjpriv->pusbdev;
-       int len;
-       u32 data;
-
-       mutex_lock(&pdvobjpriv->usb_vendor_req_mutex);
-       len = usb_control_msg(udev, usb_rcvctrlpipe(udev, 0),
-                             REALTEK_USB_VENQT_CMD_REQ, REALTEK_USB_VENQT_READ,
-                             addr, 0, &pdvobjpriv->usb_buf.val32, sizeof(data),
-                             RTW_USB_CONTROL_MSG_TIMEOUT);
-
-       data = le32_to_cpu(pdvobjpriv->usb_buf.val32);
-       mutex_unlock(&pdvobjpriv->usb_vendor_req_mutex);
-
-       return data;
-}
-
-int rtl8723au_write8(struct rtw_adapter *padapter, u16 addr, u8 val)
-{
-       struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(padapter);
-       struct usb_device *udev = pdvobjpriv->pusbdev;
-       int ret;
-
-       mutex_lock(&pdvobjpriv->usb_vendor_req_mutex);
-       pdvobjpriv->usb_buf.val8 = val;
-
-       ret = usb_control_msg(udev, usb_sndctrlpipe(udev, 0),
-                             REALTEK_USB_VENQT_CMD_REQ,
-                             REALTEK_USB_VENQT_WRITE,
-                             addr, 0, &pdvobjpriv->usb_buf.val8, sizeof(val),
-                             RTW_USB_CONTROL_MSG_TIMEOUT);
-
-       if (ret != sizeof(val))
-               ret = _FAIL;
-       else
-               ret = _SUCCESS;
-
-       mutex_unlock(&pdvobjpriv->usb_vendor_req_mutex);
-       return ret;
-}
-
-int rtl8723au_write16(struct rtw_adapter *padapter, u16 addr, u16 val)
-{
-       struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(padapter);
-       struct usb_device *udev = pdvobjpriv->pusbdev;
-       int ret;
-
-       mutex_lock(&pdvobjpriv->usb_vendor_req_mutex);
-       pdvobjpriv->usb_buf.val16 = cpu_to_le16(val);
-
-       ret = usb_control_msg(udev, usb_sndctrlpipe(udev, 0),
-                             REALTEK_USB_VENQT_CMD_REQ,
-                             REALTEK_USB_VENQT_WRITE,
-                             addr, 0, &pdvobjpriv->usb_buf.val16, sizeof(val),
-                             RTW_USB_CONTROL_MSG_TIMEOUT);
-
-       if (ret != sizeof(val))
-               ret = _FAIL;
-       else
-               ret = _SUCCESS;
-
-       mutex_unlock(&pdvobjpriv->usb_vendor_req_mutex);
-       return ret;
-}
-
-int rtl8723au_write32(struct rtw_adapter *padapter, u16 addr, u32 val)
-{
-       struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(padapter);
-       struct usb_device *udev = pdvobjpriv->pusbdev;
-       int ret;
-
-       mutex_lock(&pdvobjpriv->usb_vendor_req_mutex);
-       pdvobjpriv->usb_buf.val32 = cpu_to_le32(val);
-
-       ret = usb_control_msg(udev, usb_sndctrlpipe(udev, 0),
-                             REALTEK_USB_VENQT_CMD_REQ,
-                             REALTEK_USB_VENQT_WRITE,
-                             addr, 0, &pdvobjpriv->usb_buf.val32, sizeof(val),
-                             RTW_USB_CONTROL_MSG_TIMEOUT);
-
-       if (ret != sizeof(val))
-               ret = _FAIL;
-       else
-               ret = _SUCCESS;
-
-       mutex_unlock(&pdvobjpriv->usb_vendor_req_mutex);
-       return ret;
-}
-
-int rtl8723au_writeN(struct rtw_adapter *padapter, u16 addr, u16 len, u8 *buf)
-{
-       struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(padapter);
-       struct usb_device *udev = pdvobjpriv->pusbdev;
-       int ret;
-
-       ret = usb_control_msg(udev, usb_sndctrlpipe(udev, 0),
-                             REALTEK_USB_VENQT_CMD_REQ,
-                             REALTEK_USB_VENQT_WRITE,
-                             addr, 0, buf, len, RTW_USB_CONTROL_MSG_TIMEOUT);
-
-       if (ret != len)
-               return _FAIL;
-       return _SUCCESS;
-}
-
-/*
- * Description:
- *     Recognize the interrupt content by reading the interrupt
- *     register or content and masking interrupt mask (IMR)
- *     if it is our NIC's interrupt. After recognizing, we may clear
- *     the all interrupts (ISR).
- * Arguments:
- *     [in] Adapter -
- *             The adapter context.
- *     [in] pContent -
- *             Under PCI interface, this field is ignord.
- *             Under USB interface, the content is the interrupt
- *             content pointer.
- *             Under SDIO interface, this is the interrupt type which
- *             is Local interrupt or system interrupt.
- *     [in] ContentLen -
- *             The length in byte of pContent.
- * Return:
- *     If any interrupt matches the mask (IMR), return true, and
- *     return false otherwise.
- */
-static bool
-InterruptRecognized8723AU(struct rtw_adapter *Adapter, void *pContent,
-                         u32 ContentLen)
-{
-       struct hal_data_8723a   *pHalData = GET_HAL_DATA(Adapter);
-       u8 *buffer = (u8 *)pContent;
-       struct reportpwrstate_parm report;
-
-       memcpy(&pHalData->IntArray[0], &buffer[USB_INTR_CONTENT_HISR_OFFSET],
-              4);
-       pHalData->IntArray[0] &= pHalData->IntrMask[0];
-
-       /* For HISR extension. Added by tynli. 2009.10.07. */
-       memcpy(&pHalData->IntArray[1],
-              &buffer[USB_INTR_CONTENT_HISRE_OFFSET], 4);
-       pHalData->IntArray[1] &= pHalData->IntrMask[1];
-
-       /* We sholud remove this function later because DDK suggest
-        * not to executing too many operations in MPISR  */
-
-       memcpy(&report.state, &buffer[USB_INTR_CPWM_OFFSET], 1);
-
-       return (pHalData->IntArray[0] & pHalData->IntrMask[0]) != 0 ||
-               (pHalData->IntArray[1] & pHalData->IntrMask[1]) != 0;
-}
-
-static void usb_read_interrupt_complete(struct urb *purb)
-{
-       int err;
-       struct rtw_adapter *padapter = (struct rtw_adapter *)purb->context;
-
-       if (padapter->bSurpriseRemoved || padapter->bDriverStopped ||
-           padapter->bReadPortCancel) {
-               DBG_8723A("%s() RX Warning! bDriverStopped(%d) OR "
-                         "bSurpriseRemoved(%d) bReadPortCancel(%d)\n",
-                         __func__, padapter->bDriverStopped,
-                         padapter->bSurpriseRemoved,
-                         padapter->bReadPortCancel);
-               return;
-       }
-
-       if (purb->status == 0) {
-               struct c2h_evt_hdr *c2h_evt;
-
-               c2h_evt = (struct c2h_evt_hdr *)purb->transfer_buffer;
-
-               if (purb->actual_length > USB_INTR_CONTENT_LENGTH) {
-                       DBG_8723A("usb_read_interrupt_complete: purb->actual_"
-                                 "length > USB_INTR_CONTENT_LENGTH\n");
-                       goto urb_submit;
-               }
-
-               InterruptRecognized8723AU(padapter, purb->transfer_buffer,
-                                         purb->actual_length);
-
-               if (c2h_evt_exist(c2h_evt)) {
-                       if (c2h_id_filter_ccx_8723a(c2h_evt->id)) {
-                               /* Handle CCX report here */
-                               handle_txrpt_ccx_8723a(padapter, (void *)
-                                                      c2h_evt->payload);
-                               schedule_work(&padapter->evtpriv.irq_wk);
-                       } else {
-                               struct evt_work *c2w;
-                               int res;
-
-                               c2w = kmalloc(sizeof(struct evt_work),
-                                               GFP_ATOMIC);
-
-                               if (!c2w)
-                                       goto urb_submit;
-
-                               c2w->adapter = padapter;
-                               INIT_WORK(&c2w->work, rtw_evt_work);
-                               memcpy(c2w->u.buf, purb->transfer_buffer, 16);
-
-                               res = queue_work(padapter->evtpriv.wq,
-                                                &c2w->work);
-
-                               if (!res) {
-                                       printk(KERN_ERR "%s: Call to "
-                                              "queue_work() failed\n",
-                                              __func__);
-                                       kfree(c2w);
-                                       goto urb_submit;
-                               }
-                       }
-               }
-
-urb_submit:
-               err = usb_submit_urb(purb, GFP_ATOMIC);
-               if (err && (err != -EPERM)) {
-                       DBG_8723A("cannot submit interrupt in-token(err = "
-                                 "0x%08x), urb_status = %d\n",
-                                 err, purb->status);
-               }
-       } else {
-               DBG_8723A("###=> usb_read_interrupt_complete => urb "
-                         "status(%d)\n", purb->status);
-
-               switch (purb->status) {
-               case -EINVAL:
-               case -EPIPE:
-               case -ENODEV:
-               case -ESHUTDOWN:
-                       RT_TRACE(_module_hci_ops_os_c_, _drv_err_,
-                                "usb_read_port_complete:bSurpriseRemoved =true\n");
-                       /* Fall Through here */
-               case -ENOENT:
-                       padapter->bDriverStopped = true;
-                       RT_TRACE(_module_hci_ops_os_c_, _drv_err_,
-                                "usb_read_port_complete:bDriverStopped =true\n");
-                       break;
-               case -EPROTO:
-                       break;
-               case -EINPROGRESS:
-                       DBG_8723A("ERROR: URB IS IN PROGRESS!\n");
-                       break;
-               default:
-                       break;
-               }
-       }
-}
-
-int rtl8723au_read_interrupt(struct rtw_adapter *adapter)
-{
-       int err;
-       unsigned int pipe;
-       int ret = _SUCCESS;
-       struct dvobj_priv *pdvobj = adapter_to_dvobj(adapter);
-       struct recv_priv *precvpriv = &adapter->recvpriv;
-       struct usb_device *pusbd = pdvobj->pusbdev;
-
-       /* translate DMA FIFO addr to pipehandle */
-       pipe = usb_rcvintpipe(pusbd, pdvobj->RtInPipe[1]);
-
-       usb_fill_int_urb(precvpriv->int_in_urb, pusbd, pipe,
-                        precvpriv->int_in_buf, USB_INTR_CONTENT_LENGTH,
-                        usb_read_interrupt_complete, adapter, 1);
-
-       err = usb_submit_urb(precvpriv->int_in_urb, GFP_ATOMIC);
-       if (err && (err != -EPERM)) {
-               DBG_8723A("cannot submit interrupt in-token(err = 0x%08x),"
-                         "urb_status = %d\n", err,
-                         precvpriv->int_in_urb->status);
-               ret = _FAIL;
-       }
-
-       return ret;
-}
-
-static int recvbuf2recvframe(struct rtw_adapter *padapter, struct sk_buff *pskb)
-{
-       u8      *pbuf;
-       u8      shift_sz = 0;
-       u16     pkt_cnt;
-       u32     pkt_offset, skb_len, alloc_sz;
-       int     transfer_len;
-       struct recv_stat *prxstat;
-       struct phy_stat *pphy_info;
-       struct sk_buff *pkt_copy;
-       struct recv_frame *precvframe;
-       struct rx_pkt_attrib *pattrib;
-       struct recv_priv *precvpriv = &padapter->recvpriv;
-       struct rtw_queue *pfree_recv_queue = &precvpriv->free_recv_queue;
-
-       transfer_len = (int)pskb->len;
-       pbuf = pskb->data;
-
-       prxstat = (struct recv_stat *)pbuf;
-       pkt_cnt = (le32_to_cpu(prxstat->rxdw2) >> 16) & 0xff;
-
-       do {
-               RT_TRACE(_module_rtl871x_recv_c_, _drv_info_,
-                        "recvbuf2recvframe: rxdesc = offsset 0:0x%08x, 4:0x%08x, 8:0x%08x, C:0x%08x\n",
-                        prxstat->rxdw0, prxstat->rxdw1,
-                        prxstat->rxdw2, prxstat->rxdw4);
-
-               prxstat = (struct recv_stat *)pbuf;
-
-               precvframe = rtw_alloc_recvframe23a(pfree_recv_queue);
-               if (!precvframe) {
-                       RT_TRACE(_module_rtl871x_recv_c_, _drv_err_,
-                                "recvbuf2recvframe: precvframe == NULL\n");
-                       DBG_8723A("%s()-%d: rtw_alloc_recvframe23a() failed! RX "
-                                 "Drop!\n", __func__, __LINE__);
-                       goto _exit_recvbuf2recvframe;
-               }
-
-               INIT_LIST_HEAD(&precvframe->list);
-
-               update_recvframe_attrib(precvframe, prxstat);
-
-               pattrib = &precvframe->attrib;
-
-               if (pattrib->crc_err) {
-                       DBG_8723A("%s()-%d: RX Warning! rx CRC ERROR !!\n",
-                                 __func__, __LINE__);
-                       rtw_free_recvframe23a(precvframe);
-                       goto _exit_recvbuf2recvframe;
-               }
-
-               pkt_offset = RXDESC_SIZE + pattrib->drvinfo_sz +
-                       pattrib->shift_sz + pattrib->pkt_len;
-
-               if (pattrib->pkt_len <= 0 || pkt_offset > transfer_len) {
-                       RT_TRACE(_module_rtl871x_recv_c_, _drv_info_,
-                                "recvbuf2recvframe: pkt_len<= 0\n");
-                       DBG_8723A("%s()-%d: RX Warning!\n",
-                                 __func__, __LINE__);
-                       rtw_free_recvframe23a(precvframe);
-                       goto _exit_recvbuf2recvframe;
-               }
-
-               /*      Modified by Albert 20101213 */
-               /*      For 8 bytes IP header alignment. */
-               /*      Qos data, wireless lan header length is 26 */
-               if (pattrib->qos)
-                       shift_sz = 6;
-               else
-                       shift_sz = 0;
-
-               skb_len = pattrib->pkt_len;
-
-               /* for first fragment packet, driver need allocate
-                * 1536+drvinfo_sz+RXDESC_SIZE to defrag packet.
-                * modify alloc_sz for recvive crc error packet
-                * by thomas 2011-06-02 */
-               if (pattrib->mfrag == 1 && pattrib->frag_num == 0) {
-                       /* alloc_sz = 1664;     1664 is 128 alignment. */
-                       if (skb_len <= 1650)
-                               alloc_sz = 1664;
-                       else
-                               alloc_sz = skb_len + 14;
-               } else {
-                       alloc_sz = skb_len;
-               /*  6 is for IP header 8 bytes alignment in QoS packet case. */
-               /*  8 is for skb->data 4 bytes alignment. */
-                       alloc_sz += 14;
-               }
-
-               pkt_copy = netdev_alloc_skb(padapter->pnetdev, alloc_sz);
-               if (pkt_copy) {
-                       pkt_copy->dev = padapter->pnetdev;
-                       precvframe->pkt = pkt_copy;
-                       /* force pkt_copy->data at 8-byte alignment address */
-                       skb_reserve(pkt_copy, 8 -
-                                   ((unsigned long)(pkt_copy->data) & 7));
-                       /*force ip_hdr at 8-byte alignment address
-                         according to shift_sz. */
-                       skb_reserve(pkt_copy, shift_sz);
-                       memcpy(pkt_copy->data, pbuf + pattrib->shift_sz +
-                              pattrib->drvinfo_sz + RXDESC_SIZE, skb_len);
-                       skb_put(pkt_copy, skb_len);
-               } else {
-                       if (pattrib->mfrag == 1 && pattrib->frag_num == 0) {
-                               DBG_8723A("recvbuf2recvframe: alloc_skb fail, "
-                                         "drop frag frame \n");
-                               rtw_free_recvframe23a(precvframe);
-                               goto _exit_recvbuf2recvframe;
-                       }
-
-                       precvframe->pkt = skb_clone(pskb, GFP_ATOMIC);
-                       if (!precvframe->pkt) {
-                               DBG_8723A("recvbuf2recvframe: skb_clone "
-                                         "fail\n");
-                               rtw_free_recvframe23a(precvframe);
-                               goto _exit_recvbuf2recvframe;
-                       }
-               }
-
-               if (pattrib->physt) {
-                       pphy_info = (struct phy_stat *)(pbuf + RXDESC_OFFSET);
-                       update_recvframe_phyinfo(precvframe, pphy_info);
-               }
-
-               if (rtw_recv_entry23a(precvframe) != _SUCCESS)
-                       RT_TRACE(_module_rtl871x_recv_c_, _drv_err_,
-                                "recvbuf2recvframe: rtw_recv_entry23a(precvframe) != _SUCCESS\n");
-
-               pkt_cnt--;
-               transfer_len -= pkt_offset;
-               pbuf += pkt_offset;
-               precvframe = NULL;
-               pkt_copy = NULL;
-
-               if (transfer_len > 0 && pkt_cnt == 0)
-                       pkt_cnt = (le32_to_cpu(prxstat->rxdw2)>>16) & 0xff;
-
-       } while (transfer_len > 0 && pkt_cnt > 0);
-
-_exit_recvbuf2recvframe:
-
-       return _SUCCESS;
-}
-
-void rtl8723au_recv_tasklet(void *priv)
-{
-       struct sk_buff *pskb;
-       struct rtw_adapter *padapter = (struct rtw_adapter *)priv;
-       struct recv_priv *precvpriv = &padapter->recvpriv;
-
-       while (NULL != (pskb = skb_dequeue(&precvpriv->rx_skb_queue))) {
-               if (padapter->bDriverStopped || padapter->bSurpriseRemoved) {
-                       DBG_8723A("recv_tasklet => bDriverStopped or "
-                                 "bSurpriseRemoved \n");
-                       dev_kfree_skb_any(pskb);
-                       break;
-               }
-
-               recvbuf2recvframe(padapter, pskb);
-               skb_reset_tail_pointer(pskb);
-
-               pskb->len = 0;
-
-               skb_queue_tail(&precvpriv->free_recv_skb_queue, pskb);
-       }
-}
-
-static void usb_read_port_complete(struct urb *purb)
-{
-       struct recv_buf *precvbuf = (struct recv_buf *)purb->context;
-       struct rtw_adapter *padapter = (struct rtw_adapter *)precvbuf->adapter;
-       struct recv_priv *precvpriv = &padapter->recvpriv;
-
-       RT_TRACE(_module_hci_ops_os_c_, _drv_err_,
-                "usb_read_port_complete!!!\n");
-
-       precvpriv->rx_pending_cnt--;
-
-       if (padapter->bSurpriseRemoved || padapter->bDriverStopped ||
-           padapter->bReadPortCancel) {
-               RT_TRACE(_module_hci_ops_os_c_, _drv_err_,
-                        "usb_read_port_complete:bDriverStopped(%d) OR bSurpriseRemoved(%d)\n",
-                        padapter->bDriverStopped, padapter->bSurpriseRemoved);
-
-               DBG_8723A("%s()-%d: RX Warning! bDriverStopped(%d) OR "
-                         "bSurpriseRemoved(%d) bReadPortCancel(%d)\n",
-                         __func__, __LINE__, padapter->bDriverStopped,
-                         padapter->bSurpriseRemoved, padapter->bReadPortCancel);
-               return;
-       }
-
-       if (purb->status == 0) {
-               if (purb->actual_length > MAX_RECVBUF_SZ ||
-                   purb->actual_length < RXDESC_SIZE) {
-                       RT_TRACE(_module_hci_ops_os_c_, _drv_err_,
-                                "usb_read_port_complete: (purb->actual_length > MAX_RECVBUF_SZ) || (purb->actual_length < RXDESC_SIZE)\n");
-                       rtl8723au_read_port(padapter, 0, precvbuf);
-                       DBG_8723A("%s()-%d: RX Warning!\n",
-                                 __func__, __LINE__);
-               } else {
-                       rtw_reset_continual_urb_error(
-                               adapter_to_dvobj(padapter));
-
-                       skb_put(precvbuf->pskb, purb->actual_length);
-                       skb_queue_tail(&precvpriv->rx_skb_queue,
-                                      precvbuf->pskb);
-
-                       if (skb_queue_len(&precvpriv->rx_skb_queue) <= 1)
-                               tasklet_schedule(&precvpriv->recv_tasklet);
-
-                       precvbuf->pskb = NULL;
-                       rtl8723au_read_port(padapter, 0, precvbuf);
-               }
-       } else {
-               RT_TRACE(_module_hci_ops_os_c_, _drv_err_,
-                        "usb_read_port_complete : purb->status(%d) != 0\n",
-                        purb->status);
-               skb_put(precvbuf->pskb, purb->actual_length);
-               precvbuf->pskb = NULL;
-
-               DBG_8723A("###=> usb_read_port_complete => urb status(%d)\n",
-                         purb->status);
-
-               if (rtw_inc_and_chk_continual_urb_error(
-                           adapter_to_dvobj(padapter))) {
-                       padapter->bSurpriseRemoved = true;
-               }
-
-               switch (purb->status) {
-               case -EINVAL:
-               case -EPIPE:
-               case -ENODEV:
-               case -ESHUTDOWN:
-                       RT_TRACE(_module_hci_ops_os_c_, _drv_err_,
-                                "usb_read_port_complete:bSurpriseRemoved = true\n");
-                       /* Intentional fall through here */
-               case -ENOENT:
-                       padapter->bDriverStopped = true;
-                       RT_TRACE(_module_hci_ops_os_c_, _drv_err_,
-                                "usb_read_port_complete:bDriverStopped = true\n");
-                       break;
-               case -EPROTO:
-               case -EOVERFLOW:
-                       rtl8723au_read_port(padapter, 0, precvbuf);
-                       break;
-               case -EINPROGRESS:
-                       DBG_8723A("ERROR: URB IS IN PROGRESS!\n");
-                       break;
-               default:
-                       break;
-               }
-       }
-}
-
-int rtl8723au_read_port(struct rtw_adapter *adapter, u32 cnt,
-                       struct recv_buf *precvbuf)
-{
-       struct urb *purb;
-       struct dvobj_priv *pdvobj = adapter_to_dvobj(adapter);
-       struct recv_priv *precvpriv = &adapter->recvpriv;
-       struct usb_device *pusbd = pdvobj->pusbdev;
-       int err;
-       unsigned int pipe;
-       unsigned long tmpaddr;
-       unsigned long alignment;
-       int ret = _SUCCESS;
-
-       if (adapter->bDriverStopped || adapter->bSurpriseRemoved) {
-               RT_TRACE(_module_hci_ops_os_c_, _drv_err_,
-                        "usb_read_port:(padapter->bDriverStopped ||padapter->bSurpriseRemoved)!!!\n");
-               return _FAIL;
-       }
-
-       if (!precvbuf) {
-               RT_TRACE(_module_hci_ops_os_c_, _drv_err_,
-                        "usb_read_port:precvbuf == NULL\n");
-               return _FAIL;
-       }
-
-       if (!precvbuf->pskb)
-               precvbuf->pskb = skb_dequeue(&precvpriv->free_recv_skb_queue);
-
-       /* re-assign for linux based on skb */
-       if (!precvbuf->pskb) {
-               precvbuf->pskb = netdev_alloc_skb(adapter->pnetdev, MAX_RECVBUF_SZ + RECVBUFF_ALIGN_SZ);
-               if (precvbuf->pskb == NULL) {
-                       RT_TRACE(_module_hci_ops_os_c_, _drv_err_,
-                                "init_recvbuf(): alloc_skb fail!\n");
-                       return _FAIL;
-               }
-
-               tmpaddr = (unsigned long)precvbuf->pskb->data;
-               alignment = tmpaddr & (RECVBUFF_ALIGN_SZ-1);
-               skb_reserve(precvbuf->pskb, (RECVBUFF_ALIGN_SZ - alignment));
-       }
-
-       precvpriv->rx_pending_cnt++;
-
-       purb = precvbuf->purb;
-
-       /* translate DMA FIFO addr to pipehandle */
-       pipe = usb_rcvbulkpipe(pusbd, pdvobj->RtInPipe[0]);
-
-       usb_fill_bulk_urb(purb, pusbd, pipe, precvbuf->pskb->data,
-                         MAX_RECVBUF_SZ, usb_read_port_complete,
-                         precvbuf);/* context is precvbuf */
-
-       err = usb_submit_urb(purb, GFP_ATOMIC);
-       if ((err) && (err != -EPERM)) {
-               RT_TRACE(_module_hci_ops_os_c_, _drv_err_,
-                        "cannot submit rx in-token(err = 0x%.8x), URB_STATUS = 0x%.8x\n",
-                        err, purb->status);
-               DBG_8723A("cannot submit rx in-token(err = 0x%08x), urb_status "
-                         "= %d\n", err, purb->status);
-               ret = _FAIL;
-       }
-       return ret;
-}
-
-void rtl8723au_xmit_tasklet(void *priv)
-{
-       int ret;
-       struct rtw_adapter *padapter = (struct rtw_adapter *)priv;
-       struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-
-       if (check_fwstate(&padapter->mlmepriv, _FW_UNDER_SURVEY))
-               return;
-
-       while (1) {
-               if (padapter->bDriverStopped || padapter->bSurpriseRemoved ||
-                   padapter->bWritePortCancel) {
-                       DBG_8723A("xmit_tasklet => bDriverStopped or "
-                                 "bSurpriseRemoved or bWritePortCancel\n");
-                       break;
-               }
-
-               ret = rtl8723au_xmitframe_complete(padapter, pxmitpriv, NULL);
-
-               if (!ret)
-                       break;
-       }
-}
-
-void rtl8723au_set_hw_type(struct rtw_adapter *padapter)
-{
-       padapter->chip_type = RTL8723A;
-       padapter->HardwareType = HARDWARE_TYPE_RTL8723AU;
-       DBG_8723A("CHIP TYPE: RTL8723A\n");
-}
diff --git a/drivers/staging/rtl8723au/include/Hal8723APhyCfg.h b/drivers/staging/rtl8723au/include/Hal8723APhyCfg.h
deleted file mode 100644 (file)
index bcf3657..0000000
+++ /dev/null
@@ -1,162 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- *
- ******************************************************************************/
-#ifndef __INC_HAL8723PHYCFG_H__
-#define __INC_HAL8723PHYCFG_H__
-
-/*------------------------------Define structure----------------------------*/
-enum RF_RADIO_PATH {
-       RF_PATH_A = 0,                  /* Radio Path A */
-       RF_PATH_B = 1,                  /* Radio Path B */
-       RF_PATH_MAX                     /* Max RF number 90 support */
-};
-
-#define CHANNEL_MAX_NUMBER             14      /*  14 is the max channel number */
-
-enum WIRELESS_MODE {
-       WIRELESS_MODE_UNKNOWN   = 0x00,
-       WIRELESS_MODE_A         = BIT(2),
-       WIRELESS_MODE_B         = BIT(0),
-       WIRELESS_MODE_G         = BIT(1),
-       WIRELESS_MODE_AUTO      = BIT(5),
-       WIRELESS_MODE_N_24G     = BIT(3),
-       WIRELESS_MODE_N_5G      = BIT(4),
-       WIRELESS_MODE_AC        = BIT(6)
-};
-
-struct bb_reg_define {
-       u32 rfintfs;            /*  set software control: */
-                               /*              0x870~0x877[8 bytes] */
-       u32 rfintfi;            /*  readback data: */
-                               /*              0x8e0~0x8e7[8 bytes] */
-       u32 rfintfo;            /*  output data: */
-                               /*              0x860~0x86f [16 bytes] */
-       u32 rfintfe;            /*  output enable: */
-                               /*              0x860~0x86f [16 bytes] */
-       u32 rf3wireOffset;      /*  LSSI data: */
-                               /*              0x840~0x84f [16 bytes] */
-       u32 rfLSSI_Select;      /*  BB Band Select: */
-                               /*              0x878~0x87f [8 bytes] */
-       u32 rfTxGainStage;      /*  Tx gain stage: */
-                               /*              0x80c~0x80f [4 bytes] */
-       u32 rfHSSIPara1;        /*  wire parameter control1 : */
-                               /*              0x820~0x823, 0x828~0x82b, 0x830~0x833, 0x838~0x83b [16 bytes] */
-       u32 rfHSSIPara2;        /*  wire parameter control2 : */
-                               /*              0x824~0x827, 0x82c~0x82f, 0x834~0x837, 0x83c~0x83f [16 bytes] */
-       u32 rfSwitchControl; /* Tx Rx antenna control : */
-                               /*              0x858~0x85f [16 bytes] */
-       u32 rfAGCControl1;      /* AGC parameter control1 : */
-                               /*      0xc50~0xc53, 0xc58~0xc5b, 0xc60~0xc63, 0xc68~0xc6b [16 bytes] */
-       u32 rfAGCControl2;      /* AGC parameter control2 : */
-                               /*              0xc54~0xc57, 0xc5c~0xc5f, 0xc64~0xc67, 0xc6c~0xc6f [16 bytes] */
-       u32 rfRxIQImbalance; /* OFDM Rx IQ imbalance matrix : */
-                               /*              0xc14~0xc17, 0xc1c~0xc1f, 0xc24~0xc27, 0xc2c~0xc2f [16 bytes] */
-       u32 rfRxAFE;            /* Rx IQ DC ofset and Rx digital filter, Rx DC notch filter : */
-                               /*      0xc10~0xc13, 0xc18~0xc1b, 0xc20~0xc23, 0xc28~0xc2b [16 bytes] */
-       u32 rfTxIQImbalance; /* OFDM Tx IQ imbalance matrix */
-                               /*      0xc80~0xc83, 0xc88~0xc8b, 0xc90~0xc93, 0xc98~0xc9b [16 bytes] */
-       u32 rfTxAFE;            /* Tx IQ DC Offset and Tx DFIR type */
-                               /*      0xc84~0xc87, 0xc8c~0xc8f, 0xc94~0xc97, 0xc9c~0xc9f [16 bytes] */
-       u32 rfLSSIReadBack;     /* LSSI RF readback data SI mode */
-                               /*      0x8a0~0x8af [16 bytes] */
-       u32 rfLSSIReadBackPi;   /* LSSI RF readback data PI mode 0x8b8-8bc for Path A and B */
-};
-
-struct r_antenna_sel_ofdm {
-       u32                     r_tx_antenna:4;
-       u32                     r_ant_l:4;
-       u32                     r_ant_non_ht:4;
-       u32                     r_ant_ht1:4;
-       u32                     r_ant_ht2:4;
-       u32                     r_ant_ht_s1:4;
-       u32                     r_ant_non_ht_s1:4;
-       u32                     OFDM_TXSC:2;
-       u32                     Reserved:2;
-};
-
-struct r_antenna_sel_cck {
-       u8                      r_cckrx_enable_2:2;
-       u8                      r_cckrx_enable:2;
-       u8                      r_ccktx_enable:4;
-};
-
-/*------------------------------Define structure----------------------------*/
-
-
-/*------------------------Export global variable----------------------------*/
-/*------------------------Export global variable----------------------------*/
-
-
-/*------------------------Export Macro Definition---------------------------*/
-/*------------------------Export Macro Definition---------------------------*/
-
-
-/*--------------------------Exported Function prototype---------------------*/
-/*  */
-/*  BB and RF register read/write */
-/*  */
-u32    PHY_QueryBBReg(struct rtw_adapter *Adapter, u32 RegAddr,
-                      u32 BitMask);
-void   PHY_SetBBReg(struct rtw_adapter *Adapter, u32 RegAddr,
-                    u32 BitMask, u32 Data);
-u32    PHY_QueryRFReg(struct rtw_adapter *Adapter,
-                      enum RF_RADIO_PATH       eRFPath, u32 RegAddr,
-                      u32 BitMask);
-void   PHY_SetRFReg(struct rtw_adapter *Adapter,
-                    enum RF_RADIO_PATH eRFPath, u32 RegAddr,
-                    u32 BitMask,  u32  Data);
-
-/*  */
-/*  BB TX Power R/W */
-/*  */
-void PHY_SetTxPowerLevel8723A(struct rtw_adapter *Adapter, u8 channel);
-
-/*  */
-/*  Switch bandwidth for 8723A */
-/*  */
-void   PHY_SetBWMode23a8723A(struct rtw_adapter *pAdapter,
-                          enum ht_channel_width ChnlWidth,
-                          unsigned char Offset);
-
-/*  */
-/*  channel switch related funciton */
-/*  */
-void   PHY_SwChnl8723A(struct rtw_adapter *pAdapter, u8 channel);
-                               /*  Call after initialization */
-void ChkFwCmdIoDone(struct rtw_adapter *Adapter);
-
-/*  */
-/*  Modify the value of the hw register when beacon interval be changed. */
-/*  */
-void
-rtl8192c_PHY_SetBeaconHwReg(struct rtw_adapter *Adapter, u16 BeaconInterval);
-
-
-void PHY_SwitchEphyParameter(struct rtw_adapter *Adapter);
-
-void PHY_EnableHostClkReq(struct rtw_adapter *Adapter);
-
-bool
-SetAntennaConfig92C(struct rtw_adapter *Adapter, u8 DefaultAnt);
-
-/*--------------------------Exported Function prototype---------------------*/
-
-#define PHY_SetMacReg  PHY_SetBBReg
-
-/* MAC/BB/RF HAL config */
-int PHY_BBConfig8723A(struct rtw_adapter *Adapter);
-s32 PHY_MACConfig8723A(struct rtw_adapter *padapter);
-
-#endif
diff --git a/drivers/staging/rtl8723au/include/Hal8723APhyReg.h b/drivers/staging/rtl8723au/include/Hal8723APhyReg.h
deleted file mode 100644 (file)
index 759928f..0000000
+++ /dev/null
@@ -1,1078 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- *
- ******************************************************************************/
-#ifndef __INC_HAL8723APHYREG_H__
-#define __INC_HAL8723APHYREG_H__
-
-/*  1. PMAC duplicate register due to connection: RF_Mode, TRxRN, NumOf L-STF */
-/*  1. Page1(0x100) */
-#define rPMAC_Reset                            0x100
-#define rPMAC_TxStart                          0x104
-#define rPMAC_TxLegacySIG                      0x108
-#define rPMAC_TxHTSIG1                         0x10c
-#define rPMAC_TxHTSIG2                         0x110
-#define rPMAC_PHYDebug                         0x114
-#define rPMAC_TxPacketNum                      0x118
-#define rPMAC_TxIdle                           0x11c
-#define rPMAC_TxMACHeader0                     0x120
-#define rPMAC_TxMACHeader1                     0x124
-#define rPMAC_TxMACHeader2                     0x128
-#define rPMAC_TxMACHeader3                     0x12c
-#define rPMAC_TxMACHeader4                     0x130
-#define rPMAC_TxMACHeader5                     0x134
-#define rPMAC_TxDataType                       0x138
-#define rPMAC_TxRandomSeed                     0x13c
-#define rPMAC_CCKPLCPPreamble                  0x140
-#define rPMAC_CCKPLCPHeader                    0x144
-#define rPMAC_CCKCRC16                         0x148
-#define rPMAC_OFDMRxCRC32OK                    0x170
-#define rPMAC_OFDMRxCRC32Er                    0x174
-#define rPMAC_OFDMRxParityEr                   0x178
-#define rPMAC_OFDMRxCRC8Er                     0x17c
-#define rPMAC_CCKCRxRC16Er                     0x180
-#define rPMAC_CCKCRxRC32Er                     0x184
-#define rPMAC_CCKCRxRC32OK                     0x188
-#define rPMAC_TxStatus                         0x18c
-
-/*  2. Page2(0x200) */
-/*  The following two definition are only used for USB interface. */
-#define RF_BB_CMD_ADDR         0x02c0  /*  RF/BB read/write command address. */
-#define RF_BB_CMD_DATA         0x02c4  /*  RF/BB read/write command data. */
-
-/*  3. Page8(0x800) */
-#define rFPGA0_RFMOD           0x800   /* RF mode & CCK TxSC  RF BW Setting?? */
-
-#define rFPGA0_TxInfo          0x804   /*  Status report?? */
-#define rFPGA0_PSDFunction     0x808
-
-#define rFPGA0_TxGainStage     0x80c   /*  Set TX PWR init gain? */
-
-#define rFPGA0_RFTiming1       0x810   /*  Useless now */
-#define rFPGA0_RFTiming2       0x814
-
-#define rFPGA0_XA_HSSIParameter1       0x820   /*  RF 3 wire register */
-#define rFPGA0_XA_HSSIParameter2       0x824
-#define rFPGA0_XB_HSSIParameter1       0x828
-#define rFPGA0_XB_HSSIParameter2       0x82c
-#define rTxAGC_B_Rate18_06             0x830
-#define rTxAGC_B_Rate54_24             0x834
-#define rTxAGC_B_CCK1_55_Mcs32         0x838
-#define rTxAGC_B_Mcs03_Mcs00           0x83c
-
-#define rTxAGC_B_Mcs07_Mcs04           0x848
-#define rTxAGC_B_Mcs11_Mcs08           0x84c
-
-#define rFPGA0_XA_LSSIParameter                0x840
-#define rFPGA0_XB_LSSIParameter                0x844
-
-#define rFPGA0_RFWakeUpParameter       0x850   /*  Useless now */
-#define rFPGA0_RFSleepUpParameter      0x854
-
-#define rFPGA0_XAB_SwitchControl       0x858   /*  RF Channel switch */
-#define rFPGA0_XCD_SwitchControl       0x85c
-
-#define rFPGA0_XA_RFInterfaceOE                0x860   /*  RF Channel switch */
-#define rFPGA0_XB_RFInterfaceOE                0x864
-
-#define rTxAGC_B_Mcs15_Mcs12           0x868
-#define rTxAGC_B_CCK11_A_CCK2_11       0x86c
-
-#define rFPGA0_XAB_RFInterfaceSW       0x870   /*  RF Interface Software Control */
-#define rFPGA0_XCD_RFInterfaceSW       0x874
-
-#define rFPGA0_XAB_RFParameter         0x878   /*  RF Parameter */
-#define rFPGA0_XCD_RFParameter         0x87c
-
-#define rFPGA0_AnalogParameter1                0x880   /*  Crystal cap setting RF-R/W protection for parameter4?? */
-#define rFPGA0_AnalogParameter2                0x884
-#define rFPGA0_AnalogParameter3                0x888   /*  Useless now */
-#define rFPGA0_AnalogParameter4                0x88c
-
-#define rFPGA0_XA_LSSIReadBack         0x8a0   /*  Tranceiver LSSI Readback */
-#define rFPGA0_XB_LSSIReadBack         0x8a4
-#define rFPGA0_XC_LSSIReadBack         0x8a8
-#define rFPGA0_XD_LSSIReadBack         0x8ac
-
-#define rFPGA0_PSDReport               0x8b4   /*  Useless now */
-#define TransceiverA_HSPI_Readback     0x8b8   /*  Transceiver A HSPI Readback */
-#define TransceiverB_HSPI_Readback     0x8bc   /*  Transceiver B HSPI Readback */
-#define rFPGA0_XAB_RFInterfaceRB       0x8e0   /*  Useless now RF Interface Readback Value */
-#define rFPGA0_XCD_RFInterfaceRB       0x8e4   /*  Useless now */
-
-/*  4. Page9(0x900) */
-#define rFPGA1_RFMOD                   0x900   /* RF mode & OFDM TxSC RF BW Setting?? */
-
-#define rFPGA1_TxBlock                 0x904   /*  Useless now */
-#define rFPGA1_DebugSelect             0x908   /*  Useless now */
-#define rFPGA1_TxInfo                  0x90c   /*  Useless now Status report?? */
-
-/*  5. PageA(0xA00) */
-/*  Set Control channel to upper or lower. These settings are required only for 40MHz */
-#define rCCK0_System                   0xa00
-
-#define rCCK0_AFESetting               0xa04   /*  Disable init gain now Select RX path by RSSI */
-#define rCCK0_CCA                      0xa08   /*  Disable init gain now Init gain */
-
-#define rCCK0_RxAGC1                   0xa0c   /* AGC default value, saturation level Antenna Diversity, RX AGC, LNA Threshold, RX LNA Threshold useless now. Not the same as 90 series */
-#define rCCK0_RxAGC2                   0xa10   /* AGC & DAGC */
-
-#define rCCK0_RxHP                     0xa14
-
-#define rCCK0_DSPParameter1            0xa18   /* Timing recovery & Channel estimation threshold */
-#define rCCK0_DSPParameter2            0xa1c   /* SQ threshold */
-
-#define rCCK0_TxFilter1                        0xa20
-#define rCCK0_TxFilter2                        0xa24
-#define rCCK0_DebugPort                        0xa28   /* debug port and Tx filter3 */
-#define rCCK0_FalseAlarmReport         0xa2c   /* 0xa2d        useless now 0xa30-a4f channel report */
-#define rCCK0_TRSSIReport              0xa50
-#define rCCK0_RxReport                 0xa54  /* 0xa57 */
-#define rCCK0_FACounterLower           0xa5c  /* 0xa5b */
-#define rCCK0_FACounterUpper           0xa58  /* 0xa5c */
-/*  PageB(0xB00) */
-#define rPdp_AntA                      0xb00
-#define rPdp_AntA_4                    0xb04
-#define rConfig_Pmpd_AntA              0xb28
-#define rConfig_AntA                   0xb68
-#define rConfig_AntB                   0xb6c
-#define rPdp_AntB                      0xb70
-#define rPdp_AntB_4                    0xb74
-#define rConfig_Pmpd_AntB              0xb98
-#define rAPK                           0xbd8
-
-/*  6. PageC(0xC00) */
-#define rOFDM0_LSTF                    0xc00
-
-#define rOFDM0_TRxPathEnable           0xc04
-#define rOFDM0_TRMuxPar                        0xc08
-#define rOFDM0_TRSWIsolation           0xc0c
-
-#define rOFDM0_XARxAFE                 0xc10  /* RxIQ DC offset, Rx digital filter, DC notch filter */
-#define rOFDM0_XARxIQImbalance         0xc14  /* RxIQ imblance matrix */
-#define rOFDM0_XBRxAFE                 0xc18
-#define rOFDM0_XBRxIQImbalance         0xc1c
-#define rOFDM0_XCRxAFE                 0xc20
-#define rOFDM0_XCRxIQImbalance         0xc24
-#define rOFDM0_XDRxAFE                 0xc28
-#define rOFDM0_XDRxIQImbalance         0xc2c
-
-#define rOFDM0_RxDetector1             0xc30  /* PD,BW & SBD   DM tune init gain */
-#define rOFDM0_RxDetector2             0xc34  /* SBD & Fame Sync. */
-#define rOFDM0_RxDetector3             0xc38  /* Frame Sync. */
-#define rOFDM0_RxDetector4             0xc3c  /* PD, SBD, Frame Sync & Short-GI */
-
-#define rOFDM0_RxDSP                   0xc40  /* Rx Sync Path */
-#define rOFDM0_CFOandDAGC              0xc44  /* CFO & DAGC */
-#define rOFDM0_CCADropThreshold        0xc48 /* CCA Drop threshold */
-#define rOFDM0_ECCAThreshold           0xc4c /*  energy CCA */
-
-#define rOFDM0_XAAGCCore1              0xc50   /*  DIG */
-#define rOFDM0_XAAGCCore2              0xc54
-#define rOFDM0_XBAGCCore1              0xc58
-#define rOFDM0_XBAGCCore2              0xc5c
-#define rOFDM0_XCAGCCore1              0xc60
-#define rOFDM0_XCAGCCore2              0xc64
-#define rOFDM0_XDAGCCore1              0xc68
-#define rOFDM0_XDAGCCore2              0xc6c
-
-#define rOFDM0_AGCParameter1           0xc70
-#define rOFDM0_AGCParameter2           0xc74
-#define rOFDM0_AGCRSSITable            0xc78
-#define rOFDM0_HTSTFAGC                        0xc7c
-
-#define rOFDM0_XATxIQImbalance         0xc80   /*  TX PWR TRACK and DIG */
-#define rOFDM0_XATxAFE                 0xc84
-#define rOFDM0_XBTxIQImbalance         0xc88
-#define rOFDM0_XBTxAFE                 0xc8c
-#define rOFDM0_XCTxIQImbalance         0xc90
-#define rOFDM0_XCTxAFE                 0xc94
-#define rOFDM0_XDTxIQImbalance         0xc98
-#define rOFDM0_XDTxAFE                 0xc9c
-
-#define rOFDM0_RxIQExtAnta             0xca0
-#define rOFDM0_TxCoeff1                        0xca4
-#define rOFDM0_TxCoeff2                        0xca8
-#define rOFDM0_TxCoeff3                        0xcac
-#define rOFDM0_TxCoeff4                        0xcb0
-#define rOFDM0_TxCoeff5                        0xcb4
-#define rOFDM0_TxCoeff6                        0xcb8
-#define rOFDM0_RxHPParameter           0xce0
-#define rOFDM0_TxPseudoNoiseWgt                0xce4
-#define rOFDM0_FrameSync               0xcf0
-#define rOFDM0_DFSReport               0xcf4
-
-/*  7. PageD(0xD00) */
-#define rOFDM1_LSTF                    0xd00
-#define rOFDM1_TRxPathEnable           0xd04
-
-#define rOFDM1_CFO                     0xd08   /*  No setting now */
-#define rOFDM1_CSI1                    0xd10
-#define rOFDM1_SBD                     0xd14
-#define rOFDM1_CSI2                    0xd18
-#define rOFDM1_CFOTracking             0xd2c
-#define rOFDM1_TRxMesaure1             0xd34
-#define rOFDM1_IntfDet                 0xd3c
-#define rOFDM1_PseudoNoiseStateAB      0xd50
-#define rOFDM1_PseudoNoiseStateCD      0xd54
-#define rOFDM1_RxPseudoNoiseWgt                0xd58
-
-#define rOFDM_PHYCounter1              0xda0  /* cca, parity fail */
-#define rOFDM_PHYCounter2              0xda4  /* rate illegal, crc8 fail */
-#define rOFDM_PHYCounter3              0xda8  /* MCS not support */
-
-#define rOFDM_ShortCFOAB               0xdac   /*  No setting now */
-#define rOFDM_ShortCFOCD               0xdb0
-#define rOFDM_LongCFOAB                        0xdb4
-#define rOFDM_LongCFOCD                        0xdb8
-#define rOFDM_TailCFOAB                        0xdbc
-#define rOFDM_TailCFOCD                        0xdc0
-#define rOFDM_PWMeasure1               0xdc4
-#define rOFDM_PWMeasure2               0xdc8
-#define rOFDM_BWReport                 0xdcc
-#define rOFDM_AGCReport                        0xdd0
-#define rOFDM_RxSNR                    0xdd4
-#define rOFDM_RxEVMCSI                 0xdd8
-#define rOFDM_SIGReport                        0xddc
-
-
-/*  8. PageE(0xE00) */
-#define rTxAGC_A_Rate18_06             0xe00
-#define rTxAGC_A_Rate54_24             0xe04
-#define rTxAGC_A_CCK1_Mcs32            0xe08
-#define rTxAGC_A_Mcs03_Mcs00           0xe10
-#define rTxAGC_A_Mcs07_Mcs04           0xe14
-#define rTxAGC_A_Mcs11_Mcs08           0xe18
-#define rTxAGC_A_Mcs15_Mcs12           0xe1c
-
-#define rFPGA0_IQK                     0xe28
-#define rTx_IQK_Tone_A                 0xe30
-#define rRx_IQK_Tone_A                 0xe34
-#define rTx_IQK_PI_A                   0xe38
-#define rRx_IQK_PI_A                   0xe3c
-
-#define rTx_IQK                                0xe40
-#define rRx_IQK                                0xe44
-#define rIQK_AGC_Pts                   0xe48
-#define rIQK_AGC_Rsp                   0xe4c
-#define rTx_IQK_Tone_B                 0xe50
-#define rRx_IQK_Tone_B                 0xe54
-#define rTx_IQK_PI_B                   0xe58
-#define rRx_IQK_PI_B                   0xe5c
-#define rIQK_AGC_Cont                  0xe60
-
-#define rBlue_Tooth                    0xe6c
-#define rRx_Wait_CCA                   0xe70
-#define rTx_CCK_RFON                   0xe74
-#define rTx_CCK_BBON                   0xe78
-#define rTx_OFDM_RFON                  0xe7c
-#define rTx_OFDM_BBON                  0xe80
-#define rTx_To_Rx                      0xe84
-#define rTx_To_Tx                      0xe88
-#define rRx_CCK                                0xe8c
-
-#define rTx_Power_Before_IQK_A         0xe94
-#define rTx_Power_After_IQK_A          0xe9c
-
-#define rRx_Power_Before_IQK_A         0xea0
-#define rRx_Power_Before_IQK_A_2       0xea4
-#define rRx_Power_After_IQK_A          0xea8
-#define rRx_Power_After_IQK_A_2                0xeac
-
-#define rTx_Power_Before_IQK_B         0xeb4
-#define rTx_Power_After_IQK_B          0xebc
-
-#define rRx_Power_Before_IQK_B         0xec0
-#define rRx_Power_Before_IQK_B_2       0xec4
-#define rRx_Power_After_IQK_B          0xec8
-#define rRx_Power_After_IQK_B_2                0xecc
-
-#define rRx_OFDM                       0xed0
-#define rRx_Wait_RIFS                  0xed4
-#define rRx_TO_Rx                      0xed8
-#define rStandby                       0xedc
-#define rSleep                         0xee0
-#define rPMPD_ANAEN                    0xeec
-
-/*  7. RF Register 0x00-0x2E (RF 8256) */
-/*     RF-0222D 0x00-3F */
-/* Zebra1 */
-#define rZebra1_HSSIEnable             0x0     /*  Useless now */
-#define rZebra1_TRxEnable1             0x1
-#define rZebra1_TRxEnable2             0x2
-#define rZebra1_AGC                    0x4
-#define rZebra1_ChargePump             0x5
-#define rZebra1_Channel                        0x7     /*  RF channel switch */
-
-#define rZebra1_TxGain                 0x8     /*  Useless now */
-#define rZebra1_TxLPF                  0x9
-#define rZebra1_RxLPF                  0xb
-#define rZebra1_RxHPFCorner            0xc
-
-/* Zebra4 */
-#define rGlobalCtrl                    0       /*  Useless now */
-#define rRTL8256_TxLPF                 19
-#define rRTL8256_RxLPF                 11
-
-/* RTL8258 */
-#define rRTL8258_TxLPF                 0x11    /*  Useless now */
-#define rRTL8258_RxLPF                 0x13
-#define rRTL8258_RSSILPF               0xa
-
-/*  RL6052 Register definition */
-#define RF_AC                          0x00
-#define RF_IQADJ_G1                    0x01
-#define RF_IQADJ_G2                    0x02
-#define RF_BS_PA_APSET_G1_G4           0x03
-#define RF_BS_PA_APSET_G5_G8           0x04
-#define RF_POW_TRSW                    0x05
-#define RF_GAIN_RX                     0x06
-#define RF_GAIN_TX                     0x07
-#define RF_TXM_IDAC                    0x08
-#define RF_IPA_G                       0x09
-#define RF_TXBIAS_G                    0x0A
-#define RF_TXPA_AG                     0x0B
-#define RF_IPA_A                       0x0C
-#define RF_TXBIAS_A                    0x0D
-#define RF_BS_PA_APSET_G9_G11          0x0E
-#define RF_BS_IQGEN                    0x0F
-#define RF_MODE1                       0x10
-#define RF_MODE2                       0x11
-#define RF_RX_AGC_HP                   0x12
-#define RF_TX_AGC                      0x13
-#define RF_BIAS                                0x14
-#define RF_IPA                         0x15
-#define RF_TXBIAS                      0x16
-#define RF_POW_ABILITY                 0x17
-#define RF_MODE_AG                     0x18
-#define rRfChannel                     0x18    /*  RF channel and BW switch */
-#define RF_CHNLBW                      0x18    /*  RF channel and BW switch */
-#define RF_TOP                         0x19
-#define RF_RX_G1                       0x1A
-#define RF_RX_G2                       0x1B
-#define RF_RX_BB2                      0x1C
-#define RF_RX_BB1                      0x1D
-#define RF_RCK1                                0x1E
-#define RF_RCK2                                0x1F
-#define RF_TX_G1                       0x20
-#define RF_TX_G2                       0x21
-#define RF_TX_G3                       0x22
-#define RF_TX_BB1                      0x23
-#define RF_T_METER                     0x24
-#define RF_SYN_G1                      0x25    /*  RF TX Power control */
-#define RF_SYN_G2                      0x26    /*  RF TX Power control */
-#define RF_SYN_G3                      0x27    /*  RF TX Power control */
-#define RF_SYN_G4                      0x28    /*  RF TX Power control */
-#define RF_SYN_G5                      0x29    /*  RF TX Power control */
-#define RF_SYN_G6                      0x2A    /*  RF TX Power control */
-#define RF_SYN_G7                      0x2B    /*  RF TX Power control */
-#define RF_SYN_G8                      0x2C    /*  RF TX Power control */
-
-#define RF_RCK_OS                      0x30    /*  RF TX PA control */
-
-#define RF_TXPA_G1                     0x31    /*  RF TX PA control */
-#define RF_TXPA_G2                     0x32    /*  RF TX PA control */
-#define RF_TXPA_G3                     0x33    /*  RF TX PA control */
-
-/* Bit Mask */
-/*  1. Page1(0x100) */
-#define bBBResetB                      0x100   /*  Useless now? */
-#define bGlobalResetB                  0x200
-#define bOFDMTxStart                   0x4
-#define bCCKTxStart                    0x8
-#define bCRC32Debug                    0x100
-#define bPMACLoopback                  0x10
-#define bTxLSIG                                0xffffff
-#define bOFDMTxRate                    0xf
-#define bOFDMTxReserved                        0x10
-#define bOFDMTxLength                  0x1ffe0
-#define bOFDMTxParity                  0x20000
-#define bTxHTSIG1                      0xffffff
-#define bTxHTMCSRate                   0x7f
-#define bTxHTBW                                0x80
-#define bTxHTLength                    0xffff00
-#define bTxHTSIG2                      0xffffff
-#define bTxHTSmoothing                 0x1
-#define bTxHTSounding                  0x2
-#define bTxHTReserved                  0x4
-#define bTxHTAggreation                        0x8
-#define bTxHTSTBC                      0x30
-#define bTxHTAdvanceCoding             0x40
-#define bTxHTShortGI                   0x80
-#define bTxHTNumberHT_LTF              0x300
-#define bTxHTCRC8                      0x3fc00
-#define bCounterReset                  0x10000
-#define bNumOfOFDMTx                   0xffff
-#define bNumOfCCKTx                    0xffff0000
-#define bTxIdleInterval                        0xffff
-#define bOFDMService                   0xffff0000
-#define bTxMACHeader                   0xffffffff
-#define bTxDataInit                    0xff
-#define bTxHTMode                      0x100
-#define bTxDataType                    0x30000
-#define bTxRandomSeed                  0xffffffff
-#define bCCKTxPreamble                 0x1
-#define bCCKTxSFD                      0xffff0000
-#define bCCKTxSIG                      0xff
-#define bCCKTxService                  0xff00
-#define bCCKLengthExt                  0x8000
-#define bCCKTxLength                   0xffff0000
-#define bCCKTxCRC16                    0xffff
-#define bCCKTxStatus                   0x1
-#define bOFDMTxStatus                  0x2
-
-#define IS_BB_REG_OFFSET_92S(_Offset)                  \
-       ((_Offset >= 0x800) && (_Offset <= 0xfff))
-
-/*  2. Page8(0x800) */
-#define bRFMOD                         0x1     /*  Reg 0x800 rFPGA0_RFMOD */
-#define bJapanMode                     0x2
-#define bCCKTxSC                       0x30
-#define bCCKEn                         0x1000000
-#define bOFDMEn                                0x2000000
-
-#define bOFDMRxADCPhase                        0x10000 /*  Useless now */
-#define bOFDMTxDACPhase                        0x40000
-#define bXATxAGC                       0x3f
-
-#define bAntennaSelect                 0x0300
-
-#define bXBTxAGC                       0xf00   /*  Reg 80c rFPGA0_TxGainStage */
-#define bXCTxAGC                       0xf000
-#define bXDTxAGC                       0xf0000
-
-#define bPAStart                       0xf0000000      /*  Useless now */
-#define bTRStart                       0x00f00000
-#define bRFStart                       0x0000f000
-#define bBBStart                       0x000000f0
-#define bBBCCKStart                    0x0000000f
-#define bPAEnd                         0xf          /* Reg0x814 */
-#define bTREnd                         0x0f000000
-#define bRFEnd                         0x000f0000
-#define bCCAMask                       0x000000f0   /* T2R */
-#define bR2RCCAMask                    0x00000f00
-#define bHSSI_R2TDelay                 0xf8000000
-#define bHSSI_T2RDelay                 0xf80000
-#define bContTxHSSI                    0x400     /* chane gain at continue Tx */
-#define bIGFromCCK                     0x200
-#define bAGCAddress                    0x3f
-#define bRxHPTx                                0x7000
-#define bRxHPT2R                       0x38000
-#define bRxHPCCKIni                    0xc0000
-#define bAGCTxCode                     0xc00000
-#define bAGCRxCode                     0x300000
-
-#define b3WireDataLength               0x800   /*  Reg 0x820~84f rFPGA0_XA_HSSIParameter1 */
-#define b3WireAddressLength            0x400
-
-#define b3WireRFPowerDown              0x1     /*  Useless now */
-/* define bHWSISelect                  0x8 */
-#define b5GPAPEPolarity                        0x40000000
-#define b2GPAPEPolarity                        0x80000000
-#define bRFSW_TxDefaultAnt             0x3
-#define bRFSW_TxOptionAnt              0x30
-#define bRFSW_RxDefaultAnt             0x300
-#define bRFSW_RxOptionAnt              0x3000
-#define bRFSI_3WireData                        0x1
-#define bRFSI_3WireClock               0x2
-#define bRFSI_3WireLoad                        0x4
-#define bRFSI_3WireRW                  0x8
-#define bRFSI_3Wire                    0xf
-
-#define bRFSI_RFENV                    0x10    /*  Reg 0x870 rFPGA0_XAB_RFInterfaceSW */
-
-#define bRFSI_TRSW                     0x20    /*  Useless now */
-#define bRFSI_TRSWB                    0x40
-#define bRFSI_ANTSW                    0x100
-#define bRFSI_ANTSWB                   0x200
-#define bRFSI_PAPE                     0x400
-#define bRFSI_PAPE5G                   0x800
-#define bBandSelect                    0x1
-#define bHTSIG2_GI                     0x80
-#define bHTSIG2_Smoothing              0x01
-#define bHTSIG2_Sounding               0x02
-#define bHTSIG2_Aggreaton              0x08
-#define bHTSIG2_STBC                   0x30
-#define bHTSIG2_AdvCoding              0x40
-#define bHTSIG2_NumOfHTLTF             0x300
-#define bHTSIG2_CRC8                   0x3fc
-#define bHTSIG1_MCS                    0x7f
-#define bHTSIG1_BandWidth              0x80
-#define bHTSIG1_HTLength               0xffff
-#define bLSIG_Rate                     0xf
-#define bLSIG_Reserved                 0x10
-#define bLSIG_Length                   0x1fffe
-#define bLSIG_Parity                   0x20
-#define bCCKRxPhase                    0x4
-
-#define bLSSIReadAddress               0x7f800000   /*  T65 RF */
-
-#define bLSSIReadEdge                  0x80000000   /* LSSI "Read" edge signal */
-
-#define bLSSIReadBackData              0xfffff         /*  T65 RF */
-
-#define bLSSIReadOKFlag                        0x1000  /*  Useless now */
-#define bCCKSampleRate                 0x8       /* 0: 44MHz, 1:88MHz */
-#define bRegulator0Standby             0x1
-#define bRegulatorPLLStandby           0x2
-#define bRegulator1Standby             0x4
-#define bPLLPowerUp                    0x8
-#define bDPLLPowerUp                   0x10
-#define bDA10PowerUp                   0x20
-#define bAD7PowerUp                    0x200
-#define bDA6PowerUp                    0x2000
-#define bXtalPowerUp                   0x4000
-#define b40MDClkPowerUP                        0x8000
-#define bDA6DebugMode                  0x20000
-#define bDA6Swing                      0x380000
-
-#define bADClkPhase                    0x4000000       /*  Reg 0x880 rFPGA0_AnalogParameter1 20/40 CCK support switch 40/80 BB MHZ */
-
-#define b80MClkDelay                   0x18000000      /*  Useless */
-#define bAFEWatchDogEnable             0x20000000
-
-#define bXtalCap01                     0xc0000000      /*  Reg 0x884 rFPGA0_AnalogParameter2 Crystal cap */
-#define bXtalCap23                     0x3
-#define bXtalCap92x                    0x0f000000
-#define                bXtalCap                0x0f000000
-
-#define bIntDifClkEnable               0x400   /*  Useless */
-#define bExtSigClkEnable               0x800
-#define bBandgapMbiasPowerUp           0x10000
-#define bAD11SHGain                    0xc0000
-#define bAD11InputRange                        0x700000
-#define bAD11OPCurrent                 0x3800000
-#define bIPathLoopback                 0x4000000
-#define bQPathLoopback                 0x8000000
-#define bAFELoopback                   0x10000000
-#define bDA10Swing                     0x7e0
-#define bDA10Reverse                   0x800
-#define bDAClkSource                   0x1000
-#define bAD7InputRange                 0x6000
-#define bAD7Gain                       0x38000
-#define bAD7OutputCMMode               0x40000
-#define bAD7InputCMMode                        0x380000
-#define bAD7Current                    0xc00000
-#define bRegulatorAdjust               0x7000000
-#define bAD11PowerUpAtTx               0x1
-#define bDA10PSAtTx                    0x10
-#define bAD11PowerUpAtRx               0x100
-#define bDA10PSAtRx                    0x1000
-#define bCCKRxAGCFormat                        0x200
-#define bPSDFFTSamplepPoint            0xc000
-#define bPSDAverageNum                 0x3000
-#define bIQPathControl                 0xc00
-#define bPSDFreq                       0x3ff
-#define bPSDAntennaPath                        0x30
-#define bPSDIQSwitch                   0x40
-#define bPSDRxTrigger                  0x400000
-#define bPSDTxTrigger                  0x80000000
-#define bPSDSineToneScale              0x7f000000
-#define bPSDReport                     0xffff
-
-/*  3. Page9(0x900) */
-#define bOFDMTxSC                      0x30000000      /*  Useless */
-#define bCCKTxOn                       0x1
-#define bOFDMTxOn                      0x2
-#define bDebugPage                     0xfff  /* reset debug page and also HWord, LWord */
-#define bDebugItem                     0xff   /* reset debug page and LWord */
-#define bAntL                          0x10
-#define bAntNonHT                      0x100
-#define bAntHT1                                0x1000
-#define bAntHT2                                0x10000
-#define bAntHT1S1                      0x100000
-#define bAntNonHTS1                    0x1000000
-
-/*  4. PageA(0xA00) */
-#define bCCKBBMode                     0x3     /*  Useless */
-#define bCCKTxPowerSaving              0x80
-#define bCCKRxPowerSaving              0x40
-
-#define bCCKSideBand                   0x10    /*  Reg 0xa00 rCCK0_System 20/40 switch */
-
-#define bCCKScramble                   0x8     /*  Useless */
-#define bCCKAntDiversity               0x8000
-#define bCCKCarrierRecovery            0x4000
-#define bCCKTxRate                     0x3000
-#define bCCKDCCancel                   0x0800
-#define bCCKISICancel                  0x0400
-#define bCCKMatchFilter                        0x0200
-#define bCCKEqualizer                  0x0100
-#define bCCKPreambleDetect             0x800000
-#define bCCKFastFalseCCA               0x400000
-#define bCCKChEstStart                 0x300000
-#define bCCKCCACount                   0x080000
-#define bCCKcs_lim                     0x070000
-#define bCCKBistMode                   0x80000000
-#define bCCKCCAMask                    0x40000000
-#define bCCKTxDACPhase                 0x4
-#define bCCKRxADCPhase                 0x20000000   /* r_rx_clk */
-#define bCCKr_cp_mode0                 0x0100
-#define bCCKTxDCOffset                 0xf0
-#define bCCKRxDCOffset                 0xf
-#define bCCKCCAMode                    0xc000
-#define bCCKFalseCS_lim                        0x3f00
-#define bCCKCS_ratio                   0xc00000
-#define bCCKCorgBit_sel                        0x300000
-#define bCCKPD_lim                     0x0f0000
-#define bCCKNewCCA                     0x80000000
-#define bCCKRxHPofIG                   0x8000
-#define bCCKRxIG                       0x7f00
-#define bCCKLNAPolarity                        0x800000
-#define bCCKRx1stGain                  0x7f0000
-#define bCCKRFExtend                   0x20000000 /* CCK Rx Iinital gain polarity */
-#define bCCKRxAGCSatLevel              0x1f000000
-#define bCCKRxAGCSatCount              0xe0
-#define bCCKRxRFSettle                 0x1f       /* AGCsamp_dly */
-#define bCCKFixedRxAGC                 0x8000
-/* define bCCKRxAGCFormat              0x4000   remove to HSSI register 0x824 */
-#define bCCKAntennaPolarity            0x2000
-#define bCCKTxFilterType               0x0c00
-#define bCCKRxAGCReportType            0x0300
-#define bCCKRxDAGCEn                   0x80000000
-#define bCCKRxDAGCPeriod               0x20000000
-#define bCCKRxDAGCSatLevel             0x1f000000
-#define bCCKTimingRecovery             0x800000
-#define bCCKTxC0                       0x3f0000
-#define bCCKTxC1                       0x3f000000
-#define bCCKTxC2                       0x3f
-#define bCCKTxC3                       0x3f00
-#define bCCKTxC4                       0x3f0000
-#define bCCKTxC5                       0x3f000000
-#define bCCKTxC6                       0x3f
-#define bCCKTxC7                       0x3f00
-#define bCCKDebugPort                  0xff0000
-#define bCCKDACDebug                   0x0f000000
-#define bCCKFalseAlarmEnable           0x8000
-#define bCCKFalseAlarmRead             0x4000
-#define bCCKTRSSI                      0x7f
-#define bCCKRxAGCReport                        0xfe
-#define bCCKRxReport_AntSel            0x80000000
-#define bCCKRxReport_MFOff             0x40000000
-#define bCCKRxRxReport_SQLoss          0x20000000
-#define bCCKRxReport_Pktloss           0x10000000
-#define bCCKRxReport_Lockedbit         0x08000000
-#define bCCKRxReport_RateError         0x04000000
-#define bCCKRxReport_RxRate            0x03000000
-#define bCCKRxFACounterLower           0xff
-#define bCCKRxFACounterUpper           0xff000000
-#define bCCKRxHPAGCStart               0xe000
-#define bCCKRxHPAGCFinal               0x1c00
-#define bCCKRxFalseAlarmEnable         0x8000
-#define bCCKFACounterFreeze            0x4000
-#define bCCKTxPathSel                  0x10000000
-#define bCCKDefaultRxPath              0xc000000
-#define bCCKOptionRxPath               0x3000000
-
-/*  5. PageC(0xC00) */
-#define bNumOfSTF                      0x3     /*  Useless */
-#define bShift_L                       0xc0
-#define bGI_TH                         0xc
-#define bRxPathA                       0x1
-#define bRxPathB                       0x2
-#define bRxPathC                       0x4
-#define bRxPathD                       0x8
-#define bTxPathA                       0x1
-#define bTxPathB                       0x2
-#define bTxPathC                       0x4
-#define bTxPathD                       0x8
-#define bTRSSIFreq                     0x200
-#define bADCBackoff                    0x3000
-#define bDFIRBackoff                   0xc000
-#define bTRSSILatchPhase               0x10000
-#define bRxIDCOffset                   0xff
-#define bRxQDCOffset                   0xff00
-#define bRxDFIRMode                    0x1800000
-#define bRxDCNFType                    0xe000000
-#define bRXIQImb_A                     0x3ff
-#define bRXIQImb_B                     0xfc00
-#define bRXIQImb_C                     0x3f0000
-#define bRXIQImb_D                     0xffc00000
-#define bDC_dc_Notch                   0x60000
-#define bRxNBINotch                    0x1f000000
-#define bPD_TH                         0xf
-#define bPD_TH_Opt2                    0xc000
-#define bPWED_TH                       0x700
-#define bIfMF_Win_L                    0x800
-#define bPD_Option                     0x1000
-#define bMF_Win_L                      0xe000
-#define bBW_Search_L                   0x30000
-#define bwin_enh_L                     0xc0000
-#define bBW_TH                         0x700000
-#define bED_TH2                                0x3800000
-#define bBW_option                     0x4000000
-#define bRatio_TH                      0x18000000
-#define bWindow_L                      0xe0000000
-#define bSBD_Option                    0x1
-#define bFrame_TH                      0x1c
-#define bFS_Option                     0x60
-#define bDC_Slope_check                        0x80
-#define bFGuard_Counter_DC_L           0xe00
-#define bFrame_Weight_Short            0x7000
-#define bSub_Tune                      0xe00000
-#define bFrame_DC_Length               0xe000000
-#define bSBD_start_offset              0x30000000
-#define bFrame_TH_2                    0x7
-#define bFrame_GI2_TH                  0x38
-#define bGI2_Sync_en                   0x40
-#define bSarch_Short_Early             0x300
-#define bSarch_Short_Late              0xc00
-#define bSarch_GI2_Late                        0x70000
-#define bCFOAntSum                     0x1
-#define bCFOAcc                                0x2
-#define bCFOStartOffset                        0xc
-#define bCFOLookBack                   0x70
-#define bCFOSumWeight                  0x80
-#define bDAGCEnable                    0x10000
-#define bTXIQImb_A                     0x3ff
-#define bTXIQImb_B                     0xfc00
-#define bTXIQImb_C                     0x3f0000
-#define bTXIQImb_D                     0xffc00000
-#define bTxIDCOffset                   0xff
-#define bTxQDCOffset                   0xff00
-#define bTxDFIRMode                    0x10000
-#define bTxPesudoNoiseOn               0x4000000
-#define bTxPesudoNoise_A               0xff
-#define bTxPesudoNoise_B               0xff00
-#define bTxPesudoNoise_C               0xff0000
-#define bTxPesudoNoise_D               0xff000000
-#define bCCADropOption                 0x20000
-#define bCCADropThres                  0xfff00000
-#define bEDCCA_H                       0xf
-#define bEDCCA_L                       0xf0
-#define bLambda_ED                     0x300
-#define bRxInitialGain                 0x7f
-#define bRxAntDivEn                    0x80
-#define bRxAGCAddressForLNA            0x7f00
-#define bRxHighPowerFlow               0x8000
-#define bRxAGCFreezeThres              0xc0000
-#define bRxFreezeStep_AGC1             0x300000
-#define bRxFreezeStep_AGC2             0xc00000
-#define bRxFreezeStep_AGC3             0x3000000
-#define bRxFreezeStep_AGC0             0xc000000
-#define bRxRssi_Cmp_En                 0x10000000
-#define bRxQuickAGCEn                  0x20000000
-#define bRxAGCFreezeThresMode          0x40000000
-#define bRxOverFlowCheckType           0x80000000
-#define bRxAGCShift                    0x7f
-#define bTRSW_Tri_Only                 0x80
-#define bPowerThres                    0x300
-#define bRxAGCEn                       0x1
-#define bRxAGCTogetherEn               0x2
-#define bRxAGCMin                      0x4
-#define bRxHP_Ini                      0x7
-#define bRxHP_TRLNA                    0x70
-#define bRxHP_RSSI                     0x700
-#define bRxHP_BBP1                     0x7000
-#define bRxHP_BBP2                     0x70000
-#define bRxHP_BBP3                     0x700000
-#define bRSSI_H                                0x7f0000     /* the threshold for high power */
-#define bRSSI_Gen                      0x7f000000   /* the threshold for ant diversity */
-#define bRxSettle_TRSW                 0x7
-#define bRxSettle_LNA                  0x38
-#define bRxSettle_RSSI                 0x1c0
-#define bRxSettle_BBP                  0xe00
-#define bRxSettle_RxHP                 0x7000
-#define bRxSettle_AntSW_RSSI           0x38000
-#define bRxSettle_AntSW                        0xc0000
-#define bRxProcessTime_DAGC            0x300000
-#define bRxSettle_HSSI                 0x400000
-#define bRxProcessTime_BBPPW           0x800000
-#define bRxAntennaPowerShift           0x3000000
-#define bRSSITableSelect               0xc000000
-#define bRxHP_Final                    0x7000000
-#define bRxHTSettle_BBP                        0x7
-#define bRxHTSettle_HSSI               0x8
-#define bRxHTSettle_RxHP               0x70
-#define bRxHTSettle_BBPPW              0x80
-#define bRxHTSettle_Idle               0x300
-#define bRxHTSettle_Reserved           0x1c00
-#define bRxHTRxHPEn                    0x8000
-#define bRxHTAGCFreezeThres            0x30000
-#define bRxHTAGCTogetherEn             0x40000
-#define bRxHTAGCMin                    0x80000
-#define bRxHTAGCEn                     0x100000
-#define bRxHTDAGCEn                    0x200000
-#define bRxHTRxHP_BBP                  0x1c00000
-#define bRxHTRxHP_Final                        0xe0000000
-#define bRxPWRatioTH                   0x3
-#define bRxPWRatioEn                   0x4
-#define bRxMFHold                      0x3800
-#define bRxPD_Delay_TH1                        0x38
-#define bRxPD_Delay_TH2                        0x1c0
-#define bRxPD_DC_COUNT_MAX             0x600
-/* define bRxMF_Hold                       0x3800 */
-#define bRxPD_Delay_TH                 0x8000
-#define bRxProcess_Delay               0xf0000
-#define bRxSearchrange_GI2_Early       0x700000
-#define bRxFrame_Guard_Counter_L       0x3800000
-#define bRxSGI_Guard_L                 0xc000000
-#define bRxSGI_Search_L                        0x30000000
-#define bRxSGI_TH                      0xc0000000
-#define bDFSCnt0                       0xff
-#define bDFSCnt1                       0xff00
-#define bDFSFlag                       0xf0000
-#define bMFWeightSum                   0x300000
-#define bMinIdxTH                      0x7f000000
-#define bDAFormat                      0x40000
-#define bTxChEmuEnable                 0x01000000
-#define bTRSWIsolation_A               0x7f
-#define bTRSWIsolation_B               0x7f00
-#define bTRSWIsolation_C               0x7f0000
-#define bTRSWIsolation_D               0x7f000000
-#define bExtLNAGain                    0x7c00
-
-/*  6. PageE(0xE00) */
-#define bSTBCEn                                0x4     /*  Useless */
-#define bAntennaMapping                        0x10
-#define bNss                           0x20
-#define bCFOAntSumD                    0x200
-#define bPHYCounterReset               0x8000000
-#define bCFOReportGet                  0x4000000
-#define bOFDMContinueTx                        0x10000000
-#define bOFDMSingleCarrier             0x20000000
-#define bOFDMSingleTone                        0x40000000
-/* define bRxPath1                 0x01 */
-/* define bRxPath2                 0x02 */
-/* define bRxPath3                 0x04 */
-/* define bRxPath4                 0x08 */
-/* define bTxPath1                 0x10 */
-/* define bTxPath2                 0x20 */
-#define bHTDetect                      0x100
-#define bCFOEn                         0x10000
-#define bCFOValue                      0xfff00000
-#define bSigTone_Re                    0x3f
-#define bSigTone_Im                    0x7f00
-#define bCounter_CCA                   0xffff
-#define bCounter_ParityFail            0xffff0000
-#define bCounter_RateIllegal           0xffff
-#define bCounter_CRC8Fail              0xffff0000
-#define bCounter_MCSNoSupport          0xffff
-#define bCounter_FastSync              0xffff
-#define bShortCFO                      0xfff
-#define bShortCFOTLength               12   /* total */
-#define bShortCFOFLength               11   /* fraction */
-#define bLongCFO                       0x7ff
-#define bLongCFOTLength                        11
-#define bLongCFOFLength                        11
-#define bTailCFO                       0x1fff
-#define bTailCFOTLength                        13
-#define bTailCFOFLength                        12
-#define bmax_en_pwdB                   0xffff
-#define bCC_power_dB                   0xffff0000
-#define bnoise_pwdB                    0xffff
-#define bPowerMeasTLength              10
-#define bPowerMeasFLength              3
-#define bRx_HT_BW                      0x1
-#define bRxSC                          0x6
-#define bRx_HT                         0x8
-#define bNB_intf_det_on                        0x1
-#define bIntf_win_len_cfg              0x30
-#define bNB_Intf_TH_cfg                        0x1c0
-#define bRFGain                                0x3f
-#define bTableSel                      0x40
-#define bTRSW                          0x80
-#define bRxSNR_A                       0xff
-#define bRxSNR_B                       0xff00
-#define bRxSNR_C                       0xff0000
-#define bRxSNR_D                       0xff000000
-#define bSNREVMTLength                 8
-#define bSNREVMFLength                 1
-#define bCSI1st                                0xff
-#define bCSI2nd                                0xff00
-#define bRxEVM1st                      0xff0000
-#define bRxEVM2nd                      0xff000000
-#define bSIGEVM                                0xff
-#define bPWDB                          0xff00
-#define bSGIEN                         0x10000
-
-#define bSFactorQAM1                   0xf     /*  Useless */
-#define bSFactorQAM2                   0xf0
-#define bSFactorQAM3                   0xf00
-#define bSFactorQAM4                   0xf000
-#define bSFactorQAM5                   0xf0000
-#define bSFactorQAM6                   0xf0000
-#define bSFactorQAM7                   0xf00000
-#define bSFactorQAM8                   0xf000000
-#define bSFactorQAM9                   0xf0000000
-#define bCSIScheme                     0x100000
-
-#define bNoiseLvlTopSet                        0x3     /*  Useless */
-#define bChSmooth                      0x4
-#define bChSmoothCfg1                  0x38
-#define bChSmoothCfg2                  0x1c0
-#define bChSmoothCfg3                  0xe00
-#define bChSmoothCfg4                  0x7000
-#define bMRCMode                       0x800000
-#define bTHEVMCfg                      0x7000000
-
-#define bLoopFitType                   0x1     /*  Useless */
-#define bUpdCFO                                0x40
-#define bUpdCFOOffData                 0x80
-#define bAdvUpdCFO                     0x100
-#define bAdvTimeCtrl                   0x800
-#define bUpdClko                       0x1000
-#define bFC                            0x6000
-#define bTrackingMode                  0x8000
-#define bPhCmpEnable                   0x10000
-#define bUpdClkoLTF                    0x20000
-#define bComChCFO                      0x40000
-#define bCSIEstiMode                   0x80000
-#define bAdvUpdEqz                     0x100000
-#define bUChCfg                                0x7000000
-#define bUpdEqz                                0x8000000
-
-/* Rx Pseduo noise */
-#define bRxPesudoNoiseOn               0x20000000      /*  Useless */
-#define bRxPesudoNoise_A               0xff
-#define bRxPesudoNoise_B               0xff00
-#define bRxPesudoNoise_C               0xff0000
-#define bRxPesudoNoise_D               0xff000000
-#define bPesudoNoiseState_A            0xffff
-#define bPesudoNoiseState_B            0xffff0000
-#define bPesudoNoiseState_C            0xffff
-#define bPesudoNoiseState_D            0xffff0000
-
-/* 7. RF Register */
-/* Zebra1 */
-#define bZebra1_HSSIEnable             0x8             /*  Useless */
-#define bZebra1_TRxControl             0xc00
-#define bZebra1_TRxGainSetting         0x07f
-#define bZebra1_RxCorner               0xc00
-#define bZebra1_TxChargePump           0x38
-#define bZebra1_RxChargePump           0x7
-#define bZebra1_ChannelNum             0xf80
-#define bZebra1_TxLPFBW                        0x400
-#define bZebra1_RxLPFBW                        0x600
-
-/* Zebra4 */
-#define bRTL8256RegModeCtrl1           0x100   /*  Useless */
-#define bRTL8256RegModeCtrl0           0x40
-#define bRTL8256_TxLPFBW               0x18
-#define bRTL8256_RxLPFBW               0x600
-
-/* RTL8258 */
-#define bRTL8258_TxLPFBW               0xc     /*  Useless */
-#define bRTL8258_RxLPFBW               0xc00
-#define bRTL8258_RSSILPFBW             0xc0
-
-
-/*  Other Definition */
-
-/* byte endable for sb_write */
-#define bByte0                         0x1     /*  Useless */
-#define bByte1                         0x2
-#define bByte2                         0x4
-#define bByte3                         0x8
-#define bWord0                         0x3
-#define bWord1                         0xc
-#define bDWord                         0xf
-
-/* for PutRegsetting & GetRegSetting BitMask */
-#define bMaskByte0                     0xff    /*  Reg 0xc50 rOFDM0_XAAGCCore~0xC6f */
-#define bMaskByte1                     0xff00
-#define bMaskByte2                     0xff0000
-#define bMaskByte3                     0xff000000
-#define bMaskHWord                     0xffff0000
-#define bMaskLWord                     0x0000ffff
-#define bMaskDWord                     0xffffffff
-#define bMask12Bits                    0xfff
-#define bMaskH4Bits                    0xf0000000
-#define bMaskOFDM_D                    0xffc00000
-#define bMaskCCK                       0x3f3f3f3f
-
-/* for PutRFRegsetting & GetRFRegSetting BitMask */
-#define                bRFRegOffsetMask        0xfffff
-
-#define bDisable                       0x0
-
-#define LeftAntenna                    0x0     /*  Useless */
-#define RightAntenna                   0x1
-
-#define tCheckTxStatus                 500   /* 500ms Useless */
-#define tUpdateRxCounter               100   /* 100ms */
-
-#define rateCCK                                0       /*  Useless */
-#define rateOFDM                       1
-#define rateHT                         2
-
-/* define Register-End */
-#define bPMAC_End                      0x1ff   /*  Useless */
-#define bFPGAPHY0_End                  0x8ff
-#define bFPGAPHY1_End                  0x9ff
-#define bCCKPHY0_End                   0xaff
-#define bOFDMPHY0_End                  0xcff
-#define bOFDMPHY1_End                  0xdff
-
-/* define max debug item in each debug page */
-/* define bMaxItem_FPGA_PHY0        0x9 */
-/* define bMaxItem_FPGA_PHY1        0x3 */
-/* define bMaxItem_PHY_11B          0x16 */
-/* define bMaxItem_OFDM_PHY0        0x29 */
-/* define bMaxItem_OFDM_PHY1        0x0 */
-
-#define bPMACControl                   0x0     /*  Useless */
-#define bWMACControl                   0x1
-#define bWNICControl                   0x2
-
-#define PathA                          0x0     /*  Useless */
-#define PathB                          0x1
-#define PathC                          0x2
-#define PathD                          0x3
-
-/*  PageB(0xB00) */
-#define rPdp_AntA                      0xb00
-#define rPdp_AntA_4                    0xb04
-#define rPdp_AntA_8                    0xb08
-#define rPdp_AntA_C                    0xb0c
-#define rPdp_AntA_18                   0xb18
-#define rPdp_AntA_1C                   0xb1c
-#define rPdp_AntA_20                   0xb20
-#define rPdp_AntA_24                   0xb24
-
-#define rConfig_Pmpd_AntA              0xb28
-#define rConfig_ram64x16               0xb2c
-
-#define rBndA                          0xb30
-#define rHssiPar                       0xb34
-
-#define rConfig_AntA                   0xb68
-#define rConfig_AntB                   0xb6c
-
-#define rPdp_AntB                      0xb70
-#define rPdp_AntB_4                    0xb74
-#define rPdp_AntB_8                    0xb78
-#define rPdp_AntB_C                    0xb7c
-#define rPdp_AntB_10                   0xb80
-#define rPdp_AntB_14                   0xb84
-#define rPdp_AntB_18                   0xb88
-#define rPdp_AntB_1C                   0xb8c
-#define rPdp_AntB_20                   0xb90
-#define rPdp_AntB_24                   0xb94
-
-#define rConfig_Pmpd_AntB              0xb98
-
-#define rBndB                          0xba0
-
-#define rAPK                           0xbd8
-#define rPm_Rx0_AntA                   0xbdc
-#define rPm_Rx1_AntA                   0xbe0
-#define rPm_Rx2_AntA                   0xbe4
-#define rPm_Rx3_AntA                   0xbe8
-#define rPm_Rx0_AntB                   0xbec
-#define rPm_Rx1_AntB                   0xbf0
-#define rPm_Rx2_AntB                   0xbf4
-#define rPm_Rx3_AntB                   0xbf8
-
-#endif
diff --git a/drivers/staging/rtl8723au/include/Hal8723PwrSeq.h b/drivers/staging/rtl8723au/include/Hal8723PwrSeq.h
deleted file mode 100644 (file)
index 3771d6b..0000000
+++ /dev/null
@@ -1,126 +0,0 @@
-#ifndef __HAL8723PWRSEQ_H__
-#define __HAL8723PWRSEQ_H__
-/*
-       Check document WM-20110607-Paul-RTL8723A_Power_Architecture-R02.vsd
-       There are 6 HW Power States:
-       0: POFF--Power Off
-       1: PDN--Power Down
-       2: CARDEMU--Card Emulation
-       3: ACT--Active Mode
-       4: LPS--Low Power State
-       5: SUS--Suspend
-
-       The transision from different states are defined below
-       TRANS_CARDEMU_TO_ACT
-       TRANS_ACT_TO_CARDEMU
-       TRANS_CARDEMU_TO_SUS
-       TRANS_SUS_TO_CARDEMU
-       TRANS_CARDEMU_TO_PDN
-       TRANS_ACT_TO_LPS
-       TRANS_LPS_TO_ACT
-
-       TRANS_END
-*/
-#include "HalPwrSeqCmd.h"
-#include "rtl8723a_spec.h"
-
-#define        RTL8723A_TRANS_CARDEMU_TO_ACT_STEPS     15
-#define        RTL8723A_TRANS_ACT_TO_CARDEMU_STEPS     15
-#define        RTL8723A_TRANS_CARDEMU_TO_SUS_STEPS     15
-#define        RTL8723A_TRANS_SUS_TO_CARDEMU_STEPS     15
-#define        RTL8723A_TRANS_CARDEMU_TO_PDN_STEPS     15
-#define        RTL8723A_TRANS_PDN_TO_CARDEMU_STEPS     15
-#define        RTL8723A_TRANS_ACT_TO_LPS_STEPS 15
-#define        RTL8723A_TRANS_LPS_TO_ACT_STEPS 15
-#define        RTL8723A_TRANS_END_STEPS        1
-
-
-/* format
- * { offset, cut_msk, fab_msk|interface_msk, base|cmd, msk, value },  comments here
- */
-#define RTL8723A_TRANS_CARDEMU_TO_ACT                                                                                                          \
-       {0x0020, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(0), BIT(0)}, /*0x20[0] = 1b'1 enable LDOA12 MACRO block for all interface*/ \
-       {0x0067, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(4), 0}, /*0x67[0] = 0 to disable BT_GPS_SEL pins*/    \
-       {0x0001, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_DELAY, 1, PWRSEQ_DELAY_MS},/*Delay 1ms*/   \
-       {0x0000, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(5), 0}, /*0x00[5] = 1b'0 release analog Ips to digital , 1:isolation*/   \
-       {0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(2), 0},/* disable SW LPS 0x04[10]= 0*/        \
-       {0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT(1), BIT(1)},/* wait till 0x04[17] = 1    power ready*/      \
-       {0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(0), BIT(0)},/* release WLON reset  0x04[16]= 1*/ \
-       {0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(7), 0},/* disable HWPDN 0x04[15]= 0*/ \
-       {0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, (BIT(4)|BIT(3)), 0},/* disable WL suspend*/       \
-       {0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(0), BIT(0)},/* polling until return 0*/       \
-       {0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT(0), 0},/**/ \
-       {0x004E, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(7), 1},/*0x4C[23] = 0x4E[7] = 1, switch DPDT_SEL_P output from WL BB */\
-
-#define RTL8723A_TRANS_ACT_TO_CARDEMU                                                                                                  \
-       {0x001F, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0},/*0x1F[7:0] = 0 turn off RF*/    \
-       {0x004E, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(7), 0},/*0x4C[23] = 0x4E[7] = 0, switch DPDT_SEL_P output from register 0x65[2] */\
-       {0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(1), BIT(1)}, /*0x04[9] = 1 turn off MAC by HW state machine*/ \
-       {0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT(1), 0}, /*wait till 0x04[9] = 0 polling until return 0 to disable*/ \
-       {0x0000, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(5), BIT(5)}, /*0x00[5] = 1b'1 analog Ips to digital , 1:isolation*/   \
-       {0x0020, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(0), 0}, /*0x20[0] = 1b'0 disable LDOA12 MACRO block*/   \
-
-
-#define RTL8723A_TRANS_CARDEMU_TO_SUS                                                                                                  \
-       {0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(3)|BIT(4), BIT(3)}, /*0x04[12:11] = 2b'01 enable WL suspend*/
-
-#define RTL8723A_TRANS_SUS_TO_CARDEMU                                                                                                  \
-       {0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(3) | BIT(7), 0}, /*clear suspend enable and power down enable*/       \
-       {0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(3)|BIT(4), 0}, /*0x04[12:11] = 2b'01enable WL suspend*/
-
-#define RTL8723A_TRANS_CARDEMU_TO_CARDDIS                                                                                                      \
-       {0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(3)|BIT(4), BIT(3)}, /*0x04[12:11] = 2b'01 enable WL suspend*/ \
-       {0x004A, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(0), BIT(0)}, /*0x48[16] = 1 to enable GPIO9 as EXT WAKEUP*/
-
-#define RTL8723A_TRANS_CARDDIS_TO_CARDEMU                                                                                                      \
-       {0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(3) | BIT(7), 0}, /*clear suspend enable and power down enable*/       \
-       {0x004A, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(0), 0}, /*0x48[16] = 0 to disable GPIO9 as EXT WAKEUP*/   \
-       {0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(3)|BIT(4), 0}, /*0x04[12:11] = 2b'01enable WL suspend*/
-
-#define RTL8723A_TRANS_CARDEMU_TO_PDN                                                                                          \
-       {0x0007, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x20}, /*0x07[7:0] = 0x20 SOP option to disable BG/MB/ACK/SWR*/   \
-       {0x0006, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(0), 0},/* 0x04[16] = 0*/\
-       {0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(7), BIT(7)},/* 0x04[15] = 1*/
-
-#define RTL8723A_TRANS_PDN_TO_CARDEMU                                                                                          \
-       {0x0005, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(7), 0},/* 0x04[15] = 0*/
-
-#define RTL8723A_TRANS_ACT_TO_LPS                                                                                                              \
-       {0x0522, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0xFF},/*Tx Pause*/  \
-       {0x05F8, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, 0xFF, 0},/*Should be zero if no packet is transmitting*/        \
-       {0x05F9, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, 0xFF, 0},/*Should be zero if no packet is transmitting*/        \
-       {0x05FA, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, 0xFF, 0},/*Should be zero if no packet is transmitting*/        \
-       {0x05FB, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, 0xFF, 0},/*Should be zero if no packet is transmitting*/        \
-       {0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(0), 0},/*CCK and OFDM are disabled, and clock are gated*/     \
-       {0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_DELAY, 0, PWRSEQ_DELAY_US},/*Delay 1us*/ \
-       {0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(1), 0},/*Whole BB is reset*/  \
-       {0x0100, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x03},/*Reset MAC TRX*/     \
-       {0x0101, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(1), 0},/*check if removed later*/     \
-       {0x0553, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(5), BIT(5)},/*Respond TxOK to scheduler*/
-
-#define RTL8723A_TRANS_LPS_TO_ACT                                                                                                                      \
-       {0xFE58, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_USB_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0x84}, /*USB RPWM*/\
-       {0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_DELAY, 0, PWRSEQ_DELAY_MS}, /*Delay*/\
-       {0x0008, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(4), 0}, /*.   0x08[4] = 0              switch TSF to 40M*/\
-       {0x0109, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_POLLING, BIT(7), 0}, /*Polling 0x109[7]= 0  TSF in 40M*/\
-       {0x0029, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(6)|BIT(7), 0}, /*.    0x29[7:6] = 2b'00        enable BB clock*/\
-       {0x0101, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(1), BIT(1)}, /*.      0x101[1] = 1*/\
-       {0x0100, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0xFF}, /*.  0x100[7:0] = 0xFF        enable WMAC TRX*/\
-       {0x0002, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, BIT(1)|BIT(0), BIT(1)|BIT(0)}, /*.        0x02[1:0] = 2b'11        enable BB macro*/\
-       {0x0522, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, PWR_BASEADDR_MAC, PWR_CMD_WRITE, 0xFF, 0}, /*.     0x522 = 0*/
-
-#define RTL8723A_TRANS_END                                                                                                                     \
-       {0xFFFF, PWR_CUT_ALL_MSK, PWR_FAB_ALL_MSK, PWR_INTF_ALL_MSK, 0, PWR_CMD_END, 0, 0},
-
-
-extern struct wlan_pwr_cfg rtl8723AU_power_on_flow[RTL8723A_TRANS_CARDEMU_TO_ACT_STEPS+RTL8723A_TRANS_END_STEPS];
-extern struct wlan_pwr_cfg rtl8723AU_radio_off_flow[RTL8723A_TRANS_ACT_TO_CARDEMU_STEPS+RTL8723A_TRANS_END_STEPS];
-extern struct wlan_pwr_cfg rtl8723AU_card_disable_flow[RTL8723A_TRANS_ACT_TO_CARDEMU_STEPS+RTL8723A_TRANS_CARDEMU_TO_PDN_STEPS+RTL8723A_TRANS_END_STEPS];
-extern struct wlan_pwr_cfg rtl8723AU_card_enable_flow[RTL8723A_TRANS_ACT_TO_CARDEMU_STEPS+RTL8723A_TRANS_CARDEMU_TO_PDN_STEPS+RTL8723A_TRANS_END_STEPS];
-extern struct wlan_pwr_cfg rtl8723AU_suspend_flow[RTL8723A_TRANS_ACT_TO_CARDEMU_STEPS+RTL8723A_TRANS_CARDEMU_TO_SUS_STEPS+RTL8723A_TRANS_END_STEPS];
-extern struct wlan_pwr_cfg rtl8723AU_resume_flow[RTL8723A_TRANS_ACT_TO_CARDEMU_STEPS+RTL8723A_TRANS_CARDEMU_TO_SUS_STEPS+RTL8723A_TRANS_END_STEPS];
-extern struct wlan_pwr_cfg rtl8723AU_hwpdn_flow[RTL8723A_TRANS_ACT_TO_CARDEMU_STEPS+RTL8723A_TRANS_CARDEMU_TO_PDN_STEPS+RTL8723A_TRANS_END_STEPS];
-extern struct wlan_pwr_cfg rtl8723AU_enter_lps_flow[RTL8723A_TRANS_ACT_TO_LPS_STEPS+RTL8723A_TRANS_END_STEPS];
-extern struct wlan_pwr_cfg rtl8723AU_leave_lps_flow[RTL8723A_TRANS_LPS_TO_ACT_STEPS+RTL8723A_TRANS_END_STEPS];
-
-#endif
diff --git a/drivers/staging/rtl8723au/include/Hal8723UHWImg_CE.h b/drivers/staging/rtl8723au/include/Hal8723UHWImg_CE.h
deleted file mode 100644 (file)
index c834b3a..0000000
+++ /dev/null
@@ -1,29 +0,0 @@
-#ifndef __INC_HAL8723U_FW_IMG_H
-#define __INC_HAL8723U_FW_IMG_H
-
-/*Created on  2013/01/14, 15:51*/
-
-/* FW v16 enable usb interrupt */
-#define Rtl8723UImgArrayLength 22172
-extern u8 Rtl8723UFwImgArray[Rtl8723UImgArrayLength];
-#define Rtl8723UBTImgArrayLength 1
-extern u8 Rtl8723UFwBTImgArray[Rtl8723UBTImgArrayLength];
-
-#define Rtl8723UUMCBCutImgArrayWithBTLength 24118
-#define Rtl8723UUMCBCutImgArrayWithoutBTLength 19200
-
-extern u8 Rtl8723UFwUMCBCutImgArrayWithBT[Rtl8723UUMCBCutImgArrayWithBTLength];
-extern u8 Rtl8723UFwUMCBCutImgArrayWithoutBT[Rtl8723UUMCBCutImgArrayWithoutBTLength];
-
-#define Rtl8723SUMCBCutMPImgArrayLength 24174
-extern const u8 Rtl8723SFwUMCBCutMPImgArray[Rtl8723SUMCBCutMPImgArrayLength];
-
-#define Rtl8723EBTImgArrayLength 15276
-extern u8 Rtl8723EFwBTImgArray[Rtl8723EBTImgArrayLength];
-
-#define Rtl8723UPHY_REG_Array_PGLength 336
-extern u32 Rtl8723UPHY_REG_Array_PG[Rtl8723UPHY_REG_Array_PGLength];
-#define Rtl8723UMACPHY_Array_PGLength 1
-extern u32 Rtl8723UMACPHY_Array_PG[Rtl8723UMACPHY_Array_PGLength];
-
-#endif /* ifndef __INC_HAL8723U_FW_IMG_H */
diff --git a/drivers/staging/rtl8723au/include/HalDMOutSrc8723A.h b/drivers/staging/rtl8723au/include/HalDMOutSrc8723A.h
deleted file mode 100644 (file)
index d7651f7..0000000
+++ /dev/null
@@ -1,64 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- *
- ******************************************************************************/
-#ifndef        __RTL8723A_ODM_H__
-#define __RTL8723A_ODM_H__
-/*  */
-
-#define        RSSI_CCK        0
-#define        RSSI_OFDM       1
-#define        RSSI_DEFAULT    2
-
-#define IQK_MAC_REG_NUM                4
-#define IQK_ADDA_REG_NUM               16
-#define IQK_BB_REG_NUM                 9
-#define HP_THERMAL_NUM         8
-
-
-/*  */
-/*  structure and define */
-/*  */
-
-
-
-
-/*------------------------Export global variable----------------------------*/
-/*------------------------Export global variable----------------------------*/
-/*------------------------Export Marco Definition---------------------------*/
-/* define DM_MultiSTA_InitGainChangeNotify(Event) {DM_DigTable.CurMultiSTAConnectState = Event;} */
-
-
-/*  */
-/*  function prototype */
-/*  */
-
-/*  */
-/*  IQ calibrate */
-/*  */
-void rtl8723a_phy_iq_calibrate(struct rtw_adapter *pAdapter, bool bReCovery);
-
-/*  */
-/*  LC calibrate */
-/*  */
-void rtl8723a_phy_lc_calibrate(struct rtw_adapter *pAdapter);
-
-/*  */
-/*  AP calibrate */
-/*  */
-void rtl8723a_phy_ap_calibrate(struct rtw_adapter *pAdapter, char delta);
-
-void rtl8723a_odm_check_tx_power_tracking(struct rtw_adapter *Adapter);
-
-#endif
diff --git a/drivers/staging/rtl8723au/include/HalHWImg8723A_BB.h b/drivers/staging/rtl8723au/include/HalHWImg8723A_BB.h
deleted file mode 100644 (file)
index 1276094..0000000
+++ /dev/null
@@ -1,38 +0,0 @@
-/******************************************************************************
-*
-* Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
-*
-* This program is free software; you can redistribute it and/or modify it
-* under the terms of version 2 of the GNU General Public License as
-* published by the Free Software Foundation.
-*
-* This program is distributed in the hope that it will be useful, but WITHOUT
-* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
-* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
-* more details.
-*
-*
-******************************************************************************/
-
-#ifndef __INC_BB_8723A_HW_IMG_H
-#define __INC_BB_8723A_HW_IMG_H
-
-/******************************************************************************
-*                           AGC_TAB_1T.TXT
-******************************************************************************/
-
-void ODM_ReadAndConfig_AGC_TAB_1T_8723A(struct dm_odm_t *pDM_Odm);
-
-/******************************************************************************
-*                           PHY_REG_1T.TXT
-******************************************************************************/
-
-void ODM_ReadAndConfig_PHY_REG_1T_8723A(struct dm_odm_t *pDM_Odm);
-
-/******************************************************************************
-*                           PHY_REG_MP.TXT
-******************************************************************************/
-
-void ODM_ReadAndConfig_PHY_REG_MP_8723A(struct dm_odm_t *pDM_Odm);
-
-#endif /*  end of HWIMG_SUPPORT */
diff --git a/drivers/staging/rtl8723au/include/HalHWImg8723A_FW.h b/drivers/staging/rtl8723au/include/HalHWImg8723A_FW.h
deleted file mode 100644 (file)
index 7ee363b..0000000
+++ /dev/null
@@ -1,28 +0,0 @@
-/******************************************************************************
-*
-* Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
-*
-* This program is free software; you can redistribute it and/or modify it
-* under the terms of version 2 of the GNU General Public License as
-* published by the Free Software Foundation.
-*
-* This program is distributed in the hope that it will be useful, but WITHOUT
-* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
-* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
-* more details.
-*
-*
-******************************************************************************/
-
-#ifndef __INC_FW_8723A_HW_IMG_H
-#define __INC_FW_8723A_HW_IMG_H
-
-
-/******************************************************************************
-*                           rtl8723fw_B.TXT
-******************************************************************************/
-
-void ODM_ReadFirmware_8723A_rtl8723fw_B(struct dm_odm_t *pDM_Odm,
-                                       u8 *pFirmware, u32 *pFirmwareSize);
-
-#endif /*  end of HWIMG_SUPPORT */
diff --git a/drivers/staging/rtl8723au/include/HalHWImg8723A_MAC.h b/drivers/staging/rtl8723au/include/HalHWImg8723A_MAC.h
deleted file mode 100644 (file)
index 201be1f..0000000
+++ /dev/null
@@ -1,26 +0,0 @@
-/******************************************************************************
-*
-* Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
-*
-* This program is free software; you can redistribute it and/or modify it
-* under the terms of version 2 of the GNU General Public License as
-* published by the Free Software Foundation.
-*
-* This program is distributed in the hope that it will be useful, but WITHOUT
-* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
-* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
-* more details.
-*
-*
-******************************************************************************/
-
-#ifndef __INC_MAC_8723A_HW_IMG_H
-#define __INC_MAC_8723A_HW_IMG_H
-
-/******************************************************************************
-*                           MAC_REG.TXT
-******************************************************************************/
-
-void ODM_ReadAndConfig_MAC_REG_8723A(struct dm_odm_t *pDM_Odm);
-
-#endif /*  end of HWIMG_SUPPORT */
diff --git a/drivers/staging/rtl8723au/include/HalHWImg8723A_RF.h b/drivers/staging/rtl8723au/include/HalHWImg8723A_RF.h
deleted file mode 100644 (file)
index c9af1c3..0000000
+++ /dev/null
@@ -1,25 +0,0 @@
-/******************************************************************************
-*
-* Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
-*
-* This program is free software; you can redistribute it and/or modify it
-* under the terms of version 2 of the GNU General Public License as
-* published by the Free Software Foundation.
-*
-* This program is distributed in the hope that it will be useful, but WITHOUT
-* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
-* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
-* more details.
-*
-******************************************************************************/
-
-#ifndef __INC_RF_8723A_HW_IMG_H
-#define __INC_RF_8723A_HW_IMG_H
-
-/******************************************************************************
-*                           RadioA_1T.TXT
-******************************************************************************/
-
-void ODM_ReadAndConfig_RadioA_1T_8723A(struct dm_odm_t *pDM_Odm);
-
-#endif /*  end of HWIMG_SUPPORT */
diff --git a/drivers/staging/rtl8723au/include/HalPwrSeqCmd.h b/drivers/staging/rtl8723au/include/HalPwrSeqCmd.h
deleted file mode 100644 (file)
index 12e03a3..0000000
+++ /dev/null
@@ -1,130 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- *
- ******************************************************************************/
-#ifndef __HALPWRSEQCMD_H__
-#define __HALPWRSEQCMD_H__
-
-#include <drv_types.h>
-
-/*---------------------------------------------*/
-/*---------------------------------------------*/
-#define PWR_CMD_READ                   0x00
-     /*  offset: the read register offset */
-     /*  msk: the mask of the read value */
-     /*  value: N/A, left by 0 */
-     /*  note: dirver shall implement this function by read & msk */
-
-#define PWR_CMD_WRITE                  0x01
-     /*  offset: the read register offset */
-     /*  msk: the mask of the write bits */
-     /*  value: write value */
-     /*  note: driver shall implement this cmd by read & msk after write */
-
-#define PWR_CMD_POLLING                        0x02
-     /*  offset: the read register offset */
-     /*  msk: the mask of the polled value */
-     /*  value: the value to be polled, masked by the msd field. */
-     /*  note: driver shall implement this cmd by */
-     /*  do{ */
-     /*  if( (Read(offset) & msk) == (value & msk) ) */
-     /*  break; */
-     /*  } while(not timeout); */
-
-#define PWR_CMD_DELAY                  0x03
-     /*  offset: the value to delay */
-     /*  msk: N/A */
-     /*  value: the unit of delay, 0: us, 1: ms */
-
-#define PWR_CMD_END                            0x04
-     /*  offset: N/A */
-     /*  msk: N/A */
-     /*  value: N/A */
-
-/*---------------------------------------------*/
-/* 3 The value of base: 4 bits */
-/*---------------------------------------------*/
-   /*  define the base address of each block */
-#define PWR_BASEADDR_MAC               0x00
-#define PWR_BASEADDR_USB               0x01
-#define PWR_BASEADDR_PCIE              0x02
-#define PWR_BASEADDR_SDIO              0x03
-
-/*---------------------------------------------*/
-/* 3 The value of interface_msk: 4 bits */
-/*---------------------------------------------*/
-#define        PWR_INTF_SDIO_MSK               BIT(0)
-#define        PWR_INTF_USB_MSK                BIT(1)
-#define        PWR_INTF_PCI_MSK                BIT(2)
-#define        PWR_INTF_ALL_MSK                (BIT(0)|BIT(1)|BIT(2)|BIT(3))
-
-/*---------------------------------------------*/
-/* 3 The value of fab_msk: 4 bits */
-/*---------------------------------------------*/
-#define        PWR_FAB_TSMC_MSK                BIT(0)
-#define        PWR_FAB_UMC_MSK                 BIT(1)
-#define        PWR_FAB_ALL_MSK                 (BIT(0)|BIT(1)|BIT(2)|BIT(3))
-
-/*---------------------------------------------*/
-/* 3 The value of cut_msk: 8 bits */
-/*---------------------------------------------*/
-#define        PWR_CUT_TESTCHIP_MSK    BIT(0)
-#define        PWR_CUT_A_MSK                   BIT(1)
-#define        PWR_CUT_B_MSK                   BIT(2)
-#define        PWR_CUT_C_MSK                   BIT(3)
-#define        PWR_CUT_D_MSK                   BIT(4)
-#define        PWR_CUT_E_MSK                   BIT(5)
-#define        PWR_CUT_F_MSK                   BIT(6)
-#define        PWR_CUT_G_MSK                   BIT(7)
-#define        PWR_CUT_ALL_MSK                 0xFF
-
-
-enum pwrseq_delay_unit {
-       PWRSEQ_DELAY_US,
-       PWRSEQ_DELAY_MS,
-};
-
-struct wlan_pwr_cfg {
-       u16 offset;
-       u8 cut_msk;
-       u8 fab_msk:4;
-       u8 interface_msk:4;
-       u8 base:4;
-       u8 cmd:4;
-       u8 msk;
-       u8 value;
-};
-
-
-#define GET_PWR_CFG_OFFSET(__PWR_CMD)          __PWR_CMD.offset
-#define GET_PWR_CFG_CUT_MASK(__PWR_CMD)                __PWR_CMD.cut_msk
-#define GET_PWR_CFG_FAB_MASK(__PWR_CMD)                __PWR_CMD.fab_msk
-#define GET_PWR_CFG_INTF_MASK(__PWR_CMD)       __PWR_CMD.interface_msk
-#define GET_PWR_CFG_BASE(__PWR_CMD)                    __PWR_CMD.base
-#define GET_PWR_CFG_CMD(__PWR_CMD)                     __PWR_CMD.cmd
-#define GET_PWR_CFG_MASK(__PWR_CMD)                    __PWR_CMD.msk
-#define GET_PWR_CFG_VALUE(__PWR_CMD)           __PWR_CMD.value
-
-
-/*  */
-/*     Prototype of protected function. */
-/*  */
-u8 HalPwrSeqCmdParsing23a(
-       struct rtw_adapter              *padapter,
-       u8                              CutVersion,
-       u8                              FabVersion,
-       u8                              InterfaceType,
-       struct wlan_pwr_cfg     PwrCfgCmd[]);
-
-#endif
diff --git a/drivers/staging/rtl8723au/include/HalVerDef.h b/drivers/staging/rtl8723au/include/HalVerDef.h
deleted file mode 100644 (file)
index 2a0e4ea..0000000
+++ /dev/null
@@ -1,114 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#ifndef __HAL_VERSION_DEF_H__
-#define __HAL_VERSION_DEF_H__
-
-enum hal_ic_type {
-       CHIP_8192S              =       0,
-       CHIP_8188C      =       1,
-       CHIP_8192C      =       2,
-       CHIP_8192D      =       3,
-       CHIP_8723A      =       4,
-       CHIP_8188E      =       5,
-       CHIP_8881A      =       6,
-       CHIP_8812A      =       7,
-       CHIP_8821A      =       8,
-       CHIP_8723B      =       9,
-       CHIP_8192E              =       10,
-};
-
-enum hal_chip_type {
-       TEST_CHIP               =       0,
-       NORMAL_CHIP             =       1,
-       FPGA                    =       2,
-};
-
-enum hal_cut_version {
-       A_CUT_VERSION           =       0,
-       B_CUT_VERSION           =       1,
-       C_CUT_VERSION           =       2,
-       D_CUT_VERSION           =       3,
-       E_CUT_VERSION           =       4,
-       F_CUT_VERSION           =       5,
-       G_CUT_VERSION           =       6,
-};
-
-/*  HAL_Manufacturer */
-enum hal_vendor {
-       CHIP_VENDOR_TSMC        =       0,
-       CHIP_VENDOR_UMC         =       1,
-};
-
-struct hal_version {
-       enum hal_ic_type        ICType;
-       enum hal_chip_type      ChipType;
-       enum hal_cut_version    CUTVersion;
-       enum hal_vendor         VendorType;
-       u8                      ROMVer;
-};
-
-/*  Get element */
-#define GET_CVID_IC_TYPE(version)      ((version).ICType)
-#define GET_CVID_CHIP_TYPE(version)    ((version).ChipType)
-#define GET_CVID_MANUFACTUER(version)  ((version).VendorType)
-#define GET_CVID_CUT_VERSION(version)  ((version).CUTVersion)
-#define GET_CVID_ROM_VERSION(version)  (((version).ROMVer) & ROM_VERSION_MASK)
-
-/* Common Macro. -- */
-
-#define IS_81XXC(version)                      \
-       (((GET_CVID_IC_TYPE(version) == CHIP_8192C) ||  \
-        (GET_CVID_IC_TYPE(version) == CHIP_8188C)) ? true : false)
-#define IS_8723_SERIES(version)                        \
-       ((GET_CVID_IC_TYPE(version) == CHIP_8723A) ? true : false)
-
-#define IS_TEST_CHIP(version)                  \
-       ((GET_CVID_CHIP_TYPE(version) == TEST_CHIP) ? true : false)
-#define IS_NORMAL_CHIP(version)                        \
-       ((GET_CVID_CHIP_TYPE(version) == NORMAL_CHIP) ? true : false)
-
-#define IS_A_CUT(version)                      \
-       ((GET_CVID_CUT_VERSION(version) == A_CUT_VERSION) ? true : false)
-#define IS_B_CUT(version)                      \
-       ((GET_CVID_CUT_VERSION(version) == B_CUT_VERSION) ? true : false)
-#define IS_C_CUT(version)                      \
-       ((GET_CVID_CUT_VERSION(version) == C_CUT_VERSION) ? true : false)
-#define IS_D_CUT(version)                      \
-       ((GET_CVID_CUT_VERSION(version) == D_CUT_VERSION) ? true : false)
-#define IS_E_CUT(version)                      \
-       ((GET_CVID_CUT_VERSION(version) == E_CUT_VERSION) ? true : false)
-
-#define IS_CHIP_VENDOR_TSMC(version)           \
-       ((GET_CVID_MANUFACTUER(version) == CHIP_VENDOR_TSMC) ? true : false)
-#define IS_CHIP_VENDOR_UMC(version)            \
-       ((GET_CVID_MANUFACTUER(version) == CHIP_VENDOR_UMC) ? true : false)
-
-/* Chip version Macro. -- */
-
-#define IS_81xxC_VENDOR_UMC_A_CUT(version)                     \
-       (IS_81XXC(version)?(IS_CHIP_VENDOR_UMC(version) ?       \
-       (IS_A_CUT(version) ? true : false) : false) : false)
-#define IS_81xxC_VENDOR_UMC_B_CUT(version)                     \
-       (IS_81XXC(version) ? (IS_CHIP_VENDOR_UMC(version) ?     \
-        (IS_B_CUT(version) ? true : false) : false): false)
-#define IS_81xxC_VENDOR_UMC_C_CUT(version)                     \
-       (IS_81XXC(version)?(IS_CHIP_VENDOR_UMC(version) ?       \
-       (IS_C_CUT(version) ? true : false) : false) : false)
-#define IS_8723A_A_CUT(version)                                \
-       ((IS_8723_SERIES(version)) ? (IS_A_CUT(version) ? true : false) : false)
-#define IS_8723A_B_CUT(version)                                        \
-       ((IS_8723_SERIES(version)) ? (IS_B_CUT(version) ? true : false) : false)
-
-#endif
diff --git a/drivers/staging/rtl8723au/include/drv_types.h b/drivers/staging/rtl8723au/include/drv_types.h
deleted file mode 100644 (file)
index e83463a..0000000
+++ /dev/null
@@ -1,274 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-/*-----------------------------------------------------------------------------
-
-       For type defines and data structure defines
-
-------------------------------------------------------------------------------*/
-
-
-#ifndef __DRV_TYPES_H__
-#define __DRV_TYPES_H__
-
-#include <osdep_service.h>
-#include <wlan_bssdef.h>
-
-
-enum _NIC_VERSION {
-       RTL8711_NIC,
-       RTL8712_NIC,
-       RTL8713_NIC,
-       RTL8716_NIC
-
-};
-
-
-#include <rtw_ht.h>
-
-#include <rtw_cmd.h>
-#include <rtw_xmit.h>
-#include <rtw_recv.h>
-#include <hal_intf.h>
-#include <hal_com.h>
-#include <rtw_security.h>
-#include <rtw_pwrctrl.h>
-#include <rtw_io.h>
-#include <rtw_eeprom.h>
-#include <sta_info.h>
-#include <rtw_mlme.h>
-#include <rtw_debug.h>
-#include <rtw_rf.h>
-#include <rtw_event.h>
-#include <rtw_mlme_ext.h>
-#include <rtw_ap.h>
-
-#include "ioctl_cfg80211.h"
-
-struct registry_priv {
-       u8      chip_version;
-       u8      rfintfs;
-       struct  cfg80211_ssid ssid;
-       u8      channel;/* ad-hoc support requirement */
-       u8      wireless_mode;/* A, B, G, auto */
-       u8      scan_mode;/* active, passive */
-       u8      preamble;/* long, short, auto */
-       u8      vrtl_carrier_sense;/* Enable, Disable, Auto */
-       u8      vcs_type;/* RTS/CTS, CTS-to-self */
-       u16     rts_thresh;
-       u16  frag_thresh;
-       u8      adhoc_tx_pwr;
-       u8      soft_ap;
-       u8      power_mgnt;
-       u8      ips_mode;
-       u8      smart_ps;
-       u8      long_retry_lmt;
-       u8      short_retry_lmt;
-       u16     busy_thresh;
-       u8      ack_policy;
-       u8      software_encrypt;
-       u8      software_decrypt;
-       u8      acm_method;
-         /* UAPSD */
-       u8      wmm_enable;
-       u8      uapsd_enable;
-
-       struct wlan_bssid_ex    dev_network;
-
-       u8      ht_enable;
-       u8      cbw40_enable;
-       u8      ampdu_enable;/* for tx */
-       u8      rx_stbc;
-       u8      ampdu_amsdu;/* A-MPDU Supports A-MSDU is permitted */
-       u8      lowrate_two_xmit;
-
-       u8      rf_config;
-       u8      low_power;
-
-       u8      wifi_spec;/*  !turbo_mode */
-
-       u8      channel_plan;
-#ifdef CONFIG_8723AU_BT_COEXIST
-       u8      btcoex;
-       u8      bt_iso;
-       u8      bt_sco;
-       u8      bt_ampdu;
-#endif
-       bool    bAcceptAddbaReq;
-
-       u8      antdiv_cfg;
-       u8      antdiv_type;
-
-       u8      hwpdn_mode;/* 0:disable,1:enable,2:decide by EFUSE config */
-       u8      hwpwrp_detect;/* 0:disable,1:enable */
-
-       u8      hw_wps_pbc;/* 0:disable,1:enable */
-
-       u8      max_roaming_times; /* max number driver will try to roaming */
-
-       u8 enable80211d;
-
-       u8 ifname[16];
-       u8 if2name[16];
-
-       u8 notch_filter;
-
-       u8 regulatory_tid;
-};
-
-
-#define MAX_CONTINUAL_URB_ERR 4
-
-#define GET_PRIMARY_ADAPTER(padapter)                                  \
-       (((struct rtw_adapter *)padapter)->dvobj->if1)
-
-enum _IFACE_ID {
-       IFACE_ID0, /* maping to PRIMARY_ADAPTER */
-       IFACE_ID1, /* maping to SECONDARY_ADAPTER */
-       IFACE_ID2,
-       IFACE_ID3,
-       IFACE_ID_MAX,
-};
-
-struct dvobj_priv {
-       struct rtw_adapter *if1; /* PRIMARY_ADAPTER */
-       struct rtw_adapter *if2; /* SECONDARY_ADAPTER */
-
-       /* for local/global synchronization */
-       struct mutex hw_init_mutex;
-       struct mutex h2c_fwcmd_mutex;
-       struct mutex setch_mutex;
-       struct mutex setbw_mutex;
-
-       unsigned char   oper_channel; /* saved chan info when set chan bw */
-       unsigned char   oper_bwmode;
-       unsigned char   oper_ch_offset;/* PRIME_CHNL_OFFSET */
-
-       struct rtw_adapter *padapters[IFACE_ID_MAX];
-       u8 iface_nums; /*  total number of ifaces used runtime */
-
-       /* For 92D, DMDP have 2 interface. */
-       u8      InterfaceNumber;
-       u8      NumInterfaces;
-
-       /* In /Out Pipe information */
-       int     RtInPipe[2];
-       int     RtOutPipe[3];
-       u8      Queue2Pipe[HW_QUEUE_ENTRY];/* for out pipe mapping */
-
-/*-------- below is for USB INTERFACE --------*/
-
-       u8      nr_endpoint;
-       u8      ishighspeed;
-       u8      RtNumInPipes;
-       u8      RtNumOutPipes;
-       int     ep_num[5]; /* endpoint number */
-
-       struct mutex usb_vendor_req_mutex;
-
-       union {
-               __le32 val32;
-               __le16 val16;
-               u8 val8;
-       } usb_buf;
-
-       struct usb_interface *pusbintf;
-       struct usb_device *pusbdev;
-       atomic_t continual_urb_error;
-
-/*-------- below is for PCIE INTERFACE --------*/
-
-};
-
-static inline struct device *dvobj_to_dev(struct dvobj_priv *dvobj)
-{
-       /* todo: get interface type from dvobj and the return the dev accordingly */
-       return &dvobj->pusbintf->dev;
-}
-
-enum _IFACE_TYPE {
-       IFACE_PORT0, /* mapping to port0 for C/D series chips */
-       IFACE_PORT1, /* mapping to port1 for C/D series chip */
-       MAX_IFACE_PORT,
-};
-
-enum _ADAPTER_TYPE {
-       PRIMARY_ADAPTER,
-       SECONDARY_ADAPTER,
-       MAX_ADAPTER,
-};
-
-struct rtw_adapter {
-       int     pid[3];/* process id from UI, 0:wps, 1:hostapd, 2:dhcpcd */
-       int     bDongle;/* build-in module or external dongle */
-       u16     chip_type;
-       u16     HardwareType;
-
-       struct dvobj_priv *dvobj;
-       struct  mlme_priv mlmepriv;
-       struct  mlme_ext_priv mlmeextpriv;
-       struct  cmd_priv        cmdpriv;
-       struct  evt_priv        evtpriv;
-       struct  xmit_priv       xmitpriv;
-       struct  recv_priv       recvpriv;
-       struct  sta_priv        stapriv;
-       struct  security_priv   securitypriv;
-       struct  registry_priv   registrypriv;
-       struct  pwrctrl_priv    pwrctrlpriv;
-       struct  eeprom_priv eeprompriv;
-
-       u32     setband;
-
-       void *HalData;
-
-       s32     bDriverStopped;
-       s32     bSurpriseRemoved;
-       s32  bCardDisableWOHSM;
-
-       u32     IsrContent;
-       u32     ImrContent;
-
-       u8      EepromAddressSize;
-       u8      hw_init_completed;
-       u8      bDriverIsGoingToUnload;
-       u8      init_adpt_in_progress;
-       u8      bHaltInProgress;
-
-       struct net_device *pnetdev;
-
-       /*  used by rtw_rereg_nd_name related function */
-       int bup;
-       struct net_device_stats stats;
-
-       struct wireless_dev *rtw_wdev;
-       int net_closed;
-
-       u8 bFWReady;
-       u8 bReadPortCancel;
-       u8 bWritePortCancel;
-
-       /* extend to support multi interface */
-       /* IFACE_ID0 is equals to PRIMARY_ADAPTER */
-       /* IFACE_ID1 is equals to SECONDARY_ADAPTER */
-       u8 iface_id;
-};
-
-#define adapter_to_dvobj(adapter) (adapter->dvobj)
-
-static inline u8 *myid(struct eeprom_priv *peepriv)
-{
-       return peepriv->mac_addr;
-}
-
-#endif /* __DRV_TYPES_H__ */
diff --git a/drivers/staging/rtl8723au/include/hal_com.h b/drivers/staging/rtl8723au/include/hal_com.h
deleted file mode 100644 (file)
index 9c50320..0000000
+++ /dev/null
@@ -1,182 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#ifndef __HAL_COMMON_H__
-#define __HAL_COMMON_H__
-
-/*  */
-/*        Rate Definition */
-/*  */
-/* CCK */
-#define        RATR_1M                                 0x00000001
-#define        RATR_2M                                 0x00000002
-#define        RATR_55M                                0x00000004
-#define        RATR_11M                                0x00000008
-/* OFDM */
-#define        RATR_6M                                 0x00000010
-#define        RATR_9M                                 0x00000020
-#define        RATR_12M                                0x00000040
-#define        RATR_18M                                0x00000080
-#define        RATR_24M                                0x00000100
-#define        RATR_36M                                0x00000200
-#define        RATR_48M                                0x00000400
-#define        RATR_54M                                0x00000800
-/* MCS 1 Spatial Stream */
-#define        RATR_MCS0                               0x00001000
-#define        RATR_MCS1                               0x00002000
-#define        RATR_MCS2                               0x00004000
-#define        RATR_MCS3                               0x00008000
-#define        RATR_MCS4                               0x00010000
-#define        RATR_MCS5                               0x00020000
-#define        RATR_MCS6                               0x00040000
-#define        RATR_MCS7                               0x00080000
-/* MCS 2 Spatial Stream */
-#define        RATR_MCS8                               0x00100000
-#define        RATR_MCS9                               0x00200000
-#define        RATR_MCS10                              0x00400000
-#define        RATR_MCS11                              0x00800000
-#define        RATR_MCS12                              0x01000000
-#define        RATR_MCS13                              0x02000000
-#define        RATR_MCS14                              0x04000000
-#define        RATR_MCS15                              0x08000000
-
-/* CCK */
-#define RATE_1M                                        BIT(0)
-#define RATE_2M                                        BIT(1)
-#define RATE_5_5M                              BIT(2)
-#define RATE_11M                               BIT(3)
-/* OFDM */
-#define RATE_6M                                        BIT(4)
-#define RATE_9M                                        BIT(5)
-#define RATE_12M                               BIT(6)
-#define RATE_18M                               BIT(7)
-#define RATE_24M                               BIT(8)
-#define RATE_36M                               BIT(9)
-#define RATE_48M                               BIT(10)
-#define RATE_54M                               BIT(11)
-
-/*------------------------------ Tx Desc definition Macro ------------------------*/
-/* pragma mark -- Tx Desc related definition. -- */
-/*  */
-/*  */
-/*     Rate */
-/*  */
-/*  CCK Rates, TxHT = 0 */
-#define DESC_RATE1M                            0x00
-#define DESC_RATE2M                            0x01
-#define DESC_RATE5_5M                          0x02
-#define DESC_RATE11M                           0x03
-
-/*  OFDM Rates, TxHT = 0 */
-#define DESC_RATE6M                            0x04
-#define DESC_RATE9M                            0x05
-#define DESC_RATE12M                           0x06
-#define DESC_RATE18M                           0x07
-#define DESC_RATE24M                           0x08
-#define DESC_RATE36M                           0x09
-#define DESC_RATE48M                           0x0a
-#define DESC_RATE54M                           0x0b
-
-/*  MCS Rates, TxHT = 1 */
-#define DESC_RATEMCS0                          0x0c
-#define DESC_RATEMCS1                          0x0d
-#define DESC_RATEMCS2                          0x0e
-#define DESC_RATEMCS3                          0x0f
-#define DESC_RATEMCS4                          0x10
-#define DESC_RATEMCS5                          0x11
-#define DESC_RATEMCS6                          0x12
-#define DESC_RATEMCS7                          0x13
-#define DESC_RATEMCS8                          0x14
-#define DESC_RATEMCS9                          0x15
-#define DESC_RATEMCS10                         0x16
-#define DESC_RATEMCS11                         0x17
-#define DESC_RATEMCS12                         0x18
-#define DESC_RATEMCS13                         0x19
-#define DESC_RATEMCS14                         0x1a
-#define DESC_RATEMCS15                         0x1b
-#define DESC_RATEMCS15_SG                      0x1c
-#define DESC_RATEMCS32                         0x20
-
-#define REG_P2P_CTWIN                                  0x0572 /*  1 Byte long (in unit of TU) */
-#define REG_NOA_DESC_SEL                               0x05CF
-#define REG_NOA_DESC_DURATION          0x05E0
-#define REG_NOA_DESC_INTERVAL                  0x05E4
-#define REG_NOA_DESC_START                     0x05E8
-#define REG_NOA_DESC_COUNT                     0x05EC
-
-#include "HalVerDef.h"
-
-
-u8     /* return the final channel plan decision */
-hal_com_get_channel_plan23a(
-       struct rtw_adapter      *padapter,
-       u8                      hw_channel_plan,        /* channel plan from HW (efuse/eeprom) */
-       u8                      sw_channel_plan,        /* channel plan from SW (registry/module param) */
-       u8                      def_channel_plan,       /* channel plan used when the former two is invalid */
-       bool            AutoLoadFail
-       );
-
-u8     MRateToHwRate23a(u8 rate);
-
-void HalSetBrateCfg23a(struct rtw_adapter *padapter, u8 *mBratesOS);
-
-bool
-Hal_MappingOutPipe23a(struct rtw_adapter *pAdapter, u8 NumOutPipe);
-
-void c2h_evt_clear23a(struct rtw_adapter *adapter);
-s32 c2h_evt_read23a(struct rtw_adapter *adapter, u8 *buf);
-
-void rtl8723a_set_ampdu_min_space(struct rtw_adapter *padapter, u8 MinSpacingToSet);
-void rtl8723a_set_ampdu_factor(struct rtw_adapter *padapter, u8 FactorToSet);
-void rtl8723a_set_acm_ctrl(struct rtw_adapter *padapter, u8 ctrl);
-void rtl8723a_set_media_status(struct rtw_adapter *padapter, u8 status);
-void rtl8723a_set_media_status1(struct rtw_adapter *padapter, u8 status);
-void rtl8723a_set_bcn_func(struct rtw_adapter *padapter, u8 val);
-void rtl8723a_check_bssid(struct rtw_adapter *padapter, u8 val);
-void rtl8723a_mlme_sitesurvey(struct rtw_adapter *padapter, u8 flag);
-void rtl8723a_on_rcr_am(struct rtw_adapter *padapter);
-void rtl8723a_off_rcr_am(struct rtw_adapter *padapter);
-void rtl8723a_set_slot_time(struct rtw_adapter *padapter, u8 slottime);
-void rtl8723a_ack_preamble(struct rtw_adapter *padapter, u8 bShortPreamble);
-void rtl8723a_set_sec_cfg(struct rtw_adapter *padapter, u8 sec);
-void rtl8723a_cam_empty_entry(struct rtw_adapter *padapter, u8 ucIndex);
-void rtl8723a_cam_invalidate_all(struct rtw_adapter *padapter);
-void rtl8723a_cam_write(struct rtw_adapter *padapter,
-                       u8 entry, u16 ctrl, const u8 *mac, const u8 *key);
-void rtl8723a_fifo_cleanup(struct rtw_adapter *padapter);
-void rtl8723a_set_apfm_on_mac(struct rtw_adapter *padapter, u8 val);
-void rtl8723a_bcn_valid(struct rtw_adapter *padapter);
-bool rtl8723a_get_bcn_valid(struct rtw_adapter *padapter);
-void rtl8723a_set_beacon_interval(struct rtw_adapter *padapter, u16 interval);
-void rtl8723a_set_resp_sifs(struct rtw_adapter *padapter,
-                           u8 r2t1, u8 r2t2, u8 t2t1, u8 t2t2);
-void rtl8723a_set_ac_param_vo(struct rtw_adapter *padapter, u32 vo);
-void rtl8723a_set_ac_param_vi(struct rtw_adapter *padapter, u32 vi);
-void rtl8723a_set_ac_param_be(struct rtw_adapter *padapter, u32 be);
-void rtl8723a_set_ac_param_bk(struct rtw_adapter *padapter, u32 bk);
-void rtl8723a_set_rxdma_agg_pg_th(struct rtw_adapter *padapter, u8 val);
-void rtl8723a_set_initial_gain(struct rtw_adapter *padapter, u32 rx_gain);
-
-void rtl8723a_odm_support_ability_write(struct rtw_adapter *padapter, u32 val);
-void rtl8723a_odm_support_ability_backup(struct rtw_adapter *padapter);
-void rtl8723a_odm_support_ability_restore(struct rtw_adapter *padapter);
-void rtl8723a_odm_support_ability_set(struct rtw_adapter *padapter, u32 val);
-void rtl8723a_odm_support_ability_clr(struct rtw_adapter *padapter, u32 val);
-
-void rtl8723a_set_rpwm(struct rtw_adapter *padapter, u8 val);
-u8 rtl8723a_get_rf_type(struct rtw_adapter *padapter);
-bool rtl8723a_get_fwlps_rf_on(struct rtw_adapter *padapter);
-bool rtl8723a_chk_hi_queue_empty(struct rtw_adapter *padapter);
-
-#endif /* __HAL_COMMON_H__ */
diff --git a/drivers/staging/rtl8723au/include/hal_intf.h b/drivers/staging/rtl8723au/include/hal_intf.h
deleted file mode 100644 (file)
index b924d47..0000000
+++ /dev/null
@@ -1,115 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#ifndef __HAL_INTF_H__
-#define __HAL_INTF_H__
-
-#include <osdep_service.h>
-#include <drv_types.h>
-
-enum _CHIP_TYPE {
-       NULL_CHIP_TYPE,
-       RTL8712_8188S_8191S_8192S,
-       RTL8188C_8192C,
-       RTL8192D,
-       RTL8723A,
-       RTL8188E,
-       MAX_CHIP_TYPE
-};
-
-enum hal_def_variable {
-       HAL_DEF_UNDERCORATEDSMOOTHEDPWDB,
-       HAL_DEF_IS_SUPPORT_ANT_DIV,
-       HAL_DEF_CURRENT_ANTENNA,
-       HAL_DEF_DRVINFO_SZ,
-       HAL_DEF_MAX_RECVBUF_SZ,
-       HAL_DEF_RX_PACKET_OFFSET,
-       HAL_DEF_DBG_DUMP_RXPKT,/* for dbg */
-       HAL_DEF_DBG_DM_FUNC,/* for dbg */
-       HAL_DEF_RA_DECISION_RATE,
-       HAL_DEF_RA_SGI,
-       HAL_DEF_PT_PWR_STATUS,
-       HW_VAR_MAX_RX_AMPDU_FACTOR,
-       HW_DEF_RA_INFO_DUMP,
-       HAL_DEF_DBG_DUMP_TXPKT,
-       HW_DEF_FA_CNT_DUMP,
-       HW_DEF_ODM_DBG_FLAG,
-};
-
-enum hal_odm_variable {
-       HAL_ODM_STA_INFO,
-       HAL_ODM_P2P_STATE,
-       HAL_ODM_WIFI_DISPLAY_STATE,
-};
-
-enum rt_eeprom_type {
-       EEPROM_93C46,
-       EEPROM_93C56,
-       EEPROM_BOOT_EFUSE,
-};
-
-
-
-#define RF_CHANGE_BY_INIT      0
-#define RF_CHANGE_BY_IPS       BIT(28)
-#define RF_CHANGE_BY_PS                BIT(29)
-#define RF_CHANGE_BY_HW                BIT(30)
-#define RF_CHANGE_BY_SW                BIT(31)
-
-enum hardware_type {
-       HARDWARE_TYPE_RTL8180,
-       HARDWARE_TYPE_RTL8185,
-       HARDWARE_TYPE_RTL8187,
-       HARDWARE_TYPE_RTL8188,
-       HARDWARE_TYPE_RTL8190P,
-       HARDWARE_TYPE_RTL8192E,
-       HARDWARE_TYPE_RTL819xU,
-       HARDWARE_TYPE_RTL8192SE,
-       HARDWARE_TYPE_RTL8192SU,
-       HARDWARE_TYPE_RTL8192CE,
-       HARDWARE_TYPE_RTL8192CU,
-       HARDWARE_TYPE_RTL8192DE,
-       HARDWARE_TYPE_RTL8192DU,
-       HARDWARE_TYPE_RTL8723AE,
-       HARDWARE_TYPE_RTL8723AU,
-       HARDWARE_TYPE_RTL8723AS,
-       HARDWARE_TYPE_RTL8188EE,
-       HARDWARE_TYPE_RTL8188EU,
-       HARDWARE_TYPE_RTL8188ES,
-       HARDWARE_TYPE_MAX,
-};
-
-#define GET_EEPROM_EFUSE_PRIV(adapter) (&adapter->eeprompriv)
-
-void rtw_hal_def_value_init23a(struct rtw_adapter *padapter);
-int pm_netdev_open23a(struct net_device *pnetdev, u8 bnormal);
-
-int rtl8723au_hal_init(struct rtw_adapter *padapter);
-int rtl8723au_hal_deinit(struct rtw_adapter *padapter);
-void rtw_hal_stop(struct rtw_adapter *padapter);
-
-void rtw_hal_update_ra_mask23a(struct sta_info *psta, u8 rssi_level);
-void   rtw_hal_clone_data(struct rtw_adapter *dst_padapter, struct rtw_adapter *src_padapter);
-
-void hw_var_set_correct_tsf(struct rtw_adapter *padapter);
-void hw_var_set_mlme_disconnect(struct rtw_adapter *padapter);
-void hw_var_set_opmode(struct rtw_adapter *padapter, u8 mode);
-void hw_var_set_macaddr(struct rtw_adapter *padapter, u8 *val);
-void hw_var_set_bssid(struct rtw_adapter *padapter, u8 *val);
-void hw_var_set_mlme_join(struct rtw_adapter *padapter, u8 type);
-
-int GetHalDefVar8192CUsb(struct rtw_adapter *Adapter,
-                        enum hal_def_variable eVariable, void *pValue);
-
-#endif /* __HAL_INTF_H__ */
diff --git a/drivers/staging/rtl8723au/include/ieee80211.h b/drivers/staging/rtl8723au/include/ieee80211.h
deleted file mode 100644 (file)
index 634102e..0000000
+++ /dev/null
@@ -1,341 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#ifndef __IEEE80211_H
-#define __IEEE80211_H
-
-#include <osdep_service.h>
-#include <drv_types.h>
-#include "linux/ieee80211.h"
-#include "wifi.h"
-
-#include <linux/wireless.h>
-
-#if (WIRELESS_EXT < 22)
-#error "Obsolete pre 2007 wireless extensions are not supported"
-#endif
-
-
-#ifdef CONFIG_8723AU_AP_MODE
-
-/* STA flags */
-#define WLAN_STA_AUTH BIT(0)
-#define WLAN_STA_ASSOC BIT(1)
-#define WLAN_STA_PS BIT(2)
-#define WLAN_STA_TIM BIT(3)
-#define WLAN_STA_PERM BIT(4)
-#define WLAN_STA_AUTHORIZED BIT(5)
-#define WLAN_STA_PENDING_POLL BIT(6) /* pending activity poll not ACKed */
-#define WLAN_STA_SHORT_PREAMBLE BIT(7)
-#define WLAN_STA_PREAUTH BIT(8)
-#define WLAN_STA_WME BIT(9)
-#define WLAN_STA_MFP BIT(10)
-#define WLAN_STA_HT BIT(11)
-#define WLAN_STA_WPS BIT(12)
-#define WLAN_STA_MAYBE_WPS BIT(13)
-#define WLAN_STA_NONERP BIT(31)
-
-#endif
-
-#define WPA_CIPHER_NONE                BIT(0)
-#define WPA_CIPHER_WEP40       BIT(1)
-#define WPA_CIPHER_WEP104      BIT(2)
-#define WPA_CIPHER_TKIP                BIT(3)
-#define WPA_CIPHER_CCMP                BIT(4)
-
-
-
-#define WPA_SELECTOR_LEN 4
-extern u8 RTW_WPA_OUI23A_TYPE[] ;
-extern u16 RTW_WPA_VERSION23A ;
-extern u8 WPA_AUTH_KEY_MGMT_NONE23A[];
-extern u8 WPA_AUTH_KEY_MGMT_UNSPEC_802_1X23A[];
-extern u8 WPA_AUTH_KEY_MGMT_PSK_OVER_802_1X23A[];
-extern u8 WPA_CIPHER_SUITE_NONE23A[];
-extern u8 WPA_CIPHER_SUITE_WEP4023A[];
-extern u8 WPA_CIPHER_SUITE_TKIP23A[];
-extern u8 WPA_CIPHER_SUITE_WRAP23A[];
-extern u8 WPA_CIPHER_SUITE_CCMP23A[];
-extern u8 WPA_CIPHER_SUITE_WEP10423A[];
-
-
-#define RSN_HEADER_LEN 4
-#define RSN_SELECTOR_LEN 4
-
-extern u8 RSN_AUTH_KEY_MGMT_UNSPEC_802_1X23A[];
-extern u8 RSN_AUTH_KEY_MGMT_PSK_OVER_802_1X23A[];
-extern u8 RSN_CIPHER_SUITE_NONE23A[];
-extern u8 RSN_CIPHER_SUITE_WEP4023A[];
-extern u8 RSN_CIPHER_SUITE_TKIP23A[];
-extern u8 RSN_CIPHER_SUITE_WRAP23A[];
-extern u8 RSN_CIPHER_SUITE_CCMP23A[];
-extern u8 RSN_CIPHER_SUITE_WEP10423A[];
-
-enum ratr_table_mode {
-       RATR_INX_WIRELESS_NGB = 0,      /*  BGN 40 Mhz 2SS 1SS */
-       RATR_INX_WIRELESS_NG = 1,       /*  GN or N */
-       RATR_INX_WIRELESS_NB = 2,       /*  BGN 20 Mhz 2SS 1SS  or BN */
-       RATR_INX_WIRELESS_N = 3,
-       RATR_INX_WIRELESS_GB = 4,
-       RATR_INX_WIRELESS_G = 5,
-       RATR_INX_WIRELESS_B = 6,
-       RATR_INX_WIRELESS_MC = 7,
-       RATR_INX_WIRELESS_AC_N = 8,
-};
-
-enum NETWORK_TYPE
-{
-       WIRELESS_INVALID = 0,
-       /* Sub-Element */
-       /*  tx: cck only , rx: cck only, hw: cck */
-       WIRELESS_11B = BIT(0),
-       /*  tx: ofdm only, rx: ofdm & cck, hw: cck & ofdm */
-       WIRELESS_11G = BIT(1),
-       /*  tx: ofdm only, rx: ofdm only, hw: ofdm only */
-       WIRELESS_11A = BIT(2),
-       /*  tx: MCS only, rx: MCS & cck, hw: MCS & cck */
-       WIRELESS_11_24N = BIT(3),
-       /*  tx: MCS only, rx: MCS & ofdm, hw: ofdm only */
-       WIRELESS_11_5N = BIT(4),
-       /* WIRELESS_AUTO                = BIT(5), */
-       WIRELESS_AC = BIT(6),
-
-       /* Combination */
-        /*  tx: cck & ofdm, rx: cck & ofdm & MCS, hw: cck & ofdm */
-       WIRELESS_11BG = WIRELESS_11B|WIRELESS_11G,
-       /*  tx: ofdm & MCS, rx: ofdm & cck & MCS, hw: cck & ofdm */
-       WIRELESS_11G_24N = WIRELESS_11G | WIRELESS_11_24N,
-       /*  tx: ofdm & MCS, rx: ofdm & MCS, hw: ofdm only */
-       WIRELESS_11A_5N = WIRELESS_11A | WIRELESS_11_5N,
-       /*  tx: ofdm & cck & MCS, rx: ofdm & cck & MCS, hw: ofdm & cck */
-       WIRELESS_11BG_24N = WIRELESS_11B | WIRELESS_11G | WIRELESS_11_24N,
-       /*  tx: ofdm & MCS, rx: ofdm & MCS, hw: ofdm only */
-       WIRELESS_11AGN = WIRELESS_11A | WIRELESS_11G | WIRELESS_11_24N |
-                               WIRELESS_11_5N,
-       WIRELESS_11ABGN = WIRELESS_11A | WIRELESS_11B | WIRELESS_11G |
-                               WIRELESS_11_24N | WIRELESS_11_5N,
-};
-
-#define SUPPORTED_24G_NETTYPE_MSK (WIRELESS_11B | WIRELESS_11G | WIRELESS_11_24N)
-#define SUPPORTED_5G_NETTYPE_MSK (WIRELESS_11A | WIRELESS_11_5N)
-
-#define IsSupported24G(NetType) (NetType & SUPPORTED_24G_NETTYPE_MSK ? true : false)
-#define IsSupported5G(NetType) (NetType & SUPPORTED_5G_NETTYPE_MSK ? true : false)
-
-#define IsEnableHWCCK(NetType) IsSupported24G(NetType)
-#define IsEnableHWOFDM(NetType) (NetType & (WIRELESS_11G|WIRELESS_11_24N|SUPPORTED_5G_NETTYPE_MSK) ? true : false)
-
-#define IsSupportedRxCCK(NetType) IsEnableHWCCK(NetType)
-#define IsSupportedRxOFDM(NetType) IsEnableHWOFDM(NetType)
-#define IsSupportedRxMCS(NetType) IsEnableHWOFDM(NetType)
-
-#define IsSupportedTxCCK(NetType) (NetType & (WIRELESS_11B) ? true : false)
-#define IsSupportedTxOFDM(NetType) (NetType & (WIRELESS_11G|WIRELESS_11A) ? true : false)
-#define IsSupportedTxMCS(NetType) (NetType & (WIRELESS_11_24N|WIRELESS_11_5N) ? true : false)
-
-
-#define MIN_FRAG_THRESHOLD     256U
-#define        MAX_FRAG_THRESHOLD     2346U
-
-/* QoS,QOS */
-#define NORMAL_ACK                     0
-#define NO_ACK                         1
-#define NON_EXPLICIT_ACK               2
-#define BLOCK_ACK                      3
-
-/* IEEE 802.11 defines */
-
-#define P80211_OUI_LEN 3
-
-struct ieee80211_snap_hdr {
-       u8    dsap;   /* always 0xAA */
-       u8    ssap;   /* always 0xAA */
-       u8    ctrl;   /* always 0x03 */
-       u8    oui[P80211_OUI_LEN];    /* organizational universal id */
-} __attribute__ ((packed));
-
-
-#define SNAP_SIZE sizeof(struct ieee80211_snap_hdr)
-
-#define WLAN_REASON_JOIN_WRONG_CHANNEL       65534
-#define WLAN_REASON_EXPIRATION_CHK 65535
-
-#define IEEE80211_CCK_RATE_LEN                 4
-#define IEEE80211_NUM_OFDM_RATESLEN    8
-
-
-#define IEEE80211_CCK_RATE_1MB                 0x02
-#define IEEE80211_CCK_RATE_2MB                 0x04
-#define IEEE80211_CCK_RATE_5MB                 0x0B
-#define IEEE80211_CCK_RATE_11MB                        0x16
-#define IEEE80211_OFDM_RATE_LEN                        8
-#define IEEE80211_OFDM_RATE_6MB                        0x0C
-#define IEEE80211_OFDM_RATE_9MB                        0x12
-#define IEEE80211_OFDM_RATE_12MB               0x18
-#define IEEE80211_OFDM_RATE_18MB               0x24
-#define IEEE80211_OFDM_RATE_24MB               0x30
-#define IEEE80211_OFDM_RATE_36MB               0x48
-#define IEEE80211_OFDM_RATE_48MB               0x60
-#define IEEE80211_OFDM_RATE_54MB               0x6C
-#define IEEE80211_BASIC_RATE_MASK              0x80
-
-#define IEEE80211_CCK_RATE_1MB_MASK            (1<<0)
-#define IEEE80211_CCK_RATE_2MB_MASK            (1<<1)
-#define IEEE80211_CCK_RATE_5MB_MASK            (1<<2)
-#define IEEE80211_CCK_RATE_11MB_MASK           (1<<3)
-#define IEEE80211_OFDM_RATE_6MB_MASK           (1<<4)
-#define IEEE80211_OFDM_RATE_9MB_MASK           (1<<5)
-#define IEEE80211_OFDM_RATE_12MB_MASK          (1<<6)
-#define IEEE80211_OFDM_RATE_18MB_MASK          (1<<7)
-#define IEEE80211_OFDM_RATE_24MB_MASK          (1<<8)
-#define IEEE80211_OFDM_RATE_36MB_MASK          (1<<9)
-#define IEEE80211_OFDM_RATE_48MB_MASK          (1<<10)
-#define IEEE80211_OFDM_RATE_54MB_MASK          (1<<11)
-
-#define IEEE80211_CCK_RATES_MASK               0x0000000F
-#define IEEE80211_CCK_BASIC_RATES_MASK (IEEE80211_CCK_RATE_1MB_MASK | \
-       IEEE80211_CCK_RATE_2MB_MASK)
-#define IEEE80211_CCK_DEFAULT_RATES_MASK       (IEEE80211_CCK_BASIC_RATES_MASK | \
-       IEEE80211_CCK_RATE_5MB_MASK | \
-       IEEE80211_CCK_RATE_11MB_MASK)
-
-#define IEEE80211_OFDM_RATES_MASK              0x00000FF0
-#define IEEE80211_OFDM_BASIC_RATES_MASK        (IEEE80211_OFDM_RATE_6MB_MASK | \
-       IEEE80211_OFDM_RATE_12MB_MASK | \
-       IEEE80211_OFDM_RATE_24MB_MASK)
-#define IEEE80211_OFDM_DEFAULT_RATES_MASK      (IEEE80211_OFDM_BASIC_RATES_MASK | \
-       IEEE80211_OFDM_RATE_9MB_MASK  | \
-       IEEE80211_OFDM_RATE_18MB_MASK | \
-       IEEE80211_OFDM_RATE_36MB_MASK | \
-       IEEE80211_OFDM_RATE_48MB_MASK | \
-       IEEE80211_OFDM_RATE_54MB_MASK)
-#define IEEE80211_DEFAULT_RATES_MASK (IEEE80211_OFDM_DEFAULT_RATES_MASK | \
-                                     IEEE80211_CCK_DEFAULT_RATES_MASK)
-
-#define IEEE80211_NUM_OFDM_RATES           8
-#define IEEE80211_NUM_CCK_RATES                    4
-#define IEEE80211_OFDM_SHIFT_MASK_A         4
-
-#define WEP_KEYS 4
-
-
-/* MAX_RATES_LENGTH needs to be 12.  The spec says 8, and many APs
- * only use 8, and then use extended rates for the remaining supported
- * rates.  Other APs, however, stick all of their supported rates on the
- * main rates information element... */
-#define MAX_RATES_LENGTH       12
-#define MAX_RATES_EX_LENGTH    16
-#define MAX_CHANNEL_NUMBER     161
-#define RTW_CH_MAX_2G_CHANNEL  14      /* Max channel in 2G band */
-
-#define MAX_WPA_IE_LEN         256
-#define MAX_WPS_IE_LEN         256
-#define MAX_P2P_IE_LEN         256
-#define MAX_WFD_IE_LEN         128
-
-/*
-join_res:
--1: authentication fail
--2: association fail
-> 0: TID
-*/
-
-#define MAXTID 16
-
-#define WME_OUI_TYPE 2
-#define WME_OUI_SUBTYPE_INFORMATION_ELEMENT 0
-#define WME_OUI_SUBTYPE_PARAMETER_ELEMENT 1
-#define WME_OUI_SUBTYPE_TSPEC_ELEMENT 2
-#define WME_VERSION 1
-
-
-#define OUI_BROADCOM 0x00904c /* Broadcom (Epigram) */
-
-#define VENDOR_HT_CAPAB_OUI_TYPE 0x33 /* 00-90-4c:0x33 */
-
-/* Represent channel details, subset of ieee80211_channel */
-struct rtw_ieee80211_channel {
-       /* enum nl80211_band band; */
-       /* u16 center_freq; */
-       u16 hw_value;
-       u32 flags;
-       /* int max_antenna_gain; */
-       /* int max_power; */
-       /* int max_reg_power; */
-       /* bool beacon_found; */
-       /* u32 orig_flags; */
-       /* int orig_mag; */
-       /* int orig_mpwr; */
-};
-
-#define CHAN_FMT \
-       /*"band:%d, "*/ \
-       /*"center_freq:%u, "*/ \
-       "hw_value:%u, " \
-       "flags:0x%08x" \
-       /*"max_antenna_gain:%d\n"*/ \
-       /*"max_power:%d\n"*/ \
-       /*"max_reg_power:%d\n"*/ \
-       /*"beacon_found:%u\n"*/ \
-       /*"orig_flags:0x%08x\n"*/ \
-       /*"orig_mag:%d\n"*/ \
-       /*"orig_mpwr:%d\n"*/
-
-#define CHAN_ARG(channel) \
-       /*(channel)->band*/ \
-       /*, (channel)->center_freq*/ \
-       (channel)->hw_value \
-       , (channel)->flags \
-       /*, (channel)->max_antenna_gain*/ \
-       /*, (channel)->max_power*/ \
-       /*, (channel)->max_reg_power*/ \
-       /*, (channel)->beacon_found*/ \
-       /*, (channel)->orig_flags*/ \
-       /*, (channel)->orig_mag*/ \
-       /*, (channel)->orig_mpwr*/ \
-
-u8 *rtw_set_ie23a(u8 *pbuf, int index, uint len, const u8 *source, uint *frlen);
-
-u8 hal_ch_offset_to_secondary_ch_offset23a(u8 ch_offset);
-u8 *rtw_set_ie23a_ch_switch(u8 *buf, u32 *buf_len, u8 ch_switch_mode, u8 new_ch, u8 ch_switch_cnt);
-u8 *rtw_set_ie23a_secondary_ch_offset(u8 *buf, u32 *buf_len, u8 secondary_ch_offset);
-
-u8 *rtw_get_ie23a(u8*pbuf, int index, int *len, int limit);
-u8 *rtw_get_ie23a_ex(u8 *in_ie, uint in_len, u8 eid, u8 *oui, u8 oui_len, u8 *ie, uint *ielen);
-int rtw_ies_remove_ie23a(u8 *ies, uint *ies_len, uint offset, u8 eid, u8 *oui, u8 oui_len);
-
-void rtw_set_supported_rate23a(u8 *SupportedRates, uint mode);
-
-int rtw_parse_wpa_ie23a(const u8* wpa_ie, int wpa_ie_len, int *group_cipher, int *pairwise_cipher, int *is_8021x);
-int rtw_parse_wpa2_ie23a(const u8* wpa_ie, int wpa_ie_len, int *group_cipher, int *pairwise_cipher, int *is_8021x);
-
-const u8 *rtw_get_wps_attr23a(const u8 *wps_ie, uint wps_ielen, u16 target_attr_id ,u8 *buf_attr, u32 *len_attr);
-const u8 *rtw_get_wps_attr_content23a(const u8 *wps_ie, uint wps_ielen, u16 target_attr_id ,u8 *buf_content);
-
-uint   rtw_get_rateset_len23a(u8       *rateset);
-
-struct registry_priv;
-int rtw_generate_ie23a(struct registry_priv *pregistrypriv);
-
-
-int rtw_get_bit_value_from_ieee_value23a(u8 val);
-
-int rtw_check_network_type23a(unsigned char *rate, int ratelen, int channel);
-
-void rtw_get_bcn_info23a(struct wlan_network *pnetwork);
-
-u16 rtw_mcs_rate23a(u8 rf_type, u8 bw_40MHz, u8 short_GI_20, u8 short_GI_40,
-                   struct ieee80211_mcs_info *mcs);
-
-#endif /* IEEE80211_H */
diff --git a/drivers/staging/rtl8723au/include/ioctl_cfg80211.h b/drivers/staging/rtl8723au/include/ioctl_cfg80211.h
deleted file mode 100644 (file)
index 3a4ead5..0000000
+++ /dev/null
@@ -1,66 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#ifndef __IOCTL_CFG80211_H__
-#define __IOCTL_CFG80211_H__
-
-struct rtw_wdev_priv {
-       struct wireless_dev *rtw_wdev;
-
-       struct rtw_adapter *padapter;
-
-       struct cfg80211_scan_request *scan_request;
-       spinlock_t scan_req_lock;
-
-       struct net_device *pmon_ndev;/* for monitor interface */
-       char ifname_mon[IFNAMSIZ + 1]; /* name for monitor interface */
-
-       u8 p2p_enabled;
-
-       bool power_mgmt;
-};
-
-#define wdev_to_priv(w) ((struct rtw_wdev_priv *)(wdev_priv(w)))
-
-#define wiphy_to_adapter(x)                                    \
-       (struct rtw_adapter *)(((struct rtw_wdev_priv *)        \
-       wiphy_priv(x))->padapter)
-
-#define wiphy_to_wdev(x)                                       \
-       (struct wireless_dev *)(((struct rtw_wdev_priv *)       \
-       wiphy_priv(x))->rtw_wdev)
-
-int rtw_wdev_alloc(struct rtw_adapter *padapter, struct device *dev);
-void rtw_wdev_free(struct wireless_dev *wdev);
-void rtw_wdev_unregister(struct wireless_dev *wdev);
-
-void rtw_cfg80211_init_wiphy(struct rtw_adapter *padapter);
-
-void rtw_cfg80211_surveydone_event_callback(struct rtw_adapter *padapter);
-
-void rtw_cfg80211_indicate_connect(struct rtw_adapter *padapter);
-void rtw_cfg80211_indicate_disconnect(struct rtw_adapter *padapter);
-void rtw_cfg80211_indicate_scan_done(struct rtw_wdev_priv *pwdev_priv,
-                                    bool aborted);
-
-#ifdef CONFIG_8723AU_AP_MODE
-void rtw_cfg80211_indicate_sta_assoc(struct rtw_adapter *padapter,
-                                    u8 *pmgmt_frame, uint frame_len);
-void rtw_cfg80211_indicate_sta_disassoc(struct rtw_adapter *padapter,
-                                       unsigned char *da, unsigned short reason);
-#endif /* CONFIG_8723AU_AP_MODE */
-
-bool rtw_cfg80211_pwr_mgmt(struct rtw_adapter *adapter);
-
-#endif /* __IOCTL_CFG80211_H__ */
diff --git a/drivers/staging/rtl8723au/include/mlme_osdep.h b/drivers/staging/rtl8723au/include/mlme_osdep.h
deleted file mode 100644 (file)
index 4bb5525..0000000
+++ /dev/null
@@ -1,24 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#ifndef        __MLME_OSDEP_H_
-#define __MLME_OSDEP_H_
-
-#include <osdep_service.h>
-#include <drv_types.h>
-
-void rtw_os_indicate_disconnect23a(struct rtw_adapter *adapter);
-void rtw_reset_securitypriv23a(struct rtw_adapter *adapter);
-
-#endif /* _MLME_OSDEP_H_ */
diff --git a/drivers/staging/rtl8723au/include/odm.h b/drivers/staging/rtl8723au/include/odm.h
deleted file mode 100644 (file)
index 24f2f28..0000000
+++ /dev/null
@@ -1,860 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-
-
-#ifndef        __HALDMOUTSRC_H__
-#define __HALDMOUTSRC_H__
-
-/*  */
-/*  Definition */
-/*  */
-/*  */
-/*  2011/09/22 MH Define all team supprt ability. */
-/*  */
-
-/*  */
-/*  2011/09/22 MH Define for all teams. Please Define the constan in your precomp header. */
-/*  */
-/* define              DM_ODM_SUPPORT_AP                       0 */
-/* define              DM_ODM_SUPPORT_ADSL                     0 */
-/* define              DM_ODM_SUPPORT_CE                       0 */
-/* define              DM_ODM_SUPPORT_MP                       1 */
-
-#define        TP_MODE         0
-#define        RSSI_MODE               1
-#define        TRAFFIC_LOW     0
-#define        TRAFFIC_HIGH    1
-
-
-/*  */
-/* 3 Tx Power Tracking */
-/* 3============================================================ */
-#define                DPK_DELTA_MAPPING_NUM   13
-#define                index_mapping_HP_NUM    15
-
-
-/*  */
-/* 3 PSD Handler */
-/* 3============================================================ */
-
-#define        AFH_PSD         1       /* 0:normal PSD scan, 1: only do 20 pts PSD */
-#define        MODE_40M                0       /* 0:20M, 1:40M */
-#define        PSD_TH2         3
-#define        PSD_CHMIN               20   /*  Minimum channel number for BT AFH */
-#define        SIR_STEP_SIZE   3
-#define   Smooth_Size_1                5
-#define        Smooth_TH_1     3
-#define   Smooth_Size_2                10
-#define        Smooth_TH_2     4
-#define   Smooth_Size_3                20
-#define        Smooth_TH_3     4
-#define   Smooth_Step_Size 5
-#define        Adaptive_SIR    1
-#define        PSD_RESCAN              4
-#define        PSD_SCAN_INTERVAL       700 /* ms */
-
-/* 8723A High Power IGI Setting */
-#define DM_DIG_HIGH_PWR_IGI_LOWER_BOUND        0x22
-#define DM_DIG_Gmode_HIGH_PWR_IGI_LOWER_BOUND 0x28
-#define DM_DIG_HIGH_PWR_THRESHOLD      0x3a
-
-/*  LPS define */
-#define DM_DIG_FA_TH0_LPS                              4 /*  4 in lps */
-#define DM_DIG_FA_TH1_LPS                              15 /*  15 lps */
-#define DM_DIG_FA_TH2_LPS                              30 /*  30 lps */
-#define RSSI_OFFSET_DIG                                        0x05;
-
-/* ANT Test */
-#define                        ANTTESTALL              0x00            /* Ant A or B will be Testing */
-#define                ANTTESTA                0x01            /* Ant A will be Testing */
-#define                ANTTESTB                0x02            /* Ant B will be testing */
-
-
-/*  */
-/*  structure and define */
-/*  */
-
-struct  dig_t {
-       u8              Dig_Enable_Flag;
-       u8              Dig_Ext_Port_Stage;
-
-       int             RssiLowThresh;
-       int             RssiHighThresh;
-
-       u32             FALowThresh;
-       u32             FAHighThresh;
-
-       u8              CurSTAConnectState;
-       u8              PreSTAConnectState;
-       u8              CurMultiSTAConnectState;
-
-       u8              PreIGValue;
-       u8              CurIGValue;
-       u8              BackupIGValue;
-
-       s8              BackoffVal;
-       s8              BackoffVal_range_max;
-       s8              BackoffVal_range_min;
-       u8              rx_gain_range_max;
-       u8              rx_gain_range_min;
-       u8              Rssi_val_min;
-
-       u8              PreCCK_CCAThres;
-       u8              CurCCK_CCAThres;
-       u8              PreCCKPDState;
-       u8              CurCCKPDState;
-
-       u8              LargeFAHit;
-       u8              ForbiddenIGI;
-       u32             Recover_cnt;
-
-       u8              DIG_Dynamic_MIN_0;
-       u8              DIG_Dynamic_MIN_1;
-       bool            bMediaConnect_0;
-       bool            bMediaConnect_1;
-
-       u32             RSSI_max;
-};
-
-struct dynamic_pwr_sav {
-       u8              PreCCAState;
-       u8              CurCCAState;
-
-       u8              PreRFState;
-       u8              CurRFState;
-
-       int                 Rssi_val_min;
-
-       u8              initialize;
-       u32             Reg874, RegC70, Reg85C, RegA74;
-};
-
-struct false_alarm_stats {
-       u32     Cnt_Parity_Fail;
-       u32     Cnt_Rate_Illegal;
-       u32     Cnt_Crc8_fail;
-       u32     Cnt_Mcs_fail;
-       u32     Cnt_Ofdm_fail;
-       u32     Cnt_Cck_fail;
-       u32     Cnt_all;
-       u32     Cnt_Fast_Fsync;
-       u32     Cnt_SB_Search_fail;
-       u32     Cnt_OFDM_CCA;
-       u32     Cnt_CCK_CCA;
-       u32     Cnt_CCA_all;
-       u32     Cnt_BW_USC;     /* Gary */
-       u32     Cnt_BW_LSC;     /* Gary */
-};
-
-#define ASSOCIATE_ENTRY_NUM                                    32 /*  Max size of AsocEntry[]. */
-#define        ODM_ASSOCIATE_ENTRY_NUM                         ASSOCIATE_ENTRY_NUM
-
-/*  This indicates two different the steps. */
-/*  In SWAW_STEP_PEAK, driver needs to switch antenna and listen to the signal on the air. */
-/*  In SWAW_STEP_DETERMINE, driver just compares the signal captured in SWAW_STEP_PEAK */
-/*  with original RSSI to determine if it is necessary to switch antenna. */
-#define SWAW_STEP_PEAK         0
-#define SWAW_STEP_DETERMINE    1
-
-#define        TP_MODE         0
-#define        RSSI_MODE               1
-#define        TRAFFIC_LOW     0
-#define        TRAFFIC_HIGH    1
-
-struct sw_ant_sw {
-       u8              try_flag;
-       s32             PreRSSI;
-       u8              CurAntenna;
-       u8              PreAntenna;
-       u8              RSSI_Trying;
-       u8              TestMode;
-       u8              bTriggerAntennaSwitch;
-       u8              SelectAntennaMap;
-       u8              RSSI_target;
-
-       /*  Before link Antenna Switch check */
-       u8              SWAS_NoLink_State;
-       u32             SWAS_NoLink_BK_Reg860;
-       bool            ANTA_ON;        /* To indicate Ant A is or not */
-       bool            ANTB_ON;        /* To indicate Ant B is on or not */
-
-       s32             RSSI_sum_A;
-       s32             RSSI_sum_B;
-       s32             RSSI_cnt_A;
-       s32             RSSI_cnt_B;
-
-       u64             lastTxOkCnt;
-       u64             lastRxOkCnt;
-       u64             TXByteCnt_A;
-       u64             TXByteCnt_B;
-       u64             RXByteCnt_A;
-       u64             RXByteCnt_B;
-       u8              TrafficLoad;
-};
-
-struct edca_turbo {
-       bool bCurrentTurboEDCA;
-       u32     prv_traffic_idx; /*  edca turbo */
-};
-
-struct odm_rate_adapt {
-       u8      Type;           /*  DM_Type_ByFW/DM_Type_ByDriver */
-       u8      HighRSSIThresh; /*  if RSSI > HighRSSIThresh    => RATRState is DM_RATR_STA_HIGH */
-       u8      LowRSSIThresh;  /*  if RSSI <= LowRSSIThresh    => RATRState is DM_RATR_STA_LOW */
-       u8      RATRState;      /*  Current RSSI level, DM_RATR_STA_HIGH/DM_RATR_STA_MIDDLE/DM_RATR_STA_LOW */
-       u32     LastRATR;       /*  RATR Register Content */
-};
-
-#define IQK_MAC_REG_NUM                4
-#define IQK_ADDA_REG_NUM               16
-#define IQK_BB_REG_NUM_MAX     10
-#define IQK_BB_REG_NUM         9
-#define HP_THERMAL_NUM         8
-
-#define AVG_THERMAL_NUM                8
-#define IQK_Matrix_REG_NUM     8
-#define IQK_Matrix_Settings_NUM        1+24+21
-
-#define                DM_Type_ByFW                    0
-#define                DM_Type_ByDriver                1
-
-/*  Declare for common info */
-
-struct odm_phy_dbg_info {
-       /* ODM Write,debug info */
-       s8              RxSNRdB[RF_PATH_MAX];
-       u64             NumQryPhyStatus;
-       u64             NumQryPhyStatusCCK;
-       u64             NumQryPhyStatusOFDM;
-       /* Others */
-       s32             RxEVM[RF_PATH_MAX];
-
-};
-
-struct odm_packet_info {
-       u8              Rate;
-       u8              StationID;
-       bool            bPacketMatchBSSID;
-       bool            bPacketToSelf;
-       bool            bPacketBeacon;
-};
-
-
-enum {
-       /*  BB Team */
-       ODM_DIG                 = 0x00000001,
-       ODM_HIGH_POWER          = 0x00000002,
-       ODM_CCK_CCA_TH          = 0x00000004,
-       ODM_FA_STATISTICS       = 0x00000008,
-       ODM_RAMASK              = 0x00000010,
-       ODM_RSSI_MONITOR        = 0x00000020,
-       ODM_SW_ANTDIV           = 0x00000040,
-       ODM_HW_ANTDIV           = 0x00000080,
-       ODM_BB_PWRSV            = 0x00000100,
-       ODM_2TPATHDIV           = 0x00000200,
-       ODM_1TPATHDIV           = 0x00000400,
-       ODM_PSD2AFH             = 0x00000800
-};
-
-/*  */
-/*  2011/10/20 MH Define Common info enum for all team. */
-/*  */
-
-enum odm_cmninfo {
-       /*  Fixed value: */
-       /*  */
-
-       ODM_CMNINFO_MP_TEST_CHIP = 2,
-       ODM_CMNINFO_IC_TYPE,                    /*  enum odm_ic_type_def */
-       ODM_CMNINFO_CUT_VER,                    /*  enum odm_cut_version */
-       ODM_CMNINFO_FAB_VER,                    /*  enum odm_fab_version */
-       ODM_CMNINFO_BOARD_TYPE,                 /*  enum odm_board_type */
-       ODM_CMNINFO_EXT_LNA,                    /*  true */
-       ODM_CMNINFO_EXT_PA,
-       ODM_CMNINFO_EXT_TRSW,
-       ODM_CMNINFO_BINHCT_TEST,
-       ODM_CMNINFO_BWIFI_TEST,
-       ODM_CMNINFO_SMART_CONCURRENT,
-
-
-       /*  */
-       /*  Dynamic value: */
-       /*  */
-       ODM_CMNINFO_MP_MODE,
-
-       ODM_CMNINFO_WIFI_DIRECT,
-       ODM_CMNINFO_WIFI_DISPLAY,
-       ODM_CMNINFO_LINK,
-       ODM_CMNINFO_RSSI_MIN,
-       ODM_CMNINFO_DBG_COMP,                           /*  u64 */
-       ODM_CMNINFO_DBG_LEVEL,                          /*  u32 */
-       ODM_CMNINFO_RA_THRESHOLD_HIGH,          /*  u8 */
-       ODM_CMNINFO_RA_THRESHOLD_LOW,           /*  u8 */
-       ODM_CMNINFO_RF_ANTENNA_TYPE,            /*  u8 */
-       ODM_CMNINFO_BT_DISABLED,
-       ODM_CMNINFO_BT_OPERATION,
-       ODM_CMNINFO_BT_DIG,
-       ODM_CMNINFO_BT_BUSY,                                    /* Check Bt is using or not */
-       ODM_CMNINFO_BT_DISABLE_EDCA,
-
-       /*  */
-       /*  Dynamic ptr array hook itms. */
-       /*  */
-       ODM_CMNINFO_STA_STATUS,
-       ODM_CMNINFO_PHY_STATUS,
-       ODM_CMNINFO_MAC_STATUS,
-
-       ODM_CMNINFO_MAX,
-};
-
-/*  Define ODM support ability.  ODM_CMNINFO_ABILITY */
-enum {
-       /*  BB ODM section BIT 0-15 */
-       ODM_BB_ANT_DIV                          = BIT(6),
-};
-
-/*     ODM_CMNINFO_INTERFACE */
-enum odm_interface_def {
-       ODM_ITRF_PCIE   =       0x1,
-       ODM_ITRF_USB    =       0x2,
-       ODM_ITRF_SDIO   =       0x4,
-       ODM_ITRF_ALL    =       0x7,
-};
-
-/*  ODM_CMNINFO_IC_TYPE */
-enum odm_ic_type_def {
-       ODM_RTL8192S    =       BIT(0),
-       ODM_RTL8192C    =       BIT(1),
-       ODM_RTL8192D    =       BIT(2),
-       ODM_RTL8723A    =       BIT(3),
-       ODM_RTL8188E    =       BIT(4),
-       ODM_RTL8812     =       BIT(5),
-       ODM_RTL8821     =       BIT(6),
-};
-
-/* ODM_CMNINFO_CUT_VER */
-enum odm_cut_version {
-       ODM_CUT_A               =       1,
-       ODM_CUT_B               =       2,
-       ODM_CUT_C               =       3,
-       ODM_CUT_D               =       4,
-       ODM_CUT_E               =       5,
-       ODM_CUT_F               =       6,
-       ODM_CUT_TEST            =       7,
-};
-
-/*  ODM_CMNINFO_FAB_VER */
-enum odm_fab_version {
-       ODM_TSMC        =       0,
-       ODM_UMC         =       1,
-};
-
-/*  For example 1T2R (A+AB = BIT0|BIT4|BIT5) */
-enum rf_path_def {
-       ODM_RF_TX_A     =       BIT(0),
-       ODM_RF_TX_B     =       BIT(1),
-       ODM_RF_TX_C     =       BIT(2),
-       ODM_RF_TX_D     =       BIT(3),
-       ODM_RF_RX_A     =       BIT(4),
-       ODM_RF_RX_B     =       BIT(5),
-       ODM_RF_RX_C     =       BIT(6),
-       ODM_RF_RX_D     =       BIT(7),
-};
-
-/*  ODM Dynamic common info value definition */
-
-enum odm_mac_phy_mode {
-       ODM_SMSP        = 0,
-       ODM_DMSP        = 1,
-       ODM_DMDP        = 2,
-};
-
-
-enum odm_bt_coexist {
-       ODM_BT_BUSY             = 1,
-       ODM_BT_ON               = 2,
-       ODM_BT_OFF              = 3,
-       ODM_BT_NONE             = 4,
-};
-
-/*  ODM_CMNINFO_OP_MODE */
-enum odm_operation_mode {
-       ODM_NO_LINK             = BIT(0),
-       ODM_LINK                = BIT(1),
-       ODM_SCAN                = BIT(2),
-       ODM_POWERSAVE           = BIT(3),
-       ODM_AP_MODE             = BIT(4),
-       ODM_CLIENT_MODE         = BIT(5),
-       ODM_AD_HOC              = BIT(6),
-       ODM_WIFI_DIRECT         = BIT(7),
-       ODM_WIFI_DISPLAY        = BIT(8),
-};
-
-/*  ODM_CMNINFO_WM_MODE */
-enum odm_wireless_mode {
-       ODM_WM_UNKNOW           = 0x0,
-       ODM_WM_B                = BIT(0),
-       ODM_WM_G                = BIT(1),
-       ODM_WM_A                = BIT(2),
-       ODM_WM_N24G             = BIT(3),
-       ODM_WM_N5G              = BIT(4),
-       ODM_WM_AUTO             = BIT(5),
-       ODM_WM_AC               = BIT(6),
-};
-
-/*  ODM_CMNINFO_BAND */
-enum odm_band_type {
-       ODM_BAND_2_4G           = BIT(0),
-       ODM_BAND_5G             = BIT(1),
-
-};
-
-/*  ODM_CMNINFO_SEC_CHNL_OFFSET */
-enum odm_sec_chnl_offset {
-       ODM_DONT_CARE           = 0,
-       ODM_BELOW               = 1,
-       ODM_ABOVE               = 2
-};
-
-/*  ODM_CMNINFO_CHNL */
-
-/*  ODM_CMNINFO_BOARD_TYPE */
-enum odm_board_type {
-       ODM_BOARD_NORMAL        = 0,
-       ODM_BOARD_HIGHPWR       = 1,
-       ODM_BOARD_MINICARD      = 2,
-       ODM_BOARD_SLIM          = 3,
-       ODM_BOARD_COMBO         = 4,
-
-};
-
-/*  ODM_CMNINFO_ONE_PATH_CCA */
-enum odm_cca_path {
-       ODM_CCA_2R                      = 0,
-       ODM_CCA_1R_A                    = 1,
-       ODM_CCA_1R_B                    = 2,
-};
-
-struct iqk_matrix_regs_set {
-       bool    bIQKDone;
-       s32     Value[1][IQK_Matrix_REG_NUM];
-};
-
-struct odm_rf_cal_t {
-       /* for tx power tracking */
-
-       u32     RegA24; /*  for TempCCK */
-       s32     RegE94;
-       s32     RegE9C;
-       s32     RegEB4;
-       s32     RegEBC;
-
-       /* u8 bTXPowerTracking; */
-       u8              TXPowercount;
-       bool bTXPowerTrackingInit;
-       bool bTXPowerTracking;
-       u8              TxPowerTrackControl; /* for mp mode, turn off txpwrtracking as default */
-       u8              TM_Trigger;
-       u8              InternalPA5G[2];        /* pathA / pathB */
-
-       u8              ThermalMeter[2];    /*  ThermalMeter, index 0 for RFIC0, and 1 for RFIC1 */
-       u8              ThermalValue;
-       u8              ThermalValue_LCK;
-       u8              ThermalValue_IQK;
-       u8      ThermalValue_DPK;
-       u8      ThermalValue_AVG[AVG_THERMAL_NUM];
-       u8      ThermalValue_AVG_index;
-       u8      ThermalValue_RxGain;
-       u8      ThermalValue_Crystal;
-       u8      ThermalValue_DPKstore;
-       u8      ThermalValue_DPKtrack;
-       bool    TxPowerTrackingInProgress;
-       bool    bDPKenable;
-
-       bool    bReloadtxpowerindex;
-       u8      bRfPiEnable;
-       u32     TXPowerTrackingCallbackCnt; /* cosa add for debug */
-
-       u8      bCCKinCH14;
-       u8      CCK_index;
-       u8      OFDM_index[2];
-       bool bDoneTxpower;
-
-       u8      ThermalValue_HP[HP_THERMAL_NUM];
-       u8      ThermalValue_HP_index;
-       struct iqk_matrix_regs_set IQKMatrixRegSetting[IQK_Matrix_Settings_NUM];
-
-       u8      Delta_IQK;
-       u8      Delta_LCK;
-
-       /* for IQK */
-       u32     RegC04;
-       u32     Reg874;
-       u32     RegC08;
-       u32     RegB68;
-       u32     RegB6C;
-       u32     Reg870;
-       u32     Reg860;
-       u32     Reg864;
-
-       bool    bIQKInitialized;
-       bool bLCKInProgress;
-       bool    bAntennaDetected;
-       u32     ADDA_backup[IQK_ADDA_REG_NUM];
-       u32     IQK_MAC_backup[IQK_MAC_REG_NUM];
-       u32     IQK_BB_backup_recover[9];
-       u32     IQK_BB_backup[IQK_BB_REG_NUM];
-
-       /* for APK */
-       u32     APKoutput[2][2]; /* path A/B; output1_1a/output1_2a */
-       u8      bAPKdone;
-       u8      bAPKThermalMeterIgnore;
-       u8      bDPdone;
-       u8      bDPPathAOK;
-       u8      bDPPathBOK;
-};
-
-enum ant_dif_type {
-       NO_ANTDIV                       = 0xFF,
-       CG_TRX_HW_ANTDIV                = 0x01,
-       CGCS_RX_HW_ANTDIV               = 0x02,
-       FIXED_HW_ANTDIV                 = 0x03,
-       CG_TRX_SMART_ANTDIV             = 0x04,
-       CGCS_RX_SW_ANTDIV               = 0x05,
-};
-
-/*  2011/09/22 MH Copy from SD4 defined structure. We use to support PHY DM integration. */
-struct dm_odm_t {
-       /*  */
-       /*      Add for different team use temporarily */
-       /*  */
-       struct rtw_adapter      *Adapter;               /*  For CE/NIC team */
-
-       u64                     DebugComponents;
-       u32                     DebugLevel;
-
-/*  ODM HANDLE, DRIVER NEEDS NOT TO HOOK------ */
-       bool                    bCckHighPower;
-       u8                      RFPathRxEnable;         /*  ODM_CMNINFO_RFPATH_ENABLE */
-/*  ODM HANDLE, DRIVER NEEDS NOT TO HOOK------ */
-
-/* 1  COMMON INFORMATION */
-
-       /*  Init Value */
-/* HOOK BEFORE REG INIT----------- */
-       /*  ODM Support Ability DIG/RATR/TX_PWR_TRACK/ ¡K¡K = 1/2/3/¡K */
-       u32                     SupportAbility;
-       /*  ODM composite or independent. Bit oriented/ 92C+92D+ .... or any other type = 1/2/3/... */
-       u32                     SupportICType;
-       /*  Cut Version TestChip/A-cut/B-cut... = 0/1/2/3/... */
-       u8                      CutVersion;
-       /*  Fab Version TSMC/UMC = 0/1 */
-       u8                      FabVersion;
-       /*  Board Type Normal/HighPower/MiniCard/SLIM/Combo/... = 0/1/2/3/4/... */
-       u8                      BoardType;
-       /*  with external LNA  NO/Yes = 0/1 */
-       u8                      ExtLNA;
-       /*  with external PA  NO/Yes = 0/1 */
-       u8                      ExtPA;
-       /*  with external TRSW  NO/Yes = 0/1 */
-       u8                      ExtTRSW;
-       bool                    bInHctTest;
-       bool                    bWIFITest;
-
-       bool                    bDualMacSmartConcurrent;
-       u32                     BK_SupportAbility;
-/* HOOK BEFORE REG INIT----------- */
-
-       /*  */
-       /*  Dynamic Value */
-       /*  */
-/*  POINTER REFERENCE----------- */
-
-       u8                      u8_temp;
-       bool                    bool_temp;
-       struct rtw_adapter      *PADAPTER_temp;
-
-/*  POINTER REFERENCE----------- */
-       /*  */
-/* CALL BY VALUE------------- */
-       bool                    bWIFI_Direct;
-       bool                    bWIFI_Display;
-       bool                    bLinked;
-       u8                      RSSI_Min;
-       u8                      InterfaceIndex; /*  Add for 92D  dual MAC: 0--Mac0 1--Mac1 */
-       bool            bIsMPChip;
-       bool                    bOneEntryOnly;
-       /*  Common info for BTDM */
-       bool                    bBtDisabled;                    /*  BT is disabled */
-       bool                    bBtHsOperation;         /*  BT HS mode is under progress */
-       u8                      btHsDigVal;                     /*  use BT rssi to decide the DIG value */
-       bool                    bBtDisableEdcaTurbo;    /*  Under some condition, don't enable the EDCA Turbo */
-       bool                    bBtBusy;                        /*  BT is busy. */
-/* CALL BY VALUE------------- */
-
-       /* 2 Define STA info. */
-       /*  _ODM_STA_INFO */
-       /*  2012/01/12 MH For MP, we need to reduce one array pointer for default port.?? */
-       struct sta_info *               pODM_StaInfo[ODM_ASSOCIATE_ENTRY_NUM];
-
-       /*  Latest packet phy info (ODM write) */
-       struct odm_phy_dbg_info  PhyDbgInfo;
-       /* PHY_INFO_88E         PhyInfo; */
-
-       /*  Latest packet phy info (ODM write) */
-       /* MAC_INFO_88E         MacInfo; */
-
-       /*  Different Team independt structure?? */
-
-       /*  */
-       /* TX_RTP_CMN           TX_retrpo; */
-       /* TX_RTP_88E           TX_retrpo; */
-       /* TX_RTP_8195          TX_retrpo; */
-
-       /*  */
-       /* ODM Structure */
-       /*  */
-       struct dig_t    DM_DigTable;
-       struct dynamic_pwr_sav          DM_PSTable;
-       struct false_alarm_stats        FalseAlmCnt;
-       struct false_alarm_stats        FlaseAlmCntBuddyAdapter;
-       struct sw_ant_sw                DM_SWAT_Table;
-
-       struct edca_turbo               DM_EDCA_Table;
-       u32             WMMEDCA_BE;
-       /*  Copy from SD4 structure */
-       /*  */
-       /*  ================================================== */
-       /*  */
-
-       /* PSD */
-       u8                      RSSI_BT;                /* come from BT */
-       struct odm_rate_adapt   RateAdaptive;
-
-
-       struct odm_rf_cal_t     RFCalibrateInfo;
-};     /*  DM_Dynamic_Mechanism_Structure */
-
-enum odm_rf_content {
-       odm_radioa_txt = 0x1000,
-       odm_radiob_txt = 0x1001,
-       odm_radioc_txt = 0x1002,
-       odm_radiod_txt = 0x1003
-};
-
-/*  Status code */
-enum rt_status {
-       RT_STATUS_SUCCESS,
-       RT_STATUS_FAILURE,
-       RT_STATUS_PENDING,
-       RT_STATUS_RESOURCE,
-       RT_STATUS_INVALID_CONTEXT,
-       RT_STATUS_INVALID_PARAMETER,
-       RT_STATUS_NOT_SUPPORT,
-       RT_STATUS_OS_API_FAILED,
-};
-
-/* include "odm_function.h" */
-
-/* 3=========================================================== */
-/* 3 DIG */
-/* 3=========================================================== */
-
-enum dm_dig_op {
-       DIG_TYPE_THRESH_HIGH    = 0,
-       DIG_TYPE_THRESH_LOW     = 1,
-       DIG_TYPE_BACKOFF                = 2,
-       DIG_TYPE_RX_GAIN_MIN    = 3,
-       DIG_TYPE_RX_GAIN_MAX    = 4,
-       DIG_TYPE_ENABLE                 = 5,
-       DIG_TYPE_DISABLE                = 6,
-       DIG_OP_TYPE_MAX
-};
-
-#define                DM_DIG_THRESH_HIGH                      40
-#define                DM_DIG_THRESH_LOW                       35
-
-#define                DM_SCAN_RSSI_TH                         0x14 /* scan return issue for LC */
-
-
-#define                DM_FALSEALARM_THRESH_LOW        400
-#define                DM_FALSEALARM_THRESH_HIGH       1000
-
-#define                DM_DIG_MAX_NIC                          0x4e
-#define                DM_DIG_MIN_NIC                          0x1e
-
-#define                DM_DIG_MAX_AP                           0x32
-#define                DM_DIG_MIN_AP                           0x20
-
-#define                DM_DIG_MAX_NIC_HP                       0x46
-#define                DM_DIG_MIN_NIC_HP                       0x2e
-
-#define                DM_DIG_MAX_AP_HP                                0x42
-#define                DM_DIG_MIN_AP_HP                                0x30
-
-/* vivi 92c&92d has different definition, 20110504 */
-/* this is for 92c */
-#define                DM_DIG_FA_TH0                           0x200
-#define                DM_DIG_FA_TH1                           0x300
-#define                DM_DIG_FA_TH2                           0x400
-/* this is for 92d */
-#define                DM_DIG_FA_TH0_92D                       0x100
-#define                DM_DIG_FA_TH1_92D                       0x400
-#define                DM_DIG_FA_TH2_92D                       0x600
-
-#define                DM_DIG_BACKOFF_MAX                      12
-#define                DM_DIG_BACKOFF_MIN                      -4
-#define                DM_DIG_BACKOFF_DEFAULT          10
-
-/* 3=========================================================== */
-/* 3 AGC RX High Power Mode */
-/* 3=========================================================== */
-#define          LNA_Low_Gain_1                      0x64
-#define          LNA_Low_Gain_2                      0x5A
-#define          LNA_Low_Gain_3                      0x58
-
-#define          FA_RXHP_TH1                           5000
-#define          FA_RXHP_TH2                           1500
-#define          FA_RXHP_TH3                             800
-#define          FA_RXHP_TH4                             600
-#define          FA_RXHP_TH5                             500
-
-/* 3=========================================================== */
-/* 3 EDCA */
-/* 3=========================================================== */
-
-/* 3=========================================================== */
-/* 3 Dynamic Tx Power */
-/* 3=========================================================== */
-/* Dynamic Tx Power Control Threshold */
-#define                TX_POWER_NEAR_FIELD_THRESH_LVL2 74
-#define                TX_POWER_NEAR_FIELD_THRESH_LVL1 67
-#define                TX_POWER_NEAR_FIELD_THRESH_AP           0x3F
-
-#define                TxHighPwrLevel_Normal           0
-#define                TxHighPwrLevel_Level1           1
-#define                TxHighPwrLevel_Level2           2
-#define                TxHighPwrLevel_BT1                      3
-#define                TxHighPwrLevel_BT2                      4
-#define                TxHighPwrLevel_15                       5
-#define                TxHighPwrLevel_35                       6
-#define                TxHighPwrLevel_50                       7
-#define                TxHighPwrLevel_70                       8
-#define                TxHighPwrLevel_100                      9
-
-/* 3=========================================================== */
-/* 3 Rate Adaptive */
-/* 3=========================================================== */
-#define                DM_RATR_STA_INIT                        0
-#define                DM_RATR_STA_HIGH                        1
-#define                        DM_RATR_STA_MIDDLE              2
-#define                        DM_RATR_STA_LOW                 3
-
-/* 3=========================================================== */
-/* 3 BB Power Save */
-/* 3=========================================================== */
-
-
-enum dm_1r_cca {
-       CCA_1R =0,
-       CCA_2R = 1,
-       CCA_MAX = 2,
-};
-
-enum dm_rf_def {
-       RF_Save =0,
-       RF_Normal = 1,
-       RF_MAX = 2,
-};
-
-/* 3=========================================================== */
-/* 3 Antenna Diversity */
-/* 3=========================================================== */
-enum dm_swas {
-       Antenna_A = 1,
-       Antenna_B = 2,
-       Antenna_MAX = 3,
-};
-
-/*  Maximal number of antenna detection mechanism needs to perform, added by Roger, 2011.12.28. */
-#define        MAX_ANTENNA_DETECTION_CNT       10
-
-/*  */
-/*  Extern Global Variables. */
-/*  */
-#define        OFDM_TABLE_SIZE_92C     37
-#define        OFDM_TABLE_SIZE_92D     43
-#define        CCK_TABLE_SIZE          33
-
-extern u32 OFDMSwingTable23A[OFDM_TABLE_SIZE_92D];
-extern u8 CCKSwingTable_Ch1_Ch1323A[CCK_TABLE_SIZE][8];
-extern u8 CCKSwingTable_Ch1423A [CCK_TABLE_SIZE][8];
-
-
-
-/*  20100514 Joseph: Add definition for antenna switching test after link. */
-/*  This indicates two different the steps. */
-/*  In SWAW_STEP_PEAK, driver needs to switch antenna and listen to the signal on the air. */
-/*  In SWAW_STEP_DETERMINE, driver just compares the signal captured in SWAW_STEP_PEAK */
-/*  with original RSSI to determine if it is necessary to switch antenna. */
-#define SWAW_STEP_PEAK         0
-#define SWAW_STEP_DETERMINE    1
-
-struct hal_data_8723a;
-
-void ODM_Write_DIG23a(struct dm_odm_t *pDM_Odm,        u8      CurrentIGI);
-void ODM_Write_CCK_CCA_Thres23a(struct dm_odm_t *pDM_Odm, u8   CurCCK_CCAThres);
-
-void ODM_SetAntenna(struct dm_odm_t *pDM_Odm, u8 Antenna);
-
-
-#define dm_RF_Saving   ODM_RF_Saving23a
-void ODM_RF_Saving23a(struct dm_odm_t *pDM_Odm, u8 bForceInNormal);
-
-#define dm_CheckTXPowerTracking                ODM_TXPowerTrackingCheck23a
-void ODM_TXPowerTrackingCheck23a(struct dm_odm_t *pDM_Odm);
-
-bool ODM_RAStateCheck23a(struct dm_odm_t *pDM_Odm, s32 RSSI, bool bForceUpdate,
-                     u8 *pRATRState);
-
-
-u32 ConvertTo_dB23a(u32 Value);
-
-u32 GetPSDData(struct dm_odm_t *pDM_Odm, unsigned int point, u8 initial_gain_psd);
-
-void odm_DIG23abyRSSI_LPS(struct dm_odm_t *pDM_Odm);
-
-u32 ODM_Get_Rate_Bitmap23a(struct hal_data_8723a *pHalData, u32 macid, u32 ra_mask, u8 rssi_level);
-
-
-void ODM23a_DMInit(struct dm_odm_t *pDM_Odm);
-
-void ODM_DMWatchdog23a(struct rtw_adapter *adapter);
-
-void ODM_CmnInfoInit23a(struct dm_odm_t *pDM_Odm, enum odm_cmninfo     CmnInfo, u32 Value);
-
-void ODM_CmnInfoPtrArrayHook23a(struct dm_odm_t *pDM_Odm, enum odm_cmninfo     CmnInfo, u16 Index, void *pValue);
-
-void ODM_CmnInfoUpdate23a(struct dm_odm_t *pDM_Odm, u32 CmnInfo, u64 Value);
-
-void ODM_ResetIQKResult(struct dm_odm_t *pDM_Odm);
-
-void ODM_AntselStatistics_88C(struct dm_odm_t *pDM_Odm, u8 MacId, u32 PWDBAll, bool isCCKrate);
-
-void ODM_SingleDualAntennaDefaultSetting(struct dm_odm_t *pDM_Odm);
-
-bool ODM_SingleDualAntennaDetection(struct dm_odm_t *pDM_Odm, u8 mode);
-
-#endif
diff --git a/drivers/staging/rtl8723au/include/odm_HWConfig.h b/drivers/staging/rtl8723au/include/odm_HWConfig.h
deleted file mode 100644 (file)
index c748d5f..0000000
+++ /dev/null
@@ -1,153 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-
-
-#ifndef        __HALHWOUTSRC_H__
-#define __HALHWOUTSRC_H__
-
-#include <Hal8723APhyCfg.h>
-
-/*  */
-/*  Definition */
-/*  */
-/*  */
-/*  */
-/*  CCK Rates, TxHT = 0 */
-#define DESC92C_RATE1M                                 0x00
-#define DESC92C_RATE2M                                 0x01
-#define DESC92C_RATE5_5M                               0x02
-#define DESC92C_RATE11M                                0x03
-
-/*  OFDM Rates, TxHT = 0 */
-#define DESC92C_RATE6M                                 0x04
-#define DESC92C_RATE9M                                 0x05
-#define DESC92C_RATE12M                                0x06
-#define DESC92C_RATE18M                                0x07
-#define DESC92C_RATE24M                                0x08
-#define DESC92C_RATE36M                                0x09
-#define DESC92C_RATE48M                                0x0a
-#define DESC92C_RATE54M                                0x0b
-
-/*  MCS Rates, TxHT = 1 */
-#define DESC92C_RATEMCS0                               0x0c
-#define DESC92C_RATEMCS1                               0x0d
-#define DESC92C_RATEMCS2                               0x0e
-#define DESC92C_RATEMCS3                               0x0f
-#define DESC92C_RATEMCS4                               0x10
-#define DESC92C_RATEMCS5                               0x11
-#define DESC92C_RATEMCS6                               0x12
-#define DESC92C_RATEMCS7                               0x13
-#define DESC92C_RATEMCS8                               0x14
-#define DESC92C_RATEMCS9                               0x15
-#define DESC92C_RATEMCS10                              0x16
-#define DESC92C_RATEMCS11                              0x17
-#define DESC92C_RATEMCS12                              0x18
-#define DESC92C_RATEMCS13                              0x19
-#define DESC92C_RATEMCS14                              0x1a
-#define DESC92C_RATEMCS15                              0x1b
-#define DESC92C_RATEMCS15_SG                   0x1c
-#define DESC92C_RATEMCS32                              0x20
-
-
-/*  */
-/*  structure and define */
-/*  */
-
-struct phy_rx_agc_info {
-       #ifdef __LITTLE_ENDIAN
-               u8      gain:7, trsw:1;
-       #else
-               u8      trsw:1, gain:7;
-       #endif
-};
-
-struct phy_status_rpt {
-       struct phy_rx_agc_info path_agc[RF_PATH_MAX];
-       u8      ch_corr[RF_PATH_MAX];
-       u8      cck_sig_qual_ofdm_pwdb_all;
-       u8      cck_agc_rpt_ofdm_cfosho_a;
-       u8      cck_rpt_b_ofdm_cfosho_b;
-       u8      rsvd_1;/* ch_corr_msb; */
-       u8      noise_power_db_msb;
-       u8      path_cfotail[RF_PATH_MAX];
-       u8      pcts_mask[RF_PATH_MAX];
-       s8      stream_rxevm[RF_PATH_MAX];
-       u8      path_rxsnr[RF_PATH_MAX];
-       u8      noise_power_db_lsb;
-       u8      rsvd_2[3];
-       u8      stream_csi[RF_PATH_MAX];
-       u8      stream_target_csi[RF_PATH_MAX];
-       s8      sig_evm;
-       u8      rsvd_3;
-
-#ifdef __LITTLE_ENDIAN
-       u8      antsel_rx_keep_2:1;     /* ex_intf_flg:1; */
-       u8      sgi_en:1;
-       u8      rxsc:2;
-       u8      idle_long:1;
-       u8      r_ant_train_en:1;
-       u8      ant_sel_b:1;
-       u8      ant_sel:1;
-#else  /*  _BIG_ENDIAN_ */
-       u8      ant_sel:1;
-       u8      ant_sel_b:1;
-       u8      r_ant_train_en:1;
-       u8      idle_long:1;
-       u8      rxsc:2;
-       u8      sgi_en:1;
-       u8      antsel_rx_keep_2:1;     /* ex_intf_flg:1; */
-#endif
-};
-
-
-struct phy_status_rpt_8195 {
-       struct phy_rx_agc_info path_agc[2];
-       u8      ch_num[2];
-       u8      cck_sig_qual_ofdm_pwdb_all;
-       u8      cck_agc_rpt_ofdm_cfosho_a;
-       u8      cck_bb_pwr_ofdm_cfosho_b;
-       u8    cck_rx_path;      /* CCK_RX_PATH [3:0] (with regA07[3:0] definition) */
-       u8      rsvd_1;
-       u8      path_cfotail[2];
-       u8      pcts_mask[2];
-       s8      stream_rxevm[2];
-       u8      path_rxsnr[2];
-       u8      rsvd_2[2];
-       u8      stream_snr[2];
-       u8      stream_csi[2];
-       u8      rsvd_3[2];
-       s8      sig_evm;
-       u8      rsvd_4;
-#ifdef __LITTLE_ENDIAN
-       u8      antidx_anta:3;
-       u8      antidx_antb:3;
-       u8      rsvd_5:2;
-#else  /*  _BIG_ENDIAN_ */
-       u8      rsvd_5:2;
-       u8      antidx_antb:3;
-       u8      antidx_anta:3;
-#endif
-};
-
-
-void
-ODM_PhyStatusQuery23a(
-       struct dm_odm_t *pDM_Odm,
-       struct phy_info *pPhyInfo,
-       u8 *                                            pPhyStatus,
-       struct odm_packet_info *pPktinfo
-       );
-
-#endif
diff --git a/drivers/staging/rtl8723au/include/odm_RegConfig8723A.h b/drivers/staging/rtl8723au/include/odm_RegConfig8723A.h
deleted file mode 100644 (file)
index f2a54d8..0000000
+++ /dev/null
@@ -1,27 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#ifndef __INC_ODM_REGCONFIG_H_8723A
-#define __INC_ODM_REGCONFIG_H_8723A
-
-void odm_ConfigRFReg_8723A(struct dm_odm_t *pDM_Odm, u32 Addr, u32 Data,
-                          enum RF_RADIO_PATH RF_PATH, u32 RegAddr);
-
-void odm_ConfigMAC_8723A(struct dm_odm_t *pDM_Odm, u32 Addr, u8 Data);
-
-void odm_ConfigBB_AGC_8723A(struct dm_odm_t *pDM_Odm, u32 addr, u32 data);
-
-void odm_ConfigBB_PHY_8723A(struct dm_odm_t *pDM_Odm, u32 addr, u32 data);
-
-#endif /*  end of SUPPORT */
diff --git a/drivers/staging/rtl8723au/include/odm_RegDefine11N.h b/drivers/staging/rtl8723au/include/odm_RegDefine11N.h
deleted file mode 100644 (file)
index 2778215..0000000
+++ /dev/null
@@ -1,165 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-
-#ifndef        __ODM_REGDEFINE11N_H__
-#define __ODM_REGDEFINE11N_H__
-
-
-/* 2 RF REG LIST */
-#define        ODM_REG_RF_MODE_11N                     0x00
-#define        ODM_REG_RF_0B_11N                       0x0B
-#define        ODM_REG_CHNBW_11N                       0x18
-#define        ODM_REG_T_METER_11N                     0x24
-#define        ODM_REG_RF_25_11N                       0x25
-#define        ODM_REG_RF_26_11N                       0x26
-#define        ODM_REG_RF_27_11N                       0x27
-#define        ODM_REG_RF_2B_11N                       0x2B
-#define        ODM_REG_RF_2C_11N                       0x2C
-#define        ODM_REG_RXRF_A3_11N                     0x3C
-#define        ODM_REG_T_METER_92D_11N                 0x42
-#define        ODM_REG_T_METER_88E_11N                 0x42
-
-
-
-/* 2 BB REG LIST */
-/* PAGE 8 */
-#define        ODM_REG_BB_CTRL_11N                     0x800
-#define        ODM_REG_RF_PIN_11N                      0x804
-#define        ODM_REG_PSD_CTRL_11N                    0x808
-#define        ODM_REG_TX_ANT_CTRL_11N                 0x80C
-#define        ODM_REG_BB_PWR_SAV5_11N                 0x818
-#define        ODM_REG_CCK_RPT_FORMAT_11N              0x824
-#define        ODM_REG_RX_DEFUALT_A_11N                0x858
-#define        ODM_REG_RX_DEFUALT_B_11N                0x85A
-#define        ODM_REG_BB_PWR_SAV3_11N                 0x85C
-#define        ODM_REG_ANTSEL_CTRL_11N                 0x860
-#define        ODM_REG_RX_ANT_CTRL_11N                 0x864
-#define        ODM_REG_PIN_CTRL_11N                    0x870
-#define        ODM_REG_BB_PWR_SAV1_11N                 0x874
-#define        ODM_REG_ANTSEL_PATH_11N                 0x878
-#define        ODM_REG_BB_3WIRE_11N                    0x88C
-#define        ODM_REG_SC_CNT_11N                      0x8C4
-#define        ODM_REG_PSD_DATA_11N                    0x8B4
-/* PAGE 9 */
-#define        ODM_REG_ANT_MAPPING1_11N                0x914
-#define        ODM_REG_ANT_MAPPING2_11N                0x918
-/* PAGE A */
-#define        ODM_REG_CCK_ANTDIV_PARA1_11N            0xA00
-#define        ODM_REG_CCK_CCA_11N                     0xA0A
-#define        ODM_REG_CCK_ANTDIV_PARA2_11N            0xA0C
-#define        ODM_REG_CCK_ANTDIV_PARA3_11N            0xA10
-#define        ODM_REG_CCK_ANTDIV_PARA4_11N            0xA14
-#define        ODM_REG_CCK_FILTER_PARA1_11N            0xA22
-#define        ODM_REG_CCK_FILTER_PARA2_11N            0xA23
-#define        ODM_REG_CCK_FILTER_PARA3_11N            0xA24
-#define        ODM_REG_CCK_FILTER_PARA4_11N            0xA25
-#define        ODM_REG_CCK_FILTER_PARA5_11N            0xA26
-#define        ODM_REG_CCK_FILTER_PARA6_11N            0xA27
-#define        ODM_REG_CCK_FILTER_PARA7_11N            0xA28
-#define        ODM_REG_CCK_FILTER_PARA8_11N            0xA29
-#define        ODM_REG_CCK_FA_RST_11N                  0xA2C
-#define        ODM_REG_CCK_FA_MSB_11N                  0xA58
-#define        ODM_REG_CCK_FA_LSB_11N                  0xA5C
-#define        ODM_REG_CCK_CCA_CNT_11N                 0xA60
-#define        ODM_REG_BB_PWR_SAV4_11N                 0xA74
-/* PAGE B */
-#define        ODM_REG_LNA_SWITCH_11N                  0xB2C
-#define        ODM_REG_PATH_SWITCH_11N                 0xB30
-#define        ODM_REG_RSSI_CTRL_11N                   0xB38
-#define        ODM_REG_CONFIG_ANTA_11N                 0xB68
-#define        ODM_REG_RSSI_BT_11N                     0xB9C
-/* PAGE C */
-#define        ODM_REG_OFDM_FA_HOLDC_11N               0xC00
-#define        ODM_REG_RX_PATH_11N                     0xC04
-#define        ODM_REG_TRMUX_11N                       0xC08
-#define        ODM_REG_OFDM_FA_RSTC_11N                0xC0C
-#define        ODM_REG_RXIQI_MATRIX_11N                0xC14
-#define        ODM_REG_TXIQK_MATRIX_LSB1_11N           0xC4C
-#define        ODM_REG_IGI_A_11N                       0xC50
-#define        ODM_REG_ANTDIV_PARA2_11N                0xC54
-#define        ODM_REG_IGI_B_11N                       0xC58
-#define        ODM_REG_ANTDIV_PARA3_11N                0xC5C
-#define        ODM_REG_BB_PWR_SAV2_11N                 0xC70
-#define        ODM_REG_RX_OFF_11N                      0xC7C
-#define        ODM_REG_TXIQK_MATRIXA_11N               0xC80
-#define        ODM_REG_TXIQK_MATRIXB_11N               0xC88
-#define        ODM_REG_TXIQK_MATRIXA_LSB2_11N          0xC94
-#define        ODM_REG_TXIQK_MATRIXB_LSB2_11N          0xC9C
-#define        ODM_REG_RXIQK_MATRIX_LSB_11N            0xCA0
-#define        ODM_REG_ANTDIV_PARA1_11N                0xCA4
-#define        ODM_REG_OFDM_FA_TYPE1_11N               0xCF0
-/* PAGE D */
-#define        ODM_REG_OFDM_FA_RSTD_11N                0xD00
-#define        ODM_REG_OFDM_FA_TYPE2_11N               0xDA0
-#define        ODM_REG_OFDM_FA_TYPE3_11N               0xDA4
-#define        ODM_REG_OFDM_FA_TYPE4_11N               0xDA8
-/* PAGE E */
-#define        ODM_REG_TXAGC_A_6_18_11N                0xE00
-#define        ODM_REG_TXAGC_A_24_54_11N               0xE04
-#define        ODM_REG_TXAGC_A_1_MCS32_11N             0xE08
-#define        ODM_REG_TXAGC_A_MCS0_3_11N              0xE10
-#define        ODM_REG_TXAGC_A_MCS4_7_11N              0xE14
-#define        ODM_REG_TXAGC_A_MCS8_11_11N             0xE18
-#define        ODM_REG_TXAGC_A_MCS12_15_11N            0xE1C
-#define        ODM_REG_FPGA0_IQK_11N                   0xE28
-#define        ODM_REG_TXIQK_TONE_A_11N                0xE30
-#define        ODM_REG_RXIQK_TONE_A_11N                0xE34
-#define        ODM_REG_TXIQK_PI_A_11N                  0xE38
-#define        ODM_REG_RXIQK_PI_A_11N                  0xE3C
-#define        ODM_REG_TXIQK_11N                       0xE40
-#define        ODM_REG_RXIQK_11N                       0xE44
-#define        ODM_REG_IQK_AGC_PTS_11N                 0xE48
-#define        ODM_REG_IQK_AGC_RSP_11N                 0xE4C
-#define        ODM_REG_BLUETOOTH_11N                   0xE6C
-#define        ODM_REG_RX_WAIT_CCA_11N                 0xE70
-#define        ODM_REG_TX_CCK_RFON_11N                 0xE74
-#define        ODM_REG_TX_CCK_BBON_11N                 0xE78
-#define        ODM_REG_OFDM_RFON_11N                   0xE7C
-#define        ODM_REG_OFDM_BBON_11N                   0xE80
-#define ODM_REG_TX2RX_11N                      0xE84
-#define        ODM_REG_TX2TX_11N                       0xE88
-#define        ODM_REG_RX_CCK_11N                      0xE8C
-#define        ODM_REG_RX_OFDM_11N                     0xED0
-#define        ODM_REG_RX_WAIT_RIFS_11N                0xED4
-#define        ODM_REG_RX2RX_11N                       0xED8
-#define        ODM_REG_STANDBY_11N                     0xEDC
-#define        ODM_REG_SLEEP_11N                       0xEE0
-#define        ODM_REG_PMPD_ANAEN_11N                  0xEEC
-
-
-
-
-
-
-
-/* 2 MAC REG LIST */
-#define        ODM_REG_BB_RST_11N                      0x02
-#define        ODM_REG_ANTSEL_PIN_11N                  0x4C
-#define        ODM_REG_EARLY_MODE_11N                  0x4D0
-#define        ODM_REG_RSSI_MONITOR_11N                0x4FE
-#define        ODM_REG_EDCA_VO_11N                     0x500
-#define        ODM_REG_EDCA_VI_11N                     0x504
-#define        ODM_REG_EDCA_BE_11N                     0x508
-#define        ODM_REG_EDCA_BK_11N                     0x50C
-#define        ODM_REG_TXPAUSE_11N                     0x522
-#define        ODM_REG_RESP_TX_11N                     0x6D8
-#define        ODM_REG_ANT_TRAIN_PARA1_11N             0x7b0
-#define        ODM_REG_ANT_TRAIN_PARA2_11N             0x7b4
-
-
-/* DIG Related */
-#define        ODM_BIT_IGI_11N                         0x0000007F
-
-#endif
diff --git a/drivers/staging/rtl8723au/include/odm_debug.h b/drivers/staging/rtl8723au/include/odm_debug.h
deleted file mode 100644 (file)
index c4b375a..0000000
+++ /dev/null
@@ -1,117 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-
-
-#ifndef        __ODM_DBG_H__
-#define __ODM_DBG_H__
-
-
-/*  */
-/*     Define the debug levels */
-/*  */
-/*     1.      DBG_TRACE and DBG_LOUD are used for normal cases. */
-/*     So that, they can help SW engineer to develop or trace states changed */
-/*     and also help HW enginner to trace every operation to and from HW, */
-/*     e.g IO, Tx, Rx. */
-/*  */
-/*     2.      DBG_WARNNING and DBG_SERIOUS are used for unusual or error cases, */
-/*     which help us to debug SW or HW. */
-/*  */
-/*  */
-/*  */
-/*     Never used in a call to ODM_RT_TRACE()! */
-/*  */
-#define ODM_DBG_OFF                                    1
-
-/*  */
-/*     Fatal bug. */
-/*     For example, Tx/Rx/IO locked up, OS hangs, memory access violation, */
-/*     resource allocation failed, unexpected HW behavior, HW BUG and so on. */
-/*  */
-#define ODM_DBG_SERIOUS                                2
-
-/*  */
-/*     Abnormal, rare, or unexpeted cases. */
-/*     For example, IRP/Packet/OID canceled, device suprisely unremoved and so on. */
-/*  */
-#define ODM_DBG_WARNING                                3
-
-/*  */
-/*     Normal case with useful information about current SW or HW state. */
-/*     For example, Tx/Rx descriptor to fill, Tx/Rx descriptor completed status, */
-/*     SW protocol state change, dynamic mechanism state change and so on. */
-/*  */
-#define ODM_DBG_LOUD                                   4
-
-/*  */
-/*     Normal case with detail execution flow or information. */
-/*  */
-#define ODM_DBG_TRACE                                  5
-
-/*  */
-/*  Define the tracing components */
-/*  */
-/*  */
-/* BB Functions */
-#define ODM_COMP_DIG                           BIT(0)
-#define ODM_COMP_RA_MASK                       BIT(1)
-#define ODM_COMP_DYNAMIC_TXPWR                 BIT(2)
-#define ODM_COMP_FA_CNT                                BIT(3)
-#define ODM_COMP_RSSI_MONITOR                  BIT(4)
-#define ODM_COMP_CCK_PD                                BIT(5)
-#define ODM_COMP_ANT_DIV                       BIT(6)
-#define ODM_COMP_PWR_SAVE                      BIT(7)
-#define ODM_COMP_PWR_TRAIN                     BIT(8)
-#define ODM_COMP_RATE_ADAPTIVE                 BIT(9)
-#define ODM_COMP_PATH_DIV                      BIT(10)
-#define ODM_COMP_PSD                           BIT(11)
-#define ODM_COMP_DYNAMIC_PRICCA                        BIT(12)
-#define ODM_COMP_RXHP                          BIT(13)
-/* MAC Functions */
-#define ODM_COMP_EDCA_TURBO                    BIT(16)
-#define ODM_COMP_EARLY_MODE                    BIT(17)
-/* RF Functions */
-#define ODM_COMP_TX_PWR_TRACK                  BIT(24)
-#define ODM_COMP_RX_GAIN_TRACK                 BIT(25)
-#define ODM_COMP_CALIBRATION                   BIT(26)
-/* Common Functions */
-#define ODM_COMP_COMMON                                BIT(30)
-#define ODM_COMP_INIT                          BIT(31)
-
-/*------------------------Export Macro Definition---------------------------*/
-       #define RT_PRINTK(fmt, args...) printk("%s(): " fmt, __func__, ## args);
-
-#ifndef ASSERT
-       #define ASSERT(expr)
-#endif
-
-#define ODM_RT_TRACE(pDM_Odm, comp, level, fmt)                                                        \
-               if(((comp) & pDM_Odm->DebugComponents) && (level <= pDM_Odm->DebugLevel))       \
-               {                                                                               \
-                       printk("[ODM-8723A] ");                                         \
-                       RT_PRINTK fmt;                                                          \
-               }
-
-#define ODM_RT_ASSERT(pDM_Odm, expr, fmt)                                                      \
-               if(!(expr)) {                                                                   \
-                       printk("Assertion failed! %s at ......\n", #expr);                      \
-                       printk("      ......%s,%s,line=%d\n", __FILE__, __func__, __LINE__);\
-                       RT_PRINTK fmt;                                                          \
-                       ASSERT(false);                                                          \
-               }
-
-void ODM_InitDebugSetting23a(struct dm_odm_t *pDM_Odm);
-
-#endif /*  __ODM_DBG_H__ */
diff --git a/drivers/staging/rtl8723au/include/odm_interface.h b/drivers/staging/rtl8723au/include/odm_interface.h
deleted file mode 100644 (file)
index 1d3bf03..0000000
+++ /dev/null
@@ -1,62 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-
-
-#ifndef        __ODM_INTERFACE_H__
-#define __ODM_INTERFACE_H__
-
-
-/*  _cat: implemented by Token-Pasting Operator. */
-
-/*===================================
-
-#define ODM_REG_DIG_11N                0xC50
-#define ODM_REG_DIG_11AC       0xDDD
-
-ODM_REG(DIG,_pDM_Odm)
-=====================================*/
-
-#define _reg_11N(_name)                        ODM_REG_##_name##_11N
-#define _reg_11AC(_name)               ODM_REG_##_name##_11AC
-#define _bit_11N(_name)                        ODM_BIT_##_name##_11N
-#define _bit_11AC(_name)               ODM_BIT_##_name##_11AC
-
-#define _cat(_name, _func)                                     \
-       (                                                       \
-               _func##_11N(_name)                              \
-       )
-
-/*  _name: name of register or bit. */
-/*  Example: "ODM_REG(R_A_AGC_CORE1, pDM_Odm)" */
-/*         gets "ODM_R_A_AGC_CORE1" or "ODM_R_A_AGC_CORE1_8192C", depends on SupportICType. */
-#define ODM_REG(_name, _pDM_Odm)       _cat(_name, _reg)
-#define ODM_BIT(_name, _pDM_Odm)       _cat(_name, _bit)
-
-/*  */
-/*  2012/02/17 MH For non-MP compile pass only. Linux does not support workitem. */
-/*  Suggest HW team to use thread instead of workitem. Windows also support the feature. */
-/*  */
-typedef void (*RT_WORKITEM_CALL_BACK)(struct work_struct *pContext);
-
-/*  */
-/*  =========== EXtern Function Prototype */
-/*  */
-
-void ODM_SetRFReg(struct dm_odm_t *pDM_Odm, enum RF_RADIO_PATH eRFPath,
-                 u32 RegAddr, u32 BitMask, u32 Data);
-u32 ODM_GetRFReg(struct dm_odm_t *pDM_Odm, enum RF_RADIO_PATH eRFPath,
-                u32 RegAddr, u32 BitMask);
-
-#endif /*  __ODM_INTERFACE_H__ */
diff --git a/drivers/staging/rtl8723au/include/odm_precomp.h b/drivers/staging/rtl8723au/include/odm_precomp.h
deleted file mode 100644 (file)
index fb793c8..0000000
+++ /dev/null
@@ -1,49 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-
-#ifndef        __ODM_PRECOMP_H__
-#define __ODM_PRECOMP_H__
-
-/* 2 Config Flags and Structs - defined by each ODM Type */
-
-#include <osdep_service.h>
-#include <drv_types.h>
-#include <hal_intf.h>
-
-
-/* 2 Hardware Parameter Files */
-#include "Hal8723UHWImg_CE.h"
-
-
-/* 2 OutSrc Header Files */
-
-#include "odm.h"
-#include "odm_HWConfig.h"
-#include "odm_debug.h"
-#include "odm_RegDefine11N.h"
-
-#include "HalDMOutSrc8723A.h" /* for IQK,LCK,Power-tracking */
-#include "rtl8723a_hal.h"
-
-#include "odm_interface.h"
-#include "odm_reg.h"
-
-#include "HalHWImg8723A_MAC.h"
-#include "HalHWImg8723A_RF.h"
-#include "HalHWImg8723A_BB.h"
-#include "HalHWImg8723A_FW.h"
-#include "odm_RegConfig8723A.h"
-
-#endif /*  __ODM_PRECOMP_H__ */
diff --git a/drivers/staging/rtl8723au/include/odm_reg.h b/drivers/staging/rtl8723au/include/odm_reg.h
deleted file mode 100644 (file)
index c184331..0000000
+++ /dev/null
@@ -1,111 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-/*  */
-/*  File Name: odm_reg.h */
-/*  */
-/*  Description: */
-/*  */
-/*  This file is for general register definition. */
-/*  */
-/*  */
-/*  */
-#ifndef        __HAL_ODM_REG_H__
-#define __HAL_ODM_REG_H__
-
-/*  */
-/*  Register Definition */
-/*  */
-
-/* MAC REG */
-#define        ODM_BB_RESET                                    0x002
-#define        ODM_DUMMY                                               0x4fe
-#define        ODM_EDCA_VO_PARAM                       0x500
-#define        ODM_EDCA_VI_PARAM                       0x504
-#define        ODM_EDCA_BE_PARAM                       0x508
-#define        ODM_EDCA_BK_PARAM                       0x50C
-#define        ODM_TXPAUSE                                     0x522
-
-/* BB REG */
-#define        ODM_FPGA_PHY0_PAGE8                     0x800
-#define        ODM_PSD_SETTING                         0x808
-#define        ODM_AFE_SETTING                         0x818
-#define        ODM_TXAGC_B_6_18                                0x830
-#define        ODM_TXAGC_B_24_54                       0x834
-#define        ODM_TXAGC_B_MCS32_5                     0x838
-#define        ODM_TXAGC_B_MCS0_MCS3           0x83c
-#define        ODM_TXAGC_B_MCS4_MCS7           0x848
-#define        ODM_TXAGC_B_MCS8_MCS11          0x84c
-#define        ODM_ANALOG_REGISTER                     0x85c
-#define        ODM_RF_INTERFACE_OUTPUT         0x860
-#define        ODM_TXAGC_B_MCS12_MCS15 0x868
-#define        ODM_TXAGC_B_11_A_2_11           0x86c
-#define        ODM_AD_DA_LSB_MASK                      0x874
-#define        ODM_ENABLE_3_WIRE                       0x88c
-#define        ODM_PSD_REPORT                          0x8b4
-#define        ODM_R_ANT_SELECT                                0x90c
-#define        ODM_CCK_ANT_SELECT                      0xa07
-#define        ODM_CCK_PD_THRESH                       0xa0a
-#define        ODM_CCK_RF_REG1                         0xa11
-#define        ODM_CCK_MATCH_FILTER                    0xa20
-#define        ODM_CCK_RAKE_MAC                                0xa2e
-#define        ODM_CCK_CNT_RESET                       0xa2d
-#define        ODM_CCK_TX_DIVERSITY                    0xa2f
-#define        ODM_CCK_FA_CNT_MSB                      0xa5b
-#define        ODM_CCK_FA_CNT_LSB                      0xa5c
-#define        ODM_CCK_NEW_FUNCTION            0xa75
-#define        ODM_OFDM_PHY0_PAGE_C            0xc00
-#define        ODM_OFDM_RX_ANT                         0xc04
-#define        ODM_R_A_RXIQI                                   0xc14
-#define        ODM_R_A_AGC_CORE1                       0xc50
-#define        ODM_R_A_AGC_CORE2                       0xc54
-#define        ODM_R_B_AGC_CORE1                       0xc58
-#define        ODM_R_AGC_PAR                                   0xc70
-#define        ODM_R_HTSTF_AGC_PAR                     0xc7c
-#define        ODM_TX_PWR_TRAINING_A           0xc90
-#define        ODM_TX_PWR_TRAINING_B           0xc98
-#define        ODM_OFDM_FA_CNT1                                0xcf0
-#define        ODM_OFDM_PHY0_PAGE_D            0xd00
-#define        ODM_OFDM_FA_CNT2                                0xda0
-#define        ODM_OFDM_FA_CNT3                                0xda4
-#define        ODM_OFDM_FA_CNT4                                0xda8
-#define        ODM_TXAGC_A_6_18                                0xe00
-#define        ODM_TXAGC_A_24_54                       0xe04
-#define        ODM_TXAGC_A_1_MCS32                     0xe08
-#define        ODM_TXAGC_A_MCS0_MCS3           0xe10
-#define        ODM_TXAGC_A_MCS4_MCS7           0xe14
-#define        ODM_TXAGC_A_MCS8_MCS11          0xe18
-#define        ODM_TXAGC_A_MCS12_MCS15         0xe1c
-
-/* RF REG */
-#define        ODM_GAIN_SETTING                                0x00
-#define        ODM_CHANNEL                                     0x18
-
-/* Ant Detect Reg */
-#define        ODM_DPDT                                                0x300
-
-/* PSD Init */
-#define        ODM_PSDREG                                      0x808
-
-/* 92D Path Div */
-#define        PATHDIV_REG                                     0xB30
-#define        PATHDIV_TRI                                     0xBA0
-
-/*  */
-/*  Bitmap Definition */
-/*  */
-
-#define        BIT_FA_RESET                                    BIT(0)
-
-#endif
diff --git a/drivers/staging/rtl8723au/include/osdep_intf.h b/drivers/staging/rtl8723au/include/osdep_intf.h
deleted file mode 100644 (file)
index a157eb2..0000000
+++ /dev/null
@@ -1,45 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-
-#ifndef __OSDEP_INTF_H_
-#define __OSDEP_INTF_H_
-
-#include <osdep_service.h>
-#include <drv_types.h>
-
-int rtw_init_drv_sw23a(struct rtw_adapter *padapter);
-int rtw_free_drv_sw23a(struct rtw_adapter *padapter);
-int rtw_reset_drv_sw23a(struct rtw_adapter *padapter);
-
-void rtw_cancel_all_timer23a(struct rtw_adapter *padapter);
-
-int rtw_init_netdev23a_name23a(struct net_device *pnetdev, const char *ifname);
-struct net_device *rtw_init_netdev23a(struct rtw_adapter *padapter);
-
-u16 rtw_recv_select_queue23a(struct sk_buff *skb);
-
-void rtw_ips_dev_unload23a(struct rtw_adapter *padapter);
-
-int rtw_ips_pwr_up23a(struct rtw_adapter *padapter);
-void rtw_ips_pwr_down23a(struct rtw_adapter *padapter);
-
-int rtw_drv_register_netdev(struct rtw_adapter *padapter);
-void rtw_ndev_destructor(struct net_device *ndev);
-
-int rtl8723au_inirp_init(struct rtw_adapter *Adapter);
-int rtl8723au_inirp_deinit(struct rtw_adapter *Adapter);
-void rtl8723a_usb_intf_stop(struct rtw_adapter *padapter);
-
-#endif /* _OSDEP_INTF_H_ */
diff --git a/drivers/staging/rtl8723au/include/osdep_service.h b/drivers/staging/rtl8723au/include/osdep_service.h
deleted file mode 100644 (file)
index 33ecb9c..0000000
+++ /dev/null
@@ -1,87 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#ifndef __OSDEP_SERVICE_H_
-#define __OSDEP_SERVICE_H_
-
-#define _FAIL          0
-#define _SUCCESS       1
-#define RTW_RX_HANDLED 2
-
-#include <linux/spinlock.h>
-#include <linux/compiler.h>
-#include <linux/kernel.h>
-#include <linux/errno.h>
-#include <linux/init.h>
-#include <linux/slab.h>
-#include <linux/module.h>
-#include <linux/kref.h>
-#include <linux/netdevice.h>
-#include <linux/skbuff.h>
-#include <linux/uaccess.h>
-#include <asm/byteorder.h>
-#include <linux/atomic.h>
-#include <linux/io.h>
-#include <linux/sem.h>
-#include <linux/sched.h>
-#include <linux/etherdevice.h>
-#include <linux/wireless.h>
-#include <linux/if_arp.h>
-#include <linux/rtnetlink.h>
-#include <linux/delay.h>
-#include <linux/interrupt.h>   /*  for struct tasklet_struct */
-#include <linux/ip.h>
-
-#include <net/ieee80211_radiotap.h>
-#include <net/cfg80211.h>
-
-struct rtw_queue {
-       struct  list_head       queue;
-       spinlock_t              lock;
-};
-
-static inline struct list_head *get_list_head(struct rtw_queue *queue)
-{
-       return &queue->queue;
-}
-
-static inline int rtw_netif_queue_stopped(struct net_device *pnetdev)
-{
-       return (netif_tx_queue_stopped(netdev_get_tx_queue(pnetdev, 0)) &&
-               netif_tx_queue_stopped(netdev_get_tx_queue(pnetdev, 1)) &&
-               netif_tx_queue_stopped(netdev_get_tx_queue(pnetdev, 2)) &&
-               netif_tx_queue_stopped(netdev_get_tx_queue(pnetdev, 3)));
-}
-
-static inline u32 CHKBIT(u32 x)
-{
-       WARN_ON(x >= 32);
-       if (x >= 32)
-               return 0;
-       return BIT(x);
-}
-
-extern unsigned char MCS_rate_2R23A[16];
-
-extern unsigned char   MCS_rate_2R23A[16];
-extern unsigned char   MCS_rate_1R23A[16];
-
-void   _rtw_init_queue23a(struct rtw_queue *pqueue);
-
-/* Macros for handling unaligned memory accesses */
-
-#define RTW_GET_BE24(a) ((((u32) (a)[0]) << 16) | (((u32) (a)[1]) << 8) | \
-                        ((u32) (a)[2]))
-
-#endif
diff --git a/drivers/staging/rtl8723au/include/recv_osdep.h b/drivers/staging/rtl8723au/include/recv_osdep.h
deleted file mode 100644 (file)
index c2d3f1b..0000000
+++ /dev/null
@@ -1,36 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#ifndef __RECV_OSDEP_H_
-#define __RECV_OSDEP_H_
-
-#include <osdep_service.h>
-#include <drv_types.h>
-
-int _rtw_init_recv_priv23a(struct recv_priv *precvpriv, struct rtw_adapter *padapter);
-void _rtw_free_recv_priv23a (struct recv_priv *precvpriv);
-
-int rtw_recv_entry23a(struct recv_frame *precv_frame);
-int rtw_recv_indicatepkt23a(struct rtw_adapter *adapter, struct recv_frame *precv_frame);
-
-void rtw_handle_tkip_mic_err23a(struct rtw_adapter *padapter, u8 bgroup);
-
-int    rtw_init_recv_priv(struct recv_priv *precvpriv, struct rtw_adapter *padapter);
-void rtw_free_recv_priv (struct recv_priv *precvpriv);
-
-int rtw_os_recv_resource_init(struct recv_priv *precvpriv, struct rtw_adapter *padapter);
-
-void rtw_init_recv_timer23a(struct recv_reorder_ctrl *preorder_ctrl);
-
-#endif
diff --git a/drivers/staging/rtl8723au/include/rtl8723a_bt-coexist.h b/drivers/staging/rtl8723au/include/rtl8723a_bt-coexist.h
deleted file mode 100644 (file)
index 7add5df..0000000
+++ /dev/null
@@ -1,1627 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#ifndef __RTL8723A_BT_COEXIST_H__
-#define __RTL8723A_BT_COEXIST_H__
-
-#include <drv_types.h>
-#include "odm_precomp.h"
-
-
-/*  HEADER/PlatformDef.h */
-enum rt_media_status {
-       RT_MEDIA_DISCONNECT     = 0,
-       RT_MEDIA_CONNECT        = 1
-};
-
-/*  ===== Below this line is sync from SD7 driver COMMON/BT.h ===== */
-
-#define        BT_TMP_BUF_SIZE         100
-
-void BT_SignalCompensation(struct rtw_adapter *padapter,
-                          u8 *rssi_wifi, u8 *rssi_bt);
-void BT_HaltProcess(struct rtw_adapter *padapter);
-void BT_LpsLeave(struct rtw_adapter *padapter);
-
-
-#define        BT_HsConnectionEstablished(Adapter)             false
-/*  ===== End of sync from SD7 driver COMMON/BT.h ===== */
-
-/*  HEADER/SecurityType.h */
-#define TKIP_ENC_KEY_POS               32              /* KEK_LEN+KEK_LEN) */
-#define MAXRSNIELEN                            256
-
-/*  COMMON/Protocol802_11.h */
-/*  */
-/*       802.11 Management frame Status Code field */
-/*  */
-struct octet_string {
-       u8              *Octet;
-       u16             Length;
-};
-
-
-/*  AES_CCMP specific */
-enum {
-       AESCCMP_BLK_SIZE                =   16,     /*  # octets in an AES block */
-       AESCCMP_MAX_PACKET              =   4*512,  /*  largest packet size */
-       AESCCMP_N_RESERVED              =   0,      /*  reserved nonce octet value */
-       AESCCMP_A_DATA                  =   0x40,   /*  the Adata bit in the flags */
-       AESCCMP_M_SHIFT                 =   3,      /*  how much to shift the 3-bit M field */
-       AESCCMP_L_SHIFT                 =   0,      /*  how much to shift the 3-bit L field */
-       AESCCMP_L_SIZE                  =   2,       /*  size of the l(m) length field (in octets) */
-       AESCCMP_OFFSET_SC               =       22,
-       AESCCMP_OFFSET_DURATION =       4,
-       AESCCMP_OFFSET_A2               =       10,
-       AESCCMP_OFFSET_A4               =       24,
-       AESCCMP_QC_TID_MASK             =       0x0f,
-       AESCCMP_BLK_SIZE_TOTAL  =   16*16,     /*  Added by Annie for CKIP AES MIC BSOD, 2006-08-17. */
-                                                                                       /*  16*8 < 4*60  Resove to 16*16 */
-};
-
-/*  Key Length */
-#define PMK_LEN                                32
-#define PTK_LEN_TKIP                   64
-#define GTK_LEN                                32
-#define KEY_NONCE_LEN                  32
-
-
-/*  COMMON/Dot11d.h */
-struct chnl_txpower_triple {
-       u8 FirstChnl;
-       u8 NumChnls;
-       s8 MaxTxPowerInDbm;
-};
-
-
-/*  ===== Below this line is sync from SD7 driver COMMON/bt_hci.h ===== */
-/*  The following is for BT 3.0 + HS HCI COMMAND ERRORS CODES */
-
-#define Max80211PALPDUSize                     1492
-#define Max80211AMPASSOCLen                    672
-#define MinGUserPrio                                   4
-#define MaxGUserPrio                                   7
-#define BEUserPrio0                                            0
-#define BEUserPrio1                                            3
-#define Max80211BeaconPeriod           2000
-#define ShortRangeModePowerMax         4
-
-#define BT_Default_Chnl                                        10
-#define ACLDataHeaderLen                               4
-
-#define BTTotalDataBlockNum                    0x100
-#define BTLocalBufNum                                  0x200
-#define BTMaxDataBlockLen                              0x800
-#define BTTOTALBANDWIDTH                               0x7530
-#define BTMAXBANDGUBANDWIDTH           0x4e20
-#define TmpLocalBufSize                                        0x100
-#define BTSynDataPacketLength                  0xff
-/*  */
-
-#define BTMaxAuthCount                                 5
-#define BTMaxAsocCount                                 5
-
-#define MAX_LOGICAL_LINK_NUM                   2       /* temporarily define */
-#define MAX_BT_ASOC_ENTRY_NUM          2       /* temporarily define */
-
-#define INVALID_PL_HANDLE                              0xff
-#define INVALID_ENTRY_NUM                              0xff
-/*  */
-
-#define CAM_BT_START_INDEX             (HALF_CAM_ENTRY - 4)   /*  MAX_BT_ASOC_ENTRY_NUM : 4 !!! */
-#define BT_HWCAM_STAR                  CAM_BT_START_INDEX  /*  We used  HALF_CAM_ENTRY ~ HALF_CAM_ENTRY -MAX_BT_ASOC_ENTRY_NUM */
-
-enum hci_status {
-       HCI_STATUS_SUCCESS                      = 0x00, /* Success */
-       HCI_STATUS_UNKNOW_HCI_CMD               = 0x01, /* Unknown HCI Command */
-       HCI_STATUS_UNKNOW_CONNECT_ID            = 0X02, /* Unknown Connection Identifier */
-       HCI_STATUS_HW_FAIL                      = 0X03, /* Hardware Failure */
-       HCI_STATUS_PAGE_TIMEOUT                 = 0X04, /* Page Timeout */
-       HCI_STATUS_AUTH_FAIL                    = 0X05, /* Authentication Failure */
-       HCI_STATUS_PIN_OR_KEY_MISSING           = 0X06, /* PIN or Key Missing */
-       HCI_STATUS_MEM_CAP_EXCEED               = 0X07, /* Memory Capacity Exceeded */
-       HCI_STATUS_CONNECT_TIMEOUT              = 0X08, /* Connection Timeout */
-       HCI_STATUS_CONNECT_LIMIT                = 0X09, /* Connection Limit Exceeded */
-       HCI_STATUS_SYN_CONNECT_LIMIT            = 0X0a, /* Synchronous Connection Limit To A Device Exceeded */
-       HCI_STATUS_ACL_CONNECT_EXISTS           = 0X0b, /* ACL Connection Already Exists */
-       HCI_STATUS_CMD_DISALLOW                 = 0X0c, /* Command Disallowed */
-       HCI_STATUS_CONNECT_RJT_LIMIT_RESOURCE   = 0X0d, /* Connection Rejected due to Limited Resources */
-       HCI_STATUS_CONNECT_RJT_SEC_REASON       = 0X0e, /* Connection Rejected Due To Security Reasons */
-       HCI_STATUS_CONNECT_RJT_UNACCEPT_BD_ADDR = 0X0f, /* Connection Rejected due to Unacceptable BD_ADDR */
-       HCI_STATUS_CONNECT_ACCEPT_TIMEOUT       = 0X10, /* Connection Accept Timeout Exceeded */
-       HCI_STATUS_UNSUPPORT_FEATURE_PARA_VALUE = 0X11, /* Unsupported Feature or Parameter Value */
-       HCI_STATUS_INVALID_HCI_CMD_PARA_VALUE   = 0X12, /* Invalid HCI Command Parameters */
-       HCI_STATUS_REMOTE_USER_TERMINATE_CONNECT = 0X13, /* Remote User Terminated Connection */
-       HCI_STATUS_REMOTE_DEV_TERMINATE_LOW_RESOURCE = 0X14, /* Remote Device Terminated Connection due to Low Resources */
-       HCI_STATUS_REMOTE_DEV_TERMINATE_CONNECT_POWER_OFF = 0X15, /* Remote Device Terminated Connection due to Power Off */
-       HCI_STATUS_CONNECT_TERMINATE_LOCAL_HOST = 0X16, /* Connection Terminated By Local Host */
-       HCI_STATUS_REPEATE_ATTEMPT              = 0X17, /* Repeated Attempts */
-       HCI_STATUS_PAIR_NOT_ALLOW               = 0X18, /* Pairing Not Allowed */
-       HCI_STATUS_UNKNOW_LMP_PDU               = 0X19, /* Unknown LMP PDU */
-       HCI_STATUS_UNSUPPORT_REMOTE_LMP_FEATURE = 0X1a, /* Unsupported Remote Feature / Unsupported LMP Feature */
-       HCI_STATUS_SOC_OFFSET_REJECT            = 0X1b, /* SCO Offset Rejected */
-       HCI_STATUS_SOC_INTERVAL_REJECT          = 0X1c, /* SCO Interval Rejected */
-       HCI_STATUS_SOC_AIR_MODE_REJECT          = 0X1d,/* SCO Air Mode Rejected */
-       HCI_STATUS_INVALID_LMP_PARA             = 0X1e, /* Invalid LMP Parameters */
-       HCI_STATUS_UNSPECIFIC_ERROR             = 0X1f, /* Unspecified Error */
-       HCI_STATUS_UNSUPPORT_LMP_PARA_VALUE     = 0X20, /* Unsupported LMP Parameter Value */
-       HCI_STATUS_ROLE_CHANGE_NOT_ALLOW        = 0X21, /* Role Change Not Allowed */
-       HCI_STATUS_LMP_RESPONSE_TIMEOUT         = 0X22, /* LMP Response Timeout */
-       HCI_STATUS_LMP_ERROR_TRANSACTION_COLLISION = 0X23, /* LMP Error Transaction Collision */
-       HCI_STATUS_LMP_PDU_NOT_ALLOW            = 0X24, /* LMP PDU Not Allowed */
-       HCI_STATUS_ENCRYPTION_MODE_NOT_ALLOW    = 0X25, /* Encryption Mode Not Acceptable */
-       HCI_STATUS_LINK_KEY_CAN_NOT_CHANGE      = 0X26, /* Link Key Can Not be Changed */
-       HCI_STATUS_REQUEST_QOS_NOT_SUPPORT      = 0X27, /* Requested QoS Not Supported */
-       HCI_STATUS_INSTANT_PASSED               = 0X28, /* Instant Passed */
-       HCI_STATUS_PAIRING_UNIT_KEY_NOT_SUPPORT = 0X29, /* Pairing With Unit Key Not Supported */
-       HCI_STATUS_DIFFERENT_TRANSACTION_COLLISION = 0X2a, /* Different Transaction Collision */
-       HCI_STATUS_RESERVE_1                    = 0X2b, /* Reserved */
-       HCI_STATUS_QOS_UNACCEPT_PARA            = 0X2c, /* QoS Unacceptable Parameter */
-       HCI_STATUS_QOS_REJECT                   = 0X2d, /* QoS Rejected */
-       HCI_STATUS_CHNL_CLASSIFICATION_NOT_SUPPORT = 0X2e, /* Channel Classification Not Supported */
-       HCI_STATUS_INSUFFICIENT_SECURITY        = 0X2f, /* Insufficient Security */
-       HCI_STATUS_PARA_OUT_OF_RANGE            = 0x30, /* Parameter Out Of Mandatory Range */
-       HCI_STATUS_RESERVE_2                    = 0X31, /* Reserved */
-       HCI_STATUS_ROLE_SWITCH_PENDING          = 0X32, /* Role Switch Pending */
-       HCI_STATUS_RESERVE_3                    = 0X33, /* Reserved */
-       HCI_STATUS_RESERVE_SOLT_VIOLATION       = 0X34, /* Reserved Slot Violation */
-       HCI_STATUS_ROLE_SWITCH_FAIL             = 0X35, /* Role Switch Failed */
-       HCI_STATUS_EXTEND_INQUIRY_RSP_TOO_LARGE = 0X36, /* Extended Inquiry Response Too Large */
-       HCI_STATUS_SEC_SIMPLE_PAIRING_NOT_SUPPORT = 0X37, /* Secure Simple Pairing Not Supported By Host. */
-       HCI_STATUS_HOST_BUSY_PAIRING            = 0X38, /* Host Busy - Pairing */
-       HCI_STATUS_CONNECT_REJ_NOT_SUIT_CHNL_FOUND = 0X39, /* Connection Rejected due to No Suitable Channel Found */
-       HCI_STATUS_CONTROLLER_BUSY              = 0X3a  /* CONTROLLER BUSY */
-};
-
-/*  */
-/*  The following is for BT 3.0 + HS HCI COMMAND */
-/*  */
-
-/* bit 0  1  2  3  4  5  6  7  8  9 10 11 12 13 14 15 */
-/*      |      OCF                                  |     OGF       | */
-/*  */
-
-/* OGF 0x01 */
-#define LINK_CONTROL_COMMANDS                  0x01
-enum link_control_commands {
-       HCI_INQUIRY                                     = 0x0001,
-       HCI_INQUIRY_CANCEL                              = 0x0002,
-       HCI_PERIODIC_INQUIRY_MODE                       = 0x0003,
-       HCI_EXIT_PERIODIC_INQUIRY_MODE                  = 0x0004,
-       HCI_CREATE_CONNECTION                           = 0x0005,
-       HCI_DISCONNECT                                  = 0x0006,
-       HCI_CREATE_CONNECTION_CANCEL                    = 0x0008,
-       HCI_ACCEPT_CONNECTIONREQUEST                    = 0x0009,
-       HCI_REJECT_CONNECTION_REQUEST                   = 0x000a,
-       HCI_LINK_KEY_REQUEST_REPLY                      = 0x000b,
-       HCI_LINK_KEY_REQUEST_NEGATIVE_REPLY             = 0x000c,
-       HCI_PIN_CODE_REQUEST_REPLY                      = 0x000d,
-       HCI_PIN_CODE_REQUEST_NEGATIVE_REPLY             = 0x000e,
-       HCI_CHANGE_CONNECTION_PACKET_TYPE               = 0x000f,
-       HCI_AUTHENTICATION_REQUESTED                    = 0x0011,
-       HCI_SET_CONNECTION_ENCRYPTION                   = 0x0013,
-       HCI_CHANGE_CONNECTION_LINK_KEY                  = 0x0015,
-       HCI_MASTER_LINK_KEY                             = 0x0017,
-       HCI_REMOTE_NAME_REQUEST                         = 0x0019,
-       HCI_REMOTE_NAME_REQUEST_CANCEL                  = 0x001a,
-       HCI_READ_REMOTE_SUPPORTED_FEATURES              = 0x001b,
-       HCI_READ_REMOTE_EXTENDED_FEATURES               = 0x001c,
-       HCI_READ_REMOTE_VERSION_INFORMATION             = 0x001d,
-       HCI_READ_CLOCK_OFFSET                           = 0x001f,
-       HCI_READ_LMP_HANDLE                             = 0x0020,
-       HCI_SETUP_SYNCHRONOUS_CONNECTION                = 0x0028,
-       HCI_ACCEPT_SYNCHRONOUS_CONNECTION_REQUEST       = 0x0029,
-       HCI_REJECT_SYNCHRONOUS_CONNECTION_REQUEST       = 0x002a,
-       HCI_IO_CAPABILITY_REQUEST_REPLY                 = 0x002b,
-       HCI_USER_CONFIRMATION_REQUEST_REPLY             = 0x002c,
-       HCI_USER_CONFIRMATION_REQUEST_NEGATIVE_REPLY    = 0x002d,
-       HCI_USER_PASSKEY_REQUEST_REPLY                  = 0x002e,
-       HCI_USER_PASSKEY_REQUESTNEGATIVE_REPLY          = 0x002f,
-       HCI_REMOTE_OOB_DATA_REQUEST_REPLY               = 0x0030,
-       HCI_REMOTE_OOB_DATA_REQUEST_NEGATIVE_REPLY      = 0x0033,
-       HCI_IO_CAPABILITY_REQUEST_NEGATIVE_REPLY        = 0x0034,
-       HCI_CREATE_PHYSICAL_LINK                        = 0x0035,
-       HCI_ACCEPT_PHYSICAL_LINK                        = 0x0036,
-       HCI_DISCONNECT_PHYSICAL_LINK                    = 0x0037,
-       HCI_CREATE_LOGICAL_LINK                         = 0x0038,
-       HCI_ACCEPT_LOGICAL_LINK                         = 0x0039,
-       HCI_DISCONNECT_LOGICAL_LINK                     = 0x003a,
-       HCI_LOGICAL_LINK_CANCEL                         = 0x003b,
-       HCI_FLOW_SPEC_MODIFY                            = 0x003c
-};
-
-/* OGF 0x02 */
-#define HOLD_MODE_COMMAND                              0x02
-enum hold_mode_command {
-       HCI_HOLD_MODE                                   = 0x0001,
-       HCI_SNIFF_MODE                                  = 0x0002,
-       HCI_EXIT_SNIFF_MODE                             = 0x0003,
-       HCI_PARK_STATE                                  = 0x0005,
-       HCI_EXIT_PARK_STATE                             = 0x0006,
-       HCI_QOS_SETUP                                   = 0x0007,
-       HCI_ROLE_DISCOVERY                              = 0x0009,
-       HCI_SWITCH_ROLE                                 = 0x000b,
-       HCI_READ_LINK_POLICY_SETTINGS                   = 0x000c,
-       HCI_WRITE_LINK_POLICY_SETTINGS                  = 0x000d,
-       HCI_READ_DEFAULT_LINK_POLICY_SETTINGS           = 0x000e,
-       HCI_WRITE_DEFAULT_LINK_POLICY_SETTINGS          = 0x000f,
-       HCI_FLOW_SPECIFICATION                          = 0x0010,
-       HCI_SNIFF_SUBRATING                             = 0x0011
-};
-
-/* OGF 0x03 */
-#define OGF_SET_EVENT_MASK_COMMAND                     0x03
-enum set_event_mask_command {
-       HCI_SET_EVENT_MASK                              = 0x0001,
-       HCI_RESET                                       = 0x0003,
-       HCI_SET_EVENT_FILTER                            = 0x0005,
-       HCI_FLUSH                                       = 0x0008,
-       HCI_READ_PIN_TYPE                               = 0x0009,
-       HCI_WRITE_PIN_TYPE                              = 0x000a,
-       HCI_CREATE_NEW_UNIT_KEY                         = 0x000b,
-       HCI_READ_STORED_LINK_KEY                        = 0x000d,
-       HCI_WRITE_STORED_LINK_KEY                       = 0x0011,
-       HCI_DELETE_STORED_LINK_KEY                      = 0x0012,
-       HCI_WRITE_LOCAL_NAME                            = 0x0013,
-       HCI_READ_LOCAL_NAME                             = 0x0014,
-       HCI_READ_CONNECTION_ACCEPT_TIMEOUT              = 0x0015,
-       HCI_WRITE_CONNECTION_ACCEPT_TIMEOUT             = 0x0016,
-       HCI_READ_PAGE_TIMEOUT                           = 0x0017,
-       HCI_WRITE_PAGE_TIMEOUT                          = 0x0018,
-       HCI_READ_SCAN_ENABLE                            = 0x0019,
-       HCI_WRITE_SCAN_ENABLE                           = 0x001a,
-       HCI_READ_PAGE_SCAN_ACTIVITY                     = 0x001b,
-       HCI_WRITE_PAGE_SCAN_ACTIVITY                    = 0x001c,
-       HCI_READ_INQUIRY_SCAN_ACTIVITY                  = 0x001d,
-       HCI_WRITE_INQUIRY_SCAN_ACTIVITY                 = 0x001e,
-       HCI_READ_AUTHENTICATION_ENABLE                  = 0x001f,
-       HCI_WRITE_AUTHENTICATION_ENABLE                 = 0x0020,
-       HCI_READ_CLASS_OF_DEVICE                        = 0x0023,
-       HCI_WRITE_CLASS_OF_DEVICE                       = 0x0024,
-       HCI_READ_VOICE_SETTING                          = 0x0025,
-       HCI_WRITE_VOICE_SETTING                         = 0x0026,
-       HCI_READ_AUTOMATIC_FLUSH_TIMEOUT                = 0x0027,
-       HCI_WRITE_AUTOMATIC_FLUSH_TIMEOUT               = 0x0028,
-       HCI_READ_NUM_BROADCAST_RETRANSMISSIONS          = 0x0029,
-       HCI_WRITE_NUM_BROADCAST_RETRANSMISSIONS         = 0x002a,
-       HCI_READ_HOLD_MODE_ACTIVITY                     = 0x002b,
-       HCI_WRITE_HOLD_MODE_ACTIVITY                    = 0x002c,
-       HCI_READ_SYNCHRONOUS_FLOW_CONTROL_ENABLE        = 0x002e,
-       HCI_WRITE_SYNCHRONOUS_FLOW_CONTROL_ENABLE       = 0x002f,
-       HCI_SET_CONTROLLER_TO_HOST_FLOW_CONTROL         = 0x0031,
-       HCI_HOST_BUFFER_SIZE                            = 0x0033,
-       HCI_HOST_NUMBER_OF_COMPLETED_PACKETS            = 0x0035,
-       HCI_READ_LINK_SUPERVISION_TIMEOUT               = 0x0036,
-       HCI_WRITE_LINK_SUPERVISION_TIMEOUT              = 0x0037,
-       HCI_READ_NUMBER_OF_SUPPORTED_IAC                = 0x0038,
-       HCI_READ_CURRENT_IAC_LAP                        = 0x0039,
-       HCI_WRITE_CURRENT_IAC_LAP                       = 0x003a,
-       HCI_READ_PAGE_SCAN_MODE                         = 0x003d,
-       HCI_WRITE_PAGE_SCAN_MODE                        = 0x003e,
-       HCI_SET_AFH_HOST_CHANNEL_CLASSIFICATION         = 0x003f,
-       HCI_READ_INQUIRY_SCAN_TYPE                      = 0x0042,
-       HCI_WRITE_INQUIRY_SCAN_TYPE                     = 0x0043,
-       HCI_READ_INQUIRY_MODE                           = 0x0044,
-       HCI_WRITE_INQUIRY_MODE                          = 0x0045,
-       HCI_READ_PAGE_SCAN_TYPE                         = 0x0046,
-       HCI_WRITE_PAGE_SCAN_TYPE                        = 0x0047,
-       HCI_READ_AFH_CHANNEL_ASSESSMENT_MODE            = 0x0048,
-       HCI_WRITE_AFH_CHANNEL_ASSESSMENT_MODE           = 0x0049,
-       HCI_READ_EXTENDED_INQUIRY_RESPONSE              = 0x0051,
-       HCI_WRITE_EXTENDED_INQUIRY_RESPONSE             = 0x0052,
-       HCI_REFRESH_ENCRYPTION_KEY                      = 0x0053,
-       HCI_READ_SIMPLE_PAIRING_MODE                    = 0x0055,
-       HCI_WRITE_SIMPLE_PAIRING_MODE                   = 0x0056,
-       HCI_READ_LOCAL_OOB_DATA                         = 0x0057,
-       HCI_READ_INQUIRY_RESPONSE_TRANSMIT_POWER_LEVEL  = 0x0058,
-       HCI_WRITE_INQUIRY_TRANSMIT_POWER_LEVEL          = 0x0059,
-       HCI_READ_DEFAULT_ERRONEOUS_DATA_REPORTING       = 0x005a,
-       HCI_WRITE_DEFAULT_ERRONEOUS_DATA_REPORTING      = 0x005b,
-       HCI_ENHANCED_FLUSH                              = 0x005f,
-       HCI_SEND_KEYPRESS_NOTIFICATION                  = 0x0060,
-       HCI_READ_LOGICAL_LINK_ACCEPT_TIMEOUT            = 0x0061,
-       HCI_WRITE_LOGICAL_LINK_ACCEPT_TIMEOUT           = 0x0062,
-       HCI_SET_EVENT_MASK_PAGE_2                       = 0x0063,
-       HCI_READ_LOCATION_DATA                          = 0x0064,
-       HCI_WRITE_LOCATION_DATA                         = 0x0065,
-       HCI_READ_FLOW_CONTROL_MODE                      = 0x0066,
-       HCI_WRITE_FLOW_CONTROL_MODE                     = 0x0067,
-       HCI_READ_ENHANCE_TRANSMIT_POWER_LEVEL           = 0x0068,
-       HCI_READ_BEST_EFFORT_FLUSH_TIMEOUT              = 0x0069,
-       HCI_WRITE_BEST_EFFORT_FLUSH_TIMEOUT             = 0x006a,
-       HCI_SHORT_RANGE_MODE                            = 0x006b
-};
-
-/* OGF 0x04 */
-#define OGF_INFORMATIONAL_PARAMETERS                   0x04
-enum informational_params {
-       HCI_READ_LOCAL_VERSION_INFORMATION              = 0x0001,
-       HCI_READ_LOCAL_SUPPORTED_COMMANDS               = 0x0002,
-       HCI_READ_LOCAL_SUPPORTED_FEATURES               = 0x0003,
-       HCI_READ_LOCAL_EXTENDED_FEATURES                = 0x0004,
-       HCI_READ_BUFFER_SIZE                            = 0x0005,
-       HCI_READ_BD_ADDR                                = 0x0009,
-       HCI_READ_DATA_BLOCK_SIZE                        = 0x000a
-};
-
-/* OGF 0x05 */
-#define OGF_STATUS_PARAMETERS                          0x05
-enum status_params {
-       HCI_READ_FAILED_CONTACT_COUNTER                 = 0x0001,
-       HCI_RESET_FAILED_CONTACT_COUNTER                = 0x0002,
-       HCI_READ_LINK_QUALITY                           = 0x0003,
-       HCI_READ_RSSI                                   = 0x0005,
-       HCI_READ_AFH_CHANNEL_MAP                        = 0x0006,
-       HCI_READ_CLOCK                                  = 0x0007,
-       HCI_READ_ENCRYPTION_KEY_SIZE                    = 0x0008,
-       HCI_READ_LOCAL_AMP_INFO                         = 0x0009,
-       HCI_READ_LOCAL_AMP_ASSOC                        = 0x000a,
-       HCI_WRITE_REMOTE_AMP_ASSOC                      = 0x000b
-};
-
-/* OGF 0x06 */
-#define OGF_TESTING_COMMANDS                           0x06
-enum testing_commands {
-       HCI_READ_LOOPBACK_MODE                          = 0x0001,
-       HCI_WRITE_LOOPBACK_MODE                         = 0x0002,
-       HCI_ENABLE_DEVICE_UNDER_TEST_MODE               = 0x0003,
-       HCI_WRITE_SIMPLE_PAIRING_DEBUG_MODE             = 0x0004,
-       HCI_ENABLE_AMP_RECEIVER_REPORTS                 = 0x0007,
-       HCI_AMP_TEST_END                                = 0x0008,
-       HCI_AMP_TEST_COMMAND                            = 0x0009
-};
-
-/* OGF 0x3f */
-#define OGF_EXTENSION                                  0X3f
-enum hci_extension_commands {
-       HCI_SET_ACL_LINK_DATA_FLOW_MODE                 = 0x0010,
-       HCI_SET_ACL_LINK_STATUS                         = 0x0020,
-       HCI_SET_SCO_LINK_STATUS                         = 0x0030,
-       HCI_SET_RSSI_VALUE                              = 0x0040,
-       HCI_SET_CURRENT_BLUETOOTH_STATUS                = 0x0041,
-
-       /* The following is for RTK8723 */
-       HCI_EXTENSION_VERSION_NOTIFY                    = 0x0100,
-       HCI_LINK_STATUS_NOTIFY                          = 0x0101,
-       HCI_BT_OPERATION_NOTIFY                         = 0x0102,
-       HCI_ENABLE_WIFI_SCAN_NOTIFY                     = 0x0103,
-
-
-       /* The following is for IVT */
-       HCI_WIFI_CURRENT_CHANNEL                        = 0x0300,
-       HCI_WIFI_CURRENT_BANDWIDTH                      = 0x0301,
-       HCI_WIFI_CONNECTION_STATUS                      = 0x0302,
-};
-
-enum bt_spec {
-       BT_SPEC_1_0_b                                   = 0x00,
-       BT_SPEC_1_1                                     = 0x01,
-       BT_SPEC_1_2                                     = 0x02,
-       BT_SPEC_2_0_EDR                                 = 0x03,
-       BT_SPEC_2_1_EDR                                 = 0x04,
-       BT_SPEC_3_0_HS                                  = 0x05,
-       BT_SPEC_4_0                                     = 0x06
-};
-
-/*  The following is for BT 3.0 + HS EVENTS */
-enum hci_event {
-       HCI_EVENT_INQUIRY_COMPLETE                      = 0x01,
-       HCI_EVENT_INQUIRY_RESULT                        = 0x02,
-       HCI_EVENT_CONNECTION_COMPLETE                   = 0x03,
-       HCI_EVENT_CONNECTION_REQUEST                    = 0x04,
-       HCI_EVENT_DISCONNECTION_COMPLETE                = 0x05,
-       HCI_EVENT_AUTHENTICATION_COMPLETE               = 0x06,
-       HCI_EVENT_REMOTE_NAME_REQUEST_COMPLETE          = 0x07,
-       HCI_EVENT_ENCRYPTION_CHANGE                     = 0x08,
-       HCI_EVENT_CHANGE_LINK_KEY_COMPLETE              = 0x09,
-       HCI_EVENT_MASTER_LINK_KEY_COMPLETE              = 0x0a,
-       HCI_EVENT_READ_REMOTE_SUPPORT_FEATURES_COMPLETE = 0x0b,
-       HCI_EVENT_READ_REMOTE_VER_INFO_COMPLETE         = 0x0c,
-       HCI_EVENT_QOS_SETUP_COMPLETE                    = 0x0d,
-       HCI_EVENT_COMMAND_COMPLETE                      = 0x0e,
-       HCI_EVENT_COMMAND_STATUS                        = 0x0f,
-       HCI_EVENT_HARDWARE_ERROR                        = 0x10,
-       HCI_EVENT_FLUSH_OCCRUED                         = 0x11,
-       HCI_EVENT_ROLE_CHANGE                           = 0x12,
-       HCI_EVENT_NUMBER_OF_COMPLETE_PACKETS            = 0x13,
-       HCI_EVENT_MODE_CHANGE                           = 0x14,
-       HCI_EVENT_RETURN_LINK_KEYS                      = 0x15,
-       HCI_EVENT_PIN_CODE_REQUEST                      = 0x16,
-       HCI_EVENT_LINK_KEY_REQUEST                      = 0x17,
-       HCI_EVENT_LINK_KEY_NOTIFICATION                 = 0x18,
-       HCI_EVENT_LOOPBACK_COMMAND                      = 0x19,
-       HCI_EVENT_DATA_BUFFER_OVERFLOW                  = 0x1a,
-       HCI_EVENT_MAX_SLOTS_CHANGE                      = 0x1b,
-       HCI_EVENT_READ_CLOCK_OFFSET_COMPLETE            = 0x1c,
-       HCI_EVENT_CONNECT_PACKET_TYPE_CHANGE            = 0x1d,
-       HCI_EVENT_QOS_VIOLATION                         = 0x1e,
-       HCI_EVENT_PAGE_SCAN_REPETITION_MODE_CHANGE      = 0x20,
-       HCI_EVENT_FLOW_SEPC_COMPLETE                    = 0x21,
-       HCI_EVENT_INQUIRY_RESULT_WITH_RSSI              = 0x22,
-       HCI_EVENT_READ_REMOTE_EXT_FEATURES_COMPLETE     = 0x23,
-       HCI_EVENT_SYNC_CONNECT_COMPLETE                 = 0x2c,
-       HCI_EVENT_SYNC_CONNECT_CHANGE                   = 0x2d,
-       HCI_EVENT_SNIFFER_SUBRATING                     = 0x2e,
-       HCI_EVENT_EXTENTED_INQUIRY_RESULT               = 0x2f,
-       HCI_EVENT_ENCRYPTION_KEY_REFLASH_COMPLETE       = 0x30,
-       HCI_EVENT_IO_CAPIBILITY_COMPLETE                = 0x31,
-       HCI_EVENT_IO_CAPIBILITY_RESPONSE                = 0x32,
-       HCI_EVENT_USER_CONFIRMTION_REQUEST              = 0x33,
-       HCI_EVENT_USER_PASSKEY_REQUEST                  = 0x34,
-       HCI_EVENT_REMOTE_OOB_DATA_REQUEST               = 0x35,
-       HCI_EVENT_SIMPLE_PAIRING_COMPLETE               = 0x36,
-       HCI_EVENT_LINK_SUPERVISION_TIMEOUT_CHANGE       = 0x38,
-       HCI_EVENT_ENHANCED_FLUSH_COMPLETE               = 0x39,
-       HCI_EVENT_USER_PASSKEY_NOTIFICATION             = 0x3b,
-       HCI_EVENT_KEYPRESS_NOTIFICATION                 = 0x3c,
-       HCI_EVENT_REMOTE_HOST_SUPPORT_FEATURES_NOTIFICATION     = 0x3d,
-       HCI_EVENT_PHY_LINK_COMPLETE                     = 0x40,
-       HCI_EVENT_CHANNEL_SELECT                        = 0x41,
-       HCI_EVENT_DISCONNECT_PHY_LINK_COMPLETE          = 0x42,
-       HCI_EVENT_PHY_LINK_LOSS_EARLY_WARNING           = 0x43,
-       HCI_EVENT_PHY_LINK_RECOVER                      = 0x44,
-       HCI_EVENT_LOGICAL_LINK_COMPLETE                 = 0x45,
-       HCI_EVENT_DISCONNECT_LOGICAL_LINK_COMPLETE      = 0x46,
-       HCI_EVENT_FLOW_SPEC_MODIFY_COMPLETE             = 0x47,
-       HCI_EVENT_NUM_OF_COMPLETE_DATA_BLOCKS           = 0x48,
-       HCI_EVENT_AMP_START_TEST                        = 0x49,
-       HCI_EVENT_AMP_TEST_END                          = 0x4a,
-       HCI_EVENT_AMP_RECEIVER_REPORT                   = 0x4b,
-       HCI_EVENT_SHORT_RANGE_MODE_CHANGE_COMPLETE      = 0x4c,
-       HCI_EVENT_AMP_STATUS_CHANGE                     = 0x4d,
-       HCI_EVENT_EXTENSION_RTK                         = 0xfe,
-       HCI_EVENT_EXTENSION_MOTO                        = 0xff,
-};
-
-enum hci_extension_event_moto {
-       HCI_EVENT_GET_BT_RSSI                           = 0x01,
-};
-
-enum hci_extension_event {
-       HCI_EVENT_EXT_WIFI_SCAN_NOTIFY                  = 0x01,
-};
-
-enum hci_event_mask_page_2 {
-       EMP2_HCI_EVENT_PHY_LINK_COMPLETE                = 0x0000000000000001,
-       EMP2_HCI_EVENT_CHANNEL_SELECT                   = 0x0000000000000002,
-       EMP2_HCI_EVENT_DISCONNECT_PHY_LINK_COMPLETE     = 0x0000000000000004,
-       EMP2_HCI_EVENT_PHY_LINK_LOSS_EARLY_WARNING      = 0x0000000000000008,
-       EMP2_HCI_EVENT_PHY_LINK_RECOVER                 = 0x0000000000000010,
-       EMP2_HCI_EVENT_LOGICAL_LINK_COMPLETE            = 0x0000000000000020,
-       EMP2_HCI_EVENT_DISCONNECT_LOGICAL_LINK_COMPLETE = 0x0000000000000040,
-       EMP2_HCI_EVENT_FLOW_SPEC_MODIFY_COMPLETE        = 0x0000000000000080,
-       EMP2_HCI_EVENT_NUM_OF_COMPLETE_DATA_BLOCKS      = 0x0000000000000100,
-       EMP2_HCI_EVENT_AMP_START_TEST                   = 0x0000000000000200,
-       EMP2_HCI_EVENT_AMP_TEST_END                     = 0x0000000000000400,
-       EMP2_HCI_EVENT_AMP_RECEIVER_REPORT              = 0x0000000000000800,
-       EMP2_HCI_EVENT_SHORT_RANGE_MODE_CHANGE_COMPLETE = 0x0000000000001000,
-       EMP2_HCI_EVENT_AMP_STATUS_CHANGE                = 0x0000000000002000,
-};
-
-enum hci_state_machine {
-       HCI_STATE_STARTING                      = 0x01,
-       HCI_STATE_CONNECTING                    = 0x02,
-       HCI_STATE_AUTHENTICATING                = 0x04,
-       HCI_STATE_CONNECTED                     = 0x08,
-       HCI_STATE_DISCONNECTING                 = 0x10,
-       HCI_STATE_DISCONNECTED                  = 0x20
-};
-
-enum amp_assoc_structure_type {
-       AMP_MAC_ADDR                            = 0x01,
-       AMP_PREFERRED_CHANNEL_LIST              = 0x02,
-       AMP_CONNECTED_CHANNEL                   = 0x03,
-       AMP_80211_PAL_CAP_LIST                  = 0x04,
-       AMP_80211_PAL_VISION                    = 0x05,
-       AMP_RESERVED_FOR_TESTING                = 0x33
-};
-
-enum amp_btap_type {
-       AMP_BTAP_NONE,
-       AMP_BTAP_CREATOR,
-       AMP_BTAP_JOINER
-};
-
-enum hci_state_with_cmd {
-       STATE_CMD_CREATE_PHY_LINK,
-       STATE_CMD_ACCEPT_PHY_LINK,
-       STATE_CMD_DISCONNECT_PHY_LINK,
-       STATE_CMD_CONNECT_ACCEPT_TIMEOUT,
-       STATE_CMD_MAC_START_COMPLETE,
-       STATE_CMD_MAC_START_FAILED,
-       STATE_CMD_MAC_CONNECT_COMPLETE,
-       STATE_CMD_MAC_CONNECT_FAILED,
-       STATE_CMD_MAC_DISCONNECT_INDICATE,
-       STATE_CMD_MAC_CONNECT_CANCEL_INDICATE,
-       STATE_CMD_4WAY_FAILED,
-       STATE_CMD_4WAY_SUCCESSED,
-       STATE_CMD_ENTER_STATE,
-       STATE_CMD_NO_SUCH_CMD,
-};
-
-enum hci_service_type {
-       SERVICE_NO_TRAFFIC,
-       SERVICE_BEST_EFFORT,
-       SERVICE_GUARANTEE
-};
-
-enum hci_traffic_mode {
-       TRAFFIC_MODE_BEST_EFFORT                        = 0x00,
-       TRAFFIC_MODE_GUARANTEED_LATENCY                 = 0x01,
-       TRAFFIC_MODE_GUARANTEED_BANDWIDTH               = 0x02,
-       TRAFFIC_MODE_GUARANTEED_LATENCY_AND_BANDWIDTH   = 0x03
-};
-
-#define HCIOPCODE(_OCF, _OGF)          (_OGF<<10|_OCF)
-#define HCIOPCODELOW(_OCF, _OGF)       (u8)(HCIOPCODE(_OCF, _OGF)&0x00ff)
-#define HCIOPCODEHIGHT(_OCF, _OGF)     (u8)(HCIOPCODE(_OCF, _OGF)>>8)
-
-#define TWOBYTE_HIGHTBYTE(_DATA)       (u8)(_DATA>>8)
-#define TWOBYTE_LOWBYTE(_DATA)         (u8)(_DATA)
-
-enum amp_status {
-       AMP_STATUS_AVA_PHY_PWR_DWN              = 0x0,
-       AMP_STATUS_BT_USE_ONLY                  = 0x1,
-       AMP_STATUS_NO_CAPACITY_FOR_BT           = 0x2,
-       AMP_STATUS_LOW_CAPACITY_FOR_BT          = 0x3,
-       AMP_STATUS_MEDIUM_CAPACITY_FOR_BT       = 0x4,
-       AMP_STATUS_HIGH_CAPACITY_FOR_BT         = 0x5,
-       AMP_STATUS_FULL_CAPACITY_FOR_BT         = 0x6
-};
-
-enum bt_wpa_msg_type {
-       Type_BT_4way1st = 0,
-       Type_BT_4way2nd = 1,
-       Type_BT_4way3rd = 2,
-       Type_BT_4way4th = 3,
-       Type_BT_unknow  = 4
-};
-
-enum bt_connect_type {
-       BT_CONNECT_AUTH_REQ                     = 0x00,
-       BT_CONNECT_AUTH_RSP                     = 0x01,
-       BT_CONNECT_ASOC_REQ                     = 0x02,
-       BT_CONNECT_ASOC_RSP                     = 0x03,
-       BT_DISCONNECT                           = 0x04
-};
-
-enum bt_ll_service_type {
-       BT_LL_BE = 0x01,
-       BT_LL_GU = 0x02
-};
-
-enum bt_ll_flowspec {
-       BT_TX_BE_FS,                    /* TX best effort flowspec */
-       BT_RX_BE_FS,                    /* RX best effort flowspec */
-       BT_TX_GU_FS,                    /* TX guaranteed latency flowspec */
-       BT_RX_GU_FS,                    /* RX guaranteed latency flowspec */
-       BT_TX_BE_AGG_FS,                /* TX aggregated best effort flowspec */
-       BT_RX_BE_AGG_FS,                /* RX aggregated best effort flowspec */
-       BT_TX_GU_BW_FS,                 /* TX guaranteed bandwidth flowspec */
-       BT_RX_GU_BW_FS,                 /* RX guaranteed bandwidth flowspec */
-       BT_TX_GU_LARGE_FS,              /* TX guaranteed latency flowspec, for testing only */
-       BT_RX_GU_LARGE_FS,              /* RX guaranteed latency flowspec, for testing only */
-};
-
-enum bt_traffic_mode {
-       BT_MOTOR_EXT_BE         = 0x00, /* Best Effort. Default. for HCRP, PAN, SDP, RFCOMM-based profiles like FTP, OPP, SPP, DUN, etc. */
-       BT_MOTOR_EXT_GUL        = 0x01, /* Guaranteed Latency. This type of traffic is used e.g. for HID and AVRCP. */
-       BT_MOTOR_EXT_GUB        = 0X02, /* Guaranteed Bandwidth. */
-       BT_MOTOR_EXT_GULB       = 0X03  /* Guaranteed Latency and Bandwidth. for A2DP and VDP. */
-};
-
-enum bt_traffic_mode_profile {
-       BT_PROFILE_NONE,
-       BT_PROFILE_A2DP,
-       BT_PROFILE_PAN,
-       BT_PROFILE_HID,
-       BT_PROFILE_SCO
-};
-
-enum bt_link_role {
-       BT_LINK_MASTER  = 0,
-       BT_LINK_SLAVE   = 1
-};
-
-enum bt_state_wpa_auth {
-       STATE_WPA_AUTH_UNINITIALIZED,
-       STATE_WPA_AUTH_WAIT_PACKET_1, /*  Join */
-       STATE_WPA_AUTH_WAIT_PACKET_2, /*  Creat */
-       STATE_WPA_AUTH_WAIT_PACKET_3,
-       STATE_WPA_AUTH_WAIT_PACKET_4,
-       STATE_WPA_AUTH_SUCCESSED
-};
-
-#define BT_WPA_AUTH_TIMEOUT_PERIOD             1000
-#define BTMaxWPAAuthReTransmitCoun             5
-
-#define MAX_AMP_ASSOC_FRAG_LEN                 248
-#define TOTAL_ALLOCIATE_ASSOC_LEN                      1000
-
-struct hci_flow_spec {
-       u8                              Identifier;
-       u8                              ServiceType;
-       u16                             MaximumSDUSize;
-       u32                             SDUInterArrivalTime;
-       u32                             AccessLatency;
-       u32                             FlushTimeout;
-};
-
-struct hci_log_link_cmd_data {
-       u8                              BtPhyLinkhandle;
-       u16                             BtLogLinkhandle;
-       u8                              BtTxFlowSpecID;
-       struct hci_flow_spec            Tx_Flow_Spec;
-       struct hci_flow_spec            Rx_Flow_Spec;
-       u32                             TxPacketCount;
-       u32                             BestEffortFlushTimeout;
-
-       u8                              bLLCompleteEventIsSet;
-
-       u8                              bLLCancelCMDIsSetandComplete;
-};
-
-struct hci_phy_link_cmd_data {
-       /* Physical_Link_Handle */
-       u8                              BtPhyLinkhandle;
-
-       u16                             LinkSuperversionTimeout;
-
-       /* u16                          SuperTimeOutCnt; */
-
-       /* Dedicated_AMP_Key_Length */
-       u8                              BtAMPKeyLen;
-       /* Dedicated_AMP_Key_Type */
-       u8                              BtAMPKeyType;
-       /* Dedicated_AMP_Key */
-       u8                              BtAMPKey[PMK_LEN];
-};
-
-struct amp_assoc_structure {
-       /* TYPE ID */
-       u8                              TypeID;
-       /* Length */
-       u16                             Length;
-       /* Value */
-       u8                              Data[1];
-};
-
-struct amp_pref_chnl_regulatory {
-       u8                              reXId;
-       u8                              regulatoryClass;
-       u8                              coverageClass;
-};
-
-struct amp_assoc_cmd_data {
-       /* Physical_Link_Handle */
-       u8                              BtPhyLinkhandle;
-       /* Length_So_Far */
-       u16                             LenSoFar;
-
-       u16                             MaxRemoteASSOCLen;
-       /* AMP_ASSOC_Remaining_Length */
-       u16                             AMPAssocRemLen;
-       /* AMP_ASSOC_fragment */
-       void                            *AMPAssocfragment;
-};
-
-struct hci_link_info {
-       u16                             ConnectHandle;
-       u8                              IncomingTrafficMode;
-       u8                              OutgoingTrafficMode;
-       u8                              BTProfile;
-       u8                              BTCoreSpec;
-       s8                              BT_RSSI;
-       u8                              TrafficProfile;
-       u8                              linkRole;
-};
-
-struct hci_ext_config {
-       struct hci_link_info            linkInfo[MAX_BT_ASOC_ENTRY_NUM];
-       u8                              btOperationCode;
-       u16                             CurrentConnectHandle;
-       u8                              CurrentIncomingTrafficMode;
-       u8                              CurrentOutgoingTrafficMode;
-       s8                              MIN_BT_RSSI;
-       u8                              NumberOfHandle;
-       u8                              NumberOfSCO;
-       u8                              CurrentBTStatus;
-       u16                             HCIExtensionVer;
-
-       /* Bt coexist related */
-       u8                              btProfileCase;
-       u8                              btProfileAction;
-       u8                              bManualControl;
-       u8                              bBTBusy;
-       u8                              bBTA2DPBusy;
-       u8                              bEnableWifiScanNotify;
-
-       u8                              bHoldForBtOperation;
-       u32                             bHoldPeriodCnt;
-};
-
-struct hci_acl_packet_data {
-       u16                             ACLDataPacketLen;
-       u8                              SyncDataPacketLen;
-       u16                             TotalNumACLDataPackets;
-       u16                             TotalSyncNumDataPackets;
-};
-
-struct hci_phy_link_bss_info {
-       u16                             bdCap;  /*  capability information */
-};
-
-struct packet_irp_hcicmd_data {
-       u16             OCF:10;
-       u16             OGF:6;
-       u8              Length;
-       u8              Data[20];
-};
-
-struct bt_asoc_entry {
-       u8                                              bUsed;
-       u8                                              mAssoc;
-       u8                                              b4waySuccess;
-       u8                                              Bssid[6];
-       struct hci_phy_link_cmd_data            PhyLinkCmdData;
-
-       struct hci_log_link_cmd_data            LogLinkCmdData[MAX_LOGICAL_LINK_NUM];
-
-       struct hci_acl_packet_data                      ACLPacketsData;
-
-       struct amp_assoc_cmd_data               AmpAsocCmdData;
-       struct octet_string                             BTSsid;
-       u8                                              BTSsidBuf[33];
-
-       enum hci_status                                         PhyLinkDisconnectReason;
-
-       u8                                              bSendSupervisionPacket;
-       /* u8                                           CurrentSuervisionPacketSendNum; */
-       /* u8                                           LastSuervisionPacketSendNum; */
-       u32                                             NoRxPktCnt;
-       /* Is Creator or Joiner */
-       enum amp_btap_type                              AMPRole;
-
-       /* BT current state */
-       u8                                              BtCurrentState;
-       /* BT next state */
-       u8                                              BtNextState;
-
-       u8                                              bNeedPhysLinkCompleteEvent;
-
-       enum hci_status                                 PhysLinkCompleteStatus;
-
-       u8                                              BTRemoteMACAddr[6];
-
-       u32                                             BTCapability;
-
-       u8                                              SyncDataPacketLen;
-
-       u16                                             TotalSyncNumDataPackets;
-       u16                                             TotalNumACLDataPackets;
-
-       u8                                              ShortRangeMode;
-
-       u8                                              PTK[PTK_LEN_TKIP];
-       u8                                              GTK[GTK_LEN];
-       u8                                              ANonce[KEY_NONCE_LEN];
-       u8                                              SNonce[KEY_NONCE_LEN];
-       u64                                             KeyReplayCounter;
-       u8                                              WPAAuthReplayCount;
-       u8                                              AESKeyBuf[AESCCMP_BLK_SIZE_TOTAL];
-       u8                                              PMK[PMK_LEN];
-       enum bt_state_wpa_auth                  BTWPAAuthState;
-       s32                                             UndecoratedSmoothedPWDB;
-
-       /*  Add for HW security !! */
-       u8                                              HwCAMIndex;  /*  Cam index */
-       u8                                              bPeerQosSta;
-
-       u32                                             rxSuvpPktCnt;
-};
-
-struct bt_traffic_statistics {
-       u8                              bTxBusyTraffic;
-       u8                              bRxBusyTraffic;
-       u8                              bIdle;
-       u32                             TxPktCntInPeriod;
-       u32                             RxPktCntInPeriod;
-       u64                             TxPktLenInPeriod;
-       u64                             RxPktLenInPeriod;
-};
-
-struct bt_mgnt {
-       u8                              bBTConnectInProgress;
-       u8                              bLogLinkInProgress;
-       u8                              bPhyLinkInProgress;
-       u8                              bPhyLinkInProgressStartLL;
-       u8                              BtCurrentPhyLinkhandle;
-       u16                             BtCurrentLogLinkhandle;
-       u8                              CurrentConnectEntryNum;
-       u8                              DisconnectEntryNum;
-       u8                              CurrentBTConnectionCnt;
-       enum bt_connect_type            BTCurrentConnectType;
-       enum bt_connect_type            BTReceiveConnectPkt;
-       u8                              BTAuthCount;
-       u8                              BTAsocCount;
-       u8                              bStartSendSupervisionPkt;
-       u8                              BtOperationOn;
-       u8                              BTNeedAMPStatusChg;
-       u8                              JoinerNeedSendAuth;
-       struct hci_phy_link_bss_info    bssDesc;
-       struct hci_ext_config           ExtConfig;
-       u8                              bNeedNotifyAMPNoCap;
-       u8                              bCreateSpportQos;
-       u8                              bSupportProfile;
-       u8                              BTChannel;
-       u8                              CheckChnlIsSuit;
-       u8                              bBtScan;
-       u8                              btLogoTest;
-};
-
-struct bt_hci_dgb_info {
-       u32                             hciCmdCnt;
-       u32                             hciCmdCntUnknown;
-       u32                             hciCmdCntCreatePhyLink;
-       u32                             hciCmdCntAcceptPhyLink;
-       u32                             hciCmdCntDisconnectPhyLink;
-       u32                             hciCmdPhyLinkStatus;
-       u32                             hciCmdCntCreateLogLink;
-       u32                             hciCmdCntAcceptLogLink;
-       u32                             hciCmdCntDisconnectLogLink;
-       u32                             hciCmdCntReadLocalAmpAssoc;
-       u32                             hciCmdCntWriteRemoteAmpAssoc;
-       u32                             hciCmdCntSetAclLinkStatus;
-       u32                             hciCmdCntSetScoLinkStatus;
-       u32                             hciCmdCntExtensionVersionNotify;
-       u32                             hciCmdCntLinkStatusNotify;
-};
-
-struct bt_irp_dgb_info {
-       u32                             irpMJCreate;
-       /*  Io Control */
-       u32                             irpIoControl;
-       u32                             irpIoCtrlHciCmd;
-       u32                             irpIoCtrlHciEvent;
-       u32                             irpIoCtrlHciTxData;
-       u32                             irpIoCtrlHciRxData;
-       u32                             irpIoCtrlUnknown;
-
-       u32                             irpIoCtrlHciTxData1s;
-};
-
-struct bt_packet_dgb_info {
-       u32                             btPktTxProbReq;
-       u32                             btPktRxProbReq;
-       u32                             btPktRxProbReqFail;
-       u32                             btPktTxProbRsp;
-       u32                             btPktRxProbRsp;
-       u32                             btPktTxAuth;
-       u32                             btPktRxAuth;
-       u32                             btPktRxAuthButDrop;
-       u32                             btPktTxAssocReq;
-       u32                             btPktRxAssocReq;
-       u32                             btPktRxAssocReqButDrop;
-       u32                             btPktTxAssocRsp;
-       u32                             btPktRxAssocRsp;
-       u32                             btPktTxDisassoc;
-       u32                             btPktRxDisassoc;
-       u32                             btPktRxDeauth;
-       u32                             btPktTx4way1st;
-       u32                             btPktRx4way1st;
-       u32                             btPktTx4way2nd;
-       u32                             btPktRx4way2nd;
-       u32                             btPktTx4way3rd;
-       u32                             btPktRx4way3rd;
-       u32                             btPktTx4way4th;
-       u32                             btPktRx4way4th;
-       u32                             btPktTxLinkSuperReq;
-       u32                             btPktRxLinkSuperReq;
-       u32                             btPktTxLinkSuperRsp;
-       u32                             btPktRxLinkSuperRsp;
-       u32                             btPktTxData;
-       u32                             btPktRxData;
-};
-
-struct bt_dgb {
-       u8                              dbgCtrl;
-       u32                             dbgProfile;
-       struct bt_hci_dgb_info          dbgHciInfo;
-       struct bt_irp_dgb_info          dbgIrpInfo;
-       struct bt_packet_dgb_info       dbgBtPkt;
-};
-
-struct bt_hci_info {
-       /* 802.11 Pal version specifier */
-       u8                              BTPalVersion;
-       u16                             BTPalCompanyID;
-       u16                             BTPalsubversion;
-
-       /* Connected channel list */
-       u16                             BTConnectChnlListLen;
-       u8                              BTConnectChnllist[64];
-
-       /* Fail contact counter */
-       u16                             FailContactCount;
-
-       /* Event mask */
-       u64                             BTEventMask;
-       u64                             BTEventMaskPage2;
-
-       /* timeout var */
-       u16                             ConnAcceptTimeout;
-       u16                             LogicalAcceptTimeout;
-       u16                             PageTimeout;
-
-       u8                              LocationDomainAware;
-       u16                             LocationDomain;
-       u8                              LocationDomainOptions;
-       u8                              LocationOptions;
-
-       u8                              FlowControlMode;
-
-       /* Preferred channel list */
-       u16                             BtPreChnlListLen;
-       u8                              BTPreChnllist[64];
-
-       u16                             enFlush_LLH;    /* enhanced flush handle */
-       u16                             FLTO_LLH;               /* enhanced flush handle */
-
-       /*  */
-       /* Test command only. */
-       u8                              bInTestMode;
-       u8                              bTestIsEnd;
-       u8                              bTestNeedReport;
-       u8                              TestScenario;
-       u8                              TestReportInterval;
-       u8                              TestCtrType;
-       u32                             TestEventType;
-       u16                             TestNumOfFrame;
-       u16                             TestNumOfErrFrame;
-       u16                             TestNumOfBits;
-       u16                             TestNumOfErrBits;
-       /*  */
-};
-
-struct bt_traffic {
-       /*  Add for check replay data */
-       u8                                      LastRxUniFragNum;
-       u16                                     LastRxUniSeqNum;
-
-       /* s32                                  EntryMaxUndecoratedSmoothedPWDB; */
-       /* s32                                  EntryMinUndecoratedSmoothedPWDB; */
-
-       struct bt_traffic_statistics            Bt30TrafficStatistics;
-};
-
-#define RT_WORK_ITEM struct work_struct
-
-struct bt_security {
-       /*  WPA auth state
-        *  May need to remove to BTSecInfo ... 
-        * enum bt_state_wpa_auth BTWPAAuthState;
-        */
-       struct octet_string     RSNIE;
-       u8                      RSNIEBuf[MAXRSNIELEN];
-       u8                      bRegNoEncrypt;
-       u8                      bUsedHwEncrypt;
-};
-
-struct bt_30info {
-       struct rtw_adapter      *padapter;
-       struct bt_asoc_entry            BtAsocEntry[MAX_BT_ASOC_ENTRY_NUM];
-       struct bt_mgnt                          BtMgnt;
-       struct bt_dgb                           BtDbg;
-       struct bt_hci_info                      BtHciInfo;
-       struct bt_traffic                       BtTraffic;
-       struct bt_security                      BtSec;
-       RT_WORK_ITEM            HCICmdWorkItem;
-       struct timer_list BTHCICmdTimer;
-       RT_WORK_ITEM            BTPsDisableWorkItem;
-       RT_WORK_ITEM            BTConnectWorkItem;
-       struct timer_list BTHCIDiscardAclDataTimer;
-       struct timer_list BTHCIJoinTimeoutTimer;
-       struct timer_list BTTestSendPacketTimer;
-       struct timer_list BTDisconnectPhyLinkTimer;
-       struct timer_list BTBeaconTimer;
-       u8                              BTBeaconTmrOn;
-
-       struct timer_list BTPsDisableTimer;
-
-       void *                          pBtChnlList;
-};
-
-struct packet_irp_acl_data {
-       u16             Handle:12;
-       u16             PB_Flag:2;
-       u16             BC_Flag:2;
-       u16             Length;
-       u8              Data[1];
-};
-
-struct packet_irp_hcievent_data {
-       u8              EventCode;
-       u8              Length;
-       u8              Data[20];
-};
-
-struct common_triple {
-       u8 byte_1st;
-       u8 byte_2nd;
-       u8 byte_3rd;
-};
-
-#define COUNTRY_STR_LEN                3       /*  country string len = 3 */
-
-#define LOCAL_PMK      0
-
-enum hci_wifi_connect_status {
-       HCI_WIFI_NOT_CONNECTED                  = 0x0,
-       HCI_WIFI_CONNECTED                      = 0x1,
-       HCI_WIFI_CONNECT_IN_PROGRESS            = 0x2,
-};
-
-enum hci_ext_bp_operation {
-       HCI_BT_OP_NONE                          = 0x0,
-       HCI_BT_OP_INQUIRY_START                 = 0x1,
-       HCI_BT_OP_INQUIRY_FINISH                = 0x2,
-       HCI_BT_OP_PAGING_START                  = 0x3,
-       HCI_BT_OP_PAGING_SUCCESS                = 0x4,
-       HCI_BT_OP_PAGING_UNSUCCESS              = 0x5,
-       HCI_BT_OP_PAIRING_START                 = 0x6,
-       HCI_BT_OP_PAIRING_FINISH                = 0x7,
-       HCI_BT_OP_BT_DEV_ENABLE                 = 0x8,
-       HCI_BT_OP_BT_DEV_DISABLE                = 0x9,
-       HCI_BT_OP_MAX
-};
-
-#define BTHCI_SM_WITH_INFO(_Adapter, _StateToEnter, _StateCmd, _EntryNum)      \
-{                                                                              \
-       RTPRINT(FIOCTL, IOCTL_STATE, ("[BT state change] caused by ""%s"", line =%d\n", __func__, __LINE__));                                                   \
-       BTHCI_StateMachine(_Adapter, _StateToEnter, _StateCmd, _EntryNum);\
-}
-
-void BTHCI_EventParse(struct rtw_adapter *padapter, void *pEvntData,
-                     u32 dataLen);
-#define BT_EventParse BTHCI_EventParse
-u8 BTHCI_HsConnectionEstablished(struct rtw_adapter *padapter);
-void BTHCI_UpdateBTProfileRTKToMoto(struct rtw_adapter *padapter);
-void BTHCI_WifiScanNotify(struct rtw_adapter *padapter, u8 scanType);
-void BTHCI_StateMachine(struct rtw_adapter *padapter, u8 StateToEnter,
-                       enum hci_state_with_cmd StateCmd, u8 EntryNum);
-void BTHCI_DisconnectPeer(struct rtw_adapter *padapter, u8 EntryNum);
-void BTHCI_EventNumOfCompletedDataBlocks(struct rtw_adapter *padapter);
-void BTHCI_EventAMPStatusChange(struct rtw_adapter *padapter, u8 AMP_Status);
-void BTHCI_DisconnectAll(struct rtw_adapter *padapter);
-enum hci_status BTHCI_HandleHCICMD(struct rtw_adapter *padapter,
-                                  struct packet_irp_hcicmd_data *pHciCmd);
-
-/*  ===== End of sync from SD7 driver COMMON/bt_hci.h ===== */
-
-/*  ===== Below this line is sync from SD7 driver HAL/BTCoexist/HalBtc87231Ant.h ===== */
-#define GET_BT_INFO(padapter)  (&GET_HAL_DATA(padapter)->BtInfo)
-
-#define        BTC_FOR_SCAN_START                              1
-#define        BTC_FOR_SCAN_FINISH                             0
-
-#define        BT_TXRX_CNT_THRES_1                             1200
-#define        BT_TXRX_CNT_THRES_2                             1400
-#define        BT_TXRX_CNT_THRES_3                             3000
-#define        BT_TXRX_CNT_LEVEL_0                             0       /*  < 1200 */
-#define        BT_TXRX_CNT_LEVEL_1                             1       /*  >= 1200 && < 1400 */
-#define        BT_TXRX_CNT_LEVEL_2                             2       /*  >= 1400 */
-#define        BT_TXRX_CNT_LEVEL_3                             3       /*  >= 3000 */
-
-enum bt_state_1ant {
-       BT_INFO_STATE_DISABLED                  = 0,
-       BT_INFO_STATE_NO_CONNECTION             = 1,
-       BT_INFO_STATE_CONNECT_IDLE              = 2,
-       BT_INFO_STATE_INQ_OR_PAG                = 3,
-       BT_INFO_STATE_ACL_ONLY_BUSY             = 4,
-       BT_INFO_STATE_SCO_ONLY_BUSY             = 5,
-       BT_INFO_STATE_ACL_SCO_BUSY              = 6,
-       BT_INFO_STATE_ACL_INQ_OR_PAG            = 7,
-       BT_INFO_STATE_MAX                       = 8
-};
-
-struct btdm_8723a_1ant {
-       u8              prePsTdma;
-       u8              curPsTdma;
-       u8              psTdmaDuAdjType;
-       u8              bPrePsTdmaOn;
-       u8              bCurPsTdmaOn;
-       u8              preWifiPara;
-       u8              curWifiPara;
-       u8              preCoexWifiCon;
-       u8              curCoexWifiCon;
-       u8              wifiRssiThresh;
-
-       u32             psTdmaMonitorCnt;
-       u32             psTdmaGlobalCnt;
-
-       /* DurationAdjust For SCO */
-       u32             psTdmaMonitorCntForSCO;
-       u8              psTdmaDuAdjTypeForSCO;
-       u8              RSSI_WiFi_Last;
-       u8              RSSI_BT_Last;
-
-       u8              bWiFiHalt;
-       u8              bRAChanged;
-};
-
-void BTDM_1AntSignalCompensation(struct rtw_adapter *padapter,
-                                u8 *rssi_wifi, u8 *rssi_bt);
-void BTDM_1AntForDhcp(struct rtw_adapter *padapter);
-void BTDM_1AntBtCoexist8723A(struct rtw_adapter *padapter);
-
-/*  ===== End of sync from SD7 driver HAL/BTCoexist/HalBtc87231Ant.h ===== */
-
-/*  ===== Below this line is sync from SD7 driver HAL/BTCoexist/HalBtc87232Ant.h ===== */
-enum bt_2ant_bt_status {
-       BT_2ANT_BT_STATUS_IDLE                  = 0x0,
-       BT_2ANT_BT_STATUS_CONNECTED_IDLE        = 0x1,
-       BT_2ANT_BT_STATUS_NON_IDLE              = 0x2,
-       BT_2ANT_BT_STATUS_MAX
-};
-
-enum bt_2ant_coex_algo {
-       BT_2ANT_COEX_ALGO_UNDEFINED                     = 0x0,
-       BT_2ANT_COEX_ALGO_SCO                           = 0x1,
-       BT_2ANT_COEX_ALGO_HID                           = 0x2,
-       BT_2ANT_COEX_ALGO_A2DP                          = 0x3,
-       BT_2ANT_COEX_ALGO_PANEDR                        = 0x4,
-       BT_2ANT_COEX_ALGO_PANHS                         = 0x5,
-       BT_2ANT_COEX_ALGO_PANEDR_A2DP           = 0x6,
-       BT_2ANT_COEX_ALGO_PANEDR_HID            = 0x7,
-       BT_2ANT_COEX_ALGO_HID_A2DP_PANEDR       = 0x8,
-       BT_2ANT_COEX_ALGO_HID_A2DP                      = 0x9,
-       BT_2ANT_COEX_ALGO_HID_A2DP_PANHS        = 0xA,
-       BT_2ANT_COEX_ALGO_MAX                           = 0xB,
-};
-
-struct btdm_8723a_2ant {
-       u8      bPreDecBtPwr;
-       u8      bCurDecBtPwr;
-
-       u8      preWlanActHi;
-       u8      curWlanActHi;
-       u8      preWlanActLo;
-       u8      curWlanActLo;
-
-       u8      preFwDacSwingLvl;
-       u8      curFwDacSwingLvl;
-
-       u8      bPreRfRxLpfShrink;
-       u8      bCurRfRxLpfShrink;
-
-       u8      bPreLowPenaltyRa;
-       u8      bCurLowPenaltyRa;
-
-       u8      preBtRetryIndex;
-       u8      curBtRetryIndex;
-
-       u8      bPreDacSwingOn;
-       u32     preDacSwingLvl;
-       u8      bCurDacSwingOn;
-       u32     curDacSwingLvl;
-
-       u8      bPreAdcBackOff;
-       u8      bCurAdcBackOff;
-
-       u8      bPreAgcTableEn;
-       u8      bCurAgcTableEn;
-
-       u32     preVal0x6c0;
-       u32     curVal0x6c0;
-       u32     preVal0x6c8;
-       u32     curVal0x6c8;
-       u8      preVal0x6cc;
-       u8      curVal0x6cc;
-
-       u8      bCurIgnoreWlanAct;
-       u8      bPreIgnoreWlanAct;
-
-       u8      prePsTdma;
-       u8      curPsTdma;
-       u8      psTdmaDuAdjType;
-       u8      bPrePsTdmaOn;
-       u8      bCurPsTdmaOn;
-
-       u8      preAlgorithm;
-       u8      curAlgorithm;
-       u8      bResetTdmaAdjust;
-
-       u8      btStatus;
-};
-
-void BTDM_2AntBtCoexist8723A(struct rtw_adapter *padapter);
-/*  ===== End of sync from SD7 driver HAL/BTCoexist/HalBtc87232Ant.h ===== */
-
-/*  ===== Below this line is sync from SD7 driver HAL/BTCoexist/HalBtc8723.h ===== */
-
-#define        BT_Q_PKT_OFF            0
-#define        BT_Q_PKT_ON             1
-
-#define        BT_TX_PWR_OFF           0
-#define        BT_TX_PWR_ON            1
-
-/*  TDMA mode definition */
-#define        TDMA_2ANT                       0
-#define        TDMA_1ANT                       1
-#define        TDMA_NAV_OFF            0
-#define        TDMA_NAV_ON             1
-#define        TDMA_DAC_SWING_OFF      0
-#define        TDMA_DAC_SWING_ON       1
-
-#define        BT_RSSI_LEVEL_H 0
-#define        BT_RSSI_LEVEL_M 1
-#define        BT_RSSI_LEVEL_L 2
-
-/*  PTA mode related definition */
-#define        BT_PTA_MODE_OFF         0
-#define        BT_PTA_MODE_ON          1
-
-/*  Penalty Tx Rate Adaptive */
-#define        BT_TX_RATE_ADAPTIVE_NORMAL                      0
-#define        BT_TX_RATE_ADAPTIVE_LOW_PENALTY 1
-
-/*  RF Corner */
-#define        BT_RF_RX_LPF_CORNER_RESUME                      0
-#define        BT_RF_RX_LPF_CORNER_SHRINK                      1
-
-#define BT_INFO_ACL                    BIT(0)
-#define BT_INFO_SCO                    BIT(1)
-#define BT_INFO_INQ_PAG                BIT(2)
-#define BT_INFO_ACL_BUSY       BIT(3)
-#define BT_INFO_SCO_BUSY       BIT(4)
-#define BT_INFO_HID                    BIT(5)
-#define BT_INFO_A2DP           BIT(6)
-#define BT_INFO_FTP                    BIT(7)
-
-
-
-struct bt_coexist_8723a {
-       u32                                     highPriorityTx;
-       u32                                     highPriorityRx;
-       u32                                     lowPriorityTx;
-       u32                                     lowPriorityRx;
-       u8                                      btRssi;
-       u8                                      TotalAntNum;
-       u8                                      bC2hBtInfoSupport;
-       u8                                      c2hBtInfo;
-       u8                                      c2hBtInfoOriginal;
-       u8                                      prec2hBtInfo; /*  for 1Ant */
-       u8                                      bC2hBtInquiryPage;
-       unsigned long                           btInqPageStartTime; /*  for 2Ant */
-       u8                                      c2hBtProfile; /*  for 1Ant */
-       u8                                      btRetryCnt;
-       u8                                      btInfoExt;
-       u8                                      bC2hBtInfoReqSent;
-       u8                                      bForceFwBtInfo;
-       u8                                      bForceA2dpSink;
-       struct btdm_8723a_2ant                  btdm2Ant;
-       struct btdm_8723a_1ant                  btdm1Ant;
-};
-
-void BTDM_SetFwChnlInfo(struct rtw_adapter *padapter,
-                       enum rt_media_status mstatus);
-u8 BTDM_IsWifiConnectionExist(struct rtw_adapter *padapter);
-void BTDM_SetFw3a(struct rtw_adapter *padapter, u8 byte1, u8 byte2, u8 byte3,
-                 u8 byte4, u8 byte5);
-void BTDM_QueryBtInformation(struct rtw_adapter *padapter);
-void BTDM_SetSwRfRxLpfCorner(struct rtw_adapter *padapter, u8 type);
-void BTDM_SetSwPenaltyTxRateAdaptive(struct rtw_adapter *padapter, u8 raType);
-void BTDM_SetFwDecBtPwr(struct rtw_adapter *padapter, u8 bDecBtPwr);
-u8 BTDM_BtProfileSupport(struct rtw_adapter *padapter);
-void BTDM_LpsLeave(struct rtw_adapter *padapter);
-
-/*  ===== End of sync from SD7 driver HAL/BTCoexist/HalBtc8723.h ===== */
-
-/*  ===== Below this line is sync from SD7 driver HAL/BTCoexist/HalBtcCsr1Ant.h ===== */
-
-enum BT_A2DP_INDEX{
-       BT_A2DP_INDEX0          = 0,                    /*  32, 12; the most critical for BT */
-       BT_A2DP_INDEX1,                                 /*  12, 24 */
-       BT_A2DP_INDEX2,                                 /*  0, 0 */
-       BT_A2DP_INDEX_MAX
-};
-
-#define BT_A2DP_STATE_NOT_ENTERED              0
-#define BT_A2DP_STATE_DETECTING                1
-#define BT_A2DP_STATE_DETECTED                 2
-
-#define BTDM_ANT_BT_IDLE                               0
-#define BTDM_ANT_WIFI                                  1
-#define BTDM_ANT_BT                                            2
-
-
-void BTDM_SingleAnt(struct rtw_adapter *padapter, u8 bSingleAntOn,
-                   u8 bInterruptOn, u8 bMultiNAVOn);
-void BTDM_CheckBTIdleChange1Ant(struct rtw_adapter *padapter);
-
-/*  ===== End of sync from SD7 driver HAL/BTCoexist/HalBtcCsr1Ant.h ===== */
-
-/*  ===== Below this line is sync from SD7 driver HAL/BTCoexist/HalBtcCsr2Ant.h ===== */
-
-/*  */
-/*  For old core stack before v251 */
-/*  */
-#define BT_RSSI_STATE_NORMAL_POWER     BIT(0)
-#define BT_RSSI_STATE_AMDPU_OFF                BIT(1)
-#define BT_RSSI_STATE_SPECIAL_LOW      BIT(2)
-#define BT_RSSI_STATE_BG_EDCA_LOW      BIT(3)
-#define BT_RSSI_STATE_TXPOWER_LOW      BIT(4)
-
-#define        BT_DACSWING_OFF                         0
-#define        BT_DACSWING_M4                          1
-#define        BT_DACSWING_M7                          2
-#define        BT_DACSWING_M10                         3
-
-void BTDM_DiminishWiFi(struct rtw_adapter *Adapter, u8 bDACOn, u8 bInterruptOn,
-                      u8 DACSwingLevel, u8 bNAVOn);
-
-/*  ===== End of sync from SD7 driver HAL/BTCoexist/HalBtcCsr2Ant.h ===== */
-
-/*  HEADER/TypeDef.h */
-#define MAX_FW_SUPPORT_MACID_NUM                       64
-
-/*  ===== Below this line is sync from SD7 driver HAL/BTCoexist/HalBtCoexist.h ===== */
-
-#define        FW_VER_BT_REG                   62
-#define        FW_VER_BT_REG1          74
-#define        REG_BT_ACTIVE                   0x444
-#define        REG_BT_STATE                    0x448
-#define        REG_BT_POLLING1         0x44c
-#define        REG_BT_POLLING                  0x700
-
-#define        REG_BT_ACTIVE_OLD               0x488
-#define        REG_BT_STATE_OLD                0x48c
-#define        REG_BT_POLLING_OLD      0x490
-
-/*  The reg define is for 8723 */
-#define        REG_HIGH_PRIORITY_TXRX                  0x770
-#define        REG_LOW_PRIORITY_TXRX                   0x774
-
-#define BT_FW_COEX_THRESH_TOL                  6
-#define BT_FW_COEX_THRESH_20                           20
-#define BT_FW_COEX_THRESH_23                           23
-#define BT_FW_COEX_THRESH_25                           25
-#define BT_FW_COEX_THRESH_30                           30
-#define BT_FW_COEX_THRESH_35                           35
-#define BT_FW_COEX_THRESH_40                           40
-#define BT_FW_COEX_THRESH_45                           45
-#define BT_FW_COEX_THRESH_47                           47
-#define BT_FW_COEX_THRESH_50                           50
-#define BT_FW_COEX_THRESH_55                           55
-#define BT_FW_COEX_THRESH_65                           65
-
-#define BT_COEX_STATE_BT30                     BIT(0)
-#define BT_COEX_STATE_WIFI_HT20                        BIT(1)
-#define BT_COEX_STATE_WIFI_HT40                        BIT(2)
-#define BT_COEX_STATE_WIFI_LEGACY              BIT(3)
-
-#define BT_COEX_STATE_WIFI_RSSI_LOW            BIT(4)
-#define BT_COEX_STATE_WIFI_RSSI_MEDIUM         BIT(5)
-#define BT_COEX_STATE_WIFI_RSSI_HIGH           BIT(6)
-#define BT_COEX_STATE_DEC_BT_POWER             BIT(7)
-
-#define BT_COEX_STATE_WIFI_IDLE                        BIT(8)
-#define BT_COEX_STATE_WIFI_UPLINK              BIT(9)
-#define BT_COEX_STATE_WIFI_DOWNLINK            BIT(10)
-
-#define BT_COEX_STATE_BT_INQ_PAGE              BIT(11)
-#define BT_COEX_STATE_BT_IDLE                  BIT(12)
-#define BT_COEX_STATE_BT_UPLINK                        BIT(13)
-#define BT_COEX_STATE_BT_DOWNLINK              BIT(14)
-/*  */
-/*  Todo: Remove these definitions */
-#define BT_COEX_STATE_BT_PAN_IDLE              BIT(15)
-#define BT_COEX_STATE_BT_PAN_UPLINK            BIT(16)
-#define BT_COEX_STATE_BT_PAN_DOWNLINK          BIT(17)
-#define BT_COEX_STATE_BT_A2DP_IDLE             BIT(18)
-/*  */
-#define BT_COEX_STATE_BT_RSSI_LOW              BIT(19)
-
-#define BT_COEX_STATE_PROFILE_HID              BIT(20)
-#define BT_COEX_STATE_PROFILE_A2DP             BIT(21)
-#define BT_COEX_STATE_PROFILE_PAN              BIT(22)
-#define BT_COEX_STATE_PROFILE_SCO              BIT(23)
-
-#define BT_COEX_STATE_WIFI_RSSI_1_LOW          BIT(24)
-#define BT_COEX_STATE_WIFI_RSSI_1_MEDIUM       BIT(25)
-#define BT_COEX_STATE_WIFI_RSSI_1_HIGH         BIT(26)
-
-#define BT_COEX_STATE_WIFI_RSSI_BEACON_LOW     BIT(27)
-#define BT_COEX_STATE_WIFI_RSSI_BEACON_MEDIUM  BIT(28)
-#define BT_COEX_STATE_WIFI_RSSI_BEACON_HIGH    BIT(29)
-
-
-#define BT_COEX_STATE_BTINFO_COMMON            BIT(30)
-#define BT_COEX_STATE_BTINFO_B_HID_SCOESCO     BIT(31)
-#define BT_COEX_STATE_BTINFO_B_FTP_A2DP                BIT(32)
-
-#define BT_COEX_STATE_BT_CNT_LEVEL_0           BIT(33)
-#define BT_COEX_STATE_BT_CNT_LEVEL_1           BIT(34)
-#define BT_COEX_STATE_BT_CNT_LEVEL_2           BIT(35)
-#define BT_COEX_STATE_BT_CNT_LEVEL_3           BIT(36)
-
-#define BT_RSSI_STATE_HIGH                     0
-#define BT_RSSI_STATE_MEDIUM                   1
-#define BT_RSSI_STATE_LOW                      2
-#define BT_RSSI_STATE_STAY_HIGH                        3
-#define BT_RSSI_STATE_STAY_MEDIUM              4
-#define BT_RSSI_STATE_STAY_LOW                 5
-
-#define        BT_AGCTABLE_OFF                         0
-#define        BT_AGCTABLE_ON                          1
-
-#define        BT_BB_BACKOFF_OFF                       0
-#define        BT_BB_BACKOFF_ON                        1
-
-#define        BT_FW_NAV_OFF                           0
-#define        BT_FW_NAV_ON                            1
-
-#define        BT_COEX_MECH_NONE                       0
-#define        BT_COEX_MECH_SCO                        1
-#define        BT_COEX_MECH_HID                        2
-#define        BT_COEX_MECH_A2DP                       3
-#define        BT_COEX_MECH_PAN                        4
-#define        BT_COEX_MECH_HID_A2DP                   5
-#define        BT_COEX_MECH_HID_PAN                    6
-#define        BT_COEX_MECH_PAN_A2DP                   7
-#define        BT_COEX_MECH_HID_SCO_ESCO               8
-#define        BT_COEX_MECH_FTP_A2DP                   9
-#define        BT_COEX_MECH_COMMON                     10
-#define        BT_COEX_MECH_MAX                        11
-/*     BT Dbg Ctrl */
-#define        BT_DBG_PROFILE_NONE                     0
-#define        BT_DBG_PROFILE_SCO                      1
-#define        BT_DBG_PROFILE_HID                      2
-#define        BT_DBG_PROFILE_A2DP                     3
-#define        BT_DBG_PROFILE_PAN                      4
-#define        BT_DBG_PROFILE_HID_A2DP                 5
-#define        BT_DBG_PROFILE_HID_PAN                  6
-#define        BT_DBG_PROFILE_PAN_A2DP                 7
-#define        BT_DBG_PROFILE_MAX                      9
-
-struct bt_coexist_str {
-       u8                      BluetoothCoexist;
-       u8                      BT_Ant_Num;
-       u8                      BT_CoexistType;
-       u8                      BT_Ant_isolation;       /* 0:good, 1:bad */
-       u8                      bt_radiosharedtype;
-       u32                     Ratio_Tx;
-       u32                     Ratio_PRI;
-       u8                      bInitlized;
-       u32                     BtRfRegOrigin1E;
-       u32                     BtRfRegOrigin1F;
-       u8                      bBTBusyTraffic;
-       u8                      bBTTrafficModeSet;
-       u8                      bBTNonTrafficModeSet;
-       struct bt_traffic_statistics            BT21TrafficStatistics;
-       u64                     CurrentState;
-       u64                     PreviousState;
-       u8                      preRssiState;
-       u8                      preRssiState1;
-       u8                      preRssiStateBeacon;
-       u8                      bFWCoexistAllOff;
-       u8                      bSWCoexistAllOff;
-       u8                      bHWCoexistAllOff;
-       u8                      bBalanceOn;
-       u8                      bSingleAntOn;
-       u8                      bInterruptOn;
-       u8                      bMultiNAVOn;
-       u8                      PreWLANActH;
-       u8                      PreWLANActL;
-       u8                      WLANActH;
-       u8                      WLANActL;
-       u8                      A2DPState;
-       u8                      AntennaState;
-       u32                     lastBtEdca;
-       u16                     last_aggr_num;
-       u8                      bEDCAInitialized;
-       u8                      exec_cnt;
-       u8                      b8723aAgcTableOn;
-       u8                      b92DAgcTableOn;
-       struct bt_coexist_8723a halCoex8723;
-       u8                      btActiveZeroCnt;
-       u8                      bCurBtDisabled;
-       u8                      bPreBtDisabled;
-       u8                      bNeedToRoamForBtDisableEnable;
-       u8                      fw3aVal[5];
-};
-
-void BTDM_CheckAntSelMode(struct rtw_adapter *padapter);
-void BTDM_FwC2hBtRssi(struct rtw_adapter *padapter, u8 *tmpBuf);
-#define BT_FwC2hBtRssi BTDM_FwC2hBtRssi
-void BTDM_DisplayBtCoexInfo(struct rtw_adapter *padapter);
-#define BT_DisplayBtCoexInfo BTDM_DisplayBtCoexInfo
-void BTDM_RejectAPAggregatedPacket(struct rtw_adapter *padapter, u8 bReject);
-u8 BTDM_IsHT40(struct rtw_adapter *padapter);
-u8 BTDM_Legacy(struct rtw_adapter *padapter);
-void BTDM_CheckWiFiState(struct rtw_adapter *padapter);
-s32 BTDM_GetRxSS(struct rtw_adapter *padapter);
-u8 BTDM_CheckCoexBcnRssiState(struct rtw_adapter *padapter, u8 levelNum,
-                             u8 RssiThresh, u8 RssiThresh1);
-u8 BTDM_CheckCoexRSSIState1(struct rtw_adapter *padapter, u8 levelNum,
-                           u8 RssiThresh, u8 RssiThresh1);
-u8 BTDM_CheckCoexRSSIState(struct rtw_adapter *padapter, u8 levelNum,
-                          u8 RssiThresh, u8 RssiThresh1);
-void BTDM_Balance(struct rtw_adapter *padapter, u8 bBalanceOn, u8 ms0, u8 ms1);
-void BTDM_AGCTable(struct rtw_adapter *padapter, u8 type);
-void BTDM_BBBackOffLevel(struct rtw_adapter *padapter, u8 type);
-void BTDM_FWCoexAllOff(struct rtw_adapter *padapter);
-void BTDM_SWCoexAllOff(struct rtw_adapter *padapter);
-void BTDM_HWCoexAllOff(struct rtw_adapter *padapter);
-void BTDM_CoexAllOff(struct rtw_adapter *padapter);
-void BTDM_TurnOffBtCoexistBeforeEnterIPS(struct rtw_adapter *padapter);
-void BTDM_SignalCompensation(struct rtw_adapter *padapter, u8 *rssi_wifi,
-                            u8 *rssi_bt);
-void BTDM_UpdateCoexState(struct rtw_adapter *padapter);
-u8 BTDM_IsSameCoexistState(struct rtw_adapter *padapter);
-void BTDM_PWDBMonitor(struct rtw_adapter *padapter);
-u8 BTDM_IsBTBusy(struct rtw_adapter *padapter);
-#define BT_IsBtBusy BTDM_IsBTBusy
-u8 BTDM_IsWifiBusy(struct rtw_adapter *padapter);
-u8 BTDM_IsCoexistStateChanged(struct rtw_adapter *padapter);
-u8 BTDM_IsWifiUplink(struct rtw_adapter *padapter);
-u8 BTDM_IsWifiDownlink(struct rtw_adapter *padapter);
-u8 BTDM_IsBTHSMode(struct rtw_adapter *padapter);
-u8 BTDM_IsBTUplink(struct rtw_adapter *padapter);
-u8 BTDM_IsBTDownlink(struct rtw_adapter *padapter);
-void BTDM_AdjustForBtOperation(struct rtw_adapter *padapter);
-void BTDM_ForHalt(struct rtw_adapter *padapter);
-void BTDM_WifiScanNotify(struct rtw_adapter *padapter, u8 scanType);
-void BTDM_WifiAssociateNotify(struct rtw_adapter *padapter, u8 action);
-void BTDM_MediaStatusNotify(struct rtw_adapter *padapter,
-                           enum rt_media_status mstatus);
-void BTDM_ForDhcp(struct rtw_adapter *padapter);
-void BTDM_ResetActionProfileState(struct rtw_adapter *padapter);
-void BTDM_SetBtCoexCurrAntNum(struct rtw_adapter *padapter, u8 antNum);
-#define BT_SetBtCoexCurrAntNum BTDM_SetBtCoexCurrAntNum
-u8 BTDM_IsActionSCO(struct rtw_adapter *padapter);
-u8 BTDM_IsActionHID(struct rtw_adapter *padapter);
-u8 BTDM_IsActionA2DP(struct rtw_adapter *padapter);
-u8 BTDM_IsActionPAN(struct rtw_adapter *padapter);
-u8 BTDM_IsActionHIDA2DP(struct rtw_adapter *padapter);
-u8 BTDM_IsActionHIDPAN(struct rtw_adapter *padapter);
-u8 BTDM_IsActionPANA2DP(struct rtw_adapter *padapter);
-u32 BTDM_BtTxRxCounterH(struct rtw_adapter *padapter);
-u32 BTDM_BtTxRxCounterL(struct rtw_adapter *padapter);
-
-/*  ===== End of sync from SD7 driver HAL/BTCoexist/HalBtCoexist.h ===== */
-
-/*  ===== Below this line is sync from SD7 driver HAL/HalBT.h ===== */
-
-#define RTS_CTS_NO_LEN_LIMIT   0
-
-u8 HALBT_GetPGAntNum(struct rtw_adapter *padapter);
-#define BT_GetPGAntNum HALBT_GetPGAntNum
-void HALBT_SetKey(struct rtw_adapter *padapter, u8 EntryNum);
-void HALBT_RemoveKey(struct rtw_adapter *padapter, u8 EntryNum);
-u8 HALBT_IsBTExist(struct rtw_adapter *padapter);
-#define BT_IsBtExist HALBT_IsBTExist
-u8 HALBT_BTChipType(struct rtw_adapter *padapter);
-void HALBT_SetRtsCtsNoLenLimit(struct rtw_adapter *padapter);
-
-/*  ===== End of sync from SD7 driver HAL/HalBT.c ===== */
-
-#define _bt_dbg_off_           0
-#define _bt_dbg_on_            1
-
-extern u32 BTCoexDbgLevel;
-
-
-
-#endif /*  __RTL8723A_BT_COEXIST_H__ */
diff --git a/drivers/staging/rtl8723au/include/rtl8723a_bt_intf.h b/drivers/staging/rtl8723au/include/rtl8723a_bt_intf.h
deleted file mode 100644 (file)
index 4733559..0000000
+++ /dev/null
@@ -1,69 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
- * Copyright(c) 2014, Jes Sorensen <Jes.Sorensen@redhat.com>
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#ifndef __RTL8723A_BT_INTF_H__
-#define __RTL8723A_BT_INTF_H__
-
-#include <drv_types.h>
-
-#ifdef CONFIG_8723AU_BT_COEXIST
-enum rt_media_status;
-bool rtl8723a_BT_using_antenna_1(struct rtw_adapter *padapter);
-bool rtl8723a_BT_enabled(struct rtw_adapter *padapter);
-bool rtl8723a_BT_coexist(struct rtw_adapter *padapter);
-void rtl8723a_BT_do_coexist(struct rtw_adapter *padapter);
-void rtl8723a_BT_wifiscan_notify(struct rtw_adapter *padapter, u8 scanType);
-void rtl8723a_BT_mediastatus_notify(struct rtw_adapter *padapter,
-                                   enum rt_media_status mstatus);
-void rtl8723a_BT_specialpacket_notify(struct rtw_adapter *padapter);
-void rtl8723a_BT_lps_leave(struct rtw_adapter *padapter);
-void rtl8723a_BT_disable_coexist(struct rtw_adapter *padapter);
-bool rtl8723a_BT_disable_EDCA_turbo(struct rtw_adapter *padapter);
-void rtl8723a_dual_antenna_detection(struct rtw_adapter *padapter);
-void rtl8723a_BT_init_hwconfig(struct rtw_adapter *padapter);
-void rtl8723a_BT_wifiassociate_notify(struct rtw_adapter *padapter, u8 action);
-void rtl8723a_BT_init_hal_vars(struct rtw_adapter *padapter);
-void rtl8723a_fw_c2h_BT_info(struct rtw_adapter *padapter, u8 *tmpBuf, u8 length);
-#else
-static inline bool rtl8723a_BT_using_antenna_1(struct rtw_adapter *padapter)
-{
-       return false;
-}
-static inline bool rtl8723a_BT_enabled(struct rtw_adapter *padapter)
-{
-       return false;
-}
-static inline bool rtl8723a_BT_coexist(struct rtw_adapter *padapter)
-{
-       return false;
-}
-#define rtl8723a_BT_do_coexist(padapter)                       do {} while(0)
-#define rtl8723a_BT_wifiscan_notify(padapter, scanType)                do {} while(0)
-#define rtl8723a_BT_mediastatus_notify(padapter, mstatus)      do {} while(0)
-#define rtl8723a_BT_specialpacket_notify(padapter)             do {} while(0)
-#define rtl8723a_BT_lps_leave(padapter)                                do {} while(0)
-#define rtl8723a_BT_disable_coexist(padapter)                  do {} while(0)
-static inline bool rtl8723a_BT_disable_EDCA_turbo(struct rtw_adapter *padapter)
-{
-       return false;
-}
-#define rtl8723a_dual_antenna_detection(padapter)              do {} while(0)
-#define rtl8723a_BT_init_hwconfig(padapter)                    do {} while(0)
-#define rtl8723a_BT_wifiassociate_notify(padapter, action)     do {} while(0)
-#define rtl8723a_BT_init_hal_vars(padapter)                    do {} while(0)
-#define rtl8723a_fw_c2h_BT_info(padapter, tmpBuf, length)      do {} while(0)
-#endif
-
-#endif
diff --git a/drivers/staging/rtl8723au/include/rtl8723a_cmd.h b/drivers/staging/rtl8723au/include/rtl8723a_cmd.h
deleted file mode 100644 (file)
index f95535a..0000000
+++ /dev/null
@@ -1,158 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#ifndef __RTL8723A_CMD_H__
-#define __RTL8723A_CMD_H__
-
-
-#define H2C_BT_FW_PATCH_LEN            3
-#define H2C_BT_PWR_FORCE_LEN           3
-
-enum cmd_msg_element_id
-{
-       NONE_CMDMSG_EID,
-       AP_OFFLOAD_EID = 0,
-       SET_PWRMODE_EID = 1,
-       JOINBSS_RPT_EID = 2,
-       RSVD_PAGE_EID = 3,
-       RSSI_4_EID = 4,
-       RSSI_SETTING_EID = 5,
-       MACID_CONFIG_EID = 6,
-       MACID_PS_MODE_EID = 7,
-       P2P_PS_OFFLOAD_EID = 8,
-       SELECTIVE_SUSPEND_ROF_CMD = 9,
-       BT_QUEUE_PKT_EID = 17,
-       BT_ANT_TDMA_EID = 20,
-       BT_2ANT_HID_EID = 21,
-       P2P_PS_CTW_CMD_EID = 32,
-       FORCE_BT_TX_PWR_EID = 33,
-       SET_TDMA_WLAN_ACT_TIME_EID = 34,
-       SET_BT_TX_RETRY_INDEX_EID = 35,
-       HID_PROFILE_ENABLE_EID = 36,
-       BT_IGNORE_WLAN_ACT_EID = 37,
-       BT_PTA_MANAGER_UPDATE_ENABLE_EID = 38,
-       DAC_SWING_VALUE_EID = 41,
-       TRADITIONAL_TDMA_EN_EID = 51,
-       H2C_BT_FW_PATCH = 54,
-       B_TYPE_TDMA_EID = 58,
-       SCAN_EN_EID = 59,
-       LOWPWR_LPS_EID = 71,
-       H2C_RESET_TSF = 75,
-       MAX_CMDMSG_EID
-};
-
-struct cmd_msg_parm {
-       u8 eid; /* element id */
-       u8 sz; /*  sz */
-       u8 buf[6];
-};
-
-struct setpwrmode_parm {
-       u8 Mode;
-       u8 SmartPS;
-       u8 AwakeInterval;       /*  unit: beacon interval */
-       u8 bAllQueueUAPSD;
-
-#define SETPM_LOWRXBCN                 BIT(0)
-#define SETPM_AUTOANTSWITCH            BIT(1)
-#define SETPM_PSALLOWBTHIGHPRI BIT(2)
-       u8 BcnAntMode;
-} __packed;
-
-struct H2C_SS_RFOFF_PARAM{
-       u8 ROFOn; /*  1: on, 0:off */
-       u16 gpio_period; /*  unit: 1024 us */
-}__attribute__ ((packed));
-
-
-struct joinbssrpt_parm {
-       u8 OpMode;      /*  enum rt_media_status */
-};
-
-struct rsvdpage_loc {
-       u8 LocProbeRsp;
-       u8 LocPsPoll;
-       u8 LocNullData;
-       u8 LocQosNull;
-       u8 LocBTQosNull;
-};
-
-struct P2P_PS_Offload_t {
-       u8 Offload_En:1;
-       u8 role:1; /*  1: Owner, 0: Client */
-       u8 CTWindow_En:1;
-       u8 NoA0_En:1;
-       u8 NoA1_En:1;
-       u8 AllStaSleep:1; /*  Only valid in Owner */
-       u8 discovery:1;
-       u8 rsvd:1;
-};
-
-struct P2P_PS_CTWPeriod_t {
-       u8 CTWPeriod;   /* TU */
-};
-
-#define B_TDMA_EN                      BIT(0)
-#define B_TDMA_FIXANTINBT              BIT(1)
-#define B_TDMA_TXPSPOLL                        BIT(2)
-#define B_TDMA_VAL870                  BIT(3)
-#define B_TDMA_AUTOWAKEUP              BIT(4)
-#define B_TDMA_NOPS                    BIT(5)
-#define B_TDMA_WLANHIGHPRI             BIT(6)
-
-struct b_type_tdma_parm {
-       u8 option;
-
-       u8 TBTTOnPeriod;
-       u8 MedPeriod;
-       u8 rsvd30;
-} __packed;
-
-struct scan_en_parm {
-       u8 En;
-} __packed;
-
-/*  BT_PWR */
-#define SET_H2CCMD_BT_PWR_IDX(__pH2CCmd, __Value)                                                      SET_BITS_TO_LE_1BYTE_8BIT(__pH2CCmd, 0, 8, __Value)
-
-/*  BT_FW_PATCH */
-#define SET_H2CCMD_BT_FW_PATCH_ENABLE(__pH2CCmd, __Value)                                      SET_BITS_TO_LE_4BYTE(__pH2CCmd, 0, 8, __Value) /*       SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value) */
-#define SET_H2CCMD_BT_FW_PATCH_SIZE(__pH2CCmd, __Value)                                                SET_BITS_TO_LE_4BYTE(__pH2CCmd, 8, 16, __Value) /*      SET_BITS_TO_LE_2BYTE((__pH2CCmd)+1, 0, 16, __Value) */
-
-struct lowpwr_lps_parm{
-       u8 bcn_count:4;
-       u8 tb_bcn_threshold:3;
-       u8 enable:1;
-       u8 bcn_interval;
-       u8 drop_threshold;
-       u8 max_early_period;
-       u8 max_bcn_timeout_period;
-} __packed;
-
-
-/*  host message to firmware cmd */
-void rtl8723a_set_FwPwrMode_cmd(struct rtw_adapter *padapter, u8 Mode);
-void rtl8723a_set_FwJoinBssReport_cmd(struct rtw_adapter *padapter, u8 mstatus);
-#ifdef CONFIG_8723AU_BT_COEXIST
-void rtl8723a_set_BTCoex_AP_mode_FwRsvdPkt_cmd(struct rtw_adapter *padapter);
-#else
-#define rtl8723a_set_BTCoex_AP_mode_FwRsvdPkt_cmd(padapter) do {} while(0)
-#endif
-int rtl8723a_set_rssi_cmd(struct rtw_adapter *padapter, u32 param);
-int rtl8723a_set_raid_cmd(struct rtw_adapter *padapter, u32 mask, u8 arg);
-void rtl8723a_add_rateatid(struct rtw_adapter *padapter, u32 bitmap, u8 arg, u8 rssi_level);
-
-int FillH2CCmd(struct rtw_adapter *padapter, u8 ElementID, u32 CmdLen, u8 *pCmdBuffer);
-
-#endif
diff --git a/drivers/staging/rtl8723au/include/rtl8723a_dm.h b/drivers/staging/rtl8723au/include/rtl8723a_dm.h
deleted file mode 100644 (file)
index bf236e8..0000000
+++ /dev/null
@@ -1,137 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#ifndef __RTL8723A_DM_H__
-#define __RTL8723A_DM_H__
-/*  */
-/*  Description: */
-/*  */
-/*  This file is for 8723A dynamic mechanism only */
-/*  */
-/*  */
-/*  */
-#define DYNAMIC_FUNC_BT BIT(0)
-
-enum{
-       UP_LINK,
-       DOWN_LINK,
-};
-/*  */
-/*  structure and define */
-/*  */
-
-/*  duplicate code,will move to ODM ######### */
-#define IQK_MAC_REG_NUM                4
-#define IQK_ADDA_REG_NUM               16
-#define IQK_BB_REG_NUM                 9
-#define HP_THERMAL_NUM         8
-/*  duplicate code,will move to ODM ######### */
-struct dm_priv {
-       u32     InitODMFlag;
-
-       /*  Upper and Lower Signal threshold for Rate Adaptive*/
-       int     UndecoratedSmoothedPWDB;
-       int     UndecoratedSmoothedCCK;
-       int     EntryMinUndecoratedSmoothedPWDB;
-       int     EntryMaxUndecoratedSmoothedPWDB;
-       int     MinUndecoratedPWDBForDM;
-       int     LastMinUndecoratedPWDBForDM;
-
-       s32     UndecoratedSmoothedBeacon;
-       #ifdef CONFIG_8723AU_BT_COEXIST
-       s32 BT_EntryMinUndecoratedSmoothedPWDB;
-       s32 BT_EntryMaxUndecoratedSmoothedPWDB;
-       #endif
-
-       /* for High Power */
-       u8 DynamicTxHighPowerLvl;/* Add by Jacken Tx Power Control for Near/Far Range 2008/03/06 */
-
-       /* for tx power tracking */
-       u8      bTXPowerTracking;
-       u8      TXPowercount;
-       u8      bTXPowerTrackingInit;
-       u8      TxPowerTrackControl;    /* for mp mode, turn off txpwrtracking as default */
-       u8      TM_Trigger;
-
-       u8      ThermalMeter[2];                                /*  ThermalMeter, index 0 for RFIC0, and 1 for RFIC1 */
-       u8      ThermalValue;
-       u8      ThermalValue_LCK;
-       u8      ThermalValue_IQK;
-       u8      ThermalValue_DPK;
-
-       u8      bRfPiEnable;
-
-       /* for APK */
-       u32     APKoutput[2][2];        /* path A/B; output1_1a/output1_2a */
-       u8      bAPKdone;
-       u8      bAPKThermalMeterIgnore;
-       u8      bDPdone;
-       u8      bDPPathAOK;
-       u8      bDPPathBOK;
-
-       /* for IQK */
-       u32     RegC04;
-       u32     Reg874;
-       u32     RegC08;
-       u32     RegB68;
-       u32     RegB6C;
-       u32     Reg870;
-       u32     Reg860;
-       u32     Reg864;
-       u32     ADDA_backup[IQK_ADDA_REG_NUM];
-       u32     IQK_MAC_backup[IQK_MAC_REG_NUM];
-       u32     IQK_BB_backup_recover[9];
-       u32     IQK_BB_backup[IQK_BB_REG_NUM];
-       u8      PowerIndex_backup[6];
-
-       u8      bCCKinCH14;
-
-       u8      CCK_index;
-       u8      OFDM_index[2];
-
-       u8      bDoneTxpower;
-       u8      CCK_index_HP;
-       u8      OFDM_index_HP[2];
-       u8      ThermalValue_HP[HP_THERMAL_NUM];
-       u8      ThermalValue_HP_index;
-
-       /* for TxPwrTracking */
-       s32     RegE94;
-       s32     RegE9C;
-       s32     RegEB4;
-       s32     RegEBC;
-
-       u32     TXPowerTrackingCallbackCnt;     /* cosa add for debug */
-
-       u32     prv_traffic_idx; /*  edca turbo */
-
-       s32     OFDM_Pkt_Cnt;
-       u8      RSSI_Select;
-/*     u8      DIG_Dynamic_MIN ; */
-/*  duplicate code,will move to ODM ######### */
-       /*  Add for Reading Initial Data Rate SEL Register 0x484 during watchdog. Using for fill tx desc. 2011.3.21 by Thomas */
-       u8      INIDATA_RATE[32];
-};
-
-
-/*  */
-/*  function prototype */
-/*  */
-
-void rtl8723a_init_dm_priv(struct rtw_adapter *padapter);
-
-void rtl8723a_InitHalDm(struct rtw_adapter *padapter);
-void rtl8723a_HalDmWatchDog(struct rtw_adapter *padapter);
-
-#endif
diff --git a/drivers/staging/rtl8723au/include/rtl8723a_hal.h b/drivers/staging/rtl8723au/include/rtl8723a_hal.h
deleted file mode 100644 (file)
index 77a0fd4..0000000
+++ /dev/null
@@ -1,538 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#ifndef __RTL8723A_HAL_H__
-#define __RTL8723A_HAL_H__
-
-#include "rtl8723a_spec.h"
-#include "rtl8723a_pg.h"
-#include "Hal8723APhyReg.h"
-#include "Hal8723APhyCfg.h"
-#include "rtl8723a_rf.h"
-#include "rtl8723a_bt_intf.h"
-#ifdef CONFIG_8723AU_BT_COEXIST
-#include "rtl8723a_bt-coexist.h"
-#endif
-#include "rtl8723a_dm.h"
-#include "rtl8723a_recv.h"
-#include "rtl8723a_xmit.h"
-#include "rtl8723a_cmd.h"
-#include "rtl8723a_sreset.h"
-#include "rtw_efuse.h"
-#include "rtw_eeprom.h"
-
-#include "odm_precomp.h"
-#include "odm.h"
-
-
-/* 2TODO: We should define 8192S firmware related macro settings here!! */
-#define RTL819X_DEFAULT_RF_TYPE                        RF_1T2R
-#define RTL819X_TOTAL_RF_PATH                          2
-
-/*  */
-/*             RTL8723S From header */
-/*  */
-
-/*  Fw Array */
-#define Rtl8723_FwImageArray                           Rtl8723UFwImgArray
-#define Rtl8723_FwUMCBCutImageArrayWithBT              Rtl8723UFwUMCBCutImgArrayWithBT
-#define Rtl8723_FwUMCBCutImageArrayWithoutBT   Rtl8723UFwUMCBCutImgArrayWithoutBT
-
-#define Rtl8723_ImgArrayLength                         Rtl8723UImgArrayLength
-#define Rtl8723_UMCBCutImgArrayWithBTLength            Rtl8723UUMCBCutImgArrayWithBTLength
-#define Rtl8723_UMCBCutImgArrayWithoutBTLength Rtl8723UUMCBCutImgArrayWithoutBTLength
-
-#define Rtl8723_PHY_REG_Array_PG                       Rtl8723UPHY_REG_Array_PG
-#define Rtl8723_PHY_REG_Array_PGLength         Rtl8723UPHY_REG_Array_PGLength
-
-#define Rtl8723_FwUMCBCutMPImageArray          Rtl8723SFwUMCBCutMPImgAr
-#define Rtl8723_UMCBCutMPImgArrayLength                Rtl8723SUMCBCutMPImgArrayLength
-
-#define DRVINFO_SZ                             4 /*  unit is 8bytes */
-#define PageNum_128(_Len)              (u32)(((_Len)>>7) + ((_Len)&0x7F ? 1:0))
-
-#define FW_8723A_SIZE                  0x8000
-#define FW_8723A_START_ADDRESS 0x1000
-#define FW_8723A_END_ADDRESS           0x1FFF /* 0x5FFF */
-
-#define MAX_PAGE_SIZE                  4096    /*  @ page : 4k bytes */
-
-#define IS_FW_HEADER_EXIST(_pFwHdr)    ((le16_to_cpu(_pFwHdr->Signature)&0xFFF0) == 0x92C0 ||\
-                                                                       (le16_to_cpu(_pFwHdr->Signature)&0xFFF0) == 0x88C0 ||\
-                                                                       (le16_to_cpu(_pFwHdr->Signature)&0xFFF0) == 0x2300)
-
-/*  */
-/*  This structure must be cared byte-ordering */
-/*  */
-/*  Added by tynli. 2009.12.04. */
-struct rt_8723a_firmware_hdr {
-       /*  8-byte alinment required */
-
-       /*  LONG WORD 0 ---- */
-       __le16          Signature;  /*
-                                    * 92C0: test chip; 92C, 88C0: test chip;
-                                    * 88C1: MP A-cut; 92C1: MP A-cut
-                                    */
-       u8              Category;       /*  AP/NIC and USB/PCI */
-       u8              Function;       /*  Reserved for different FW function indcation, for further use when driver needs to download different FW in different conditions */
-       __le16          Version;                /*  FW Version */
-       u8              Subversion;     /*  FW Subversion, default 0x00 */
-       u8              Rsvd1;
-
-
-       /*  LONG WORD 1 ---- */
-       u8              Month;  /*  Release time Month field */
-       u8              Date;   /*  Release time Date field */
-       u8              Hour;   /*  Release time Hour field */
-       u8              Minute; /*  Release time Minute field */
-       __le16          RamCodeSize;    /*  The size of RAM code */
-       __le16          Rsvd2;
-
-       /*  LONG WORD 2 ---- */
-       __le32          SvnIdx; /*  The SVN entry index */
-       __le32          Rsvd3;
-
-       /*  LONG WORD 3 ---- */
-       __le32          Rsvd4;
-       __le32          Rsvd5;
-};
-
-#define DRIVER_EARLY_INT_TIME          0x05
-#define BCN_DMA_ATIME_INT_TIME         0x02
-
-
-/*  BK, BE, VI, VO, HCCA, MANAGEMENT, COMMAND, HIGH, BEACON. */
-#define MAX_TX_QUEUE           9
-
-#define TX_SELE_HQ                     BIT(0)          /*  High Queue */
-#define TX_SELE_LQ                     BIT(1)          /*  Low Queue */
-#define TX_SELE_NQ                     BIT(2)          /*  Normal Queue */
-
-/*  Note: We will divide number of page equally for each queue other than public queue! */
-#define TX_TOTAL_PAGE_NUMBER   0xF8
-#define TX_PAGE_BOUNDARY               (TX_TOTAL_PAGE_NUMBER + 1)
-
-/*  For Normal Chip Setting */
-/*  (HPQ + LPQ + NPQ + PUBQ) shall be TX_TOTAL_PAGE_NUMBER */
-#define NORMAL_PAGE_NUM_PUBQ   0xE7
-#define NORMAL_PAGE_NUM_HPQ            0x0C
-#define NORMAL_PAGE_NUM_LPQ            0x02
-#define NORMAL_PAGE_NUM_NPQ            0x02
-
-/*  For Test Chip Setting */
-/*  (HPQ + LPQ + PUBQ) shall be TX_TOTAL_PAGE_NUMBER */
-#define TEST_PAGE_NUM_PUBQ             0x7E
-
-/*  For Test Chip Setting */
-#define WMM_TEST_TX_TOTAL_PAGE_NUMBER  0xF5
-#define WMM_TEST_TX_PAGE_BOUNDARY              (WMM_TEST_TX_TOTAL_PAGE_NUMBER + 1) /* F6 */
-
-#define WMM_TEST_PAGE_NUM_PUBQ         0xA3
-#define WMM_TEST_PAGE_NUM_HPQ          0x29
-#define WMM_TEST_PAGE_NUM_LPQ          0x29
-
-/*  Note: For Normal Chip Setting, modify later */
-#define WMM_NORMAL_TX_TOTAL_PAGE_NUMBER        0xF5
-#define WMM_NORMAL_TX_PAGE_BOUNDARY            (WMM_TEST_TX_TOTAL_PAGE_NUMBER + 1) /* F6 */
-
-#define WMM_NORMAL_PAGE_NUM_PUBQ       0xB0
-#define WMM_NORMAL_PAGE_NUM_HPQ                0x29
-#define WMM_NORMAL_PAGE_NUM_LPQ                0x1C
-#define WMM_NORMAL_PAGE_NUM_NPQ                0x1C
-
-
-/*  */
-/*     Chip specific */
-/*  */
-#define CHIP_BONDING_IDENTIFIER(_value)        (((_value)>>22)&0x3)
-#define CHIP_BONDING_92C_1T2R                  0x1
-#define CHIP_BONDING_88C_USB_MCARD             0x2
-#define CHIP_BONDING_88C_USB_HP                        0x1
-
-#include "HalVerDef.h"
-#include "hal_com.h"
-
-/*  */
-/*     Channel Plan */
-/*  */
-enum ChannelPlan
-{
-       CHPL_FCC        = 0,
-       CHPL_IC         = 1,
-       CHPL_ETSI       = 2,
-       CHPL_SPAIN      = 3,
-       CHPL_FRANCE     = 4,
-       CHPL_MKK        = 5,
-       CHPL_MKK1       = 6,
-       CHPL_ISRAEL     = 7,
-       CHPL_TELEC      = 8,
-       CHPL_GLOBAL     = 9,
-       CHPL_WORLD      = 10,
-};
-
-#define EFUSE_REAL_CONTENT_LEN         512
-#define EFUSE_MAP_LEN                          128
-#define EFUSE_MAX_SECTION                      16
-#define EFUSE_IC_ID_OFFSET                     506     /* For some inferiority IC purpose. added by Roger, 2009.09.02. */
-#define AVAILABLE_EFUSE_ADDR(addr)     (addr < EFUSE_REAL_CONTENT_LEN)
-/*  */
-/*  <Roger_Notes> */
-/*  To prevent out of boundary programming case, */
-/*  leave 1byte and program full section */
-/*  9bytes + 1byt + 5bytes and pre 1byte. */
-/*  For worst case: */
-/*  | 1byte|----8bytes----|1byte|--5bytes--| */
-/*  |         |            Reserved(14bytes)         | */
-/*  */
-
-/*  PG data exclude header, dummy 6 bytes from CP test and reserved 1byte. */
-#define EFUSE_OOB_PROTECT_BYTES                        15
-
-#define EFUSE_REAL_CONTENT_LEN_8723A   512
-#define EFUSE_MAP_LEN_8723A                            256
-#define EFUSE_MAX_SECTION_8723A                        32
-
-/*  */
-/*                     EFUSE for BT definition */
-/*  */
-#define EFUSE_BT_REAL_BANK_CONTENT_LEN 512
-#define EFUSE_BT_REAL_CONTENT_LEN              1536    /*  512*3 */
-#define EFUSE_BT_MAP_LEN                               1024    /*  1k bytes */
-#define EFUSE_BT_MAX_SECTION                   128             /*  1024/8 */
-
-#define EFUSE_PROTECT_BYTES_BANK               16
-
-/*  */
-/*  <Roger_Notes> For RTL8723 WiFi/BT/GPS multi-function configuration. 2010.10.06. */
-/*  */
-enum RT_MULTI_FUNC {
-       RT_MULTI_FUNC_NONE = 0x00,
-       RT_MULTI_FUNC_WIFI = 0x01,
-       RT_MULTI_FUNC_BT = 0x02,
-       RT_MULTI_FUNC_GPS = 0x04,
-};
-
-/*  */
-/*  <Roger_Notes> For RTL8723 WiFi PDn/GPIO polarity control configuration. 2010.10.08. */
-/*  */
-enum RT_POLARITY_CTL {
-       RT_POLARITY_LOW_ACT = 0,
-       RT_POLARITY_HIGH_ACT = 1,
-};
-
-/*  For RTL8723 regulator mode. by tynli. 2011.01.14. */
-enum RT_REGULATOR_MODE {
-       RT_SWITCHING_REGULATOR = 0,
-       RT_LDO_REGULATOR = 1,
-};
-
-/*  Description: Determine the types of C2H events that are the same in driver and Fw. */
-/*  Fisrt constructed by tynli. 2009.10.09. */
-enum {
-       C2H_DBG = 0,
-       C2H_TSF = 1,
-       C2H_AP_RPT_RSP = 2,
-       C2H_CCX_TX_RPT = 3,     /*  The FW notify the report of the specific tx packet. */
-       C2H_BT_RSSI = 4,
-       C2H_BT_OP_MODE = 5,
-       C2H_EXT_RA_RPT = 6,
-       C2H_HW_INFO_EXCH = 10,
-       C2H_C2H_H2C_TEST = 11,
-       C2H_BT_INFO = 12,
-       C2H_BT_MP_INFO = 15,
-       MAX_C2HEVENT
-};
-
-struct hal_data_8723a {
-       struct hal_version              VersionID;
-       enum rt_customer_id CustomerID;
-
-       u16     FirmwareVersion;
-       u16     FirmwareVersionRev;
-       u16     FirmwareSubVersion;
-       u16     FirmwareSignature;
-
-       /* current WIFI_PHY values */
-       u32     ReceiveConfig;
-       enum WIRELESS_MODE              CurrentWirelessMode;
-       enum ht_channel_width   CurrentChannelBW;
-       u8      CurrentChannel;
-       u8      nCur40MhzPrimeSC;/*  Control channel sub-carrier */
-
-       u16     BasicRateSet;
-
-       /* rf_ctrl */
-       u8      rf_type;
-       u8      NumTotalRFPath;
-
-       u8      BoardType;
-       u8      CrystalCap;
-       /*  */
-       /*  EEPROM setting. */
-       /*  */
-       u8      EEPROMVersion;
-       u8      EEPROMCustomerID;
-       u8      EEPROMSubCustomerID;
-       u8      EEPROMRegulatory;
-       u8      EEPROMThermalMeter;
-       u8      EEPROMBluetoothCoexist;
-       u8      EEPROMBluetoothType;
-       u8      EEPROMBluetoothAntNum;
-       u8      EEPROMBluetoothAntIsolation;
-       u8      EEPROMBluetoothRadioShared;
-
-       u8      bTXPowerDataReadFromEEPORM;
-       u8      bAPKThermalMeterIgnore;
-
-       u8      bIQKInitialized;
-       u8      bAntennaDetected;
-
-       u8      TxPwrLevelCck[RF_PATH_MAX][CHANNEL_MAX_NUMBER];
-       u8      TxPwrLevelHT40_1S[RF_PATH_MAX][CHANNEL_MAX_NUMBER];     /*  For HT 40MHZ pwr */
-       u8      TxPwrLevelHT40_2S[RF_PATH_MAX][CHANNEL_MAX_NUMBER];     /*  For HT 40MHZ pwr */
-       u8      TxPwrHt20Diff[RF_PATH_MAX][CHANNEL_MAX_NUMBER];/*  HT 20<->40 Pwr diff */
-       u8      TxPwrLegacyHtDiff[RF_PATH_MAX][CHANNEL_MAX_NUMBER];/*  For HT<->legacy pwr diff */
-       /*  For power group */
-       u8      PwrGroupHT20[RF_PATH_MAX][CHANNEL_MAX_NUMBER];
-       u8      PwrGroupHT40[RF_PATH_MAX][CHANNEL_MAX_NUMBER];
-
-       u8      LegacyHTTxPowerDiff;/*  Legacy to HT rate power diff */
-
-       /*  Read/write are allow for following hardware information variables */
-       u8      framesync;
-       u32     framesyncC34;
-       u8      framesyncMonitor;
-       u8      pwrGroupCnt;
-       u32     MCSTxPowerLevelOriginalOffset[7][16];
-       u32     CCKTxPowerLevelOriginalOffset;
-
-       u32     AntennaTxPath;                                  /*  Antenna path Tx */
-       u32     AntennaRxPath;                                  /*  Antenna path Rx */
-       u8      ExternalPA;
-
-       u8      bLedOpenDrain; /*  Support Open-drain arrangement for controlling the LED. Added by Roger, 2009.10.16. */
-
-       u8      b1x1RecvCombine;        /*  for 1T1R receive combining */
-
-       /*  For EDCA Turbo mode */
-
-       u32     AcParam_BE; /* Original parameter for BE, use for EDCA turbo. */
-
-       /* vivi, for tx power tracking, 20080407 */
-       /* u16  TSSI_13dBm; */
-       /* u32  Pwr_Track; */
-       /*  The current Tx Power Level */
-       u8      CurrentCckTxPwrIdx;
-       u8      CurrentOfdm24GTxPwrIdx;
-
-       struct bb_reg_define    PHYRegDef[4];   /* Radio A/B/C/D */
-
-       bool            bRFPathRxEnable[4];     /*  We support 4 RF path now. */
-
-       u32     RfRegChnlVal[2];
-
-       u8      bCckHighPower;
-
-       /* RDG enable */
-       bool     bRDGEnable;
-
-       /* for host message to fw */
-       u8      LastHMEBoxNum;
-
-       u8      RegTxPause;
-       /*  Beacon function related global variable. */
-       u8      RegFwHwTxQCtrl;
-       u8      RegReg542;
-
-       struct dm_priv  dmpriv;
-       struct dm_odm_t         odmpriv;
-       struct sreset_priv srestpriv;
-
-#ifdef CONFIG_8723AU_BT_COEXIST
-       u8                              bBTMode;
-       /*  BT only. */
-       struct bt_30info                BtInfo;
-       /*  For bluetooth co-existance */
-       struct bt_coexist_str   bt_coexist;
-#endif
-
-       u8      bDumpRxPkt;/* for debug */
-       u8      FwRsvdPageStartOffset; /* 2010.06.23. Added by tynli. Reserve page start offset except beacon in TxQ. */
-
-       /*  2010/08/09 MH Add CU power down mode. */
-       u8      pwrdown;
-
-       u8      OutEpQueueSel;
-       u8      OutEpNumber;
-
-       /*  */
-       /*  Add For EEPROM Efuse switch and  Efuse Shadow map Setting */
-       /*  */
-       u8                      EepromOrEfuse;
-       u16                     EfuseUsedBytes;
-       u16                     BTEfuseUsedBytes;
-
-       /*  Interrupt relatd register information. */
-       u32                     SysIntrStatus;
-       u32                     SysIntrMask;
-
-       /*  */
-       /*  2011/02/23 MH Add for 8723 mylti function definition. The define should be moved to an */
-       /*  independent file in the future. */
-       /*  */
-       /* 8723-----------------------------------------*/
-       enum RT_MULTI_FUNC      MultiFunc; /*  For multi-function consideration. */
-       enum RT_POLARITY_CTL    PolarityCtl; /*  For Wifi PDn Polarity control. */
-       enum RT_REGULATOR_MODE  RegulatorMode; /*  switching regulator or LDO */
-       /* 8723-----------------------------------------
-        *  2011/02/23 MH Add for 8723 mylti function definition. The define should be moved to an */
-       /*  independent file in the future. */
-
-       /*  Interrupt related register information. */
-       u32     IntArray[2];
-       u32     IntrMask[2];
-};
-
-#define GET_HAL_DATA(__pAdapter)       ((struct hal_data_8723a *)((__pAdapter)->HalData))
-#define GET_RF_TYPE(priv)                      (GET_HAL_DATA(priv)->rf_type)
-
-#define INCLUDE_MULTI_FUNC_BT(_Adapter)                (GET_HAL_DATA(_Adapter)->MultiFunc & RT_MULTI_FUNC_BT)
-#define INCLUDE_MULTI_FUNC_GPS(_Adapter)       (GET_HAL_DATA(_Adapter)->MultiFunc & RT_MULTI_FUNC_GPS)
-
-struct rxreport_8723a {
-       u32 pktlen:14;
-       u32 crc32:1;
-       u32 icverr:1;
-       u32 drvinfosize:4;
-       u32 security:3;
-       u32 qos:1;
-       u32 shift:2;
-       u32 physt:1;
-       u32 swdec:1;
-       u32 ls:1;
-       u32 fs:1;
-       u32 eor:1;
-       u32 own:1;
-
-       u32 macid:5;
-       u32 tid:4;
-       u32 hwrsvd:4;
-       u32 amsdu:1;
-       u32 paggr:1;
-       u32 faggr:1;
-       u32 a1fit:4;
-       u32 a2fit:4;
-       u32 pam:1;
-       u32 pwr:1;
-       u32 md:1;
-       u32 mf:1;
-       u32 type:2;
-       u32 mc:1;
-       u32 bc:1;
-
-       u32 seq:12;
-       u32 frag:4;
-       u32 nextpktlen:14;
-       u32 nextind:1;
-       u32 rsvd0831:1;
-
-       u32 rxmcs:6;
-       u32 rxht:1;
-       u32 gf:1;
-       u32 splcp:1;
-       u32 bw:1;
-       u32 htc:1;
-       u32 eosp:1;
-       u32 bssidfit:2;
-       u32 rsvd1214:16;
-       u32 unicastwake:1;
-       u32 magicwake:1;
-
-       u32 pattern0match:1;
-       u32 pattern1match:1;
-       u32 pattern2match:1;
-       u32 pattern3match:1;
-       u32 pattern4match:1;
-       u32 pattern5match:1;
-       u32 pattern6match:1;
-       u32 pattern7match:1;
-       u32 pattern8match:1;
-       u32 pattern9match:1;
-       u32 patternamatch:1;
-       u32 patternbmatch:1;
-       u32 patterncmatch:1;
-       u32 rsvd1613:19;
-
-       u32 tsfl;
-
-       u32 bassn:12;
-       u32 bavld:1;
-       u32 rsvd2413:19;
-};
-
-/*  rtl8723a_hal_init.c */
-s32 rtl8723a_FirmwareDownload(struct rtw_adapter *padapter);
-void rtl8723a_FirmwareSelfReset(struct rtw_adapter *padapter);
-void rtl8723a_InitializeFirmwareVars(struct rtw_adapter *padapter);
-
-void rtl8723a_InitAntenna_Selection(struct rtw_adapter *padapter);
-void rtl8723a_DeinitAntenna_Selection(struct rtw_adapter *padapter);
-void rtl8723a_CheckAntenna_Selection(struct rtw_adapter *padapter);
-void rtl8723a_init_default_value(struct rtw_adapter *padapter);
-
-s32 InitLLTTable23a(struct rtw_adapter *padapter, u32 boundary);
-
-s32 CardDisableHWSM(struct rtw_adapter *padapter, u8 resetMCU);
-s32 CardDisableWithoutHWSM(struct rtw_adapter *padapter);
-
-/*  EFuse */
-u8 GetEEPROMSize8723A(struct rtw_adapter *padapter);
-void Hal_InitPGData(struct rtw_adapter *padapter, u8 *PROMContent);
-void Hal_EfuseParseIDCode(struct rtw_adapter *padapter, u8 *hwinfo);
-void Hal_EfuseParsetxpowerinfo_8723A(struct rtw_adapter *padapter, u8 *PROMContent, bool AutoLoadFail);
-void Hal_EfuseParseBTCoexistInfo_8723A(struct rtw_adapter *padapter, u8 *hwinfo, bool AutoLoadFail);
-void Hal_EfuseParseEEPROMVer(struct rtw_adapter *padapter, u8 *hwinfo, bool AutoLoadFail);
-void rtl8723a_EfuseParseChnlPlan(struct rtw_adapter *padapter, u8 *hwinfo, bool AutoLoadFail);
-void Hal_EfuseParseCustomerID(struct rtw_adapter *padapter, u8 *hwinfo, bool AutoLoadFail);
-void Hal_EfuseParseAntennaDiversity(struct rtw_adapter *padapter, u8 *hwinfo, bool AutoLoadFail);
-void Hal_EfuseParseRateIndicationOption(struct rtw_adapter *padapter, u8 *hwinfo, bool AutoLoadFail);
-void Hal_EfuseParseXtal_8723A(struct rtw_adapter *pAdapter, u8 *hwinfo, u8 AutoLoadFail);
-void Hal_EfuseParseThermalMeter_8723A(struct rtw_adapter *padapter, u8 *hwinfo, bool AutoLoadFail);
-
-/*  register */
-void SetBcnCtrlReg23a(struct rtw_adapter *padapter, u8 SetBits, u8 ClearBits);
-void rtl8723a_InitBeaconParameters(struct rtw_adapter *padapter);
-
-void rtl8723a_start_thread(struct rtw_adapter *padapter);
-void rtl8723a_stop_thread(struct rtw_adapter *padapter);
-
-bool c2h_id_filter_ccx_8723a(u8 id);
-int c2h_handler_8723a(struct rtw_adapter *padapter, struct c2h_evt_hdr *c2h_evt);
-
-void rtl8723a_read_adapter_info(struct rtw_adapter *Adapter);
-void rtl8723a_read_chip_version(struct rtw_adapter *padapter);
-void rtl8723a_notch_filter(struct rtw_adapter *adapter, bool enable);
-void rtl8723a_SetBeaconRelatedRegisters(struct rtw_adapter *padapter);
-void rtl8723a_SetHalODMVar(struct rtw_adapter *Adapter,
-                          enum hal_odm_variable eVariable,
-                          void *pValue1, bool bSet);
-void
-rtl8723a_readefuse(struct rtw_adapter *padapter,
-                  u8 efuseType, u16 _offset, u16 _size_byte, u8 *pbuf);
-u16 rtl8723a_EfuseGetCurrentSize_WiFi(struct rtw_adapter *padapter);
-u16 rtl8723a_EfuseGetCurrentSize_BT(struct rtw_adapter *padapter);
-void rtl8723a_update_ramask(struct rtw_adapter *padapter,
-                           u32 mac_id, u8 rssi_level);
-
-#endif
diff --git a/drivers/staging/rtl8723au/include/rtl8723a_pg.h b/drivers/staging/rtl8723au/include/rtl8723a_pg.h
deleted file mode 100644 (file)
index 5c2ec44..0000000
+++ /dev/null
@@ -1,98 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#ifndef __RTL8723A_PG_H__
-#define __RTL8723A_PG_H__
-
-/*                     EEPROM/Efuse PG Offset for 8723E/8723U/8723S */
-#define EEPROM_CCK_TX_PWR_INX_8723A                    0x10
-#define EEPROM_HT40_1S_TX_PWR_INX_8723A                0x16
-#define EEPROM_HT20_TX_PWR_INX_DIFF_8723A      0x1C
-#define EEPROM_OFDM_TX_PWR_INX_DIFF_8723A      0x1F
-#define EEPROM_HT40_MAX_PWR_OFFSET_8723A       0x22
-#define EEPROM_HT20_MAX_PWR_OFFSET_8723A       0x25
-
-#define EEPROM_ChannelPlan_8723A                       0x28
-#define EEPROM_TSSI_A_8723A                                    0x29
-#define EEPROM_THERMAL_METER_8723A                     0x2A
-#define RF_OPTION1_8723A                                       0x2B
-#define RF_OPTION2_8723A                                       0x2C
-#define RF_OPTION3_8723A                                       0x2D
-#define RF_OPTION4_8723A                                       0x2E
-#define EEPROM_VERSION_8723A                           0x30
-#define EEPROM_CustomID_8723A                          0x31
-#define EEPROM_SubCustomID_8723A                       0x32
-#define EEPROM_XTAL_K_8723A                                    0x33
-#define EEPROM_Chipset_8723A                           0x34
-
-/*  RTL8723AE */
-#define EEPROM_VID_8723AE                                      0x49
-#define EEPROM_DID_8723AE                                      0x4B
-#define EEPROM_SVID_8723AE                                     0x4D
-#define EEPROM_SMID_8723AE                                     0x4F
-#define EEPROM_MAC_ADDR_8723AE                         0x67
-
-/*  RTL8723AU */
-#define EEPROM_MAC_ADDR_8723AU                         0xC6
-#define EEPROM_VID_8723AU                                      0xB7
-#define EEPROM_PID_8723AU                                      0xB9
-
-/*  RTL8723AS */
-#define EEPROM_MAC_ADDR_8723AS                         0xAA
-
-/*                     EEPROM/Efuse Value Type */
-#define EETYPE_TX_PWR                                          0x0
-
-/*                     EEPROM/Efuse Default Value */
-#define EEPROM_Default_CrystalCap_8723A                0x20
-
-
-/*        EEPROM/EFUSE data structure definition. */
-#define        MAX_CHNL_GROUP          3+9
-
-struct txpowerinfo {
-       u8 CCKIndex[RF_PATH_MAX][MAX_CHNL_GROUP];
-       u8 HT40_1SIndex[RF_PATH_MAX][MAX_CHNL_GROUP];
-       u8 HT40_2SIndexDiff[RF_PATH_MAX][MAX_CHNL_GROUP];
-       u8 HT20IndexDiff[RF_PATH_MAX][MAX_CHNL_GROUP];
-       u8 OFDMIndexDiff[RF_PATH_MAX][MAX_CHNL_GROUP];
-       u8 HT40MaxOffset[RF_PATH_MAX][MAX_CHNL_GROUP];
-       u8 HT20MaxOffset[RF_PATH_MAX][MAX_CHNL_GROUP];
-       u8 TSSI_A[3];
-       u8 TSSI_B[3];
-       u8 TSSI_A_5G[3];                /* 5GL/5GM/5GH */
-       u8 TSSI_B_5G[3];
-};
-
-enum bt_ant_num {
-       Ant_x2  = 0,
-       Ant_x1  = 1
-};
-
-enum bt_cotype {
-       BT_2Wire                = 0,
-       BT_ISSC_3Wire           = 1,
-       BT_Accel                = 2,
-       BT_CSR_BC4              = 3,
-       BT_CSR_BC8              = 4,
-       BT_RTL8756              = 5,
-       BT_RTL8723A             = 6
-};
-
-enum bt_radioshared {
-       BT_Radio_Shared         = 0,
-       BT_Radio_Individual     = 1,
-};
-
-#endif
diff --git a/drivers/staging/rtl8723au/include/rtl8723a_recv.h b/drivers/staging/rtl8723au/include/rtl8723a_recv.h
deleted file mode 100644 (file)
index 875d37b..0000000
+++ /dev/null
@@ -1,65 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#ifndef __RTL8723A_RECV_H__
-#define __RTL8723A_RECV_H__
-
-#include <osdep_service.h>
-#include <drv_types.h>
-
-#define NR_RECVBUFF                    4
-
-#define NR_PREALLOC_RECV_SKB           8
-
-#define RECV_BLK_SZ                    512
-#define RECV_BLK_CNT                   16
-#define RECV_BLK_TH                    RECV_BLK_CNT
-
-#define MAX_RECVBUF_SZ                 15360 /*  15k < 16k */
-
-#define PHY_RSSI_SLID_WIN_MAX          100
-#define PHY_LINKQUALITY_SLID_WIN_MAX   20
-
-
-struct phy_stat {
-       unsigned int phydw0;
-       unsigned int phydw1;
-       unsigned int phydw2;
-       unsigned int phydw3;
-       unsigned int phydw4;
-       unsigned int phydw5;
-       unsigned int phydw6;
-       unsigned int phydw7;
-};
-
-/*  Rx smooth factor */
-#define        Rx_Smooth_Factor                20
-
-struct interrupt_msg_format {
-       unsigned int C2H_MSG0;
-       unsigned int C2H_MSG1;
-       unsigned int C2H_MSG2;
-       unsigned int C2H_MSG3;
-       unsigned int HISR; /*  from HISR Reg0x124, read to clear */
-       unsigned int HISRE;/*  from HISRE Reg0x12c, read to clear */
-       unsigned int  MSG_EX;
-};
-
-int rtl8723au_init_recv_priv(struct rtw_adapter *padapter);
-void rtl8723au_free_recv_priv(struct rtw_adapter *padapter);
-void rtl8723a_process_phy_info(struct rtw_adapter *padapter, void *prframe);
-void update_recvframe_attrib(struct recv_frame *precvframe, struct recv_stat *prxstat);
-void update_recvframe_phyinfo(struct recv_frame *precvframe, struct phy_stat *pphy_info);
-
-#endif
diff --git a/drivers/staging/rtl8723au/include/rtl8723a_rf.h b/drivers/staging/rtl8723au/include/rtl8723a_rf.h
deleted file mode 100644 (file)
index 0432799..0000000
+++ /dev/null
@@ -1,58 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#ifndef __RTL8723A_RF_H__
-#define __RTL8723A_RF_H__
-
-/*--------------------------Define Parameters-------------------------------*/
-
-/*  */
-/*  For RF 6052 Series */
-/*  */
-#define                RF6052_MAX_TX_PWR                       0x3F
-#define                RF6052_MAX_REG                          0x3F
-#define                RF6052_MAX_PATH                         2
-/*--------------------------Define Parameters-------------------------------*/
-
-
-/*------------------------------Define structure----------------------------*/
-
-/*------------------------------Define structure----------------------------*/
-
-
-/*------------------------Export global variable----------------------------*/
-/*------------------------Export global variable----------------------------*/
-
-/*------------------------Export Marco Definition---------------------------*/
-
-/*------------------------Export Marco Definition---------------------------*/
-
-
-/*--------------------------Exported Function prototype---------------------*/
-
-/*  */
-/*  RF RL6052 Series API */
-/*  */
-void rtl8723a_phy_rf6052set_bw(struct rtw_adapter *Adapter,
-                              enum ht_channel_width Bandwidth);
-void rtl823a_phy_rf6052setccktxpower(struct rtw_adapter *Adapter,
-                                     u8 *pPowerlevel);
-void rtl8723a_PHY_RF6052SetOFDMTxPower(struct rtw_adapter *Adapter,
-                                      u8 *pPowerLevel, u8 Channel);
-
-/*--------------------------Exported Function prototype---------------------*/
-
-int    PHY_RF6052_Config8723A(struct rtw_adapter *Adapter);
-
-#endif
diff --git a/drivers/staging/rtl8723au/include/rtl8723a_spec.h b/drivers/staging/rtl8723au/include/rtl8723a_spec.h
deleted file mode 100644 (file)
index 2f18689..0000000
+++ /dev/null
@@ -1,2148 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- *******************************************************************************/
-#ifndef __RTL8723A_SPEC_H__
-#define __RTL8723A_SPEC_H__
-
-/*  */
-/*  */
-/*     0x0000h ~ 0x00FFh       System Configuration */
-/*  */
-/*  */
-#define REG_SYS_ISO_CTRL               0x0000
-#define REG_SYS_FUNC_EN                        0x0002
-#define REG_APS_FSMCO                  0x0004
-#define REG_SYS_CLKR                   0x0008
-#define REG_9346CR                     0x000A
-#define REG_EE_VPD                     0x000C
-#define REG_AFE_MISC                   0x0010
-#define REG_SPS0_CTRL                  0x0011
-#define REG_SPS_OCP_CFG                        0x0018
-#define REG_RSV_CTRL                   0x001C
-#define REG_RF_CTRL                    0x001F
-#define REG_LDOA15_CTRL                        0x0020
-#define REG_LDOV12D_CTRL               0x0021
-#define REG_LDOHCI12_CTRL              0x0022
-#define REG_LPLDO_CTRL                 0x0023
-#define REG_AFE_XTAL_CTRL              0x0024
-#define REG_AFE_PLL_CTRL               0x0028
-#define REG_MAC_PHY_CTRL               0x002c
-#define REG_EFUSE_CTRL                 0x0030
-#define REG_EFUSE_TEST                 0x0034
-#define REG_PWR_DATA                   0x0038
-#define REG_CAL_TIMER                  0x003C
-#define REG_ACLK_MON                   0x003E
-#define REG_GPIO_MUXCFG                        0x0040
-#define REG_GPIO_IO_SEL                        0x0042
-#define REG_MAC_PINMUX_CFG             0x0043
-#define REG_GPIO_PIN_CTRL              0x0044
-#define REG_GPIO_INTM                  0x0048
-#define REG_LEDCFG0                    0x004C
-#define REG_LEDCFG1                    0x004D
-#define REG_LEDCFG2                    0x004E
-#define REG_LEDCFG3                    0x004F
-#define REG_LEDCFG                     REG_LEDCFG2
-#define REG_FSIMR                      0x0050
-#define REG_FSISR                      0x0054
-#define REG_HSIMR                      0x0058
-#define REG_HSISR                      0x005c
- /*  RTL8723 WIFI/BT/GPS Multi-Function GPIO Pin Control. */
-#define REG_GPIO_PIN_CTRL_2            0x0060
- /*  RTL8723 WIFI/BT/GPS Multi-Function GPIO Select. */
-#define REG_GPIO_IO_SEL_2              0x0062
- /*  RTL8723 WIFI/BT/GPS Multi-Function control source. */
-#define REG_MULTI_FUNC_CTRL            0x0068
-#define REG_MCUFWDL                    0x0080
-#define REG_HMEBOX_EXT_0               0x0088
-#define REG_HMEBOX_EXT_1               0x008A
-#define REG_HMEBOX_EXT_2               0x008C
-#define REG_HMEBOX_EXT_3               0x008E
-       /*  Host suspend counter on FPGA platform */
-#define REG_HOST_SUSP_CNT              0x00BC
-       /*  Efuse access protection for RTL8723 */
-#define REG_EFUSE_ACCESS               0x00CF
-#define REG_BIST_SCAN                  0x00D0
-#define REG_BIST_RPT                   0x00D4
-#define REG_BIST_ROM_RPT               0x00D8
-#define REG_USB_SIE_INTF               0x00E0
-#define REG_PCIE_MIO_INTF              0x00E4
-#define REG_PCIE_MIO_INTD              0x00E8
-#define REG_HPON_FSM                   0x00EC
-#define REG_SYS_CFG                    0x00F0
-#define REG_GPIO_OUTSTS                        0x00F4  /*  For RTL8723 only. */
-
-/*  */
-/*  */
-/*     0x0100h ~ 0x01FFh       MACTOP General Configuration */
-/*  */
-/*  */
-#define REG_CR                         0x0100
-#define REG_PBP                                0x0104
-#define REG_TRXDMA_CTRL                        0x010C
-#define REG_TRXFF_BNDY                 0x0114
-#define REG_TRXFF_STATUS               0x0118
-#define REG_RXFF_PTR                   0x011C
-#define REG_HIMR                       0x0120
-#define REG_HISR                       0x0124
-#define REG_HIMRE                      0x0128
-#define REG_HISRE                      0x012C
-#define REG_CPWM                       0x012F
-#define REG_FWIMR                      0x0130
-#define REG_FWISR                      0x0134
-#define REG_PKTBUF_DBG_CTRL            0x0140
-#define REG_PKTBUF_DBG_DATA_L          0x0144
-#define REG_PKTBUF_DBG_DATA_H          0x0148
-
-#define REG_TC0_CTRL                   0x0150
-#define REG_TC1_CTRL                   0x0154
-#define REG_TC2_CTRL                   0x0158
-#define REG_TC3_CTRL                   0x015C
-#define REG_TC4_CTRL                   0x0160
-#define REG_TCUNIT_BASE                        0x0164
-#define REG_MBIST_START                        0x0174
-#define REG_MBIST_DONE                 0x0178
-#define REG_MBIST_FAIL                 0x017C
-#define REG_C2HEVT_MSG_NORMAL          0x01A0
-#define REG_C2HEVT_CLEAR               0x01AF
-#define REG_C2HEVT_MSG_TEST            0x01B8
-#define REG_MCUTST_1                   0x01c0
-#define REG_FMETHR                     0x01C8
-#define REG_HMETFR                     0x01CC
-#define REG_HMEBOX_0                   0x01D0
-#define REG_HMEBOX_1                   0x01D4
-#define REG_HMEBOX_2                   0x01D8
-#define REG_HMEBOX_3                   0x01DC
-
-#define REG_LLT_INIT                   0x01E0
-#define REG_BB_ACCEESS_CTRL            0x01E8
-#define REG_BB_ACCESS_DATA             0x01EC
-
-
-/*  */
-/*  */
-/*     0x0200h ~ 0x027Fh       TXDMA Configuration */
-/*  */
-/*  */
-#define REG_RQPN                       0x0200
-#define REG_FIFOPAGE                   0x0204
-#define REG_TDECTRL                    0x0208
-#define REG_TXDMA_OFFSET_CHK           0x020C
-#define REG_TXDMA_STATUS               0x0210
-#define REG_RQPN_NPQ                   0x0214
-
-/*  */
-/*  */
-/*     0x0280h ~ 0x02FFh       RXDMA Configuration */
-/*  */
-/*  */
-#define REG_RXDMA_AGG_PG_TH            0x0280
-#define REG_RXPKT_NUM                  0x0284
-#define REG_RXDMA_STATUS               0x0288
-
-
-/*  */
-/*  */
-/*     0x0300h ~ 0x03FFh       PCIe */
-/*  */
-/*  */
-#define        REG_PCIE_CTRL_REG               0x0300
-#define        REG_INT_MIG                     0x0304  /*  Interrupt Migration */
-       /*  TX Beacon Descriptor Address */
-#define        REG_BCNQ_DESA                   0x0308
-       /*  TX High Queue Descriptor Address */
-#define        REG_HQ_DESA                     0x0310
-       /*  TX Manage Queue Descriptor Address */
-#define        REG_MGQ_DESA                    0x0318
-       /*  TX VO Queue Descriptor Address */
-#define        REG_VOQ_DESA                    0x0320
-       /*  TX VI Queue Descriptor Address */
-#define        REG_VIQ_DESA                    0x0328
-       /*  TX BE Queue Descriptor Address */
-#define        REG_BEQ_DESA                    0x0330
-       /*  TX BK Queue Descriptor Address */
-#define        REG_BKQ_DESA                    0x0338
-       /*  RX Queue    Descriptor Address */
-#define        REG_RX_DESA                     0x0340
-       /*  Backdoor REG for Access Configuration */
-#define        REG_DBI                         0x0348
-       /*  MDIO for Access PCIE PHY */
-#define        REG_MDIO                        0x0354
-       /*  Debug Selection Register */
-#define        REG_DBG_SEL                     0x0360
-       /* PCIe RPWM */
-#define        REG_PCIE_HRPWM                  0x0361
-       /* PCIe CPWM */
-#define        REG_PCIE_HCPWM                  0x0363
-       /*  UART        Control */
-#define        REG_UART_CTRL                   0x0364
-       /*  UART TX Descriptor Address */
-#define        REG_UART_TX_DESA                0x0370
-       /*  UART Rx Descriptor Address */
-#define        REG_UART_RX_DESA                0x0378
-
-
-/*  spec version 11 */
-/*  */
-/*  */
-/*     0x0400h ~ 0x047Fh       Protocol Configuration */
-/*  */
-/*  */
-#define REG_VOQ_INFORMATION            0x0400
-#define REG_VIQ_INFORMATION            0x0404
-#define REG_BEQ_INFORMATION            0x0408
-#define REG_BKQ_INFORMATION            0x040C
-#define REG_MGQ_INFORMATION            0x0410
-#define REG_HGQ_INFORMATION            0x0414
-#define REG_BCNQ_INFORMATION           0x0418
-
-
-#define REG_CPU_MGQ_INFORMATION                0x041C
-#define REG_FWHW_TXQ_CTRL              0x0420
-#define REG_HWSEQ_CTRL                 0x0423
-#define REG_TXPKTBUF_BCNQ_BDNY         0x0424
-#define REG_TXPKTBUF_MGQ_BDNY          0x0425
-#define REG_LIFETIME_EN                        0x0426
-#define REG_MULTI_BCNQ_OFFSET          0x0427
-#define REG_SPEC_SIFS                  0x0428
-#define REG_RL                         0x042A
-#define REG_DARFRC                     0x0430
-#define REG_RARFRC                     0x0438
-#define REG_RRSR                       0x0440
-#define REG_ARFR0                      0x0444
-#define REG_ARFR1                      0x0448
-#define REG_ARFR2                      0x044C
-#define REG_ARFR3                      0x0450
-#define REG_AGGLEN_LMT                 0x0458
-#define REG_AMPDU_MIN_SPACE            0x045C
-#define REG_TXPKTBUF_WMAC_LBK_BF_HD    0x045D
-#define REG_FAST_EDCA_CTRL             0x0460
-#define REG_RD_RESP_PKT_TH             0x0463
-#define REG_INIRTS_RATE_SEL            0x0480
-#define REG_INIDATA_RATE_SEL           0x0484
-
-
-#define REG_POWER_STATUS               0x04A4
-#define REG_POWER_STAGE1               0x04B4
-#define REG_POWER_STAGE2               0x04B8
-#define REG_PKT_VO_VI_LIFE_TIME                0x04C0
-#define REG_PKT_BE_BK_LIFE_TIME                0x04C2
-#define REG_STBC_SETTING               0x04C4
-#define REG_PROT_MODE_CTRL             0x04C8
-#define REG_MAX_AGGR_NUM               0x04CA
-#define REG_RTS_MAX_AGGR_NUM           0x04CB
-#define REG_BAR_MODE_CTRL              0x04CC
-#define REG_RA_TRY_RATE_AGG_LMT                0x04CF
-#define REG_NQOS_SEQ                   0x04DC
-#define REG_QOS_SEQ                    0x04DE
-#define REG_NEED_CPU_HANDLE            0x04E0
-#define REG_PKT_LOSE_RPT               0x04E1
-#define REG_PTCL_ERR_STATUS            0x04E2
-#define REG_DUMMY                      0x04FC
-
-
-
-/*  */
-/*  */
-/*     0x0500h ~ 0x05FFh       EDCA Configuration */
-/*  */
-/*  */
-#define REG_EDCA_VO_PARAM              0x0500
-#define REG_EDCA_VI_PARAM              0x0504
-#define REG_EDCA_BE_PARAM              0x0508
-#define REG_EDCA_BK_PARAM              0x050C
-#define REG_BCNTCFG                    0x0510
-#define REG_PIFS                       0x0512
-#define REG_RDG_PIFS                   0x0513
-#define REG_SIFS_CCK                   0x0514
-#define REG_SIFS_OFDM                  0x0516
-#define REG_SIFS_CTX                   0x0514
-#define REG_SIFS_TRX                   0x0516
-#define REG_TSFTR_SYN_OFFSET           0x0518
-#define REG_AGGR_BREAK_TIME            0x051A
-#define REG_SLOT                       0x051B
-#define REG_TX_PTCL_CTRL               0x0520
-#define REG_TXPAUSE                    0x0522
-#define REG_DIS_TXREQ_CLR              0x0523
-#define REG_RD_CTRL                    0x0524
-#define REG_TBTT_PROHIBIT              0x0540
-#define REG_RD_NAV_NXT                 0x0544
-#define REG_NAV_PROT_LEN               0x0546
-#define REG_BCN_CTRL                   0x0550
-#define REG_BCN_CTRL_1                 0x0551
-#define REG_MBID_NUM                   0x0552
-#define REG_DUAL_TSF_RST               0x0553
-       /*  The same as REG_MBSSID_BCN_SPACE */
-#define REG_BCN_INTERVAL               0x0554
-#define REG_MBSSID_BCN_SPACE           0x0554
-#define REG_DRVERLYINT                 0x0558
-#define REG_BCNDMATIM                  0x0559
-#define REG_ATIMWND                    0x055A
-#define REG_BCN_MAX_ERR                        0x055D
-#define REG_RXTSF_OFFSET_CCK           0x055E
-#define REG_RXTSF_OFFSET_OFDM          0x055F
-#define REG_TSFTR                      0x0560
-#define REG_TSFTR1                     0x0568
-#define REG_INIT_TSFTR                 0x0564
-#define REG_ATIMWND_1                  0x0570
-#define REG_PSTIMER                    0x0580
-#define REG_TIMER0                     0x0584
-#define REG_TIMER1                     0x0588
-#define REG_ACMHWCTRL                  0x05C0
-#define REG_ACMRSTCTRL                 0x05C1
-#define REG_ACMAVG                     0x05C2
-#define REG_VO_ADMTIME                 0x05C4
-#define REG_VI_ADMTIME                 0x05C6
-#define REG_BE_ADMTIME                 0x05C8
-#define REG_EDCA_RANDOM_GEN            0x05CC
-#define REG_SCH_TXCMD                  0x05D0
-
-/* define REG_FW_TSF_SYNC_CNT          0x04A0 */
-#define REG_FW_RESET_TSF_CNT_1         0x05FC
-#define REG_FW_RESET_TSF_CNT_0         0x05FD
-#define REG_FW_BCN_DIS_CNT             0x05FE
-
-/*  */
-/*  */
-/*     0x0600h ~ 0x07FFh       WMAC Configuration */
-/*  */
-/*  */
-#define REG_APSD_CTRL                  0x0600
-#define REG_BWOPMODE                   0x0603
-#define REG_TCR                                0x0604
-#define REG_RCR                                0x0608
-#define REG_RX_PKT_LIMIT               0x060C
-#define REG_RX_DLK_TIME                        0x060D
-#define REG_RX_DRVINFO_SZ              0x060F
-
-#define REG_MACID                      0x0610
-#define REG_BSSID                      0x0618
-#define REG_MAR                                0x0620
-#define REG_MBIDCAMCFG                 0x0628
-
-#define REG_USTIME_EDCA                        0x0638
-#define REG_MAC_SPEC_SIFS              0x063A
-
-/*  20100719 Joseph: Hardware register definition change. (HW datasheet v54) */
-       /*  [15:8]SIFS_R2T_OFDM, [7:0]SIFS_R2T_CCK */
-#define REG_R2T_SIFS                   0x063C
-       /*  [15:8]SIFS_T2T_OFDM, [7:0]SIFS_T2T_CCK */
-#define REG_T2T_SIFS                   0x063E
-#define REG_ACKTO                      0x0640
-#define REG_CTS2TO                     0x0641
-#define REG_EIFS                       0x0642
-
-/* WMA, BA, CCX */
-#define REG_NAV_CTRL                   0x0650
-#define REG_BACAMCMD                   0x0654
-#define REG_BACAMCONTENT               0x0658
-#define REG_LBDLY                      0x0660
-#define REG_FWDLY                      0x0661
-#define REG_RXERR_RPT                  0x0664
-#define REG_WMAC_TRXPTCL_CTL           0x0668
-
-
-/*  Security */
-#define REG_CAMCMD                     0x0670
-#define REG_CAMWRITE                   0x0674
-#define REG_CAMREAD                    0x0678
-#define REG_CAMDBG                     0x067C
-#define REG_SECCFG                     0x0680
-
-/*  Power */
-#define REG_WOW_CTRL                   0x0690
-#define REG_PSSTATUS                   0x0691
-#define REG_PS_RX_INFO                 0x0692
-#define REG_LPNAV_CTRL                 0x0694
-#define REG_WKFMCAM_CMD                        0x0698
-#define REG_WKFMCAM_RWD                        0x069C
-#define REG_RXFLTMAP0                  0x06A0
-#define REG_RXFLTMAP1                  0x06A2
-#define REG_RXFLTMAP2                  0x06A4
-#define REG_BCN_PSR_RPT                        0x06A8
-#define REG_CALB32K_CTRL               0x06AC
-#define REG_PKT_MON_CTRL               0x06B4
-#define REG_BT_COEX_TABLE              0x06C0
-#define REG_WMAC_RESP_TXINFO           0x06D8
-
-#define REG_MACID1                     0x0700
-#define REG_BSSID1                     0x0708
-
-
-/*  */
-/*  */
-/*     0xFE00h ~ 0xFE55h       USB Configuration */
-/*  */
-/*  */
-#define REG_USB_INFO                   0xFE17
-#define REG_USB_SPECIAL_OPTION         0xFE55
-#define REG_USB_DMA_AGG_TO             0xFE5B
-#define REG_USB_AGG_TO                 0xFE5C
-#define REG_USB_AGG_TH                 0xFE5D
-
-/*  For test chip */
-#define REG_TEST_USB_TXQS              0xFE48
-#define REG_TEST_SIE_VID               0xFE60          /*  0xFE60~0xFE61 */
-#define REG_TEST_SIE_PID               0xFE62          /*  0xFE62~0xFE63 */
-#define REG_TEST_SIE_OPTIONAL          0xFE64
-#define REG_TEST_SIE_CHIRP_K           0xFE65
-#define REG_TEST_SIE_PHY               0xFE66          /*  0xFE66~0xFE6B */
-#define REG_TEST_SIE_MAC_ADDR          0xFE70          /*  0xFE70~0xFE75 */
-#define REG_TEST_SIE_STRING            0xFE80          /*  0xFE80~0xFEB9 */
-
-
-/*  For normal chip */
-#define REG_NORMAL_SIE_VID             0xFE60          /*  0xFE60~0xFE61 */
-#define REG_NORMAL_SIE_PID             0xFE62          /*  0xFE62~0xFE63 */
-#define REG_NORMAL_SIE_OPTIONAL                0xFE64
-#define REG_NORMAL_SIE_EP              0xFE65          /*  0xFE65~0xFE67 */
-#define REG_NORMAL_SIE_PHY             0xFE68          /*  0xFE68~0xFE6B */
-#define REG_NORMAL_SIE_OPTIONAL2       0xFE6C
-#define REG_NORMAL_SIE_GPS_EP          0xFE6D          /*  RTL8723 only */
-#define REG_NORMAL_SIE_MAC_ADDR                0xFE70          /*  0xFE70~0xFE75 */
-#define REG_NORMAL_SIE_STRING          0xFE80          /*  0xFE80~0xFEDF */
-
-
-/*  */
-/*  */
-/*     Redifine 8192C register definition for compatibility */
-/*  */
-/*  */
-
-/*  TODO: use these definition when using REG_xxx naming rule. */
-/*  NOTE: DO NOT Remove these definition. Use later. */
-
-       /*  System Isolation Interface Control. */
-#define        SYS_ISO_CTRL                    REG_SYS_ISO_CTRL
-       /*  System Function Enable. */
-#define        SYS_FUNC_EN                     REG_SYS_FUNC_EN
-#define        SYS_CLK                         REG_SYS_CLKR
-       /*  93C46/93C56 Command Register. */
-#define        CR9346                          REG_9346CR
-       /*  E-Fuse Control. */
-#define        EFUSE_CTRL                      REG_EFUSE_CTRL
-       /*  E-Fuse Test. */
-#define        EFUSE_TEST                      REG_EFUSE_TEST
-       /*  Media Status register */
-#define        MSR                             (REG_CR + 2)
-#define        ISR                             REG_HISR
-       /*  Timing Sync Function Timer Register. */
-#define        TSFR                            REG_TSFTR
-
-       /*  MAC ID Register, Offset 0x0050-0x0053 */
-#define        MACIDR0                         REG_MACID
-       /*  MAC ID Register, Offset 0x0054-0x0055 */
-#define        MACIDR4                         (REG_MACID + 4)
-
-#define        PBP                             REG_PBP
-
-       /*  Redifine MACID register, to compatible prior ICs. */
-#define        IDR0                            MACIDR0
-#define        IDR4                            MACIDR4
-
-
-/*  */
-/*  9. Security Control Registers      (Offset: ) */
-/*  */
-       /*  Software write CAM input content */
-#define        WCAMI                           REG_CAMWRITE
-       /*  Software read/write CAM config */
-#define        RCAMO                           REG_CAMREAD
-#define        CAMDBG                          REG_CAMDBG
-       /* Security Configuration Register */
-#define        SECR                            REG_SECCFG
-
-/*  Unused register */
-#define        UnusedRegister                  0x1BF
-#define        DCAM                            UnusedRegister
-#define        PSR                             UnusedRegister
-#define        BBAddr                          UnusedRegister
-#define        PhyDataR                        UnusedRegister
-
-#define        InvalidBBRFValue                0x12345678
-
-/*  Min Spacing related settings. */
-#define        MAX_MSS_DENSITY_2T              0x13
-#define        MAX_MSS_DENSITY_1T              0x0A
-
-/*  */
-/* 8192C Cmd9346CR bits                        (Offset 0xA, 16bit) */
-/*  */
-        /*  EEPROM enable when set 1 */
-#define        CmdEEPROM_En                    BIT(5)
-       /*  System EEPROM select, 0: boot from E-FUSE,
-           1: The EEPROM used is 9346 */
-#define        CmdEERPOMSEL                    BIT(4)
-#define        Cmd9346CR_9356SEL               BIT(4)
-#define        AutoLoadEEPROM                  (CmdEEPROM_En|CmdEERPOMSEL)
-#define        AutoLoadEFUSE                   CmdEEPROM_En
-
-/*  */
-/* 8192C GPIO MUX Configuration Register (offset 0x40, 4 byte) */
-/*  */
-#define        GPIOSEL_GPIO                    0
-#define        GPIOSEL_ENBT                    BIT(5)
-
-/*  */
-/*        8192C GPIO PIN Control Register (offset 0x44, 4 byte) */
-/*  */
-       /*  GPIO pins input value */
-#define        GPIO_IN                         REG_GPIO_PIN_CTRL
-       /*  GPIO pins output value */
-#define        GPIO_OUT                        (REG_GPIO_PIN_CTRL+1)
-       /*  GPIO pins output enable when a bit is set to "1";
-           otherwise, input is configured. */
-#define        GPIO_IO_SEL                     (REG_GPIO_PIN_CTRL+2)
-#define        GPIO_MOD                        (REG_GPIO_PIN_CTRL+3)
-
-/*  */
-/* 8192C (MSR) Media Status Register   (Offset 0x4C, 8 bits) */
-/*  */
-/*
-Network Type
-00: No link
-01: Link in ad hoc network
-10: Link in infrastructure network
-11: AP mode
-Default: 00b.
-*/
-#define        MSR_NOLINK                      0x00
-#define        MSR_ADHOC                       0x01
-#define        MSR_INFRA                       0x02
-#define        MSR_AP                          0x03
-
-/*  */
-/*  6. Adaptive Control Registers  (Offset: 0x0160 - 0x01CF) */
-/*  */
-/*  */
-/* 8192C Response Rate Set Register    (offset 0x181, 24bits) */
-/*  */
-#define        RRSR_RSC_OFFSET                 21
-#define        RRSR_SHORT_OFFSET               23
-#define        RRSR_RSC_BW_40M                 0x600000
-#define        RRSR_RSC_UPSUBCHNL              0x400000
-#define        RRSR_RSC_LOWSUBCHNL             0x200000
-#define        RRSR_SHORT                      0x800000
-#define        RRSR_1M                         BIT(0)
-#define        RRSR_2M                         BIT(1)
-#define        RRSR_5_5M                       BIT(2)
-#define        RRSR_11M                        BIT(3)
-#define        RRSR_6M                         BIT(4)
-#define        RRSR_9M                         BIT(5)
-#define        RRSR_12M                        BIT(6)
-#define        RRSR_18M                        BIT(7)
-#define        RRSR_24M                        BIT(8)
-#define        RRSR_36M                        BIT(9)
-#define        RRSR_48M                        BIT(10)
-#define        RRSR_54M                        BIT(11)
-#define        RRSR_MCS0                       BIT(12)
-#define        RRSR_MCS1                       BIT(13)
-#define        RRSR_MCS2                       BIT(14)
-#define        RRSR_MCS3                       BIT(15)
-#define        RRSR_MCS4                       BIT(16)
-#define        RRSR_MCS5                       BIT(17)
-#define        RRSR_MCS6                       BIT(18)
-#define        RRSR_MCS7                       BIT(19)
-#define        BRSR_AckShortPmb                BIT(23)
-/*  CCK ACK: use Short Preamble or not */
-
-/*  */
-/* 8192C BW_OPMODE bits                        (Offset 0x203, 8bit) */
-/*  */
-#define        BW_OPMODE_20MHZ                 BIT(2)
-#define        BW_OPMODE_5G                    BIT(1)
-#define        BW_OPMODE_11J                   BIT(0)
-
-
-/*  */
-/* 8192C CAM Config Setting (offset 0x250, 1 byte) */
-/*  */
-#define        CAM_VALID                       BIT(15)
-#define        CAM_NOTVALID                    0x0000
-#define        CAM_USEDK                       BIT(5)
-
-#define        CAM_CONTENT_COUNT               8
-
-#define        CAM_NONE                        0x0
-#define        CAM_WEP40                       0x01
-#define        CAM_TKIP                        0x02
-#define        CAM_AES                         0x04
-#define        CAM_WEP104                      0x05
-
-#define        TOTAL_CAM_ENTRY                 32
-#define        HALF_CAM_ENTRY                  16
-
-#define        CAM_CONFIG_USEDK                true
-#define        CAM_CONFIG_NO_USEDK             false
-
-#define        CAM_WRITE                       BIT(16)
-#define        CAM_READ                        0x00000000
-#define        CAM_POLLINIG                    BIT(31)
-
-#define        SCR_UseDK                       0x01
-#define        SCR_TxSecEnable                 0x02
-#define        SCR_RxSecEnable                 0x04
-
-
-/*  */
-/*  12. Host Interrupt Status Registers         (Offset: 0x0300 - 0x030F) */
-/*  */
-/*  */
-/* 8190 IMR/ISR bits                   (offset 0xfd,  8bits) */
-/*  */
-#define        IMR8190_DISABLED                0x0
-/*  IMR DW0 Bit 0-31 */
-
-#define        IMR_BCNDMAINT6                  BIT(31) /*  Beacon DMA Interrupt 6 */
-#define        IMR_BCNDMAINT5                  BIT(30) /*  Beacon DMA Interrupt 5 */
-#define        IMR_BCNDMAINT4                  BIT(29) /*  Beacon DMA Interrupt 4 */
-#define        IMR_BCNDMAINT3                  BIT(28) /*  Beacon DMA Interrupt 3 */
-#define        IMR_BCNDMAINT2                  BIT(27) /*  Beacon DMA Interrupt 2 */
-#define        IMR_BCNDMAINT1                  BIT(26) /*  Beacon DMA Interrupt 1 */
-#define        IMR_BCNDOK8                     BIT(25) /*  Beacon Queue DMA OK
-                                                   Interrupt 8 */
-#define        IMR_BCNDOK7                     BIT(24) /*  Beacon Queue DMA OK
-                                                   Interrupt 7 */
-#define        IMR_BCNDOK6                     BIT(23) /*  Beacon Queue DMA OK
-                                                   Interrupt 6 */
-#define        IMR_BCNDOK5                     BIT(22) /*  Beacon Queue DMA OK
-                                                   Interrupt 5 */
-#define        IMR_BCNDOK4                     BIT(21) /*  Beacon Queue DMA OK
-                                                   Interrupt 4 */
-#define        IMR_BCNDOK3                     BIT(20) /*  Beacon Queue DMA OK
-                                                   Interrupt 3 */
-#define        IMR_BCNDOK2                     BIT(19) /*  Beacon Queue DMA OK
-                                                   Interrupt 2 */
-#define        IMR_BCNDOK1                     BIT(18) /*  Beacon Queue DMA OK
-                                                   Interrupt 1 */
-#define        IMR_TIMEOUT2                    BIT(17) /*  Timeout interrupt 2 */
-#define        IMR_TIMEOUT1                    BIT(16) /*  Timeout interrupt 1 */
-#define        IMR_TXFOVW                      BIT(15) /*  Transmit FIFO Overflow */
-#define        IMR_PSTIMEOUT                   BIT(14) /*  Power save time out
-                                                   interrupt */
-#define        IMR_BcnInt                      BIT(13) /*  Beacon DMA Interrupt 0 */
-#define        IMR_RXFOVW                      BIT(12) /*  Receive FIFO Overflow */
-#define        IMR_RDU                         BIT(11) /*  Receive Descriptor
-                                                   Unavailable */
-#define        IMR_ATIMEND                     BIT(10) /*  For 92C,ATIM Window
-                                                   End Interrupt */
-#define        IMR_BDOK                        BIT(9)  /*  Beacon Queue DMA OK
-                                                   Interrup */
-#define        IMR_HIGHDOK                     BIT(8)  /*  High Queue DMA OK
-                                                   Interrupt */
-#define        IMR_TBDOK                       BIT(7)  /*  Transmit Beacon OK
-                                                   interrup */
-#define        IMR_MGNTDOK                     BIT(6)  /*  Management Queue DMA OK
-                                                   Interrupt */
-#define        IMR_TBDER                       BIT(5)  /*  For 92C,Transmit Beacon
-                                                   Error Interrupt */
-#define        IMR_BKDOK                       BIT(4)  /*  AC_BK DMA OK Interrupt */
-#define        IMR_BEDOK                       BIT(3)  /*  AC_BE DMA OK Interrupt */
-#define        IMR_VIDOK                       BIT(2)  /*  AC_VI DMA OK Interrupt */
-#define        IMR_VODOK                       BIT(1)  /*  AC_VO DMA Interrupt */
-#define        IMR_ROK                         BIT(0)  /*  Receive DMA OK Interrupt */
-
-#define        IMR_RX_MASK                     (IMR_ROK|IMR_RDU|IMR_RXFOVW)
-#define        IMR_TX_MASK                     (IMR_VODOK|IMR_VIDOK|IMR_BEDOK| \
-                                        IMR_BKDOK|IMR_MGNTDOK|IMR_HIGHDOK| \
-                                        IMR_BDOK)
-
-/*  13. Host Interrupt Status Extension Register (Offset: 0x012C-012Eh) */
-#define        IMR_BcnInt_E                    BIT(12)
-#define        IMR_TXERR                       BIT(11)
-#define        IMR_RXERR                       BIT(10)
-#define        IMR_C2HCMD                      BIT(9)
-#define        IMR_CPWM                        BIT(8)
-/* RSVD [2-7] */
-#define        IMR_OCPINT                      BIT(1)
-#define        IMR_WLANOFF                     BIT(0)
-
-
-/*        8192C EEPROM/EFUSE share register definition. */
-
-/*  Default Value for EEPROM or EFUSE!!! */
-#define EEPROM_Default_TSSI                    0x0
-#define EEPROM_Default_TxPowerDiff             0x0
-#define EEPROM_Default_CrystalCap              0x5
- /*  Default: 2X2, RTL8192CE(QFPN68) */
-#define EEPROM_Default_BoardType               0x02
-#define EEPROM_Default_TxPower                 0x1010
-#define EEPROM_Default_HT2T_TxPwr              0x10
-
-#define EEPROM_Default_LegacyHTTxPowerDiff     0x3
-#define EEPROM_Default_ThermalMeter            0x12
-
-#define EEPROM_Default_AntTxPowerDiff          0x0
-#define EEPROM_Default_TxPwDiff_CrystalCap     0x5
-#define EEPROM_Default_TxPowerLevel            0x22
-#define EEPROM_Default_HT40_2SDiff             0x0
-       /*  HT20<->40 default Tx Power Index Difference */
-#define EEPROM_Default_HT20_Diff               2
-#define EEPROM_Default_LegacyHTTxPowerDiff     0x3
-#define EEPROM_Default_HT40_PwrMaxOffset       0
-#define EEPROM_Default_HT20_PwrMaxOffset       0
-
-/*  For debug */
-#define EEPROM_Default_PID                     0x1234
-#define EEPROM_Default_VID                     0x5678
-#define EEPROM_Default_CustomerID              0xAB
-#define EEPROM_Default_SubCustomerID           0xCD
-#define EEPROM_Default_Version                 0
-
-#define EEPROM_CHANNEL_PLAN_FCC                        0x0
-#define EEPROM_CHANNEL_PLAN_IC                 0x1
-#define EEPROM_CHANNEL_PLAN_ETSI               0x2
-#define EEPROM_CHANNEL_PLAN_SPAIN              0x3
-#define EEPROM_CHANNEL_PLAN_FRANCE             0x4
-#define EEPROM_CHANNEL_PLAN_MKK                        0x5
-#define EEPROM_CHANNEL_PLAN_MKK1               0x6
-#define EEPROM_CHANNEL_PLAN_ISRAEL             0x7
-#define EEPROM_CHANNEL_PLAN_TELEC              0x8
-#define EEPROM_CHANNEL_PLAN_GLOBAL_DOMAIN      0x9
-#define EEPROM_CHANNEL_PLAN_WORLD_WIDE_13      0xA
-#define EEPROM_CHANNEL_PLAN_NCC                        0xB
-#define EEPROM_USB_OPTIONAL1                   0xE
-#define EEPROM_CHANNEL_PLAN_BY_HW_MASK         0x80
-
-
-#define EEPROM_CID_DEFAULT                     0x0
-#define EEPROM_CID_TOSHIBA                     0x4
- /*  CCX test. By Bruce, 2009-02-25. */
-#define EEPROM_CID_CCX                         0x10
-#define EEPROM_CID_QMI                         0x0D
- /*  added by chiyoko for dtm, 20090108 */
-#define EEPROM_CID_WHQL                                0xFE
-
-
-#define        RTL_EEPROM_ID                           0x8129
-
-#define        SUPPORT_HW_RADIO_DETECT(pHalData)               \
-       (pHalData->BoardType == BOARD_MINICARD ||       \
-       pHalData->BoardType == BOARD_USB_SOLO ||        \
-       pHalData->BoardType == BOARD_USB_COMBO)
-
-/*  */
-/*  EEPROM address for Test chip */
-/*  */
-#define EEPROM_TEST_USB_OPT            0x0E
-#define EEPROM_TEST_CHIRP_K            0x0F
-#define EEPROM_TEST_EP_SETTING         0x0E
-#define EEPROM_TEST_USB_PHY            0x10
-
-
-/*  */
-/*  EEPROM address for Normal chip */
-/*  */
-#define EEPROM_NORMAL_USB_OPT          0x0E
-#define EEPROM_NORMAL_CHIRP_K          0x0E    /*  Changed */
-#define EEPROM_NORMAL_EP_SETTING       0x0F    /*  Changed */
-#define EEPROM_NORMAL_USB_PHY          0x12    /*  Changed */
-
-enum {
-       BOARD_USB_DONGLE = 0,   /*  USB dongle */
-       BOARD_USB_High_PA = 1,  /*  USB dongle with high power PA */
-       BOARD_MINICARD = 2,     /*  Minicard */
-       BOARD_USB_SOLO = 3,     /*  USB solo-Slim module */
-       BOARD_USB_COMBO = 4,    /*  USB Combo-Slim module */
-};
-
-/*  Test chip and normal chip common define */
-/*  */
-/*  EEPROM address for both */
-/*  */
-#define EEPROM_ID0                     0x00
-#define EEPROM_ID1                     0x01
-#define EEPROM_RTK_RSV1                        0x02
-#define EEPROM_RTK_RSV2                        0x03
-#define EEPROM_RTK_RSV3                        0x04
-#define EEPROM_RTK_RSV4                        0x05
-#define EEPROM_RTK_RSV5                        0x06
-#define EEPROM_DBG_SEL                 0x07
-#define EEPROM_RTK_RSV6                        0x08
-#define EEPROM_VID                     0x0A
-#define EEPROM_PID                     0x0C
-
-#define EEPROM_MAC_ADDR                        0x16
-#define EEPROM_STRING                  0x1C
-#define EEPROM_SUBCUSTOMER_ID          0x59
-#define EEPROM_CCK_TX_PWR_INX          0x5A
-#define EEPROM_HT40_1S_TX_PWR_INX      0x60
-#define EEPROM_HT40_2S_TX_PWR_INX_DIFF 0x66
-#define EEPROM_HT20_TX_PWR_INX_DIFF    0x69
-#define EEPROM_OFDM_TX_PWR_INX_DIFF    0x6C
-#define EEPROM_HT40_MAX_PWR_OFFSET     0x6F
-#define EEPROM_HT20_MAX_PWR_OFFSET     0x72
-
-#define EEPROM_CHANNEL_PLAN            0x75
-#define EEPROM_TSSI_A                  0x76
-#define EEPROM_TSSI_B                  0x77
-#define EEPROM_THERMAL_METER           0x78
-#define EEPROM_RF_OPT1                 0x79
-#define EEPROM_RF_OPT2                 0x7A
-#define EEPROM_RF_OPT3                 0x7B
-#define EEPROM_RF_OPT4                 0x7C
-#define EEPROM_VERSION                 0x7E
-#define EEPROM_CUSTOMER_ID             0x7F
-
-        /* 0x0: RTL8188SU, 0x1: RTL8191SU, 0x2: RTL8192SU, 0x3: RTL8191GU */
-#define EEPROM_BoardType               0x54
-       /* 0x5C-0x76, Tx Power index. */
-#define EEPROM_TxPwIndex               0x5C
-       /*  Difference of gain index between legacy and high throughput OFDM. */
-#define EEPROM_PwDiff                  0x67
-       /*  CCK Tx Power */
-#define EEPROM_TxPowerCCK              0x5A
-
-/*  2009/02/09 Cosa Add for SD3 requirement */
-       /*  HT20 Tx Power Index Difference */
-#define EEPROM_TX_PWR_HT20_DIFF                0x6e
-       /*  HT20<->40 default Tx Power Index Difference */
-#define DEFAULT_HT20_TXPWR_DIFF                2
-       /*  OFDM Tx Power Index Difference */
-#define EEPROM_TX_PWR_OFDM_DIFF                0x71
-
-       /*  Power diff for channel group */
-#define EEPROM_TxPWRGroup              0x73
-       /*  Check if power safety is need */
-#define EEPROM_Regulatory              0x79
-
-       /*  92cu, 0x7E[4] */
-#define EEPROM_BLUETOOTH_COEXIST       0x7E
-#define EEPROM_NORMAL_BoardType                EEPROM_RF_OPT1  /* 7:5] */
-#define BOARD_TYPE_NORMAL_MASK         0xE0
-#define BOARD_TYPE_TEST_MASK           0x0F
-       /* BIT0 1 for build-in module, 0 for external dongle */
-#define EEPROM_EASY_REPLACEMENT                0x50
-/*  */
-/* EPROM content definitions */
-/*  */
-#define OS_LINK_SPEED                  BIT(5)
-
-#define BOARD_TYPE_MASK                        0xF
-
-#define BT_COEXISTENCE                 BIT(4)
-#define BT_CO_SHIFT                    4
-
-#define EP_NUMBER_MASK                 0x30    /* bit 4:5 0Eh */
-#define EP_NUMBER_SHIFT                        4
-
-
-#define USB_PHY_PARA_SIZE              5
-
-
-/*  */
-/*     \14EEPROM default value definitions */
-/*  */
-/*  Use 0xABCD instead of 0x8192 for debug */
-#define EEPROM_DEF_ID_0                        0xCD    /*  Byte 0x00 */
-#define EEPROM_DEF_ID_1                        0xAB    /*  Byte 0x01 */
-
-#define EEPROM_DEF_RTK_RSV_A3          0x74    /*  Byte 0x03 */
-#define EEPROM_DEF_RTK_RSV_A4          0x6D    /*  Byte 0x04 */
-#define EEPROM_DEF_RTK_RSV_A8          0xFF    /*  Byte 0x08 */
-
-#define EEPROM_DEF_VID_0               0x0A    /*  Byte 0x0A */
-#define EEPROM_DEF_VID_1               0x0B
-
-#define EEPROM_DEF_PID_0               0x92    /*  Byte 0x0C */
-#define EEPROM_DEF_PID_1               0x81
-
-
-#define EEPROM_TEST_DEF_USB_OPT                0x80    /*  Byte 0x0E */
-#define EEPROM_NORMAL_DEF_USB_OPT      0x00    /*  Byte 0x0E */
-
-#define EEPROM_DEF_CHIRPK              0x15    /*  Byte 0x0F */
-
-#define EEPROM_DEF_USB_PHY_0           0x85    /*  Byte 0x10 */
-#define EEPROM_DEF_USB_PHY_1           0x62    /*  Byte 0x11 */
-#define EEPROM_DEF_USB_PHY_2           0x9E    /*  Byte 0x12 */
-#define EEPROM_DEF_USB_PHY_3           0x06    /*  Byte 0x13 */
-
-#define EEPROM_DEF_TSSI_A              0x09    /*  Byte 0x78 */
-#define EEPROM_DEF_TSSI_B              0x09    /*  Byte 0x79 */
-
-
-#define EEPROM_DEF_THERMAL_METER       0x12    /*  Byte 0x7A */
-
-       /*  Check if power safety spec is need */
-#define RF_OPTION1                     0x79
-#define RF_OPTION2                     0x7A
-#define RF_OPTION3                     0x7B
-#define RF_OPTION4                     0x7C
-
-
-#define        EEPROM_USB_SN                   BIT(0)
-#define        EEPROM_USB_REMOTE_WAKEUP        BIT(1)
-#define        EEPROM_USB_DEVICE_PWR           BIT(2)
-#define        EEPROM_EP_NUMBER                (BIT(3)|BIT(4))
-
-/*===================================================================
-=====================================================================
-Here the register defines are for 92C. When the define is as same with 92C,
-we will use the 92C's define for the consistency
-So the following defines for 92C is not entire!!!!!!
-=====================================================================
-=====================================================================*/
-/*
-Based on Datasheet V33---090401
-Register Summary
-Current IOREG MAP
-0x0000h ~ 0x00FFh   System Configuration (256 Bytes)
-0x0100h ~ 0x01FFh   MACTOP General Configuration (256 Bytes)
-0x0200h ~ 0x027Fh   TXDMA Configuration (128 Bytes)
-0x0280h ~ 0x02FFh   RXDMA Configuration (128 Bytes)
-0x0300h ~ 0x03FFh   PCIE EMAC Reserved Region (256 Bytes)
-0x0400h ~ 0x04FFh   Protocol Configuration (256 Bytes)
-0x0500h ~ 0x05FFh   EDCA Configuration (256 Bytes)
-0x0600h ~ 0x07FFh   WMAC Configuration (512 Bytes)
-0x2000h ~ 0x3FFFh   8051 FW Download Region (8196 Bytes)
-*/
-
-/*  */
-/* 8192C (RCR) Receive Configuration Register  (Offset 0x608, 32 bits) */
-/*  */
-#define        RCR_APPFCS                      BIT(31) /* WMAC append FCS after payload*/
-#define        RCR_APP_MIC                     BIT(30)
-#define        RCR_APP_PHYSTS                  BIT(28)
-#define        RCR_APP_ICV                     BIT(29)
-#define        RCR_APP_PHYST_RXFF              BIT(28)
-#define        RCR_APP_BA_SSN                  BIT(27) /* Accept BA SSN */
-#define        RCR_ENMBID                      BIT(24) /* Enable Multiple BssId. */
-#define        RCR_LSIGEN                      BIT(23)
-#define        RCR_MFBEN                       BIT(22)
-#define        RCR_HTC_LOC_CTRL                BIT(14) /* MFC<--HTC=1 MFC-->HTC=0 */
-#define        RCR_AMF                         BIT(13) /* Accept management type frame */
-#define        RCR_ACF                         BIT(12) /* Accept control type frame */
-#define        RCR_ADF                         BIT(11) /* Accept data type frame */
-#define        RCR_AICV                        BIT(9)  /* Accept ICV error packet */
-#define        RCR_ACRC32                      BIT(8)  /* Accept CRC32 error packet */
-#define        RCR_CBSSID_BCN                  BIT(7)  /* Accept BSSID match packet
-                                                (Rx beacon, probe rsp) */
-#define        RCR_CBSSID_DATA                 BIT(6)  /* Accept BSSID match packet
-                                                (Data) */
-#define        RCR_CBSSID                      RCR_CBSSID_DATA /* Accept BSSID match
-                                                          packet */
-#define        RCR_APWRMGT                     BIT(5)  /* Accept power management
-                                                packet */
-#define        RCR_ADD3                        BIT(4)  /* Accept address 3 match
-                                                packet */
-#define        RCR_AB                          BIT(3)  /* Accept broadcast packet */
-#define        RCR_AM                          BIT(2)  /* Accept multicast packet */
-#define        RCR_APM                         BIT(1)  /* Accept physical match packet */
-#define        RCR_AAP                         BIT(0)  /* Accept all unicast packet */
-#define        RCR_MXDMA_OFFSET                8
-#define        RCR_FIFO_OFFSET                 13
-
-
-
-/*  */
-/* 8192c USB specific Regsiter Offset and Content definition, */
-/* 2009.08.18, added by vivi. for merge 92c and 92C into one driver */
-/*  */
-/* define APS_FSMCO                    0x0004  same with 92Ce */
-#define RSV_CTRL                       0x001C
-#define RD_CTRL                                0x0524
-
-/*  */
-/*  */
-/*     0xFE00h ~ 0xFE55h       USB Configuration */
-/*  */
-/*  */
-#define REG_USB_INFO                   0xFE17
-#define REG_USB_SPECIAL_OPTION         0xFE55
-#define REG_USB_DMA_AGG_TO             0xFE5B
-#define REG_USB_AGG_TO                 0xFE5C
-#define REG_USB_AGG_TH                 0xFE5D
-
-#define REG_USB_VID                    0xFE60
-#define REG_USB_PID                    0xFE62
-#define REG_USB_OPTIONAL               0xFE64
-#define REG_USB_CHIRP_K                        0xFE65
-#define REG_USB_PHY                    0xFE66
-#define REG_USB_MAC_ADDR               0xFE70
-
-#define REG_USB_HRPWM                  0xFE58
-#define REG_USB_HCPWM                  0xFE57
-
-#define        InvalidBBRFValue                0x12345678
-
-/*  */
-/*        8192C Regsiter Bit and Content definition */
-/*  */
-/*  */
-/*  */
-/*     0x0000h ~ 0x00FFh       System Configuration */
-/*  */
-/*  */
-
-/* 2 SPS0_CTRL */
-#define SW18_FPWM                      BIT(3)
-
-
-/* 2 SYS_ISO_CTRL */
-#define ISO_MD2PP                      BIT(0)
-#define ISO_UA2USB                     BIT(1)
-#define ISO_UD2CORE                    BIT(2)
-#define ISO_PA2PCIE                    BIT(3)
-#define ISO_PD2CORE                    BIT(4)
-#define ISO_IP2MAC                     BIT(5)
-#define ISO_DIOP                       BIT(6)
-#define ISO_DIOE                       BIT(7)
-#define ISO_EB2CORE                    BIT(8)
-#define ISO_DIOR                       BIT(9)
-
-#define PWC_EV25V                      BIT(14)
-#define PWC_EV12V                      BIT(15)
-
-
-/* 2 SYS_FUNC_EN */
-#define FEN_BBRSTB                     BIT(0)
-#define FEN_BB_GLB_RSTn                        BIT(1)
-#define FEN_USBA                       BIT(2)
-#define FEN_UPLL                       BIT(3)
-#define FEN_USBD                       BIT(4)
-#define FEN_DIO_PCIE                   BIT(5)
-#define FEN_PCIEA                      BIT(6)
-#define FEN_PPLL                       BIT(7)
-#define FEN_PCIED                      BIT(8)
-#define FEN_DIOE                       BIT(9)
-#define FEN_CPUEN                      BIT(10)
-#define FEN_DCORE                      BIT(11)
-#define FEN_ELDR                       BIT(12)
-#define FEN_DIO_RF                     BIT(13)
-#define FEN_HWPDN                      BIT(14)
-#define FEN_MREGEN                     BIT(15)
-
-/* 2 APS_FSMCO */
-#define PFM_LDALL                      BIT(0)
-#define PFM_ALDN                       BIT(1)
-#define PFM_LDKP                       BIT(2)
-#define PFM_WOWL                       BIT(3)
-#define EnPDN                          BIT(4)
-#define PDN_PL                         BIT(5)
-#define APFM_ONMAC                     BIT(8)
-#define APFM_OFF                       BIT(9)
-#define APFM_RSM                       BIT(10)
-#define AFSM_HSUS                      BIT(11)
-#define AFSM_PCIE                      BIT(12)
-#define APDM_MAC                       BIT(13)
-#define APDM_HOST                      BIT(14)
-#define APDM_HPDN                      BIT(15)
-#define RDY_MACON                      BIT(16)
-#define SUS_HOST                       BIT(17)
-#define ROP_ALD                                BIT(20)
-#define ROP_PWR                                BIT(21)
-#define ROP_SPS                                BIT(22)
-#define SOP_MRST                       BIT(25)
-#define SOP_FUSE                       BIT(26)
-#define SOP_ABG                                BIT(27)
-#define SOP_AMB                                BIT(28)
-#define SOP_RCK                                BIT(29)
-#define SOP_A8M                                BIT(30)
-#define XOP_BTCK                       BIT(31)
-
-/* 2 SYS_CLKR */
-#define ANAD16V_EN                     BIT(0)
-#define ANA8M                          BIT(1)
-#define MACSLP                         BIT(4)
-#define LOADER_CLK_EN                  BIT(5)
-#define _80M_SSC_DIS                   BIT(7)
-#define _80M_SSC_EN_HO                 BIT(8)
-#define PHY_SSC_RSTB                   BIT(9)
-#define SEC_CLK_EN                     BIT(10)
-#define MAC_CLK_EN                     BIT(11)
-#define SYS_CLK_EN                     BIT(12)
-#define RING_CLK_EN                    BIT(13)
-
-
-/* 2 9346CR */
-
-
-#define                EEDO                    BIT(0)
-#define                EEDI                    BIT(1)
-#define                EESK                    BIT(2)
-#define                EECS                    BIT(3)
-/* define      EERPROMSEL              BIT(4) */
-/* define      EEPROM_EN               BIT(5) */
-#define                BOOT_FROM_EEPROM        BIT(4)
-#define                EEPROM_EN               BIT(5)
-#define                EEM0                    BIT(6)
-#define                EEM1                    BIT(7)
-
-
-/* 2 AFE_MISC */
-#define AFE_BGEN                       BIT(0)
-#define AFE_MBEN                       BIT(1)
-#define MAC_ID_EN                      BIT(7)
-
-
-/* 2 SPS0_CTRL */
-
-
-/* 2 SPS_OCP_CFG */
-
-
-/* 2 RSV_CTRL */
-#define WLOCK_ALL                      BIT(0)
-#define WLOCK_00                       BIT(1)
-#define WLOCK_04                       BIT(2)
-#define WLOCK_08                       BIT(3)
-#define WLOCK_40                       BIT(4)
-#define R_DIS_PRST_0                   BIT(5)
-#define R_DIS_PRST_1                   BIT(6)
-#define LOCK_ALL_EN                    BIT(7)
-
-/* 2 RF_CTRL */
-#define RF_EN                          BIT(0)
-#define RF_RSTB                                BIT(1)
-#define RF_SDMRSTB                     BIT(2)
-
-
-
-/* 2 LDOA15_CTRL */
-#define LDA15_EN                       BIT(0)
-#define LDA15_STBY                     BIT(1)
-#define LDA15_OBUF                     BIT(2)
-#define LDA15_REG_VOS                  BIT(3)
-#define _LDA15_VOADJ(x)                        (((x) & 0x7) << 4)
-
-
-
-/* 2 LDOV12D_CTRL */
-#define LDV12_EN                       BIT(0)
-#define LDV12_SDBY                     BIT(1)
-#define LPLDO_HSM                      BIT(2)
-#define LPLDO_LSM_DIS                  BIT(3)
-#define _LDV12_VADJ(x)                 (((x) & 0xF) << 4)
-
-
-/* 2 AFE_XTAL_CTRL */
-#define XTAL_EN                                BIT(0)
-#define XTAL_BSEL                      BIT(1)
-#define _XTAL_BOSC(x)                  (((x) & 0x3) << 2)
-#define _XTAL_CADJ(x)                  (((x) & 0xF) << 4)
-#define XTAL_GATE_USB                  BIT(8)
-#define _XTAL_USB_DRV(x)               (((x) & 0x3) << 9)
-#define XTAL_GATE_AFE                  BIT(11)
-#define _XTAL_AFE_DRV(x)               (((x) & 0x3) << 12)
-#define XTAL_RF_GATE                   BIT(14)
-#define _XTAL_RF_DRV(x)                        (((x) & 0x3) << 15)
-#define XTAL_GATE_DIG                  BIT(17)
-#define _XTAL_DIG_DRV(x)               (((x) & 0x3) << 18)
-#define XTAL_BT_GATE                   BIT(20)
-#define _XTAL_BT_DRV(x)                        (((x) & 0x3) << 21)
-#define _XTAL_GPIO(x)                  (((x) & 0x7) << 23)
-
-
-#define CKDLY_AFE                      BIT(26)
-#define CKDLY_USB                      BIT(27)
-#define CKDLY_DIG                      BIT(28)
-#define CKDLY_BT                       BIT(29)
-
-
-/* 2 AFE_PLL_CTRL */
-#define APLL_EN                                BIT(0)
-#define APLL_320_EN                    BIT(1)
-#define APLL_FREF_SEL                  BIT(2)
-#define APLL_EDGE_SEL                  BIT(3)
-#define APLL_WDOGB                     BIT(4)
-#define APLL_LPFEN                     BIT(5)
-
-#define APLL_REF_CLK_13MHZ             0x1
-#define APLL_REF_CLK_19_2MHZ           0x2
-#define APLL_REF_CLK_20MHZ             0x3
-#define APLL_REF_CLK_25MHZ             0x4
-#define APLL_REF_CLK_26MHZ             0x5
-#define APLL_REF_CLK_38_4MHZ           0x6
-#define APLL_REF_CLK_40MHZ             0x7
-
-#define APLL_320EN                     BIT(14)
-#define APLL_80EN                      BIT(15)
-#define APLL_1MEN                      BIT(24)
-
-
-/* 2 EFUSE_CTRL */
-#define ALD_EN                         BIT(18)
-#define EF_PD                          BIT(19)
-#define EF_FLAG                                BIT(31)
-
-/* 2 EFUSE_TEST (For RTL8723 partially) */
-#define EF_TRPT                                BIT(7)
-       /*  00: Wifi Efuse, 01: BT Efuse0, 10: BT Efuse1, 11: BT Efuse2 */
-#define EF_CELL_SEL                    (BIT(8)|BIT(9))
-#define LDOE25_EN                      BIT(31)
-#define EFUSE_SEL(x)                   (((x) & 0x3) << 8)
-#define EFUSE_SEL_MASK                 0x300
-#define EFUSE_WIFI_SEL_0               0x0
-#define EFUSE_BT_SEL_0                 0x1
-#define EFUSE_BT_SEL_1                 0x2
-#define EFUSE_BT_SEL_2                 0x3
-
-#define EFUSE_ACCESS_ON                        0x69    /*  For RTL8723 only. */
-#define EFUSE_ACCESS_OFF               0x00    /*  For RTL8723 only. */
-
-/* 2 PWR_DATA */
-
-/* 2 CAL_TIMER */
-
-/* 2 ACLK_MON */
-#define RSM_EN                         BIT(0)
-#define Timer_EN                       BIT(4)
-
-
-/* 2 GPIO_MUXCFG */
-#define TRSW0EN                                BIT(2)
-#define TRSW1EN                                BIT(3)
-#define EROM_EN                                BIT(4)
-#define EnBT                           BIT(5)
-#define EnUart                         BIT(8)
-#define Uart_910                       BIT(9)
-#define EnPMAC                         BIT(10)
-#define SIC_SWRST                      BIT(11)
-#define EnSIC                          BIT(12)
-#define SIC_23                         BIT(13)
-#define EnHDP                          BIT(14)
-#define SIC_LBK                                BIT(15)
-
-/* 2 GPIO_PIN_CTRL */
-
-/*  GPIO BIT */
-#define HAL_8192C_HW_GPIO_WPS_BIT      BIT(2)
-
-/* 2 GPIO_INTM */
-
-/* 2 LEDCFG */
-#define LED0PL                         BIT(4)
-#define LED0DIS                                BIT(7)
-#define LED1DIS                                BIT(15)
-#define LED1PL                         BIT(12)
-
-#define  SECCAM_CLR                    BIT(30)
-
-
-/* 2 FSIMR */
-
-/* 2 FSISR */
-
-
-/* 2 8051FWDL */
-/* 2 MCUFWDL */
-#define MCUFWDL_EN                     BIT(0)
-#define MCUFWDL_RDY                    BIT(1)
-#define FWDL_ChkSum_rpt                        BIT(2)
-#define MACINI_RDY                     BIT(3)
-#define BBINI_RDY                      BIT(4)
-#define RFINI_RDY                      BIT(5)
-#define WINTINI_RDY                    BIT(6)
-#define CPRST                          BIT(23)
-
-/* 2REG_HPON_FSM */
-#define BOND92CE_1T2R_CFG              BIT(22)
-
-
-/* 2 REG_SYS_CFG */
-#define XCLK_VLD                       BIT(0)
-#define ACLK_VLD                       BIT(1)
-#define UCLK_VLD                       BIT(2)
-#define PCLK_VLD                       BIT(3)
-#define PCIRSTB                                BIT(4)
-#define V15_VLD                                BIT(5)
-#define TRP_B15V_EN                    BIT(7)
-#define SIC_IDLE                       BIT(8)
-#define BD_MAC2                                BIT(9)
-#define BD_MAC1                                BIT(10)
-#define IC_MACPHY_MODE                 BIT(11)
-#define CHIP_VER                       (BIT(12)|BIT(13)|BIT(14)|BIT(15))
-#define BT_FUNC                                BIT(16)
-#define VENDOR_ID                      BIT(19)
-#define PAD_HWPD_IDN                   BIT(22)
-#define TRP_VAUX_EN                    BIT(23)
-#define TRP_BT_EN                      BIT(24)
-#define BD_PKG_SEL                     BIT(25)
-#define BD_HCI_SEL                     BIT(26)
-#define TYPE_ID                                BIT(27)
-
-#define CHIP_VER_RTL_MASK              0xF000  /* Bit 12 ~ 15 */
-#define CHIP_VER_RTL_SHIFT             12
-
-/* 2REG_GPIO_OUTSTS (For RTL8723 only) */
-#define        EFS_HCI_SEL                     (BIT(0)|BIT(1))
-#define        PAD_HCI_SEL                     (BIT(2)|BIT(3))
-#define        HCI_SEL                         (BIT(4)|BIT(5))
-#define        PKG_SEL_HCI                     BIT(6)
-#define        FEN_GPS                         BIT(7)
-#define        FEN_BT                          BIT(8)
-#define        FEN_WL                          BIT(9)
-#define        FEN_PCI                         BIT(10)
-#define        FEN_USB                         BIT(11)
-#define        BTRF_HWPDN_N                    BIT(12)
-#define        WLRF_HWPDN_N                    BIT(13)
-#define        PDN_BT_N                        BIT(14)
-#define        PDN_GPS_N                       BIT(15)
-#define        BT_CTL_HWPDN                    BIT(16)
-#define        GPS_CTL_HWPDN                   BIT(17)
-#define        PPHY_SUSB                       BIT(20)
-#define        UPHY_SUSB                       BIT(21)
-#define        PCI_SUSEN                       BIT(22)
-#define        USB_SUSEN                       BIT(23)
-#define        RF_RL_ID                        (BIT(31)|BIT(30)|BIT(29)|BIT(28))
-
-/*  */
-/*  */
-/*     0x0100h ~ 0x01FFh       MACTOP General Configuration */
-/*  */
-/*  */
-
-
-/* 2 Function Enable Registers */
-/* 2 CR */
-
-#define REG_LBMODE                     (REG_CR + 3)
-
-
-#define HCI_TXDMA_EN                   BIT(0)
-#define HCI_RXDMA_EN                   BIT(1)
-#define TXDMA_EN                       BIT(2)
-#define RXDMA_EN                       BIT(3)
-#define PROTOCOL_EN                    BIT(4)
-#define SCHEDULE_EN                    BIT(5)
-#define MACTXEN                                BIT(6)
-#define MACRXEN                                BIT(7)
-#define ENSWBCN                                BIT(8)
-#define ENSEC                          BIT(9)
-
-#define _LBMODE(x)                     (((x) & 0xF) << 24)
-#define MASK_LBMODE                    0xF000000
-#define LOOPBACK_NORMAL                        0x0
-#define LOOPBACK_IMMEDIATELY           0xB
-#define LOOPBACK_MAC_DELAY             0x3
-#define LOOPBACK_PHY                   0x1
-#define LOOPBACK_DMA                   0x7
-
-
-/* 2 PBP - Page Size Register */
-#define GET_RX_PAGE_SIZE(value)                ((value) & 0xF)
-#define GET_TX_PAGE_SIZE(value)                (((value) & 0xF0) >> 4)
-#define _PSRX_MASK                     0xF
-#define _PSTX_MASK                     0xF0
-#define _PSRX(x)                       (x)
-#define _PSTX(x)                       ((x) << 4)
-
-#define PBP_64                         0x0
-#define PBP_128                                0x1
-#define PBP_256                                0x2
-#define PBP_512                                0x3
-#define PBP_1024                       0x4
-
-
-/* 2 TX/RXDMA */
-#define RXDMA_ARBBW_EN                 BIT(0)
-#define RXSHFT_EN                      BIT(1)
-#define RXDMA_AGG_EN                   BIT(2)
-#define QS_VO_QUEUE                    BIT(8)
-#define QS_VI_QUEUE                    BIT(9)
-#define QS_BE_QUEUE                    BIT(10)
-#define QS_BK_QUEUE                    BIT(11)
-#define QS_MANAGER_QUEUE               BIT(12)
-#define QS_HIGH_QUEUE                  BIT(13)
-
-#define HQSEL_VOQ                      BIT(0)
-#define HQSEL_VIQ                      BIT(1)
-#define HQSEL_BEQ                      BIT(2)
-#define HQSEL_BKQ                      BIT(3)
-#define HQSEL_MGTQ                     BIT(4)
-#define HQSEL_HIQ                      BIT(5)
-
-/*  For normal driver, 0x10C */
-#define _TXDMA_HIQ_MAP(x)              (((x)&0x3) << 14)
-#define _TXDMA_MGQ_MAP(x)              (((x)&0x3) << 12)
-#define _TXDMA_BKQ_MAP(x)              (((x)&0x3) << 10)
-#define _TXDMA_BEQ_MAP(x)              (((x)&0x3) << 8)
-#define _TXDMA_VIQ_MAP(x)              (((x)&0x3) << 6)
-#define _TXDMA_VOQ_MAP(x)              (((x)&0x3) << 4)
-
-#define QUEUE_LOW                      1
-#define QUEUE_NORMAL                   2
-#define QUEUE_HIGH                     3
-
-
-
-/* 2 TRXFF_BNDY */
-
-
-/* 2 LLT_INIT */
-#define _LLT_NO_ACTIVE                 0x0
-#define _LLT_WRITE_ACCESS              0x1
-#define _LLT_READ_ACCESS               0x2
-
-#define _LLT_INIT_DATA(x)              ((x) & 0xFF)
-#define _LLT_INIT_ADDR(x)              (((x) & 0xFF) << 8)
-#define _LLT_OP(x)                     (((x) & 0x3) << 30)
-#define _LLT_OP_VALUE(x)               (((x) >> 30) & 0x3)
-
-
-/* 2 BB_ACCESS_CTRL */
-#define BB_WRITE_READ_MASK             (BIT(31) | BIT(30))
-#define BB_WRITE_EN                    BIT(30)
-#define BB_READ_EN                     BIT(31)
-/* define BB_ADDR_MASK                 0xFFF */
-/* define _BB_ADDR(x)                  ((x) & BB_ADDR_MASK) */
-
-/*  */
-/*  */
-/*     0x0200h ~ 0x027Fh       TXDMA Configuration */
-/*  */
-/*  */
-/* 2 RQPN */
-#define _HPQ(x)                                ((x) & 0xFF)
-#define _LPQ(x)                                (((x) & 0xFF) << 8)
-#define _PUBQ(x)                       (((x) & 0xFF) << 16)
-       /*  NOTE: in RQPN_NPQ register */
-#define _NPQ(x)                                ((x) & 0xFF)
-
-
-#define HPQ_PUBLIC_DIS                 BIT(24)
-#define LPQ_PUBLIC_DIS                 BIT(25)
-#define LD_RQPN                                BIT(31)
-
-
-/* 2 TDECTRL */
-#define BCN_VALID                      BIT(16)
-#define BCN_HEAD(x)                    (((x) & 0xFF) << 8)
-#define        BCN_HEAD_MASK                   0xFF00
-
-/* 2 TDECTL */
-#define BLK_DESC_NUM_SHIFT             4
-#define BLK_DESC_NUM_MASK              0xF
-
-
-/* 2 TXDMA_OFFSET_CHK */
-#define DROP_DATA_EN                   BIT(9)
-
-/*  */
-/*  */
-/*     0x0400h ~ 0x047Fh       Protocol Configuration */
-/*  */
-/*  */
-/* 2 FWHW_TXQ_CTRL */
-#define EN_AMPDU_RTY_NEW               BIT(7)
-
-/* 2 INIRTSMCS_SEL */
-#define _INIRTSMCS_SEL(x)              ((x) & 0x3F)
-
-
-/* 2 SPEC SIFS */
-#define _SPEC_SIFS_CCK(x)              ((x) & 0xFF)
-#define _SPEC_SIFS_OFDM(x)             (((x) & 0xFF) << 8)
-
-
-/* 2 RRSR */
-
-#define RATE_REG_BITMAP_ALL            0xFFFFF
-
-#define _RRSC_BITMAP(x)                        ((x) & 0xFFFFF)
-
-#define _RRSR_RSC(x)                   (((x) & 0x3) << 21)
-#define RRSR_RSC_RESERVED              0x0
-#define RRSR_RSC_UPPER_SUBCHANNEL      0x1
-#define RRSR_RSC_LOWER_SUBCHANNEL      0x2
-#define RRSR_RSC_DUPLICATE_MODE                0x3
-
-
-/* 2 ARFR */
-#define USE_SHORT_G1                   BIT(20)
-
-/* 2 AGGLEN_LMT_L */
-#define _AGGLMT_MCS0(x)                        ((x) & 0xF)
-#define _AGGLMT_MCS1(x)                        (((x) & 0xF) << 4)
-#define _AGGLMT_MCS2(x)                        (((x) & 0xF) << 8)
-#define _AGGLMT_MCS3(x)                        (((x) & 0xF) << 12)
-#define _AGGLMT_MCS4(x)                        (((x) & 0xF) << 16)
-#define _AGGLMT_MCS5(x)                        (((x) & 0xF) << 20)
-#define _AGGLMT_MCS6(x)                        (((x) & 0xF) << 24)
-#define _AGGLMT_MCS7(x)                        (((x) & 0xF) << 28)
-
-
-/* 2 RL */
-#define        RETRY_LIMIT_SHORT_SHIFT         8
-#define        RETRY_LIMIT_LONG_SHIFT          0
-
-
-/* 2 DARFRC */
-#define _DARF_RC1(x)                   ((x) & 0x1F)
-#define _DARF_RC2(x)                   (((x) & 0x1F) << 8)
-#define _DARF_RC3(x)                   (((x) & 0x1F) << 16)
-#define _DARF_RC4(x)                   (((x) & 0x1F) << 24)
-/*  NOTE: shift starting from address (DARFRC + 4) */
-#define _DARF_RC5(x)                   ((x) & 0x1F)
-#define _DARF_RC6(x)                   (((x) & 0x1F) << 8)
-#define _DARF_RC7(x)                   (((x) & 0x1F) << 16)
-#define _DARF_RC8(x)                   (((x) & 0x1F) << 24)
-
-
-/* 2 RARFRC */
-#define _RARF_RC1(x)                   ((x) & 0x1F)
-#define _RARF_RC2(x)                   (((x) & 0x1F) << 8)
-#define _RARF_RC3(x)                   (((x) & 0x1F) << 16)
-#define _RARF_RC4(x)                   (((x) & 0x1F) << 24)
-/*  NOTE: shift starting from address (RARFRC + 4) */
-#define _RARF_RC5(x)                   ((x) & 0x1F)
-#define _RARF_RC6(x)                   (((x) & 0x1F) << 8)
-#define _RARF_RC7(x)                   (((x) & 0x1F) << 16)
-#define _RARF_RC8(x)                   (((x) & 0x1F) << 24)
-
-
-/*  */
-/*  */
-/*     0x0500h ~ 0x05FFh       EDCA Configuration */
-/*  */
-/*  */
-
-
-
-/* 2 EDCA setting */
-#define AC_PARAM_TXOP_LIMIT_OFFSET     16
-#define AC_PARAM_ECW_MAX_OFFSET                12
-#define AC_PARAM_ECW_MIN_OFFSET                8
-#define AC_PARAM_AIFS_OFFSET           0
-
-
-/* 2 EDCA_VO_PARAM */
-#define _AIFS(x)                       (x)
-#define _ECW_MAX_MIN(x)                        ((x) << 8)
-#define _TXOP_LIMIT(x)                 ((x) << 16)
-
-
-#define _BCNIFS(x)                     ((x) & 0xFF)
-#define _BCNECW(x)                     (((x) & 0xF))<< 8)
-
-
-#define _LRL(x)                                ((x) & 0x3F)
-#define _SRL(x)                                (((x) & 0x3F) << 8)
-
-
-/* 2 SIFS_CCK */
-#define _SIFS_CCK_CTX(x)               ((x) & 0xFF)
-#define _SIFS_CCK_TRX(x)               (((x) & 0xFF) << 8);
-
-
-/* 2 SIFS_OFDM */
-#define _SIFS_OFDM_CTX(x)              ((x) & 0xFF)
-#define _SIFS_OFDM_TRX(x)              (((x) & 0xFF) << 8);
-
-
-/* 2 TBTT PROHIBIT */
-#define _TBTT_PROHIBIT_HOLD(x)         (((x) & 0xFF) << 8)
-
-
-/* 2 REG_RD_CTRL */
-#define DIS_EDCA_CNT_DWN               BIT(11)
-
-
-/* 2 BCN_CTRL */
-#define EN_MBSSID                      BIT(1)
-#define EN_TXBCN_RPT                   BIT(2)
-#define        EN_BCN_FUNCTION                 BIT(3)
-#define DIS_TSF_UPDATE                 BIT(3)
-
-/*  The same function but different bit field. */
-#define        DIS_TSF_UDT0_NORMAL_CHIP        BIT(4)
-#define        DIS_TSF_UDT0_TEST_CHIP          BIT(5)
-
-/* 2 ACMHWCTRL */
-#define        AcmHw_HwEn                      BIT(0)
-#define        AcmHw_BeqEn                     BIT(1)
-#define        AcmHw_ViqEn                     BIT(2)
-#define        AcmHw_VoqEn                     BIT(3)
-#define        AcmHw_BeqStatus                 BIT(4)
-#define        AcmHw_ViqStatus                 BIT(5)
-#define        AcmHw_VoqStatus                 BIT(6)
-
-
-
-/*  */
-/*  */
-/*     0x0600h ~ 0x07FFh       WMAC Configuration */
-/*  */
-/*  */
-
-/* 2 APSD_CTRL */
-#define APSDOFF                                BIT(6)
-#define APSDOFF_STATUS                 BIT(7)
-
-
-/* 2 BWOPMODE */
-#define BW_20MHZ                       BIT(2)
-
-
-#define RATE_BITMAP_ALL                        0xFFFFF
-
-/*  Only use CCK 1M rate for ACK */
-#define RATE_RRSR_CCK_ONLY_1M          0xFFFF1
-
-/* 2 TCR */
-#define TSFRST                         BIT(0)
-#define DIS_GCLK                       BIT(1)
-#define PAD_SEL                                BIT(2)
-#define PWR_ST                         BIT(6)
-#define PWRBIT_OW_EN                   BIT(7)
-#define ACRC                           BIT(8)
-#define CFENDFORM                      BIT(9)
-#define ICV                            BIT(10)
-
-
-
-/* 2 RCR */
-#define AAP                            BIT(0)
-#define APM                            BIT(1)
-#define AM                             BIT(2)
-#define AB                             BIT(3)
-#define ADD3                           BIT(4)
-#define APWRMGT                                BIT(5)
-#define CBSSID                         BIT(6)
-#define CBSSID_BCN                     BIT(7)
-#define ACRC32                         BIT(8)
-#define AICV                           BIT(9)
-#define ADF                            BIT(11)
-#define ACF                            BIT(12)
-#define AMF                            BIT(13)
-#define HTC_LOC_CTRL                   BIT(14)
-#define UC_DATA_EN                     BIT(16)
-#define BM_DATA_EN                     BIT(17)
-#define MFBEN                          BIT(22)
-#define LSIGEN                         BIT(23)
-#define EnMBID                         BIT(24)
-#define APP_BASSN                      BIT(27)
-#define APP_PHYSTS                     BIT(28)
-#define APP_ICV                                BIT(29)
-#define APP_MIC                                BIT(30)
-#define APP_FCS                                BIT(31)
-
-/* 2 RX_PKT_LIMIT */
-
-/* 2 RX_DLK_TIME */
-
-/* 2 MBIDCAMCFG */
-
-
-
-/* 2 AMPDU_MIN_SPACE */
-#define _MIN_SPACE(x)                  ((x) & 0x7)
-#define _SHORT_GI_PADDING(x)           (((x) & 0x1F) << 3)
-
-
-/* 2 RXERR_RPT */
-#define RXERR_TYPE_OFDM_PPDU           0
-#define RXERR_TYPE_OFDMfalse_ALARM     1
-#define        RXERR_TYPE_OFDM_MPDU_OK         2
-#define RXERR_TYPE_OFDM_MPDU_FAIL      3
-#define RXERR_TYPE_CCK_PPDU            4
-#define RXERR_TYPE_CCKfalse_ALARM      5
-#define RXERR_TYPE_CCK_MPDU_OK         6
-#define RXERR_TYPE_CCK_MPDU_FAIL       7
-#define RXERR_TYPE_HT_PPDU             8
-#define RXERR_TYPE_HTfalse_ALARM       9
-#define RXERR_TYPE_HT_MPDU_TOTAL       10
-#define RXERR_TYPE_HT_MPDU_OK          11
-#define RXERR_TYPE_HT_MPDU_FAIL                12
-#define RXERR_TYPE_RX_FULL_DROP                15
-
-#define RXERR_COUNTER_MASK             0xFFFFF
-#define RXERR_RPT_RST                  BIT(27)
-#define _RXERR_RPT_SEL(type)           ((type) << 28)
-
-
-/* 2 SECCFG */
-#define        SCR_TxUseDK                     BIT(0)  /* Force Tx Use Default Key */
-#define        SCR_RxUseDK                     BIT(1)  /* Force Rx Use Default Key */
-#define        SCR_TxEncEnable                 BIT(2)  /* Enable Tx Encryption */
-#define        SCR_RxDecEnable                 BIT(3)  /* Enable Rx Decryption */
-#define        SCR_SKByA2                      BIT(4)  /* Search kEY BY A2 */
-#define        SCR_NoSKMC                      BIT(5)  /* No Key Search Multicast */
-
-
-
-/*  */
-/*  */
-/*     0xFE00h ~ 0xFE55h       USB Configuration */
-/*  */
-/*  */
-
-/* 2 USB Information (0xFE17) */
-#define USB_IS_HIGH_SPEED              0
-#define USB_IS_FULL_SPEED              1
-#define USB_SPEED_MASK                 BIT(5)
-
-#define USB_NORMAL_SIE_EP_MASK         0xF
-#define USB_NORMAL_SIE_EP_SHIFT                4
-
-#define USB_TEST_EP_MASK               0x30
-#define USB_TEST_EP_SHIFT              4
-
-/* 2 Special Option */
-#define USB_AGG_EN                     BIT(3)
-
-
-/* 2REG_C2HEVT_CLEAR */
-       /*  Set by driver and notify FW that the driver has read the
-           C2H command message */
-#define C2H_EVT_HOST_CLOSE             0x00
-       /*  Set by FW indicating that FW had set the C2H command message
-           and it's not yet read by driver. */
-#define C2H_EVT_FW_CLOSE               0xFF
-
-
-/* 2REG_MULTI_FUNC_CTRL(For RTL8723 Only) */
-       /*  Enable GPIO[9] as WiFi HW PDn source */
-#define        WL_HWPDN_EN                     BIT(0)
-       /*  WiFi HW PDn polarity control */
-#define        WL_HWPDN_SL                     BIT(1)
-       /*  WiFi function enable */
-#define        WL_FUNC_EN                      BIT(2)
-       /*  Enable GPIO[9] as WiFi RF HW PDn source */
-#define        WL_HWROF_EN                     BIT(3)
-       /*  Enable GPIO[11] as BT HW PDn source */
-#define        BT_HWPDN_EN                     BIT(16)
-       /*  BT HW PDn polarity control */
-#define        BT_HWPDN_SL                     BIT(17)
-       /*  BT function enable */
-#define        BT_FUNC_EN                      BIT(18)
-       /*  Enable GPIO[11] as BT/GPS RF HW PDn source */
-#define        BT_HWROF_EN                     BIT(19)
-       /*  Enable GPIO[10] as GPS HW PDn source */
-#define        GPS_HWPDN_EN                    BIT(20)
-       /*  GPS HW PDn polarity control */
-#define        GPS_HWPDN_SL                    BIT(21)
-       /*  GPS function enable */
-#define        GPS_FUNC_EN                     BIT(22)
-
-/* 3 REG_LIFECTRL_CTRL */
-#define        HAL92C_EN_PKT_LIFE_TIME_BK      BIT(3)
-#define        HAL92C_EN_PKT_LIFE_TIME_BE      BIT(2)
-#define        HAL92C_EN_PKT_LIFE_TIME_VI      BIT(1)
-#define        HAL92C_EN_PKT_LIFE_TIME_VO      BIT(0)
-
-#define        HAL92C_MSDU_LIFE_TIME_UNIT      128     /*  in us, said by Tim. */
-
-/*  */
-/*  General definitions */
-/*  */
-
-#define LAST_ENTRY_OF_TX_PKT_BUFFER    255
-
-#define POLLING_LLT_THRESHOLD          20
-#define POLLING_READY_TIMEOUT_COUNT    1000
-
-/*  Min Spacing related settings. */
-#define        MAX_MSS_DENSITY_2T              0x13
-#define        MAX_MSS_DENSITY_1T              0x0A
-
-/*  */
-/*     8723A Regsiter offset definition */
-/*  */
-#define HAL_8723A_NAV_UPPER_UNIT       128             /*  micro-second */
-
-/*  */
-/*  */
-/*     0x0000h ~ 0x00FFh       System Configuration */
-/*  */
-/*  */
-#define REG_SYSON_REG_LOCK             0x001C
-
-
-/*  */
-/*  */
-/*     0x0100h ~ 0x01FFh       MACTOP General Configuration */
-/*  */
-/*  */
-#define REG_FTIMR                      0x0138
-
-
-/*  */
-/*  */
-/*     0x0200h ~ 0x027Fh       TXDMA Configuration */
-/*  */
-/*  */
-
-
-/*  */
-/*  */
-/*     0x0280h ~ 0x02FFh       RXDMA Configuration */
-/*  */
-/*  */
-
-
-/*  */
-/*  */
-/*     0x0300h ~ 0x03FFh       PCIe */
-/*  */
-/*  */
-
-
-/*  */
-/*  */
-/*     0x0400h ~ 0x047Fh       Protocol Configuration */
-/*  */
-/*  */
-#define REG_EARLY_MODE_CONTROL         0x4D0
-
-
-/*  */
-/*  */
-/*     0x0500h ~ 0x05FFh       EDCA Configuration */
-/*  */
-/*  */
-
-/* 2 BCN_CTRL */
-#define DIS_ATIM                       BIT(0)
-#define DIS_BCNQ_SUB                   BIT(1)
-#define DIS_TSF_UDT                    BIT(4)
-
-
-/*  */
-/*  */
-/*     0x0600h ~ 0x07FFh       WMAC Configuration */
-/*  */
-/*  */
-/*  */
-/*  Note: */
-/*     The NAV upper value is very important to WiFi 11n 5.2.3 NAV test.
- *     The default value is always too small, but the WiFi TestPlan test
- *     by 25,000 microseconds of NAV through sending CTS in the air. We
- *     must update this value greater than 25,000 microseconds to pass the
- *     item.
-*      The offset of NAV_UPPER in 8192C Spec is incorrect, and the offset
-*      should be 0x0652. Commented by SD1 Scott. */
-/*  By Bruce, 2011-07-18. */
-/*  */
-#define        REG_NAV_UPPER                   0x0652  /*  unit of 128 */
-
-
-/*  */
-/*     8723 Regsiter Bit and Content definition */
-/*  */
-
-/*  */
-/*  */
-/*     0x0000h ~ 0x00FFh       System Configuration */
-/*  */
-/*  */
-
-/* 2 SPS0_CTRL */
-
-/* 2 SYS_ISO_CTRL */
-
-/* 2 SYS_FUNC_EN */
-
-/* 2 APS_FSMCO */
-#define EN_WLON                                BIT(16)
-
-/* 2 SYS_CLKR */
-
-/* 2 9346CR */
-
-/* 2 AFE_MISC */
-
-/* 2 SPS0_CTRL */
-
-/* 2 SPS_OCP_CFG */
-
-/* 2 SYSON_REG_LOCK */
-#define WLOCK_ALL                      BIT(0)
-#define WLOCK_00                       BIT(1)
-#define WLOCK_04                       BIT(2)
-#define WLOCK_08                       BIT(3)
-#define WLOCK_40                       BIT(4)
-#define WLOCK_1C_B6                    BIT(5)
-#define R_DIS_PRST_1                   BIT(6)
-#define LOCK_ALL_EN                    BIT(7)
-
-/* 2 RF_CTRL */
-
-/* 2 LDOA15_CTRL */
-
-/* 2 LDOV12D_CTRL */
-
-/* 2 AFE_XTAL_CTRL */
-
-/* 2 AFE_PLL_CTRL */
-
-/* 2 EFUSE_CTRL */
-
-/* 2 EFUSE_TEST (For RTL8723 partially) */
-
-/* 2 PWR_DATA */
-
-/* 2 CAL_TIMER */
-
-/* 2 ACLK_MON */
-
-/* 2 GPIO_MUXCFG */
-
-/* 2 GPIO_PIN_CTRL */
-
-/* 2 GPIO_INTM */
-
-/* 2 LEDCFG */
-
-/* 2 FSIMR */
-
-/* 2 FSISR */
-
-/* 2 HSIMR */
-/*  8723 Host System Interrupt Mask Register (offset 0x58, 32 byte) */
-#define HSIMR_GPIO12_0_INT_EN          BIT(0)
-#define HSIMR_SPS_OCP_INT_EN           BIT(5)
-#define HSIMR_RON_INT_EN               BIT(6)
-#define HSIMR_PDNINT_EN                        BIT(7)
-#define HSIMR_GPIO9_INT_EN             BIT(25)
-
-/* 2 HSISR */
-/*  8723 Host System Interrupt Status Register (offset 0x5C, 32 byte) */
-#define HSISR_GPIO12_0_INT             BIT(0)
-#define HSISR_SPS_OCP_INT              BIT(5)
-#define HSISR_RON_INT                  BIT(6)
-#define HSISR_PDNINT                   BIT(7)
-#define        HSISR_GPIO9_INT                 BIT(25)
-
-/*  interrupt mask which needs to clear */
-#define MASK_HSISR_CLEAR               (HSISR_GPIO12_0_INT | \
-                                        HSISR_SPS_OCP_INT | \
-                                        HSISR_RON_INT | \
-                                        HSISR_PDNINT | \
-                                        HSISR_GPIO9_INT)
-
-/* 2 MCUFWDL */
-#define RAM_DL_SEL                     BIT(7)  /*  1:RAM, 0:ROM */
-
-/* 2 HPON_FSM */
-
-/* 2 SYS_CFG */
-#define RTL_ID                         BIT(23) /*  TestChip ID,
-                                                   1:Test(RLE); 0:MP(RL) */
-#define SPS_SEL                                BIT(24) /*  1:LDO regulator mode;
-                                                   0:Switching regulator mode*/
-
-
-/*  */
-/*  */
-/*     0x0100h ~ 0x01FFh       MACTOP General Configuration */
-/*  */
-/*  */
-
-/* 2 Function Enable Registers */
-
-/* 2 CR */
-#define CALTMR_EN                      BIT(10)
-
-/* 2 PBP - Page Size Register */
-
-/* 2 TX/RXDMA */
-
-/* 2 TRXFF_BNDY */
-
-/* 2 LLT_INIT */
-
-/* 2 BB_ACCESS_CTRL */
-
-
-/*  */
-/*  */
-/*     0x0200h ~ 0x027Fh       TXDMA Configuration */
-/*  */
-/*  */
-
-/* 2 RQPN */
-
-/* 2 TDECTRL */
-
-/* 2 TDECTL */
-
-/* 2 TXDMA_OFFSET_CHK */
-
-
-/*  */
-/*  */
-/*     0x0400h ~ 0x047Fh       Protocol Configuration */
-/*  */
-/*  */
-
-/* 2 FWHW_TXQ_CTRL */
-
-/* 2 INIRTSMCS_SEL */
-
-/* 2 SPEC SIFS */
-
-/* 2 RRSR */
-
-/* 2 ARFR */
-
-/* 2 AGGLEN_LMT_L */
-
-/* 2 RL */
-
-/* 2 DARFRC */
-
-/* 2 RARFRC */
-
-
-/*  */
-/*  */
-/*     0x0500h ~ 0x05FFh       EDCA Configuration */
-/*  */
-/*  */
-
-/* 2 EDCA setting */
-
-/* 2 EDCA_VO_PARAM */
-
-/* 2 SIFS_CCK */
-
-/* 2 SIFS_OFDM */
-
-/* 2 TBTT PROHIBIT */
-
-/* 2 REG_RD_CTRL */
-
-/* 2 BCN_CTRL */
-
-/* 2 ACMHWCTRL */
-
-
-/*  */
-/*  */
-/*     0x0600h ~ 0x07FFh       WMAC Configuration */
-/*  */
-/*  */
-
-/* 2 APSD_CTRL */
-
-/* 2 BWOPMODE */
-
-/* 2 TCR */
-
-/* 2 RCR */
-
-/* 2 RX_PKT_LIMIT */
-
-/* 2 RX_DLK_TIME */
-
-/* 2 MBIDCAMCFG */
-
-/* 2 AMPDU_MIN_SPACE */
-
-/* 2 RXERR_RPT */
-
-/* 2 SECCFG */
-
-
-/*  */
-/*  */
-/*     0xFE00h ~ 0xFE55h       RTL8723 SDIO Configuration */
-/*  */
-/*  */
-
-/*  I/O bus domain address mapping */
-#define WLAN_IOREG_BASE                        0x10260000
-#define FIRMWARE_FIFO_BASE             0x10270000
-#define TX_HIQ_BASE                    0x10310000
-#define TX_MIQ_BASE                    0x10320000
-#define TX_LOQ_BASE                    0x10330000
-#define RX_RX0FF_BASE                  0x10340000
-
-/*  SDIO host local register space mapping. */
-#define WLAN_IOREG_MSK                 0x7FFF
-#define WLAN_FIFO_MSK                  0x1FFF  /*  Aggregation Length[12:0] */
-#define WLAN_RX0FF_MSK                 0x0003
-
-#define WLAN_RX0FF_DEVICE_ID           7       /*  0b[16], 111b[15:13] */
-#define WLAN_IOREG_DEVICE_ID           8       /*  1b[16] */
-
-/*  8723 EFUSE */
-#define HWSET_MAX_SIZE                 256
-
-
-/* USB interrupt */
-#define        UHIMR_TIMEOUT2                  BIT(31)
-#define        UHIMR_TIMEOUT1                  BIT(30)
-#define        UHIMR_PSTIMEOUT                 BIT(29)
-#define        UHIMR_GTINT4                    BIT(28)
-#define        UHIMR_GTINT3                    BIT(27)
-#define        UHIMR_TXBCNERR                  BIT(26)
-#define        UHIMR_TXBCNOK                   BIT(25)
-#define        UHIMR_TSF_BIT32_TOGGLE          BIT(24)
-#define        UHIMR_BCNDMAINT3                BIT(23)
-#define        UHIMR_BCNDMAINT2                BIT(22)
-#define        UHIMR_BCNDMAINT1                BIT(21)
-#define        UHIMR_BCNDMAINT0                BIT(20)
-#define        UHIMR_BCNDOK3                   BIT(19)
-#define        UHIMR_BCNDOK2                   BIT(18)
-#define        UHIMR_BCNDOK1                   BIT(17)
-#define        UHIMR_BCNDOK0                   BIT(16)
-#define        UHIMR_HSISR_IND                 BIT(15)
-#define        UHIMR_BCNDMAINT_E               BIT(14)
-/* RSVD        BIT(13) */
-#define        UHIMR_CTW_END                   BIT(12)
-/* RSVD        BIT(11) */
-#define        UHIMR_C2HCMD                    BIT(10)
-#define        UHIMR_CPWM2                     BIT(9)
-#define        UHIMR_CPWM                      BIT(8)
-#define        UHIMR_HIGHDOK                   BIT(7)  /*  High Queue DMA OK
-                                                   Interrupt */
-#define        UHIMR_MGNTDOK                   BIT(6)  /*  Management Queue DMA OK
-                                                   Interrupt */
-#define        UHIMR_BKDOK                     BIT(5)  /*  AC_BK DMA OK Interrupt */
-#define        UHIMR_BEDOK                     BIT(4)  /*  AC_BE DMA OK Interrupt */
-#define        UHIMR_VIDOK                     BIT(3)  /*  AC_VI DMA OK Interrupt */
-#define        UHIMR_VODOK                     BIT(2)  /*  AC_VO DMA Interrupt */
-#define        UHIMR_RDU                       BIT(1)  /*  Receive Descriptor
-                                                   Unavailable */
-#define        UHIMR_ROK                       BIT(0)  /*  Receive DMA OK Interrupt */
-
-/*  USB Host Interrupt Status Extension bit */
-#define        UHIMR_BCNDMAINT7                BIT(23)
-#define        UHIMR_BCNDMAINT6                BIT(22)
-#define        UHIMR_BCNDMAINT5                BIT(21)
-#define        UHIMR_BCNDMAINT4                BIT(20)
-#define        UHIMR_BCNDOK7                   BIT(19)
-#define        UHIMR_BCNDOK6                   BIT(18)
-#define        UHIMR_BCNDOK5                   BIT(17)
-#define        UHIMR_BCNDOK4                   BIT(16)
-/*  bit14-15: RSVD */
-#define        UHIMR_ATIMEND_E                 BIT(13)
-#define        UHIMR_ATIMEND                   BIT(12)
-#define        UHIMR_TXERR                     BIT(11)
-#define        UHIMR_RXERR                     BIT(10)
-#define        UHIMR_TXFOVW                    BIT(9)
-#define        UHIMR_RXFOVW                    BIT(8)
-/*  bit2-7: RSVD */
-#define        UHIMR_OCPINT                    BIT(1)
-/*  bit0: RSVD */
-
-#define        REG_USB_HIMR                    0xFE38
-#define        REG_USB_HIMRE                   0xFE3C
-#define        REG_USB_HISR                    0xFE78
-#define        REG_USB_HISRE                   0xFE7C
-
-#define        USB_INTR_CPWM_OFFSET            16
-#define        USB_INTR_CONTENT_HISR_OFFSET    48
-#define        USB_INTR_CONTENT_HISRE_OFFSET   52
-#define        USB_INTR_CONTENT_LENGTH         56
-#define        USB_C2H_CMDID_OFFSET            0
-#define        USB_C2H_SEQ_OFFSET              1
-#define        USB_C2H_EVENT_OFFSET            2
-/*  */
-/*     General definitions */
-/*  */
-
-#endif
diff --git a/drivers/staging/rtl8723au/include/rtl8723a_sreset.h b/drivers/staging/rtl8723au/include/rtl8723a_sreset.h
deleted file mode 100644 (file)
index 6197910..0000000
+++ /dev/null
@@ -1,24 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#ifndef _RTL8723A_SRESET_H_
-#define _RTL8723A_SRESET_H_
-
-#include <osdep_service.h>
-#include <drv_types.h>
-#include <rtw_sreset.h>
-
-void rtl8723a_sreset_xmit_status_check(struct rtw_adapter *padapter);
-
-#endif
diff --git a/drivers/staging/rtl8723au/include/rtl8723a_xmit.h b/drivers/staging/rtl8723au/include/rtl8723a_xmit.h
deleted file mode 100644 (file)
index 7db29f4..0000000
+++ /dev/null
@@ -1,225 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#ifndef __RTL8723A_XMIT_H__
-#define __RTL8723A_XMIT_H__
-
-/*  */
-/*  Queue Select Value in TxDesc */
-/*  */
-#define QSLT_BK                                                        0x2/* 0x01 */
-#define QSLT_BE                                                        0x0
-#define QSLT_VI                                                        0x5/* 0x4 */
-#define QSLT_VO                                                        0x7/* 0x6 */
-#define QSLT_BEACON                                            0x10
-#define QSLT_HIGH                                              0x11
-#define QSLT_MGNT                                              0x12
-#define QSLT_CMD                                               0x13
-
-/*  */
-/* defined for TX DESC Operation */
-/*  */
-
-#define MAX_TID (15)
-
-/* OFFSET 0 */
-#define OFFSET_SZ      0
-#define OFFSET_SHT     16
-#define BMC            BIT(24)
-#define LSG            BIT(26)
-#define FSG            BIT(27)
-#define OWN            BIT(31)
-
-
-/* OFFSET 4 */
-#define PKT_OFFSET_SZ  0
-#define BK             BIT(6)
-#define QSEL_SHT       8
-#define Rate_ID_SHT    16
-#define NAVUSEHDR      BIT(20)
-#define PKT_OFFSET_SHT 26
-#define HWPC           BIT(31)
-
-/* OFFSET 8 */
-#define AGG_EN         BIT(29)
-
-/* OFFSET 12 */
-#define SEQ_SHT                16
-
-/* OFFSET 16 */
-#define QoS            BIT(6)
-#define HW_SEQ_EN      BIT(7)
-#define USERATE                BIT(8)
-#define DISDATAFB      BIT(10)
-#define DATA_SHORT     BIT(24)
-#define DATA_BW                BIT(25)
-
-/* OFFSET 20 */
-#define SGI            BIT(6)
-
-struct txdesc_8723a {
-       u32 pktlen:16;
-       u32 offset:8;
-       u32 bmc:1;
-       u32 htc:1;
-       u32 ls:1;
-       u32 fs:1;
-       u32 linip:1;
-       u32 noacm:1;
-       u32 gf:1;
-       u32 own:1;
-
-       u32 macid:5;
-       u32 agg_en:1;
-       u32 bk:1;
-       u32 rd_en:1;
-       u32 qsel:5;
-       u32 rd_nav_ext:1;
-       u32 lsig_txop_en:1;
-       u32 pifs:1;
-       u32 rate_id:4;
-       u32 navusehdr:1;
-       u32 en_desc_id:1;
-       u32 sectype:2;
-       u32 rsvd0424:2;
-       u32 pkt_offset:5;       /*  unit: 8 bytes */
-       u32 rsvd0431:1;
-
-       u32 rts_rc:6;
-       u32 data_rc:6;
-       u32 rsvd0812:2;
-       u32 bar_rty_th:2;
-       u32 rsvd0816:1;
-       u32 morefrag:1;
-       u32 raw:1;
-       u32 ccx:1;
-       u32 ampdu_density:3;
-       u32 bt_null:1;
-       u32 ant_sel_a:1;
-       u32 ant_sel_b:1;
-       u32 tx_ant_cck:2;
-       u32 tx_antl:2;
-       u32 tx_ant_ht:2;
-
-       u32 nextheadpage:8;
-       u32 tailpage:8;
-       u32 seq:12;
-       u32 cpu_handle:1;
-       u32 tag1:1;
-       u32 trigger_int:1;
-       u32 hwseq_en:1;
-
-       u32 rtsrate:5;
-       u32 ap_dcfe:1;
-       u32 hwseq_sel:2;
-       u32 userate:1;
-       u32 disrtsfb:1;
-       u32 disdatafb:1;
-       u32 cts2self:1;
-       u32 rtsen:1;
-       u32 hw_rts_en:1;
-       u32 port_id:1;
-       u32 rsvd1615:3;
-       u32 wait_dcts:1;
-       u32 cts2ap_en:1;
-       u32 data_sc:2;
-       u32 data_stbc:2;
-       u32 data_short:1;
-       u32 data_bw:1;
-       u32 rts_short:1;
-       u32 rts_bw:1;
-       u32 rts_sc:2;
-       u32 vcs_stbc:2;
-
-       u32 datarate:6;
-       u32 sgi:1;
-       u32 try_rate:1;
-       u32 data_ratefb_lmt:5;
-       u32 rts_ratefb_lmt:4;
-       u32 rty_lmt_en:1;
-       u32 data_rt_lmt:6;
-       u32 usb_txagg_num:8;
-
-       u32 txagg_a:5;
-       u32 txagg_b:5;
-       u32 use_max_len:1;
-       u32 max_agg_num:5;
-       u32 mcsg1_max_len:4;
-       u32 mcsg2_max_len:4;
-       u32 mcsg3_max_len:4;
-       u32 mcs7_sgi_max_len:4;
-
-       u32 checksum:16;        /*  TxBuffSize(PCIe)/CheckSum(USB) */
-       u32 mcsg4_max_len:4;
-       u32 mcsg5_max_len:4;
-       u32 mcsg6_max_len:4;
-       u32 mcs15_sgi_max_len:4;
-};
-
-#define txdesc_set_ccx_sw_8723a(txdesc, value) \
-       do { \
-               ((struct txdesc_8723a *)(txdesc))->mcsg4_max_len = (((value)>>8) & 0x0f); \
-               ((struct txdesc_8723a *)(txdesc))->mcs15_sgi_max_len= (((value)>>4) & 0x0f); \
-               ((struct txdesc_8723a *)(txdesc))->mcsg6_max_len = ((value) & 0x0f); \
-       } while (0)
-
-struct txrpt_ccx_8723a {
-       /* offset 0 */
-       u8 tag1:1;
-       u8 rsvd:4;
-       u8 int_bt:1;
-       u8 int_tri:1;
-       u8 int_ccx:1;
-
-       /* offset 1 */
-       u8 mac_id:5;
-       u8 pkt_drop:1;
-       u8 pkt_ok:1;
-       u8 bmc:1;
-
-       /* offset 2 */
-       u8 retry_cnt:6;
-       u8 lifetime_over:1;
-       u8 retry_over:1;
-
-       /* offset 3 */
-       u8 ccx_qtime0;
-       u8 ccx_qtime1;
-
-       /* offset 5 */
-       u8 final_data_rate;
-
-       /* offset 6 */
-       u8 sw1:4;
-       u8 qsel:4;
-
-       /* offset 7 */
-       u8 sw0;
-};
-
-#define txrpt_ccx_sw_8723a(txrpt_ccx) ((txrpt_ccx)->sw0 + ((txrpt_ccx)->sw1<<8))
-#define txrpt_ccx_qtime_8723a(txrpt_ccx) ((txrpt_ccx)->ccx_qtime0+((txrpt_ccx)->ccx_qtime1<<8))
-
-void handle_txrpt_ccx_8723a(struct rtw_adapter *adapter, void *buf);
-void rtl8723a_fill_fake_txdesc(struct rtw_adapter *padapter, u8 *pDesc, u32 BufferLen, u8 IsPsPoll, u8 IsBTQosNull);
-
-int rtl8723au_hal_xmitframe_enqueue(struct rtw_adapter *padapter, struct xmit_frame *pxmitframe);
-s32 rtl8723au_xmit_buf_handler(struct rtw_adapter *padapter);
-#define hal_xmit_handler rtl8723au_xmit_buf_handler
-bool rtl8723au_hal_xmit(struct rtw_adapter *padapter, struct xmit_frame *pxmitframe);
-int rtl8723au_mgnt_xmit(struct rtw_adapter *padapter, struct xmit_frame *pmgntframe);
-bool rtl8723au_xmitframe_complete(struct rtw_adapter *padapter, struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf);
-
-
-#endif
diff --git a/drivers/staging/rtl8723au/include/rtw_ap.h b/drivers/staging/rtl8723au/include/rtw_ap.h
deleted file mode 100644 (file)
index 55a708f..0000000
+++ /dev/null
@@ -1,51 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#ifndef __RTW_AP_H_
-#define __RTW_AP_H_
-
-#include <osdep_service.h>
-#include <drv_types.h>
-
-
-#ifdef CONFIG_8723AU_AP_MODE
-
-/* external function */
-
-void init_mlme_ap_info23a(struct rtw_adapter *padapter);
-void free_mlme_ap_info23a(struct rtw_adapter *padapter);
-/* void update_BCNTIM(struct rtw_adapter *padapter); */
-void rtw_add_bcn_ie(struct rtw_adapter *padapter, struct wlan_bssid_ex *pnetwork, u8 index, u8 *data, u8 len);
-void rtw_remove_bcn_ie(struct rtw_adapter *padapter, struct wlan_bssid_ex *pnetwork, u8 index);
-void update_beacon23a(struct rtw_adapter *padapter, u8 ie_id, u8 *oui, u8 tx);
-void add_RATid23a(struct rtw_adapter *padapter, struct sta_info *psta, u8 rssi_level);
-void expire_timeout_chk23a(struct rtw_adapter *padapter);
-void update_sta_info23a_apmode23a(struct rtw_adapter *padapter, struct sta_info *psta);
-int rtw_check_beacon_data23a(struct rtw_adapter *padapter,
-                            struct ieee80211_mgmt *mgmt, unsigned int len);
-void rtw_ap_restore_network(struct rtw_adapter *padapter);
-void rtw_set_macaddr_acl23a(struct rtw_adapter *padapter, int mode);
-
-void associated_clients_update23a(struct rtw_adapter *padapter, u8 updated);
-void bss_cap_update_on_sta_join23a(struct rtw_adapter *padapter, struct sta_info *psta);
-u8 bss_cap_update_on_sta_leave23a(struct rtw_adapter *padapter, struct sta_info *psta);
-void sta_info_update23a(struct rtw_adapter *padapter, struct sta_info *psta);
-void ap_sta_info_defer_update23a(struct rtw_adapter *padapter, struct sta_info *psta);
-u8 ap_free_sta23a(struct rtw_adapter *padapter, struct sta_info *psta, bool active, u16 reason);
-int rtw_sta_flush23a(struct rtw_adapter *padapter);
-void start_ap_mode23a(struct rtw_adapter *padapter);
-void stop_ap_mode23a(struct rtw_adapter *padapter);
-#endif /* end of CONFIG_8723AU_AP_MODE */
-
-#endif
diff --git a/drivers/staging/rtl8723au/include/rtw_cmd.h b/drivers/staging/rtl8723au/include/rtw_cmd.h
deleted file mode 100644 (file)
index d1fa95d..0000000
+++ /dev/null
@@ -1,815 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#ifndef __RTW_CMD_H_
-#define __RTW_CMD_H_
-
-#include <wlan_bssdef.h>
-#include <rtw_rf.h>
-
-#define C2H_MEM_SZ (16*1024)
-
-#include <osdep_service.h>
-#include <ieee80211.h> /*  <ieee80211/ieee80211.h> */
-
-
-#define MAX_CMDSZ      1024
-#define MAX_RSPSZ      512
-#define MAX_EVTSZ      1024
-
-#define CMDBUFF_ALIGN_SZ 512
-
-struct cmd_obj {
-       struct work_struct work;
-       struct rtw_adapter *padapter;
-       u16     cmdcode;
-       int     res;
-       u32     cmdsz;
-       u8      *parmbuf;
-       u8      *rsp;
-       u32     rspsz;
-};
-
-struct cmd_priv {
-       struct workqueue_struct *wq;
-       u32     cmd_issued_cnt;
-       u32     cmd_done_cnt;
-       u32     rsp_cnt;
-       struct rtw_adapter *padapter;
-};
-
-#define C2H_QUEUE_MAX_LEN 10
-
-struct evt_priv {
-       struct workqueue_struct *wq;
-       struct work_struct irq_wk;
-};
-
-#define init_h2fwcmd_w_parm_no_rsp(pcmd, pparm, code) \
-do {\
-       pcmd->cmdcode = code;\
-       pcmd->parmbuf = (u8 *)(pparm);\
-       pcmd->cmdsz = sizeof (*pparm);\
-       pcmd->rsp = NULL;\
-       pcmd->rspsz = 0;\
-} while(0)
-
-struct c2h_evt_hdr {
-       u8 id:4;
-       u8 plen:4;
-       u8 seq;
-       u8 payload[0];
-};
-
-/*
- * Do not reorder - this allows for struct evt_work to be passed on to
- * rtw_c2h_wk_cmd23a() as a 'struct c2h_evt_hdr *' without making an
- * additional copy.
- */
-struct evt_work {
-       union {
-               struct c2h_evt_hdr c2h_evt;
-               u8 buf[16];
-       } u;
-       struct work_struct work;
-       struct rtw_adapter *adapter;
-};
-
-#define c2h_evt_exist(c2h_evt) ((c2h_evt)->id || (c2h_evt)->plen)
-
-void rtw_evt_work(struct work_struct *work);
-
-int rtw_enqueue_cmd23a(struct cmd_priv *pcmdpriv, struct cmd_obj *obj);
-void rtw_free_cmd_obj23a(struct cmd_obj *pcmd);
-
-int rtw_cmd_thread23a(void *context);
-
-int rtw_init_cmd_priv23a(struct cmd_priv *pcmdpriv);
-
-u32 rtw_init_evt_priv23a (struct evt_priv *pevtpriv);
-void rtw_free_evt_priv23a (struct evt_priv *pevtpriv);
-void rtw_evt_notify_isr(struct evt_priv *pevtpriv);
-
-enum rtw_drvextra_cmd_id
-{
-       NONE_WK_CID,
-       DYNAMIC_CHK_WK_CID,
-       DM_CTRL_WK_CID,
-       PBC_POLLING_WK_CID,
-       POWER_SAVING_CTRL_WK_CID,/* IPS,AUTOSuspend */
-       LPS_CTRL_WK_CID,
-       ANT_SELECT_WK_CID,
-       P2P_PS_WK_CID,
-       P2P_PROTO_WK_CID,
-       CHECK_HIQ_WK_CID,/* for softap mode, check hi queue if empty */
-       C2H_WK_CID,
-       RTP_TIMER_CFG_WK_CID,
-       MAX_WK_CID
-};
-
-enum LPS_CTRL_TYPE
-{
-       LPS_CTRL_SCAN=0,
-       LPS_CTRL_JOINBSS=1,
-       LPS_CTRL_CONNECT=2,
-       LPS_CTRL_DISCONNECT=3,
-       LPS_CTRL_SPECIAL_PACKET=4,
-       LPS_CTRL_LEAVE=5,
-};
-
-enum RFINTFS {
-       SWSI,
-       HWSI,
-       HWPI,
-};
-
-/*
-Caller Mode: Infra, Ad-HoC(C)
-
-Notes: To enter USB suspend mode
-
-Command Mode
-
-*/
-struct usb_suspend_parm {
-       u32 action;/*  1: sleep, 0:resume */
-};
-
-/*
-Caller Mode: Infra, Ad-HoC
-
-Notes: To join a known BSS.
-
-Command-Event Mode
-
-*/
-
-/*
-Caller Mode: Infra, Ad-HoC(C)
-
-Notes: To disconnect the current associated BSS
-
-Command Mode
-
-*/
-struct disconnect_parm {
-       u32 deauth_timeout_ms;
-};
-
-struct setopmode_parm {
-       enum nl80211_iftype mode;
-};
-
-/*
-Caller Mode: AP, Ad-HoC, Infra
-
-Notes: To ask RTL8711 performing site-survey
-
-Command-Event Mode
-
-*/
-
-#define RTW_SSID_SCAN_AMOUNT 9 /*  for WEXT_CSCAN_AMOUNT 9 */
-#define RTW_CHANNEL_SCAN_AMOUNT (14+37)
-struct sitesurvey_parm {
-       int scan_mode;  /* active: 1, passive: 0 */
-       u8 ssid_num;
-       u8 ch_num;
-       struct cfg80211_ssid ssid[RTW_SSID_SCAN_AMOUNT];
-       struct rtw_ieee80211_channel ch[RTW_CHANNEL_SCAN_AMOUNT];
-};
-
-/*
-Caller Mode: Any
-
-Notes: To set the auth type of RTL8711. open/shared/802.1x
-
-Command Mode
-
-*/
-struct setauth_parm {
-       u8 mode;  /* 0: legacy open, 1: legacy shared 2: 802.1x */
-       u8 _1x;   /* 0: PSK, 1: TLS */
-       u8 rsvd[2];
-};
-
-/*
-Caller Mode: Infra
-
-a. algorithm: wep40, wep104, tkip & aes
-b. keytype: grp key/unicast key
-c. key contents
-
-when shared key ==> keyid is the camid
-when 802.1x ==> keyid [0:1] ==> grp key
-when 802.1x ==> keyid > 2 ==> unicast key
-
-*/
-struct setkey_parm {
-       u32     algorithm;      /*  encryption algorithm, could be none, wep40, TKIP, CCMP, wep104 */
-       u8      keyid;
-       u8      grpkey;         /*  1: this is the grpkey for 802.1x. 0: this is the unicast key for 802.1x */
-       u8      set_tx;         /*  1: main tx key for wep. 0: other key. */
-       u8      key[16];        /*  this could be 40 or 104 */
-};
-
-/*
-When in AP or Ad-Hoc mode, this is used to
-allocate an sw/hw entry for a newly associated sta.
-
-Command
-
-when shared key ==> algorithm/keyid
-
-*/
-struct set_stakey_parm {
-       u8      addr[ETH_ALEN];
-       u8      id;/*  currently for erasing cam entry if algorithm == _NO_PRIVACY_ */
-       u32     algorithm;
-       u8      key[16];
-};
-
-struct set_stakey_rsp {
-       u8      addr[ETH_ALEN];
-       u8      keyid;
-       u8      rsvd;
-};
-
-/*
-Caller Ad-Hoc/AP
-
-Command -Rsp(AID == CAMID) mode
-
-This is to force fw to add an sta_data entry per driver's request.
-
-FW will write an cam entry associated with it.
-
-*/
-struct set_assocsta_parm {
-       u8      addr[ETH_ALEN];
-};
-
-struct set_assocsta_rsp {
-       u8      cam_id;
-       u8      rsvd[3];
-};
-
-/*
-       Caller Ad-Hoc/AP
-
-       Command mode
-
-       This is to force fw to del an sta_data entry per driver's request
-
-       FW will invalidate the cam entry associated with it.
-
-*/
-struct del_assocsta_parm {
-       u8      addr[ETH_ALEN];
-};
-
-/*
-Caller Mode: AP/Ad-HoC(M)
-
-Notes: To notify fw that given staid has changed its power state
-
-Command Mode
-
-*/
-struct setstapwrstate_parm {
-       u8      staid;
-       u8      status;
-       u8      hwaddr[6];
-};
-
-/*
-Caller Mode: Any
-
-Notes: To setup the basic rate of RTL8711
-
-Command Mode
-
-*/
-struct setbasicrate_parm {
-       u8      basicrates[NumRates];
-};
-
-/*
-Caller Mode: Any
-
-Notes: To read the current basic rate
-
-Command-Rsp Mode
-
-*/
-struct getbasicrate_parm {
-       u32 rsvd;
-};
-
-struct getbasicrate_rsp {
-       u8 basicrates[NumRates];
-};
-
-/*
-Caller Mode: Any
-
-Notes: To setup the data rate of RTL8711
-
-Command Mode
-
-*/
-struct setdatarate_parm {
-       u8      mac_id;
-       u8      datarates[NumRates];
-};
-
-/*
-Caller Mode: Any
-
-Notes: To read the current data rate
-
-Command-Rsp Mode
-
-*/
-struct getdatarate_parm {
-       u32 rsvd;
-};
-
-struct getdatarate_rsp {
-       u8 datarates[NumRates];
-};
-
-
-/*
-Caller Mode: Any
-AP: AP can use the info for the contents of beacon frame
-Infra: STA can use the info when sitesurveying
-Ad-HoC(M): Like AP
-Ad-HoC(C): Like STA
-
-
-Notes: To set the phy capability of the NIC
-
-Command Mode
-
-*/
-
-struct setphyinfo_parm {
-       struct regulatory_class class_sets[NUM_REGULATORYS];
-       u8      status;
-};
-
-struct getphyinfo_parm {
-       u32 rsvd;
-};
-
-struct getphyinfo_rsp {
-       struct regulatory_class class_sets[NUM_REGULATORYS];
-       u8      status;
-};
-
-/*
-Caller Mode: Any
-
-Notes: To set the channel/modem/band
-This command will be used when channel/modem/band is changed.
-
-Command Mode
-
-*/
-struct setphy_parm {
-       u8      rfchannel;
-       u8      modem;
-};
-
-/*
-Caller Mode: Any
-
-Notes: To get the current setting of channel/modem/band
-
-Command-Rsp Mode
-
-*/
-struct getphy_parm {
-       u32 rsvd;
-};
-
-struct getphy_rsp {
-       u8      rfchannel;
-       u8      modem;
-};
-
-struct readBB_parm {
-       u8      offset;
-};
-
-struct readBB_rsp {
-       u8      value;
-};
-
-struct readTSSI_parm {
-       u8      offset;
-};
-
-struct readTSSI_rsp {
-       u8      value;
-};
-
-struct writeBB_parm {
-       u8      offset;
-       u8      value;
-};
-
-struct readRF_parm {
-       u8      offset;
-};
-
-struct readRF_rsp {
-       u32     value;
-};
-
-struct writeRF_parm {
-       u32     offset;
-       u32     value;
-};
-
-struct getrfintfs_parm {
-       u8      rfintfs;
-};
-
-struct Tx_Beacon_param {
-       struct wlan_bssid_ex network;
-};
-
-/*  CMD param Formart for driver extra cmd handler */
-struct drvextra_cmd_parm {
-       int ec_id; /* extra cmd id */
-       int type_size; /*  Can use this field as the type id or command size */
-       unsigned char *pbuf;
-};
-
-/*------------------- Below are used for RF/BB tunning ---------------------*/
-
-struct setantenna_parm {
-       u8      tx_antset;
-       u8      rx_antset;
-       u8      tx_antenna;
-       u8      rx_antenna;
-};
-
-struct enrateadaptive_parm {
-       u32     en;
-};
-
-struct settxagctbl_parm {
-       u32     txagc[MAX_RATES_LENGTH];
-};
-
-struct gettxagctbl_parm {
-       u32 rsvd;
-};
-
-struct gettxagctbl_rsp {
-       u32     txagc[MAX_RATES_LENGTH];
-};
-
-struct setagcctrl_parm {
-       u32     agcctrl;                /*  0: pure hw, 1: fw */
-};
-
-struct setssup_parm    {
-       u32     ss_ForceUp[MAX_RATES_LENGTH];
-};
-
-struct getssup_parm    {
-       u32 rsvd;
-};
-
-struct getssup_rsp     {
-       u8      ss_ForceUp[MAX_RATES_LENGTH];
-};
-
-struct setssdlevel_parm        {
-       u8      ss_DLevel[MAX_RATES_LENGTH];
-};
-
-struct getssdlevel_parm        {
-       u32 rsvd;
-};
-
-struct getssdlevel_rsp {
-       u8      ss_DLevel[MAX_RATES_LENGTH];
-};
-
-struct setssulevel_parm        {
-       u8      ss_ULevel[MAX_RATES_LENGTH];
-};
-
-struct getssulevel_parm        {
-       u32 rsvd;
-};
-
-struct getssulevel_rsp {
-       u8      ss_ULevel[MAX_RATES_LENGTH];
-};
-
-struct setcountjudge_parm {
-       u8      count_judge[MAX_RATES_LENGTH];
-};
-
-struct getcountjudge_parm {
-       u32 rsvd;
-};
-
-struct getcountjudge_rsp {
-       u8      count_judge[MAX_RATES_LENGTH];
-};
-
-struct setratable_parm {
-       u8 ss_ForceUp[NumRates];
-       u8 ss_ULevel[NumRates];
-       u8 ss_DLevel[NumRates];
-       u8 count_judge[NumRates];
-};
-
-struct getratable_parm {
-       uint rsvd;
-};
-
-struct getratable_rsp {
-       u8 ss_ForceUp[NumRates];
-       u8 ss_ULevel[NumRates];
-       u8 ss_DLevel[NumRates];
-       u8 count_judge[NumRates];
-};
-
-/* to get TX,RX retry count */
-struct gettxretrycnt_parm{
-       unsigned int rsvd;
-};
-struct gettxretrycnt_rsp{
-       unsigned long tx_retrycnt;
-};
-
-struct getrxretrycnt_parm{
-       unsigned int rsvd;
-};
-struct getrxretrycnt_rsp{
-       unsigned long rx_retrycnt;
-};
-
-/* to get BCNOK,BCNERR count */
-struct getbcnokcnt_parm{
-       unsigned int rsvd;
-};
-struct getbcnokcnt_rsp{
-       unsigned long  bcnokcnt;
-};
-
-struct getbcnerrcnt_parm{
-       unsigned int rsvd;
-};
-struct getbcnerrcnt_rsp{
-       unsigned long bcnerrcnt;
-};
-
-/*  to get current TX power level */
-struct getcurtxpwrlevel_parm{
-       unsigned int rsvd;
-};
-
-struct getcurtxpwrlevel_rsp{
-       unsigned short tx_power;
-};
-
-struct setprobereqextraie_parm {
-       unsigned char e_id;
-       unsigned char ie_len;
-       unsigned char ie[0];
-};
-
-struct setassocreqextraie_parm {
-       unsigned char e_id;
-       unsigned char ie_len;
-       unsigned char ie[0];
-};
-
-struct setproberspextraie_parm {
-       unsigned char e_id;
-       unsigned char ie_len;
-       unsigned char ie[0];
-};
-
-struct setassocrspextraie_parm {
-       unsigned char e_id;
-       unsigned char ie_len;
-       unsigned char ie[0];
-};
-
-struct addBaReq_parm {
-       unsigned int tid;
-       u8      addr[ETH_ALEN];
-};
-
-/*H2C Handler index: 46 */
-struct set_ch_parm {
-       u8 ch;
-       u8 bw;
-       u8 ch_offset;
-};
-
-/*H2C Handler index: 59 */
-struct SetChannelPlan_param {
-       u8 channel_plan;
-};
-
-/*H2C Handler index: 60 */
-struct LedBlink_param {
-       struct led_8723a *pLed;
-};
-
-/*H2C Handler index: 61 */
-struct SetChannelSwitch_param {
-       u8 new_ch_no;
-};
-
-/*H2C Handler index: 62 */
-struct TDLSoption_param {
-       u8 addr[ETH_ALEN];
-       u8 option;
-};
-
-#define GEN_CMD_CODE(cmd)      cmd ## _CMD_
-
-
-/*
-
-Result:
-0x00: success
-0x01: success, and check Response.
-0x02: cmd ignored due to duplicated sequcne number
-0x03: cmd dropped due to invalid cmd code
-0x04: reserved.
-
-*/
-
-#define H2C_RSP_OFFSET                 512
-
-#define H2C_SUCCESS                    0x00
-#define H2C_SUCCESS_RSP                        0x01
-#define H2C_DUPLICATED                 0x02
-#define H2C_DROPPED                    0x03
-#define H2C_PARAMETERS_ERROR           0x04
-#define H2C_REJECTED                   0x05
-#define H2C_CMD_OVERFLOW               0x06
-#define H2C_RESERVED                   0x07
-
-int rtw_setassocsta_cmd(struct rtw_adapter  *padapter, u8 *mac_addr);
-int rtw_setstandby_cmd(struct rtw_adapter *padapter, uint action);
-int rtw_sitesurvey_cmd23a(struct rtw_adapter  *padapter, struct cfg80211_ssid *ssid, int ssid_num, struct rtw_ieee80211_channel *ch, int ch_num);
-int rtw_createbss_cmd23a(struct rtw_adapter  *padapter);
-int rtw_createbss_cmd23a_ex(struct rtw_adapter  *padapter, unsigned char *pbss, unsigned int sz);
-int rtw_setphy_cmd(struct rtw_adapter  *padapter, u8 modem, u8 ch);
-int rtw_setstakey_cmd23a(struct rtw_adapter  *padapter, u8 *psta, u8 unicast_key);
-int rtw_clearstakey_cmd23a(struct rtw_adapter *padapter, u8 *psta, u8 entry, u8 enqueue);
-int rtw_joinbss_cmd23a(struct rtw_adapter  *padapter, struct wlan_network* pnetwork);
-int rtw_disassoc_cmd23a(struct rtw_adapter *padapter, u32 deauth_timeout_ms, bool enqueue);
-int rtw_setopmode_cmd23a(struct rtw_adapter *padapter, enum nl80211_iftype ifmode);
-int rtw_setdatarate_cmd(struct rtw_adapter  *padapter, u8 *rateset);
-int rtw_setbasicrate_cmd(struct rtw_adapter  *padapter, u8 *rateset);
-int rtw_setbbreg_cmd(struct rtw_adapter *padapter, u8 offset, u8 val);
-int rtw_setrfreg_cmd(struct rtw_adapter *padapter, u8 offset, u32 val);
-int rtw_getbbreg_cmd(struct rtw_adapter *padapter, u8 offset, u8 *pval);
-int rtw_getrfreg_cmd(struct rtw_adapter *padapter, u8 offset, u8 *pval);
-int rtw_setrfintfs_cmd(struct rtw_adapter  *padapter, u8 mode);
-int rtw_setrttbl_cmd(struct rtw_adapter  *padapter, struct setratable_parm *prate_table);
-int rtw_getrttbl_cmd(struct rtw_adapter  *padapter, struct getratable_rsp *pval);
-
-int rtw_gettssi_cmd(struct rtw_adapter  *padapter, u8 offset, u8 *pval);
-int rtw_setfwdig_cmd(struct rtw_adapter*padapter, u8 type);
-int rtw_setfwra_cmd(struct rtw_adapter*padapter, u8 type);
-
-int rtw_addbareq_cmd23a(struct rtw_adapter*padapter, u8 tid, u8 *addr);
-
-int rtw_dynamic_chk_wk_cmd23a(struct rtw_adapter *adapter);
-
-int rtw_lps_ctrl_wk_cmd23a(struct rtw_adapter*padapter, u8 lps_ctrl_type, u8 enqueue);
-
-int rtw_ps_cmd23a(struct rtw_adapter*padapter);
-
-#ifdef CONFIG_8723AU_AP_MODE
-int rtw_chk_hi_queue_cmd23a(struct rtw_adapter*padapter);
-#endif
-
-int rtw_set_chplan_cmd(struct rtw_adapter*padapter, u8 chplan, u8 enqueue);
-int rtw_led_blink_cmd(struct rtw_adapter*padapter, struct led_8723a *pLed);
-int rtw_set_csa_cmd(struct rtw_adapter*padapter, u8 new_ch_no);
-
-int rtw_c2h_wk_cmd23a(struct rtw_adapter *padapter, u8 *c2h_evt);
-
-int rtw_drvextra_cmd_hdl23a(struct rtw_adapter *padapter, const u8 *pbuf);
-
-void rtw_survey_cmd_callback23a(struct rtw_adapter  *padapter, struct cmd_obj *pcmd);
-void rtw_disassoc_cmd23a_callback(struct rtw_adapter  *padapter, struct cmd_obj *pcmd);
-void rtw_joinbss_cmd23a_callback(struct rtw_adapter  *padapter, struct cmd_obj *pcmd);
-void rtw_createbss_cmd23a_callback(struct rtw_adapter  *padapter, struct cmd_obj *pcmd);
-void rtw_getbbrfreg_cmdrsp_callback23a(struct rtw_adapter  *padapter, struct cmd_obj *pcmd);
-
-void rtw_setstaKey_cmdrsp_callback23a(struct rtw_adapter  *padapter,  struct cmd_obj *pcmd);
-void rtw_setassocsta_cmdrsp_callback23a(struct rtw_adapter  *padapter,  struct cmd_obj *pcmd);
-
-struct _cmd_callback {
-       u32     cmd_code;
-       void (*callback)(struct rtw_adapter  *padapter, struct cmd_obj *cmd);
-};
-
-enum rtw_h2c_cmd {
-       GEN_CMD_CODE(_Read_MACREG) ,    /*0*/
-       GEN_CMD_CODE(_Write_MACREG) ,
-       GEN_CMD_CODE(_Read_BBREG) ,
-       GEN_CMD_CODE(_Write_BBREG) ,
-       GEN_CMD_CODE(_Read_RFREG) ,
-       GEN_CMD_CODE(_Write_RFREG) , /*5*/
-       GEN_CMD_CODE(_Read_EEPROM) ,
-       GEN_CMD_CODE(_Write_EEPROM) ,
-       GEN_CMD_CODE(_Read_EFUSE) ,
-       GEN_CMD_CODE(_Write_EFUSE) ,
-
-       GEN_CMD_CODE(_Read_CAM) ,       /*10*/
-       GEN_CMD_CODE(_Write_CAM) ,
-       GEN_CMD_CODE(_setBCNITV),
-       GEN_CMD_CODE(_setMBIDCFG),
-       GEN_CMD_CODE(_JoinBss),   /*14*/
-       GEN_CMD_CODE(_DisConnect) , /*15*/
-       GEN_CMD_CODE(_CreateBss) ,
-       GEN_CMD_CODE(_SetOpMode) ,
-       GEN_CMD_CODE(_SiteSurvey),  /*18*/
-       GEN_CMD_CODE(_SetAuth) ,
-
-       GEN_CMD_CODE(_SetKey) , /*20*/
-       GEN_CMD_CODE(_SetStaKey) ,
-       GEN_CMD_CODE(_SetAssocSta) ,
-       GEN_CMD_CODE(_DelAssocSta) ,
-       GEN_CMD_CODE(_SetStaPwrState) ,
-       GEN_CMD_CODE(_SetBasicRate) , /*25*/
-       GEN_CMD_CODE(_GetBasicRate) ,
-       GEN_CMD_CODE(_SetDataRate) ,
-       GEN_CMD_CODE(_GetDataRate) ,
-       GEN_CMD_CODE(_SetPhyInfo) ,
-
-       GEN_CMD_CODE(_GetPhyInfo) ,     /*30*/
-       GEN_CMD_CODE(_SetPhy) ,
-       GEN_CMD_CODE(_GetPhy) ,
-       GEN_CMD_CODE(_readRssi) ,
-       GEN_CMD_CODE(_readGain) ,
-       GEN_CMD_CODE(_SetAtim) , /*35*/
-       GEN_CMD_CODE(_SetPwrMode) ,
-       GEN_CMD_CODE(_JoinbssRpt),
-       GEN_CMD_CODE(_SetRaTable) ,
-       GEN_CMD_CODE(_GetRaTable) ,
-
-       GEN_CMD_CODE(_GetCCXReport), /*40*/
-       GEN_CMD_CODE(_GetDTMReport),
-       GEN_CMD_CODE(_GetTXRateStatistics),
-       GEN_CMD_CODE(_SetUsbSuspend),
-       GEN_CMD_CODE(_SetH2cLbk),
-       GEN_CMD_CODE(_AddBAReq) , /*45*/
-       GEN_CMD_CODE(_SetChannel), /*46*/
-       GEN_CMD_CODE(_SetTxPower),
-       GEN_CMD_CODE(_SwitchAntenna),
-       GEN_CMD_CODE(_SetCrystalCap),
-       GEN_CMD_CODE(_SetSingleCarrierTx), /*50*/
-
-       GEN_CMD_CODE(_SetSingleToneTx),/*51*/
-       GEN_CMD_CODE(_SetCarrierSuppressionTx),
-       GEN_CMD_CODE(_SetContinuousTx),
-       GEN_CMD_CODE(_SwitchBandwidth), /*54*/
-       GEN_CMD_CODE(_TX_Beacon), /*55*/
-
-       GEN_CMD_CODE(_Set_MLME_EVT), /*56*/
-       GEN_CMD_CODE(_Set_Drv_Extra), /*57*/
-       GEN_CMD_CODE(_Set_H2C_MSG), /*58*/
-
-       GEN_CMD_CODE(_SetChannelPlan), /*59*/
-       GEN_CMD_CODE(_LedBlink), /*60*/
-
-       GEN_CMD_CODE(_SetChannelSwitch), /*61*/
-       GEN_CMD_CODE(_TDLS), /*62*/
-
-       MAX_H2CCMD
-};
-
-extern struct _cmd_callback    rtw_cmd_callback[];
-
-#endif /*  _CMD_H_ */
diff --git a/drivers/staging/rtl8723au/include/rtw_debug.h b/drivers/staging/rtl8723au/include/rtw_debug.h
deleted file mode 100644 (file)
index 159183e..0000000
+++ /dev/null
@@ -1,191 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- *
- ******************************************************************************/
-#ifndef __RTW_DEBUG_H__
-#define __RTW_DEBUG_H__
-
-#include <osdep_service.h>
-#include <drv_types.h>
-
-#define _drv_always_                   1
-#define _drv_emerg_                    2
-#define _drv_alert_                    3
-#define _drv_err_                      4
-#define        _drv_warning_                   5
-#define _drv_notice_                   6
-#define _drv_info_                     7
-#define        _drv_debug_                     8
-
-#define _module_rtl871x_xmit_c_                BIT(0)
-#define _module_xmit_osdep_c_          BIT(1)
-#define _module_rtl871x_recv_c_                BIT(2)
-#define _module_recv_osdep_c_          BIT(3)
-#define _module_rtl871x_mlme_c_                BIT(4)
-#define _module_mlme_osdep_c_          BIT(5)
-#define _module_rtl871x_sta_mgt_c_     BIT(6)
-#define _module_rtl871x_cmd_c_         BIT(7)
-#define _module_cmd_osdep_c_           BIT(8)
-#define _module_rtl871x_io_c_          BIT(9)
-#define _module_io_osdep_c_            BIT(10)
-#define _module_os_intfs_c_            BIT(11)
-#define _module_rtl871x_security_c_    BIT(12)
-#define _module_rtl871x_eeprom_c_      BIT(13)
-#define _module_hal_init_c_            BIT(14)
-#define _module_hci_hal_init_c_                BIT(15)
-#define _module_rtl871x_ioctl_c_       BIT(16)
-#define _module_rtl871x_ioctl_set_c_   BIT(17)
-#define _module_rtl871x_ioctl_query_c_ BIT(18)
-#define _module_rtl871x_pwrctrl_c_     BIT(19)
-#define _module_hci_intfs_c_           BIT(20)
-#define _module_hci_ops_c_             BIT(21)
-#define _module_osdep_service_c_       BIT(22)
-#define _module_mp_                    BIT(23)
-#define _module_hci_ops_os_c_          BIT(24)
-#define _module_rtl871x_ioctl_os_c     BIT(25)
-#define _module_rtl8712_cmd_c_         BIT(26)
-#define        _module_rtl8192c_xmit_c_        BIT(28)
-#define _module_hal_xmit_c_            BIT(28) /* duplication intentional */
-#define _module_efuse_                 BIT(29)
-#define _module_rtl8712_recv_c_                BIT(30)
-#define _module_rtl8712_led_c_         BIT(31)
-
-#undef _MODULE_DEFINE_
-
-#if defined _RTW_XMIT_C_
-       #define _MODULE_DEFINE_ _module_rtl871x_xmit_c_
-#elif defined _XMIT_OSDEP_C_
-       #define _MODULE_DEFINE_ _module_xmit_osdep_c_
-#elif defined _RTW_RECV_C_
-       #define _MODULE_DEFINE_ _module_rtl871x_recv_c_
-#elif defined _RECV_OSDEP_C_
-       #define _MODULE_DEFINE_ _module_recv_osdep_c_
-#elif defined _RTW_MLME_C_
-       #define _MODULE_DEFINE_ _module_rtl871x_mlme_c_
-#elif defined _MLME_OSDEP_C_
-       #define _MODULE_DEFINE_ _module_mlme_osdep_c_
-#elif defined _RTW_MLME_EXT_C_
-       #define _MODULE_DEFINE_ 1
-#elif defined _RTW_STA_MGT_C_
-       #define _MODULE_DEFINE_ _module_rtl871x_sta_mgt_c_
-#elif defined _RTW_CMD_C_
-       #define _MODULE_DEFINE_ _module_rtl871x_cmd_c_
-#elif defined _CMD_OSDEP_C_
-       #define _MODULE_DEFINE_ _module_cmd_osdep_c_
-#elif defined _RTW_IO_C_
-       #define _MODULE_DEFINE_ _module_rtl871x_io_c_
-#elif defined _IO_OSDEP_C_
-       #define _MODULE_DEFINE_ _module_io_osdep_c_
-#elif defined _OS_INTFS_C_
-       #define _MODULE_DEFINE_ _module_os_intfs_c_
-#elif defined _RTW_SECURITY_C_
-       #define _MODULE_DEFINE_ _module_rtl871x_security_c_
-#elif defined _RTW_EEPROM_C_
-       #define _MODULE_DEFINE_ _module_rtl871x_eeprom_c_
-#elif defined _HAL_INTF_C_
-       #define _MODULE_DEFINE_ _module_hal_init_c_
-#elif (defined _HCI_HAL_INIT_C_) || (defined _SDIO_HALINIT_C_)
-       #define _MODULE_DEFINE_ _module_hci_hal_init_c_
-#elif defined _RTL871X_IOCTL_C_
-       #define _MODULE_DEFINE_ _module_rtl871x_ioctl_c_
-#elif defined _RTL871X_IOCTL_SET_C_
-       #define _MODULE_DEFINE_ _module_rtl871x_ioctl_set_c_
-#elif defined _RTL871X_IOCTL_QUERY_C_
-       #define _MODULE_DEFINE_ _module_rtl871x_ioctl_query_c_
-#elif defined _RTL871X_PWRCTRL_C_
-       #define _MODULE_DEFINE_ _module_rtl871x_pwrctrl_c_
-#elif defined _RTW_PWRCTRL_C_
-       #define _MODULE_DEFINE_ 1
-#elif defined _HCI_INTF_C_
-       #define _MODULE_DEFINE_ _module_hci_intfs_c_
-#elif defined _HCI_OPS_C_
-       #define _MODULE_DEFINE_ _module_hci_ops_c_
-#elif defined _SDIO_OPS_C_
-       #define _MODULE_DEFINE_ 1
-#elif defined _OSDEP_HCI_INTF_C_
-       #define _MODULE_DEFINE_ _module_hci_intfs_c_
-#elif defined _OSDEP_SERVICE_C_
-       #define _MODULE_DEFINE_ _module_osdep_service_c_
-#elif defined _HCI_OPS_OS_C_
-       #define _MODULE_DEFINE_ _module_hci_ops_os_c_
-#elif defined _RTL871X_IOCTL_LINUX_C_
-       #define _MODULE_DEFINE_ _module_rtl871x_ioctl_os_c
-#elif defined _RTL8712_CMD_C_
-       #define _MODULE_DEFINE_ _module_rtl8712_cmd_c_
-#elif defined _RTL8192C_XMIT_C_
-       #define _MODULE_DEFINE_ 1
-#elif defined _RTL8723AS_XMIT_C_
-       #define _MODULE_DEFINE_ 1
-#elif defined _RTL8712_RECV_C_
-       #define _MODULE_DEFINE_ _module_rtl8712_recv_c_
-#elif defined _RTL8192CU_RECV_C_
-       #define _MODULE_DEFINE_ _module_rtl8712_recv_c_
-#elif defined _RTL871X_MLME_EXT_C_
-       #define _MODULE_DEFINE_ _module_mlme_osdep_c_
-#elif defined _RTW_MP_C_
-       #define _MODULE_DEFINE_ _module_mp_
-#elif defined _RTW_MP_IOCTL_C_
-       #define _MODULE_DEFINE_ _module_mp_
-#elif defined _RTW_EFUSE_C_
-       #define _MODULE_DEFINE_ _module_efuse_
-#endif
-
-#define DRIVER_PREFIX  "RTL8723AU: "
-#define DEBUG_LEVEL    (_drv_err_)
-#define DBG_8723A_LEVEL(_level, fmt, arg...)                           \
-       do {                                                            \
-               if (_level <= GlobalDebugLevel23A)                              \
-                       pr_info(DRIVER_PREFIX fmt, ##arg);\
-       } while (0)
-
-#define DBG_8723A(...)                                                 \
-       do {                                                            \
-               if (_drv_err_ <= GlobalDebugLevel23A)                   \
-                       pr_info(DRIVER_PREFIX __VA_ARGS__);             \
-       } while (0)
-
-#define MSG_8723A(...)                                                 \
-       do {                                                            \
-               if (_drv_err_ <= GlobalDebugLevel23A)                   \
-                       pr_info(DRIVER_PREFIX __VA_ARGS__);             \
-       } while (0)
-
-extern u32 GlobalDebugLevel23A;
-
-__printf(3, 4)
-void rt_trace(int comp, int level, const char *fmt, ...);
-
-#define RT_TRACE(_Comp, _Level, Fmt, ...)                              \
-do {                                                                   \
-       if (_Level <= GlobalDebugLevel23A)                              \
-               rt_trace(_Comp, _Level, Fmt, ##__VA_ARGS__);            \
-} while (0)
-
-#define RT_PRINT_DATA(_Comp, _Level, _TitleString, _HexData,           \
-                     _HexDataLen)                                      \
-       if (_Level <= GlobalDebugLevel23A) {                            \
-               int __i;                                                \
-               u8      *ptr = (u8 *)_HexData;                          \
-               pr_info("%s", DRIVER_PREFIX);                           \
-               pr_info(_TitleString);                                  \
-               for (__i = 0; __i < (int)_HexDataLen; __i++) {          \
-                       printk("%02X%s", ptr[__i],                      \
-                              (((__i + 1) % 4) == 0) ? "  " : " ");    \
-                       if (((__i + 1) % 16) == 0)                      \
-                               printk("\n");                           \
-               }                                                       \
-               printk("\n");                                           \
-       }
-
-#endif /* __RTW_DEBUG_H__ */
diff --git a/drivers/staging/rtl8723au/include/rtw_eeprom.h b/drivers/staging/rtl8723au/include/rtw_eeprom.h
deleted file mode 100644 (file)
index a86f36e..0000000
+++ /dev/null
@@ -1,135 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#ifndef __RTW_EEPROM_H__
-#define __RTW_EEPROM_H__
-
-#include <osdep_service.h>
-#include <drv_types.h>
-
-#define        RTL8712_EEPROM_ID                       0x8712
-/* define      EEPROM_MAX_SIZE                 256 */
-
-#define        HWSET_MAX_SIZE_512              512
-#define        EEPROM_MAX_SIZE                 HWSET_MAX_SIZE_512
-
-#define        CLOCK_RATE                                      50                      /* 100us */
-
-/*  EEPROM opcodes */
-#define EEPROM_READ_OPCODE             06
-#define EEPROM_WRITE_OPCODE            05
-#define EEPROM_ERASE_OPCODE            07
-#define EEPROM_EWEN_OPCODE             19      /*  Erase/write enable */
-#define EEPROM_EWDS_OPCODE             16      /*  Erase/write disable */
-
-/* Country codes */
-#define USA                                                    0x555320
-#define EUROPE                                         0x1 /* temp, should be provided later */
-#define JAPAN                                          0x2 /* temp, should be provided later */
-
-#define        EEPROM_CID_DEFAULT                      0x0
-#define        EEPROM_CID_ALPHA                                0x1
-#define        EEPROM_CID_Senao                                0x3
-#define        EEPROM_CID_NetCore                              0x5
-#define        EEPROM_CID_CAMEO                                0X8
-#define        EEPROM_CID_SITECOM                              0x9
-#define        EEPROM_CID_COREGA                               0xB
-#define        EEPROM_CID_EDIMAX_BELKIN                0xC
-#define        EEPROM_CID_SERCOMM_BELKIN               0xE
-#define        EEPROM_CID_CAMEO1                               0xF
-#define        EEPROM_CID_WNC_COREGA           0x12
-#define        EEPROM_CID_CLEVO                                0x13
-#define        EEPROM_CID_WHQL                         0xFE /*  added by chiyoko for dtm, 20090108 */
-
-/*  */
-/*  Customer ID, note that: */
-/*  This variable is initiailzed through EEPROM or registry, */
-/*  however, its definition may be different with that in EEPROM for */
-/*  EEPROM size consideration. So, we have to perform proper translation between them. */
-/*  Besides, CustomerID of registry has precedence of that of EEPROM. */
-/*  defined below. 060703, by rcnjko. */
-/*  */
-enum rt_customer_id
-{
-       RT_CID_DEFAULT = 0,
-       RT_CID_8187_ALPHA0 = 1,
-       RT_CID_8187_SERCOMM_PS = 2,
-       RT_CID_8187_HW_LED = 3,
-       RT_CID_8187_NETGEAR = 4,
-       RT_CID_WHQL = 5,
-       RT_CID_819x_CAMEO  = 6,
-       RT_CID_819x_RUNTOP = 7,
-       RT_CID_819x_Senao = 8,
-       RT_CID_TOSHIBA = 9,     /*  Merge by Jacken, 2008/01/31. */
-       RT_CID_819x_Netcore = 10,
-       RT_CID_Nettronix = 11,
-       RT_CID_DLINK = 12,
-       RT_CID_PRONET = 13,
-       RT_CID_COREGA = 14,
-       RT_CID_CHINA_MOBILE = 15,
-       RT_CID_819x_ALPHA = 16,
-       RT_CID_819x_Sitecom = 17,
-       RT_CID_CCX = 18, /*  It's set under CCX logo test and isn't demanded for CCX functions, but for test behavior like retry limit and tx report. By Bruce, 2009-02-17. */
-       RT_CID_819x_Lenovo = 19,
-       RT_CID_819x_QMI = 20,
-       RT_CID_819x_Edimax_Belkin = 21,
-       RT_CID_819x_Sercomm_Belkin = 22,
-       RT_CID_819x_CAMEO1 = 23,
-       RT_CID_819x_MSI = 24,
-       RT_CID_819x_Acer = 25,
-       RT_CID_819x_AzWave_ASUS = 26,
-       RT_CID_819x_AzWave = 27, /*  For AzWave in PCIe, The ID is AzWave use and not only Asus */
-       RT_CID_819x_HP = 28,
-       RT_CID_819x_WNC_COREGA = 29,
-       RT_CID_819x_Arcadyan_Belkin = 30,
-       RT_CID_819x_SAMSUNG = 31,
-       RT_CID_819x_CLEVO = 32,
-       RT_CID_819x_DELL = 33,
-       RT_CID_819x_PRONETS = 34,
-       RT_CID_819x_Edimax_ASUS = 35,
-       RT_CID_819x_CAMEO_NETGEAR = 36,
-       RT_CID_PLANEX = 37,
-       RT_CID_CC_C = 38,
-       RT_CID_819x_Xavi = 39,
-       RT_CID_819x_FUNAI_TV = 40,
-       RT_CID_819x_ALPHA_WD=41,
-};
-
-struct eeprom_priv {
-       u8              mac_addr[6];    /* PermanentAddress */
-       u8              bautoload_fail_flag;
-       u8              bloadfile_fail_flag;
-       u8              bloadmac_fail_flag;
-       /* u8           bempty; */
-       /* u8           sys_config; */
-       /* u8           config0; */
-       u16             channel_plan;
-       /* u8           country_string[3]; */
-       /* u8           tx_power_b[15]; */
-       /* u8           tx_power_g[15]; */
-       /* u8           tx_power_a[201]; */
-
-       u8              EepromOrEfuse;
-
-       u8              efuse_eeprom_data[HWSET_MAX_SIZE_512]; /* 92C:256bytes, 88E:512bytes, we use union set (512bytes) */
-};
-
-void eeprom_write16(struct rtw_adapter *padapter, u16 reg, u16 data);
-u16 eeprom_read16(struct rtw_adapter *padapter, u16 reg);
-void read_eeprom_content(struct rtw_adapter *padapter);
-void eeprom_read_sz(struct rtw_adapter *padapter, u16 reg, u8 *data, u32 sz);
-
-void read_eeprom_content_by_attrib(struct rtw_adapter *padapter);
-
-#endif  /* __RTL871X_EEPROM_H__ */
diff --git a/drivers/staging/rtl8723au/include/rtw_efuse.h b/drivers/staging/rtl8723au/include/rtw_efuse.h
deleted file mode 100644 (file)
index c577e26..0000000
+++ /dev/null
@@ -1,109 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- *
- ******************************************************************************/
-#ifndef __RTW_EFUSE_H__
-#define __RTW_EFUSE_H__
-
-#include <osdep_service.h>
-
-#define        EFUSE_ERROE_HANDLE              1
-
-#define        PG_STATE_HEADER                 0x01
-#define        PG_STATE_WORD_0         0x02
-#define        PG_STATE_WORD_1         0x04
-#define        PG_STATE_WORD_2         0x08
-#define        PG_STATE_WORD_3         0x10
-#define        PG_STATE_DATA                   0x20
-
-#define        PG_SWBYTE_H                     0x01
-#define        PG_SWBYTE_L                     0x02
-
-#define        PGPKT_DATA_SIZE         8
-
-#define        EFUSE_WIFI                              0
-#define        EFUSE_BT                                1
-
-enum _EFUSE_DEF_TYPE {
-       TYPE_EFUSE_MAX_SECTION                          = 0,
-       TYPE_EFUSE_REAL_CONTENT_LEN                     = 1,
-       TYPE_AVAILABLE_EFUSE_BYTES_BANK         = 2,
-       TYPE_AVAILABLE_EFUSE_BYTES_TOTAL        = 3,
-       TYPE_EFUSE_MAP_LEN                                      = 4,
-       TYPE_EFUSE_PROTECT_BYTES_BANK           = 5,
-       TYPE_EFUSE_CONTENT_LEN_BANK                     = 6,
-};
-
-/* E-Fuse */
-#define EFUSE_MAP_SIZE      256
-
-#define EFUSE_MAX_SIZE      512
-/* end of E-Fuse */
-
-#define                EFUSE_MAX_MAP_LEN               256
-#define                EFUSE_MAX_HW_SIZE               512
-#define                EFUSE_MAX_SECTION_BASE  16
-
-#define EXT_HEADER(header) ((header & 0x1F) == 0x0F)
-#define ALL_WORDS_DISABLED(wde)        ((wde & 0x0F) == 0x0F)
-#define GET_HDR_OFFSET_2_0(header) ( (header & 0xE0) >> 5)
-
-#define                EFUSE_REPEAT_THRESHOLD_                 3
-
-/*  */
-/*     The following is for BT Efuse definition */
-/*  */
-#define                EFUSE_BT_MAX_MAP_LEN            1024
-#define                EFUSE_MAX_BANK                  4
-#define                EFUSE_MAX_BT_BANK               (EFUSE_MAX_BANK-1)
-/*  */
-/*--------------------------Define Parameters-------------------------------*/
-#define                EFUSE_MAX_WORD_UNIT                     4
-
-/*------------------------------Define structure----------------------------*/
-struct pg_pkt_struct {
-       u8 offset;
-       u8 word_en;
-       u8 data[8];
-       u8 word_cnts;
-};
-
-/*------------------------Export global variable----------------------------*/
-
-u16    efuse_GetMaxSize23a(struct rtw_adapter *padapter);
-int    rtw_efuse_access23a(struct rtw_adapter *padapter, u8 bRead, u16 start_addr, u16 cnts, u8 *data);
-int    rtw_efuse_map_read23a(struct rtw_adapter *padapter, u16 addr, u16 cnts, u8 *data);
-u8     rtw_efuse_map_write(struct rtw_adapter *padapter, u16 addr, u16 cnts, u8 *data);
-int    rtw_BT_efuse_map_read23a(struct rtw_adapter *padapter, u16 addr, u16 cnts, u8 *data);
-u8     rtw_BT_efuse_map_write(struct rtw_adapter *padapter, u16 addr, u16 cnts, u8 *data);
-
-u16    Efuse_GetCurrentSize23a(struct rtw_adapter *pAdapter, u8 efuseType);
-u8     Efuse_CalculateWordCnts23a(u8 word_en);
-void   ReadEFuseByte23a(struct rtw_adapter *Adapter, u16 _offset, u8 *pbuf);
-void   EFUSE_GetEfuseDefinition23a(struct rtw_adapter *pAdapter, u8 efuseType, u8 type, void *pOut);
-int    efuse_OneByteRead23a(struct rtw_adapter *pAdapter, u16 addr, u8 *data);
-int    efuse_OneByteWrite23a(struct rtw_adapter *pAdapter, u16 addr, u8 data);
-
-void   Efuse_PowerSwitch23a(struct rtw_adapter *pAdapter, u8 bWrite,
-                            u8 PwrState);
-int    Efuse_PgPacketRead23a(struct rtw_adapter *pAdapter, u8 offset, u8 *data);
-int    Efuse_PgPacketWrite23a(struct rtw_adapter *pAdapter, u8 offset, u8 word_en, u8 *data);
-void   efuse_WordEnableDataRead23a(u8 word_en, u8 *sourdata, u8 *targetdata);
-u8     Efuse_WordEnableDataWrite23a(struct rtw_adapter *pAdapter, u16 efuse_addr, u8 word_en, u8 *data);
-
-u8     EFUSE_Read1Byte23a(struct rtw_adapter *pAdapter, u16 Address);
-void   EFUSE_ShadowMapUpdate23a(struct rtw_adapter *pAdapter, u8 efuseType);
-void   EFUSE_ShadowRead23a(struct rtw_adapter *pAdapter, u8 Type, u16 Offset, u32 *Value);
-
-#endif
diff --git a/drivers/staging/rtl8723au/include/rtw_event.h b/drivers/staging/rtl8723au/include/rtw_event.h
deleted file mode 100644 (file)
index 4557aec..0000000
+++ /dev/null
@@ -1,74 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#ifndef _RTW_EVENT_H_
-#define _RTW_EVENT_H_
-
-#include <osdep_service.h>
-#include <wlan_bssdef.h>
-
-/*
-Used to report a bss has been scanned
-*/
-struct survey_event {
-       struct wlan_bssid_ex *bss;
-};
-
-/*
-Used to report that the requested site survey has been done.
-bss_cnt indicates the number of bss that has been reported.
-*/
-struct surveydone_event {
-       unsigned int bss_cnt;
-};
-
-/*
-Used to report the link result of joinning the given bss
-join_res:
--1: authentication fail
--2: association fail
-> 0: TID
-*/
-struct joinbss_event {
-       struct wlan_network network;
-};
-
-/*
-Used to report a given STA has joinned the created BSS.
-It is used in AP/Ad-HoC(M) mode.
-*/
-struct stassoc_event {
-       unsigned char macaddr[6];
-       unsigned char rsvd[2];
-       int cam_id;
-};
-
-struct stadel_event {
-       unsigned char macaddr[6];
-       unsigned char rsvd[2]; /* for reason */
-       int mac_id;
-};
-
-struct addba_event {
-       unsigned int tid;
-};
-
-#define GEN_EVT_CODE(event)    event ## _EVT_
-
-struct fwevent {
-       u32 parmsize;
-       void (*event_callback)(struct rtw_adapter *dev, const u8 *pbuf);
-};
-
-#endif /*  _WLANEVENT_H_ */
diff --git a/drivers/staging/rtl8723au/include/rtw_ht.h b/drivers/staging/rtl8723au/include/rtw_ht.h
deleted file mode 100644 (file)
index 780eb89..0000000
+++ /dev/null
@@ -1,42 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#ifndef _RTW_HT_H_
-#define _RTW_HT_H_
-
-#include <osdep_service.h>
-#include "linux/ieee80211.h"
-#include "wifi.h"
-
-struct ht_priv {
-       bool    ht_option;
-       bool    ampdu_enable;/* for enable Tx A-MPDU */
-       /* u8   baddbareq_issued[16]; */
-       u32     tx_amsdu_enable;/* for enable Tx A-MSDU */
-       u32     tx_amdsu_maxlen; /*  1: 8k, 0:4k ; default:8k, for tx */
-       u32     rx_ampdu_maxlen; /* for rx reordering ctrl win_sz, updated when join_callback. */
-
-       u8      bwmode;/*  */
-       u8      ch_offset;/* PRIME_CHNL_OFFSET */
-       u8      sgi;/* short GI */
-
-       /* for processing Tx A-MPDU */
-       u16     agg_enable_bitmap;
-       /* u8   ADDBA_retry_count; */
-       u16     candidate_tid_bitmap;
-
-       struct ieee80211_ht_cap ht_cap;
-};
-
-#endif /* _RTL871X_HT_H_ */
diff --git a/drivers/staging/rtl8723au/include/rtw_io.h b/drivers/staging/rtl8723au/include/rtw_io.h
deleted file mode 100644 (file)
index d875e9e..0000000
+++ /dev/null
@@ -1,235 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-
-#ifndef _RTW_IO_H_
-#define _RTW_IO_H_
-
-#include <osdep_service.h>
-#include <osdep_intf.h>
-
-#include <asm/byteorder.h>
-#include <linux/list.h>
-/* include <linux/smp_lock.h> */
-#include <linux/spinlock.h>
-#include <asm/atomic.h>
-
-#include <linux/usb.h>
-#include <linux/usb/ch9.h>
-
-#define rtw_usb_buffer_alloc(dev, size, dma) usb_alloc_coherent((dev), (size), (in_interrupt() ? GFP_ATOMIC : GFP_KERNEL), (dma))
-#define rtw_usb_buffer_free(dev, size, addr, dma) usb_free_coherent((dev), (size), (addr), (dma))
-
-#define NUM_IOREQ              8
-
-#define MAX_PROT_SZ    (64-16)
-
-#define _IOREADY                       0
-#define _IO_WAIT_COMPLETE   1
-#define _IO_WAIT_RSP        2
-
-/*  IO COMMAND TYPE */
-#define _IOSZ_MASK_            (0x7F)
-#define _IO_WRITE_             BIT(7)
-#define _IO_FIXED_             BIT(8)
-#define _IO_BURST_             BIT(9)
-#define _IO_BYTE_              BIT(10)
-#define _IO_HW_                        BIT(11)
-#define _IO_WORD_              BIT(12)
-#define _IO_SYNC_              BIT(13)
-#define _IO_CMDMASK_   (0x1F80)
-
-
-/*
-       For prompt mode accessing, caller shall free io_req
-       Otherwise, io_handler will free io_req
-*/
-
-
-
-/*  IO STATUS TYPE */
-#define _IO_ERR_               BIT(2)
-#define _IO_SUCCESS_   BIT(1)
-#define _IO_DONE_              BIT(0)
-
-
-#define IO_RD32                        (_IO_SYNC_ | _IO_WORD_)
-#define IO_RD16                        (_IO_SYNC_ | _IO_HW_)
-#define IO_RD8                 (_IO_SYNC_ | _IO_BYTE_)
-
-#define IO_RD32_ASYNC  (_IO_WORD_)
-#define IO_RD16_ASYNC  (_IO_HW_)
-#define IO_RD8_ASYNC   (_IO_BYTE_)
-
-#define IO_WR32                        (_IO_WRITE_ | _IO_SYNC_ | _IO_WORD_)
-#define IO_WR16                        (_IO_WRITE_ | _IO_SYNC_ | _IO_HW_)
-#define IO_WR8                 (_IO_WRITE_ | _IO_SYNC_ | _IO_BYTE_)
-
-#define IO_WR32_ASYNC  (_IO_WRITE_ | _IO_WORD_)
-#define IO_WR16_ASYNC  (_IO_WRITE_ | _IO_HW_)
-#define IO_WR8_ASYNC   (_IO_WRITE_ | _IO_BYTE_)
-
-/*
-
-       Only Sync. burst accessing is provided.
-
-*/
-
-#define IO_WR_BURST(x)         (_IO_WRITE_ | _IO_SYNC_ | _IO_BURST_ | ( (x) & _IOSZ_MASK_))
-#define IO_RD_BURST(x)         (_IO_SYNC_ | _IO_BURST_ | ( (x) & _IOSZ_MASK_))
-
-
-
-/* below is for the intf_option bit defition... */
-
-#define _INTF_ASYNC_   BIT(0)  /* support async io */
-
-struct intf_priv;
-
-struct io_req {
-       struct list_head        list;
-       u32     addr;
-       volatile u32    val;
-       u32     command;
-       u32     status;
-       u8      *pbuf;
-
-       void (*_async_io_callback)(struct rtw_adapter *padater, struct io_req *pio_req, u8 *cnxt);
-       u8 *cnxt;
-};
-
-struct reg_protocol_rd {
-
-#ifdef __LITTLE_ENDIAN
-
-       /* DW1 */
-       u32             NumOfTrans:4;
-       u32             Reserved1:4;
-       u32             Reserved2:24;
-       /* DW2 */
-       u32             ByteCount:7;
-       u32             WriteEnable:1;          /* 0:read, 1:write */
-       u32             FixOrContinuous:1;      /* 0:continuous, 1: Fix */
-       u32             BurstMode:1;
-       u32             Byte1Access:1;
-       u32             Byte2Access:1;
-       u32             Byte4Access:1;
-       u32             Reserved3:3;
-       u32             Reserved4:16;
-       /* DW3 */
-       u32             BusAddress;
-       /* DW4 */
-       /* u32          Value; */
-#else
-
-
-/* DW1 */
-       u32 Reserved1  :4;
-       u32 NumOfTrans :4;
-
-       u32 Reserved2  :24;
-
-       /* DW2 */
-       u32 WriteEnable : 1;
-       u32 ByteCount :7;
-
-
-       u32 Reserved3 : 3;
-       u32 Byte4Access : 1;
-
-       u32 Byte2Access : 1;
-       u32 Byte1Access : 1;
-       u32 BurstMode :1 ;
-       u32 FixOrContinuous : 1;
-
-       u32 Reserved4 : 16;
-
-       /* DW3 */
-       u32             BusAddress;
-
-       /* DW4 */
-       /* u32          Value; */
-
-#endif
-
-};
-
-
-struct reg_protocol_wt {
-
-
-#ifdef __LITTLE_ENDIAN
-
-       /* DW1 */
-       u32             NumOfTrans:4;
-       u32             Reserved1:4;
-       u32             Reserved2:24;
-       /* DW2 */
-       u32             ByteCount:7;
-       u32             WriteEnable:1;          /* 0:read, 1:write */
-       u32             FixOrContinuous:1;      /* 0:continuous, 1: Fix */
-       u32             BurstMode:1;
-       u32             Byte1Access:1;
-       u32             Byte2Access:1;
-       u32             Byte4Access:1;
-       u32             Reserved3:3;
-       u32             Reserved4:16;
-       /* DW3 */
-       u32             BusAddress;
-       /* DW4 */
-       u32             Value;
-
-#else
-       /* DW1 */
-       u32 Reserved1  :4;
-       u32 NumOfTrans :4;
-
-       u32 Reserved2  :24;
-
-       /* DW2 */
-       u32 WriteEnable : 1;
-       u32 ByteCount :7;
-
-       u32 Reserved3 : 3;
-       u32 Byte4Access : 1;
-
-       u32 Byte2Access : 1;
-       u32 Byte1Access : 1;
-       u32 BurstMode :1 ;
-       u32 FixOrContinuous : 1;
-
-       u32 Reserved4 : 16;
-
-       /* DW3 */
-       u32             BusAddress;
-
-       /* DW4 */
-       u32             Value;
-
-#endif
-
-};
-
-#define PlatformEFIOWrite1Byte(_a, _b, _c)             \
-       rtl8723au_write8(_a, _b, _c)
-#define PlatformEFIOWrite2Byte(_a, _b, _c)             \
-       rtl8723au_write16(_a, _b, _c)
-#define PlatformEFIOWrite4Byte(_a, _b, _c)             \
-       rtl8723au_write32(_a, _b, _c)
-
-#define PlatformEFIORead1Byte(_a, _b)          rtl8723au_read8(_a, _b)
-#define PlatformEFIORead2Byte(_a, _b)          rtl8723au_read16(_a, _b)
-#define PlatformEFIORead4Byte(_a, _b)          rtl8723au_read32(_a, _b)
-
-#endif /* _RTL8711_IO_H_ */
diff --git a/drivers/staging/rtl8723au/include/rtw_mlme.h b/drivers/staging/rtl8723au/include/rtw_mlme.h
deleted file mode 100644 (file)
index dbd3a5f..0000000
+++ /dev/null
@@ -1,340 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- *
- ******************************************************************************/
-#ifndef __RTW_MLME_H_
-#define __RTW_MLME_H_
-
-#include <osdep_service.h>
-#include <mlme_osdep.h>
-#include <drv_types.h>
-#include <wlan_bssdef.h>
-
-#define        MAX_BSS_CNT     128
-#define   MAX_JOIN_TIMEOUT     6500
-
-/* Increase the scanning timeout because of increasing the SURVEY_TO value. */
-
-#define        SCANNING_TIMEOUT        8000
-
-#define        SCAN_INTERVAL   (30) /*  unit:2sec, 30*2 = 60sec */
-
-#define        SCANQUEUE_LIFETIME 20 /*  unit:sec */
-
-#define        WIFI_NULL_STATE         0x00000000
-
-#define        WIFI_ASOC_STATE         0x00000001 /*  Under Linked state.*/
-#define        WIFI_REASOC_STATE       0x00000002
-#define        WIFI_SLEEP_STATE        0x00000004
-#define        WIFI_STATION_STATE      0x00000008
-
-#define        WIFI_AP_STATE           0x00000010
-#define        WIFI_ADHOC_STATE        0x00000020
-#define   WIFI_ADHOC_MASTER_STATE      0x00000040
-#define   WIFI_UNDER_LINKING   0x00000080
-
-#define        WIFI_UNDER_WPS          0x00000100
-#define        WIFI_STA_ALIVE_CHK_STATE        0x00000400
-/* to indicate the station is under site surveying */
-#define        WIFI_SITE_MONITOR       0x00000800
-
-#define        WIFI_MP_STATE           0x00010000
-#define        WIFI_MP_CTX_BACKGROUND  0x00020000      /*  in continuous tx background */
-#define        WIFI_MP_CTX_ST          0x00040000      /*  in continuous tx with single-tone */
-#define        WIFI_MP_CTX_BACKGROUND_PENDING  0x00080000      /*  pending in continuous tx background due to out of skb */
-#define        WIFI_MP_CTX_CCK_HW      0x00100000      /*  in continuous tx */
-#define        WIFI_MP_CTX_CCK_CS      0x00200000      /*  in continuous tx with carrier suppression */
-#define   WIFI_MP_LPBK_STATE   0x00400000
-
-#define _FW_UNDER_LINKING      WIFI_UNDER_LINKING
-#define _FW_LINKED             WIFI_ASOC_STATE
-#define _FW_UNDER_SURVEY       WIFI_SITE_MONITOR
-
-
-enum dot11AuthAlgrthmNum {
-       dot11AuthAlgrthm_Open = 0,
-       dot11AuthAlgrthm_Shared,
-       dot11AuthAlgrthm_8021X,
-       dot11AuthAlgrthm_Auto,
-       dot11AuthAlgrthm_MaxNum
-};
-
-/*  Scan type including active and passive scan. */
-enum rt_scan_type {
-       SCAN_PASSIVE,
-       SCAN_ACTIVE,
-       SCAN_MIX,
-};
-
-enum {
-       GHZ24_50 = 0,
-       GHZ_50,
-       GHZ_24,
-};
-
-/*
-
-there are several "locks" in mlme_priv,
-since mlme_priv is a shared resource between many threads,
-like ISR/Call-Back functions, the OID handlers, and even timer functions.
-
-
-Each _queue has its own locks, already.
-Other items are protected by mlme_priv.lock.
-
-To avoid possible dead lock, any thread trying to modifiying mlme_priv
-SHALL not lock up more than one locks at a time!
-*/
-
-struct rt_link_detect {
-       u32     NumTxOkInPeriod;
-       u32     NumRxOkInPeriod;
-       u32     NumRxUnicastOkInPeriod;
-       bool    bBusyTraffic;
-       bool    bTxBusyTraffic;
-       bool    bRxBusyTraffic;
-       bool    bHigherBusyTraffic; /*  For interrupt migration purpose. */
-       bool    bHigherBusyRxTraffic; /*  We may disable Tx interrupt according as Rx traffic. */
-       bool    bHigherBusyTxTraffic; /*  We may disable Tx interrupt according as Tx traffic. */
-};
-
-struct mlme_priv {
-       spinlock_t      lock;
-       int     fw_state;
-       u8 bScanInProcess;
-       u8      to_join; /* flag */
-       u8 to_roaming; /*  roaming trying times */
-
-       struct rtw_adapter *nic_hdl;
-
-       u8      not_indic_disco;
-       struct rtw_queue        scanned_queue;
-
-       struct cfg80211_ssid assoc_ssid;
-       u8      assoc_bssid[6];
-
-       struct wlan_network     cur_network;
-
-       /* uint wireless_mode; no used, remove it */
-
-       u32     scan_interval;
-
-       struct timer_list assoc_timer;
-
-       uint assoc_by_bssid;
-       uint assoc_by_rssi;
-
-       struct timer_list scan_to_timer;
-
-       struct timer_list set_scan_deny_timer;
-       atomic_t set_scan_deny; /* 0: allowed, 1: deny */
-
-       unsigned int qos_option;
-
-       /* Number of non-HT AP/stations */
-       int num_sta_no_ht;
-
-       int num_FortyMHzIntolerant;
-
-       struct ht_priv  htpriv;
-
-       struct rt_link_detect LinkDetectInfo;
-       struct timer_list dynamic_chk_timer; /* dynamic/periodic check timer */
-
-       u8      key_mask; /* use for ips to set wep key after ips_leave23a */
-       u8      acm_mask; /*  for wmm acm mask */
-       u8      ChannelPlan;
-       enum rt_scan_type scan_mode; /*  active: 1, passive: 0 */
-
-       u8 *wps_probe_req_ie;
-       u32 wps_probe_req_ie_len;
-       u8 *assoc_req;
-       u32 assoc_req_len;
-       u32 assoc_rsp_len;
-       u8 *assoc_rsp;
-
-#ifdef CONFIG_8723AU_AP_MODE
-       /* Number of associated Non-ERP stations (i.e., stations using 802.11b
-        * in 802.11g BSS) */
-       int num_sta_non_erp;
-
-       /* Number of associated stations that do not support Short Slot Time */
-       int num_sta_no_short_slot_time;
-
-       /* Number of associated stations that do not support Short Preamble */
-       int num_sta_no_short_preamble;
-
-       int olbc; /* Overlapping Legacy BSS Condition */
-
-       /* Number of HT associated stations that do not support greenfield */
-       int num_sta_ht_no_gf;
-
-       /* Number of associated non-HT stations */
-       /* int num_sta_no_ht; */
-
-       /* Number of HT associated stations 20 MHz */
-       int num_sta_ht_20mhz;
-
-       /* Overlapping BSS information */
-       int olbc_ht;
-
-       u16 ht_op_mode;
-
-       spinlock_t      bcn_update_lock;
-       u8              update_bcn;
-
-#endif /* ifdef CONFIG_8723AU_AP_MODE */
-};
-
-void rtw_joinbss_event_prehandle23a(struct rtw_adapter *adapter, u8 *pbuf);
-void rtw_survey_event_cb23a(struct rtw_adapter *adapter, const u8 *pbuf);
-void rtw_surveydone_event_callback23a(struct rtw_adapter *adapter, const u8 *pbuf);
-void rtw23a_joinbss_event_cb(struct rtw_adapter *adapter, const u8 *pbuf);
-void rtw_stassoc_event_callback23a(struct rtw_adapter *adapter, const u8 *pbuf);
-void rtw_stadel_event_callback23a(struct rtw_adapter *adapter, const u8 *pbuf);
-
-int event_thread(void *context);
-void rtw23a_join_to_handler(unsigned long);
-
-void rtw_free_network_queue23a(struct rtw_adapter *adapter);
-int rtw_init_mlme_priv23a(struct rtw_adapter *adapter);
-
-void rtw_free_mlme_priv23a(struct mlme_priv *pmlmepriv);
-
-int rtw_do_join_adhoc(struct rtw_adapter *adapter);
-int rtw_do_join_network(struct rtw_adapter *adapter,
-                       struct wlan_network *candidate);
-int rtw_select_and_join_from_scanned_queue23a(struct mlme_priv *pmlmepriv);
-int rtw_set_key23a(struct rtw_adapter *adapter,
-               struct security_priv *psecuritypriv, int keyid, u8 set_tx);
-int rtw_set_auth23a(struct rtw_adapter *adapter,
-                struct security_priv *psecuritypriv);
-
-static inline u8 *get_bssid(struct mlme_priv *pmlmepriv)
-{      /* if sta_mode:pmlmepriv->cur_network.network.MacAddress => bssid */
-       /*  if adhoc_mode:pmlmepriv->cur_network.network.MacAddress => ibss mac address */
-       return pmlmepriv->cur_network.network.MacAddress;
-}
-
-static inline bool check_fwstate(struct mlme_priv *pmlmepriv, int state)
-{
-       if (pmlmepriv->fw_state & state)
-               return true;
-
-       return false;
-}
-
-static inline int get_fwstate(struct mlme_priv *pmlmepriv)
-{
-       return pmlmepriv->fw_state;
-}
-
-/*
- * No Limit on the calling context,
- * therefore set it to be the critical section...
- *
- * ### NOTE:#### (!!!!)
- * MUST TAKE CARE THAT BEFORE CALLING THIS FUNC, YOU SHOULD HAVE LOCKED pmlmepriv->lock
- */
-static inline void set_fwstate(struct mlme_priv *pmlmepriv, int state)
-{
-       pmlmepriv->fw_state |= state;
-       /* FOR HW integration */
-       if (_FW_UNDER_SURVEY == state)
-               pmlmepriv->bScanInProcess = true;
-}
-
-static inline void _clr_fwstate_(struct mlme_priv *pmlmepriv, int state)
-{
-       pmlmepriv->fw_state &= ~state;
-       /* FOR HW integration */
-       if (_FW_UNDER_SURVEY == state)
-               pmlmepriv->bScanInProcess = false;
-}
-
-/*
- * No Limit on the calling context,
- * therefore set it to be the critical section...
- */
-static inline void clr_fwstate(struct mlme_priv *pmlmepriv, int state)
-{
-       spin_lock_bh(&pmlmepriv->lock);
-       if (check_fwstate(pmlmepriv, state))
-               pmlmepriv->fw_state ^= state;
-       spin_unlock_bh(&pmlmepriv->lock);
-}
-
-static inline void clr_fwstate_ex(struct mlme_priv *pmlmepriv, int state)
-{
-       spin_lock_bh(&pmlmepriv->lock);
-       _clr_fwstate_(pmlmepriv, state);
-       spin_unlock_bh(&pmlmepriv->lock);
-}
-
-void rtw_disconnect_hdl23a_under_linked(struct rtw_adapter *adapter,
-                                    struct sta_info *psta, u8 free_assoc);
-void rtw_generate_random_ibss23a(u8 *pibss);
-struct wlan_network *rtw_find_network23a(struct rtw_queue *scanned_queue, u8 *addr);
-struct wlan_network *rtw_get_oldest_wlan_network23a(struct rtw_queue *scanned_queue);
-
-void rtw_free_assoc_resources23a(struct rtw_adapter *adapter,
-                             int lock_scanned_queue);
-void rtw_indicate_disconnect23a(struct rtw_adapter *adapter);
-void rtw_indicate_connect23a(struct rtw_adapter *adapter);
-void rtw_scan_abort23a(struct rtw_adapter *adapter);
-
-int rtw_restruct_sec_ie23a(struct rtw_adapter *adapter, u8 *in_ie, u8 *out_ie,
-                       uint in_len);
-int rtw_restruct_wmm_ie23a(struct rtw_adapter *adapter, u8 *in_ie, u8 *out_ie,
-                       uint in_len, uint initial_out_len);
-void rtw_init_registrypriv_dev_network23a(struct rtw_adapter *adapter);
-
-void rtw_update_registrypriv_dev_network23a(struct rtw_adapter *adapter);
-
-void rtw_scan_timeout_handler23a(unsigned long data);
-
-void rtw_dynamic_check_timer_handler(unsigned long data);
-bool rtw_is_scan_deny(struct rtw_adapter *adapter);
-void rtw_clear_scan_deny(struct rtw_adapter *adapter);
-void rtw_set_scan_deny_timer_hdl(unsigned long data);
-void rtw_set_scan_deny(struct rtw_adapter *adapter, u32 ms);
-
-void rtw23a_free_mlme_priv_ie_data(struct mlme_priv *pmlmepriv);
-
-void _rtw_free_mlme_priv23a(struct mlme_priv *pmlmepriv);
-
-struct wlan_network *rtw_alloc_network(struct mlme_priv *pmlmepriv, gfp_t gfp);
-
-int rtw_if_up23a(struct rtw_adapter *padapter);
-
-int rtw_linked_check(struct rtw_adapter *padapter);
-
-void rtw_joinbss_reset23a(struct rtw_adapter *padapter);
-
-bool rtw_restructure_ht_ie23a(struct rtw_adapter *padapter, u8 *in_ie,
-                             u8 *out_ie, uint in_len, uint *pout_len);
-void rtw_update_ht_cap23a(struct rtw_adapter *padapter,
-                      u8 *pie, uint ie_len);
-void rtw_issue_addbareq_cmd23a(struct rtw_adapter *padapter,
-                           struct xmit_frame *pxmitframe);
-
-bool rtw_is_same_ibss23a(struct rtw_adapter *adapter,
-                        struct wlan_network *pnetwork);
-int is_same_network23a(struct wlan_bssid_ex *src, struct wlan_bssid_ex *dst);
-
-void rtw23a_roaming(struct rtw_adapter *adapter,
-                struct wlan_network *tgt_network);
-void rtw_set_roaming(struct rtw_adapter *adapter, u8 to_roaming);
-
-#endif /* __RTL871X_MLME_H_ */
diff --git a/drivers/staging/rtl8723au/include/rtw_mlme_ext.h b/drivers/staging/rtl8723au/include/rtw_mlme_ext.h
deleted file mode 100644 (file)
index 0e7d3da..0000000
+++ /dev/null
@@ -1,683 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#ifndef __RTW_MLME_EXT_H_
-#define __RTW_MLME_EXT_H_
-
-#include <osdep_service.h>
-#include <drv_types.h>
-#include <wlan_bssdef.h>
-
-
-/*     Commented by Albert 20101105 */
-/*     Increase the SURVEY_TO value from 100 to 150  ( 100ms to 150ms ) */
-/*     The Realtek 8188CE SoftAP will spend around 100ms to send the probe response after receiving the probe request. */
-/*     So, this driver tried to extend the dwell time for each scanning channel. */
-/*     This will increase the chance to receive the probe response from SoftAP. */
-
-#define SURVEY_TO              (100)
-#define REAUTH_TO              (300) /* 50) */
-#define REASSOC_TO             (300) /* 50) */
-/* define DISCONNECT_TO        (3000) */
-#define ADDBA_TO                       (2000)
-
-#define LINKED_TO (1) /* unit:2 sec, 1x2=2 sec */
-
-#define REAUTH_LIMIT   (4)
-#define REASSOC_LIMIT  (4)
-#define READDBA_LIMIT  (2)
-
-#define ROAMING_LIMIT  8
-
-#define        DYNAMIC_FUNC_DISABLE                    (0x0)
-
-/*  ====== enum odm_ability ======== */
-/*  BB ODM section BIT 0-15 */
-#define        DYNAMIC_BB_DIG                          BIT(0)
-#define        DYNAMIC_BB_RA_MASK                      BIT(1)
-#define        DYNAMIC_BB_DYNAMIC_TXPWR        BIT(2)
-#define        DYNAMIC_BB_BB_FA_CNT                    BIT(3)
-
-#define                DYNAMIC_BB_RSSI_MONITOR         BIT(4)
-#define                DYNAMIC_BB_CCK_PD                       BIT(5)
-#define                DYNAMIC_BB_ANT_DIV                      BIT(6)
-#define                DYNAMIC_BB_PWR_SAVE                     BIT(7)
-#define                DYNAMIC_BB_PWR_TRAIN                    BIT(8)
-#define                DYNAMIC_BB_RATE_ADAPTIVE                BIT(9)
-#define                DYNAMIC_BB_PATH_DIV                     BIT(10)
-#define                DYNAMIC_BB_PSD                          BIT(11)
-
-/*  MAC DM section BIT 16-23 */
-#define                DYNAMIC_MAC_struct edca_turboURBO               BIT(16)
-#define                DYNAMIC_MAC_EARLY_MODE          BIT(17)
-
-/*  RF ODM section BIT 24-31 */
-#define                DYNAMIC_RF_TX_PWR_TRACK         BIT(24)
-#define                DYNAMIC_RF_RX_GAIN_TRACK                BIT(25)
-#define                DYNAMIC_RF_CALIBRATION          BIT(26)
-
-#define                DYNAMIC_ALL_FUNC_ENABLE         0xFFFFFFF
-
-#define _HW_STATE_NOLINK_              0x00
-#define _HW_STATE_ADHOC_               0x01
-#define _HW_STATE_STATION_     0x02
-#define _HW_STATE_AP_                  0x03
-
-
-#define                _1M_RATE_       0
-#define                _2M_RATE_       1
-#define                _5M_RATE_       2
-#define                _11M_RATE_      3
-#define                _6M_RATE_       4
-#define                _9M_RATE_       5
-#define                _12M_RATE_      6
-#define                _18M_RATE_      7
-#define                _24M_RATE_      8
-#define                _36M_RATE_      9
-#define                _48M_RATE_      10
-#define                _54M_RATE_      11
-
-
-extern unsigned char WMM_OUI23A[];
-extern unsigned char WPS_OUI23A[];
-extern unsigned char WFD_OUI23A[];
-extern unsigned char P2P_OUI23A[];
-
-extern unsigned char WMM_INFO_OUI23A[];
-extern unsigned char WMM_PARA_OUI23A[];
-
-
-/*  */
-/*  Channel Plan Type. */
-/*  Note: */
-/*     We just add new channel plan when the new channel plan is different from any of the following */
-/*     channel plan. */
-/*     If you just want to customize the actions(scan period or join actions) about one of the channel plan, */
-/*     customize them in struct rt_channel_info in the RT_CHANNEL_LIST. */
-/*  */
-enum  { /* _RT_CHANNEL_DOMAIN */
-       /*  old channel plan mapping ===== */
-       RT_CHANNEL_DOMAIN_FCC = 0x00,
-       RT_CHANNEL_DOMAIN_IC = 0x01,
-       RT_CHANNEL_DOMAIN_ETSI = 0x02,
-       RT_CHANNEL_DOMAIN_SPAIN = 0x03,
-       RT_CHANNEL_DOMAIN_FRANCE = 0x04,
-       RT_CHANNEL_DOMAIN_MKK = 0x05,
-       RT_CHANNEL_DOMAIN_MKK1 = 0x06,
-       RT_CHANNEL_DOMAIN_ISRAEL = 0x07,
-       RT_CHANNEL_DOMAIN_TELEC = 0x08,
-       RT_CHANNEL_DOMAIN_GLOBAL_DOAMIN = 0x09,
-       RT_CHANNEL_DOMAIN_WORLD_WIDE_13 = 0x0A,
-       RT_CHANNEL_DOMAIN_TAIWAN = 0x0B,
-       RT_CHANNEL_DOMAIN_CHINA = 0x0C,
-       RT_CHANNEL_DOMAIN_SINGAPORE_INDIA_MEXICO = 0x0D,
-       RT_CHANNEL_DOMAIN_KOREA = 0x0E,
-       RT_CHANNEL_DOMAIN_TURKEY = 0x0F,
-       RT_CHANNEL_DOMAIN_JAPAN = 0x10,
-       RT_CHANNEL_DOMAIN_FCC_NO_DFS = 0x11,
-       RT_CHANNEL_DOMAIN_JAPAN_NO_DFS = 0x12,
-       RT_CHANNEL_DOMAIN_WORLD_WIDE_5G = 0x13,
-       RT_CHANNEL_DOMAIN_TAIWAN_NO_DFS = 0x14,
-
-       /*  new channel plan mapping, (2GDOMAIN_5GDOMAIN) ===== */
-       RT_CHANNEL_DOMAIN_WORLD_NULL = 0x20,
-       RT_CHANNEL_DOMAIN_ETSI1_NULL = 0x21,
-       RT_CHANNEL_DOMAIN_FCC1_NULL = 0x22,
-       RT_CHANNEL_DOMAIN_MKK1_NULL = 0x23,
-       RT_CHANNEL_DOMAIN_ETSI2_NULL = 0x24,
-       RT_CHANNEL_DOMAIN_FCC1_FCC1 = 0x25,
-       RT_CHANNEL_DOMAIN_WORLD_ETSI1 = 0x26,
-       RT_CHANNEL_DOMAIN_MKK1_MKK1 = 0x27,
-       RT_CHANNEL_DOMAIN_WORLD_KCC1 = 0x28,
-       RT_CHANNEL_DOMAIN_WORLD_FCC2 = 0x29,
-       RT_CHANNEL_DOMAIN_WORLD_FCC3 = 0x30,
-       RT_CHANNEL_DOMAIN_WORLD_FCC4 = 0x31,
-       RT_CHANNEL_DOMAIN_WORLD_FCC5 = 0x32,
-       RT_CHANNEL_DOMAIN_WORLD_FCC6 = 0x33,
-       RT_CHANNEL_DOMAIN_FCC1_FCC7 = 0x34,
-       RT_CHANNEL_DOMAIN_WORLD_ETSI2 = 0x35,
-       RT_CHANNEL_DOMAIN_WORLD_ETSI3 = 0x36,
-       RT_CHANNEL_DOMAIN_MKK1_MKK2 = 0x37,
-       RT_CHANNEL_DOMAIN_MKK1_MKK3 = 0x38,
-       RT_CHANNEL_DOMAIN_FCC1_NCC1 = 0x39,
-       RT_CHANNEL_DOMAIN_FCC1_NCC2 = 0x40,
-       RT_CHANNEL_DOMAIN_GLOBAL_DOAMIN_2G = 0x41,
-       /*  Add new channel plan above this line=============== */
-       RT_CHANNEL_DOMAIN_MAX,
-       RT_CHANNEL_DOMAIN_REALTEK_DEFINE = 0x7F,
-};
-
-enum { /* _RT_CHANNEL_DOMAIN_2G */
-       RT_CHANNEL_DOMAIN_2G_WORLD = 0x00,              /* Worldwird 13 */
-       RT_CHANNEL_DOMAIN_2G_ETSI1 = 0x01,              /* Europe */
-       RT_CHANNEL_DOMAIN_2G_FCC1 = 0x02,               /* US */
-       RT_CHANNEL_DOMAIN_2G_MKK1 = 0x03,               /* Japan */
-       RT_CHANNEL_DOMAIN_2G_ETSI2 = 0x04,              /* France */
-       RT_CHANNEL_DOMAIN_2G_NULL = 0x05,
-       /*  Add new channel plan above this line=============== */
-       RT_CHANNEL_DOMAIN_2G_MAX,
-};
-
-enum { /* _RT_CHANNEL_DOMAIN_5G */
-       RT_CHANNEL_DOMAIN_5G_NULL = 0x00,
-       RT_CHANNEL_DOMAIN_5G_ETSI1 = 0x01,              /* Europe */
-       RT_CHANNEL_DOMAIN_5G_ETSI2 = 0x02,              /* Australia, New Zealand */
-       RT_CHANNEL_DOMAIN_5G_ETSI3 = 0x03,              /* Russia */
-       RT_CHANNEL_DOMAIN_5G_FCC1 = 0x04,               /* US */
-       RT_CHANNEL_DOMAIN_5G_FCC2 = 0x05,               /* FCC o/w DFS Channels */
-       RT_CHANNEL_DOMAIN_5G_FCC3 = 0x06,               /* India, Mexico */
-       RT_CHANNEL_DOMAIN_5G_FCC4 = 0x07,               /* Venezuela */
-       RT_CHANNEL_DOMAIN_5G_FCC5 = 0x08,               /* China */
-       RT_CHANNEL_DOMAIN_5G_FCC6 = 0x09,               /* Israel */
-       RT_CHANNEL_DOMAIN_5G_FCC7_IC1 = 0x0A,   /* US, Canada */
-       RT_CHANNEL_DOMAIN_5G_KCC1 = 0x0B,               /* Korea */
-       RT_CHANNEL_DOMAIN_5G_MKK1 = 0x0C,               /* Japan */
-       RT_CHANNEL_DOMAIN_5G_MKK2 = 0x0D,               /* Japan (W52, W53) */
-       RT_CHANNEL_DOMAIN_5G_MKK3 = 0x0E,               /* Japan (W56) */
-       RT_CHANNEL_DOMAIN_5G_NCC1 = 0x0F,               /* Taiwan */
-       RT_CHANNEL_DOMAIN_5G_NCC2 = 0x10,               /* Taiwan o/w DFS */
-       /*  Add new channel plan above this line=============== */
-       /*  Driver Self Defined ===== */
-       RT_CHANNEL_DOMAIN_5G_FCC = 0x11,
-       RT_CHANNEL_DOMAIN_5G_JAPAN_NO_DFS = 0x12,
-       RT_CHANNEL_DOMAIN_5G_FCC4_NO_DFS = 0x13,
-       RT_CHANNEL_DOMAIN_5G_MAX,
-};
-
-#define rtw_is_channel_plan_valid(chplan) (chplan<RT_CHANNEL_DOMAIN_MAX || chplan == RT_CHANNEL_DOMAIN_REALTEK_DEFINE)
-
-struct rt_channel_plan {
-       unsigned char   Channel[MAX_CHANNEL_NUM];
-       unsigned char   Len;
-};
-
-struct rt_channel_plan_2g {
-       unsigned char   Channel[MAX_CHANNEL_NUM_2G];
-       unsigned char   Len;
-};
-
-struct rt_channel_plan_5g {
-       unsigned char   Channel[MAX_CHANNEL_NUM_5G];
-       unsigned char   Len;
-};
-
-struct rt_channel_plan_map {
-       unsigned char   Index2G;
-       unsigned char   Index5G;
-};
-
-enum Associated_AP {
-       atherosAP       = 0,
-       broadcomAP      = 1,
-       ciscoAP         = 2,
-       marvellAP       = 3,
-       ralinkAP        = 4,
-       realtekAP       = 5,
-       airgocapAP      = 6,
-       unknownAP       = 7,
-       maxAP,
-};
-
-enum { /* HT_IOT_PEER_E */
-       HT_IOT_PEER_UNKNOWN             = 0,
-       HT_IOT_PEER_REALTEK             = 1,
-       HT_IOT_PEER_REALTEK_92SE        = 2,
-       HT_IOT_PEER_BROADCOM            = 3,
-       HT_IOT_PEER_RALINK              = 4,
-       HT_IOT_PEER_ATHEROS             = 5,
-       HT_IOT_PEER_CISCO               = 6,
-       HT_IOT_PEER_MERU                = 7,
-       HT_IOT_PEER_MARVELL             = 8,
-       HT_IOT_PEER_REALTEK_SOFTAP      = 9,/*  peer is RealTek SOFT_AP, by Bohn, 2009.12.17 */
-       HT_IOT_PEER_SELF_SOFTAP         = 10, /*  Self is SoftAP */
-       HT_IOT_PEER_AIRGO               = 11,
-       HT_IOT_PEER_INTEL               = 12,
-       HT_IOT_PEER_RTK_APCLIENT        = 13,
-       HT_IOT_PEER_REALTEK_81XX        = 14,
-       HT_IOT_PEER_REALTEK_WOW         = 15,
-       HT_IOT_PEER_TENDA               = 16,
-       HT_IOT_PEER_MAX                 = 17
-};
-
-enum SCAN_STATE {
-       SCAN_DISABLE = 0,
-       SCAN_START = 1,
-       SCAN_TXNULL = 2,
-       SCAN_PROCESS = 3,
-       SCAN_COMPLETE = 4,
-       SCAN_STATE_MAX,
-};
-
-struct mlme_handler {
-       char *str;
-       int (*func)(struct rtw_adapter *padapter, struct recv_frame *precv_frame);
-};
-
-struct action_handler {
-       unsigned int   num;
-       char *str;
-       int (*func)(struct rtw_adapter *padapter, struct recv_frame *precv_frame);
-};
-
-struct ss_res {
-       int     state;
-       int     bss_cnt;
-       int     channel_idx;
-       int     scan_mode;
-       u8 ssid_num;
-       u8 ch_num;
-       struct cfg80211_ssid ssid[RTW_SSID_SCAN_AMOUNT];
-       struct rtw_ieee80211_channel ch[RTW_CHANNEL_SCAN_AMOUNT];
-};
-
-#define        WIFI_FW_AUTH_NULL                       0x00000100
-#define        WIFI_FW_AUTH_STATE                      0x00000200
-#define        WIFI_FW_AUTH_SUCCESS                    0x00000400
-
-#define        WIFI_FW_ASSOC_STATE                     0x00002000
-#define        WIFI_FW_ASSOC_SUCCESS           0x00004000
-
-#define        WIFI_FW_LINKING_STATE           (WIFI_FW_AUTH_NULL | WIFI_FW_AUTH_STATE | WIFI_FW_AUTH_SUCCESS |WIFI_FW_ASSOC_STATE)
-
-struct FW_Sta_Info {
-       struct sta_info *psta;
-       u32     status;
-       u32     rx_pkt;
-       u32     retry;
-       unsigned char SupportedRates[NDIS_802_11_LENGTH_RATES_EX];
-};
-
-/*
- * Usage:
- * When one iface acted as AP mode and the other iface is STA mode and scanning,
- * it should switch back to AP's operating channel periodically.
- * Parameters info:
- * When the driver scanned RTW_SCAN_NUM_OF_CH channels, it would switch back to AP's operating channel for
- * RTW_STAY_AP_CH_MILLISECOND * SURVEY_TO milliseconds.
- * Example:
- * For chip supports 2.4G + 5GHz and AP mode is operating in channel 1,
- * RTW_SCAN_NUM_OF_CH is 8, RTW_STAY_AP_CH_MILLISECOND is 3 and SURVEY_TO is 100.
- * When it's STA mode gets set_scan command,
- * it would
- * 1. Doing the scan on channel 1.2.3.4.5.6.7.8
- * 2. Back to channel 1 for 300 milliseconds
- * 3. Go through doing site survey on channel 9.10.11.36.40.44.48.52
- * 4. Back to channel 1 for 300 milliseconds
- * 5. ... and so on, till survey done.
- */
-
-struct mlme_ext_info {
-       u32     state;
-       u32     reauth_count;
-       u32     reassoc_count;
-       u32     link_count;
-       u32     auth_seq;
-       u32     auth_algo;      /*  802.11 auth, could be open, shared, auto */
-       u32     authModeToggle;
-       u32     enc_algo;/* encrypt algorithm; */
-       u32     key_index;      /*  this is only valid for legendary wep, 0~3 for key id. */
-       u32     iv;
-       u8      chg_txt[128];
-       u16     aid;
-       u16     bcn_interval;
-       u16     capability;
-       u8      assoc_AP_vendor;
-       u8      slotTime;
-       u8      preamble_mode;
-       u8      WMM_enable;
-       u8      ERP_enable;
-       u8      ERP_IE;
-       u8      HT_enable;
-       u8      HT_caps_enable;
-       u8      HT_info_enable;
-       u8      HT_protection;
-       u8      turboMode_cts2self;
-       u8      turboMode_rtsen;
-       u8      SM_PS;
-       u8      ADDBA_retry_count;
-       u8      dialogToken;
-       /*  Accept ADDBA Request */
-       bool bAcceptAddbaReq;
-       u8      bwmode_updated;
-       u8      hidden_ssid_mode;
-
-       struct ADDBA_request            ADDBA_req;
-       struct WMM_para_element WMM_param;
-       struct ieee80211_ht_cap ht_cap;
-       struct ieee80211_ht_operation HT_info;
-       struct wlan_bssid_ex                    network;/* join network or bss_network, if in ap mode, it is the same to cur_network.network */
-       struct FW_Sta_Info              FW_sta_info[NUM_STA];
-};
-
-/*  The channel information about this channel including joining, scanning, and power constraints. */
-struct rt_channel_info {
-       u8              ChannelNum;             /*  The channel number. */
-       enum rt_scan_type ScanType;             /*  Scan type such as passive or active scan. */
-};
-
-int rtw_ch_set_search_ch23a(struct rt_channel_info *ch_set, const u32 ch);
-
-/*  P2P_MAX_REG_CLASSES - Maximum number of regulatory classes */
-#define P2P_MAX_REG_CLASSES 10
-
-/*  P2P_MAX_REG_CLASS_CHANNELS - Maximum number of channels per regulatory class */
-#define P2P_MAX_REG_CLASS_CHANNELS 20
-
-/*   struct p2p_channels - List of supported channels */
-struct p2p_channels {
-       /*  struct p2p_reg_class - Supported regulatory class */
-       struct p2p_reg_class {
-               /*  reg_class - Regulatory class (IEEE 802.11-2007, Annex J) */
-               u8 reg_class;
-
-               /*  channel - Supported channels */
-               u8 channel[P2P_MAX_REG_CLASS_CHANNELS];
-
-               /*  channels - Number of channel entries in use */
-               size_t channels;
-       } reg_class[P2P_MAX_REG_CLASSES];
-
-       /*  reg_classes - Number of reg_class entries in use */
-       size_t reg_classes;
-};
-
-struct p2p_oper_class_map {
-       enum hw_mode {IEEE80211G, IEEE80211A} mode;
-       u8 op_class;
-       u8 min_chan;
-       u8 max_chan;
-       u8 inc;
-       enum {
-               BW20, BW40PLUS, BW40MINUS
-       } bw;
-};
-
-struct mlme_ext_priv {
-       struct rtw_adapter      *padapter;
-       u8      mlmeext_init;
-       atomic_t                event_seq;
-       u16     mgnt_seq;
-
-       /* struct fw_priv       fwpriv; */
-
-       unsigned char   cur_channel;
-       unsigned char   cur_bwmode;
-       unsigned char   cur_ch_offset;/* PRIME_CHNL_OFFSET */
-       unsigned char   cur_wireless_mode;      /*  NETWORK_TYPE */
-
-       unsigned char   max_chan_nums;
-       struct rt_channel_info          channel_set[MAX_CHANNEL_NUM];
-       struct p2p_channels channel_list;
-       unsigned char   basicrate[NumRates];
-       unsigned char   datarate[NumRates];
-
-       struct ss_res           sitesurvey_res;
-       struct mlme_ext_info    mlmext_info;/* for sta/adhoc mode, including current scanning/connecting/connected related info. */
-                                                     /* for ap mode, network includes ap's cap_info */
-       struct timer_list               survey_timer;
-       struct timer_list               link_timer;
-       u16                     chan_scan_time;
-
-       u8      scan_abort;
-       u8      tx_rate; /*  TXRATE when USERATE is set. */
-
-       u32     retry; /* retry for issue probereq */
-
-       u64 TSFValue;
-
-       unsigned char bstart_bss;
-       u8 update_channel_plan_by_ap_done;
-       /* recv_decache check for Action_public frame */
-       u8 action_public_dialog_token;
-       u16      action_public_rxseq;
-       u8 active_keep_alive_check;
-};
-
-int init_mlme_ext_priv23a(struct rtw_adapter *padapter);
-int init_hw_mlme_ext23a(struct rtw_adapter *padapter);
-void free_mlme_ext_priv23a (struct mlme_ext_priv *pmlmeext);
-void init_mlme_ext_timer23a(struct rtw_adapter *padapter);
-void init_addba_retry_timer23a(struct sta_info *psta);
-struct xmit_frame *alloc_mgtxmitframe23a(struct xmit_priv *pxmitpriv);
-
-unsigned char networktype_to_raid23a(unsigned char network_type);
-u8 judge_network_type23a(struct rtw_adapter *padapter, unsigned char *rate,
-                     int ratelen);
-void get_rate_set23a(struct rtw_adapter *padapter, unsigned char *pbssrate,
-                 int *bssrate_len);
-void UpdateBrateTbl23a(struct rtw_adapter *padapter, u8 *mBratesOS);
-void Update23aTblForSoftAP(u8 *bssrateset, u32 bssratelen);
-
-u8 rtw_get_oper_ch23a(struct rtw_adapter *adapter);
-void rtw_set_oper_ch23a(struct rtw_adapter *adapter, u8 ch);
-void rtw_set_oper_bw23a(struct rtw_adapter *adapter, u8 bw);
-void rtw_set_oper_ch23aoffset23a(struct rtw_adapter *adapter, u8 offset);
-
-void set_channel_bwmode23a(struct rtw_adapter *padapter, unsigned char channel,
-                       unsigned char channel_offset, unsigned short bwmode);
-void SelectChannel23a(struct rtw_adapter *padapter, unsigned char channel);
-
-unsigned int decide_wait_for_beacon_timeout23a(unsigned int bcn_interval);
-
-void clear_cam_entry23a(struct rtw_adapter *padapter, u8 entry);
-
-void invalidate_cam_all23a(struct rtw_adapter *padapter);
-
-int allocate_fw_sta_entry23a(struct rtw_adapter *padapter);
-void flush_all_cam_entry23a(struct rtw_adapter *padapter);
-
-bool IsLegal5GChannel(struct rtw_adapter *Adapter, u8 channel);
-
-void update_network23a(struct wlan_bssid_ex *dst, struct wlan_bssid_ex *src,
-                   struct rtw_adapter *padapter, bool update_ie);
-
-u8 *get_my_bssid23a(struct wlan_bssid_ex *pnetwork);
-
-bool is_client_associated_to_ap23a(struct rtw_adapter *padapter);
-bool is_client_associated_to_ibss23a(struct rtw_adapter *padapter);
-bool is_IBSS_empty23a(struct rtw_adapter *padapter);
-
-unsigned char check_assoc_AP23a(u8 *pframe, uint len);
-
-int WMM_param_handler23a(struct rtw_adapter *padapter, const u8 *p);
-void WMMOnAssocRsp23a(struct rtw_adapter *padapter);
-
-void HT_caps_handler23a(struct rtw_adapter *padapter, const u8 *p);
-void HT_info_handler23a(struct rtw_adapter *padapter, const u8 *p);
-void HTOnAssocRsp23a(struct rtw_adapter *padapter);
-
-void ERP_IE_handler23a(struct rtw_adapter *padapter, const u8 *p);
-void VCS_update23a(struct rtw_adapter *padapter, struct sta_info *psta);
-
-void update_beacon23a_info(struct rtw_adapter *padapter,
-                          struct ieee80211_mgmt *mgmt, uint len,
-                          struct sta_info *psta);
-int rtw_check_bcn_info23a(struct rtw_adapter *Adapter,
-                         struct ieee80211_mgmt *mgmt, u32 packet_len);
-void update_IOT_info23a(struct rtw_adapter *padapter);
-void update_capinfo23a(struct rtw_adapter *Adapter, u16 updateCap);
-void update_wireless_mode23a(struct rtw_adapter *padapter);
-void update_tx_basic_rate23a(struct rtw_adapter *padapter, u8 modulation);
-void update_bmc_sta_support_rate23a(struct rtw_adapter *padapter, u32 mac_id);
-int update_sta_support_rate23a(struct rtw_adapter *padapter, u8 *pvar_ie,
-                           uint var_ie_len, int cam_idx);
-
-/* for sta/adhoc mode */
-void update_sta_info23a(struct rtw_adapter *padapter, struct sta_info *psta);
-unsigned int update_basic_rate23a(unsigned char *ptn, unsigned int ptn_sz);
-unsigned int update_supported_rate23a(unsigned char *ptn, unsigned int ptn_sz);
-unsigned int update_MSC_rate23a(struct ieee80211_ht_cap *ht_cap);
-void Update_RA_Entry23a(struct rtw_adapter *padapter, struct sta_info *psta);
-void set_sta_rate23a(struct rtw_adapter *padapter, struct sta_info *psta);
-
-int receive_disconnect23a(struct rtw_adapter *padapter,
-                         unsigned char *MacAddr, unsigned short reason);
-
-unsigned char get_highest_rate_idx23a(u32 mask);
-int support_short_GI23a(struct rtw_adapter *padapter,
-                       struct ieee80211_ht_cap *ht_cap);
-bool is_ap_in_tkip23a(struct rtw_adapter *padapter);
-bool is_ap_in_wep23a(struct rtw_adapter *padapter);
-bool should_forbid_n_rate23a(struct rtw_adapter *padapter);
-
-void report_join_res23a(struct rtw_adapter *padapter, int res);
-void report_survey_event23a(struct rtw_adapter *padapter,
-                        struct recv_frame *precv_frame);
-void report_surveydone_event23a(struct rtw_adapter *padapter);
-void report_del_sta_event23a(struct rtw_adapter *padapter,
-                         unsigned char *MacAddr, unsigned short reason);
-void report_add_sta_event23a(struct rtw_adapter *padapter,
-                         unsigned char *MacAddr, int cam_idx);
-
-int set_tx_beacon_cmd23a(struct rtw_adapter*padapter);
-unsigned int setup_beacon_frame(struct rtw_adapter *padapter,
-                               unsigned char *beacon_frame);
-void update_mgnt_tx_rate23a(struct rtw_adapter *padapter, u8 rate);
-void update_mgntframe_attrib23a(struct rtw_adapter *padapter,
-                            struct pkt_attrib *pattrib);
-void dump_mgntframe23a(struct rtw_adapter *padapter,
-                   struct xmit_frame *pmgntframe);
-s32 dump_mgntframe23a_and_wait(struct rtw_adapter *padapter,
-                           struct xmit_frame *pmgntframe, int timeout_ms);
-s32 dump_mgntframe23a_and_wait_ack23a(struct rtw_adapter *padapter,
-                               struct xmit_frame *pmgntframe);
-
-void issue_beacon23a(struct rtw_adapter *padapter, int timeout_ms);
-int issue_nulldata23a(struct rtw_adapter *padapter, unsigned char *da,
-                  unsigned int power_mode, int try_cnt, int wait_ms);
-int issue_qos_nulldata23a(struct rtw_adapter *padapter, unsigned char *da, u16 tid,
-                      int try_cnt, int wait_ms);
-int issue_deauth23a(struct rtw_adapter *padapter, unsigned char *da,
-                unsigned short reason);
-void issue_action_spct_ch_switch23a(struct rtw_adapter *padapter, u8 *ra,
-                                u8 new_ch, u8 ch_offset);
-void issue_action_BA23a(struct rtw_adapter *padapter,
-                       const unsigned char *raddr,
-                       unsigned char action, unsigned short status);
-int send_delba23a(struct rtw_adapter *padapter, u8 initiator, u8 *addr);
-int send_beacon23a(struct rtw_adapter *padapter);
-
-void mlmeext_joinbss_event_callback23a(struct rtw_adapter *padapter, int join_res);
-void mlmeext_sta_del_event_callback23a(struct rtw_adapter *padapter);
-void mlmeext_sta_add_event_callback23a(struct rtw_adapter *padapter, struct sta_info *psta);
-
-void linked_status_chk23a(struct rtw_adapter *padapter);
-
-#define set_survey_timer(mlmeext, ms) \
-       /*DBG_8723A("%s set_survey_timer(%p, %d)\n", __func__, (mlmeext), (ms));*/ \
-       mod_timer(&mlmeext->survey_timer, jiffies + msecs_to_jiffies(ms));
-
-#define set_link_timer(mlmeext, ms) \
-       /*DBG_8723A("%s set_link_timer(%p, %d)\n", __func__, (mlmeext), (ms));*/ \
-       mod_timer(&mlmeext->link_timer, jiffies + msecs_to_jiffies(ms));
-
-int cckrates_included23a(unsigned char *rate, int ratelen);
-int cckratesonly_included23a(unsigned char *rate, int ratelen);
-
-void process_addba_req23a(struct rtw_adapter *padapter, u8 *paddba_req, u8 *addr);
-
-void correct_TSF23a(struct rtw_adapter *padapter, struct mlme_ext_priv *pmlmeext);
-
-struct cmd_hdl {
-       uint    parmsize;
-       int (*h2cfuns)(struct rtw_adapter *padapter, const u8 *pbuf);
-};
-
-
-int read_macreg_hdl(struct rtw_adapter *padapter, u8 *pbuf);
-int write_macreg_hdl(struct rtw_adapter *padapter, u8 *pbuf);
-int read_bbreg_hdl(struct rtw_adapter *padapter, u8 *pbuf);
-int write_bbreg_hdl(struct rtw_adapter *padapter, u8 *pbuf);
-int read_rfreg_hdl(struct rtw_adapter *padapter, u8 *pbuf);
-int write_rfreg_hdl(struct rtw_adapter *padapter, u8 *pbuf);
-
-
-int NULL_hdl23a(struct rtw_adapter *padapter, const u8 *pbuf);
-int join_cmd_hdl23a(struct rtw_adapter *padapter, const u8 *pbuf);
-int disconnect_hdl23a(struct rtw_adapter *padapter, const u8 *pbuf);
-int createbss_hdl23a(struct rtw_adapter *padapter, const u8 *pbuf);
-int setopmode_hdl23a(struct rtw_adapter *padapter, const u8 *pbuf);
-int sitesurvey_cmd_hdl23a(struct rtw_adapter *padapter, const u8 *pbuf);
-int setauth_hdl23a(struct rtw_adapter *padapter, const u8 *pbuf);
-int setkey_hdl23a(struct rtw_adapter *padapter, const u8 *pbuf);
-int set_stakey_hdl23a(struct rtw_adapter *padapter, const u8 *pbuf);
-int set_assocsta_hdl(struct rtw_adapter *padapter, const u8 *pbuf);
-int del_assocsta_hdl(struct rtw_adapter *padapter, const u8 *pbuf);
-int add_ba_hdl23a(struct rtw_adapter *padapter, const u8 *pbuf);
-
-int mlme_evt_hdl23a(struct rtw_adapter *padapter, const u8 *pbuf);
-int h2c_msg_hdl23a(struct rtw_adapter *padapter, const u8 *pbuf);
-int tx_beacon_hdl23a(struct rtw_adapter *padapter, const u8 *pbuf);
-int set_ch_hdl23a(struct rtw_adapter *padapter, const u8 *pbuf);
-int set_chplan_hdl23a(struct rtw_adapter *padapter, const u8 *pbuf);
-int led_blink_hdl23a(struct rtw_adapter *padapter, const u8 *pbuf);
-int set_csa_hdl23a(struct rtw_adapter *padapter, const u8 *pbuf);      /* Kurt: Handling DFS channel switch announcement ie. */
-int tdls_hdl23a(struct rtw_adapter *padapter, const u8 *pbuf);
-
-#define GEN_DRV_CMD_HANDLER(size, cmd) {size, &cmd ## _hdl23a},
-#define GEN_MLME_EXT_HANDLER(size, cmd)        {size, cmd},
-
-struct C2HEvent_Header {
-#ifdef __LITTLE_ENDIAN
-
-       unsigned int len:16;
-       unsigned int ID:8;
-       unsigned int seq:8;
-
-#elif defined(__BIG_ENDIAN)
-
-       unsigned int seq:8;
-       unsigned int ID:8;
-       unsigned int len:16;
-
-#else
-
-#  error "Must be LITTLE or BIG Endian"
-
-#endif
-
-       unsigned int rsvd;
-};
-
-enum rtw_c2h_event {
-       GEN_EVT_CODE(_Read_MACREG) = 0, /*0*/
-       GEN_EVT_CODE(_Read_BBREG),
-       GEN_EVT_CODE(_Read_RFREG),
-       GEN_EVT_CODE(_Read_EEPROM),
-       GEN_EVT_CODE(_Read_EFUSE),
-       GEN_EVT_CODE(_Read_CAM),                        /*5*/
-       GEN_EVT_CODE(_Get_BasicRate),
-       GEN_EVT_CODE(_Get_DataRate),
-       GEN_EVT_CODE(_Survey),   /*8*/
-       GEN_EVT_CODE(_SurveyDone),       /*9*/
-
-       GEN_EVT_CODE(_JoinBss) , /*10*/
-       GEN_EVT_CODE(_AddSTA),
-       GEN_EVT_CODE(_DelSTA),
-       GEN_EVT_CODE(_AtimDone) ,
-       GEN_EVT_CODE(_TX_Report),
-       GEN_EVT_CODE(_CCX_Report),                      /*15*/
-       GEN_EVT_CODE(_DTM_Report),
-       GEN_EVT_CODE(_TX_Rate_Statistics),
-       GEN_EVT_CODE(_C2HLBK),
-       GEN_EVT_CODE(_FWDBG),
-       GEN_EVT_CODE(_C2HFEEDBACK),               /*20*/
-       GEN_EVT_CODE(_ADDBA),
-       GEN_EVT_CODE(_C2HBCN),
-       GEN_EVT_CODE(_ReportPwrState),          /* filen: only for PCIE, USB */
-       GEN_EVT_CODE(_CloseRF),                         /* filen: only for PCIE, work around ASPM */
-       MAX_C2HEVT
-};
-
-#endif
diff --git a/drivers/staging/rtl8723au/include/rtw_pwrctrl.h b/drivers/staging/rtl8723au/include/rtw_pwrctrl.h
deleted file mode 100644 (file)
index 699b9f3..0000000
+++ /dev/null
@@ -1,242 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#ifndef __RTW_PWRCTRL_H_
-#define __RTW_PWRCTRL_H_
-
-#include <linux/mutex.h>
-#include <osdep_service.h>
-#include <drv_types.h>
-
-#define FW_PWR0                0
-#define FW_PWR1                1
-#define FW_PWR2                2
-#define FW_PWR3                3
-
-
-#define HW_PWR0                7
-#define HW_PWR1                6
-#define HW_PWR2                2
-#define HW_PWR3                0
-#define HW_PWR4                8
-
-#define FW_PWRMSK      0x7
-
-
-#define XMIT_ALIVE     BIT(0)
-#define RECV_ALIVE     BIT(1)
-#define CMD_ALIVE      BIT(2)
-#define EVT_ALIVE      BIT(3)
-
-enum Power_Mgnt {
-       PS_MODE_ACTIVE  = 0,
-       PS_MODE_MIN,
-       PS_MODE_MAX,
-       PS_MODE_DTIM,
-       PS_MODE_VOIP,
-       PS_MODE_UAPSD_WMM,
-       PS_MODE_UAPSD,
-       PS_MODE_IBSS,
-       PS_MODE_WWLAN,
-       PM_Radio_Off,
-       PM_Card_Disable,
-       PS_MODE_NUM
-};
-
-
-/* BIT[2:0] = HW state
- * BIT[3] = Protocol PS state,  0: active, 1: sleep state
- * BIT[4] = sub-state
- */
-
-#define PS_DPS                 BIT(0)
-#define PS_LCLK                        (PS_DPS)
-#define PS_RF_OFF              BIT(1)
-#define PS_ALL_ON              BIT(2)
-#define PS_ST_ACTIVE           BIT(3)
-
-#define PS_ISR_ENABLE          BIT(4)
-#define PS_IMR_ENABLE          BIT(5)
-#define PS_ACK                 BIT(6)
-#define PS_TOGGLE              BIT(7)
-
-#define PS_STATE_MASK          (0x0F)
-#define PS_STATE_HW_MASK       (0x07)
-#define PS_SEQ_MASK            (0xc0)
-
-#define PS_STATE(x)            (PS_STATE_MASK & (x))
-#define PS_STATE_HW(x) (PS_STATE_HW_MASK & (x))
-#define PS_SEQ(x)              (PS_SEQ_MASK & (x))
-
-#define PS_STATE_S0            (PS_DPS)
-#define PS_STATE_S1            (PS_LCLK)
-#define PS_STATE_S2            (PS_RF_OFF)
-#define PS_STATE_S3            (PS_ALL_ON)
-#define PS_STATE_S4            ((PS_ST_ACTIVE) | (PS_ALL_ON))
-
-
-#define PS_IS_RF_ON(x) ((x) & (PS_ALL_ON))
-#define PS_IS_ACTIVE(x)        ((x) & (PS_ST_ACTIVE))
-#define CLR_PS_STATE(x)        ((x) = ((x) & (0xF0)))
-
-
-struct reportpwrstate_parm {
-       unsigned char mode;
-       unsigned char state; /* the CPWM value */
-       unsigned short rsvd;
-};
-
-#define LPS_DELAY_TIME (1*HZ) /*  1 sec */
-
-#define EXE_PWR_NONE           0x01
-#define EXE_PWR_IPS            0x02
-#define EXE_PWR_LPS            0x04
-
-/*  RF state. */
-enum rt_rf_power_state {
-       rf_on,          /*  RF is on after RFSleep or RFOff */
-       rf_sleep,       /*  802.11 Power Save mode */
-       rf_off,         /*  HW/SW Radio OFF or Inactive Power Save */
-       /* Add the new RF state above this line===== */
-       rf_max
-};
-
-/*  RF Off Level for IPS or HW/SW radio off */
-#define        RT_RF_OFF_LEVL_ASPM             BIT(0)  /*  PCI ASPM */
-#define        RT_RF_OFF_LEVL_CLK_REQ          BIT(1)  /*  PCI clock request */
-#define        RT_RF_OFF_LEVL_PCI_D3           BIT(2)  /*  PCI D3 mode */
-/* NIC halt, re-init hw params */
-#define        RT_RF_OFF_LEVL_HALT_NIC         BIT(3)
-/*  FW free, re-download the FW */
-#define        RT_RF_OFF_LEVL_FREE_FW          BIT(4)
-#define        RT_RF_OFF_LEVL_FW_32K           BIT(5)  /*  FW in 32k */
-/*  Always enable ASPM and Clock Req in initialization. */
-#define        RT_RF_PS_LEVEL_ALWAYS_ASPM      BIT(6)
-/*  When LPS is on, disable 2R if no packet is received or transmittd. */
-#define        RT_RF_LPS_DISALBE_2R            BIT(30)
-#define        RT_RF_LPS_LEVEL_ASPM            BIT(31) /*  LPS with ASPM */
-
-#define        RT_IN_PS_LEVEL(ppsc, _PS_FLAG)                          \
-       ((ppsc->cur_ps_level & _PS_FLAG) ? true : false)
-#define        RT_CLEAR_PS_LEVEL(ppsc, _PS_FLAG)                       \
-       (ppsc->cur_ps_level &= (~(_PS_FLAG)))
-#define        RT_SET_PS_LEVEL(ppsc, _PS_FLAG)                         \
-       (ppsc->cur_ps_level |= _PS_FLAG)
-
-
-enum {
-       PSBBREG_RF0 = 0,
-       PSBBREG_RF1,
-       PSBBREG_RF2,
-       PSBBREG_AFE0,
-       PSBBREG_TOTALCNT
-};
-
-enum { /*  for ips_mode */
-       IPS_NONE = 0,
-       IPS_NORMAL,
-       IPS_LEVEL_2,
-};
-
-struct pwrctrl_priv {
-       struct mutex mutex_lock;
-       volatile u8 rpwm; /* requested power state for fw */
-       volatile u8 cpwm; /* fw current power state. updated when 1.
-                          * read from HCPWM 2. driver lowers power level
-                          */
-       volatile u8 tog; /*  toggling */
-
-       u8      pwr_mode;
-       u8      smart_ps;
-       u8      bcn_ant_mode;
-
-       u8      bpower_saving;
-
-       u8      reg_rfoff;
-       u32     rfoff_reason;
-
-       /* RF OFF Level */
-       u32     cur_ps_level;
-       u32     reg_rfps_level;
-
-       uint    ips_enter23a_cnts;
-       uint    ips_leave23a_cnts;
-
-       u8      ips_mode;
-       u8      ips_mode_req; /*  used to accept the mode setting request */
-       uint bips_processing;
-       unsigned long ips_deny_time; /* deny IPS when system time is smaller */
-       u8 ps_processing; /* used to mark whether in rtw_ps_processor23a */
-
-       u8      bLeisurePs;
-       u8      LpsIdleCount;
-       u8      power_mgnt;
-       u8      bFwCurrentInPSMode;
-       unsigned long   DelayLPSLastTimeStamp;
-       u8      btcoex_rfon;
-
-       u8              bInSuspend;
-#ifdef CONFIG_8723AU_BT_COEXIST
-       u8              bAutoResume;
-       u8              autopm_cnt;
-#endif
-       u8              bSupportRemoteWakeup;
-       struct timer_list       pwr_state_check_timer;
-       int             pwr_state_check_interval;
-       u8              pwr_state_check_cnts;
-
-       enum rt_rf_power_state  rf_pwrstate;/* cur power state */
-       enum rt_rf_power_state  change_rfpwrstate;
-
-       u8      bkeepfwalive;
-       unsigned long PS_BBRegBackup[PSBBREG_TOTALCNT];
-};
-
-#define RTW_PWR_STATE_CHK_INTERVAL 2000
-
-#define _rtw_set_pwr_state_check_timer(pwrctrlpriv, ms) \
-       (mod_timer(&pwrctrlpriv->pwr_state_check_timer, jiffies +       \
-                 msecs_to_jiffies(ms)))
-
-#define rtw_set_pwr_state_check_timer(pwrctrlpriv)     \
-       (_rtw_set_pwr_state_check_timer((pwrctrlpriv),  \
-                        (pwrctrlpriv)->pwr_state_check_interval))
-
-void rtw_init_pwrctrl_priv23a(struct rtw_adapter *adapter);
-void rtw_free_pwrctrl_priv(struct rtw_adapter *adapter);
-
-void rtw_set_ps_mode23a(struct rtw_adapter *padapter, u8 ps_mode,
-                    u8 smart_ps, u8 bcn_ant_mode);
-void rtw_set_rpwm23a(struct rtw_adapter *padapter, u8 val8);
-void LeaveAllPowerSaveMode23a(struct rtw_adapter *adapter);
-void ips_enter23a(struct rtw_adapter *padapter);
-int ips_leave23a(struct rtw_adapter *padapter);
-
-void rtw_ps_processor23a(struct rtw_adapter *padapter);
-
-enum rt_rf_power_state RfOnOffDetect23a(struct rtw_adapter *adapter);
-
-s32 LPS_RF_ON_check23a(struct rtw_adapter *padapter, u32 delay_ms);
-void LPS_Enter23a(struct rtw_adapter *padapter);
-void LPS_Leave23a(struct rtw_adapter *padapter);
-
-void rtw_set_ips_deny23a(struct rtw_adapter *padapter, u32 ms);
-int _rtw_pwr_wakeup23a(struct rtw_adapter *padapter, u32 ips_deffer_ms,
-                   const char *caller);
-#define rtw_pwr_wakeup(adapter) _rtw_pwr_wakeup23a(adapter,            \
-        RTW_PWR_STATE_CHK_INTERVAL, __func__)
-int rtw_pm_set_ips23a(struct rtw_adapter *padapter, u8 mode);
-int rtw_pm_set_lps23a(struct rtw_adapter *padapter, u8 mode);
-
-#endif  /* __RTL871X_PWRCTRL_H_ */
diff --git a/drivers/staging/rtl8723au/include/rtw_recv.h b/drivers/staging/rtl8723au/include/rtw_recv.h
deleted file mode 100644 (file)
index 85a5edb..0000000
+++ /dev/null
@@ -1,305 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#ifndef _RTW_RECV_H_
-#define _RTW_RECV_H_
-
-#include <osdep_service.h>
-#include <drv_types.h>
-#include <Hal8723APhyCfg.h>
-
-#define NR_RECVFRAME           256
-
-#define MAX_RXFRAME_CNT                512
-#define MAX_RX_NUMBLKS         (32)
-#define RECVFRAME_HDR_ALIGN    128
-
-#define SNAP_SIZE sizeof(struct ieee80211_snap_hdr)
-
-#define MAX_SUBFRAME_COUNT     64
-
-/* for Rx reordering buffer control */
-struct recv_reorder_ctrl {
-       struct rtw_adapter      *padapter;
-       u8 enable;
-       u16 indicate_seq;/* wstart_b, init_value=0xffff */
-       u16 wend_b;
-       u8 wsize_b;
-       struct rtw_queue pending_recvframe_queue;
-       struct timer_list reordering_ctrl_timer;
-};
-
-struct stainfo_rxcache {
-       u16     tid_rxseq[16];
-/*
-       unsigned short  tid0_rxseq;
-       unsigned short  tid1_rxseq;
-       unsigned short  tid2_rxseq;
-       unsigned short  tid3_rxseq;
-       unsigned short  tid4_rxseq;
-       unsigned short  tid5_rxseq;
-       unsigned short  tid6_rxseq;
-       unsigned short  tid7_rxseq;
-       unsigned short  tid8_rxseq;
-       unsigned short  tid9_rxseq;
-       unsigned short  tid10_rxseq;
-       unsigned short  tid11_rxseq;
-       unsigned short  tid12_rxseq;
-       unsigned short  tid13_rxseq;
-       unsigned short  tid14_rxseq;
-       unsigned short  tid15_rxseq;
-*/
-};
-
-struct smooth_rssi_data {
-       u32     elements[100];  /* array to store values */
-       u32     index;                  /* index to current array to store */
-       u32     total_num;              /* num of valid elements */
-       u32     total_val;              /* sum of valid elements */
-};
-
-struct signal_stat {
-       u8      update_req;             /* used to indicate */
-       u8      avg_val;                /* avg of valid elements */
-       u32     total_num;              /* num of valid elements */
-       u32     total_val;              /* sum of valid elements */
-};
-
-struct phy_info {
-       u8              RxPWDBAll;
-       u8              SignalQuality;   /*  in 0-100 index. */
-       u8              RxMIMOSignalQuality[RF_PATH_MAX]; /* EVM */
-       u8              RxMIMOSignalStrength[RF_PATH_MAX];/* 0~100 */
-       s8              RxPower; /*  in dBm Translate from PWdB */
-       /* Real power in dBm for this packet, no beautification and aggregation.
-        * Keep this raw info to be used for the other procedures.
-        */
-       s8              RecvSignalPower;
-       u8              BTRxRSSIPercentage;
-       u8              SignalStrength; /*  in 0-100 index. */
-       u8              RxPwr[RF_PATH_MAX];/* per-path's pwdb */
-       u8              RxSNR[RF_PATH_MAX];/* per-path's SNR */
-};
-
-
-struct rx_pkt_attrib   {
-       u16     pkt_len;
-       u8      physt;
-       u8      drvinfo_sz;
-       u8      shift_sz;
-       u8      hdrlen; /* the WLAN Header Len */
-       u8      amsdu;
-       u8      qos;
-       u8      priority;
-       u8      pw_save;
-       u8      mdata;
-       u16     seq_num;
-       u8      frag_num;
-       u8      mfrag;
-       u8      order;
-       u8      privacy; /* in frame_ctrl field */
-       u8      bdecrypted;
-       /* when 0 indicate no encrypt. when non-zero, indicate the algorith */
-       u32     encrypt;
-       u8      iv_len;
-       u8      icv_len;
-       u8      crc_err;
-       u8      icv_err;
-
-       u16 eth_type;
-
-       u8      dst[ETH_ALEN];
-       u8      src[ETH_ALEN];
-       u8      ta[ETH_ALEN];
-       u8      ra[ETH_ALEN];
-       u8      bssid[ETH_ALEN];
-
-       u8 ack_policy;
-
-       u8      tcpchk_valid; /*  0: invalid, 1: valid */
-       u8      ip_chkrpt; /* 0: incorrect, 1: correct */
-       u8      tcp_chkrpt; /* 0: incorrect, 1: correct */
-       u8      key_index;
-
-       u8      mcs_rate;
-       u8      rxht;
-       u8      sgi;
-       u8      pkt_rpt_type;
-       u32     MacIDValidEntry[2];     /*  64 bits present 64 entry. */
-       struct phy_info phy_info;
-};
-
-/* These definition is used for Rx packet reordering. */
-#define SN_LESS(a, b)          (((a-b) & 0x800) != 0)
-#define SN_EQUAL(a, b)         (a == b)
-#define REORDER_WAIT_TIME      (50) /*  (ms) */
-
-#define RECVBUFF_ALIGN_SZ 8
-
-#define RXDESC_SIZE    24
-#define RXDESC_OFFSET RXDESC_SIZE
-
-struct recv_stat {
-       __le32 rxdw0;
-       __le32 rxdw1;
-       __le32 rxdw2;
-       __le32 rxdw3;
-       __le32 rxdw4;
-       __le32 rxdw5;
-};
-
-/* accesser of recv_priv: rtw_recv_entry23a(dispatch / passive level); \
- * recv_thread(passive) ; returnpkt(dispatch) ; halt(passive) ;
- *
- * using enter_critical section to protect
- */
-struct recv_priv {
-       spinlock_t      lock;
-
-       struct rtw_queue        free_recv_queue;
-       struct rtw_queue        recv_pending_queue;
-       struct rtw_queue        uc_swdec_pending_queue;
-
-       int free_recvframe_cnt;
-
-       struct rtw_adapter      *adapter;
-
-       u32     bIsAnyNonBEPkts;
-       u64     rx_bytes;
-       u64     rx_pkts;
-       u64     rx_drop;
-       u64     last_rx_bytes;
-
-       uint  rx_icv_err;
-       uint  rx_largepacket_crcerr;
-       uint  rx_smallpacket_crcerr;
-       uint  rx_middlepacket_crcerr;
-
-       /* u8 *pallocated_urb_buf; */
-       u8      rx_pending_cnt;
-
-       struct urb *int_in_urb;
-
-       u8      *int_in_buf;
-
-       struct tasklet_struct irq_prepare_beacon_tasklet;
-       struct tasklet_struct recv_tasklet;
-       struct sk_buff_head free_recv_skb_queue;
-       struct sk_buff_head rx_skb_queue;
-       u8 *precv_buf;
-
-       /* For display the phy informatiom */
-       s8 rxpwdb;
-       u8 signal_strength;
-       u8 signal_qual;
-       u8 noise;
-       int RxSNRdB[2];
-       s8 RxRssi[2];
-       int FalseAlmCnt_all;
-
-       struct timer_list signal_stat_timer;
-       u32 signal_stat_sampling_interval;
-       /* u32 signal_stat_converging_constant; */
-       struct signal_stat signal_qual_data;
-       struct signal_stat signal_strength_data;
-};
-
-#define rtw_set_signal_stat_timer(recvpriv)                    \
-        mod_timer(&(recvpriv)->signal_stat_timer, jiffies +    \
-                  msecs_to_jiffies((recvpriv)->signal_stat_sampling_interval))
-
-struct sta_recv_priv {
-       spinlock_t      lock;
-       int     option;
-
-       /* struct rtw_queue     blk_strms[MAX_RX_NUMBLKS]; */
-       struct rtw_queue defrag_q;       /* keeping the fragment frame until defrag */
-
-       struct  stainfo_rxcache rxcache;
-
-       /* uint sta_rx_bytes; */
-       /* uint sta_rx_pkts; */
-       /* uint sta_rx_fail; */
-
-};
-
-
-struct recv_buf {
-       struct list_head list;
-
-       struct rtw_adapter *adapter;
-
-       struct urb *purb;
-       struct sk_buff *pskb;
-};
-
-/*     head  ----->
- *
- *             data  ----->
- *
- *                     payload
- *
- *             tail  ----->
- *
- *     end   ----->
- *
- *     len = (unsigned int )(tail - data);
- *
- */
-struct recv_frame {
-       struct list_head        list;
-       struct sk_buff *pkt;
-
-       struct rtw_adapter  *adapter;
-
-       struct rx_pkt_attrib attrib;
-
-       struct sta_info *psta;
-
-       /* for A-MPDU Rx reordering buffer control */
-       struct recv_reorder_ctrl *preorder_ctrl;
-};
-
-/* get a free recv_frame from pfree_recv_queue */
-struct recv_frame *rtw_alloc_recvframe23a(struct rtw_queue *pfree_recv_queue);
-int rtw_free_recvframe23a(struct recv_frame *precvframe);
-
-int rtw_enqueue_recvframe23a(struct recv_frame *precvframe, struct rtw_queue *queue);
-
-u32 rtw_free_uc_swdec_pending_queue23a(struct rtw_adapter *adapter);
-
-struct recv_buf *rtw_dequeue_recvbuf23a(struct rtw_queue *queue);
-
-void rtw_reordering_ctrl_timeout_handler23a(unsigned long pcontext);
-
-static inline s32 translate_percentage_to_dbm(u32 SignalStrengthIndex)
-{
-       s32     SignalPower; /*  in dBm. */
-
-       /*  Translate to dBm (x=0.5y-95). */
-       SignalPower = (s32)((SignalStrengthIndex + 1) >> 1);
-       SignalPower -= 95;
-
-       return SignalPower;
-}
-
-
-struct sta_info;
-
-void _rtw_init_sta_recv_priv23a(struct sta_recv_priv *psta_recvpriv);
-
-void mgt_dispatcher23a(struct rtw_adapter *padapter,
-                   struct recv_frame *precv_frame);
-
-#endif
diff --git a/drivers/staging/rtl8723au/include/rtw_rf.h b/drivers/staging/rtl8723au/include/rtw_rf.h
deleted file mode 100644 (file)
index a7de714..0000000
+++ /dev/null
@@ -1,102 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#ifndef        __RTW_RF_H_
-#define __RTW_RF_H_
-
-#include <rtw_cmd.h>
-
-#define OFDM_PHY               1
-#define MIXED_PHY              2
-#define CCK_PHY                        3
-
-#define NumRates               (13)
-
-/*  slot time for 11g */
-#define SHORT_SLOT_TIME                        9
-#define NON_SHORT_SLOT_TIME            20
-
-/*  We now define the max channels in each channel plan. */
-#define        MAX_CHANNEL_NUM_2G      14
-#define        MAX_CHANNEL_NUM_5G      24
-#define        MAX_CHANNEL_NUM         38/* 14+24 */
-
-/* define NUM_REGULATORYS      21 */
-#define NUM_REGULATORYS        1
-
-/* Country codes */
-#define USA            0x555320
-#define EUROPE         0x1 /* temp, should be provided later */
-#define JAPAN          0x2 /* temp, should be provided later */
-
-struct regulatory_class {
-       u32     starting_freq;                                  /* MHz, */
-       u8      channel_set[MAX_CHANNEL_NUM];
-       u8      channel_cck_power[MAX_CHANNEL_NUM];/* dbm */
-       u8      channel_ofdm_power[MAX_CHANNEL_NUM];/* dbm */
-       u8      txpower_limit;                                  /* dbm */
-       u8      channel_spacing;                                /* MHz */
-       u8      modem;
-};
-
-enum {
-       cESS            = 0x0001,
-       cIBSS           = 0x0002,
-       cPollable       = 0x0004,
-       cPollReq        = 0x0008,
-       cPrivacy        = 0x0010,
-       cShortPreamble  = 0x0020,
-       cPBCC           = 0x0040,
-       cChannelAgility = 0x0080,
-       cSpectrumMgnt   = 0x0100,
-       cQos            = 0x0200,       /*  For HCCA, use with CF-Pollable and CF-PollReq */
-       cShortSlotTime  = 0x0400,
-       cAPSD           = 0x0800,
-       cRM             = 0x1000,       /*  RRM (Radio Request Measurement) */
-       cDSSS_OFDM      = 0x2000,
-       cDelayedBA      = 0x4000,
-       cImmediateBA    = 0x8000,
-};
-
-enum {
-       PREAMBLE_LONG   = 1,
-       PREAMBLE_AUTO   = 2,
-       PREAMBLE_SHORT  = 3,
-};
-
-/*  Bandwidth Offset */
-#define HAL_PRIME_CHNL_OFFSET_DONT_CARE        0
-#define HAL_PRIME_CHNL_OFFSET_LOWER    1
-#define HAL_PRIME_CHNL_OFFSET_UPPER    2
-
-/*  Represent Channel Width in HT Capabilities */
-enum ht_channel_width {
-       HT_CHANNEL_WIDTH_20 = 0,
-       HT_CHANNEL_WIDTH_40 = 1,
-       HT_CHANNEL_WIDTH_80 = 2,
-       HT_CHANNEL_WIDTH_160 = 3,
-       HT_CHANNEL_WIDTH_10 = 4,
-};
-
-/* 2007/11/15 MH Define different RF type. */
-enum {
-       RF_1T2R = 0,
-       RF_2T4R = 1,
-       RF_2T2R = 2,
-       RF_1T1R = 3,
-       RF_2T2R_GREEN = 4,
-       RF_819X_MAX_TYPE = 5,
-};
-
-#endif /* _RTL8711_RF_H_ */
diff --git a/drivers/staging/rtl8723au/include/rtw_security.h b/drivers/staging/rtl8723au/include/rtw_security.h
deleted file mode 100644 (file)
index 624a9d7..0000000
+++ /dev/null
@@ -1,331 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#ifndef __RTW_SECURITY_H_
-#define __RTW_SECURITY_H_
-
-#include <osdep_service.h>
-#include <drv_types.h>
-#include <net/lib80211.h>
-
-
-#define is_wep_enc(alg) (alg == WLAN_CIPHER_SUITE_WEP40 || \
-                        alg == WLAN_CIPHER_SUITE_WEP104)
-
-#define SHA256_MAC_LEN 32
-#define AES_BLOCK_SIZE 16
-#define AES_PRIV_SIZE (4 * 44)
-
-enum ENCRYP_PROTOCOL {
-       ENCRYP_PROTOCOL_OPENSYS,   /* open system */
-       ENCRYP_PROTOCOL_WEP,       /* WEP */
-       ENCRYP_PROTOCOL_WPA,       /* WPA */
-       ENCRYP_PROTOCOL_WPA2,      /* WPA2 */
-       ENCRYP_PROTOCOL_MAX
-};
-
-#ifndef Ndis802_11AuthModeWPA2
-#define Ndis802_11AuthModeWPA2 (Ndis802_11AuthModeWPANone + 1)
-#endif
-
-#ifndef Ndis802_11AuthModeWPA2PSK
-#define Ndis802_11AuthModeWPA2PSK (Ndis802_11AuthModeWPANone + 2)
-#endif
-
-union pn48 {
-       u64     val;
-
-#ifdef __LITTLE_ENDIAN
-
-struct {
-       u8 TSC0;
-       u8 TSC1;
-       u8 TSC2;
-       u8 TSC3;
-       u8 TSC4;
-       u8 TSC5;
-       u8 TSC6;
-       u8 TSC7;
-} _byte_;
-
-#elif defined(__BIG_ENDIAN)
-
-struct {
-       u8 TSC7;
-       u8 TSC6;
-       u8 TSC5;
-       u8 TSC4;
-       u8 TSC3;
-       u8 TSC2;
-       u8 TSC1;
-       u8 TSC0;
-} _byte_;
-#else
-#error Need BIG or LITTLE endian
-
-#endif
-
-};
-
-union Keytype {
-       u8   skey[16];
-       u32    lkey[4];
-};
-
-struct rtw_wep_key {
-       u8 key[WLAN_KEY_LEN_WEP104 + 1]; /* 14 */
-       u16 keylen;
-};
-
-struct rt_pmkid_list {
-       u8      bUsed;
-       u8      Bssid[6];
-       u8      PMKID[16];
-       u8      SsidBuf[33];
-       u8      *ssid_octet;
-       u16     ssid_length;
-};
-
-struct security_priv {
-       u32       dot11AuthAlgrthm;     /*  802.11 auth, could be open, shared,
-                                        * 8021x and authswitch */
-       u32       dot11PrivacyAlgrthm;  /* This specifies the privacy for
-                                        * shared auth. algorithm.
-                                        */
-       /* WEP */
-       u32       dot11PrivacyKeyIndex; /*  this is only valid for legendary
-                                        * wep, 0~3 for key id. (tx key index)
-                                        */
-       struct rtw_wep_key wep_key[NUM_WEP_KEYS];
-
-       u32 dot118021XGrpPrivacy;       /* specify the privacy algthm.
-                                        * used for Grp key
-                                        */
-       u32     dot118021XGrpKeyid;     /*  key id used for Grp Key
-                                        * (tx key index)
-                                        */
-       union Keytype   dot118021XGrpKey[4];/* 802.1x Grp Key, inx0 and inx1 */
-       union Keytype   dot118021XGrptxmickey[4];
-       union Keytype   dot118021XGrprxmickey[4];
-       union pn48      dot11Grptxpn;           /* PN48 used for Grp Key xmit.*/
-       union pn48      dot11Grprxpn;           /* PN48 used for Grp Key recv.*/
-
-#ifdef CONFIG_8723AU_AP_MODE
-       /* extend security capabilities for AP_MODE */
-       unsigned int dot8021xalg;/* 0:disable, 1:psk, 2:802.1x */
-       unsigned int wpa_psk;/* 0:disable, bit(0): WPA, bit(1):WPA2 */
-       unsigned int wpa_group_cipher;
-       unsigned int wpa2_group_cipher;
-       unsigned int wpa_pairwise_cipher;
-       unsigned int wpa2_pairwise_cipher;
-#endif
-
-       u8 wps_ie[MAX_WPS_IE_LEN];/* added in assoc req */
-       int wps_ie_len;
-       unsigned int binstallGrpkey:1;
-       unsigned int busetkipkey:1;
-       unsigned int bcheck_grpkey:1;
-       unsigned int hw_decrypted:1;
-       u32 ndisauthtype;       /*  enum ndis_802_11_auth_mode */
-       u32 ndisencryptstatus;  /*  NDIS_802_11_ENCRYPTION_STATUS */
-       struct wlan_bssid_ex sec_bss;  /* for joinbss (h2c buffer) usage */
-       u8 assoc_info[600];
-       u8 szofcapability[256]; /* for wpa2 usage */
-       u8 oidassociation[512]; /* for wpa/wpa2 usage */
-       u8 supplicant_ie[256];  /* store sta security information element */
-
-       /* for tkip countermeasure */
-       unsigned long last_mic_err_time;
-       u8      btkip_countermeasure;
-       u8      btkip_wait_report;
-       unsigned long btkip_countermeasure_time;
-
-       /*  For WPA2 Pre-Authentication. */
-       struct rt_pmkid_list PMKIDList[NUM_PMKID_CACHE];
-       u8 PMKIDIndex;
-       u8 bWepDefaultKeyIdxSet;
-};
-
-struct sha256_state {
-       u64 length;
-       u32 state[8], curlen;
-       u8 buf[64];
-};
-
-#define GET_ENCRY_ALGO(psecuritypriv, psta, encry_algo, bmcst)\
-do {\
-       switch (psecuritypriv->dot11AuthAlgrthm) {\
-       case dot11AuthAlgrthm_Open:\
-       case dot11AuthAlgrthm_Shared:\
-       case dot11AuthAlgrthm_Auto:\
-               encry_algo = psecuritypriv->dot11PrivacyAlgrthm;\
-               break;\
-       case dot11AuthAlgrthm_8021X:\
-               if (bmcst)\
-                       encry_algo = psecuritypriv->dot118021XGrpPrivacy;\
-               else\
-                       encry_algo = psta->dot118021XPrivacy;\
-               break;\
-       }       \
-} while (0)
-
-#define GET_TKIP_PN(iv, dot11txpn)\
-do {\
-       dot11txpn._byte_.TSC0 = iv[2];\
-       dot11txpn._byte_.TSC1 = iv[0];\
-       dot11txpn._byte_.TSC2 = iv[4];\
-       dot11txpn._byte_.TSC3 = iv[5];\
-       dot11txpn._byte_.TSC4 = iv[6];\
-       dot11txpn._byte_.TSC5 = iv[7];\
-} while (0)
-
-#define ROL32(A, n)  (((A) << (n)) | (((A)>>(32-(n)))  & ((1UL << (n)) - 1)))
-#define ROR32(A, n)  ROL32((A), 32-(n))
-
-struct mic_data {
-       u32  K0, K1;         /*  Key */
-       u32  L, R;           /*  Current state */
-       u32  M;              /*  Message accumulator (single word) */
-       u32     nBytesInM;      /*  # bytes in M */
-};
-
-extern const u32 Te0[256];
-extern const u32 Te1[256];
-extern const u32 Te2[256];
-extern const u32 Te3[256];
-extern const u32 Te4[256];
-extern const u32 Td0[256];
-extern const u32 Td1[256];
-extern const u32 Td2[256];
-extern const u32 Td3[256];
-extern const u32 Td4[256];
-extern const u32 rcon[10];
-extern const u8 Td4s[256];
-extern const u8 rcons[10];
-
-#define RCON(i) (rcons[(i)] << 24)
-
-static inline u32 rotr(u32 val, int bits)
-{
-       return (val >> bits) | (val << (32 - bits));
-}
-
-#define TE0(i) Te0[((i) >> 24) & 0xff]
-#define TE1(i) rotr(Te0[((i) >> 16) & 0xff], 8)
-#define TE2(i) rotr(Te0[((i) >> 8) & 0xff], 16)
-#define TE3(i) rotr(Te0[(i) & 0xff], 24)
-#define TE41(i) ((Te0[((i) >> 24) & 0xff] << 8) & 0xff000000)
-#define TE42(i) (Te0[((i) >> 16) & 0xff] & 0x00ff0000)
-#define TE43(i) (Te0[((i) >> 8) & 0xff] & 0x0000ff00)
-#define TE44(i) ((Te0[(i) & 0xff] >> 8) & 0x000000ff)
-#define TE421(i) ((Te0[((i) >> 16) & 0xff] << 8) & 0xff000000)
-#define TE432(i) (Te0[((i) >> 8) & 0xff] & 0x00ff0000)
-#define TE443(i) (Te0[(i) & 0xff] & 0x0000ff00)
-#define TE414(i) ((Te0[((i) >> 24) & 0xff] >> 8) & 0x000000ff)
-#define TE4(i) ((Te0[(i)] >> 8) & 0x000000ff)
-
-#define TD0(i) Td0[((i) >> 24) & 0xff]
-#define TD1(i) rotr(Td0[((i) >> 16) & 0xff], 8)
-#define TD2(i) rotr(Td0[((i) >> 8) & 0xff], 16)
-#define TD3(i) rotr(Td0[(i) & 0xff], 24)
-#define TD41(i) (Td4s[((i) >> 24) & 0xff] << 24)
-#define TD42(i) (Td4s[((i) >> 16) & 0xff] << 16)
-#define TD43(i) (Td4s[((i) >> 8) & 0xff] << 8)
-#define TD44(i) (Td4s[(i) & 0xff])
-#define TD0_(i) Td0[(i) & 0xff]
-#define TD1_(i) rotr(Td0[(i) & 0xff], 8)
-#define TD2_(i) rotr(Td0[(i) & 0xff], 16)
-#define TD3_(i) rotr(Td0[(i) & 0xff], 24)
-
-#define GETU32(pt) (((u32)(pt)[0] << 24) ^ ((u32)(pt)[1] << 16) ^ \
-                       ((u32)(pt)[2] <<  8) ^ ((u32)(pt)[3]))
-
-#define PUTU32(ct, st) { \
-(ct)[0] = (u8)((st) >> 24); (ct)[1] = (u8)((st) >> 16); \
-(ct)[2] = (u8)((st) >>  8); (ct)[3] = (u8)(st); }
-
-#define WPA_GET_BE32(a) ((((u32) (a)[0]) << 24) | (((u32) (a)[1]) << 16) | \
-                        (((u32) (a)[2]) << 8) | ((u32) (a)[3]))
-
-#define WPA_PUT_LE16(a, val)                   \
-       do {                                    \
-               (a)[1] = ((u16) (val)) >> 8;    \
-               (a)[0] = ((u16) (val)) & 0xff;  \
-       } while (0)
-
-#define WPA_PUT_BE32(a, val)                                   \
-       do {                                                    \
-               (a)[0] = (u8) ((((u32) (val)) >> 24) & 0xff);   \
-               (a)[1] = (u8) ((((u32) (val)) >> 16) & 0xff);   \
-               (a)[2] = (u8) ((((u32) (val)) >> 8) & 0xff);    \
-               (a)[3] = (u8) (((u32) (val)) & 0xff);           \
-       } while (0)
-
-#define WPA_PUT_BE64(a, val)                           \
-       do {                                            \
-               (a)[0] = (u8) (((u64) (val)) >> 56);    \
-               (a)[1] = (u8) (((u64) (val)) >> 48);    \
-               (a)[2] = (u8) (((u64) (val)) >> 40);    \
-               (a)[3] = (u8) (((u64) (val)) >> 32);    \
-               (a)[4] = (u8) (((u64) (val)) >> 24);    \
-               (a)[5] = (u8) (((u64) (val)) >> 16);    \
-               (a)[6] = (u8) (((u64) (val)) >> 8);     \
-               (a)[7] = (u8) (((u64) (val)) & 0xff);   \
-       } while (0)
-
-/* ===== start - public domain SHA256 implementation ===== */
-
-/* This is based on SHA256 implementation in LibTomCrypt that was released into
- * public domain by Tom St Denis. */
-
-/* the K array */
-static const unsigned long K[64] = {
-       0x428a2f98UL, 0x71374491UL, 0xb5c0fbcfUL, 0xe9b5dba5UL, 0x3956c25bUL,
-       0x59f111f1UL, 0x923f82a4UL, 0xab1c5ed5UL, 0xd807aa98UL, 0x12835b01UL,
-       0x243185beUL, 0x550c7dc3UL, 0x72be5d74UL, 0x80deb1feUL, 0x9bdc06a7UL,
-       0xc19bf174UL, 0xe49b69c1UL, 0xefbe4786UL, 0x0fc19dc6UL, 0x240ca1ccUL,
-       0x2de92c6fUL, 0x4a7484aaUL, 0x5cb0a9dcUL, 0x76f988daUL, 0x983e5152UL,
-       0xa831c66dUL, 0xb00327c8UL, 0xbf597fc7UL, 0xc6e00bf3UL, 0xd5a79147UL,
-       0x06ca6351UL, 0x14292967UL, 0x27b70a85UL, 0x2e1b2138UL, 0x4d2c6dfcUL,
-       0x53380d13UL, 0x650a7354UL, 0x766a0abbUL, 0x81c2c92eUL, 0x92722c85UL,
-       0xa2bfe8a1UL, 0xa81a664bUL, 0xc24b8b70UL, 0xc76c51a3UL, 0xd192e819UL,
-       0xd6990624UL, 0xf40e3585UL, 0x106aa070UL, 0x19a4c116UL, 0x1e376c08UL,
-       0x2748774cUL, 0x34b0bcb5UL, 0x391c0cb3UL, 0x4ed8aa4aUL, 0x5b9cca4fUL,
-       0x682e6ff3UL, 0x748f82eeUL, 0x78a5636fUL, 0x84c87814UL, 0x8cc70208UL,
-       0x90befffaUL, 0xa4506cebUL, 0xbef9a3f7UL, 0xc67178f2UL
-};
-
-void rtw_secmicsetkey23a(struct mic_data *pmicdata, u8 *key);
-void rtw_secmicappend23abyte23a(struct mic_data *pmicdata, u8 b);
-void rtw_secmicappend23a(struct mic_data *pmicdata, u8 *src, u32 nbBytes);
-void rtw_secgetmic23a(struct mic_data *pmicdata, u8 *dst);
-
-void rtw_seccalctkipmic23a(u8 *key, u8 *header, u8 *data, u32 data_len,
-                       u8 *Miccode, u8 priorityi);
-
-int rtw_aes_encrypt23a(struct rtw_adapter *padapter,
-                   struct xmit_frame *pxmitframe);
-int rtw_tkip_encrypt23a(struct rtw_adapter *padapter,
-                    struct xmit_frame *pxmitframe);
-void rtw_wep_encrypt23a(struct rtw_adapter *padapter,
-                    struct xmit_frame *pxmitframe);
-int rtw_aes_decrypt23a(struct rtw_adapter *padapter,
-                   struct recv_frame *precvframe);
-int rtw_tkip_decrypt23a(struct rtw_adapter *padapter,
-                    struct recv_frame *precvframe);
-void rtw_wep_decrypt23a(struct rtw_adapter *padapter, struct recv_frame *precvframe);
-
-void rtw_use_tkipkey_handler23a(void *FunctionContext);
-
-#endif /* __RTL871X_SECURITY_H_ */
diff --git a/drivers/staging/rtl8723au/include/rtw_sreset.h b/drivers/staging/rtl8723au/include/rtw_sreset.h
deleted file mode 100644 (file)
index 60fa829..0000000
+++ /dev/null
@@ -1,36 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#ifndef _RTW_SRESET_C_
-#define _RTW_SRESET_C_
-
-#include <osdep_service.h>
-#include <drv_types.h>
-
-struct sreset_priv {
-       struct mutex    silentreset_mutex;
-       u8      silent_reset_inprogress;
-       unsigned long last_tx_time;
-       unsigned long last_tx_complete_time;
-};
-
-#include <rtl8723a_hal.h>
-
-void rtw_sreset_init(struct rtw_adapter *padapter);
-void rtw_sreset_reset_value(struct rtw_adapter *padapter);
-bool rtw_sreset_inprogress(struct rtw_adapter *padapter);
-void sreset_set_trigger_point(struct rtw_adapter *padapter, s32 tgp);
-void rtw_sreset_reset(struct rtw_adapter *active_adapter);
-
-#endif
diff --git a/drivers/staging/rtl8723au/include/rtw_version.h b/drivers/staging/rtl8723au/include/rtw_version.h
deleted file mode 100644 (file)
index c947733..0000000
+++ /dev/null
@@ -1 +0,0 @@
-#define DRIVERVERSION  "v4.1.6_7336.20130426"
diff --git a/drivers/staging/rtl8723au/include/rtw_xmit.h b/drivers/staging/rtl8723au/include/rtw_xmit.h
deleted file mode 100644 (file)
index 24f326b..0000000
+++ /dev/null
@@ -1,380 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#ifndef _RTW_XMIT_H_
-#define _RTW_XMIT_H_
-
-#include <osdep_service.h>
-#include <drv_types.h>
-
-#define MAX_XMITBUF_SZ         2048
-#define NR_XMITBUFF            4
-
-#define XMITBUF_ALIGN_SZ       512
-
-/*  xmit extension buff defination */
-#define MAX_XMIT_EXTBUF_SZ     1536
-#define NR_XMIT_EXTBUFF                32
-
-#define MAX_NUMBLKS            1
-
-#define XMIT_VO_QUEUE          0
-#define XMIT_VI_QUEUE          1
-#define XMIT_BE_QUEUE          2
-#define XMIT_BK_QUEUE          3
-
-#define VO_QUEUE_INX           0
-#define VI_QUEUE_INX           1
-#define BE_QUEUE_INX           2
-#define BK_QUEUE_INX           3
-#define BCN_QUEUE_INX          4
-#define MGT_QUEUE_INX          5
-#define HIGH_QUEUE_INX         6
-#define TXCMD_QUEUE_INX                7
-
-#define HW_QUEUE_ENTRY         8
-
-#define WEP_IV(pattrib_iv, dot11txpn, keyidx)                          \
-do {                                                                   \
-       pattrib_iv[0] = dot11txpn._byte_.TSC0;                          \
-       pattrib_iv[1] = dot11txpn._byte_.TSC1;                          \
-       pattrib_iv[2] = dot11txpn._byte_.TSC2;                          \
-       pattrib_iv[3] = ((keyidx & 0x3) << 6);                          \
-       dot11txpn.val = (dot11txpn.val == 0xffffff) ? 0 :               \
-                        (dot11txpn.val+1);                             \
-} while (0)
-
-#define TKIP_IV(pattrib_iv, dot11txpn, keyidx)                         \
-do {                                                                   \
-       pattrib_iv[0] = dot11txpn._byte_.TSC1;                          \
-       pattrib_iv[1] = (dot11txpn._byte_.TSC1 | 0x20) & 0x7f;          \
-       pattrib_iv[2] = dot11txpn._byte_.TSC0;                          \
-       pattrib_iv[3] = BIT(5) | ((keyidx & 0x3)<<6);                   \
-       pattrib_iv[4] = dot11txpn._byte_.TSC2;                          \
-       pattrib_iv[5] = dot11txpn._byte_.TSC3;                          \
-       pattrib_iv[6] = dot11txpn._byte_.TSC4;                          \
-       pattrib_iv[7] = dot11txpn._byte_.TSC5;                          \
-       dot11txpn.val = dot11txpn.val == 0xffffffffffffULL ? 0 :        \
-                                        (dot11txpn.val+1);             \
-} while (0)
-
-#define AES_IV(pattrib_iv, dot11txpn, keyidx)\
-do {                                                                   \
-       pattrib_iv[0] = dot11txpn._byte_.TSC0;                          \
-       pattrib_iv[1] = dot11txpn._byte_.TSC1;                          \
-       pattrib_iv[2] = 0;                                              \
-       pattrib_iv[3] = BIT(5) | ((keyidx & 0x3) << 6);                 \
-       pattrib_iv[4] = dot11txpn._byte_.TSC2;                          \
-       pattrib_iv[5] = dot11txpn._byte_.TSC3;                          \
-       pattrib_iv[6] = dot11txpn._byte_.TSC4;                          \
-       pattrib_iv[7] = dot11txpn._byte_.TSC5;                          \
-       dot11txpn.val = dot11txpn.val == 0xffffffffffffULL ? 0 :        \
-                                        (dot11txpn.val+1);             \
-} while (0)
-
-#define HWXMIT_ENTRY   4
-
-#define TXDESC_SIZE 32
-
-#define PACKET_OFFSET_SZ 8
-#define TXDESC_OFFSET (TXDESC_SIZE + PACKET_OFFSET_SZ)
-
-struct tx_desc {
-       /* DWORD 0 */
-       __le32 txdw0;
-       __le32 txdw1;
-       __le32 txdw2;
-       __le32 txdw3;
-       __le32 txdw4;
-       __le32 txdw5;
-       __le32 txdw6;
-       __le32 txdw7;
-};
-
-union txdesc {
-       struct tx_desc txdesc;
-       unsigned int value[TXDESC_SIZE>>2];
-};
-
-struct hw_xmit {
-       struct rtw_queue *sta_queue;
-       int     accnt;
-};
-
-/* reduce size */
-struct pkt_attrib {
-       u16     type;
-       u8      bswenc;
-       u8      dhcp_pkt;
-       u16     ether_type;
-       u16     seqnum;
-       u16     pkt_hdrlen;     /* the original 802.3 pkt header len */
-       u16     hdrlen;         /* the WLAN Header Len */
-       u32     pktlen;         /* the original 802.3 pkt raw_data len */
-       u32     last_txcmdsz;
-       u32     encrypt;        /* when 0 indicate no encrypt. */
-       u8      nr_frags;
-       u8      iv_len;
-       u8      icv_len;
-       u8      iv[18];
-       u8      icv[16];
-       u8      priority;
-       u8      ack_policy;
-       u8      mac_id;
-       u8      vcs_mode;       /* virtual carrier sense method */
-       u8      dst[ETH_ALEN];
-       u8      src[ETH_ALEN];
-       u8      ta[ETH_ALEN];
-       u8      ra[ETH_ALEN];
-       u8      key_idx;
-       u8      qos_en;
-       u8      ht_en;
-       u8      raid;/* rate adpative id */
-       u8      bwmode;
-       u8      ch_offset;/* PRIME_CHNL_OFFSET */
-       u8      sgi;/* short GI */
-       u8      ampdu_en;/* tx ampdu enable */
-       u8      mdata;/* more data bit */
-       u8      pctrl;/* per packet txdesc control enable */
-       u8      triggered;/* for ap mode handling Power Saving sta */
-       u8      qsel;
-       u8      eosp;
-       u8      rate;
-       u8      retry_ctrl;
-       struct sta_info *psta;
-};
-
-#define WLANHDR_OFFSET         64
-
-#define NULL_FRAMETAG          0x0
-#define DATA_FRAMETAG          0x01
-#define L2_FRAMETAG            0x02
-#define MGNT_FRAMETAG          0x03
-#define AMSDU_FRAMETAG         0x04
-
-#define EII_FRAMETAG           0x05
-#define IEEE8023_FRAMETAG      0x06
-
-#define MP_FRAMETAG            0x07
-
-#define TXAGG_FRAMETAG         0x08
-
-struct  submit_ctx {
-       u32 timeout_ms; /* <0: not synchronous, 0: wait forever,
-                        * >0: up to ms waiting
-                        */
-       int status; /* status for operation */
-       struct completion done;
-};
-
-enum {
-       RTW_SCTX_SUBMITTED = -1,
-       RTW_SCTX_DONE_SUCCESS = 0,
-       RTW_SCTX_DONE_UNKNOWN,
-       RTW_SCTX_DONE_TIMEOUT,
-       RTW_SCTX_DONE_BUF_ALLOC,
-       RTW_SCTX_DONE_BUF_FREE,
-       RTW_SCTX_DONE_WRITE_PORT_ERR,
-       RTW_SCTX_DONE_TX_DESC_NA,
-       RTW_SCTX_DONE_TX_DENY,
-       RTW_SCTX_DONE_CCX_PKT_FAIL,
-       RTW_SCTX_DONE_DRV_STOP,
-       RTW_SCTX_DONE_DEV_REMOVE,
-};
-
-void rtw_sctx_init23a(struct submit_ctx *sctx, int timeout_ms);
-int rtw_sctx_wait23a(struct submit_ctx *sctx);
-void rtw23a_sctx_done_err(struct submit_ctx **sctx, int status);
-
-struct xmit_buf {
-       struct list_head list, list2;
-       struct rtw_adapter *padapter;
-
-       u8 *pallocated_buf;
-       u8 *pbuf;
-       void *priv_data;
-
-       u16 ext_tag; /*  0: Normal xmitbuf, 1: extension xmitbuf. */
-       u16 flags;
-       u32 alloc_sz;
-       u32  len;
-       struct submit_ctx *sctx;
-       u32     ff_hwaddr;
-       struct urb *pxmit_urb[8];
-       u8 bpending[8];
-       int last[8];
-#if defined(DBG_XMIT_BUF) || defined(DBG_XMIT_BUF_EXT)
-       u8 no;
-#endif
-};
-
-struct xmit_frame {
-       struct list_head        list;
-       struct pkt_attrib attrib;
-       struct sk_buff *pkt;
-       int     frame_tag;
-       struct rtw_adapter *padapter;
-       u8      *buf_addr;
-       struct xmit_buf *pxmitbuf;
-
-       s8      pkt_offset;
-
-       u8 ack_report;
-
-       u8 ext_tag; /* 0:data, 1:mgmt */
-};
-
-struct tx_servq {
-       struct list_head        tx_pending;
-       struct rtw_queue        sta_pending;
-       int qcnt;
-};
-
-struct sta_xmit_priv {
-       spinlock_t      lock;
-       int     option;
-       int     apsd_setting;   /* When bit mask is on, the associated edca
-                                * queue supports APSD.
-                                */
-       struct tx_servq be_q;                   /* priority == 0,3 */
-       struct tx_servq bk_q;                   /* priority == 1,2 */
-       struct tx_servq vi_q;                   /* priority == 4,5 */
-       struct tx_servq vo_q;                   /* priority == 6,7 */
-       struct list_head legacy_dz;
-       struct list_head apsd;
-       u16 txseq_tid[16];
-};
-
-struct hw_txqueue {
-       volatile int head;
-       volatile int tail;
-       volatile int free_sz;   /* in units of 64 bytes */
-       volatile int free_cmdsz;
-       volatile int txsz[8];
-       uint    ff_hwaddr;
-       uint    cmd_hwaddr;
-       int     ac_tag;
-};
-
-struct agg_pkt_info {
-       u16 offset;
-       u16 pkt_len;
-};
-
-struct xmit_priv {
-       spinlock_t      lock;
-
-       struct rtw_queue        be_pending;
-       struct rtw_queue        bk_pending;
-       struct rtw_queue        vi_pending;
-       struct rtw_queue        vo_pending;
-       struct rtw_queue        bm_pending;
-
-       int free_xmitframe_cnt;
-       struct rtw_queue        free_xmit_queue;
-
-       int free_xframe_ext_cnt;
-       struct rtw_queue free_xframe_ext_queue;
-
-       uint    frag_len;
-
-       struct rtw_adapter      *adapter;
-
-       u64     tx_bytes;
-       u64     tx_pkts;
-       u64     tx_drop;
-       u64     last_tx_bytes;
-       u64     last_tx_pkts;
-
-       struct hw_xmit *hwxmits;
-       u8      hwxmit_entry;
-       u8      vcs;
-       u8      nqos_ssn;
-
-       u8      wmm_para_seq[4];/* sequence for wmm ac parameter strength from
-                                * large to small. it's value is 0->vo, 1->vi,
-                                * 2->be, 3->bk.
-                                */
-
-       struct tasklet_struct xmit_tasklet;
-
-       struct rtw_queue free_xmitbuf_queue;
-       struct list_head xmitbuf_list;          /* track buffers for cleanup */
-       struct rtw_queue pending_xmitbuf_queue;
-       uint free_xmitbuf_cnt;
-
-       struct rtw_queue free_xmit_extbuf_queue;
-       struct list_head xmitextbuf_list;       /* track buffers for cleanup */
-       uint free_xmit_extbuf_cnt;
-
-       int     ack_tx;
-       struct mutex ack_tx_mutex;
-       struct submit_ctx ack_tx_ops;
-       spinlock_t lock_sctx;
-};
-
-struct xmit_buf *rtw_alloc_xmitbuf23a_ext(struct xmit_priv *pxmitpriv);
-s32 rtw_free_xmitbuf_ext23a(struct xmit_priv *pxmitpriv,
-                        struct xmit_buf *pxmitbuf);
-
-struct xmit_buf *rtw_alloc_xmitbuf23a(struct xmit_priv *pxmitpriv);
-s32 rtw_free_xmitbuf23a(struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf);
-
-void rtw_count_tx_stats23a(struct rtw_adapter *padapter,
-                       struct xmit_frame *pxmitframe, int sz);
-void rtw_update_protection23a(struct rtw_adapter *padapter, u8 *ie, uint ie_len);
-struct xmit_frame *rtw_alloc_xmitframe23a_ext(struct xmit_priv *pxmitpriv);
-struct xmit_frame *rtw_alloc_xmitframe23a_once(struct xmit_priv *pxmitpriv);
-s32 rtw_free_xmitframe23a(struct xmit_priv *pxmitpriv,
-                      struct xmit_frame *pxmitframe);
-void rtw_free_xmitframe_queue23a(struct xmit_priv *pxmitpriv, struct rtw_queue *pframequeue);
-struct tx_servq *rtw_get_sta_pending23a(struct rtw_adapter *padapter,
-                                    struct sta_info *psta, int up, u8 *ac);
-s32 rtw_xmitframe_enqueue23a(struct rtw_adapter *padapter,
-                            struct xmit_frame *pxmitframe);
-struct xmit_frame *rtw_dequeue_xframe23a(struct xmit_priv *pxmitpriv,
-                                     struct hw_xmit *phwxmit_i, int entry);
-s32 rtw_xmit23a_classifier(struct rtw_adapter *padapter,
-                       struct xmit_frame *pxmitframe);
-s32 rtw_xmitframe_coalesce23a(struct rtw_adapter *padapter, struct sk_buff *pkt,
-                             struct xmit_frame *pxmitframe);
-s32 _rtw_init_hw_txqueue(struct hw_txqueue *phw_txqueue, u8 ac_tag);
-void _rtw_init_sta_xmit_priv23a(struct sta_xmit_priv *psta_xmitpriv);
-
-s32 rtw_txframes_pending23a(struct rtw_adapter *padapter);
-s32 rtw_txframes_sta_ac_pending23a(struct rtw_adapter *padapter,
-                               struct pkt_attrib *pattrib);
-void rtw_init_hwxmits23a(struct hw_xmit *phwxmit, int entry);
-int _rtw_init_xmit_priv23a(struct xmit_priv *pxmitpriv,
-                       struct rtw_adapter *padapter);
-void _rtw_free_xmit_priv23a(struct xmit_priv *pxmitpriv);
-void rtw_alloc_hwxmits23a(struct rtw_adapter *padapter);
-void rtw_free_hwxmits23a(struct rtw_adapter *padapter);
-int rtw_xmit23a(struct rtw_adapter *padapter, struct sk_buff *pkt);
-#if defined(CONFIG_8723AU_AP_MODE)
-int xmitframe_enqueue_for_sleeping_sta23a(struct rtw_adapter *padapter,
-                                      struct xmit_frame *pxmitframe);
-void stop_sta_xmit23a(struct rtw_adapter *padapter, struct sta_info *psta);
-void wakeup_sta_to_xmit23a(struct rtw_adapter *padapter, struct sta_info *psta);
-void xmit_delivery_enabled_frames23a(struct rtw_adapter *padapter,
-                                 struct sta_info *psta);
-#endif
-u8     qos_acm23a(u8 acm_mask, u8 priority);
-u32    rtw_get_ff_hwaddr23a(struct xmit_frame  *pxmitframe);
-int rtw_ack_tx_wait23a(struct xmit_priv *pxmitpriv, u32 timeout_ms);
-
-/* include after declaring struct xmit_buf, in order to avoid warning */
-#include <xmit_osdep.h>
-
-#endif /* _RTL871X_XMIT_H_ */
diff --git a/drivers/staging/rtl8723au/include/sta_info.h b/drivers/staging/rtl8723au/include/sta_info.h
deleted file mode 100644 (file)
index e726005..0000000
+++ /dev/null
@@ -1,373 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#ifndef __STA_INFO_H_
-#define __STA_INFO_H_
-
-#include <osdep_service.h>
-#include <drv_types.h>
-#include <wifi.h>
-
-#define IBSS_START_MAC_ID      2
-#define NUM_STA 32
-#define NUM_ACL 16
-
-
-/* if mode ==0, then the sta is allowed once the addr is hit. */
-/* if mode ==1, then the sta is rejected once the addr is non-hit. */
-struct rtw_wlan_acl_node {
-       struct list_head        list;
-       u8       addr[ETH_ALEN];
-       u8       valid;
-};
-
-/* mode=0, disable */
-/* mode=1, accept unless in deny list */
-/* mode=2, deny unless in accept list */
-struct wlan_acl_pool {
-       int mode;
-       int num;
-       struct rtw_wlan_acl_node aclnode[NUM_ACL];
-       struct rtw_queue        acl_node_q;
-};
-
-struct rssi_sta  {
-       s32     UndecoratedSmoothedPWDB;
-       s32     UndecoratedSmoothedCCK;
-       s32     UndecoratedSmoothedOFDM;
-       u64     PacketMap;
-       u8      ValidBit;
-};
-
-struct stainfo_stats   {
-       u64 rx_mgnt_pkts;
-               u64 rx_beacon_pkts;
-               u64 rx_probereq_pkts;
-               u64 rx_probersp_pkts;
-               u64 rx_probersp_bm_pkts;
-               u64 rx_probersp_uo_pkts;
-       u64 rx_ctrl_pkts;
-       u64 rx_data_pkts;
-
-       u64     last_rx_mgnt_pkts;
-               u64 last_rx_beacon_pkts;
-               u64 last_rx_probereq_pkts;
-               u64 last_rx_probersp_pkts;
-               u64 last_rx_probersp_bm_pkts;
-               u64 last_rx_probersp_uo_pkts;
-       u64     last_rx_ctrl_pkts;
-       u64     last_rx_data_pkts;
-
-       u64     rx_bytes;
-       u64     rx_drops;
-
-       u64     tx_pkts;
-       u64     tx_bytes;
-       u64  tx_drops;
-
-};
-
-struct sta_info {
-       spinlock_t      lock;
-       struct list_head        list; /* free_sta_queue */
-       struct list_head        hash_list; /* sta_hash */
-       struct rtw_adapter *padapter;
-
-       struct sta_xmit_priv sta_xmitpriv;
-       struct sta_recv_priv sta_recvpriv;
-
-       struct rtw_queue sleep_q;
-       unsigned int sleepq_len;
-
-       uint state;
-       uint aid;
-       uint mac_id;
-       uint qos_option;
-       u8      hwaddr[ETH_ALEN];
-
-       uint    ieee8021x_blocked;      /* 0: allowed, 1:blocked */
-       u32     dot118021XPrivacy; /* aes, tkip... */
-       union Keytype   dot11tkiptxmickey;
-       union Keytype   dot11tkiprxmickey;
-       union Keytype   dot118021x_UncstKey;
-       union pn48              dot11txpn;                      /*  PN48 used for Unicast xmit. */
-       union pn48              dot11rxpn;                      /*  PN48 used for Unicast recv. */
-
-
-       u8      bssrateset[16];
-       u32     bssratelen;
-       s32  rssi;
-       s32     signal_quality;
-
-       u8      cts2self;
-       u8      rtsen;
-
-       u8      raid;
-       u8      init_rate;
-       u32     ra_mask;
-       u8      wireless_mode;  /*  NETWORK_TYPE */
-       struct stainfo_stats sta_stats;
-
-       /* for A-MPDU TX, ADDBA timeout check */
-       struct timer_list addba_retry_timer;
-
-       /* for A-MPDU Rx reordering buffer control */
-       struct recv_reorder_ctrl recvreorder_ctrl[16];
-
-       /* for A-MPDU Tx */
-       /* unsigned char                ampdu_txen_bitmap; */
-       u16     BA_starting_seqctrl[16];
-
-       struct ht_priv  htpriv;
-
-       /* Notes: */
-       /* STA_Mode: */
-       /* curr_network(mlme_priv/security_priv/qos/ht) + sta_info: (STA & AP) CAP/INFO */
-       /* scan_q: AP CAP/INFO */
-
-       /* AP_Mode: */
-       /* curr_network(mlme_priv/security_priv/qos/ht) : AP CAP/INFO */
-       /* sta_info: (AP & STA) CAP/INFO */
-
-       struct list_head asoc_list;
-       struct list_head auth_list;
-
-       unsigned int expire_to;
-       unsigned int auth_seq;
-       unsigned int authalg;
-       unsigned char chg_txt[128];
-
-       u16 capability;
-       int flags;
-
-       int dot8021xalg;/* 0:disable, 1:psk, 2:802.1x */
-       int wpa_psk;/* 0:disable, bit(0): WPA, bit(1):WPA2 */
-       int wpa_group_cipher;
-       int wpa2_group_cipher;
-       int wpa_pairwise_cipher;
-       int wpa2_pairwise_cipher;
-
-       u8 bpairwise_key_installed;
-
-       u8 wpa_ie[32];
-
-       u8 nonerp_set;
-       u8 no_short_slot_time_set;
-       u8 no_short_preamble_set;
-       u8 no_ht_gf_set;
-       u8 no_ht_set;
-       u8 ht_20mhz_set;
-
-       unsigned int tx_ra_bitmap;
-       u8 qos_info;
-
-       u8 max_sp_len;
-       u8 uapsd_bk;/* BIT(0): Delivery enabled, BIT(1): Trigger enabled */
-       u8 uapsd_be;
-       u8 uapsd_vi;
-       u8 uapsd_vo;
-
-       u8 has_legacy_ac;
-       unsigned int sleepq_ac_len;
-
-       /* p2p priv data */
-       u8 is_p2p_device;
-       u8 p2p_status_code;
-
-       u8 keep_alive_trycnt;
-
-       /* p2p client info */
-       u8 dev_addr[ETH_ALEN];
-       u8 dev_cap;
-       u16 config_methods;
-       u8 primary_dev_type[8];
-       u8 num_of_secdev_type;
-       u8 secdev_types_list[32];/*  32/8 == 4; */
-       u16 dev_name_len;
-       u8 dev_name[32];
-       u8 *passoc_req;
-       u32 assoc_req_len;
-
-       /* for DM */
-       struct rssi_sta  rssi_stat;
-
-       /*  */
-       /*  ================ODM Relative Info======================= */
-       /*  Please be care, dont declare too much structure here. It will cost memory * STA support num. */
-       /*  */
-       /*  */
-       /*  2011/10/20 MH Add for ODM STA info. */
-       /*  */
-       /*  Driver Write */
-       u8              bValid;                         /*  record the sta status link or not? */
-       u8              rssi_level;                     /* for Refresh RA mask */
-       /*  ODM Write */
-       /* 1 PHY_STATUS_INFO */
-       u8              RSSI_Path[4];           /*  */
-       u8              RSSI_Ave;
-       u8              RXEVM[4];
-       u8              RXSNR[4];
-
-       /*  ODM Write */
-       /* 1 TX_INFO (may changed by IC) */
-       /*  ================ODM Relative Info======================= */
-       /*  */
-
-       /* To store the sequence number of received management frame */
-       u16 RxMgmtFrameSeqNum;
-};
-
-#define sta_rx_pkts(sta) \
-       (sta->sta_stats.rx_mgnt_pkts \
-       + sta->sta_stats.rx_ctrl_pkts \
-       + sta->sta_stats.rx_data_pkts)
-
-#define sta_last_rx_pkts(sta) \
-       (sta->sta_stats.last_rx_mgnt_pkts \
-       + sta->sta_stats.last_rx_ctrl_pkts \
-       + sta->sta_stats.last_rx_data_pkts)
-
-#define sta_rx_data_pkts(sta) \
-       (sta->sta_stats.rx_data_pkts)
-
-#define sta_last_rx_data_pkts(sta) \
-       (sta->sta_stats.last_rx_data_pkts)
-
-#define sta_rx_mgnt_pkts(sta) \
-       (sta->sta_stats.rx_mgnt_pkts)
-
-#define sta_last_rx_mgnt_pkts(sta) \
-       (sta->sta_stats.last_rx_mgnt_pkts)
-
-#define sta_rx_beacon_pkts(sta) \
-       (sta->sta_stats.rx_beacon_pkts)
-
-#define sta_last_rx_beacon_pkts(sta) \
-       (sta->sta_stats.last_rx_beacon_pkts)
-
-#define sta_rx_probereq_pkts(sta) \
-       (sta->sta_stats.rx_probereq_pkts)
-
-#define sta_last_rx_probereq_pkts(sta) \
-       (sta->sta_stats.last_rx_probereq_pkts)
-
-#define sta_rx_probersp_pkts(sta) \
-       (sta->sta_stats.rx_probersp_pkts)
-
-#define sta_last_rx_probersp_pkts(sta) \
-       (sta->sta_stats.last_rx_probersp_pkts)
-
-#define sta_rx_probersp_bm_pkts(sta) \
-       (sta->sta_stats.rx_probersp_bm_pkts)
-
-#define sta_last_rx_probersp_bm_pkts(sta) \
-       (sta->sta_stats.last_rx_probersp_bm_pkts)
-
-#define sta_rx_probersp_uo_pkts(sta) \
-       (sta->sta_stats.rx_probersp_uo_pkts)
-
-#define sta_last_rx_probersp_uo_pkts(sta) \
-       (sta->sta_stats.last_rx_probersp_uo_pkts)
-
-#define sta_update_last_rx_pkts(sta) \
-       do { \
-               sta->sta_stats.last_rx_mgnt_pkts = sta->sta_stats.rx_mgnt_pkts; \
-               sta->sta_stats.last_rx_beacon_pkts = sta->sta_stats.rx_beacon_pkts; \
-               sta->sta_stats.last_rx_probereq_pkts = sta->sta_stats.rx_probereq_pkts; \
-               sta->sta_stats.last_rx_probersp_pkts = sta->sta_stats.rx_probersp_pkts; \
-               sta->sta_stats.last_rx_probersp_bm_pkts = sta->sta_stats.rx_probersp_bm_pkts; \
-               sta->sta_stats.last_rx_probersp_uo_pkts = sta->sta_stats.rx_probersp_uo_pkts; \
-               sta->sta_stats.last_rx_ctrl_pkts = sta->sta_stats.rx_ctrl_pkts; \
-               sta->sta_stats.last_rx_data_pkts = sta->sta_stats.rx_data_pkts; \
-       } while (0)
-
-#define STA_RX_PKTS_ARG(sta) \
-       sta->sta_stats.rx_mgnt_pkts \
-       , sta->sta_stats.rx_ctrl_pkts \
-       , sta->sta_stats.rx_data_pkts
-
-#define STA_LAST_RX_PKTS_ARG(sta) \
-       sta->sta_stats.last_rx_mgnt_pkts, \
-       sta->sta_stats.last_rx_ctrl_pkts, \
-       sta->sta_stats.last_rx_data_pkts
-
-#define STA_RX_PKTS_DIFF_ARG(sta) \
-       sta->sta_stats.rx_mgnt_pkts - sta->sta_stats.last_rx_mgnt_pkts, \
-       sta->sta_stats.rx_ctrl_pkts - sta->sta_stats.last_rx_ctrl_pkts, \
-       sta->sta_stats.rx_data_pkts - sta->sta_stats.last_rx_data_pkts
-
-#define STA_PKTS_FMT "(m:%llu, c:%llu, d:%llu)"
-
-struct sta_priv {
-       spinlock_t sta_hash_lock;
-       struct list_head sta_hash[NUM_STA];
-       int asoc_sta_count;
-
-       struct rtw_adapter *padapter;
-       struct list_head asoc_list;
-       struct list_head auth_list;
-       spinlock_t asoc_list_lock;
-       spinlock_t auth_list_lock;
-       u8 asoc_list_cnt;
-       u8 auth_list_cnt;
-
-       unsigned int auth_to;  /* sec, time to expire in authenticating. */
-       unsigned int assoc_to; /* sec, time to expire before associating. */
-       unsigned int expire_to; /* sec , time to expire after associated. */
-
-       /* pointers to STA info; based on allocated AID or NULL if AID free
-        * AID is in the range 1-2007, so sta_aid[0] corresponders to AID 1
-        * and so on
-        */
-       struct sta_info *sta_aid[NUM_STA];
-
-       u16 sta_dz_bitmap;/* only support 15 stations, station aid bitmap
-                          * for sleeping sta. */
-       u16 tim_bitmap;/* only support 15 stations,
-                       * aid=0~15 mapping bit0~bit15 */
-
-       u16 max_num_sta;
-
-       struct wlan_acl_pool acl_list;
-};
-
-static inline u32 wifi_mac_hash(const u8 *mac)
-{
-       u32 x;
-
-       x = mac[0];
-       x = (x << 2) ^ mac[1];
-       x = (x << 2) ^ mac[2];
-       x = (x << 2) ^ mac[3];
-       x = (x << 2) ^ mac[4];
-       x = (x << 2) ^ mac[5];
-
-       x ^= x >> 8;
-       x  = x & (NUM_STA - 1);
-
-       return x;
-}
-
-int _rtw_init_sta_priv23a(struct sta_priv *pstapriv);
-int _rtw_free_sta_priv23a(struct sta_priv *pstapriv);
-
-struct sta_info *rtw_alloc_stainfo23a(struct sta_priv *pstapriv, const u8 *hwaddr, gfp_t gfp);
-int rtw_free_stainfo23a(struct rtw_adapter *padapter, struct sta_info *psta);
-void rtw_free_all_stainfo23a(struct rtw_adapter *padapter);
-struct sta_info *rtw_get_stainfo23a(struct sta_priv *pstapriv, const u8 *hwaddr);
-int rtw_init_bcmc_stainfo23a(struct rtw_adapter *padapter);
-struct sta_info *rtw_get_bcmc_stainfo23a(struct rtw_adapter *padapter);
-bool rtw_access_ctrl23a(struct rtw_adapter *padapter, u8 *mac_addr);
-
-#endif /* _STA_INFO_H_ */
diff --git a/drivers/staging/rtl8723au/include/usb_ops.h b/drivers/staging/rtl8723au/include/usb_ops.h
deleted file mode 100644 (file)
index ff11e13..0000000
+++ /dev/null
@@ -1,68 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#ifndef __USB_OPS_H_
-#define __USB_OPS_H_
-
-#include <osdep_service.h>
-#include <drv_types.h>
-#include <osdep_intf.h>
-#include <usb_ops_linux.h>
-
-#define REALTEK_USB_VENQT_READ         0xC0
-#define REALTEK_USB_VENQT_WRITE                0x40
-#define REALTEK_USB_VENQT_CMD_REQ      0x05
-#define REALTEK_USB_VENQT_CMD_IDX      0x00
-
-enum {
-       VENDOR_WRITE = 0x00,
-       VENDOR_READ = 0x01,
-};
-
-#define ALIGNMENT_UNIT                         16
-#define MAX_VENDOR_REQ_CMD_SIZE        254             /* 8188cu SIE Support */
-#define MAX_USB_IO_CTL_SIZE    (MAX_VENDOR_REQ_CMD_SIZE +ALIGNMENT_UNIT)
-
-void rtl8723au_set_hw_type(struct rtw_adapter *padapter);
-
-void rtl8723au_recv_tasklet(void *priv);
-
-void rtl8723au_xmit_tasklet(void *priv);
-
-/* Increase and check if the continual_urb_error of this @param dvobjprive is
- * larger than MAX_CONTINUAL_URB_ERR. Return result
- */
-static inline int rtw_inc_and_chk_continual_urb_error(struct dvobj_priv *dvobj)
-{
-       int ret = false;
-       int value;
-
-       value = atomic_inc_return(&dvobj->continual_urb_error);
-       if (value > MAX_CONTINUAL_URB_ERR) {
-               DBG_8723A("[dvobj:%p][ERROR] continual_urb_error:%d > %d\n",
-                         dvobj, value, MAX_CONTINUAL_URB_ERR);
-               ret = true;
-       }
-       return ret;
-}
-
-/* Set the continual_urb_error of this @param dvobjprive to 0 */
-static inline void rtw_reset_continual_urb_error(struct dvobj_priv *dvobj)
-{
-       atomic_set(&dvobj->continual_urb_error, 0);
-}
-
-bool rtl8723au_chip_configure(struct rtw_adapter *padapter);
-
-#endif /* __USB_OPS_H_ */
diff --git a/drivers/staging/rtl8723au/include/usb_ops_linux.h b/drivers/staging/rtl8723au/include/usb_ops_linux.h
deleted file mode 100644 (file)
index af2f14b..0000000
+++ /dev/null
@@ -1,41 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#ifndef __USB_OPS_LINUX_H__
-#define __USB_OPS_LINUX_H__
-
-#define VENDOR_CMD_MAX_DATA_LEN        254
-
-#define RTW_USB_CONTROL_MSG_TIMEOUT    500/* ms */
-
-#define MAX_USBCTRL_VENDORREQ_TIMES    10
-
-int rtl8723au_read_port(struct rtw_adapter *adapter, u32 cnt,
-                       struct recv_buf *precvbuf);
-void rtl8723au_read_port_cancel(struct rtw_adapter *padapter);
-int rtl8723au_write_port(struct rtw_adapter *padapter, u32 addr, u32 cnt,
-                        struct xmit_buf *pxmitbuf);
-void rtl8723au_write_port_cancel(struct rtw_adapter *padapter);
-int rtl8723au_read_interrupt(struct rtw_adapter *adapter);
-
-u8 rtl8723au_read8(struct rtw_adapter *padapter, u16 addr);
-u16 rtl8723au_read16(struct rtw_adapter *padapter, u16 addr);
-u32 rtl8723au_read32(struct rtw_adapter *padapter, u16 addr);
-int rtl8723au_write8(struct rtw_adapter *padapter, u16 addr, u8 val);
-int rtl8723au_write16(struct rtw_adapter *padapter, u16 addr, u16 val);
-int rtl8723au_write32(struct rtw_adapter *padapter, u16 addr, u32 val);
-int rtl8723au_writeN(struct rtw_adapter *padapter,
-                    u16 addr, u16 length, u8 *pdata);
-
-#endif
diff --git a/drivers/staging/rtl8723au/include/wifi.h b/drivers/staging/rtl8723au/include/wifi.h
deleted file mode 100644 (file)
index 25d573c..0000000
+++ /dev/null
@@ -1,84 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#ifndef _WIFI_H_
-#define _WIFI_H_
-
-/*  This value is tested by WiFi 11n Test Plan 5.2.3.
- *  This test verifies the WLAN NIC can update the NAV through sending
- *  the CTS with large duration.
- */
-#define        WiFiNavUpperUs          30000   /*  30 ms */
-
-/*-----------------------------------------------------------------------------
-                               Below is the definition for 802.11n
-------------------------------------------------------------------------------*/
-
-struct AC_param {
-       u8                      ACI_AIFSN;
-       u8                      CW;
-       __le16                  TXOP_limit;
-}  __packed;
-
-struct WMM_para_element {
-       unsigned char           QoS_info;
-       unsigned char           reserved;
-       struct AC_param ac_param[4];
-}  __packed;
-
-struct ADDBA_request {
-       u8              dialog_token;
-       __le16          BA_para_set;
-       __le16          BA_timeout_value;
-       __le16          BA_starting_seqctrl;
-}  __packed;
-
-
-/*     ===============WPS Section=============== */
-/*     WPS attribute ID */
-#define WPS_ATTR_VER1                          0x104A
-#define WPS_ATTR_SIMPLE_CONF_STATE             0x1044
-#define WPS_ATTR_RESP_TYPE                     0x103B
-#define WPS_ATTR_UUID_E                                0x1047
-#define WPS_ATTR_MANUFACTURER                  0x1021
-#define WPS_ATTR_MODEL_NAME                    0x1023
-#define WPS_ATTR_MODEL_NUMBER                  0x1024
-#define WPS_ATTR_SERIAL_NUMBER                 0x1042
-#define WPS_ATTR_PRIMARY_DEV_TYPE              0x1054
-#define WPS_ATTR_SEC_DEV_TYPE_LIST             0x1055
-#define WPS_ATTR_DEVICE_NAME                   0x1011
-#define WPS_ATTR_CONF_METHOD                   0x1008
-#define WPS_ATTR_RF_BANDS                      0x103C
-#define WPS_ATTR_DEVICE_PWID                   0x1012
-#define WPS_ATTR_REQUEST_TYPE                  0x103A
-#define WPS_ATTR_ASSOCIATION_STATE             0x1002
-#define WPS_ATTR_CONFIG_ERROR                  0x1009
-#define WPS_ATTR_VENDOR_EXT                    0x1049
-#define WPS_ATTR_SELECTED_REGISTRAR            0x1041
-
-/*     WPS Configuration Method */
-#define        WPS_CM_NONE                                     0x0000
-#define        WPS_CM_LABEL                                    0x0004
-#define        WPS_CM_DISPLYA                                  0x0008
-#define        WPS_CM_EXTERNAL_NFC_TOKEN                       0x0010
-#define        WPS_CM_INTEGRATED_NFC_TOKEN                     0x0020
-#define        WPS_CM_NFC_INTERFACE                            0x0040
-#define        WPS_CM_PUSH_BUTTON                              0x0080
-#define        WPS_CM_KEYPAD                                   0x0100
-#define        WPS_CM_SW_PUHS_BUTTON                           0x0280
-#define        WPS_CM_HW_PUHS_BUTTON                           0x0480
-#define        WPS_CM_SW_DISPLAY_PIN                           0x2008
-#define        WPS_CM_LCD_DISPLAY_PIN                          0x4008
-
-#endif /*  _WIFI_H_ */
diff --git a/drivers/staging/rtl8723au/include/wlan_bssdef.h b/drivers/staging/rtl8723au/include/wlan_bssdef.h
deleted file mode 100644 (file)
index 95b32e1..0000000
+++ /dev/null
@@ -1,123 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#ifndef __WLAN_BSSDEF_H__
-#define __WLAN_BSSDEF_H__
-
-
-#define MAX_IE_SZ      768
-
-
-#define NDIS_802_11_LENGTH_RATES        8
-#define NDIS_802_11_LENGTH_RATES_EX     16
-
-/* Length is the 4 bytes multiples of the sum of
- * sizeof(6 * sizeof(unsigned char)) + 2 + sizeof(struct ndis_802_11_ssid) +
- * sizeof(u32) + sizeof(long) + sizeof(enum ndis_802_11_net_type) +
- * sizeof(struct ndis_802_11_config) + sizeof(sizeof(unsigned char) *
- * NDIS_802_11_LENGTH_RATES_EX) + IELength
- *
- * Except the IELength, all other fields are fixed length. Therefore,
- * we can define a macro to present the partial sum.
- */
-
-enum ndis_802_11_auth_mode {
-       Ndis802_11AuthModeOpen,
-       Ndis802_11AuthModeShared,
-       Ndis802_11AuthModeAutoSwitch,
-       Ndis802_11AuthModeWPA,
-       Ndis802_11AuthModeWPAPSK,
-       Ndis802_11AuthModeWPANone,
-       dis802_11AuthModeMax       /*  upper bound */
-};
-
-enum  {
-       Ndis802_11WEPEnabled,
-       Ndis802_11Encryption1Enabled = Ndis802_11WEPEnabled,
-       Ndis802_11WEPDisabled,
-       Ndis802_11EncryptionDisabled = Ndis802_11WEPDisabled,
-       Ndis802_11WEPKeyAbsent,
-       Ndis802_11Encryption1KeyAbsent = Ndis802_11WEPKeyAbsent,
-       Ndis802_11WEPNotSupported,
-       Ndis802_11EncryptionNotSupported = Ndis802_11WEPNotSupported,
-       Ndis802_11Encryption2Enabled,
-       Ndis802_11Encryption2KeyAbsent,
-       Ndis802_11Encryption3Enabled,
-       Ndis802_11Encryption3KeyAbsent,
-};
-
-struct wlan_bcn_info {
-       /* these infor get from rtw_get_encrypt_info when
-        *       * translate scan to UI */
-       u8 encryp_protocol;/* ENCRYP_PROTOCOL_E: OPEN/WEP/WPA/WPA2 */
-       int group_cipher; /* WPA/WPA2 group cipher */
-       int pairwise_cipher;/* WPA/WPA2/WEP pairwise cipher */
-       int is_8021x;
-
-       /* bwmode 20/40 and ch_offset UP/LOW */
-};
-
-struct wlan_bssid_ex {
-       u32  Length;
-       u8 MacAddress[ETH_ALEN];
-       u16 reserved;
-       struct cfg80211_ssid Ssid;
-       u32  Privacy;
-       long  Rssi;/* in dBM, raw data , get from PHY) */
-       u16 beacon_interval;
-       u16 capability;
-       u64 tsf;
-       u32 ATIMWindow;         /*  units are Kusec */
-       u32 DSConfig;           /*  Frequency, units are kHz */
-       enum nl80211_iftype ifmode;
-       unsigned char SupportedRates[NDIS_802_11_LENGTH_RATES_EX];
-       u8 SignalStrength;/* in percentage */
-       u8 SignalQuality;/* in percentage */
-       u32  IELength;
-       u8  IEs[MAX_IE_SZ]; /* timestamp, beacon interval, and capability info*/
-} __packed;
-
-static inline uint get_wlan_bssid_ex_sz(struct wlan_bssid_ex *bss)
-{
-       return sizeof(struct wlan_bssid_ex) - MAX_IE_SZ + bss->IELength;
-}
-
-struct wlan_network {
-       struct list_head        list;
-       int     network_type;   /* refer to ieee80211.h for 11A/B/G */
-       /*  set to fixed when not to be removed as site-surveying */
-       int     fixed;
-       unsigned long   last_scanned; /* timestamp for the network */
-       int     join_res;
-       struct wlan_bssid_ex    network; /* must be the last item */
-       struct wlan_bcn_info    BcnInfo;
-};
-
-enum VRTL_CARRIER_SENSE {
-       DISABLE_VCS,
-       ENABLE_VCS,
-       AUTO_VCS
-};
-
-enum VCS_TYPE {
-       NONE_VCS,
-       RTS_CTS,
-       CTS_TO_SELF
-};
-
-/* john */
-#define NUM_PRE_AUTH_KEY 16
-#define NUM_PMKID_CACHE NUM_PRE_AUTH_KEY
-
-#endif /* ifndef WLAN_BSSDEF_H_ */
diff --git a/drivers/staging/rtl8723au/include/xmit_osdep.h b/drivers/staging/rtl8723au/include/xmit_osdep.h
deleted file mode 100644 (file)
index 2be04c4..0000000
+++ /dev/null
@@ -1,38 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#ifndef __XMIT_OSDEP_H_
-#define __XMIT_OSDEP_H_
-
-#include <osdep_service.h>
-#include <drv_types.h>
-
-
-#define NR_XMITFRAME   256
-
-int rtw_xmit23a_entry23a(struct sk_buff *pkt, struct net_device *pnetdev);
-
-void rtw_os_xmit_schedule23a(struct rtw_adapter *padapter);
-
-int rtw_os_xmit_resource_alloc23a(struct rtw_adapter *padapter,
-                              struct xmit_buf *pxmitbuf, u32 alloc_sz);
-void rtw_os_xmit_resource_free23a(struct rtw_adapter *padapter,
-                              struct xmit_buf *pxmitbuf);
-
-void rtw_os_pkt_complete23a(struct rtw_adapter *padapter, struct sk_buff *pkt);
-void rtw_os_xmit_complete23a(struct rtw_adapter *padapter,
-                         struct xmit_frame *pxframe);
-int netdev_open23a(struct net_device *pnetdev);
-
-#endif /* __XMIT_OSDEP_H_ */
diff --git a/drivers/staging/rtl8723au/os_dep/ioctl_cfg80211.c b/drivers/staging/rtl8723au/os_dep/ioctl_cfg80211.c
deleted file mode 100644 (file)
index d0ba377..0000000
+++ /dev/null
@@ -1,3348 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#define  _IOCTL_CFG80211_C_
-
-#include <osdep_service.h>
-#include <drv_types.h>
-#include <xmit_osdep.h>
-
-#include "ioctl_cfg80211.h"
-
-#define RTW_MAX_MGMT_TX_CNT 8
-
-#define RTW_MAX_REMAIN_ON_CHANNEL_DURATION 65535       /* ms */
-#define RTW_MAX_NUM_PMKIDS 4
-
-static const u32 rtw_cipher_suites[] = {
-       WLAN_CIPHER_SUITE_WEP40,
-       WLAN_CIPHER_SUITE_WEP104,
-       WLAN_CIPHER_SUITE_TKIP,
-       WLAN_CIPHER_SUITE_CCMP,
-};
-
-#define RATETAB_ENT(_rate, _rateid, _flags) {                  \
-       .bitrate        = (_rate),                              \
-       .hw_value       = (_rateid),                            \
-       .flags          = (_flags),                             \
-}
-
-#define CHAN2G(_channel, _freq, _flags) {                      \
-       .band                   = NL80211_BAND_2GHZ,            \
-       .center_freq            = (_freq),                      \
-       .hw_value               = (_channel),                   \
-       .flags                  = (_flags),                     \
-       .max_antenna_gain       = 0,                            \
-       .max_power              = 30,                           \
-}
-
-#define CHAN5G(_channel, _flags) {                             \
-       .band                   = NL80211_BAND_5GHZ,            \
-       .center_freq            = 5000 + (5 * (_channel)),      \
-       .hw_value               = (_channel),                   \
-       .flags                  = (_flags),                     \
-       .max_antenna_gain       = 0,                            \
-       .max_power              = 30,                           \
-}
-
-static struct ieee80211_rate rtw_rates[] = {
-       RATETAB_ENT(10, 0x1, 0),
-       RATETAB_ENT(20, 0x2, 0),
-       RATETAB_ENT(55, 0x4, 0),
-       RATETAB_ENT(110, 0x8, 0),
-       RATETAB_ENT(60, 0x10, 0),
-       RATETAB_ENT(90, 0x20, 0),
-       RATETAB_ENT(120, 0x40, 0),
-       RATETAB_ENT(180, 0x80, 0),
-       RATETAB_ENT(240, 0x100, 0),
-       RATETAB_ENT(360, 0x200, 0),
-       RATETAB_ENT(480, 0x400, 0),
-       RATETAB_ENT(540, 0x800, 0),
-};
-
-#define rtw_a_rates            (rtw_rates + 4)
-#define RTW_A_RATES_NUM        8
-#define rtw_g_rates            (rtw_rates + 0)
-#define RTW_G_RATES_NUM        12
-
-#define RTW_2G_CHANNELS_NUM 14
-#define RTW_5G_CHANNELS_NUM 37
-
-static struct ieee80211_channel rtw_2ghz_channels[] = {
-       CHAN2G(1, 2412, 0),
-       CHAN2G(2, 2417, 0),
-       CHAN2G(3, 2422, 0),
-       CHAN2G(4, 2427, 0),
-       CHAN2G(5, 2432, 0),
-       CHAN2G(6, 2437, 0),
-       CHAN2G(7, 2442, 0),
-       CHAN2G(8, 2447, 0),
-       CHAN2G(9, 2452, 0),
-       CHAN2G(10, 2457, 0),
-       CHAN2G(11, 2462, 0),
-       CHAN2G(12, 2467, 0),
-       CHAN2G(13, 2472, 0),
-       CHAN2G(14, 2484, 0),
-};
-
-static struct ieee80211_channel rtw_5ghz_a_channels[] = {
-       CHAN5G(34, 0), CHAN5G(36, 0),
-       CHAN5G(38, 0), CHAN5G(40, 0),
-       CHAN5G(42, 0), CHAN5G(44, 0),
-       CHAN5G(46, 0), CHAN5G(48, 0),
-       CHAN5G(52, 0), CHAN5G(56, 0),
-       CHAN5G(60, 0), CHAN5G(64, 0),
-       CHAN5G(100, 0), CHAN5G(104, 0),
-       CHAN5G(108, 0), CHAN5G(112, 0),
-       CHAN5G(116, 0), CHAN5G(120, 0),
-       CHAN5G(124, 0), CHAN5G(128, 0),
-       CHAN5G(132, 0), CHAN5G(136, 0),
-       CHAN5G(140, 0), CHAN5G(149, 0),
-       CHAN5G(153, 0), CHAN5G(157, 0),
-       CHAN5G(161, 0), CHAN5G(165, 0),
-       CHAN5G(184, 0), CHAN5G(188, 0),
-       CHAN5G(192, 0), CHAN5G(196, 0),
-       CHAN5G(200, 0), CHAN5G(204, 0),
-       CHAN5G(208, 0), CHAN5G(212, 0),
-       CHAN5G(216, 0),
-};
-
-static void rtw_2g_channels_init(struct ieee80211_channel *channels)
-{
-       memcpy((void *)channels, (void *)rtw_2ghz_channels,
-              sizeof(struct ieee80211_channel) * RTW_2G_CHANNELS_NUM);
-}
-
-static void rtw_5g_channels_init(struct ieee80211_channel *channels)
-{
-       memcpy((void *)channels, (void *)rtw_5ghz_a_channels,
-              sizeof(struct ieee80211_channel) * RTW_5G_CHANNELS_NUM);
-}
-
-static void rtw_2g_rates_init(struct ieee80211_rate *rates)
-{
-       memcpy(rates, rtw_g_rates,
-              sizeof(struct ieee80211_rate) * RTW_G_RATES_NUM);
-}
-
-static void rtw_5g_rates_init(struct ieee80211_rate *rates)
-{
-       memcpy(rates, rtw_a_rates,
-              sizeof(struct ieee80211_rate) * RTW_A_RATES_NUM);
-}
-
-static struct ieee80211_supported_band *
-rtw_spt_band_alloc(enum nl80211_band band)
-{
-       struct ieee80211_supported_band *spt_band = NULL;
-       int n_channels, n_bitrates;
-
-       if (band == NL80211_BAND_2GHZ) {
-               n_channels = RTW_2G_CHANNELS_NUM;
-               n_bitrates = RTW_G_RATES_NUM;
-       } else if (band == NL80211_BAND_5GHZ) {
-               n_channels = RTW_5G_CHANNELS_NUM;
-               n_bitrates = RTW_A_RATES_NUM;
-       } else {
-               goto exit;
-       }
-       spt_band = kzalloc(sizeof(struct ieee80211_supported_band) +
-                          sizeof(struct ieee80211_channel) * n_channels +
-                          sizeof(struct ieee80211_rate) * n_bitrates,
-                          GFP_KERNEL);
-       if (!spt_band)
-               goto exit;
-
-       spt_band->channels =
-               (struct ieee80211_channel *)(((u8 *) spt_band) +
-                                            sizeof(struct
-                                                   ieee80211_supported_band));
-       spt_band->bitrates =
-               (struct ieee80211_rate *)(((u8 *) spt_band->channels) +
-                                         sizeof(struct ieee80211_channel) *
-                                         n_channels);
-       spt_band->band = band;
-       spt_band->n_channels = n_channels;
-       spt_band->n_bitrates = n_bitrates;
-
-       if (band == NL80211_BAND_2GHZ) {
-               rtw_2g_channels_init(spt_band->channels);
-               rtw_2g_rates_init(spt_band->bitrates);
-       } else if (band == NL80211_BAND_5GHZ) {
-               rtw_5g_channels_init(spt_band->channels);
-               rtw_5g_rates_init(spt_band->bitrates);
-       }
-
-       /* spt_band.ht_cap */
-
-exit:
-       return spt_band;
-}
-
-static const struct ieee80211_txrx_stypes
-rtw_cfg80211_default_mgmt_stypes[NUM_NL80211_IFTYPES] = {
-       [NL80211_IFTYPE_ADHOC] = {
-               .tx = 0xffff,
-               .rx = BIT(IEEE80211_STYPE_ACTION >> 4)
-       },
-       [NL80211_IFTYPE_STATION] = {
-               .tx = 0xffff,
-               .rx = BIT(IEEE80211_STYPE_ACTION >> 4) |
-                     BIT(IEEE80211_STYPE_PROBE_REQ >> 4)
-       },
-       [NL80211_IFTYPE_AP] = {
-               .tx = 0xffff,
-               .rx = BIT(IEEE80211_STYPE_ASSOC_REQ >> 4) |
-                     BIT(IEEE80211_STYPE_REASSOC_REQ >> 4) |
-                     BIT(IEEE80211_STYPE_PROBE_REQ >> 4) |
-                     BIT(IEEE80211_STYPE_DISASSOC >> 4) |
-                     BIT(IEEE80211_STYPE_AUTH >> 4) |
-                     BIT(IEEE80211_STYPE_DEAUTH >> 4) |
-                     BIT(IEEE80211_STYPE_ACTION >> 4)
-       },
-       [NL80211_IFTYPE_AP_VLAN] = {
-               /* copy AP */
-               .tx = 0xffff,
-               .rx = BIT(IEEE80211_STYPE_ASSOC_REQ >> 4) |
-                     BIT(IEEE80211_STYPE_REASSOC_REQ >> 4) |
-                     BIT(IEEE80211_STYPE_PROBE_REQ >> 4) |
-                     BIT(IEEE80211_STYPE_DISASSOC >> 4) |
-                     BIT(IEEE80211_STYPE_AUTH >> 4) |
-                     BIT(IEEE80211_STYPE_DEAUTH >> 4) |
-                     BIT(IEEE80211_STYPE_ACTION >> 4)
-       },
-       [NL80211_IFTYPE_P2P_CLIENT] = {
-               .tx = 0xffff,
-               .rx = BIT(IEEE80211_STYPE_ACTION >> 4) |
-                     BIT(IEEE80211_STYPE_PROBE_REQ >> 4)
-       },
-       [NL80211_IFTYPE_P2P_GO] = {
-               .tx = 0xffff,
-               .rx = BIT(IEEE80211_STYPE_ASSOC_REQ >> 4) |
-                     BIT(IEEE80211_STYPE_REASSOC_REQ >> 4) |
-                     BIT(IEEE80211_STYPE_PROBE_REQ >> 4) |
-                     BIT(IEEE80211_STYPE_DISASSOC >> 4) |
-                     BIT(IEEE80211_STYPE_AUTH >> 4) |
-                     BIT(IEEE80211_STYPE_DEAUTH >> 4) |
-                     BIT(IEEE80211_STYPE_ACTION >> 4)
-       },
-};
-
-static int rtw_cfg80211_inform_bss(struct rtw_adapter *padapter,
-                                  struct wlan_network *pnetwork)
-{
-       int ret = 0;
-       struct ieee80211_channel *notify_channel;
-       struct cfg80211_bss *bss;
-       u16 channel;
-       u32 freq;
-       u8 *notify_ie;
-       size_t notify_ielen;
-       s32 notify_signal;
-       struct wireless_dev *wdev = padapter->rtw_wdev;
-       struct wiphy *wiphy = wdev->wiphy;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-
-       channel = pnetwork->network.DSConfig;
-       if (channel <= RTW_CH_MAX_2G_CHANNEL)
-               freq = ieee80211_channel_to_frequency(channel,
-                                                     NL80211_BAND_2GHZ);
-       else
-               freq = ieee80211_channel_to_frequency(channel,
-                                                     NL80211_BAND_5GHZ);
-
-       notify_channel = ieee80211_get_channel(wiphy, freq);
-
-       notify_ie = pnetwork->network.IEs;
-       notify_ielen = pnetwork->network.IELength;
-
-       /* We've set wiphy's signal_type as CFG80211_SIGNAL_TYPE_MBM:
-        *  signal strength in mBm (100*dBm)
-        */
-       if (check_fwstate(pmlmepriv, _FW_LINKED) &&
-           is_same_network23a(&pmlmepriv->cur_network.network,
-                           &pnetwork->network)) {
-               notify_signal = 100 * translate_percentage_to_dbm(padapter->recvpriv.signal_strength);  /* dbm */
-       } else {
-               notify_signal = 100 * translate_percentage_to_dbm(
-                       pnetwork->network.SignalStrength);      /* dbm */
-       }
-
-       bss = cfg80211_inform_bss(wiphy, notify_channel,
-                                 CFG80211_BSS_FTYPE_UNKNOWN,
-                                 pnetwork->network.MacAddress,
-                                 pnetwork->network.tsf,
-                                 pnetwork->network.capability,
-                                 pnetwork->network.beacon_interval,
-                                 notify_ie, notify_ielen,
-                                 notify_signal, GFP_ATOMIC);
-
-       if (unlikely(!bss)) {
-               DBG_8723A("rtw_cfg80211_inform_bss error\n");
-               return -EINVAL;
-       }
-
-       cfg80211_put_bss(wiphy, bss);
-
-       return ret;
-}
-
-void rtw_cfg80211_indicate_connect(struct rtw_adapter *padapter)
-{
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct wlan_network *cur_network = &pmlmepriv->cur_network;
-       struct wireless_dev *pwdev = padapter->rtw_wdev;
-
-       DBG_8723A("%s(padapter =%p)\n", __func__, padapter);
-
-       if (pwdev->iftype != NL80211_IFTYPE_STATION &&
-           pwdev->iftype != NL80211_IFTYPE_P2P_CLIENT)
-               return;
-
-       if (check_fwstate(pmlmepriv, WIFI_AP_STATE))
-               return;
-
-       if (padapter->mlmepriv.to_roaming > 0) {
-               struct wiphy *wiphy = pwdev->wiphy;
-               struct ieee80211_channel *notify_channel;
-               u32 freq;
-               u16 channel = cur_network->network.DSConfig;
-
-               if (channel <= RTW_CH_MAX_2G_CHANNEL)
-                       freq =
-                           ieee80211_channel_to_frequency(channel,
-                                                          NL80211_BAND_2GHZ);
-               else
-                       freq =
-                           ieee80211_channel_to_frequency(channel,
-                                                          NL80211_BAND_5GHZ);
-
-               notify_channel = ieee80211_get_channel(wiphy, freq);
-
-               DBG_8723A("%s call cfg80211_roamed\n", __func__);
-               cfg80211_roamed(padapter->pnetdev, notify_channel,
-                               cur_network->network.MacAddress,
-                               pmlmepriv->assoc_req +
-                               sizeof(struct ieee80211_hdr_3addr) + 2,
-                               pmlmepriv->assoc_req_len -
-                               sizeof(struct ieee80211_hdr_3addr) - 2,
-                               pmlmepriv->assoc_rsp +
-                               sizeof(struct ieee80211_hdr_3addr) + 6,
-                               pmlmepriv->assoc_rsp_len -
-                               sizeof(struct ieee80211_hdr_3addr) - 6,
-                               GFP_ATOMIC);
-       } else {
-               cfg80211_connect_result(padapter->pnetdev,
-                                       cur_network->network.MacAddress,
-                                       pmlmepriv->assoc_req +
-                                       sizeof(struct ieee80211_hdr_3addr) + 2,
-                                       pmlmepriv->assoc_req_len -
-                                       sizeof(struct ieee80211_hdr_3addr) - 2,
-                                       pmlmepriv->assoc_rsp +
-                                       sizeof(struct ieee80211_hdr_3addr) + 6,
-                                       pmlmepriv->assoc_rsp_len -
-                                       sizeof(struct ieee80211_hdr_3addr) - 6,
-                                       WLAN_STATUS_SUCCESS, GFP_ATOMIC);
-       }
-}
-
-void rtw_cfg80211_indicate_disconnect(struct rtw_adapter *padapter)
-{
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct wireless_dev *pwdev = padapter->rtw_wdev;
-
-       DBG_8723A("%s(padapter =%p)\n", __func__, padapter);
-
-       if (pwdev->iftype != NL80211_IFTYPE_STATION &&
-           pwdev->iftype != NL80211_IFTYPE_P2P_CLIENT)
-               return;
-
-       if (check_fwstate(pmlmepriv, WIFI_AP_STATE))
-               return;
-
-       if (!padapter->mlmepriv.not_indic_disco) {
-               if (check_fwstate(&padapter->mlmepriv, WIFI_UNDER_LINKING)) {
-                       cfg80211_connect_result(padapter->pnetdev, NULL, NULL,
-                                               0, NULL, 0,
-                                               WLAN_STATUS_UNSPECIFIED_FAILURE,
-                                               GFP_ATOMIC);
-               } else {
-                       cfg80211_disconnected(padapter->pnetdev, 0, NULL,
-                                             0, false, GFP_ATOMIC);
-               }
-       }
-}
-
-#ifdef CONFIG_8723AU_AP_MODE
-static int set_pairwise_key(struct rtw_adapter *padapter, struct sta_info *psta)
-{
-       struct cmd_obj *ph2c;
-       struct set_stakey_parm *psetstakey_para;
-       struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
-       int res = _SUCCESS;
-
-       ph2c = kzalloc(sizeof(struct cmd_obj), GFP_KERNEL);
-       if (ph2c == NULL) {
-               res = _FAIL;
-               goto exit;
-       }
-
-       psetstakey_para = kzalloc(sizeof(struct set_stakey_parm), GFP_KERNEL);
-       if (psetstakey_para == NULL) {
-               kfree(ph2c);
-               res = _FAIL;
-               goto exit;
-       }
-
-       init_h2fwcmd_w_parm_no_rsp(ph2c, psetstakey_para, _SetStaKey_CMD_);
-
-       psetstakey_para->algorithm = psta->dot118021XPrivacy;
-
-       ether_addr_copy(psetstakey_para->addr, psta->hwaddr);
-
-       memcpy(psetstakey_para->key, &psta->dot118021x_UncstKey, 16);
-
-       res = rtw_enqueue_cmd23a(pcmdpriv, ph2c);
-
-exit:
-       return res;
-}
-
-static int set_group_key(struct rtw_adapter *padapter, struct key_params *parms,
-                        u32 alg, u8 keyid)
-{
-       struct cmd_obj *pcmd;
-       struct setkey_parm *psetkeyparm;
-       struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
-       int res = _SUCCESS;
-
-       DBG_8723A("%s\n", __func__);
-
-       if (keyid >= 4) {
-               res = _FAIL;
-               goto exit;
-       }
-
-       pcmd = kzalloc(sizeof(struct cmd_obj), GFP_KERNEL);
-       if (!pcmd) {
-               res = _FAIL;
-               goto exit;
-       }
-       psetkeyparm = kzalloc(sizeof(struct setkey_parm), GFP_KERNEL);
-       if (!psetkeyparm) {
-               kfree(pcmd);
-               res = _FAIL;
-               goto exit;
-       }
-
-       psetkeyparm->keyid = keyid;
-       if (is_wep_enc(alg))
-               padapter->mlmepriv.key_mask |= BIT(psetkeyparm->keyid);
-
-       psetkeyparm->algorithm = alg;
-
-       psetkeyparm->set_tx = 1;
-
-       memcpy(&psetkeyparm->key, parms->key, parms->key_len);
-
-       pcmd->cmdcode = _SetKey_CMD_;
-       pcmd->parmbuf = (u8 *) psetkeyparm;
-       pcmd->cmdsz = sizeof(struct setkey_parm);
-       pcmd->rsp = NULL;
-       pcmd->rspsz = 0;
-
-       res = rtw_enqueue_cmd23a(pcmdpriv, pcmd);
-
-exit:
-       return res;
-}
-
-static int rtw_cfg80211_ap_set_encryption(struct net_device *dev, u8 key_index,
-                                         int set_tx, const u8 *sta_addr,
-                                         struct key_params *keyparms)
-{
-       int key_len;
-       struct sta_info *psta = NULL, *pbcmc_sta = NULL;
-       struct rtw_adapter *padapter = netdev_priv(dev);
-       struct security_priv *psecuritypriv = &padapter->securitypriv;
-       struct sta_priv *pstapriv = &padapter->stapriv;
-
-       DBG_8723A("%s\n", __func__);
-
-       if (!is_broadcast_ether_addr(sta_addr)) {
-               psta = rtw_get_stainfo23a(pstapriv, sta_addr);
-               if (!psta) {
-                       /* ret = -EINVAL; */
-                       DBG_8723A("rtw_set_encryption(), sta has already "
-                                 "been removed or never been added\n");
-                       goto exit;
-               }
-       }
-
-       key_len = keyparms->key_len;
-
-       if (!psta && (keyparms->cipher == WLAN_CIPHER_SUITE_WEP40 ||
-                     keyparms->cipher == WLAN_CIPHER_SUITE_WEP104)) {
-               DBG_8723A("r871x_set_encryption, crypt.alg = WEP\n");
-
-               DBG_8723A("r871x_set_encryption, wep_key_idx =%d, len =%d\n",
-                         key_index, key_len);
-
-               if (psecuritypriv->bWepDefaultKeyIdxSet == 0) {
-                       /* wep default key has not been set, so use
-                          this key index as default key. */
-
-                       psecuritypriv->ndisencryptstatus =
-                               Ndis802_11Encryption1Enabled;
-                       psecuritypriv->dot11PrivacyAlgrthm = keyparms->cipher;
-                       psecuritypriv->dot118021XGrpPrivacy = keyparms->cipher;
-
-                       psecuritypriv->dot11PrivacyKeyIndex = key_index;
-               }
-
-               memcpy(&psecuritypriv->wep_key[key_index].key,
-                      keyparms->key, key_len);
-
-               psecuritypriv->wep_key[key_index].keylen = key_len;
-
-               set_group_key(padapter, keyparms, keyparms->cipher, key_index);
-
-               goto exit;
-       }
-
-       if (!psta) {    /*  group key */
-               if (set_tx == 0) {      /* group key */
-                       if (keyparms->cipher == WLAN_CIPHER_SUITE_WEP40 ||
-                           keyparms->cipher == WLAN_CIPHER_SUITE_WEP104) {
-                               DBG_8723A("%s, set group_key, WEP\n", __func__);
-
-                               memcpy(psecuritypriv->
-                                      dot118021XGrpKey[key_index].skey,
-                                      keyparms->key, key_len);
-
-                               psecuritypriv->dot118021XGrpPrivacy =
-                                       keyparms->cipher;
-                       } else if (keyparms->cipher == WLAN_CIPHER_SUITE_TKIP) {
-                               DBG_8723A("%s, set group_key, TKIP\n",
-                                         __func__);
-
-                               psecuritypriv->dot118021XGrpPrivacy =
-                                       WLAN_CIPHER_SUITE_TKIP;
-
-                               memcpy(psecuritypriv->
-                                      dot118021XGrpKey[key_index].skey,
-                                      keyparms->key,
-                                      (min(16, key_len)));
-
-                               /* set mic key */
-                               memcpy(psecuritypriv->
-                                      dot118021XGrptxmickey[key_index].skey,
-                                      &keyparms->key[16], 8);
-                               memcpy(psecuritypriv->
-                                      dot118021XGrprxmickey[key_index].skey,
-                                      &keyparms->key[24], 8);
-
-                               psecuritypriv->busetkipkey = 1;
-
-                       } else if (keyparms->cipher == WLAN_CIPHER_SUITE_CCMP) {
-                                       DBG_8723A("%s, set group_key, CCMP\n",
-                                         __func__);
-
-                               psecuritypriv->dot118021XGrpPrivacy =
-                                       WLAN_CIPHER_SUITE_CCMP;
-
-                               memcpy(psecuritypriv->
-                                      dot118021XGrpKey[key_index].skey,
-                                      keyparms->key,
-                                      (min(16, key_len)));
-                       } else {
-                               DBG_8723A("%s, set group_key, none\n",
-                                         __func__);
-
-                               psecuritypriv->dot118021XGrpPrivacy = 0;
-                       }
-
-                       psecuritypriv->dot118021XGrpKeyid = key_index;
-
-                       psecuritypriv->binstallGrpkey = 1;
-
-                       psecuritypriv->dot11PrivacyAlgrthm =
-                               psecuritypriv->dot118021XGrpPrivacy;
-
-                       set_group_key(padapter, keyparms,
-                                     psecuritypriv->dot118021XGrpPrivacy,
-                                     key_index);
-
-                       pbcmc_sta = rtw_get_bcmc_stainfo23a(padapter);
-                       if (pbcmc_sta) {
-                               pbcmc_sta->ieee8021x_blocked = false;
-                               /* rx will use bmc_sta's dot118021XPrivacy */
-                               pbcmc_sta->dot118021XPrivacy =
-                                       psecuritypriv->dot118021XGrpPrivacy;
-
-                       }
-
-               }
-
-               goto exit;
-       }
-
-       if (psecuritypriv->dot11AuthAlgrthm == dot11AuthAlgrthm_8021X && psta) {
-               /*  psk/802_1x */
-               if (set_tx == 1) {
-                       /* pairwise key */
-                       memcpy(psta->dot118021x_UncstKey.skey,
-                              keyparms->key, (min(16, key_len)));
-
-                       if (keyparms->cipher == WLAN_CIPHER_SUITE_WEP40 ||
-                           keyparms->cipher == WLAN_CIPHER_SUITE_WEP104) {
-                               DBG_8723A("%s, set pairwise key, WEP\n",
-                                         __func__);
-
-                               psecuritypriv->dot118021XGrpPrivacy =
-                                       keyparms->cipher;
-                       } else if (keyparms->cipher == WLAN_CIPHER_SUITE_TKIP) {
-                               DBG_8723A("%s, set pairwise key, TKIP\n",
-                                         __func__);
-
-                               psta->dot118021XPrivacy =
-                                       WLAN_CIPHER_SUITE_TKIP;
-
-                               /* set mic key */
-                               memcpy(psta->dot11tkiptxmickey.skey,
-                                      &keyparms->key[16], 8);
-                               memcpy(psta->dot11tkiprxmickey.skey,
-                                      &keyparms->key[24], 8);
-
-                               psecuritypriv->busetkipkey = 1;
-
-                       } else if (keyparms->cipher == WLAN_CIPHER_SUITE_CCMP) {
-                               DBG_8723A("%s, set pairwise key, CCMP\n",
-                                         __func__);
-
-                               psta->dot118021XPrivacy =
-                                       WLAN_CIPHER_SUITE_CCMP;
-                       } else {
-                               DBG_8723A("%s, set pairwise key, none\n",
-                                         __func__);
-
-                               psta->dot118021XPrivacy = 0;
-                       }
-
-                       set_pairwise_key(padapter, psta);
-
-                       psta->ieee8021x_blocked = false;
-
-                       psta->bpairwise_key_installed = true;
-               } else {        /* group key??? */
-                       if (keyparms->cipher == WLAN_CIPHER_SUITE_WEP40 ||
-                           keyparms->cipher == WLAN_CIPHER_SUITE_WEP104) {
-                               memcpy(psecuritypriv->
-                                      dot118021XGrpKey[key_index].skey,
-                                      keyparms->key, key_len);
-
-                               psecuritypriv->dot118021XGrpPrivacy =
-                                       keyparms->cipher;
-                       } else if (keyparms->cipher == WLAN_CIPHER_SUITE_TKIP) {
-                               psecuritypriv->dot118021XGrpPrivacy =
-                                       WLAN_CIPHER_SUITE_TKIP;
-
-                               memcpy(psecuritypriv->
-                                      dot118021XGrpKey[key_index].skey,
-                                      keyparms->key,
-                                      (min(16, key_len)));
-
-                               /* set mic key */
-                               memcpy(psecuritypriv->
-                                      dot118021XGrptxmickey[key_index].skey,
-                                      &keyparms->key[16], 8);
-                               memcpy(psecuritypriv->
-                                      dot118021XGrprxmickey[key_index].skey,
-                                      &keyparms->key[24], 8);
-
-                               psecuritypriv->busetkipkey = 1;
-                       } else if (keyparms->cipher == WLAN_CIPHER_SUITE_CCMP) {
-                               psecuritypriv->dot118021XGrpPrivacy =
-                                       WLAN_CIPHER_SUITE_CCMP;
-
-                               memcpy(psecuritypriv->
-                                      dot118021XGrpKey[key_index].skey,
-                                      keyparms->key,
-                                      (min(16, key_len)));
-                       } else {
-                               psecuritypriv->dot118021XGrpPrivacy = 0;
-                       }
-
-                       psecuritypriv->dot118021XGrpKeyid = key_index;
-
-                       psecuritypriv->binstallGrpkey = 1;
-
-                       psecuritypriv->dot11PrivacyAlgrthm =
-                               psecuritypriv->dot118021XGrpPrivacy;
-
-                       set_group_key(padapter, keyparms,
-                                     psecuritypriv->dot118021XGrpPrivacy,
-                                     key_index);
-
-                       pbcmc_sta = rtw_get_bcmc_stainfo23a(padapter);
-                       if (pbcmc_sta) {
-                               /* rx will use bmc_sta's
-                                  dot118021XPrivacy */
-                               pbcmc_sta->ieee8021x_blocked = false;
-                               pbcmc_sta->dot118021XPrivacy =
-                                       psecuritypriv->dot118021XGrpPrivacy;
-                       }
-               }
-       }
-
-exit:
-
-       return 0;
-}
-#endif
-
-static int rtw_cfg80211_set_encryption(struct net_device *dev, u8 key_index,
-                                      int set_tx, const u8 *sta_addr,
-                                      struct key_params *keyparms)
-{
-       int ret = 0;
-       int key_len;
-       struct rtw_adapter *padapter = netdev_priv(dev);
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct security_priv *psecuritypriv = &padapter->securitypriv;
-
-       DBG_8723A("%s\n", __func__);
-
-       key_len = keyparms->key_len;
-
-       if (keyparms->cipher == WLAN_CIPHER_SUITE_WEP40 ||
-           keyparms->cipher == WLAN_CIPHER_SUITE_WEP104) {
-               RT_TRACE(_module_rtl871x_ioctl_os_c, _drv_err_,
-                        "wpa_set_encryption, crypt.alg = WEP\n");
-               DBG_8723A("wpa_set_encryption, crypt.alg = WEP\n");
-
-               if (psecuritypriv->bWepDefaultKeyIdxSet == 0) {
-                       /* wep default key has not been set, so use this
-                          key index as default key. */
-
-                       psecuritypriv->ndisencryptstatus =
-                               Ndis802_11Encryption1Enabled;
-                       psecuritypriv->dot11PrivacyAlgrthm = keyparms->cipher;
-                       psecuritypriv->dot118021XGrpPrivacy = keyparms->cipher;
-
-                       psecuritypriv->dot11PrivacyKeyIndex = key_index;
-               }
-
-               memcpy(&psecuritypriv->wep_key[key_index].key,
-                      keyparms->key, key_len);
-
-               psecuritypriv->wep_key[key_index].keylen = key_len;
-
-               rtw_set_key23a(padapter, psecuritypriv, key_index, 0);
-
-               goto exit;
-       }
-
-       if (padapter->securitypriv.dot11AuthAlgrthm ==
-           dot11AuthAlgrthm_8021X) {   /*  802_1x */
-               struct sta_info *psta, *pbcmc_sta;
-               struct sta_priv *pstapriv = &padapter->stapriv;
-
-               if (check_fwstate(pmlmepriv,
-                                 WIFI_STATION_STATE | WIFI_MP_STATE)) {
-                       /* sta mode */
-                       psta = rtw_get_stainfo23a(pstapriv, get_bssid(pmlmepriv));
-                       if (psta == NULL) {
-                               DBG_8723A("%s, : Obtain Sta_info fail\n",
-                                         __func__);
-                       } else {
-                               /* Jeff: don't disable ieee8021x_blocked
-                                  while clearing key */
-                               if (keyparms->cipher != IW_AUTH_CIPHER_NONE &&
-                                   keyparms->cipher != 0)
-                                       psta->ieee8021x_blocked = false;
-
-                               if ((padapter->securitypriv.ndisencryptstatus ==
-                                    Ndis802_11Encryption2Enabled) ||
-                                   (padapter->securitypriv.ndisencryptstatus ==
-                                    Ndis802_11Encryption3Enabled)) {
-                                       psta->dot118021XPrivacy =
-                                               padapter->securitypriv.
-                                               dot11PrivacyAlgrthm;
-                               }
-
-                               if (set_tx == 1) {
-                                       /* pairwise key */
-                                       DBG_8723A("%s, : set_tx == 1\n",
-                                                 __func__);
-
-                                       memcpy(psta->dot118021x_UncstKey.skey,
-                                              keyparms->key,
-                                              (min(16, key_len)));
-
-                                       if (keyparms->cipher ==
-                                           WLAN_CIPHER_SUITE_TKIP) {
-                                               memcpy(psta->dot11tkiptxmickey.
-                                                      skey,
-                                                      &keyparms->key[16], 8);
-                                               memcpy(psta->dot11tkiprxmickey.
-                                                      skey,
-                                                      &keyparms->key[24], 8);
-
-                                               padapter->securitypriv.
-                                                       busetkipkey = 0;
-                                       }
-                                       DBG_8723A(" ~~~~set sta key:unicastkey\n");
-
-                                       rtw_setstakey_cmd23a(padapter,
-                                                         (unsigned char *)psta,
-                                                         true);
-                               } else {        /* group key */
-                                       memcpy(padapter->securitypriv.
-                                              dot118021XGrpKey[key_index].skey,
-                                              keyparms->key,
-                                              (min(16, key_len)));
-                                       memcpy(padapter->securitypriv.
-                                              dot118021XGrptxmickey[key_index].
-                                              skey, &keyparms->key[16], 8);
-                                       memcpy(padapter->securitypriv.
-                                              dot118021XGrprxmickey[key_index].
-                                              skey, &keyparms->key[24], 8);
-                                       padapter->securitypriv.binstallGrpkey =
-                                               1;
-                                       DBG_8723A
-                                           (" ~~~~set sta key:groupkey\n");
-
-                                       padapter->securitypriv.
-                                           dot118021XGrpKeyid = key_index;
-
-                                       rtw_set_key23a(padapter,
-                                                   &padapter->securitypriv,
-                                                   key_index, 1);
-                               }
-                       }
-
-                       pbcmc_sta = rtw_get_bcmc_stainfo23a(padapter);
-                       if (pbcmc_sta) {
-                               /* Jeff: don't disable ieee8021x_blocked
-                                  while clearing key */
-                               if (keyparms->cipher != IW_AUTH_CIPHER_NONE &&
-                                   keyparms->cipher != 0)
-                                       pbcmc_sta->ieee8021x_blocked = false;
-
-                               if ((padapter->securitypriv.ndisencryptstatus ==
-                                    Ndis802_11Encryption2Enabled) ||
-                                   (padapter->securitypriv.ndisencryptstatus ==
-                                    Ndis802_11Encryption3Enabled)) {
-                                       pbcmc_sta->dot118021XPrivacy =
-                                           padapter->securitypriv.
-                                           dot11PrivacyAlgrthm;
-                               }
-                       }
-               }
-       }
-
-exit:
-
-       DBG_8723A("%s, ret =%d\n", __func__, ret);
-
-
-
-       return ret;
-}
-
-static int cfg80211_rtw_add_key(struct wiphy *wiphy, struct net_device *ndev,
-                               u8 key_index, bool pairwise,
-                               const u8 *mac_addr, struct key_params *params)
-{
-       int set_tx, ret = 0;
-       struct wireless_dev *rtw_wdev = wiphy_to_wdev(wiphy);
-       struct rtw_adapter *padapter = wiphy_to_adapter(wiphy);
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       u8 sta_addr[ETH_ALEN];
-
-       DBG_8723A("%s(%s): adding key for %pM\n", __func__, ndev->name,
-                 mac_addr);
-       DBG_8723A("cipher = 0x%x\n", params->cipher);
-       DBG_8723A("key_len = 0x%x\n", params->key_len);
-       DBG_8723A("seq_len = 0x%x\n", params->seq_len);
-       DBG_8723A("key_index =%d\n", key_index);
-       DBG_8723A("pairwise =%d\n", pairwise);
-
-       switch (params->cipher) {
-       case IW_AUTH_CIPHER_NONE:
-       case WLAN_CIPHER_SUITE_WEP40:
-               if (params->key_len != WLAN_KEY_LEN_WEP40) {
-                       ret = -EINVAL;
-                       goto exit;
-               }
-       case WLAN_CIPHER_SUITE_WEP104:
-               if (params->key_len != WLAN_KEY_LEN_WEP104) {
-                       ret = -EINVAL;
-                       goto exit;
-               }
-       case WLAN_CIPHER_SUITE_TKIP:
-       case WLAN_CIPHER_SUITE_CCMP:
-               break;
-       default:
-               ret = -ENOTSUPP;
-               goto exit;
-       }
-
-       if (key_index >= WEP_KEYS || params->key_len < 0) {
-               ret = -EINVAL;
-               goto exit;
-       }
-
-       eth_broadcast_addr(sta_addr);
-
-       if (!mac_addr || is_broadcast_ether_addr(mac_addr))
-               set_tx = 0;     /* for wpa/wpa2 group key */
-       else
-               set_tx = 1;     /* for wpa/wpa2 pairwise key */
-
-       if (check_fwstate(pmlmepriv, WIFI_STATION_STATE)) {
-               ret = rtw_cfg80211_set_encryption(ndev, key_index, set_tx,
-                                                 sta_addr, params);
-       } else if (check_fwstate(pmlmepriv, WIFI_AP_STATE)) {
-#ifdef CONFIG_8723AU_AP_MODE
-               if (mac_addr)
-                       ether_addr_copy(sta_addr, mac_addr);
-
-               ret = rtw_cfg80211_ap_set_encryption(ndev, key_index, set_tx,
-                                                    sta_addr, params);
-#endif
-       } else {
-               DBG_8723A("error! fw_state = 0x%x, iftype =%d\n",
-                         pmlmepriv->fw_state, rtw_wdev->iftype);
-
-       }
-
-exit:
-       return ret;
-}
-
-static int
-cfg80211_rtw_get_key(struct wiphy *wiphy, struct net_device *ndev,
-                    u8 key_index, bool pairwise, const u8 *mac_addr,
-                    void *cookie,
-                    void (*callback) (void *cookie, struct key_params *))
-{
-       DBG_8723A("%s(%s)\n", __func__, ndev->name);
-       return 0;
-}
-
-static int cfg80211_rtw_del_key(struct wiphy *wiphy, struct net_device *ndev,
-                               u8 key_index, bool pairwise,
-                               const u8 *mac_addr)
-{
-       struct rtw_adapter *padapter = netdev_priv(ndev);
-       struct security_priv *psecuritypriv = &padapter->securitypriv;
-
-       DBG_8723A("%s(%s): key_index =%d\n", __func__, ndev->name, key_index);
-
-       if (key_index == psecuritypriv->dot11PrivacyKeyIndex) {
-               /* clear the flag of wep default key set. */
-               psecuritypriv->bWepDefaultKeyIdxSet = 0;
-       }
-
-       return 0;
-}
-
-static int cfg80211_rtw_set_default_key(struct wiphy *wiphy,
-                                       struct net_device *ndev, u8 key_index,
-                                       bool unicast, bool multicast)
-{
-       struct rtw_adapter *padapter = netdev_priv(ndev);
-       struct security_priv *psecuritypriv = &padapter->securitypriv;
-
-       DBG_8723A("%s(%s): key_index =%d, unicast =%d, multicast =%d.\n",
-                 __func__, ndev->name, key_index, unicast, multicast);
-
-       if (key_index < NUM_WEP_KEYS &&
-           (psecuritypriv->dot11PrivacyAlgrthm == WLAN_CIPHER_SUITE_WEP40 ||
-            psecuritypriv->dot11PrivacyAlgrthm == WLAN_CIPHER_SUITE_WEP104)) {
-               /* set wep default key */
-               psecuritypriv->ndisencryptstatus = Ndis802_11Encryption1Enabled;
-
-               psecuritypriv->dot11PrivacyKeyIndex = key_index;
-
-               psecuritypriv->dot11PrivacyAlgrthm = WLAN_CIPHER_SUITE_WEP40;
-               psecuritypriv->dot118021XGrpPrivacy = WLAN_CIPHER_SUITE_WEP40;
-               if (psecuritypriv->wep_key[key_index].keylen == 13) {
-                       psecuritypriv->dot11PrivacyAlgrthm =
-                               WLAN_CIPHER_SUITE_WEP104;
-                       psecuritypriv->dot118021XGrpPrivacy =
-                               WLAN_CIPHER_SUITE_WEP104;
-               }
-
-               /* set the flag to represent that wep default key
-                  has been set */
-               psecuritypriv->bWepDefaultKeyIdxSet = 1;
-       }
-
-       return 0;
-}
-
-static u16 rtw_get_cur_max_rate(struct rtw_adapter *adapter)
-{
-       int i = 0;
-       const u8 *p;
-       u16 rate = 0, max_rate = 0;
-       struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       struct registry_priv *pregistrypriv = &adapter->registrypriv;
-       struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
-       struct wlan_bssid_ex  *pcur_bss = &pmlmepriv->cur_network.network;
-       struct ieee80211_ht_cap *pht_capie;
-       u8 rf_type = 0;
-       u8 bw_40MHz = 0, short_GI_20 = 0, short_GI_40 = 0;
-       u16 mcs_rate = 0;
-
-       p = cfg80211_find_ie(WLAN_EID_HT_CAPABILITY,
-                            pcur_bss->IEs, pcur_bss->IELength);
-       if (p && p[1] > 0) {
-               pht_capie = (struct ieee80211_ht_cap *)(p + 2);
-
-               memcpy(&mcs_rate, &pht_capie->mcs, 2);
-
-               /* bw_40MHz = (pht_capie->cap_info&
-                  IEEE80211_HT_CAP_SUP_WIDTH_20_40) ? 1:0; */
-               /* cur_bwmod is updated by beacon, pmlmeinfo is
-                  updated by association response */
-               bw_40MHz = (pmlmeext->cur_bwmode &&
-                           (pmlmeinfo->HT_info.ht_param &
-                            IEEE80211_HT_PARAM_CHAN_WIDTH_ANY)) ? 1:0;
-
-               /* short_GI = (pht_capie->cap_info & (IEEE80211_HT_CAP
-                  _SGI_20|IEEE80211_HT_CAP_SGI_40)) ? 1 : 0; */
-               short_GI_20 = (pmlmeinfo->ht_cap.cap_info &
-                              cpu_to_le16(IEEE80211_HT_CAP_SGI_20)) ? 1:0;
-               short_GI_40 = (pmlmeinfo->ht_cap.cap_info &
-                              cpu_to_le16(IEEE80211_HT_CAP_SGI_40)) ? 1:0;
-
-               rf_type = rtl8723a_get_rf_type(adapter);
-               max_rate = rtw_mcs_rate23a(rf_type, bw_40MHz &
-                                          pregistrypriv->cbw40_enable,
-                                          short_GI_20, short_GI_40,
-                                          &pmlmeinfo->ht_cap.mcs);
-       } else {
-               while (pcur_bss->SupportedRates[i] != 0 &&
-                      pcur_bss->SupportedRates[i] != 0xFF) {
-                       rate = pcur_bss->SupportedRates[i] & 0x7F;
-                       if (rate > max_rate)
-                               max_rate = rate;
-                       i++;
-               }
-
-               max_rate = max_rate * 10 / 2;
-       }
-
-       return max_rate;
-}
-
-static int cfg80211_rtw_get_station(struct wiphy *wiphy,
-                                   struct net_device *ndev,
-                                   const u8 *mac, struct station_info *sinfo)
-{
-       int ret = 0;
-       struct rtw_adapter *padapter = wiphy_to_adapter(wiphy);
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct sta_info *psta = NULL;
-       struct sta_priv *pstapriv = &padapter->stapriv;
-
-       sinfo->filled = 0;
-
-       if (!mac) {
-               DBG_8723A("%s(%s): mac ==%p\n", __func__, ndev->name, mac);
-               ret = -ENOENT;
-               goto exit;
-       }
-
-       psta = rtw_get_stainfo23a(pstapriv, mac);
-       if (psta == NULL) {
-               DBG_8723A("%s, sta_info is null\n", __func__);
-               ret = -ENOENT;
-               goto exit;
-       }
-       DBG_8723A("%s(%s): mac=%pM\n", __func__, ndev->name, mac);
-
-       /* for infra./P2PClient mode */
-       if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) &&
-           check_fwstate(pmlmepriv, _FW_LINKED)) {
-               struct wlan_network *cur_network = &pmlmepriv->cur_network;
-
-               if (!ether_addr_equal(mac, cur_network->network.MacAddress)) {
-                       DBG_8723A("%s, mismatch bssid=%pM\n",
-                                 __func__, cur_network->network.MacAddress);
-                       ret = -ENOENT;
-                       goto exit;
-               }
-
-               sinfo->filled |= BIT(NL80211_STA_INFO_SIGNAL);
-               sinfo->signal = translate_percentage_to_dbm(padapter->recvpriv.
-                                                           signal_strength);
-
-               sinfo->filled |= BIT(NL80211_STA_INFO_TX_BITRATE);
-               sinfo->txrate.legacy = rtw_get_cur_max_rate(padapter);
-
-               sinfo->filled |= BIT(NL80211_STA_INFO_RX_PACKETS);
-               sinfo->rx_packets = sta_rx_data_pkts(psta);
-
-               sinfo->filled |= BIT(NL80211_STA_INFO_TX_PACKETS);
-               sinfo->tx_packets = psta->sta_stats.tx_pkts;
-       }
-
-       /* for Ad-Hoc/AP mode */
-       if ((check_fwstate(pmlmepriv, WIFI_ADHOC_STATE) ||
-            check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE) ||
-            check_fwstate(pmlmepriv, WIFI_AP_STATE)) &&
-           check_fwstate(pmlmepriv, _FW_LINKED)
-           ) {
-               /* TODO: should acquire station info... */
-       }
-
-exit:
-       return ret;
-}
-
-static int cfg80211_infrastructure_mode(struct rtw_adapter *padapter,
-                                enum nl80211_iftype ifmode)
-{
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct wlan_network *cur_network = &pmlmepriv->cur_network;
-       enum nl80211_iftype old_mode;
-
-       old_mode = cur_network->network.ifmode;
-
-       RT_TRACE(_module_rtl871x_ioctl_set_c_, _drv_notice_,
-                "+%s: old =%d new =%d fw_state = 0x%08x\n", __func__,
-                old_mode, ifmode, get_fwstate(pmlmepriv));
-
-       if (old_mode != ifmode) {
-               spin_lock_bh(&pmlmepriv->lock);
-
-               RT_TRACE(_module_rtl871x_ioctl_set_c_, _drv_info_,
-                        "change mode!\n");
-
-               if (old_mode == NL80211_IFTYPE_AP ||
-                   old_mode == NL80211_IFTYPE_P2P_GO) {
-                       /* change to other mode from Ndis802_11APMode */
-                       cur_network->join_res = -1;
-
-#ifdef CONFIG_8723AU_AP_MODE
-                       stop_ap_mode23a(padapter);
-#endif
-               }
-
-               if (check_fwstate(pmlmepriv, _FW_LINKED) ||
-                   old_mode == NL80211_IFTYPE_ADHOC)
-                       rtw_disassoc_cmd23a(padapter, 0, true);
-
-               if (check_fwstate(pmlmepriv, _FW_LINKED) ||
-                   check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE))
-                       rtw_free_assoc_resources23a(padapter, 1);
-
-               if (old_mode == NL80211_IFTYPE_STATION ||
-                   old_mode == NL80211_IFTYPE_P2P_CLIENT ||
-                   old_mode == NL80211_IFTYPE_ADHOC) {
-                       if (check_fwstate(pmlmepriv, _FW_LINKED)) {
-                               /* will clr Linked_state; before this function,
-                                  we must have chked whether issue
-                                  dis-assoc_cmd or not */
-                               rtw_indicate_disconnect23a(padapter);
-                       }
-              }
-
-               cur_network->network.ifmode = ifmode;
-
-               _clr_fwstate_(pmlmepriv, ~WIFI_NULL_STATE);
-
-               switch (ifmode) {
-               case NL80211_IFTYPE_ADHOC:
-                       set_fwstate(pmlmepriv, WIFI_ADHOC_STATE);
-                       break;
-
-               case NL80211_IFTYPE_P2P_CLIENT:
-               case NL80211_IFTYPE_STATION:
-                       set_fwstate(pmlmepriv, WIFI_STATION_STATE);
-                       break;
-
-               case NL80211_IFTYPE_P2P_GO:
-               case NL80211_IFTYPE_AP:
-                       set_fwstate(pmlmepriv, WIFI_AP_STATE);
-#ifdef CONFIG_8723AU_AP_MODE
-                       start_ap_mode23a(padapter);
-                       /* rtw_indicate_connect23a(padapter); */
-#endif
-                       break;
-
-               default:
-                       break;
-               }
-
-               /* SecClearAllKeys(adapter); */
-
-               spin_unlock_bh(&pmlmepriv->lock);
-       }
-
-       return _SUCCESS;
-}
-
-static int cfg80211_rtw_change_iface(struct wiphy *wiphy,
-                                    struct net_device *ndev,
-                                    enum nl80211_iftype type, u32 *flags,
-                                    struct vif_params *params)
-{
-       enum nl80211_iftype old_type;
-       struct rtw_adapter *padapter = wiphy_to_adapter(wiphy);
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct wireless_dev *rtw_wdev = wiphy_to_wdev(wiphy);
-       int ret = 0;
-
-       DBG_8723A("%s(%s): call netdev_open23a\n", __func__, ndev->name);
-
-       old_type = rtw_wdev->iftype;
-       DBG_8723A("%s(%s): old_iftype =%d, new_iftype =%d\n",
-                 __func__, ndev->name, old_type, type);
-
-       if (old_type != type) {
-               pmlmeext->action_public_rxseq = 0xffff;
-               pmlmeext->action_public_dialog_token = 0xff;
-       }
-
-       switch (type) {
-       case NL80211_IFTYPE_ADHOC:
-       case NL80211_IFTYPE_P2P_CLIENT:
-       case NL80211_IFTYPE_STATION:
-       case NL80211_IFTYPE_P2P_GO:
-       case NL80211_IFTYPE_AP:
-       case NL80211_IFTYPE_UNSPECIFIED:
-               break;
-       default:
-               return -EOPNOTSUPP;
-       }
-
-       rtw_wdev->iftype = type;
-
-       if (cfg80211_infrastructure_mode(padapter, type) != _SUCCESS) {
-               rtw_wdev->iftype = old_type;
-               ret = -EPERM;
-               goto exit;
-       }
-
-       rtw_setopmode_cmd23a(padapter, type);
-
-exit:
-       return ret;
-}
-
-void rtw_cfg80211_indicate_scan_done(struct rtw_wdev_priv *pwdev_priv,
-                                    bool aborted)
-{
-       spin_lock_bh(&pwdev_priv->scan_req_lock);
-       if (pwdev_priv->scan_request != NULL) {
-               DBG_8723A("%s with scan req\n", __func__);
-
-               if (pwdev_priv->scan_request->wiphy !=
-                   pwdev_priv->rtw_wdev->wiphy) {
-                       DBG_8723A("error wiphy compare\n");
-               } else {
-                       struct cfg80211_scan_info info = {
-                               .aborted = aborted,
-                       };
-
-                       cfg80211_scan_done(pwdev_priv->scan_request, &info);
-               }
-
-               pwdev_priv->scan_request = NULL;
-       } else {
-               DBG_8723A("%s without scan req\n", __func__);
-       }
-       spin_unlock_bh(&pwdev_priv->scan_req_lock);
-}
-
-void rtw_cfg80211_surveydone_event_callback(struct rtw_adapter *padapter)
-{
-       struct list_head *phead;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct rtw_queue *queue = &pmlmepriv->scanned_queue;
-       struct wlan_network *pnetwork, *ptmp;
-
-       spin_lock_bh(&pmlmepriv->scanned_queue.lock);
-       phead = get_list_head(queue);
-       list_for_each_entry_safe(pnetwork, ptmp, phead, list) {
-               /* report network only if the current channel set
-                  contains the channel to which this network belongs */
-               if (rtw_ch_set_search_ch23a
-                   (padapter->mlmeextpriv.channel_set,
-                    pnetwork->network.DSConfig) >= 0)
-                       rtw_cfg80211_inform_bss(padapter, pnetwork);
-       }
-       spin_unlock_bh(&pmlmepriv->scanned_queue.lock);
-
-       /* call this after other things have been done */
-       rtw_cfg80211_indicate_scan_done(wdev_to_priv(padapter->rtw_wdev),
-                                       false);
-}
-
-static int rtw_cfg80211_set_probe_req_wpsp2pie(struct rtw_adapter *padapter,
-                                              char *buf, int len)
-{
-       int ret = 0;
-       const u8 *wps_ie;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-
-       DBG_8723A("%s, ielen =%d\n", __func__, len);
-
-       if (len > 0) {
-               wps_ie = cfg80211_find_vendor_ie(WLAN_OUI_MICROSOFT,
-                                                WLAN_OUI_TYPE_MICROSOFT_WPS,
-                                                buf, len);
-               if (wps_ie) {
-                       DBG_8723A("probe_req_wps_ielen =%d\n", wps_ie[1]);
-
-                       if (pmlmepriv->wps_probe_req_ie) {
-                               pmlmepriv->wps_probe_req_ie_len = 0;
-                               kfree(pmlmepriv->wps_probe_req_ie);
-                               pmlmepriv->wps_probe_req_ie = NULL;
-                       }
-
-                       pmlmepriv->wps_probe_req_ie = kmemdup(wps_ie, wps_ie[1],
-                                                             GFP_KERNEL);
-                       if (pmlmepriv->wps_probe_req_ie == NULL) {
-                               DBG_8723A("%s()-%d: kmalloc() ERROR!\n",
-                                         __func__, __LINE__);
-                               return -EINVAL;
-                       }
-                       pmlmepriv->wps_probe_req_ie_len = wps_ie[1];
-               }
-       }
-
-       return ret;
-}
-
-static int cfg80211_rtw_scan(struct wiphy *wiphy,
-                            struct cfg80211_scan_request *request)
-{
-       int i;
-       u8 _status = false;
-       int ret = 0;
-       struct rtw_adapter *padapter = wiphy_to_adapter(wiphy);
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct cfg80211_ssid ssid[RTW_SSID_SCAN_AMOUNT];
-       struct rtw_ieee80211_channel ch[RTW_CHANNEL_SCAN_AMOUNT];
-       struct rtw_wdev_priv *pwdev_priv = wdev_to_priv(padapter->rtw_wdev);
-       struct cfg80211_ssid *ssids = request->ssids;
-       bool need_indicate_scan_done = false;
-
-       DBG_8723A("%s(%s)\n", __func__, padapter->pnetdev->name);
-
-       spin_lock_bh(&pwdev_priv->scan_req_lock);
-       pwdev_priv->scan_request = request;
-       spin_unlock_bh(&pwdev_priv->scan_req_lock);
-
-       if (check_fwstate(pmlmepriv, WIFI_AP_STATE)) {
-               DBG_8723A("%s under WIFI_AP_STATE\n", __func__);
-               /* need_indicate_scan_done = true; */
-               /* goto check_need_indicate_scan_done; */
-       }
-
-       if (rtw_pwr_wakeup(padapter) == _FAIL) {
-               need_indicate_scan_done = true;
-               goto check_need_indicate_scan_done;
-       }
-
-       if (request->ie && request->ie_len > 0) {
-               rtw_cfg80211_set_probe_req_wpsp2pie(padapter,
-                                                   (u8 *) request->ie,
-                                                   request->ie_len);
-       }
-
-       if (pmlmepriv->LinkDetectInfo.bBusyTraffic == true) {
-               DBG_8723A("%s, bBusyTraffic == true\n", __func__);
-               need_indicate_scan_done = true;
-               goto check_need_indicate_scan_done;
-       }
-       if (rtw_is_scan_deny(padapter)) {
-               DBG_8723A("%s(%s): scan deny\n", __func__,
-                         padapter->pnetdev->name);
-               need_indicate_scan_done = true;
-               goto check_need_indicate_scan_done;
-       }
-
-       if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY | _FW_UNDER_LINKING) ==
-           true) {
-               DBG_8723A("%s, fwstate = 0x%x\n", __func__, pmlmepriv->fw_state);
-               need_indicate_scan_done = true;
-               goto check_need_indicate_scan_done;
-       }
-
-       memset(ssid, 0, sizeof(struct cfg80211_ssid) * RTW_SSID_SCAN_AMOUNT);
-       /* parsing request ssids, n_ssids */
-       for (i = 0; i < request->n_ssids && i < RTW_SSID_SCAN_AMOUNT; i++) {
-               DBG_8723A("ssid =%s, len =%d\n", ssids[i].ssid,
-                         ssids[i].ssid_len);
-               memcpy(ssid[i].ssid, ssids[i].ssid, ssids[i].ssid_len);
-               ssid[i].ssid_len = ssids[i].ssid_len;
-       }
-
-       /* parsing channels, n_channels */
-       memset(ch, 0,
-              sizeof(struct rtw_ieee80211_channel) * RTW_CHANNEL_SCAN_AMOUNT);
-
-       if (request->n_channels == 1) {
-               for (i = 0; i < request->n_channels &&
-                    i < RTW_CHANNEL_SCAN_AMOUNT; i++) {
-                       DBG_8723A("%s:(%s):" CHAN_FMT "\n",
-                                 __func__, padapter->pnetdev->name,
-                                 CHAN_ARG(request->channels[i]));
-                       ch[i].hw_value = request->channels[i]->hw_value;
-                       ch[i].flags = request->channels[i]->flags;
-               }
-       }
-
-       spin_lock_bh(&pmlmepriv->lock);
-       if (request->n_channels == 1) {
-               memcpy(&ch[1], &ch[0], sizeof(struct rtw_ieee80211_channel));
-               memcpy(&ch[2], &ch[0], sizeof(struct rtw_ieee80211_channel));
-               _status = rtw_sitesurvey_cmd23a(padapter, ssid,
-                                            RTW_SSID_SCAN_AMOUNT, ch, 3);
-       } else {
-               _status = rtw_sitesurvey_cmd23a(padapter, ssid,
-                                            RTW_SSID_SCAN_AMOUNT, NULL, 0);
-       }
-       spin_unlock_bh(&pmlmepriv->lock);
-
-       if (_status == false)
-               ret = -1;
-
-check_need_indicate_scan_done:
-       if (need_indicate_scan_done)
-               rtw_cfg80211_surveydone_event_callback(padapter);
-       return ret;
-}
-
-static int cfg80211_rtw_set_wiphy_params(struct wiphy *wiphy, u32 changed)
-{
-       DBG_8723A("%s\n", __func__);
-       return 0;
-}
-
-static int cfg80211_rtw_join_ibss(struct wiphy *wiphy, struct net_device *ndev,
-                                 struct cfg80211_ibss_params *params)
-{
-       DBG_8723A("%s(%s)\n", __func__, ndev->name);
-       return 0;
-}
-
-static int cfg80211_rtw_leave_ibss(struct wiphy *wiphy, struct net_device *ndev)
-{
-       DBG_8723A("%s(%s)\n", __func__, ndev->name);
-       return 0;
-}
-
-static int rtw_cfg80211_set_wpa_version(struct security_priv *psecuritypriv,
-                                       u32 wpa_version)
-{
-       DBG_8723A("%s, wpa_version =%d\n", __func__, wpa_version);
-
-       if (!wpa_version) {
-               psecuritypriv->ndisauthtype = Ndis802_11AuthModeOpen;
-               return 0;
-       }
-
-       if (wpa_version & (NL80211_WPA_VERSION_1 | NL80211_WPA_VERSION_2))
-               psecuritypriv->ndisauthtype = Ndis802_11AuthModeWPAPSK;
-
-/*
-       if (wpa_version & NL80211_WPA_VERSION_2)
-       {
-               psecuritypriv->ndisauthtype = Ndis802_11AuthModeWPA2PSK;
-       }
-*/
-
-       return 0;
-}
-
-static int rtw_cfg80211_set_auth_type(struct security_priv *psecuritypriv,
-                                     enum nl80211_auth_type sme_auth_type)
-{
-       DBG_8723A("%s, nl80211_auth_type =%d\n", __func__, sme_auth_type);
-
-       switch (sme_auth_type) {
-       case NL80211_AUTHTYPE_AUTOMATIC:
-               psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_Auto;
-
-               break;
-       case NL80211_AUTHTYPE_OPEN_SYSTEM:
-               psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_Open;
-
-               if (psecuritypriv->ndisauthtype > Ndis802_11AuthModeWPA)
-                       psecuritypriv->dot11AuthAlgrthm =
-                               dot11AuthAlgrthm_8021X;
-               break;
-       case NL80211_AUTHTYPE_SHARED_KEY:
-               psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_Shared;
-
-               psecuritypriv->ndisencryptstatus = Ndis802_11Encryption1Enabled;
-               break;
-       default:
-               psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_Open;
-               /* return -ENOTSUPP; */
-       }
-
-       return 0;
-}
-
-static int rtw_cfg80211_set_cipher(struct security_priv *psecuritypriv,
-                                  u32 cipher, bool ucast)
-{
-       u32 ndisencryptstatus = Ndis802_11EncryptionDisabled;
-
-       u32 *profile_cipher = ucast ? &psecuritypriv->dot11PrivacyAlgrthm :
-           &psecuritypriv->dot118021XGrpPrivacy;
-
-       DBG_8723A("%s, ucast =%d, cipher = 0x%x\n", __func__, ucast, cipher);
-
-       if (!cipher) {
-               *profile_cipher = 0;
-               psecuritypriv->ndisencryptstatus = ndisencryptstatus;
-               return 0;
-       }
-
-       switch (cipher) {
-       case IW_AUTH_CIPHER_NONE:
-               *profile_cipher = 0;
-               ndisencryptstatus = Ndis802_11EncryptionDisabled;
-               break;
-       case WLAN_CIPHER_SUITE_WEP40:
-               *profile_cipher = WLAN_CIPHER_SUITE_WEP40;
-               ndisencryptstatus = Ndis802_11Encryption1Enabled;
-               break;
-       case WLAN_CIPHER_SUITE_WEP104:
-               *profile_cipher = WLAN_CIPHER_SUITE_WEP104;
-               ndisencryptstatus = Ndis802_11Encryption1Enabled;
-               break;
-       case WLAN_CIPHER_SUITE_TKIP:
-               *profile_cipher = WLAN_CIPHER_SUITE_TKIP;
-               ndisencryptstatus = Ndis802_11Encryption2Enabled;
-               break;
-       case WLAN_CIPHER_SUITE_CCMP:
-               *profile_cipher = WLAN_CIPHER_SUITE_CCMP;
-               ndisencryptstatus = Ndis802_11Encryption3Enabled;
-               break;
-       default:
-               DBG_8723A("Unsupported cipher: 0x%x\n", cipher);
-               return -ENOTSUPP;
-       }
-
-       if (ucast)
-               psecuritypriv->ndisencryptstatus = ndisencryptstatus;
-
-       return 0;
-}
-
-static int rtw_cfg80211_set_key_mgt(struct security_priv *psecuritypriv,
-                                   u32 key_mgt)
-{
-       DBG_8723A("%s, key_mgt = 0x%x\n", __func__, key_mgt);
-
-       if (key_mgt == WLAN_AKM_SUITE_8021X)
-               psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_8021X;
-       else if (key_mgt == WLAN_AKM_SUITE_PSK)
-               psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_8021X;
-       else
-               DBG_8723A("Invalid key mgt: 0x%x\n", key_mgt);
-
-       return 0;
-}
-
-static int rtw_cfg80211_set_wpa_ie(struct rtw_adapter *padapter, const u8 *pie,
-                                  size_t ielen)
-{
-       const u8 *wps_ie;
-       int group_cipher = 0, pairwise_cipher = 0;
-       int ret = 0;
-       const u8 *pwpa, *pwpa2;
-       int i;
-
-       if (!pie || !ielen) {
-               /* Treat this as normal case, but need to clear
-                  WIFI_UNDER_WPS */
-               _clr_fwstate_(&padapter->mlmepriv, WIFI_UNDER_WPS);
-               goto exit;
-       }
-       if (ielen > MAX_WPA_IE_LEN + MAX_WPS_IE_LEN + MAX_P2P_IE_LEN) {
-               ret = -EINVAL;
-               goto exit;
-       }
-
-       /* dump */
-       DBG_8723A("set wpa_ie(length:%zu):\n", ielen);
-       for (i = 0; i < ielen; i = i + 8)
-               DBG_8723A("0x%.2x 0x%.2x 0x%.2x 0x%.2x "
-                         "0x%.2x 0x%.2x 0x%.2x 0x%.2x\n",
-                         pie[i], pie[i + 1], pie[i + 2], pie[i + 3],
-                         pie[i + 4], pie[i + 5], pie[i + 6], pie[i + 7]);
-       if (ielen < RSN_HEADER_LEN) {
-               RT_TRACE(_module_rtl871x_ioctl_os_c, _drv_err_,
-                        "Ie len too short %d\n", (int)ielen);
-               ret = -1;
-               goto exit;
-       }
-
-       pwpa = cfg80211_find_vendor_ie(WLAN_OUI_MICROSOFT,
-                                      WLAN_OUI_TYPE_MICROSOFT_WPA,
-                                      pie, ielen);
-       if (pwpa && pwpa[1] > 0) {
-               if (rtw_parse_wpa_ie23a(pwpa, pwpa[1] + 2, &group_cipher,
-                                       &pairwise_cipher, NULL) == _SUCCESS) {
-                       padapter->securitypriv.dot11AuthAlgrthm =
-                               dot11AuthAlgrthm_8021X;
-                       padapter->securitypriv.ndisauthtype =
-                               Ndis802_11AuthModeWPAPSK;
-                       memcpy(padapter->securitypriv.supplicant_ie, pwpa,
-                              pwpa[1] + 2);
-
-                       DBG_8723A("got wpa_ie, wpa_ielen:%u\n", pwpa[1]);
-               }
-       }
-
-       pwpa2 = cfg80211_find_ie(WLAN_EID_RSN, pie, ielen);
-       if (pwpa2 && pwpa2[1] > 0) {
-               if (rtw_parse_wpa2_ie23a (pwpa2, pwpa2[1] + 2, &group_cipher,
-                                         &pairwise_cipher, NULL) == _SUCCESS) {
-                       padapter->securitypriv.dot11AuthAlgrthm =
-                               dot11AuthAlgrthm_8021X;
-                       padapter->securitypriv.ndisauthtype =
-                               Ndis802_11AuthModeWPA2PSK;
-                       memcpy(padapter->securitypriv.supplicant_ie, pwpa2,
-                              pwpa2[1] + 2);
-
-                       DBG_8723A("got wpa2_ie, wpa2_ielen:%u\n", pwpa2[1]);
-               }
-       }
-
-       if (group_cipher == 0) {
-               group_cipher = WPA_CIPHER_NONE;
-       }
-       if (pairwise_cipher == 0) {
-               pairwise_cipher = WPA_CIPHER_NONE;
-       }
-
-       switch (group_cipher) {
-       case WPA_CIPHER_NONE:
-               padapter->securitypriv.dot118021XGrpPrivacy = 0;
-               padapter->securitypriv.ndisencryptstatus =
-                       Ndis802_11EncryptionDisabled;
-               break;
-       case WPA_CIPHER_WEP40:
-               padapter->securitypriv.dot118021XGrpPrivacy = WLAN_CIPHER_SUITE_WEP40;
-               padapter->securitypriv.ndisencryptstatus =
-                       Ndis802_11Encryption1Enabled;
-               break;
-       case WPA_CIPHER_TKIP:
-               padapter->securitypriv.dot118021XGrpPrivacy = WLAN_CIPHER_SUITE_TKIP;
-               padapter->securitypriv.ndisencryptstatus =
-                       Ndis802_11Encryption2Enabled;
-               break;
-       case WPA_CIPHER_CCMP:
-               padapter->securitypriv.dot118021XGrpPrivacy = WLAN_CIPHER_SUITE_CCMP;
-               padapter->securitypriv.ndisencryptstatus =
-                       Ndis802_11Encryption3Enabled;
-               break;
-       case WPA_CIPHER_WEP104:
-               padapter->securitypriv.dot118021XGrpPrivacy = WLAN_CIPHER_SUITE_WEP104;
-               padapter->securitypriv.ndisencryptstatus =
-                       Ndis802_11Encryption1Enabled;
-               break;
-       }
-
-       switch (pairwise_cipher) {
-       case WPA_CIPHER_NONE:
-               padapter->securitypriv.dot11PrivacyAlgrthm = 0;
-               padapter->securitypriv.ndisencryptstatus =
-                       Ndis802_11EncryptionDisabled;
-               break;
-       case WPA_CIPHER_WEP40:
-               padapter->securitypriv.dot11PrivacyAlgrthm = WLAN_CIPHER_SUITE_WEP40;
-               padapter->securitypriv.ndisencryptstatus =
-                       Ndis802_11Encryption1Enabled;
-               break;
-       case WPA_CIPHER_TKIP:
-               padapter->securitypriv.dot11PrivacyAlgrthm = WLAN_CIPHER_SUITE_TKIP;
-               padapter->securitypriv.ndisencryptstatus =
-                       Ndis802_11Encryption2Enabled;
-               break;
-       case WPA_CIPHER_CCMP:
-               padapter->securitypriv.dot11PrivacyAlgrthm = WLAN_CIPHER_SUITE_CCMP;
-               padapter->securitypriv.ndisencryptstatus =
-                       Ndis802_11Encryption3Enabled;
-               break;
-       case WPA_CIPHER_WEP104:
-               padapter->securitypriv.dot11PrivacyAlgrthm = WLAN_CIPHER_SUITE_WEP104;
-               padapter->securitypriv.ndisencryptstatus =
-                       Ndis802_11Encryption1Enabled;
-               break;
-       }
-
-       wps_ie = cfg80211_find_vendor_ie(WLAN_OUI_MICROSOFT,
-                                        WLAN_OUI_TYPE_MICROSOFT_WPS,
-                                        pie, ielen);
-       if (wps_ie && wps_ie[1] > 0) {
-               DBG_8723A("got wps_ie, wps_ielen:%u\n", wps_ie[1]);
-               padapter->securitypriv.wps_ie_len = wps_ie[1];
-               memcpy(padapter->securitypriv.wps_ie, wps_ie,
-                      padapter->securitypriv.wps_ie_len);
-               set_fwstate(&padapter->mlmepriv, WIFI_UNDER_WPS);
-       } else {
-               _clr_fwstate_(&padapter->mlmepriv, WIFI_UNDER_WPS);
-       }
-
-       /* TKIP and AES disallow multicast packets until installing group key */
-       if (padapter->securitypriv.dot11PrivacyAlgrthm ==
-           WLAN_CIPHER_SUITE_TKIP ||
-           padapter->securitypriv.dot11PrivacyAlgrthm ==
-           WLAN_CIPHER_SUITE_CCMP)
-               /* WPS open need to enable multicast */
-               /* check_fwstate(&padapter->mlmepriv, WIFI_UNDER_WPS) == true)*/
-               rtl8723a_off_rcr_am(padapter);
-
-       RT_TRACE(_module_rtl871x_ioctl_os_c, _drv_info_,
-                "rtw_set_wpa_ie: pairwise_cipher = 0x%08x padapter->securitypriv.ndisencryptstatus =%d padapter->securitypriv.ndisauthtype =%d\n",
-                pairwise_cipher,
-                padapter->securitypriv.ndisencryptstatus,
-                padapter->securitypriv.ndisauthtype);
-
-exit:
-       if (ret)
-               _clr_fwstate_(&padapter->mlmepriv, WIFI_UNDER_WPS);
-       return ret;
-}
-
-static int rtw_cfg80211_add_wep(struct rtw_adapter *padapter,
-                               struct rtw_wep_key *wep, u8 keyid)
-{
-       int res;
-       struct security_priv *psecuritypriv = &padapter->securitypriv;
-
-       if (keyid >= NUM_WEP_KEYS) {
-               RT_TRACE(_module_rtl871x_ioctl_set_c_, _drv_err_,
-                        "%s:keyid>4 =>fail\n", __func__);
-               res = _FAIL;
-               goto exit;
-       }
-
-       switch (wep->keylen) {
-       case WLAN_KEY_LEN_WEP40:
-               psecuritypriv->dot11PrivacyAlgrthm = WLAN_CIPHER_SUITE_WEP40;
-               RT_TRACE(_module_rtl871x_ioctl_set_c_, _drv_info_,
-                        "%s:wep->KeyLength = 5\n", __func__);
-               break;
-       case WLAN_KEY_LEN_WEP104:
-               psecuritypriv->dot11PrivacyAlgrthm = WLAN_CIPHER_SUITE_WEP104;
-               RT_TRACE(_module_rtl871x_ioctl_set_c_, _drv_info_,
-                        "%s:wep->KeyLength = 13\n", __func__);
-               break;
-       default:
-               psecuritypriv->dot11PrivacyAlgrthm = 0;
-               RT_TRACE(_module_rtl871x_ioctl_set_c_, _drv_info_,
-                        "%s:wep->KeyLength!= 5 or 13\n", __func__);
-               res = _FAIL;
-               goto exit;
-       }
-
-       RT_TRACE(_module_rtl871x_ioctl_set_c_, _drv_info_,
-                "%s:before memcpy, wep->KeyLength = 0x%x keyid =%x\n",
-                __func__, wep->keylen, keyid);
-
-       memcpy(&psecuritypriv->wep_key[keyid], wep, sizeof(struct rtw_wep_key));
-
-       psecuritypriv->dot11PrivacyKeyIndex = keyid;
-
-       RT_TRACE(_module_rtl871x_ioctl_set_c_, _drv_info_,
-                "%s:security key material : %x %x %x %x %x %x %x %x %x %x %x %x %x\n",
-                __func__,
-                psecuritypriv->wep_key[keyid].key[0],
-                psecuritypriv->wep_key[keyid].key[1],
-                psecuritypriv->wep_key[keyid].key[2],
-                psecuritypriv->wep_key[keyid].key[3],
-                psecuritypriv->wep_key[keyid].key[4],
-                psecuritypriv->wep_key[keyid].key[5],
-                psecuritypriv->wep_key[keyid].key[6],
-                psecuritypriv->wep_key[keyid].key[7],
-                psecuritypriv->wep_key[keyid].key[8],
-                psecuritypriv->wep_key[keyid].key[9],
-                psecuritypriv->wep_key[keyid].key[10],
-                psecuritypriv->wep_key[keyid].key[11],
-                psecuritypriv->wep_key[keyid].key[12]);
-
-       res = rtw_set_key23a(padapter, psecuritypriv, keyid, 1);
-
-exit:
-
-       return res;
-}
-
-static int rtw_set_ssid(struct rtw_adapter *padapter,
-                       struct wlan_network *newnetwork)
-{
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct wlan_network *pnetwork = &pmlmepriv->cur_network;
-       int status = _SUCCESS;
-       u32 cur_time = 0;
-
-       DBG_8723A_LEVEL(_drv_always_, "set ssid [%s] fw_state = 0x%08x\n",
-                       newnetwork->network.Ssid.ssid, get_fwstate(pmlmepriv));
-
-       if (padapter->hw_init_completed == false) {
-               RT_TRACE(_module_rtl871x_ioctl_set_c_, _drv_err_,
-                        "set_ssid: hw_init_completed == false =>exit!!!\n");
-               status = _FAIL;
-               goto exit;
-       }
-
-       spin_lock_bh(&pmlmepriv->lock);
-
-       DBG_8723A("Set SSID under fw_state = 0x%08x\n", get_fwstate(pmlmepriv));
-       if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY))
-               goto handle_tkip_countermeasure;
-
-       if (check_fwstate(pmlmepriv, _FW_LINKED|WIFI_ADHOC_MASTER_STATE)) {
-               RT_TRACE(_module_rtl871x_ioctl_set_c_, _drv_info_,
-                        "set_ssid: _FW_LINKED||WIFI_ADHOC_MASTER_STATE\n");
-
-               if (pmlmepriv->assoc_ssid.ssid_len ==
-                   newnetwork->network.Ssid.ssid_len &&
-                   !memcmp(&pmlmepriv->assoc_ssid.ssid,
-                           newnetwork->network.Ssid.ssid,
-                           newnetwork->network.Ssid.ssid_len)) {
-                       if (!check_fwstate(pmlmepriv, WIFI_STATION_STATE)) {
-                               RT_TRACE(_module_rtl871x_ioctl_set_c_,
-                                        _drv_err_,
-                                        "New SSID is same SSID, fw_state = 0x%08x\n",
-                                        get_fwstate(pmlmepriv));
-
-                               if (rtw_is_same_ibss23a(padapter, pnetwork)) {
-                                       /*
-                                        * it means driver is in
-                                        * WIFI_ADHOC_MASTER_STATE, we needn't
-                                        * create bss again.
-                                        */
-                                       goto release_mlme_lock;
-                               }
-
-                               /*
-                                * if in WIFI_ADHOC_MASTER_STATE |
-                                * WIFI_ADHOC_STATE, create bss or
-                                * rejoin again
-                                */
-                               rtw_disassoc_cmd23a(padapter, 0, true);
-
-                               if (check_fwstate(pmlmepriv, _FW_LINKED))
-                                       rtw_indicate_disconnect23a(padapter);
-
-                               rtw_free_assoc_resources23a(padapter, 1);
-
-                               if (check_fwstate(pmlmepriv,
-                                                 WIFI_ADHOC_MASTER_STATE)) {
-                                       _clr_fwstate_(pmlmepriv,
-                                                     WIFI_ADHOC_MASTER_STATE);
-                                       set_fwstate(pmlmepriv,
-                                                   WIFI_ADHOC_STATE);
-                               }
-                       } else {
-                               rtw_lps_ctrl_wk_cmd23a(padapter,
-                                                      LPS_CTRL_JOINBSS, 1);
-                       }
-               } else {
-                       RT_TRACE(_module_rtl871x_ioctl_set_c_, _drv_info_,
-                                "Set SSID not the same ssid\n");
-                       RT_TRACE(_module_rtl871x_ioctl_set_c_, _drv_info_,
-                                "set_ssid =[%s] len = 0x%x\n",
-                                newnetwork->network.Ssid.ssid,
-                                newnetwork->network.Ssid.ssid_len);
-                       RT_TRACE(_module_rtl871x_ioctl_set_c_, _drv_info_,
-                                "assoc_ssid =[%s] len = 0x%x\n",
-                                pmlmepriv->assoc_ssid.ssid,
-                                pmlmepriv->assoc_ssid.ssid_len);
-
-                       rtw_disassoc_cmd23a(padapter, 0, true);
-
-                       if (check_fwstate(pmlmepriv, _FW_LINKED))
-                               rtw_indicate_disconnect23a(padapter);
-
-                       rtw_free_assoc_resources23a(padapter, 1);
-
-                       if (check_fwstate(pmlmepriv, WIFI_ADHOC_MASTER_STATE)) {
-                               _clr_fwstate_(pmlmepriv, WIFI_ADHOC_MASTER_STATE);
-                               set_fwstate(pmlmepriv, WIFI_ADHOC_STATE);
-                       }
-               }
-       }
-
-handle_tkip_countermeasure:
-
-       if (padapter->securitypriv.btkip_countermeasure == true) {
-               cur_time = jiffies;
-
-               if ((cur_time -
-                    padapter->securitypriv.btkip_countermeasure_time) >
-                   60 * HZ) {
-                       padapter->securitypriv.btkip_countermeasure = false;
-                       padapter->securitypriv.btkip_countermeasure_time = 0;
-               } else {
-                       status = _FAIL;
-                       goto release_mlme_lock;
-               }
-       }
-
-       memcpy(&pmlmepriv->assoc_ssid, &newnetwork->network.Ssid,
-              sizeof(struct cfg80211_ssid));
-
-       pmlmepriv->assoc_by_bssid = false;
-
-       pmlmepriv->to_join = true;
-
-       if (!check_fwstate(pmlmepriv, _FW_UNDER_SURVEY)) {
-               pmlmepriv->cur_network.join_res = -2;
-
-               status = rtw_do_join_network(padapter, newnetwork);
-               if (status == _SUCCESS) {
-                       pmlmepriv->to_join = false;
-               } else {
-                       if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE)) {
-                               /* switch to ADHOC_MASTER */
-                               status = rtw_do_join_adhoc(padapter);
-                               if (status != _SUCCESS)
-                                       goto release_mlme_lock;
-                       } else {
-                               /* can't associate ; reset under-linking */
-                               _clr_fwstate_(pmlmepriv, _FW_UNDER_LINKING);
-                               status = _FAIL;
-                               pmlmepriv->to_join = false;
-                       }
-               }
-       }
-release_mlme_lock:
-       spin_unlock_bh(&pmlmepriv->lock);
-
-exit:
-       RT_TRACE(_module_rtl871x_ioctl_set_c_, _drv_err_,
-                "-%s: status =%d\n", __func__, status);
-
-       return status;
-}
-
-static int cfg80211_rtw_connect(struct wiphy *wiphy, struct net_device *ndev,
-                               struct cfg80211_connect_params *sme)
-{
-       int ret = 0;
-       struct list_head *phead, *plist, *ptmp;
-       struct wlan_network *pnetwork = NULL;
-       /* u8 matched_by_bssid = false; */
-       /* u8 matched_by_ssid = false; */
-       u8 matched = false;
-       struct rtw_adapter *padapter = wiphy_to_adapter(wiphy);
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct security_priv *psecuritypriv = &padapter->securitypriv;
-       struct rtw_queue *queue = &pmlmepriv->scanned_queue;
-
-       DBG_8723A("=>" "%s(%s)\n", __func__, ndev->name);
-       DBG_8723A("privacy =%d, key =%p, key_len =%d, key_idx =%d\n",
-                 sme->privacy, sme->key, sme->key_len, sme->key_idx);
-
-       if (_FAIL == rtw_pwr_wakeup(padapter)) {
-               ret = -EPERM;
-               goto exit;
-       }
-
-       if (check_fwstate(pmlmepriv, WIFI_AP_STATE)) {
-               ret = -EPERM;
-               goto exit;
-       }
-
-       if (!sme->ssid || !sme->ssid_len ||
-           sme->ssid_len > IEEE80211_MAX_SSID_LEN) {
-               ret = -EINVAL;
-               goto exit;
-       }
-
-       DBG_8723A("ssid =%s, len =%zu\n", sme->ssid, sme->ssid_len);
-
-       if (sme->bssid)
-               DBG_8723A("bssid=%pM\n", sme->bssid);
-
-       if (check_fwstate(pmlmepriv, _FW_UNDER_LINKING)) {
-               ret = -EBUSY;
-               DBG_8723A("%s, fw_state = 0x%x, goto exit\n", __func__,
-                         pmlmepriv->fw_state);
-               goto exit;
-       }
-       if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY)) {
-               rtw_scan_abort23a(padapter);
-       }
-
-       spin_lock_bh(&queue->lock);
-
-       phead = get_list_head(queue);
-
-       list_for_each_safe(plist, ptmp, phead) {
-               pnetwork = container_of(plist, struct wlan_network, list);
-
-               if (sme->bssid) {
-                       if (!ether_addr_equal(pnetwork->network.MacAddress,
-                                             sme->bssid))
-                               continue;
-               }
-
-               if (sme->ssid && sme->ssid_len) {
-                       if (pnetwork->network.Ssid.ssid_len != sme->ssid_len ||
-                           memcmp(pnetwork->network.Ssid.ssid, sme->ssid,
-                                  sme->ssid_len))
-                               continue;
-               }
-
-               if (sme->bssid) {
-                       if (ether_addr_equal(pnetwork->network.MacAddress,
-                                            sme->bssid)) {
-                               DBG_8723A("matched by bssid\n");
-
-                               matched = true;
-                               break;
-                       }
-               } else if (sme->ssid && sme->ssid_len) {
-                       if (!memcmp(pnetwork->network.Ssid.ssid,
-                                   sme->ssid, sme->ssid_len) &&
-                           pnetwork->network.Ssid.ssid_len == sme->ssid_len) {
-                               DBG_8723A("matched by ssid\n");
-
-                               matched = true;
-                               break;
-                       }
-               }
-       }
-
-       spin_unlock_bh(&queue->lock);
-
-       if (!matched || !pnetwork) {
-               ret = -ENOENT;
-               DBG_8723A("connect, matched == false, goto exit\n");
-               goto exit;
-       }
-
-       if (cfg80211_infrastructure_mode(
-                   padapter, pnetwork->network.ifmode) != _SUCCESS) {
-               ret = -EPERM;
-               goto exit;
-       }
-
-       psecuritypriv->ndisencryptstatus = Ndis802_11EncryptionDisabled;
-       psecuritypriv->dot11PrivacyAlgrthm = 0;
-       psecuritypriv->dot118021XGrpPrivacy = 0;
-       psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_Open;
-       psecuritypriv->ndisauthtype = Ndis802_11AuthModeOpen;
-
-       ret = rtw_cfg80211_set_wpa_version(psecuritypriv,
-                                          sme->crypto.wpa_versions);
-       if (ret < 0)
-               goto exit;
-
-       ret = rtw_cfg80211_set_auth_type(psecuritypriv, sme->auth_type);
-
-       if (ret < 0)
-               goto exit;
-
-       DBG_8723A("%s, ie_len =%zu\n", __func__, sme->ie_len);
-
-       ret = rtw_cfg80211_set_wpa_ie(padapter, sme->ie, sme->ie_len);
-       if (ret < 0)
-               goto exit;
-
-       if (sme->crypto.n_ciphers_pairwise) {
-               ret = rtw_cfg80211_set_cipher(psecuritypriv,
-                                             sme->crypto.ciphers_pairwise[0],
-                                             true);
-               if (ret < 0)
-                       goto exit;
-       }
-
-       /* For WEP Shared auth */
-       if ((psecuritypriv->dot11AuthAlgrthm == dot11AuthAlgrthm_Shared ||
-            psecuritypriv->dot11AuthAlgrthm == dot11AuthAlgrthm_Auto) &&
-           sme->key) {
-               struct rtw_wep_key wep_key;
-               u8 wep_key_idx, wep_key_len;
-               DBG_8723A("%s(): Shared/Auto WEP\n", __func__);
-
-               wep_key_idx = sme->key_idx;
-               wep_key_len = sme->key_len;
-
-               if (wep_key_idx > WEP_KEYS || !wep_key_len ||
-                   wep_key_len > WLAN_KEY_LEN_WEP104) {
-                       ret = -EINVAL;
-                       goto exit;
-               }
-
-               wep_key_len = wep_key_len <= 5 ? 5 : 13;
-
-               memset(&wep_key, 0, sizeof(struct rtw_wep_key));
-
-               wep_key.keylen = wep_key_len;
-
-               if (wep_key_len == 13) {
-                       padapter->securitypriv.dot11PrivacyAlgrthm =
-                               WLAN_CIPHER_SUITE_WEP104;
-                       padapter->securitypriv.dot118021XGrpPrivacy =
-                               WLAN_CIPHER_SUITE_WEP104;
-               } else {
-                       padapter->securitypriv.dot11PrivacyAlgrthm =
-                               WLAN_CIPHER_SUITE_WEP40;
-                       padapter->securitypriv.dot118021XGrpPrivacy =
-                               WLAN_CIPHER_SUITE_WEP40;
-               }
-
-               memcpy(wep_key.key, (void *)sme->key, wep_key.keylen);
-
-               if (rtw_cfg80211_add_wep(padapter, &wep_key, wep_key_idx) !=
-                   _SUCCESS)
-                       ret = -EOPNOTSUPP;
-
-               if (ret < 0)
-                       goto exit;
-       }
-
-       ret = rtw_cfg80211_set_cipher(psecuritypriv,
-                                     sme->crypto.cipher_group, false);
-       if (ret < 0)
-               goto exit;
-
-       if (sme->crypto.n_akm_suites) {
-               ret = rtw_cfg80211_set_key_mgt(psecuritypriv,
-                                              sme->crypto.akm_suites[0]);
-               if (ret < 0)
-                       goto exit;
-       }
-
-       if (psecuritypriv->ndisauthtype > 3)
-               psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_8021X;
-
-       if (rtw_set_auth23a(padapter, psecuritypriv) != _SUCCESS) {
-               ret = -EBUSY;
-               goto exit;
-       }
-
-       /* rtw_set_802_11_encryption_mode(padapter,
-          padapter->securitypriv.ndisencryptstatus); */
-
-       if (rtw_set_ssid(padapter, pnetwork) != _SUCCESS) {
-               ret = -EBUSY;
-               goto exit;
-       }
-
-       DBG_8723A("set ssid:dot11AuthAlgrthm =%d, dot11PrivacyAlgrthm =%d, "
-                 "dot118021XGrpPrivacy =%d\n", psecuritypriv->dot11AuthAlgrthm,
-                 psecuritypriv->dot11PrivacyAlgrthm,
-                 psecuritypriv->dot118021XGrpPrivacy);
-
-exit:
-
-       DBG_8723A("<=%s, ret %d\n", __func__, ret);
-
-       return ret;
-}
-
-static int cfg80211_rtw_disconnect(struct wiphy *wiphy, struct net_device *ndev,
-                                  u16 reason_code)
-{
-       struct rtw_adapter *padapter = wiphy_to_adapter(wiphy);
-
-       DBG_8723A("%s(%s)\n", __func__, ndev->name);
-
-       rtw_set_roaming(padapter, 0);
-
-       if (check_fwstate(&padapter->mlmepriv, _FW_LINKED)) {
-               rtw_scan_abort23a(padapter);
-               LeaveAllPowerSaveMode23a(padapter);
-               rtw_disassoc_cmd23a(padapter, 500, false);
-
-               DBG_8723A("%s...call rtw_indicate_disconnect23a\n", __func__);
-
-               padapter->mlmepriv.not_indic_disco = true;
-               rtw_indicate_disconnect23a(padapter);
-               padapter->mlmepriv.not_indic_disco = false;
-
-               rtw_free_assoc_resources23a(padapter, 1);
-       }
-
-       return 0;
-}
-
-static int cfg80211_rtw_set_txpower(struct wiphy *wiphy,
-                                   struct wireless_dev *wdev,
-                                   enum nl80211_tx_power_setting type, int mbm)
-{
-       DBG_8723A("%s\n", __func__);
-       return 0;
-}
-
-static int cfg80211_rtw_get_txpower(struct wiphy *wiphy,
-                                   struct wireless_dev *wdev, int *dbm)
-{
-       DBG_8723A("%s\n", __func__);
-       *dbm = 12;
-       return 0;
-}
-
-inline bool rtw_cfg80211_pwr_mgmt(struct rtw_adapter *adapter)
-{
-       struct rtw_wdev_priv *rtw_wdev_priv = wdev_to_priv(adapter->rtw_wdev);
-       return rtw_wdev_priv->power_mgmt;
-}
-
-static int cfg80211_rtw_set_power_mgmt(struct wiphy *wiphy,
-                                      struct net_device *ndev,
-                                      bool enabled, int timeout)
-{
-       struct rtw_adapter *padapter = wiphy_to_adapter(wiphy);
-       struct rtw_wdev_priv *rtw_wdev_priv = wdev_to_priv(padapter->rtw_wdev);
-
-       DBG_8723A("%s(%s): enabled:%u, timeout:%d\n",
-                 __func__, ndev->name, enabled, timeout);
-
-       rtw_wdev_priv->power_mgmt = enabled;
-
-       if (!enabled)
-               LPS_Leave23a(padapter);
-
-       return 0;
-}
-
-static int cfg80211_rtw_set_pmksa(struct wiphy *wiphy,
-                                 struct net_device *netdev,
-                                 struct cfg80211_pmksa *pmksa)
-{
-       u8 index, blInserted = false;
-       struct rtw_adapter *padapter = wiphy_to_adapter(wiphy);
-       struct security_priv *psecuritypriv = &padapter->securitypriv;
-
-       DBG_8723A("%s(%s)\n", __func__, netdev->name);
-
-       if (is_zero_ether_addr(pmksa->bssid))
-               return -EINVAL;
-
-       blInserted = false;
-
-       /* overwrite PMKID */
-       for (index = 0; index < NUM_PMKID_CACHE; index++) {
-               if (ether_addr_equal(psecuritypriv->PMKIDList[index].Bssid,
-                                    pmksa->bssid)) {
-                       /* BSSID is matched, the same AP => rewrite with
-                          new PMKID. */
-                       DBG_8723A("%s(%s):  BSSID exists in the PMKList.\n",
-                                 __func__, netdev->name);
-
-                       memcpy(psecuritypriv->PMKIDList[index].PMKID,
-                              pmksa->pmkid, WLAN_PMKID_LEN);
-                       psecuritypriv->PMKIDList[index].bUsed = true;
-                       psecuritypriv->PMKIDIndex = index + 1;
-                       blInserted = true;
-                       break;
-               }
-       }
-
-       if (!blInserted) {
-               /*  Find a new entry */
-               DBG_8723A("%s(%s): Use new entry index = %d for this PMKID\n",
-                         __func__, netdev->name, psecuritypriv->PMKIDIndex);
-
-               ether_addr_copy(
-                       psecuritypriv->PMKIDList[psecuritypriv->PMKIDIndex].
-                       Bssid, pmksa->bssid);
-               memcpy(psecuritypriv->PMKIDList[psecuritypriv->PMKIDIndex].
-                      PMKID, pmksa->pmkid, WLAN_PMKID_LEN);
-
-               psecuritypriv->PMKIDList[psecuritypriv->PMKIDIndex].bUsed =
-                       true;
-               psecuritypriv->PMKIDIndex++;
-               if (psecuritypriv->PMKIDIndex == 16) {
-                       psecuritypriv->PMKIDIndex = 0;
-               }
-       }
-
-       return 0;
-}
-
-static int cfg80211_rtw_del_pmksa(struct wiphy *wiphy,
-                                 struct net_device *netdev,
-                                 struct cfg80211_pmksa *pmksa)
-{
-       u8 index, bMatched = false;
-       struct rtw_adapter *padapter = wiphy_to_adapter(wiphy);
-       struct security_priv *psecuritypriv = &padapter->securitypriv;
-
-       DBG_8723A("%s(%s)\n", __func__, netdev->name);
-
-       for (index = 0; index < NUM_PMKID_CACHE; index++) {
-               if (ether_addr_equal(psecuritypriv->PMKIDList[index].Bssid,
-                                    pmksa->bssid)) {
-                       /* BSSID is matched, the same AP => Remove this PMKID
-                          information and reset it. */
-                       eth_zero_addr(psecuritypriv->PMKIDList[index].Bssid);
-                       memset(psecuritypriv->PMKIDList[index].PMKID, 0x00,
-                              WLAN_PMKID_LEN);
-                       psecuritypriv->PMKIDList[index].bUsed = false;
-                       bMatched = true;
-                       break;
-               }
-       }
-
-       if (false == bMatched) {
-               DBG_8723A("%s(%s): do not have matched BSSID\n", __func__,
-                         netdev->name);
-               return -EINVAL;
-       }
-
-       return 0;
-}
-
-static int cfg80211_rtw_flush_pmksa(struct wiphy *wiphy,
-                                   struct net_device *netdev)
-{
-       struct rtw_adapter *padapter = wiphy_to_adapter(wiphy);
-       struct security_priv *psecuritypriv = &padapter->securitypriv;
-
-       DBG_8723A("%s(%s)\n", __func__, netdev->name);
-
-       memset(&psecuritypriv->PMKIDList[0], 0x00,
-              sizeof(struct rt_pmkid_list) * NUM_PMKID_CACHE);
-       psecuritypriv->PMKIDIndex = 0;
-
-       return 0;
-}
-
-#ifdef CONFIG_8723AU_AP_MODE
-void rtw_cfg80211_indicate_sta_assoc(struct rtw_adapter *padapter,
-                                    u8 *pmgmt_frame, uint frame_len)
-{
-       s32 freq;
-       int channel;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct net_device *ndev = padapter->pnetdev;
-
-       DBG_8723A("%s(padapter =%p,%s)\n", __func__, padapter, ndev->name);
-
-#if defined(RTW_USE_CFG80211_STA_EVENT)
-       {
-               struct station_info sinfo;
-               u8 ie_offset;
-
-               if (ieee80211_is_assoc_req(hdr->frame_control))
-                       ie_offset = offsetof(struct ieee80211_mgmt,
-                                            u.assoc_req.variable);
-               else            /*  WIFI_REASSOCREQ */
-                       ie_offset = offsetof(struct ieee80211_mgmt,
-                                            u.reassoc_req.variable);
-
-               sinfo.filled = 0;
-               sinfo.assoc_req_ies = pmgmt_frame + ie_offset;
-               sinfo.assoc_req_ies_len = frame_len - ie_offset;
-               cfg80211_new_sta(ndev, hdr->addr2, &sinfo, GFP_ATOMIC);
-       }
-#else /* defined(RTW_USE_CFG80211_STA_EVENT) */
-       channel = pmlmeext->cur_channel;
-       if (channel <= RTW_CH_MAX_2G_CHANNEL)
-               freq = ieee80211_channel_to_frequency(channel,
-                                                     NL80211_BAND_2GHZ);
-       else
-               freq = ieee80211_channel_to_frequency(channel,
-                                                     NL80211_BAND_5GHZ);
-
-       cfg80211_rx_mgmt(padapter->rtw_wdev, freq, 0, pmgmt_frame, frame_len,
-                        0);
-#endif /* defined(RTW_USE_CFG80211_STA_EVENT) */
-}
-
-void rtw_cfg80211_indicate_sta_disassoc(struct rtw_adapter *padapter,
-                                       unsigned char *da,
-                                       unsigned short reason)
-{
-       s32 freq;
-       int channel;
-       uint frame_len;
-       struct ieee80211_mgmt mgmt;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-       struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
-       struct net_device *ndev = padapter->pnetdev;
-
-       DBG_8723A("%s(padapter =%p,%s)\n", __func__, padapter, ndev->name);
-
-       memset(&mgmt, 0, sizeof(struct ieee80211_mgmt));
-
-#if defined(RTW_USE_CFG80211_STA_EVENT)
-       cfg80211_del_sta(ndev, da, GFP_ATOMIC);
-#else /* defined(RTW_USE_CFG80211_STA_EVENT) */
-       channel = pmlmeext->cur_channel;
-       if (channel <= RTW_CH_MAX_2G_CHANNEL)
-               freq = ieee80211_channel_to_frequency(channel,
-                                                     NL80211_BAND_2GHZ);
-       else
-               freq = ieee80211_channel_to_frequency(channel,
-                                                     NL80211_BAND_5GHZ);
-
-       mgmt.frame_control =
-               cpu_to_le16(IEEE80211_FTYPE_MGMT | IEEE80211_STYPE_DEAUTH);
-
-       ether_addr_copy(mgmt.da, myid(&padapter->eeprompriv));
-       ether_addr_copy(mgmt.sa, da);
-       ether_addr_copy(mgmt.bssid, get_my_bssid23a(&pmlmeinfo->network));
-
-       mgmt.seq_ctrl = cpu_to_le16(IEEE80211_SN_TO_SEQ(pmlmeext->mgnt_seq));
-       pmlmeext->mgnt_seq++;
-
-       mgmt.u.disassoc.reason_code = cpu_to_le16(reason);
-
-       frame_len = sizeof(struct ieee80211_hdr_3addr) + 2;
-
-       cfg80211_rx_mgmt(padapter->rtw_wdev, freq, 0, (u8 *)&mgmt, frame_len,
-                        0);
-#endif /* defined(RTW_USE_CFG80211_STA_EVENT) */
-}
-
-static int rtw_cfg80211_monitor_if_open(struct net_device *ndev)
-{
-       DBG_8723A("%s\n", __func__);
-
-       return 0;
-}
-
-static int rtw_cfg80211_monitor_if_close(struct net_device *ndev)
-{
-       DBG_8723A("%s\n", __func__);
-
-       return 0;
-}
-
-static int rtw_cfg80211_monitor_if_xmit_entry(struct sk_buff *skb,
-                                             struct net_device *ndev)
-{
-       int ret = 0;
-       int rtap_len;
-       int qos_len = 0;
-       int dot11_hdr_len = 24;
-       int snap_len = 6;
-       unsigned char *pdata;
-       unsigned char src_mac_addr[6];
-       unsigned char dst_mac_addr[6];
-       struct ieee80211_hdr *dot11_hdr;
-       struct ieee80211_radiotap_header *rtap_hdr;
-       struct rtw_adapter *padapter = netdev_priv(ndev);
-
-       DBG_8723A("%s(%s)\n", __func__, ndev->name);
-
-       if (unlikely(skb->len < sizeof(struct ieee80211_radiotap_header)))
-               goto fail;
-
-       rtap_hdr = (struct ieee80211_radiotap_header *)skb->data;
-       if (unlikely(rtap_hdr->it_version))
-               goto fail;
-
-       rtap_len = ieee80211_get_radiotap_len(skb->data);
-       if (unlikely(skb->len < rtap_len))
-               goto fail;
-
-       if (rtap_len != 14) {
-               DBG_8723A("radiotap len (should be 14): %d\n", rtap_len);
-               goto fail;
-       }
-
-       /* Skip the ratio tap header */
-       skb_pull(skb, rtap_len);
-
-       dot11_hdr = (struct ieee80211_hdr *)skb->data;
-       /* Check if the QoS bit is set */
-       if (ieee80211_is_data(dot11_hdr->frame_control)) {
-               /* Check if this ia a Wireless Distribution System (WDS) frame
-                * which has 4 MAC addresses
-                */
-               if (ieee80211_is_data_qos(dot11_hdr->frame_control))
-                       qos_len = IEEE80211_QOS_CTL_LEN;
-               if (ieee80211_has_a4(dot11_hdr->frame_control))
-                       dot11_hdr_len += 6;
-
-               memcpy(dst_mac_addr, dot11_hdr->addr1, sizeof(dst_mac_addr));
-               memcpy(src_mac_addr, dot11_hdr->addr2, sizeof(src_mac_addr));
-
-               /*
-                * Skip the 802.11 header, QoS (if any) and SNAP,
-                * but leave spaces for two MAC addresses
-                */
-               skb_pull(skb, dot11_hdr_len + qos_len + snap_len -
-                        ETH_ALEN * 2);
-               pdata = (unsigned char *)skb->data;
-               ether_addr_copy(pdata, dst_mac_addr);
-               ether_addr_copy(pdata + ETH_ALEN, src_mac_addr);
-
-               DBG_8723A("should be eapol packet\n");
-
-               /* Use the real net device to transmit the packet */
-               ret = rtw_xmit23a_entry23a(skb, padapter->pnetdev);
-
-               return ret;
-
-       } else if (ieee80211_is_action(dot11_hdr->frame_control)) {
-               struct ieee80211_mgmt *mgmt;
-               /* only for action frames */
-               struct xmit_frame *pmgntframe;
-               struct pkt_attrib *pattrib;
-               unsigned char *pframe;
-               /* u8 category, action, OUI_Subtype, dialogToken = 0; */
-               /* unsigned char        *frame_body; */
-               struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-               struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-               u32 len = skb->len;
-               u8 category, action;
-
-               mgmt = (struct ieee80211_mgmt *)dot11_hdr;
-
-               DBG_8723A("RTW_Tx:da=%pM via %s(%s)\n",
-                         mgmt->da, __func__, ndev->name);
-               category = mgmt->u.action.category;
-               action = mgmt->u.action.u.wme_action.action_code;
-               DBG_8723A("RTW_Tx:category(%u), action(%u)\n",
-                         category, action);
-
-               /* starting alloc mgmt frame to dump it */
-               pmgntframe = alloc_mgtxmitframe23a(pxmitpriv);
-               if (pmgntframe == NULL)
-                       goto fail;
-
-               /* update attribute */
-               pattrib = &pmgntframe->attrib;
-               update_mgntframe_attrib23a(padapter, pattrib);
-               pattrib->retry_ctrl = false;
-
-               memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
-
-               pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
-
-               memcpy(pframe, skb->data, len);
-               pattrib->pktlen = len;
-
-               /* update seq number */
-               pmlmeext->mgnt_seq = le16_to_cpu(dot11_hdr->seq_ctrl) >> 4;
-               pattrib->seqnum = pmlmeext->mgnt_seq;
-               pmlmeext->mgnt_seq++;
-
-               pattrib->last_txcmdsz = pattrib->pktlen;
-
-               dump_mgntframe23a(padapter, pmgntframe);
-       }
-
-fail:
-
-       dev_kfree_skb(skb);
-
-       return 0;
-}
-
-static int
-rtw_cfg80211_monitor_if_set_mac_address(struct net_device *ndev, void *addr)
-{
-       DBG_8723A("%s\n", __func__);
-
-       return 0;
-}
-
-static const struct net_device_ops rtw_cfg80211_monitor_if_ops = {
-       .ndo_open = rtw_cfg80211_monitor_if_open,
-       .ndo_stop = rtw_cfg80211_monitor_if_close,
-       .ndo_start_xmit = rtw_cfg80211_monitor_if_xmit_entry,
-       .ndo_set_mac_address = rtw_cfg80211_monitor_if_set_mac_address,
-};
-
-static int rtw_cfg80211_add_monitor_if(struct rtw_adapter *padapter, char *name,
-                                      unsigned char name_assign_type,
-                                      struct net_device **ndev)
-{
-       int ret = 0;
-       struct net_device *mon_ndev = NULL;
-       struct wireless_dev *mon_wdev = NULL;
-       struct rtw_wdev_priv *pwdev_priv = wdev_to_priv(padapter->rtw_wdev);
-
-       if (!name) {
-               DBG_8723A("%s(%s): without specific name\n",
-                         __func__, padapter->pnetdev->name);
-               ret = -EINVAL;
-               goto out;
-       }
-
-       if (pwdev_priv->pmon_ndev) {
-               DBG_8723A("%s(%s): monitor interface exist: %s\n", __func__,
-                         padapter->pnetdev->name, pwdev_priv->pmon_ndev->name);
-               ret = -EBUSY;
-               goto out;
-       }
-
-       mon_ndev = alloc_etherdev(sizeof(struct rtw_adapter));
-       if (!mon_ndev) {
-               DBG_8723A("%s(%s): allocate ndev fail\n", __func__,
-                         padapter->pnetdev->name);
-               ret = -ENOMEM;
-               goto out;
-       }
-
-       mon_ndev->type = ARPHRD_IEEE80211_RADIOTAP;
-       strncpy(mon_ndev->name, name, IFNAMSIZ);
-       mon_ndev->name[IFNAMSIZ - 1] = 0;
-       mon_ndev->name_assign_type = name_assign_type;
-       mon_ndev->destructor = rtw_ndev_destructor;
-
-       mon_ndev->netdev_ops = &rtw_cfg80211_monitor_if_ops;
-
-       /*  wdev */
-       mon_wdev = kzalloc(sizeof(struct wireless_dev), GFP_KERNEL);
-       if (!mon_wdev) {
-               ret = -ENOMEM;
-               goto out;
-       }
-
-       mon_wdev->wiphy = padapter->rtw_wdev->wiphy;
-       mon_wdev->netdev = mon_ndev;
-       mon_wdev->iftype = NL80211_IFTYPE_MONITOR;
-       mon_ndev->ieee80211_ptr = mon_wdev;
-
-       ret = register_netdevice(mon_ndev);
-       if (ret) {
-               goto out;
-       }
-
-       *ndev = pwdev_priv->pmon_ndev = mon_ndev;
-       memcpy(pwdev_priv->ifname_mon, name, IFNAMSIZ + 1);
-
-out:
-       if (ret) {
-               kfree(mon_wdev);
-               mon_wdev = NULL;
-       }
-
-       if (ret && mon_ndev) {
-               free_netdev(mon_ndev);
-               *ndev = mon_ndev = NULL;
-       }
-
-       return ret;
-}
-
-static struct wireless_dev *
-cfg80211_rtw_add_virtual_intf(struct wiphy *wiphy, const char *name,
-                             unsigned char name_assign_type,
-                             enum nl80211_iftype type, u32 *flags,
-                             struct vif_params *params)
-{
-       int ret = 0;
-       struct net_device *ndev = NULL;
-       struct rtw_adapter *padapter = wiphy_to_adapter(wiphy);
-
-       DBG_8723A("%s(%s): wiphy:%s, name:%s, type:%d\n", __func__,
-                 padapter->pnetdev->name, wiphy_name(wiphy), name, type);
-
-       switch (type) {
-       case NL80211_IFTYPE_ADHOC:
-       case NL80211_IFTYPE_AP_VLAN:
-       case NL80211_IFTYPE_WDS:
-       case NL80211_IFTYPE_MESH_POINT:
-               ret = -ENODEV;
-               break;
-       case NL80211_IFTYPE_MONITOR:
-               ret =
-                   rtw_cfg80211_add_monitor_if(padapter, (char *)name,
-                                               name_assign_type, &ndev);
-               break;
-
-       case NL80211_IFTYPE_P2P_CLIENT:
-       case NL80211_IFTYPE_STATION:
-               ret = -ENODEV;
-               break;
-
-       case NL80211_IFTYPE_P2P_GO:
-       case NL80211_IFTYPE_AP:
-               ret = -ENODEV;
-               break;
-       default:
-               ret = -ENODEV;
-               DBG_8723A("Unsupported interface type\n");
-               break;
-       }
-
-       DBG_8723A("%s(%s): ndev:%p, ret:%d\n", __func__,
-                 padapter->pnetdev->name,
-                 ndev, ret);
-
-       return ndev ? ndev->ieee80211_ptr : ERR_PTR(ret);
-}
-
-static int cfg80211_rtw_del_virtual_intf(struct wiphy *wiphy,
-                                        struct wireless_dev *wdev)
-{
-       struct rtw_wdev_priv *pwdev_priv =
-           (struct rtw_wdev_priv *)wiphy_priv(wiphy);
-       struct net_device *ndev;
-       ndev = wdev ? wdev->netdev : NULL;
-
-       if (!ndev)
-               goto exit;
-
-       unregister_netdevice(ndev);
-
-       if (ndev == pwdev_priv->pmon_ndev) {
-               pwdev_priv->pmon_ndev = NULL;
-               pwdev_priv->ifname_mon[0] = '\0';
-               DBG_8723A("%s(%s): remove monitor interface\n",
-                         __func__, ndev->name);
-       }
-
-exit:
-       return 0;
-}
-
-static int rtw_add_beacon(struct rtw_adapter *adapter, const u8 *head,
-                         size_t head_len, const u8 *tail, size_t tail_len)
-{
-       int ret = 0;
-       u8 *pbuf;
-       uint len, ielen, wps_ielen = 0;
-       struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
-       struct wlan_bssid_ex *bss = &pmlmepriv->cur_network.network;
-       const struct ieee80211_mgmt *mgmt = (struct ieee80211_mgmt *)head;
-       struct ieee80211_mgmt *tmpmgmt;
-       /* struct sta_priv *pstapriv = &padapter->stapriv; */
-
-       DBG_8723A("%s beacon_head_len =%zu, beacon_tail_len =%zu\n",
-                 __func__, head_len, tail_len);
-
-       if (check_fwstate(pmlmepriv, WIFI_AP_STATE) != true)
-               return -EINVAL;
-
-       if (head_len < offsetof(struct ieee80211_mgmt, u.beacon.variable))
-               return -EINVAL;
-
-       pbuf = kzalloc(head_len + tail_len, GFP_KERNEL);
-       if (!pbuf)
-               return -ENOMEM;
-       tmpmgmt = (struct ieee80211_mgmt *)pbuf;
-
-       bss->beacon_interval = get_unaligned_le16(&mgmt->u.beacon.beacon_int);
-       bss->capability = get_unaligned_le16(&mgmt->u.beacon.capab_info);
-       bss->tsf = get_unaligned_le64(&mgmt->u.beacon.timestamp);
-
-       /*  24 = beacon header len. */
-       memcpy(pbuf, (void *)head, head_len);
-       memcpy(pbuf + head_len, (void *)tail, tail_len);
-
-       len = head_len + tail_len;
-       ielen = len - offsetof(struct ieee80211_mgmt, u.beacon.variable);
-       /* check wps ie if inclued */
-       if (cfg80211_find_vendor_ie(WLAN_OUI_MICROSOFT,
-                                   WLAN_OUI_TYPE_MICROSOFT_WPS,
-                                   tmpmgmt->u.beacon.variable, ielen))
-               DBG_8723A("add bcn, wps_ielen =%d\n", wps_ielen);
-
-       /* pbss_network->IEs will not include p2p_ie, wfd ie */
-       rtw_ies_remove_ie23a(tmpmgmt->u.beacon.variable, &ielen, 0,
-                            WLAN_EID_VENDOR_SPECIFIC, P2P_OUI23A, 4);
-       rtw_ies_remove_ie23a(tmpmgmt->u.beacon.variable, &ielen, 0,
-                            WLAN_EID_VENDOR_SPECIFIC, WFD_OUI23A, 4);
-
-       len = ielen + offsetof(struct ieee80211_mgmt, u.beacon.variable);
-       if (rtw_check_beacon_data23a(adapter, tmpmgmt, len) == _SUCCESS) {
-               ret = 0;
-       } else {
-               ret = -EINVAL;
-       }
-
-       kfree(pbuf);
-
-       return ret;
-}
-
-static int cfg80211_rtw_start_ap(struct wiphy *wiphy, struct net_device *ndev,
-                                struct cfg80211_ap_settings *settings)
-{
-       int ret = 0;
-       struct rtw_adapter *adapter = wiphy_to_adapter(wiphy);
-
-       DBG_8723A("%s(%s): hidden_ssid:%d, auth_type:%d\n",
-                 __func__, ndev->name, settings->hidden_ssid,
-                 settings->auth_type);
-
-       ret = rtw_add_beacon(adapter, settings->beacon.head,
-                            settings->beacon.head_len, settings->beacon.tail,
-                            settings->beacon.tail_len);
-
-       adapter->mlmeextpriv.mlmext_info.hidden_ssid_mode =
-               settings->hidden_ssid;
-
-       if (settings->ssid && settings->ssid_len) {
-               struct wlan_bssid_ex *pbss_network =
-                       &adapter->mlmepriv.cur_network.network;
-               struct wlan_bssid_ex *pbss_network_ext =
-                       &adapter->mlmeextpriv.mlmext_info.network;
-
-               memcpy(pbss_network->Ssid.ssid, (void *)settings->ssid,
-                      settings->ssid_len);
-               pbss_network->Ssid.ssid_len = settings->ssid_len;
-               memcpy(pbss_network_ext->Ssid.ssid, (void *)settings->ssid,
-                      settings->ssid_len);
-               pbss_network_ext->Ssid.ssid_len = settings->ssid_len;
-       }
-
-       return ret;
-}
-
-static int cfg80211_rtw_change_beacon(struct wiphy *wiphy,
-                                     struct net_device *ndev,
-                                     struct cfg80211_beacon_data *info)
-{
-       int ret = 0;
-       struct rtw_adapter *adapter = wiphy_to_adapter(wiphy);
-
-       DBG_8723A("%s(%s)\n", __func__, ndev->name);
-
-       ret = rtw_add_beacon(adapter, info->head, info->head_len, info->tail,
-                            info->tail_len);
-
-       return ret;
-}
-
-static int cfg80211_rtw_stop_ap(struct wiphy *wiphy, struct net_device *ndev)
-{
-       DBG_8723A("%s(%s)\n", __func__, ndev->name);
-       return 0;
-}
-
-static int cfg80211_rtw_add_station(struct wiphy *wiphy,
-                                   struct net_device *ndev, const u8 *mac,
-                                   struct station_parameters *params)
-{
-       DBG_8723A("%s(%s)\n", __func__, ndev->name);
-
-       return 0;
-}
-
-static int cfg80211_rtw_del_station(struct wiphy *wiphy,
-                                   struct net_device *ndev,
-                                   struct station_del_parameters *params)
-{
-       const u8 *mac = params->mac;
-       int ret = 0;
-       struct list_head *phead;
-       u8 updated = 0;
-       struct sta_info *psta, *ptmp;
-       struct rtw_adapter *padapter = netdev_priv(ndev);
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct sta_priv *pstapriv = &padapter->stapriv;
-
-       DBG_8723A("+%s(%s)\n", __func__, ndev->name);
-
-       if (check_fwstate(pmlmepriv, (_FW_LINKED | WIFI_AP_STATE)) != true) {
-               DBG_8723A("%s, fw_state != FW_LINKED|WIFI_AP_STATE\n",
-                         __func__);
-               return -EINVAL;
-       }
-
-       if (!mac) {
-               DBG_8723A("flush all sta, and cam_entry\n");
-
-               flush_all_cam_entry23a(padapter);       /* clear CAM */
-
-               ret = rtw_sta_flush23a(padapter);
-
-               return ret;
-       }
-
-       DBG_8723A("free sta macaddr=%pM\n", mac);
-
-       if (is_broadcast_ether_addr(mac))
-               return -EINVAL;
-
-       spin_lock_bh(&pstapriv->asoc_list_lock);
-       phead = &pstapriv->asoc_list;
-       /* check asoc_queue */
-       list_for_each_entry_safe(psta, ptmp, phead, asoc_list) {
-               if (ether_addr_equal(mac, psta->hwaddr)) {
-                       if (psta->dot8021xalg == 1 &&
-                           psta->bpairwise_key_installed == false) {
-                               DBG_8723A("%s, sta's dot8021xalg = 1 and "
-                                         "key_installed = false\n", __func__);
-                       } else {
-                               DBG_8723A("free psta =%p, aid =%d\n", psta,
-                                         psta->aid);
-
-                               list_del_init(&psta->asoc_list);
-                               pstapriv->asoc_list_cnt--;
-
-                               /* spin_unlock_bh(&pstapriv->asoc_list_lock); */
-                               updated =
-                                   ap_free_sta23a(padapter, psta, true,
-                                               WLAN_REASON_DEAUTH_LEAVING);
-                               /* spin_lock_bh(&pstapriv->asoc_list_lock); */
-
-                               psta = NULL;
-
-                               break;
-                       }
-               }
-       }
-       spin_unlock_bh(&pstapriv->asoc_list_lock);
-
-       associated_clients_update23a(padapter, updated);
-
-       DBG_8723A("-%s(%s)\n", __func__, ndev->name);
-
-       return ret;
-}
-
-static int cfg80211_rtw_change_station(struct wiphy *wiphy,
-                                      struct net_device *ndev, const u8 *mac,
-                                      struct station_parameters *params)
-{
-       DBG_8723A("%s(%s)\n", __func__, ndev->name);
-       return 0;
-}
-
-static int cfg80211_rtw_dump_station(struct wiphy *wiphy,
-                                    struct net_device *ndev, int idx, u8 *mac,
-                                    struct station_info *sinfo)
-{
-       DBG_8723A("%s(%s)\n", __func__, ndev->name);
-
-       /* TODO: dump scanned queue */
-
-       return -ENOENT;
-}
-
-static int cfg80211_rtw_change_bss(struct wiphy *wiphy, struct net_device *ndev,
-                                  struct bss_parameters *params)
-{
-       DBG_8723A("%s(%s)\n", __func__, ndev->name);
-       return 0;
-}
-#endif /* CONFIG_8723AU_AP_MODE */
-
-static int _cfg80211_rtw_mgmt_tx(struct rtw_adapter *padapter, u8 tx_ch,
-                                const u8 *buf, size_t len)
-{
-       struct xmit_frame *pmgntframe;
-       struct pkt_attrib *pattrib;
-       unsigned char *pframe;
-       int ret = _FAIL;
-       struct ieee80211_hdr *pwlanhdr;
-       struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-       struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
-
-       if (_FAIL == rtw_pwr_wakeup(padapter)) {
-               ret = -EFAULT;
-               goto exit;
-       }
-
-       rtw_set_scan_deny(padapter, 1000);
-
-       rtw_scan_abort23a(padapter);
-
-       if (tx_ch != rtw_get_oper_ch23a(padapter)) {
-               if (!check_fwstate(&padapter->mlmepriv, _FW_LINKED))
-                       pmlmeext->cur_channel = tx_ch;
-               set_channel_bwmode23a(padapter, tx_ch,
-                                  HAL_PRIME_CHNL_OFFSET_DONT_CARE,
-                                  HT_CHANNEL_WIDTH_20);
-       }
-
-       /* starting alloc mgmt frame to dump it */
-       pmgntframe = alloc_mgtxmitframe23a(pxmitpriv);
-       if (!pmgntframe) {
-               /* ret = -ENOMEM; */
-               ret = _FAIL;
-               goto exit;
-       }
-
-       /* update attribute */
-       pattrib = &pmgntframe->attrib;
-       update_mgntframe_attrib23a(padapter, pattrib);
-       pattrib->retry_ctrl = false;
-
-       memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
-
-       pframe = (u8 *) (pmgntframe->buf_addr) + TXDESC_OFFSET;
-
-       memcpy(pframe, (void *)buf, len);
-       pattrib->pktlen = len;
-
-       pwlanhdr = (struct ieee80211_hdr *)pframe;
-       /* update seq number */
-       pmlmeext->mgnt_seq = le16_to_cpu(pwlanhdr->seq_ctrl) >> 4;
-       pattrib->seqnum = pmlmeext->mgnt_seq;
-       pmlmeext->mgnt_seq++;
-
-       pattrib->last_txcmdsz = pattrib->pktlen;
-
-       ret = dump_mgntframe23a_and_wait_ack23a(padapter, pmgntframe);
-
-       if (ret  != _SUCCESS)
-               DBG_8723A("%s, ack == false\n", __func__);
-       else
-               DBG_8723A("%s, ack == true\n", __func__);
-
-exit:
-
-       DBG_8723A("%s, ret =%d\n", __func__, ret);
-
-       return ret;
-}
-
-static int cfg80211_rtw_mgmt_tx(struct wiphy *wiphy, struct wireless_dev *wdev,
-                               struct cfg80211_mgmt_tx_params *params,
-                               u64 *cookie)
-{
-       struct rtw_adapter *padapter =
-               (struct rtw_adapter *)wiphy_to_adapter(wiphy);
-       int ret = 0;
-       int tx_ret;
-       u32 dump_limit = RTW_MAX_MGMT_TX_CNT;
-       u32 dump_cnt = 0;
-       bool ack = true;
-       u8 category, action;
-       unsigned long start = jiffies;
-       size_t len = params->len;
-       struct ieee80211_channel *chan = params->chan;
-       const u8 *buf = params->buf;
-       struct ieee80211_mgmt *hdr = (struct ieee80211_mgmt *)buf;
-       u8 tx_ch = (u8) ieee80211_frequency_to_channel(chan->center_freq);
-
-       if (!ieee80211_is_action(hdr->frame_control))
-               return -EINVAL;
-
-       /* cookie generation */
-       *cookie = (unsigned long)buf;
-
-       DBG_8723A("%s(%s): len =%zu, ch =%d\n", __func__,
-                 padapter->pnetdev->name, len, tx_ch);
-
-       /* indicate ack before issue frame to avoid racing with rsp frame */
-       cfg80211_mgmt_tx_status(padapter->rtw_wdev, *cookie, buf, len, ack,
-                               GFP_KERNEL);
-
-       DBG_8723A("RTW_Tx:tx_ch =%d, da =%pM\n", tx_ch, hdr->da);
-       category = hdr->u.action.category;
-       action = hdr->u.action.u.wme_action.action_code;
-       DBG_8723A("RTW_Tx:category(%u), action(%u)\n", category, action);
-
-       do {
-               dump_cnt++;
-               tx_ret = _cfg80211_rtw_mgmt_tx(padapter, tx_ch, buf, len);
-       } while (dump_cnt < dump_limit && tx_ret != _SUCCESS);
-
-       if (tx_ret != _SUCCESS || dump_cnt > 1) {
-               DBG_8723A("%s(%s): %s (%d/%d) in %d ms\n",
-                         __func__, padapter->pnetdev->name,
-                         tx_ret == _SUCCESS ? "OK" : "FAIL", dump_cnt,
-                         dump_limit, jiffies_to_msecs(jiffies - start));
-       }
-
-       return ret;
-}
-
-static void cfg80211_rtw_mgmt_frame_register(struct wiphy *wiphy,
-                                            struct wireless_dev *wdev,
-                                            u16 frame_type, bool reg)
-{
-       if (frame_type != (IEEE80211_FTYPE_MGMT | IEEE80211_STYPE_PROBE_REQ))
-               return;
-
-       return;
-}
-
-static struct cfg80211_ops rtw_cfg80211_ops = {
-       .change_virtual_intf = cfg80211_rtw_change_iface,
-       .add_key = cfg80211_rtw_add_key,
-       .get_key = cfg80211_rtw_get_key,
-       .del_key = cfg80211_rtw_del_key,
-       .set_default_key = cfg80211_rtw_set_default_key,
-       .get_station = cfg80211_rtw_get_station,
-       .scan = cfg80211_rtw_scan,
-       .set_wiphy_params = cfg80211_rtw_set_wiphy_params,
-       .connect = cfg80211_rtw_connect,
-       .disconnect = cfg80211_rtw_disconnect,
-       .join_ibss = cfg80211_rtw_join_ibss,
-       .leave_ibss = cfg80211_rtw_leave_ibss,
-       .set_tx_power = cfg80211_rtw_set_txpower,
-       .get_tx_power = cfg80211_rtw_get_txpower,
-       .set_power_mgmt = cfg80211_rtw_set_power_mgmt,
-       .set_pmksa = cfg80211_rtw_set_pmksa,
-       .del_pmksa = cfg80211_rtw_del_pmksa,
-       .flush_pmksa = cfg80211_rtw_flush_pmksa,
-
-#ifdef CONFIG_8723AU_AP_MODE
-       .add_virtual_intf = cfg80211_rtw_add_virtual_intf,
-       .del_virtual_intf = cfg80211_rtw_del_virtual_intf,
-
-       .start_ap = cfg80211_rtw_start_ap,
-       .change_beacon = cfg80211_rtw_change_beacon,
-       .stop_ap = cfg80211_rtw_stop_ap,
-
-       .add_station = cfg80211_rtw_add_station,
-       .del_station = cfg80211_rtw_del_station,
-       .change_station = cfg80211_rtw_change_station,
-       .dump_station = cfg80211_rtw_dump_station,
-       .change_bss = cfg80211_rtw_change_bss,
-#endif /* CONFIG_8723AU_AP_MODE */
-
-       .mgmt_tx = cfg80211_rtw_mgmt_tx,
-       .mgmt_frame_register = cfg80211_rtw_mgmt_frame_register,
-};
-
-static void rtw_cfg80211_init_ht_capab(struct ieee80211_sta_ht_cap *ht_cap,
-                                      enum nl80211_band band, u8 rf_type)
-{
-
-#define MAX_BIT_RATE_40MHZ_MCS15       300     /* Mbps */
-#define MAX_BIT_RATE_40MHZ_MCS7                150     /* Mbps */
-
-       ht_cap->ht_supported = true;
-
-       ht_cap->cap = IEEE80211_HT_CAP_SUP_WIDTH_20_40 |
-           IEEE80211_HT_CAP_SGI_40 | IEEE80211_HT_CAP_SGI_20 |
-           IEEE80211_HT_CAP_DSSSCCK40 | IEEE80211_HT_CAP_MAX_AMSDU;
-
-       /*
-        *Maximum length of AMPDU that the STA can receive.
-        *Length = 2 ^ (13 + max_ampdu_length_exp) - 1 (octets)
-        */
-       ht_cap->ampdu_factor = IEEE80211_HT_MAX_AMPDU_64K;
-
-       /*Minimum MPDU start spacing , */
-       ht_cap->ampdu_density = IEEE80211_HT_MPDU_DENSITY_16;
-
-       ht_cap->mcs.tx_params = IEEE80211_HT_MCS_TX_DEFINED;
-
-       /*
-        *hw->wiphy->bands[NL80211_BAND_2GHZ]
-        *base on ant_num
-        *rx_mask: RX mask
-        *if rx_ant = 1 rx_mask[0]= 0xff;==>MCS0-MCS7
-        *if rx_ant = 2 rx_mask[1]= 0xff;==>MCS8-MCS15
-        *if rx_ant >= 3 rx_mask[2]= 0xff;
-        *if BW_40 rx_mask[4]= 0x01;
-        *highest supported RX rate
-        */
-       if (rf_type == RF_1T1R) {
-               ht_cap->mcs.rx_mask[0] = 0xFF;
-               ht_cap->mcs.rx_mask[1] = 0x00;
-               ht_cap->mcs.rx_mask[4] = 0x01;
-
-               ht_cap->mcs.rx_highest = cpu_to_le16(MAX_BIT_RATE_40MHZ_MCS7);
-       } else if ((rf_type == RF_1T2R) || (rf_type == RF_2T2R)) {
-               ht_cap->mcs.rx_mask[0] = 0xFF;
-               ht_cap->mcs.rx_mask[1] = 0xFF;
-               ht_cap->mcs.rx_mask[4] = 0x01;
-
-               ht_cap->mcs.rx_highest = cpu_to_le16(MAX_BIT_RATE_40MHZ_MCS15);
-       } else {
-               DBG_8723A("%s, error rf_type =%d\n", __func__, rf_type);
-       }
-
-}
-
-void rtw_cfg80211_init_wiphy(struct rtw_adapter *padapter)
-{
-       u8 rf_type;
-       struct ieee80211_supported_band *bands;
-       struct wireless_dev *pwdev = padapter->rtw_wdev;
-       struct wiphy *wiphy = pwdev->wiphy;
-
-       rf_type = rtl8723a_get_rf_type(padapter);
-
-       DBG_8723A("%s:rf_type =%d\n", __func__, rf_type);
-
-       /* if (padapter->registrypriv.wireless_mode & WIRELESS_11G) */
-       {
-               bands = wiphy->bands[NL80211_BAND_2GHZ];
-               if (bands)
-                       rtw_cfg80211_init_ht_capab(&bands->ht_cap,
-                                                  NL80211_BAND_2GHZ,
-                                                  rf_type);
-       }
-
-       /* if (padapter->registrypriv.wireless_mode & WIRELESS_11A) */
-       {
-               bands = wiphy->bands[NL80211_BAND_5GHZ];
-               if (bands)
-                       rtw_cfg80211_init_ht_capab(&bands->ht_cap,
-                                                  NL80211_BAND_5GHZ,
-                                                  rf_type);
-       }
-}
-
-static void rtw_cfg80211_preinit_wiphy(struct rtw_adapter *padapter,
-                                      struct wiphy *wiphy)
-{
-       wiphy->signal_type = CFG80211_SIGNAL_TYPE_MBM;
-
-       wiphy->max_scan_ssids = RTW_SSID_SCAN_AMOUNT;
-       wiphy->max_scan_ie_len = IEEE80211_MAX_DATA_LEN;
-       wiphy->max_num_pmkids = RTW_MAX_NUM_PMKIDS;
-
-       wiphy->max_remain_on_channel_duration =
-           RTW_MAX_REMAIN_ON_CHANNEL_DURATION;
-
-       wiphy->interface_modes = BIT(NL80211_IFTYPE_STATION) |
-           BIT(NL80211_IFTYPE_ADHOC) |
-#ifdef CONFIG_8723AU_AP_MODE
-           BIT(NL80211_IFTYPE_AP) | BIT(NL80211_IFTYPE_MONITOR) |
-#endif
-           0;
-
-#ifdef CONFIG_8723AU_AP_MODE
-       wiphy->mgmt_stypes = rtw_cfg80211_default_mgmt_stypes;
-#endif /* CONFIG_8723AU_AP_MODE */
-
-       wiphy->software_iftypes |= BIT(NL80211_IFTYPE_MONITOR);
-
-       /*
-          wiphy->iface_combinations = &rtw_combinations;
-          wiphy->n_iface_combinations = 1;
-        */
-
-       wiphy->cipher_suites = rtw_cipher_suites;
-       wiphy->n_cipher_suites = ARRAY_SIZE(rtw_cipher_suites);
-
-       /* if (padapter->registrypriv.wireless_mode & WIRELESS_11G) */
-       wiphy->bands[NL80211_BAND_2GHZ] =
-           rtw_spt_band_alloc(NL80211_BAND_2GHZ);
-       /* if (padapter->registrypriv.wireless_mode & WIRELESS_11A) */
-       wiphy->bands[NL80211_BAND_5GHZ] =
-           rtw_spt_band_alloc(NL80211_BAND_5GHZ);
-
-       wiphy->flags |= WIPHY_FLAG_HAS_REMAIN_ON_CHANNEL;
-       wiphy->flags |= WIPHY_FLAG_OFFCHAN_TX | WIPHY_FLAG_HAVE_AP_SME;
-
-       if (padapter->registrypriv.power_mgnt != PS_MODE_ACTIVE)
-               wiphy->flags |= WIPHY_FLAG_PS_ON_BY_DEFAULT;
-       else
-               wiphy->flags &= ~WIPHY_FLAG_PS_ON_BY_DEFAULT;
-}
-
-int rtw_wdev_alloc(struct rtw_adapter *padapter, struct device *dev)
-{
-       int ret = 0;
-       struct wiphy *wiphy;
-       struct wireless_dev *wdev;
-       struct rtw_wdev_priv *pwdev_priv;
-       struct net_device *pnetdev = padapter->pnetdev;
-
-       DBG_8723A("%s(padapter =%p)\n", __func__, padapter);
-
-       /* wiphy */
-       wiphy = wiphy_new(&rtw_cfg80211_ops, sizeof(struct rtw_wdev_priv));
-       if (!wiphy) {
-               DBG_8723A("Couldn't allocate wiphy device\n");
-               ret = -ENOMEM;
-               goto exit;
-       }
-
-       /*  wdev */
-       wdev = kzalloc(sizeof(struct wireless_dev), GFP_KERNEL);
-       if (!wdev) {
-               ret = -ENOMEM;
-               goto free_wiphy;
-       }
-
-       set_wiphy_dev(wiphy, dev);
-       rtw_cfg80211_preinit_wiphy(padapter, wiphy);
-
-       ret = wiphy_register(wiphy);
-       if (ret < 0) {
-               DBG_8723A("Couldn't register wiphy device\n");
-               goto free_wdev;
-       }
-
-       wdev->wiphy = wiphy;
-       wdev->netdev = pnetdev;
-       /* wdev->iftype = NL80211_IFTYPE_STATION; */
-       /*  for rtw_setopmode_cmd23a() in cfg80211_rtw_change_iface() */
-       wdev->iftype = NL80211_IFTYPE_MONITOR;
-       padapter->rtw_wdev = wdev;
-       pnetdev->ieee80211_ptr = wdev;
-
-       /* init pwdev_priv */
-       pwdev_priv = wdev_to_priv(wdev);
-       pwdev_priv->rtw_wdev = wdev;
-       pwdev_priv->pmon_ndev = NULL;
-       pwdev_priv->ifname_mon[0] = '\0';
-       pwdev_priv->padapter = padapter;
-       pwdev_priv->scan_request = NULL;
-       spin_lock_init(&pwdev_priv->scan_req_lock);
-
-       pwdev_priv->p2p_enabled = false;
-
-       if (padapter->registrypriv.power_mgnt != PS_MODE_ACTIVE)
-               pwdev_priv->power_mgmt = true;
-       else
-               pwdev_priv->power_mgmt = false;
-
-       return ret;
-free_wdev:
-       kfree(wdev);
-free_wiphy:
-       wiphy_free(wiphy);
-exit:
-       return ret;
-}
-
-void rtw_wdev_free(struct wireless_dev *wdev)
-{
-       DBG_8723A("%s(wdev =%p)\n", __func__, wdev);
-
-       if (!wdev)
-               return;
-
-       kfree(wdev->wiphy->bands[NL80211_BAND_2GHZ]);
-       kfree(wdev->wiphy->bands[NL80211_BAND_5GHZ]);
-
-       wiphy_free(wdev->wiphy);
-
-       kfree(wdev);
-}
-
-void rtw_wdev_unregister(struct wireless_dev *wdev)
-{
-       struct rtw_wdev_priv *pwdev_priv;
-
-       DBG_8723A("%s(wdev =%p)\n", __func__, wdev);
-
-       if (!wdev)
-               return;
-
-       pwdev_priv = wdev_to_priv(wdev);
-
-       rtw_cfg80211_indicate_scan_done(pwdev_priv, true);
-
-       if (pwdev_priv->pmon_ndev) {
-               DBG_8723A("%s, unregister monitor interface\n", __func__);
-               unregister_netdev(pwdev_priv->pmon_ndev);
-       }
-
-       wiphy_unregister(wdev->wiphy);
-}
diff --git a/drivers/staging/rtl8723au/os_dep/mlme_linux.c b/drivers/staging/rtl8723au/os_dep/mlme_linux.c
deleted file mode 100644 (file)
index ca24369..0000000
+++ /dev/null
@@ -1,81 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-
-#define _MLME_OSDEP_C_
-
-#include <osdep_service.h>
-#include <drv_types.h>
-#include <mlme_osdep.h>
-
-static struct rt_pmkid_list backupPMKIDList[NUM_PMKID_CACHE];
-
-void rtw_reset_securitypriv23a(struct rtw_adapter *adapter)
-{
-       u8      backupPMKIDIndex = 0;
-       u8      backupTKIPCountermeasure = 0x00;
-       unsigned long backupTKIPcountermeasure_time = 0;
-
-       if (adapter->securitypriv.dot11AuthAlgrthm ==
-           dot11AuthAlgrthm_8021X) { /* 802.1x */
-               /*  We have to backup the PMK information for WiFi PMK
-                *  Caching test item.
-                *  Backup the btkip_countermeasure information.
-                *  When the countermeasure is trigger, the driver have to
-                *  disconnect with AP for 60 seconds.
-                */
-               memcpy(&backupPMKIDList[0], &adapter->securitypriv.PMKIDList[0],
-                      sizeof(struct rt_pmkid_list) * NUM_PMKID_CACHE);
-               backupPMKIDIndex = adapter->securitypriv.PMKIDIndex;
-               backupTKIPCountermeasure = adapter->securitypriv.btkip_countermeasure;
-               backupTKIPcountermeasure_time = adapter->securitypriv.btkip_countermeasure_time;
-
-               memset((unsigned char *)&adapter->securitypriv, 0,
-                      sizeof (struct security_priv));
-               /* Restore the PMK information to securitypriv structure
-                * for the following connection.
-                */
-               memcpy(&adapter->securitypriv.PMKIDList[0], &backupPMKIDList[0],
-                      sizeof(struct rt_pmkid_list) * NUM_PMKID_CACHE);
-               adapter->securitypriv.PMKIDIndex = backupPMKIDIndex;
-               adapter->securitypriv.btkip_countermeasure = backupTKIPCountermeasure;
-               adapter->securitypriv.btkip_countermeasure_time = backupTKIPcountermeasure_time;
-
-               adapter->securitypriv.ndisauthtype = Ndis802_11AuthModeOpen;
-               adapter->securitypriv.ndisencryptstatus = Ndis802_11WEPDisabled;
-       } else {  /* reset values in securitypriv */
-               struct security_priv *psec_priv = &adapter->securitypriv;
-
-               /* open system */
-               psec_priv->dot11AuthAlgrthm = dot11AuthAlgrthm_Open;
-               psec_priv->dot11PrivacyAlgrthm = 0;
-               psec_priv->dot11PrivacyKeyIndex = 0;
-
-               psec_priv->dot118021XGrpPrivacy = 0;
-               psec_priv->dot118021XGrpKeyid = 1;
-
-               psec_priv->ndisauthtype = Ndis802_11AuthModeOpen;
-               psec_priv->ndisencryptstatus = Ndis802_11WEPDisabled;
-       }
-}
-
-void rtw_os_indicate_disconnect23a(struct rtw_adapter *adapter)
-{
-       /* Do it first for tx broadcast pkt after disconnection issue! */
-       netif_carrier_off(adapter->pnetdev);
-
-       rtw_cfg80211_indicate_disconnect(adapter);
-
-       rtw_reset_securitypriv23a(adapter);
-}
diff --git a/drivers/staging/rtl8723au/os_dep/os_intfs.c b/drivers/staging/rtl8723au/os_dep/os_intfs.c
deleted file mode 100644 (file)
index b8848c2..0000000
+++ /dev/null
@@ -1,852 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#define _OS_INTFS_C_
-
-#include <osdep_service.h>
-#include <drv_types.h>
-#include <xmit_osdep.h>
-#include <recv_osdep.h>
-#include <hal_intf.h>
-#include <rtw_version.h>
-
-#include <rtl8723a_hal.h>
-
-MODULE_LICENSE("GPL");
-MODULE_DESCRIPTION("Realtek Wireless Lan Driver");
-MODULE_AUTHOR("Realtek Semiconductor Corp.");
-MODULE_AUTHOR("Larry Finger <Larry.Finger@lwfinger.net>");
-MODULE_AUTHOR("Jes Sorensen <Jes.Sorensen@redhat.com>");
-MODULE_VERSION(DRIVERVERSION);
-MODULE_FIRMWARE("rtlwifi/rtl8723aufw_A.bin");
-MODULE_FIRMWARE("rtlwifi/rtl8723aufw_B.bin");
-MODULE_FIRMWARE("rtlwifi/rtl8723aufw_B_NoBT.bin");
-
-/* module param defaults */
-static int rtw_chip_version;
-static int rtw_rfintfs = HWPI;
-static int rtw_debug = 1;
-
-static int rtw_channel = 1;/* ad-hoc support requirement */
-static int rtw_wireless_mode = WIRELESS_11BG_24N;
-static int rtw_vrtl_carrier_sense = AUTO_VCS;
-static int rtw_vcs_type = RTS_CTS;/*  */
-static int rtw_rts_thresh = 2347;/*  */
-static int rtw_frag_thresh = 2346;/*  */
-static int rtw_preamble = PREAMBLE_LONG;/* long, short, auto */
-static int rtw_scan_mode = 1;/* active, passive */
-static int rtw_adhoc_tx_pwr = 1;
-static int rtw_soft_ap;
-static int rtw_power_mgnt = 1;
-static int rtw_ips_mode = IPS_NORMAL;
-
-static int rtw_smart_ps = 2;
-
-module_param(rtw_ips_mode, int, 0644);
-MODULE_PARM_DESC(rtw_ips_mode, "The default IPS mode");
-
-static int rtw_long_retry_lmt = 7;
-static int rtw_short_retry_lmt = 7;
-static int rtw_busy_thresh = 40;
-static int rtw_ack_policy = NORMAL_ACK;
-
-static int rtw_acm_method;/*  0:By SW 1:By HW. */
-
-static int rtw_wmm_enable = 1;/*  default is set to enable the wmm. */
-static int rtw_uapsd_enable;
-
-static int rtw_ht_enable = 1;
-/* 0 :diable, bit(0): enable 2.4g, bit(1): enable 5g */
-static int rtw_cbw40_enable = 3;
-static int rtw_ampdu_enable = 1;/* for enable tx_ampdu */
-/*  0: disable, bit(0):enable 2.4g, bit(1):enable 5g, default is set to enable
- * 2.4GHZ for IOT issue with bufflao's AP at 5GHZ
- */
-static int rtw_rx_stbc = 1;
-static int rtw_ampdu_amsdu;/*  0: disabled, 1:enabled, 2:auto */
-
-/* Use 2 path Tx to transmit MCS0~7 and legacy mode */
-static int rtw_lowrate_two_xmit = 1;
-
-/* int rf_config = RF_1T2R;  1T2R */
-static int rtw_rf_config = RF_819X_MAX_TYPE;  /* auto */
-static int rtw_low_power;
-static int rtw_wifi_spec;
-static int rtw_channel_plan = RT_CHANNEL_DOMAIN_MAX;
-
-#ifdef CONFIG_8723AU_BT_COEXIST
-static int rtw_btcoex_enable = 1;
-static int rtw_bt_iso = 2;/*  0:Low, 1:High, 2:From Efuse */
-/*  0:Idle, 1:None-SCO, 2:SCO, 3:From Counter, 4.Busy, 5.OtherBusy */
-static int rtw_bt_sco = 3;
-/*  0:Disable BT control A-MPDU, 1:Enable BT control A-MPDU. */
-static int rtw_bt_ampdu = 1;
-#endif
-
-/*  0:Reject AP's Add BA req, 1:Accept AP's Add BA req. */
-static int rtw_AcceptAddbaReq = true;
-
-static int rtw_antdiv_cfg = 2; /*  0:OFF , 1:ON, 2:decide by Efuse config */
-static int rtw_antdiv_type; /* 0:decide by efuse */
-
-static int rtw_enusbss;/* 0:disable, 1:enable */
-
-static int rtw_hwpdn_mode = 2;/* 0:disable, 1:enable, 2: by EFUSE config */
-
-static int rtw_hwpwrp_detect; /* HW power  ping detect 0:disable , 1:enable */
-
-static int rtw_hw_wps_pbc = 1;
-
-static int rtw_80211d;
-
-static int rtw_regulatory_id = 0xff;/*  Regulatory tab id, 0xff = follow efuse's setting */
-
-module_param(rtw_regulatory_id, int, 0644);
-
-static char *ifname = "wlan%d";
-module_param(ifname, charp, 0644);
-MODULE_PARM_DESC(ifname, "The default name to allocate for first interface");
-
-static char *if2name = "wlan%d";
-module_param(if2name, charp, 0644);
-MODULE_PARM_DESC(if2name, "The default name to allocate for second interface");
-
-module_param(rtw_channel_plan, int, 0644);
-module_param(rtw_chip_version, int, 0644);
-module_param(rtw_rfintfs, int, 0644);
-module_param(rtw_channel, int, 0644);
-module_param(rtw_wmm_enable, int, 0644);
-module_param(rtw_vrtl_carrier_sense, int, 0644);
-module_param(rtw_vcs_type, int, 0644);
-module_param(rtw_busy_thresh, int, 0644);
-module_param(rtw_ht_enable, int, 0644);
-module_param(rtw_cbw40_enable, int, 0644);
-module_param(rtw_ampdu_enable, int, 0644);
-module_param(rtw_rx_stbc, int, 0644);
-module_param(rtw_ampdu_amsdu, int, 0644);
-
-module_param(rtw_lowrate_two_xmit, int, 0644);
-
-module_param(rtw_rf_config, int, 0644);
-module_param(rtw_power_mgnt, int, 0644);
-module_param(rtw_smart_ps, int, 0644);
-module_param(rtw_low_power, int, 0644);
-module_param(rtw_wifi_spec, int, 0644);
-
-module_param(rtw_antdiv_cfg, int, 0644);
-
-module_param(rtw_enusbss, int, 0644);
-module_param(rtw_hwpdn_mode, int, 0644);
-module_param(rtw_hwpwrp_detect, int, 0644);
-
-module_param(rtw_hw_wps_pbc, int, 0644);
-
-static uint rtw_max_roaming_times = 2;
-module_param(rtw_max_roaming_times, uint, 0644);
-MODULE_PARM_DESC(rtw_max_roaming_times, "The max roaming times to try");
-
-module_param(rtw_80211d, int, 0644);
-MODULE_PARM_DESC(rtw_80211d, "Enable 802.11d mechanism");
-
-#ifdef CONFIG_8723AU_BT_COEXIST
-module_param(rtw_btcoex_enable, int, 0644);
-MODULE_PARM_DESC(rtw_btcoex_enable, "Enable BT co-existence mechanism");
-#endif
-
-static uint rtw_notch_filter;
-module_param(rtw_notch_filter, uint, 0644);
-MODULE_PARM_DESC(rtw_notch_filter, "0:Disable, 1:Enable, 2:Enable only for P2P");
-module_param_named(debug, rtw_debug, int, 0444);
-MODULE_PARM_DESC(debug, "Set debug level (1-9) (default 1)");
-
-static int netdev_close(struct net_device *pnetdev);
-
-static void loadparam(struct rtw_adapter *padapter,  struct net_device *pnetdev)
-{
-       struct registry_priv  *registry_par = &padapter->registrypriv;
-
-       GlobalDebugLevel23A = rtw_debug;
-       registry_par->chip_version = (u8)rtw_chip_version;
-       registry_par->rfintfs = (u8)rtw_rfintfs;
-       memcpy(registry_par->ssid.ssid, "ANY", 3);
-       registry_par->ssid.ssid_len = 3;
-       registry_par->channel = (u8)rtw_channel;
-       registry_par->wireless_mode = (u8)rtw_wireless_mode;
-       registry_par->vrtl_carrier_sense = (u8)rtw_vrtl_carrier_sense;
-       registry_par->vcs_type = (u8)rtw_vcs_type;
-       registry_par->rts_thresh = (u16)rtw_rts_thresh;
-       registry_par->frag_thresh = (u16)rtw_frag_thresh;
-       registry_par->preamble = (u8)rtw_preamble;
-       registry_par->scan_mode = (u8)rtw_scan_mode;
-       registry_par->adhoc_tx_pwr = (u8)rtw_adhoc_tx_pwr;
-       registry_par->soft_ap =  (u8)rtw_soft_ap;
-       registry_par->smart_ps =  (u8)rtw_smart_ps;
-       registry_par->power_mgnt = (u8)rtw_power_mgnt;
-       registry_par->ips_mode = (u8)rtw_ips_mode;
-       registry_par->long_retry_lmt = (u8)rtw_long_retry_lmt;
-       registry_par->short_retry_lmt = (u8)rtw_short_retry_lmt;
-       registry_par->busy_thresh = (u16)rtw_busy_thresh;
-       registry_par->ack_policy = (u8)rtw_ack_policy;
-       registry_par->acm_method = (u8)rtw_acm_method;
-        /* UAPSD */
-       registry_par->wmm_enable = (u8)rtw_wmm_enable;
-       registry_par->uapsd_enable = (u8)rtw_uapsd_enable;
-       registry_par->ht_enable = (u8)rtw_ht_enable;
-       registry_par->cbw40_enable = (u8)rtw_cbw40_enable;
-       registry_par->ampdu_enable = (u8)rtw_ampdu_enable;
-       registry_par->rx_stbc = (u8)rtw_rx_stbc;
-       registry_par->ampdu_amsdu = (u8)rtw_ampdu_amsdu;
-       registry_par->lowrate_two_xmit = (u8)rtw_lowrate_two_xmit;
-       registry_par->rf_config = (u8)rtw_rf_config;
-       registry_par->low_power = (u8)rtw_low_power;
-       registry_par->wifi_spec = (u8)rtw_wifi_spec;
-       registry_par->channel_plan = (u8)rtw_channel_plan;
-#ifdef CONFIG_8723AU_BT_COEXIST
-       registry_par->btcoex = (u8)rtw_btcoex_enable;
-       registry_par->bt_iso = (u8)rtw_bt_iso;
-       registry_par->bt_sco = (u8)rtw_bt_sco;
-       registry_par->bt_ampdu = (u8)rtw_bt_ampdu;
-#endif
-       registry_par->bAcceptAddbaReq = (u8)rtw_AcceptAddbaReq;
-       registry_par->antdiv_cfg = (u8)rtw_antdiv_cfg;
-       registry_par->antdiv_type = (u8)rtw_antdiv_type;
-
-       /* 0:disable, 1:enable, 2:by EFUSE config */
-       registry_par->hwpdn_mode = (u8)rtw_hwpdn_mode;
-       /* 0:disable, 1:enable */
-       registry_par->hwpwrp_detect = (u8)rtw_hwpwrp_detect;
-       registry_par->hw_wps_pbc = (u8)rtw_hw_wps_pbc;
-       registry_par->max_roaming_times = (u8)rtw_max_roaming_times;
-       registry_par->enable80211d = (u8)rtw_80211d;
-       snprintf(registry_par->ifname, 16, "%s", ifname);
-       snprintf(registry_par->if2name, 16, "%s", if2name);
-       registry_par->notch_filter = (u8)rtw_notch_filter;
-       registry_par->regulatory_tid = (u8)rtw_regulatory_id;
-}
-
-static int rtw_net_set_mac_address(struct net_device *pnetdev, void *p)
-{
-       struct rtw_adapter *padapter = netdev_priv(pnetdev);
-       struct sockaddr *addr = p;
-
-       if (!padapter->bup)
-               ether_addr_copy(padapter->eeprompriv.mac_addr, addr->sa_data);
-       return 0;
-}
-
-static struct net_device_stats *rtw_net_get_stats(struct net_device *pnetdev)
-{
-       struct rtw_adapter *padapter = netdev_priv(pnetdev);
-       struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-       struct recv_priv *precvpriv = &padapter->recvpriv;
-
-       padapter->stats.tx_packets = pxmitpriv->tx_pkts;
-       padapter->stats.rx_packets = precvpriv->rx_pkts;
-       padapter->stats.tx_dropped = pxmitpriv->tx_drop;
-       padapter->stats.rx_dropped = precvpriv->rx_drop;
-       padapter->stats.tx_bytes = pxmitpriv->tx_bytes;
-       padapter->stats.rx_bytes = precvpriv->rx_bytes;
-
-       return &padapter->stats;
-}
-
-/*
- * AC to queue mapping
- *
- * AC_VO -> queue 0
- * AC_VI -> queue 1
- * AC_BE -> queue 2
- * AC_BK -> queue 3
- */
-static const u16 rtw_1d_to_queue[8] = { 2, 3, 3, 2, 1, 1, 0, 0 };
-
-/* Given a data frame determine the 802.1p/1d tag to use. */
-static u32 rtw_classify8021d(struct sk_buff *skb)
-{
-       u32 dscp;
-
-       /* skb->priority values from 256->263 are magic values to
-        * directly indicate a specific 802.1d priority.  This is used
-        * to allow 802.1d priority to be passed directly in from VLAN
-        * tags, etc.
-        */
-       if (skb->priority >= 256 && skb->priority <= 263)
-               return skb->priority - 256;
-       switch (skb->protocol) {
-       case htons(ETH_P_IP):
-               dscp = ip_hdr(skb)->tos & 0xfc;
-               break;
-       default:
-               return 0;
-       }
-       return dscp >> 5;
-}
-
-static u16 rtw_select_queue(struct net_device *dev, struct sk_buff *skb,
-                           void *accel_priv,
-                           select_queue_fallback_t fallback)
-{
-       struct rtw_adapter *padapter = netdev_priv(dev);
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-
-       skb->priority = rtw_classify8021d(skb);
-
-       if (pmlmepriv->acm_mask != 0)
-               skb->priority = qos_acm23a(pmlmepriv->acm_mask, skb->priority);
-       return rtw_1d_to_queue[skb->priority];
-}
-
-u16 rtw_recv_select_queue23a(struct sk_buff *skb)
-{
-       struct iphdr *piphdr;
-       struct ethhdr *eth = (struct ethhdr *)skb->data;
-       unsigned int dscp;
-       u16 eth_type = get_unaligned_be16(&eth->h_proto);
-       u32 priority;
-       u8 *pdata = skb->data;
-
-       switch (eth_type) {
-       case ETH_P_IP:
-               piphdr = (struct iphdr *)(pdata + ETH_HLEN);
-               dscp = piphdr->tos & 0xfc;
-               priority = dscp >> 5;
-               break;
-       default:
-               priority = 0;
-       }
-       return rtw_1d_to_queue[priority];
-}
-
-static const struct net_device_ops rtw_netdev_ops = {
-       .ndo_open = netdev_open23a,
-       .ndo_stop = netdev_close,
-       .ndo_start_xmit = rtw_xmit23a_entry23a,
-       .ndo_select_queue = rtw_select_queue,
-       .ndo_set_mac_address = rtw_net_set_mac_address,
-       .ndo_get_stats = rtw_net_get_stats,
-};
-
-int rtw_init_netdev23a_name23a(struct net_device *pnetdev, const char *ifname)
-{
-       if (dev_alloc_name(pnetdev, ifname) < 0) {
-               RT_TRACE(_module_os_intfs_c_, _drv_err_,
-                        "dev_alloc_name, fail!\n");
-       }
-       netif_carrier_off(pnetdev);
-       return 0;
-}
-
-static const struct device_type wlan_type = {
-       .name = "wlan",
-};
-
-struct net_device *rtw_init_netdev23a(struct rtw_adapter *old_padapter)
-{
-       struct rtw_adapter *padapter;
-       struct net_device *pnetdev;
-
-       RT_TRACE(_module_os_intfs_c_, _drv_info_, "+init_net_dev\n");
-
-       pnetdev = alloc_etherdev_mq(sizeof(struct rtw_adapter), 4);
-       if (!pnetdev)
-               return NULL;
-
-       pnetdev->dev.type = &wlan_type;
-       padapter = netdev_priv(pnetdev);
-       padapter->pnetdev = pnetdev;
-
-       DBG_8723A("register rtw_netdev_ops to netdev_ops\n");
-       pnetdev->netdev_ops = &rtw_netdev_ops;
-
-       pnetdev->watchdog_timeo = HZ*3; /* 3 second timeout */
-
-       loadparam(padapter, pnetdev);
-       return pnetdev;
-}
-
-static int rtw_init_default_value(struct rtw_adapter *padapter)
-{
-       struct registry_priv *pregistrypriv = &padapter->registrypriv;
-       struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct security_priv *psecuritypriv = &padapter->securitypriv;
-
-       /* xmit_priv */
-       pxmitpriv->vcs = pregistrypriv->vcs_type;
-       /* pxmitpriv->rts_thresh = pregistrypriv->rts_thresh; */
-       pxmitpriv->frag_len = pregistrypriv->frag_thresh;
-
-       /* mlme_priv */
-       pmlmepriv->scan_interval = SCAN_INTERVAL;/*  30*2 sec = 60sec */
-       pmlmepriv->scan_mode = SCAN_ACTIVE;
-
-       /* ht_priv */
-       pmlmepriv->htpriv.ampdu_enable = false;/* set to disabled */
-
-       /* security_priv */
-       psecuritypriv->binstallGrpkey = 0;
-
-        /* open system */
-       psecuritypriv->dot11AuthAlgrthm = dot11AuthAlgrthm_Open;
-       psecuritypriv->dot11PrivacyAlgrthm = 0;
-
-       psecuritypriv->dot11PrivacyKeyIndex = 0;
-
-       psecuritypriv->dot118021XGrpPrivacy = 0;
-       psecuritypriv->dot118021XGrpKeyid = 1;
-
-       psecuritypriv->ndisauthtype = Ndis802_11AuthModeOpen;
-       psecuritypriv->ndisencryptstatus = Ndis802_11WEPDisabled;
-
-       /* registry_priv */
-       rtw_init_registrypriv_dev_network23a(padapter);
-       rtw_update_registrypriv_dev_network23a(padapter);
-
-       /* hal_priv */
-       rtl8723a_init_default_value(padapter);
-
-       /* misc. */
-       padapter->bReadPortCancel = false;
-       padapter->bWritePortCancel = false;
-       return _SUCCESS;
-}
-
-int rtw_reset_drv_sw23a(struct rtw_adapter *padapter)
-{
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct pwrctrl_priv *pwrctrlpriv = &padapter->pwrctrlpriv;
-
-       /* hal_priv */
-       rtl8723a_init_default_value(padapter);
-       padapter->bReadPortCancel = false;
-       padapter->bWritePortCancel = false;
-       pmlmepriv->scan_interval = SCAN_INTERVAL;/*  30*2 sec = 60sec */
-
-       padapter->xmitpriv.tx_pkts = 0;
-       padapter->recvpriv.rx_pkts = 0;
-
-       pmlmepriv->LinkDetectInfo.bBusyTraffic = false;
-
-       _clr_fwstate_(pmlmepriv, _FW_UNDER_SURVEY | _FW_UNDER_LINKING);
-
-       rtw_sreset_reset_value(padapter);
-       pwrctrlpriv->pwr_state_check_cnts = 0;
-
-       /* mlmeextpriv */
-       padapter->mlmeextpriv.sitesurvey_res.state = SCAN_DISABLE;
-
-       rtw_set_signal_stat_timer(&padapter->recvpriv);
-       return _SUCCESS;
-}
-
-int rtw_init_drv_sw23a(struct rtw_adapter *padapter)
-{
-       int ret8 = _SUCCESS;
-
-       RT_TRACE(_module_os_intfs_c_, _drv_info_, "+rtw_init_drv_sw23a\n");
-
-       if (rtw_init_cmd_priv23a(&padapter->cmdpriv) == _FAIL) {
-               RT_TRACE(_module_os_intfs_c_, _drv_err_,
-                        "Can't init cmd_priv\n");
-               ret8 = _FAIL;
-               goto exit;
-       }
-
-       padapter->cmdpriv.padapter = padapter;
-
-       if (rtw_init_evt_priv23a(&padapter->evtpriv) == _FAIL) {
-               RT_TRACE(_module_os_intfs_c_, _drv_err_,
-                        "Can't init evt_priv\n");
-               ret8 = _FAIL;
-               goto exit;
-       }
-
-       if (rtw_init_mlme_priv23a(padapter) == _FAIL) {
-               RT_TRACE(_module_os_intfs_c_, _drv_err_,
-                        "Can't init mlme_priv\n");
-               ret8 = _FAIL;
-               goto exit;
-       }
-
-
-       if (init_mlme_ext_priv23a(padapter) == _FAIL) {
-               RT_TRACE(_module_os_intfs_c_, _drv_err_,
-                        "Can't init mlme_ext_priv\n");
-               ret8 = _FAIL;
-               goto exit;
-       }
-
-       if (_rtw_init_xmit_priv23a(&padapter->xmitpriv, padapter) == _FAIL) {
-               DBG_8723A("Can't _rtw_init_xmit_priv23a\n");
-               ret8 = _FAIL;
-               goto exit;
-       }
-
-       if (_rtw_init_recv_priv23a(&padapter->recvpriv, padapter) == _FAIL) {
-               DBG_8723A("Can't _rtw_init_recv_priv23a\n");
-               ret8 = _FAIL;
-               goto exit;
-       }
-
-       if (_rtw_init_sta_priv23a(&padapter->stapriv) == _FAIL) {
-               DBG_8723A("Can't _rtw_init_sta_priv23a\n");
-               ret8 = _FAIL;
-               goto exit;
-       }
-
-       padapter->stapriv.padapter = padapter;
-       padapter->setband = GHZ24_50;
-       rtw_init_bcmc_stainfo23a(padapter);
-
-       rtw_init_pwrctrl_priv23a(padapter);
-
-       ret8 = rtw_init_default_value(padapter);
-
-       rtl8723a_init_dm_priv(padapter);
-
-       rtw_sreset_init(padapter);
-
-exit:
-
-       RT_TRACE(_module_os_intfs_c_, _drv_info_, "-rtw_init_drv_sw23a\n");
-       return ret8;
-}
-
-void rtw_cancel_all_timer23a(struct rtw_adapter *padapter)
-{
-       RT_TRACE(_module_os_intfs_c_, _drv_info_,
-                "+rtw_cancel_all_timer23a\n");
-
-       del_timer_sync(&padapter->mlmepriv.assoc_timer);
-       RT_TRACE(_module_os_intfs_c_, _drv_info_,
-                "%s:cancel association timer complete!\n", __func__);
-
-       del_timer_sync(&padapter->mlmepriv.scan_to_timer);
-       RT_TRACE(_module_os_intfs_c_, _drv_info_,
-                "%s:cancel scan_to_timer!\n", __func__);
-
-       del_timer_sync(&padapter->mlmepriv.dynamic_chk_timer);
-       RT_TRACE(_module_os_intfs_c_, _drv_info_,
-                "%s:cancel dynamic_chk_timer!\n", __func__);
-
-       del_timer_sync(&padapter->pwrctrlpriv.pwr_state_check_timer);
-
-       del_timer_sync(&padapter->mlmepriv.set_scan_deny_timer);
-       rtw_clear_scan_deny(padapter);
-       RT_TRACE(_module_os_intfs_c_, _drv_info_,
-                "%s:cancel set_scan_deny_timer!\n", __func__);
-
-       del_timer_sync(&padapter->recvpriv.signal_stat_timer);
-}
-
-int rtw_free_drv_sw23a(struct rtw_adapter *padapter)
-{
-       RT_TRACE(_module_os_intfs_c_, _drv_info_, "==>rtw_free_drv_sw23a\n");
-
-       free_mlme_ext_priv23a(&padapter->mlmeextpriv);
-
-       rtw_free_evt_priv23a(&padapter->evtpriv);
-
-       rtw_free_mlme_priv23a(&padapter->mlmepriv);
-
-       _rtw_free_xmit_priv23a(&padapter->xmitpriv);
-
-       /* will free bcmc_stainfo here */
-       _rtw_free_sta_priv23a(&padapter->stapriv);
-
-       _rtw_free_recv_priv23a(&padapter->recvpriv);
-
-       rtw_free_pwrctrl_priv(padapter);
-
-       kfree(padapter->HalData);
-       padapter->HalData = NULL;
-
-       RT_TRACE(_module_os_intfs_c_, _drv_info_, "-rtw_free_drv_sw23a\n");
-       return _SUCCESS;
-}
-
-static int _rtw_drv_register_netdev(struct rtw_adapter *padapter, char *name)
-{
-       struct net_device *pnetdev = padapter->pnetdev;
-       int ret = _SUCCESS;
-
-       /* alloc netdev name */
-       rtw_init_netdev23a_name23a(pnetdev, name);
-
-       ether_addr_copy(pnetdev->dev_addr, padapter->eeprompriv.mac_addr);
-
-       /* Tell the network stack we exist */
-       if (register_netdev(pnetdev)) {
-               DBG_8723A("%s(%s): Failed!\n", __func__, pnetdev->name);
-               ret = _FAIL;
-               goto error_register_netdev;
-       }
-       DBG_8723A("%s, MAC Address (if%d) = %pM\n",
-                 __func__, padapter->iface_id + 1, pnetdev->dev_addr);
-       return ret;
-
-error_register_netdev:
-
-       if (padapter->iface_id > IFACE_ID0) {
-               rtw_free_drv_sw23a(padapter);
-
-               free_netdev(pnetdev);
-       }
-       return ret;
-}
-
-int rtw_drv_register_netdev(struct rtw_adapter *if1)
-{
-       struct dvobj_priv *dvobj = if1->dvobj;
-       int i, status = _SUCCESS;
-
-       if (dvobj->iface_nums >= IFACE_ID_MAX) {
-               status = _FAIL; /* -EINVAL */
-               goto exit;
-       }
-
-       for (i = 0; i < dvobj->iface_nums; i++) {
-               struct rtw_adapter *padapter = dvobj->padapters[i];
-
-               if (padapter) {
-                       char *name;
-
-                       if (padapter->iface_id == IFACE_ID0)
-                               name = if1->registrypriv.ifname;
-                       else if (padapter->iface_id == IFACE_ID1)
-                               name = if1->registrypriv.if2name;
-                       else
-                               name = "wlan%d";
-                       status = _rtw_drv_register_netdev(padapter, name);
-                       if (status != _SUCCESS)
-                               break;
-               }
-       }
-
-exit:
-       return status;
-}
-
-int netdev_open23a(struct net_device *pnetdev)
-{
-       struct rtw_adapter *padapter = netdev_priv(pnetdev);
-       struct pwrctrl_priv *pwrctrlpriv;
-       int ret = 0;
-       int status;
-
-       RT_TRACE(_module_os_intfs_c_, _drv_info_, "+871x_drv - dev_open\n");
-       DBG_8723A("+871x_drv - drv_open, bup =%d\n", padapter->bup);
-
-       mutex_lock(&adapter_to_dvobj(padapter)->hw_init_mutex);
-
-       pwrctrlpriv = &padapter->pwrctrlpriv;
-
-       if (!padapter->bup) {
-               padapter->bDriverStopped = false;
-               padapter->bSurpriseRemoved = false;
-               padapter->bCardDisableWOHSM = false;
-
-               status = rtl8723au_hal_init(padapter);
-               if (status == _FAIL) {
-                       RT_TRACE(_module_os_intfs_c_, _drv_err_,
-                                "rtl871x_hal_init(): Can't init h/w!\n");
-                       goto netdev_open23a_error;
-               }
-
-               DBG_8723A("MAC Address = %pM\n", pnetdev->dev_addr);
-
-               if (init_hw_mlme_ext23a(padapter) == _FAIL) {
-                       DBG_8723A("can't init mlme_ext_priv\n");
-                       goto netdev_open23a_error;
-               }
-
-               rtl8723au_inirp_init(padapter);
-
-               rtw_cfg80211_init_wiphy(padapter);
-
-               padapter->bup = true;
-       }
-       padapter->net_closed = false;
-
-       mod_timer(&padapter->mlmepriv.dynamic_chk_timer,
-                 jiffies + msecs_to_jiffies(2000));
-
-       padapter->pwrctrlpriv.bips_processing = false;
-       rtw_set_pwr_state_check_timer(&padapter->pwrctrlpriv);
-
-       /* netif_carrier_on(pnetdev);call this func when
-          rtw23a_joinbss_event_cb return success */
-       if (!rtw_netif_queue_stopped(pnetdev))
-               netif_tx_start_all_queues(pnetdev);
-       else
-               netif_tx_wake_all_queues(pnetdev);
-
-       RT_TRACE(_module_os_intfs_c_, _drv_info_, "-871x_drv - dev_open\n");
-       DBG_8723A("-871x_drv - drv_open, bup =%d\n", padapter->bup);
-exit:
-       mutex_unlock(&adapter_to_dvobj(padapter)->hw_init_mutex);
-       return ret;
-
-netdev_open23a_error:
-       padapter->bup = false;
-
-       netif_carrier_off(pnetdev);
-       netif_tx_stop_all_queues(pnetdev);
-
-       RT_TRACE(_module_os_intfs_c_, _drv_err_,
-                "-871x_drv - dev_open, fail!\n");
-       DBG_8723A("-871x_drv - drv_open fail, bup =%d\n", padapter->bup);
-
-       ret = -1;
-       goto exit;
-}
-
-static int ips_netdrv_open(struct rtw_adapter *padapter)
-{
-       int status = _SUCCESS;
-
-       padapter->net_closed = false;
-       DBG_8723A("===> %s.........\n", __func__);
-
-       padapter->bDriverStopped = false;
-       padapter->bSurpriseRemoved = false;
-       padapter->bCardDisableWOHSM = false;
-
-       status = rtl8723au_hal_init(padapter);
-       if (status == _FAIL) {
-               RT_TRACE(_module_os_intfs_c_, _drv_err_,
-                        "ips_netdrv_open(): Can't init h/w!\n");
-               goto netdev_open23a_error;
-       }
-
-       rtl8723au_inirp_init(padapter);
-
-       rtw_set_pwr_state_check_timer(&padapter->pwrctrlpriv);
-       mod_timer(&padapter->mlmepriv.dynamic_chk_timer,
-                 jiffies + msecs_to_jiffies(5000));
-
-       return _SUCCESS;
-
-netdev_open23a_error:
-       /* padapter->bup = false; */
-       DBG_8723A("-ips_netdrv_open - drv_open failure, bup =%d\n",
-                 padapter->bup);
-
-       return _FAIL;
-}
-
-int rtw_ips_pwr_up23a(struct rtw_adapter *padapter)
-{
-       int result;
-       unsigned long start_time = jiffies;
-
-       DBG_8723A("===>  rtw_ips_pwr_up23a..............\n");
-       rtw_reset_drv_sw23a(padapter);
-
-       result = ips_netdrv_open(padapter);
-
-       DBG_8723A("<===  rtw_ips_pwr_up23a.............. in %dms\n",
-                 jiffies_to_msecs(jiffies - start_time));
-       return result;
-}
-
-void rtw_ips_pwr_down23a(struct rtw_adapter *padapter)
-{
-       unsigned long start_time = jiffies;
-
-       DBG_8723A("===> rtw_ips_pwr_down23a...................\n");
-
-       padapter->bCardDisableWOHSM = true;
-       padapter->net_closed = true;
-
-       rtw_ips_dev_unload23a(padapter);
-       padapter->bCardDisableWOHSM = false;
-       DBG_8723A("<=== rtw_ips_pwr_down23a..................... in %dms\n",
-                 jiffies_to_msecs(jiffies - start_time));
-}
-
-void rtw_ips_dev_unload23a(struct rtw_adapter *padapter)
-{
-       rtl8723a_fifo_cleanup(padapter);
-
-       rtl8723a_usb_intf_stop(padapter);
-
-       /* s5. */
-       if (!padapter->bSurpriseRemoved)
-               rtl8723au_hal_deinit(padapter);
-}
-
-int pm_netdev_open23a(struct net_device *pnetdev, u8 bnormal)
-{
-       int status;
-
-       if (bnormal)
-               status = netdev_open23a(pnetdev);
-       else
-               status = (_SUCCESS == ips_netdrv_open(netdev_priv(pnetdev))) ?
-                        (0) : (-1);
-
-       return status;
-}
-
-static int netdev_close(struct net_device *pnetdev)
-{
-       struct rtw_adapter *padapter = netdev_priv(pnetdev);
-
-       RT_TRACE(_module_os_intfs_c_, _drv_info_, "+871x_drv - drv_close\n");
-
-       padapter->net_closed = true;
-
-       if (padapter->pwrctrlpriv.rf_pwrstate == rf_on) {
-               DBG_8723A("(2)871x_drv - drv_close, bup =%d, "
-                         "hw_init_completed =%d\n", padapter->bup,
-                         padapter->hw_init_completed);
-
-               /* s1. */
-               if (pnetdev) {
-                       if (!rtw_netif_queue_stopped(pnetdev))
-                               netif_tx_stop_all_queues(pnetdev);
-               }
-
-               /* s2. */
-               LeaveAllPowerSaveMode23a(padapter);
-               rtw_disassoc_cmd23a(padapter, 500, false);
-               /* s2-2.  indicate disconnect to os */
-               rtw_indicate_disconnect23a(padapter);
-               /* s2-3. */
-               rtw_free_assoc_resources23a(padapter, 1);
-               /* s2-4. */
-               rtw_free_network_queue23a(padapter);
-       }
-
-       rtw_scan_abort23a(padapter);
-
-       RT_TRACE(_module_os_intfs_c_, _drv_info_, "-871x_drv - drv_close\n");
-       DBG_8723A("-871x_drv - drv_close, bup =%d\n", padapter->bup);
-
-       return 0;
-}
-
-void rtw_ndev_destructor(struct net_device *ndev)
-{
-       DBG_8723A("%s(%s)\n", __func__, ndev->name);
-       kfree(ndev->ieee80211_ptr);
-       free_netdev(ndev);
-}
-
-void _rtw_init_queue23a(struct rtw_queue *pqueue)
-{
-       INIT_LIST_HEAD(&pqueue->queue);
-       spin_lock_init(&pqueue->lock);
-}
diff --git a/drivers/staging/rtl8723au/os_dep/recv_linux.c b/drivers/staging/rtl8723au/os_dep/recv_linux.c
deleted file mode 100644 (file)
index 084b506..0000000
+++ /dev/null
@@ -1,165 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#define _RECV_OSDEP_C_
-
-#include <osdep_service.h>
-#include <drv_types.h>
-
-#include <wifi.h>
-#include <recv_osdep.h>
-
-#include <osdep_intf.h>
-
-#include <usb_ops.h>
-
-void rtw_handle_tkip_mic_err23a(struct rtw_adapter *padapter, u8 bgroup)
-{
-       enum nl80211_key_type key_type = 0;
-       union iwreq_data wrqu;
-       struct iw_michaelmicfailure ev;
-       struct mlme_priv *pmlmepriv  = &padapter->mlmepriv;
-       struct security_priv *psecuritypriv = &padapter->securitypriv;
-       unsigned long cur_time;
-
-       if (psecuritypriv->last_mic_err_time == 0) {
-               psecuritypriv->last_mic_err_time = jiffies;
-       } else {
-               cur_time = jiffies;
-
-               if (cur_time - psecuritypriv->last_mic_err_time < 60*HZ) {
-                       psecuritypriv->btkip_countermeasure = true;
-                       psecuritypriv->last_mic_err_time = 0;
-                       psecuritypriv->btkip_countermeasure_time = cur_time;
-               } else {
-                       psecuritypriv->last_mic_err_time = jiffies;
-               }
-       }
-
-       if (bgroup)
-               key_type |= NL80211_KEYTYPE_GROUP;
-       else
-               key_type |= NL80211_KEYTYPE_PAIRWISE;
-
-       cfg80211_michael_mic_failure(padapter->pnetdev,
-                                    (u8 *)&pmlmepriv->assoc_bssid[0],
-                                    key_type, -1, NULL, GFP_ATOMIC);
-
-       memset(&ev, 0x00, sizeof(ev));
-       if (bgroup)
-               ev.flags |= IW_MICFAILURE_GROUP;
-       else
-               ev.flags |= IW_MICFAILURE_PAIRWISE;
-
-       ev.src_addr.sa_family = ARPHRD_ETHER;
-       ether_addr_copy(ev.src_addr.sa_data, &pmlmepriv->assoc_bssid[0]);
-
-       memset(&wrqu, 0x00, sizeof(wrqu));
-       wrqu.data.length = sizeof(ev);
-}
-
-int rtw_recv_indicatepkt23a(struct rtw_adapter *padapter,
-                        struct recv_frame *precv_frame)
-{
-       struct recv_priv *precvpriv;
-       struct sk_buff *skb;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-
-       precvpriv = &padapter->recvpriv;
-
-       skb = precv_frame->pkt;
-       if (!skb) {
-               RT_TRACE(_module_recv_osdep_c_, _drv_err_,
-                        "rtw_recv_indicatepkt23a():skb == NULL!!!!\n");
-               goto _recv_indicatepkt_drop;
-       }
-
-       RT_TRACE(_module_recv_osdep_c_, _drv_info_,
-                "rtw_recv_indicatepkt23a():skb != NULL !!!\n");
-       RT_TRACE(_module_recv_osdep_c_, _drv_info_,
-                "rtw_recv_indicatepkt23a():precv_frame->hdr.rx_data =%p\n",
-                precv_frame->pkt->data);
-       RT_TRACE(_module_recv_osdep_c_, _drv_info_,
-                "skb->head =%p skb->data =%p skb->tail =%p skb->end =%p skb->len =%d\n",
-                skb->head, skb->data,
-                skb_tail_pointer(skb), skb_end_pointer(skb), skb->len);
-
-       if (check_fwstate(pmlmepriv, WIFI_AP_STATE) == true) {
-               struct sk_buff *pskb2 = NULL;
-               struct sta_info *psta = NULL;
-               struct sta_priv *pstapriv = &padapter->stapriv;
-               struct rx_pkt_attrib *pattrib = &precv_frame->attrib;
-               int bmcast = is_multicast_ether_addr(pattrib->dst);
-
-               /* DBG_8723A("bmcast =%d\n", bmcast); */
-
-               if (!ether_addr_equal(pattrib->dst,
-                                     myid(&padapter->eeprompriv))) {
-                       /* DBG_8723A("not ap psta =%p, addr =%pM\n", psta, pattrib->dst); */
-                       if (bmcast) {
-                               psta = rtw_get_bcmc_stainfo23a(padapter);
-                               pskb2 = skb_clone(skb, GFP_ATOMIC);
-                       } else {
-                               psta = rtw_get_stainfo23a(pstapriv, pattrib->dst);
-                       }
-
-                       if (psta) {
-                               struct net_device *pnetdev = padapter->pnetdev;
-
-                               /* DBG_8723A("directly forwarding to the rtw_xmit23a_entry23a\n"); */
-
-                               /* skb->ip_summed = CHECKSUM_NONE; */
-                               skb->dev = pnetdev;
-                               skb_set_queue_mapping(skb, rtw_recv_select_queue23a(skb));
-
-                               rtw_xmit23a_entry23a(skb, pnetdev);
-
-                               if (bmcast)
-                                       skb = pskb2;
-                               else
-                                       goto _recv_indicatepkt_end;
-                       }
-               } else { /*  to APself */
-                       /* DBG_8723A("to APSelf\n"); */
-               }
-       }
-
-       skb->ip_summed = CHECKSUM_NONE;
-       skb->dev = padapter->pnetdev;
-       skb->protocol = eth_type_trans(skb, padapter->pnetdev);
-
-       netif_rx(skb);
-
-_recv_indicatepkt_end:
-
-       precv_frame->pkt = NULL; /*  pointers to NULL before rtw_free_recvframe23a() */
-
-       rtw_free_recvframe23a(precv_frame);
-
-       RT_TRACE(_module_recv_osdep_c_, _drv_info_,
-                "rtw_recv_indicatepkt23a :after netif_rx!!!!\n");
-       return _SUCCESS;
-
-_recv_indicatepkt_drop:
-
-        rtw_free_recvframe23a(precv_frame);
-        return _FAIL;
-}
-
-void rtw_init_recv_timer23a(struct recv_reorder_ctrl *preorder_ctrl)
-{
-       setup_timer(&preorder_ctrl->reordering_ctrl_timer,
-                   rtw_reordering_ctrl_timeout_handler23a,
-                   (unsigned long)preorder_ctrl);
-}
diff --git a/drivers/staging/rtl8723au/os_dep/usb_intf.c b/drivers/staging/rtl8723au/os_dep/usb_intf.c
deleted file mode 100644 (file)
index fa7dda5..0000000
+++ /dev/null
@@ -1,628 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#define _HCI_INTF_C_
-
-#include <linux/mutex.h>
-#include <osdep_service.h>
-#include <drv_types.h>
-#include <recv_osdep.h>
-#include <xmit_osdep.h>
-#include <hal_intf.h>
-#include <rtw_version.h>
-#include <osdep_intf.h>
-#include <usb_ops.h>
-#include <rtl8723a_hal.h>
-
-static int rtw_suspend(struct usb_interface *intf, pm_message_t message);
-static int rtw_resume(struct usb_interface *intf);
-static int rtw_drv_init(struct usb_interface *pusb_intf,
-                       const struct usb_device_id *pdid);
-static void rtw_disconnect(struct usb_interface *pusb_intf);
-
-#define USB_VENDER_ID_REALTEK          0x0BDA
-
-#define RTL8723A_USB_IDS \
-       {USB_DEVICE_AND_INTERFACE_INFO(USB_VENDER_ID_REALTEK, 0x8724,   \
-        0xff, 0xff, 0xff)}, /* 8723AU 1*1 */ \
-       {USB_DEVICE_AND_INTERFACE_INFO(USB_VENDER_ID_REALTEK, 0x1724,   \
-        0xff, 0xff, 0xff)}, /* 8723AU 1*1 */ \
-       {USB_DEVICE_AND_INTERFACE_INFO(USB_VENDER_ID_REALTEK, 0x0724,   \
-        0xff, 0xff, 0xff)}, /* 8723AU 1*1 */
-
-static struct usb_device_id rtl8723a_usb_id_tbl[] = {
-       RTL8723A_USB_IDS
-       {}      /* Terminating entry */
-};
-
-MODULE_DEVICE_TABLE(usb, rtl8723a_usb_id_tbl);
-
-static struct usb_driver rtl8723a_usb_drv = {
-       .name = (char *)"rtl8723au",
-       .probe = rtw_drv_init,
-       .disconnect = rtw_disconnect,
-       .id_table = rtl8723a_usb_id_tbl,
-       .suspend = rtw_suspend,
-       .resume = rtw_resume,
-       .reset_resume  = rtw_resume,
-};
-
-static struct usb_driver *usb_drv = &rtl8723a_usb_drv;
-
-static int rtw_init_intf_priv(struct dvobj_priv *dvobj)
-{
-       mutex_init(&dvobj->usb_vendor_req_mutex);
-
-       return _SUCCESS;
-}
-
-static int rtw_deinit_intf_priv(struct dvobj_priv *dvobj)
-{
-       mutex_destroy(&dvobj->usb_vendor_req_mutex);
-
-       return _SUCCESS;
-}
-
-static struct dvobj_priv *usb_dvobj_init(struct usb_interface *usb_intf)
-{
-       struct dvobj_priv *pdvobjpriv;
-       struct usb_host_config   *phost_conf;
-       struct usb_config_descriptor *pconf_desc;
-       struct usb_host_interface *phost_iface;
-       struct usb_interface_descriptor *piface_desc;
-       struct usb_endpoint_descriptor *pendp_desc;
-       struct usb_device *pusbd;
-       int i, status = _FAIL;
-
-       pdvobjpriv = kzalloc(sizeof(*pdvobjpriv), GFP_KERNEL);
-       if (!pdvobjpriv)
-               goto exit;
-
-       mutex_init(&pdvobjpriv->hw_init_mutex);
-       mutex_init(&pdvobjpriv->h2c_fwcmd_mutex);
-       mutex_init(&pdvobjpriv->setch_mutex);
-       mutex_init(&pdvobjpriv->setbw_mutex);
-
-       pdvobjpriv->pusbintf = usb_intf;
-       pusbd = interface_to_usbdev(usb_intf);
-       pdvobjpriv->pusbdev = pusbd;
-       usb_set_intfdata(usb_intf, pdvobjpriv);
-
-       pdvobjpriv->RtNumInPipes = 0;
-       pdvobjpriv->RtNumOutPipes = 0;
-
-       phost_conf = pusbd->actconfig;
-       pconf_desc = &phost_conf->desc;
-
-       phost_iface = &usb_intf->altsetting[0];
-       piface_desc = &phost_iface->desc;
-
-       pdvobjpriv->NumInterfaces = pconf_desc->bNumInterfaces;
-       pdvobjpriv->InterfaceNumber = piface_desc->bInterfaceNumber;
-       pdvobjpriv->nr_endpoint = piface_desc->bNumEndpoints;
-
-       for (i = 0; i < pdvobjpriv->nr_endpoint; i++) {
-               pendp_desc = &phost_iface->endpoint[i].desc;
-
-               DBG_8723A("\nusb_endpoint_descriptor(%d):\n", i);
-               DBG_8723A("bLength =%x\n", pendp_desc->bLength);
-               DBG_8723A("bDescriptorType =%x\n", pendp_desc->bDescriptorType);
-               DBG_8723A("bEndpointAddress =%x\n",
-                         pendp_desc->bEndpointAddress);
-               DBG_8723A("wMaxPacketSize =%d\n",
-                         le16_to_cpu(pendp_desc->wMaxPacketSize));
-               DBG_8723A("bInterval =%x\n", pendp_desc->bInterval);
-
-               if (usb_endpoint_is_bulk_in(pendp_desc)) {
-                       DBG_8723A("usb_endpoint_is_bulk_in = %x\n",
-                                 usb_endpoint_num(pendp_desc));
-                       pdvobjpriv->RtInPipe[pdvobjpriv->RtNumInPipes] =
-                               usb_endpoint_num(pendp_desc);
-                       pdvobjpriv->RtNumInPipes++;
-               } else if (usb_endpoint_is_int_in(pendp_desc)) {
-                       DBG_8723A("usb_endpoint_is_int_in = %x, Interval = "
-                                 "%x\n", usb_endpoint_num(pendp_desc),
-                                 pendp_desc->bInterval);
-                       pdvobjpriv->RtInPipe[pdvobjpriv->RtNumInPipes] =
-                               usb_endpoint_num(pendp_desc);
-                       pdvobjpriv->RtNumInPipes++;
-               } else if (usb_endpoint_is_bulk_out(pendp_desc)) {
-                       DBG_8723A("usb_endpoint_is_bulk_out = %x\n",
-                                 usb_endpoint_num(pendp_desc));
-                       pdvobjpriv->RtOutPipe[pdvobjpriv->RtNumOutPipes] =
-                               usb_endpoint_num(pendp_desc);
-                       pdvobjpriv->RtNumOutPipes++;
-               }
-               pdvobjpriv->ep_num[i] = usb_endpoint_num(pendp_desc);
-       }
-       DBG_8723A("nr_endpoint =%d, in_num =%d, out_num =%d\n\n",
-                 pdvobjpriv->nr_endpoint, pdvobjpriv->RtNumInPipes,
-                 pdvobjpriv->RtNumOutPipes);
-
-       if (pusbd->speed == USB_SPEED_HIGH) {
-               pdvobjpriv->ishighspeed = true;
-               DBG_8723A("USB_SPEED_HIGH\n");
-       } else {
-               pdvobjpriv->ishighspeed = false;
-               DBG_8723A("NON USB_SPEED_HIGH\n");
-       }
-
-       if (rtw_init_intf_priv(pdvobjpriv) == _FAIL) {
-               RT_TRACE(_module_os_intfs_c_, _drv_err_,
-                        "Can't INIT rtw_init_intf_priv\n");
-               goto free_dvobj;
-       }
-       /* 3 misc */
-       rtw_reset_continual_urb_error(pdvobjpriv);
-       usb_get_dev(pusbd);
-       status = _SUCCESS;
-free_dvobj:
-       if (status != _SUCCESS && pdvobjpriv) {
-               usb_set_intfdata(usb_intf, NULL);
-               mutex_destroy(&pdvobjpriv->hw_init_mutex);
-               mutex_destroy(&pdvobjpriv->h2c_fwcmd_mutex);
-               mutex_destroy(&pdvobjpriv->setch_mutex);
-               mutex_destroy(&pdvobjpriv->setbw_mutex);
-               kfree(pdvobjpriv);
-               pdvobjpriv = NULL;
-       }
-exit:
-       return pdvobjpriv;
-}
-
-static void usb_dvobj_deinit(struct usb_interface *usb_intf)
-{
-       struct dvobj_priv *dvobj = usb_get_intfdata(usb_intf);
-
-       usb_set_intfdata(usb_intf, NULL);
-       if (dvobj) {
-               /* Modify condition for 92DU DMDP 2010.11.18, by Thomas */
-               if ((dvobj->NumInterfaces != 2 && dvobj->NumInterfaces != 3) ||
-                   (dvobj->InterfaceNumber == 1)) {
-                       if (interface_to_usbdev(usb_intf)->state !=
-                           USB_STATE_NOTATTACHED) {
-                               /* If we didn't unplug usb dongle and
-                                * remove/insert module, driver fails on
-                                * sitesurvey for the first time when
-                                * device is up .
-                                * Reset usb port for sitesurvey fail issue.
-                                */
-                               DBG_8723A("usb attached..., try to reset usb device\n");
-                               usb_reset_device(interface_to_usbdev(usb_intf));
-                       }
-               }
-               rtw_deinit_intf_priv(dvobj);
-               mutex_destroy(&dvobj->hw_init_mutex);
-               mutex_destroy(&dvobj->h2c_fwcmd_mutex);
-               mutex_destroy(&dvobj->setch_mutex);
-               mutex_destroy(&dvobj->setbw_mutex);
-               kfree(dvobj);
-       }
-       usb_put_dev(interface_to_usbdev(usb_intf));
-}
-
-void rtl8723a_usb_intf_stop(struct rtw_adapter *padapter)
-{
-       RT_TRACE(_module_hci_intfs_c_, _drv_err_, "+usb_intf_stop\n");
-
-       /* disable_hw_interrupt */
-       if (!padapter->bSurpriseRemoved) {
-               /* device still exists, so driver can do i/o operation
-                * TODO:
-                */
-               RT_TRACE(_module_hci_intfs_c_, _drv_err_,
-                        "SurpriseRemoved == false\n");
-       }
-
-       /* cancel in irp */
-       rtl8723au_inirp_deinit(padapter);
-
-       /* cancel out irp */
-       rtl8723au_write_port_cancel(padapter);
-
-       /* todo:cancel other irps */
-       RT_TRACE(_module_hci_intfs_c_, _drv_err_, "-usb_intf_stop\n");
-}
-
-static void rtw_dev_unload(struct rtw_adapter *padapter)
-{
-       struct submit_ctx *pack_tx_ops = &padapter->xmitpriv.ack_tx_ops;
-
-       RT_TRACE(_module_hci_intfs_c_, _drv_err_, "+rtw_dev_unload\n");
-
-       if (padapter->bup) {
-               DBG_8723A("===> rtw_dev_unload\n");
-
-               padapter->bDriverStopped = true;
-               if (padapter->xmitpriv.ack_tx)
-                       rtw23a_sctx_done_err(&pack_tx_ops,
-                                            RTW_SCTX_DONE_DRV_STOP);
-
-               /* s3. */
-               rtl8723a_usb_intf_stop(padapter);
-
-               /* s4. */
-               flush_workqueue(padapter->cmdpriv.wq);
-
-               /* s5. */
-               if (!padapter->bSurpriseRemoved) {
-                       rtl8723au_hal_deinit(padapter);
-                       padapter->bSurpriseRemoved = true;
-               }
-               padapter->bup = false;
-       } else {
-               RT_TRACE(_module_hci_intfs_c_, _drv_err_,
-                        "r871x_dev_unload():padapter->bup == false\n");
-       }
-       DBG_8723A("<=== rtw_dev_unload\n");
-       RT_TRACE(_module_hci_intfs_c_, _drv_err_, "-rtw_dev_unload\n");
-}
-
-static int rtw_suspend(struct usb_interface *pusb_intf, pm_message_t message)
-{
-       struct dvobj_priv *dvobj = usb_get_intfdata(pusb_intf);
-       struct rtw_adapter *padapter = dvobj->if1;
-       struct net_device *pnetdev = padapter->pnetdev;
-       struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
-       struct pwrctrl_priv *pwrpriv = &padapter->pwrctrlpriv;
-       int ret = 0;
-       unsigned long start_time = jiffies;
-
-       DBG_8723A("==> %s (%s:%d)\n", __func__, current->comm, current->pid);
-
-       if ((!padapter->bup) || (padapter->bDriverStopped) ||
-           (padapter->bSurpriseRemoved)) {
-               DBG_8723A("padapter->bup =%d bDriverStopped =%d bSurpriseRemoved = %d\n",
-                         padapter->bup, padapter->bDriverStopped,
-                         padapter->bSurpriseRemoved);
-               goto exit;
-       }
-       pwrpriv->bInSuspend = true;
-       rtw_cancel_all_timer23a(padapter);
-       LeaveAllPowerSaveMode23a(padapter);
-
-       mutex_lock(&pwrpriv->mutex_lock);
-       /* padapter->net_closed = true; */
-       /* s1. */
-       if (pnetdev) {
-               netif_carrier_off(pnetdev);
-               netif_tx_stop_all_queues(pnetdev);
-       }
-
-       /* s2. */
-       rtw_disassoc_cmd23a(padapter, 0, false);
-
-       if (check_fwstate(pmlmepriv, WIFI_STATION_STATE) &&
-           check_fwstate(pmlmepriv, _FW_LINKED)) {
-               DBG_8723A("%s:%d %s(%pM), length:%d assoc_ssid.length:%d\n",
-                         __func__, __LINE__,
-                         pmlmepriv->cur_network.network.Ssid.ssid,
-                         pmlmepriv->cur_network.network.MacAddress,
-                         pmlmepriv->cur_network.network.Ssid.ssid_len,
-                         pmlmepriv->assoc_ssid.ssid_len);
-
-               rtw_set_roaming(padapter, 1);
-       }
-       /* s2-2.  indicate disconnect to os */
-       rtw_indicate_disconnect23a(padapter);
-       /* s2-3. */
-       rtw_free_assoc_resources23a(padapter, 1);
-       /* s2-4. */
-       rtw_free_network_queue23a(padapter);
-
-       rtw_dev_unload(padapter);
-       mutex_unlock(&pwrpriv->mutex_lock);
-
-       if (check_fwstate(pmlmepriv, _FW_UNDER_SURVEY))
-               rtw_cfg80211_indicate_scan_done(
-                       wdev_to_priv(padapter->rtw_wdev), true);
-
-       if (check_fwstate(pmlmepriv, _FW_UNDER_LINKING))
-               rtw_indicate_disconnect23a(padapter);
-
-exit:
-       DBG_8723A("<===  %s return %d.............. in %dms\n", __func__,
-                 ret, jiffies_to_msecs(jiffies - start_time));
-
-       return ret;
-}
-
-static int rtw_resume(struct usb_interface *pusb_intf)
-{
-       struct dvobj_priv *dvobj = usb_get_intfdata(pusb_intf);
-       struct rtw_adapter *padapter = dvobj->if1;
-       struct net_device *pnetdev;
-       struct pwrctrl_priv *pwrpriv = NULL;
-       int ret = -1;
-       unsigned long start_time = jiffies;
-
-       DBG_8723A("==> %s (%s:%d)\n", __func__, current->comm, current->pid);
-
-       if (!padapter)
-               goto exit;
-       pnetdev = padapter->pnetdev;
-       pwrpriv = &padapter->pwrctrlpriv;
-
-       mutex_lock(&pwrpriv->mutex_lock);
-       rtw_reset_drv_sw23a(padapter);
-       pwrpriv->bkeepfwalive = false;
-
-       DBG_8723A("bkeepfwalive(%x)\n", pwrpriv->bkeepfwalive);
-       if (pm_netdev_open23a(pnetdev, true) != 0) {
-               mutex_unlock(&pwrpriv->mutex_lock);
-               goto exit;
-       }
-
-       netif_device_attach(pnetdev);
-       netif_carrier_on(pnetdev);
-
-       mutex_unlock(&pwrpriv->mutex_lock);
-
-       if (padapter->pid[1] != 0) {
-               DBG_8723A("pid[1]:%d\n", padapter->pid[1]);
-               kill_pid(find_vpid(padapter->pid[1]), SIGUSR2, 1);
-       }
-
-       rtw23a_roaming(padapter, NULL);
-
-       ret = 0;
-exit:
-       if (pwrpriv)
-               pwrpriv->bInSuspend = false;
-       DBG_8723A("<===  %s return %d.............. in %dms\n", __func__,
-                 ret, jiffies_to_msecs(jiffies - start_time));
-
-       return ret;
-}
-
-/*
- * drv_init() - a device potentially for us
- *
- * notes: drv_init() is called when the bus driver has located a card
- * for us to support.
- *        We accept the new device by returning 0.
- */
-static struct rtw_adapter *rtw_usb_if1_init(struct dvobj_priv *dvobj,
-                                           struct usb_interface *pusb_intf,
-                                           const struct usb_device_id *pdid)
-{
-       struct rtw_adapter *padapter = NULL;
-       struct net_device *pnetdev = NULL;
-       int status = _FAIL;
-
-       pnetdev = rtw_init_netdev23a(padapter);
-       if (!pnetdev)
-               goto free_adapter;
-       padapter = netdev_priv(pnetdev);
-
-       padapter->dvobj = dvobj;
-       padapter->bDriverStopped = true;
-       dvobj->if1 = padapter;
-       dvobj->padapters[dvobj->iface_nums++] = padapter;
-       padapter->iface_id = IFACE_ID0;
-
-       rtl8723au_set_hw_type(padapter);
-
-       SET_NETDEV_DEV(pnetdev, dvobj_to_dev(dvobj));
-
-       if (rtw_wdev_alloc(padapter, dvobj_to_dev(dvobj)))
-               goto free_adapter;
-
-       /* step 2. allocate HalData */
-       padapter->HalData = kzalloc(sizeof(struct hal_data_8723a), GFP_KERNEL);
-       if (!padapter->HalData)
-               goto free_wdev;
-
-       /* step read_chip_version */
-       rtl8723a_read_chip_version(padapter);
-
-       /* step usb endpoint mapping */
-       if (!rtl8723au_chip_configure(padapter))
-               goto free_hal_data;
-
-       /* step read efuse/eeprom data and get mac_addr */
-       rtl8723a_read_adapter_info(padapter);
-
-       /* step 5. */
-       if (rtw_init_drv_sw23a(padapter) == _FAIL) {
-               RT_TRACE(_module_hci_intfs_c_, _drv_err_,
-                        "Initialize driver software resource Failed!\n");
-               goto free_hal_data;
-       }
-
-#ifdef CONFIG_PM
-       if (padapter->pwrctrlpriv.bSupportRemoteWakeup) {
-               dvobj->pusbdev->do_remote_wakeup = 1;
-               pusb_intf->needs_remote_wakeup = 1;
-               device_init_wakeup(&pusb_intf->dev, 1);
-               DBG_8723A("\n  padapter->pwrctrlpriv.bSupportRemoteWakeup~~~~~~\n");
-               DBG_8723A("\n  padapter->pwrctrlpriv.bSupportRemoteWakeup~~~[%d]~~~\n",
-                         device_may_wakeup(&pusb_intf->dev));
-       }
-#endif
-       /* 2012-07-11 Move here to prevent the 8723AS-VAU BT
-        * auto suspend influence
-        */
-       if (usb_autopm_get_interface(pusb_intf) < 0)
-               DBG_8723A("can't get autopm:\n");
-#ifdef CONFIG_8723AU_BT_COEXIST
-       padapter->pwrctrlpriv.autopm_cnt = 1;
-#endif
-
-       /* If the eeprom mac address is corrupted, assign a random address */
-       if (is_broadcast_ether_addr(padapter->eeprompriv.mac_addr) ||
-           is_zero_ether_addr(padapter->eeprompriv.mac_addr))
-               eth_random_addr(padapter->eeprompriv.mac_addr);
-
-       DBG_8723A("bDriverStopped:%d, bSurpriseRemoved:%d, bup:%d, hw_init_completed:%d\n",
-                 padapter->bDriverStopped, padapter->bSurpriseRemoved,
-                 padapter->bup, padapter->hw_init_completed
-       );
-       status = _SUCCESS;
-
-free_hal_data:
-       if (status != _SUCCESS)
-               kfree(padapter->HalData);
-free_wdev:
-       if (status != _SUCCESS) {
-               rtw_wdev_unregister(padapter->rtw_wdev);
-               rtw_wdev_free(padapter->rtw_wdev);
-       }
-free_adapter:
-       if (status != _SUCCESS) {
-               if (pnetdev)
-                       free_netdev(pnetdev);
-               padapter = NULL;
-       }
-       return padapter;
-}
-
-static void rtw_usb_if1_deinit(struct rtw_adapter *if1)
-{
-       struct net_device *pnetdev = if1->pnetdev;
-       struct mlme_priv *pmlmepriv = &if1->mlmepriv;
-
-       if (check_fwstate(pmlmepriv, _FW_LINKED))
-               rtw_disassoc_cmd23a(if1, 0, false);
-
-#ifdef CONFIG_8723AU_AP_MODE
-       free_mlme_ap_info23a(if1);
-#endif
-
-       if (pnetdev)
-               unregister_netdev(pnetdev); /* will call netdev_close() */
-
-       rtw_cancel_all_timer23a(if1);
-
-       rtw_dev_unload(if1);
-
-       DBG_8723A("+r871xu_dev_remove, hw_init_completed =%d\n",
-                 if1->hw_init_completed);
-
-       if (if1->rtw_wdev) {
-               rtw_wdev_unregister(if1->rtw_wdev);
-               rtw_wdev_free(if1->rtw_wdev);
-       }
-
-#ifdef CONFIG_8723AU_BT_COEXIST
-       if (1 == if1->pwrctrlpriv.autopm_cnt) {
-               usb_autopm_put_interface(adapter_to_dvobj(if1)->pusbintf);
-               if1->pwrctrlpriv.autopm_cnt--;
-       }
-#endif
-
-       rtw_free_drv_sw23a(if1);
-
-       if (pnetdev)
-               free_netdev(pnetdev);
-}
-
-static int rtw_drv_init(struct usb_interface *pusb_intf,
-                       const struct usb_device_id *pdid)
-{
-       struct rtw_adapter *if1 = NULL;
-       struct dvobj_priv *dvobj;
-       struct usb_device *udev;
-       int status = _FAIL;
-
-       RT_TRACE(_module_hci_intfs_c_, _drv_err_, "+rtw_drv_init\n");
-
-       /* Initialize dvobj_priv */
-       dvobj = usb_dvobj_init(pusb_intf);
-       if (!dvobj) {
-               RT_TRACE(_module_hci_intfs_c_, _drv_err_,
-                        "initialize device object priv Failed!\n");
-               goto exit;
-       }
-
-       udev = dvobj->pusbdev;
-       dev_warn(&udev->dev, "WARNING: The rtl8723au driver is deprecated!");
-       dev_warn(&udev->dev, "Please use the rtl8xxxu driver for this device!");
-
-       if1 = rtw_usb_if1_init(dvobj, pusb_intf, pdid);
-       if (!if1) {
-               DBG_8723A("rtw_init_primary_adapter Failed!\n");
-               goto free_dvobj;
-       }
-
-       /* dev_alloc_name && register_netdev */
-       status = rtw_drv_register_netdev(if1);
-       if (status != _SUCCESS)
-               goto free_if1;
-       RT_TRACE(_module_hci_intfs_c_, _drv_err_,
-                "-871x_drv - drv_init, success!\n");
-
-       status = _SUCCESS;
-
-free_if1:
-       if (status != _SUCCESS && if1)
-               rtw_usb_if1_deinit(if1);
-free_dvobj:
-       if (status != _SUCCESS)
-               usb_dvobj_deinit(pusb_intf);
-exit:
-       return status == _SUCCESS ? 0 : -ENODEV;
-}
-
-/* dev_remove() - our device is being removed */
-static void rtw_disconnect(struct usb_interface *pusb_intf)
-{
-       struct dvobj_priv *dvobj;
-       struct rtw_adapter *padapter;
-       struct net_device *pnetdev;
-       struct mlme_priv *pmlmepriv;
-
-       dvobj = usb_get_intfdata(pusb_intf);
-       if (!dvobj)
-               return;
-
-       padapter = dvobj->if1;
-       pnetdev = padapter->pnetdev;
-       pmlmepriv = &padapter->mlmepriv;
-
-       usb_set_intfdata(pusb_intf, NULL);
-
-       RT_TRACE(_module_hci_intfs_c_, _drv_err_, "+dev_remove()\n");
-
-       rtw_pm_set_ips23a(padapter, IPS_NONE);
-       rtw_pm_set_lps23a(padapter, PS_MODE_ACTIVE);
-
-       LeaveAllPowerSaveMode23a(padapter);
-
-       rtw_usb_if1_deinit(padapter);
-
-       usb_dvobj_deinit(pusb_intf);
-
-       RT_TRACE(_module_hci_intfs_c_, _drv_err_, "-dev_remove()\n");
-       DBG_8723A("-r871xu_dev_remove, done\n");
-}
-
-static int __init rtw_drv_entry(void)
-{
-       RT_TRACE(_module_hci_intfs_c_, _drv_err_, "+rtw_drv_entry\n");
-       return usb_register(usb_drv);
-}
-
-static void __exit rtw_drv_halt(void)
-{
-       RT_TRACE(_module_hci_intfs_c_, _drv_err_, "+rtw_drv_halt\n");
-       DBG_8723A("+rtw_drv_halt\n");
-
-       usb_deregister(usb_drv);
-
-       DBG_8723A("-rtw_drv_halt\n");
-}
-
-module_init(rtw_drv_entry);
-module_exit(rtw_drv_halt);
diff --git a/drivers/staging/rtl8723au/os_dep/usb_ops_linux.c b/drivers/staging/rtl8723au/os_dep/usb_ops_linux.c
deleted file mode 100644 (file)
index cf4a506..0000000
+++ /dev/null
@@ -1,233 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#define _USB_OPS_LINUX_C_
-
-#include <drv_types.h>
-#include <usb_ops_linux.h>
-#include <rtw_sreset.h>
-
-void rtl8723au_read_port_cancel(struct rtw_adapter *padapter)
-{
-       struct recv_buf *precvbuf;
-       int i;
-
-       precvbuf = (struct recv_buf *)padapter->recvpriv.precv_buf;
-
-       DBG_8723A("%s\n", __func__);
-
-       padapter->bReadPortCancel = true;
-
-       for (i = 0; i < NR_RECVBUFF ; i++) {
-               if (precvbuf->purb)
-                       usb_kill_urb(precvbuf->purb);
-               precvbuf++;
-       }
-       usb_kill_urb(padapter->recvpriv.int_in_urb);
-}
-
-static void usb_write_port23a_complete(struct urb *purb)
-{
-       struct xmit_buf *pxmitbuf = (struct xmit_buf *)purb->context;
-       struct rtw_adapter *padapter = pxmitbuf->padapter;
-       struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-       struct hal_data_8723a *phaldata;
-       unsigned long irqL;
-
-       switch (pxmitbuf->flags) {
-       case HIGH_QUEUE_INX:
-#ifdef CONFIG_8723AU_AP_MODE
-               rtw_chk_hi_queue_cmd23a(padapter);
-#endif
-               break;
-       default:
-               break;
-       }
-
-       if (padapter->bSurpriseRemoved || padapter->bDriverStopped ||
-           padapter->bWritePortCancel) {
-               RT_TRACE(_module_hci_ops_os_c_, _drv_err_,
-                        "usb_write_port23a_complete:bDriverStopped(%d) OR bSurpriseRemoved(%d)\n",
-                        padapter->bDriverStopped, padapter->bSurpriseRemoved);
-               DBG_8723A("%s(): TX Warning! bDriverStopped(%d) OR "
-                         "bSurpriseRemoved(%d) bWritePortCancel(%d) "
-                         "pxmitbuf->ext_tag(%x)\n", __func__,
-                         padapter->bDriverStopped, padapter->bSurpriseRemoved,
-                         padapter->bReadPortCancel, pxmitbuf->ext_tag);
-
-               goto check_completion;
-       }
-
-       if (purb->status) {
-               RT_TRACE(_module_hci_ops_os_c_, _drv_err_,
-                        "usb_write_port23a_complete : purb->status(%d) != 0\n",
-                        purb->status);
-               DBG_8723A("###=> urb_write_port_complete status(%d)\n",
-                         purb->status);
-               if (purb->status == -EPIPE || purb->status == -EPROTO) {
-               } else if (purb->status == -EINPROGRESS) {
-                       RT_TRACE(_module_hci_ops_os_c_, _drv_err_,
-                                "usb_write_port23a_complete: EINPROGESS\n");
-                       goto check_completion;
-               } else if (purb->status == -ENOENT) {
-                       DBG_8723A("%s: -ENOENT\n", __func__);
-                       goto check_completion;
-               } else if (purb->status == -ECONNRESET) {
-                       DBG_8723A("%s: -ECONNRESET\n", __func__);
-                       goto check_completion;
-               } else if (purb->status == -ESHUTDOWN) {
-                       RT_TRACE(_module_hci_ops_os_c_, _drv_err_,
-                                "usb_write_port23a_complete: ESHUTDOWN\n");
-                       padapter->bDriverStopped = true;
-                       RT_TRACE(_module_hci_ops_os_c_, _drv_err_,
-                                "usb_write_port23a_complete:bDriverStopped = true\n");
-                       goto check_completion;
-               } else {
-                       padapter->bSurpriseRemoved = true;
-                       DBG_8723A("bSurpriseRemoved = true\n");
-                       RT_TRACE(_module_hci_ops_os_c_, _drv_err_,
-                                "usb_write_port23a_complete:bSurpriseRemoved = true\n");
-                       goto check_completion;
-               }
-       }
-       phaldata = GET_HAL_DATA(padapter);
-       phaldata->srestpriv.last_tx_complete_time = jiffies;
-
-check_completion:
-       spin_lock_irqsave(&pxmitpriv->lock_sctx, irqL);
-       rtw23a_sctx_done_err(&pxmitbuf->sctx,
-                            purb->status ? RTW_SCTX_DONE_WRITE_PORT_ERR :
-                            RTW_SCTX_DONE_SUCCESS);
-       spin_unlock_irqrestore(&pxmitpriv->lock_sctx, irqL);
-
-       rtw_free_xmitbuf23a(pxmitpriv, pxmitbuf);
-
-       tasklet_hi_schedule(&pxmitpriv->xmit_tasklet);
-}
-
-int rtl8723au_write_port(struct rtw_adapter *padapter, u32 addr, u32 cnt,
-                        struct xmit_buf *pxmitbuf)
-{
-       struct urb *purb = NULL;
-       struct dvobj_priv *pdvobj = adapter_to_dvobj(padapter);
-       struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-       struct xmit_frame *pxmitframe;
-       struct usb_device *pusbd = pdvobj->pusbdev;
-       unsigned long irqL;
-       unsigned int pipe, ep_num;
-       int status;
-       int ret = _FAIL;
-
-       RT_TRACE(_module_hci_ops_os_c_, _drv_err_, "+usb_write_port23a\n");
-
-       if (padapter->bDriverStopped || padapter->bSurpriseRemoved) {
-               RT_TRACE(_module_hci_ops_os_c_, _drv_err_,
-                        "%s:(padapter->bDriverStopped || padapter->bSurpriseRemoved)!!!\n",
-                        __func__);
-               rtw23a_sctx_done_err(&pxmitbuf->sctx, RTW_SCTX_DONE_TX_DENY);
-               goto exit;
-       }
-
-       pxmitframe = (struct xmit_frame *)pxmitbuf->priv_data;
-       spin_lock_irqsave(&pxmitpriv->lock, irqL);
-
-       switch (addr) {
-       case VO_QUEUE_INX:
-               pxmitbuf->flags = VO_QUEUE_INX;
-               break;
-       case VI_QUEUE_INX:
-               pxmitbuf->flags = VI_QUEUE_INX;
-               break;
-       case BE_QUEUE_INX:
-               pxmitbuf->flags = BE_QUEUE_INX;
-               break;
-       case BK_QUEUE_INX:
-               pxmitbuf->flags = BK_QUEUE_INX;
-               break;
-       case HIGH_QUEUE_INX:
-               pxmitbuf->flags = HIGH_QUEUE_INX;
-               break;
-       default:
-               pxmitbuf->flags = MGT_QUEUE_INX;
-               break;
-       }
-
-       spin_unlock_irqrestore(&pxmitpriv->lock, irqL);
-
-       purb = pxmitbuf->pxmit_urb[0];
-
-       /* translate DMA FIFO addr to pipehandle */
-       ep_num = pdvobj->Queue2Pipe[addr];
-       pipe = usb_sndbulkpipe(pusbd, ep_num);
-
-       usb_fill_bulk_urb(purb, pusbd, pipe,
-                         pxmitframe->buf_addr, /*  pxmitbuf->pbuf */
-                         cnt, usb_write_port23a_complete,
-                         pxmitbuf);/* context is pxmitbuf */
-
-       status = usb_submit_urb(purb, GFP_ATOMIC);
-       if (!status) {
-               struct hal_data_8723a *phaldata = GET_HAL_DATA(padapter);
-               phaldata->srestpriv.last_tx_time = jiffies;
-       } else {
-               rtw23a_sctx_done_err(&pxmitbuf->sctx,
-                                    RTW_SCTX_DONE_WRITE_PORT_ERR);
-               DBG_8723A("usb_write_port23a, status =%d\n", status);
-               RT_TRACE(_module_hci_ops_os_c_, _drv_err_,
-                        "usb_write_port23a(): usb_submit_urb, status =%x\n",
-                        status);
-
-               switch (status) {
-               case -ENODEV:
-                       padapter->bDriverStopped = true;
-                       break;
-               default:
-                       break;
-               }
-               goto exit;
-       }
-       ret = _SUCCESS;
-       RT_TRACE(_module_hci_ops_os_c_, _drv_err_, "-usb_write_port23a\n");
-
-exit:
-       if (ret != _SUCCESS)
-               rtw_free_xmitbuf23a(pxmitpriv, pxmitbuf);
-
-       return ret;
-}
-
-void rtl8723au_write_port_cancel(struct rtw_adapter *padapter)
-{
-       struct xmit_buf *pxmitbuf;
-       int j;
-
-       DBG_8723A("%s\n", __func__);
-
-       padapter->bWritePortCancel = true;
-
-       list_for_each_entry(pxmitbuf, &padapter->xmitpriv.xmitbuf_list,
-                           list2) {
-               for (j = 0; j < 8; j++) {
-                       if (pxmitbuf->pxmit_urb[j])
-                               usb_kill_urb(pxmitbuf->pxmit_urb[j]);
-               }
-       }
-       list_for_each_entry(pxmitbuf, &padapter->xmitpriv.xmitextbuf_list,
-                           list2) {
-               for (j = 0; j < 8; j++) {
-                       if (pxmitbuf->pxmit_urb[j])
-                               usb_kill_urb(pxmitbuf->pxmit_urb[j]);
-               }
-       }
-}
diff --git a/drivers/staging/rtl8723au/os_dep/xmit_linux.c b/drivers/staging/rtl8723au/os_dep/xmit_linux.c
deleted file mode 100644 (file)
index 64be72a..0000000
+++ /dev/null
@@ -1,154 +0,0 @@
-/******************************************************************************
- *
- * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- ******************************************************************************/
-#define _XMIT_OSDEP_C_
-
-#include <osdep_service.h>
-#include <drv_types.h>
-
-#include <linux/if_ether.h>
-#include <linux/ip.h>
-#include <wifi.h>
-#include <mlme_osdep.h>
-#include <xmit_osdep.h>
-#include <osdep_intf.h>
-
-int rtw_os_xmit_resource_alloc23a(struct rtw_adapter *padapter,
-                              struct xmit_buf *pxmitbuf, u32 alloc_sz)
-{
-       int i;
-
-       pxmitbuf->pallocated_buf = kzalloc(alloc_sz, GFP_KERNEL);
-       if (pxmitbuf->pallocated_buf == NULL)
-               return _FAIL;
-
-       pxmitbuf->pbuf = PTR_ALIGN(pxmitbuf->pallocated_buf, XMITBUF_ALIGN_SZ);
-
-       for (i = 0; i < 8; i++) {
-               pxmitbuf->pxmit_urb[i] = usb_alloc_urb(0, GFP_KERNEL);
-               if (!pxmitbuf->pxmit_urb[i]) {
-                       DBG_8723A("pxmitbuf->pxmit_urb[i]==NULL");
-                       return _FAIL;
-               }
-       }
-       return _SUCCESS;
-}
-
-void rtw_os_xmit_resource_free23a(struct rtw_adapter *padapter,
-                              struct xmit_buf *pxmitbuf)
-{
-       int i;
-
-       for (i = 0; i < 8; i++)
-               usb_free_urb(pxmitbuf->pxmit_urb[i]);
-       kfree(pxmitbuf->pallocated_buf);
-}
-
-#define WMM_XMIT_THRESHOLD     (NR_XMITFRAME*2/5)
-
-void rtw_os_pkt_complete23a(struct rtw_adapter *padapter, struct sk_buff *pkt)
-{
-       struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-       u16     queue;
-
-       queue = skb_get_queue_mapping(pkt);
-       if (padapter->registrypriv.wifi_spec) {
-               if (__netif_subqueue_stopped(padapter->pnetdev, queue) &&
-                   (pxmitpriv->hwxmits[queue].accnt < WMM_XMIT_THRESHOLD))
-                       netif_wake_subqueue(padapter->pnetdev, queue);
-       } else {
-               if (__netif_subqueue_stopped(padapter->pnetdev, queue))
-                       netif_wake_subqueue(padapter->pnetdev, queue);
-       }
-       dev_kfree_skb_any(pkt);
-}
-
-void rtw_os_xmit_complete23a(struct rtw_adapter *padapter,
-                         struct xmit_frame *pxframe)
-{
-       if (pxframe->pkt)
-               rtw_os_pkt_complete23a(padapter, pxframe->pkt);
-
-       pxframe->pkt = NULL;
-}
-
-void rtw_os_xmit_schedule23a(struct rtw_adapter *padapter)
-{
-       struct xmit_priv *pxmitpriv;
-
-       if (!padapter)
-               return;
-       pxmitpriv = &padapter->xmitpriv;
-
-       spin_lock_bh(&pxmitpriv->lock);
-
-       if (rtw_txframes_pending23a(padapter))
-               tasklet_hi_schedule(&pxmitpriv->xmit_tasklet);
-       spin_unlock_bh(&pxmitpriv->lock);
-}
-
-static void rtw_check_xmit_resource(struct rtw_adapter *padapter,
-                                   struct sk_buff *pkt)
-{
-       struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-       u16     queue;
-
-       queue = skb_get_queue_mapping(pkt);
-       if (padapter->registrypriv.wifi_spec) {
-               /* No free space for Tx, tx_worker is too slow */
-               if (pxmitpriv->hwxmits[queue].accnt > WMM_XMIT_THRESHOLD)
-                       netif_stop_subqueue(padapter->pnetdev, queue);
-       } else {
-               if (pxmitpriv->free_xmitframe_cnt <= 4) {
-                       if (!netif_tx_queue_stopped(netdev_get_tx_queue(padapter->pnetdev, queue)))
-                               netif_stop_subqueue(padapter->pnetdev, queue);
-               }
-       }
-}
-
-int rtw_xmit23a_entry23a(struct sk_buff *skb, struct net_device *pnetdev)
-{
-       struct rtw_adapter *padapter = netdev_priv(pnetdev);
-       struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
-       int res = 0;
-
-       RT_TRACE(_module_rtl871x_mlme_c_, _drv_info_, "+xmit_enry\n");
-
-       if (!rtw_if_up23a(padapter)) {
-               RT_TRACE(_module_xmit_osdep_c_, _drv_err_,
-                        "rtw_xmit23a_entry23a: rtw_if_up23a fail\n");
-               goto drop_packet;
-       }
-
-       rtw_check_xmit_resource(padapter, skb);
-
-       res = rtw_xmit23a(padapter, skb);
-       if (res < 0)
-               goto drop_packet;
-
-       pxmitpriv->tx_pkts++;
-       RT_TRACE(_module_xmit_osdep_c_, _drv_info_,
-                "rtw_xmit23a_entry23a: tx_pkts=%d\n",
-                (u32)pxmitpriv->tx_pkts);
-       goto exit;
-
-drop_packet:
-       pxmitpriv->tx_drop++;
-       dev_kfree_skb_any(skb);
-       RT_TRACE(_module_xmit_osdep_c_, _drv_notice_,
-                "rtw_xmit23a_entry23a: drop, tx_drop=%d\n",
-                (u32)pxmitpriv->tx_drop);
-exit:
-       return 0;
-}